[PATCH] D159317: [clang][Docs] Document X86 interrupt attribute
Antonio Abbatangelo via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Aug 31 16:12:20 PDT 2023
antangelo created this revision.
antangelo added reviewers: pengfei, aaron.ballman.
Herald added a project: All.
antangelo requested review of this revision.
Herald added a project: clang.
Herald added a subscriber: cfe-commits.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D159317
Files:
clang/include/clang/Basic/Attr.td
clang/include/clang/Basic/AttrDocs.td
Index: clang/include/clang/Basic/AttrDocs.td
===================================================================
--- clang/include/clang/Basic/AttrDocs.td
+++ clang/include/clang/Basic/AttrDocs.td
@@ -4801,6 +4801,54 @@
}];
}
+def AnyX86InterruptDocs : Documentation {
+ let Category = DocCatFunction;
+ let Heading = "interrupt (X86)";
+ let Content = [{
+Clang supports the GNU style ``__attribute__((interrupt))`` attribute on X86
+targets. This attribute may be attached to a function definition and instructs
+the backend to generate appropriate function entry/exit code so that it can be
+used directly as an interrupt service routine.
+
+Interrupt handlers have access to the stack frame pushed onto the stack by the processor,
+and return using the ``IRET`` instruction. All registers in an interrupt handler are callee-saved.
+Exception handlers also have access to the error code pushed onto the stack by the processor,
+when applicable.
+
+An interrupt handler must take the following arguments:
+
+ .. code-block:: c
+
+ __attribute__ ((interrupt))
+ void f (struct stack_frame *frame) {
+ ...
+ }
+
+ Where ``struct stack_frame`` is a suitable struct matching the stack frame pushed by the
+ processor.
+
+An exception handler must take the following arguments:
+
+ .. code-block:: c
+
+ __attribute__ ((interrupt))
+ void g (struct stack_frame *frame, unsigned long code) {
+ ...
+ }
+
+ On 32-bit targets, the ``code`` argument should be of type ``unsigned int``.
+
+Exception handlers should only be used when an error code is pushed by the processor.
+Using the incorrect handler type will crash the system.
+
+Interrupt and exception handlers cannot be called by other functions and must have return type ``void``.
+
+Interrupt and exception handlers should only call functions with the 'no_caller_saved_registers'
+attribute, or should be compiled with the '-mgeneral-regs-only' flag to avoid saving unused
+non-GPR registers.
+ }];
+}
+
def AnyX86NoCallerSavedRegistersDocs : Documentation {
let Category = DocCatFunction;
let Content = [{
Index: clang/include/clang/Basic/Attr.td
===================================================================
--- clang/include/clang/Basic/Attr.td
+++ clang/include/clang/Basic/Attr.td
@@ -3113,7 +3113,7 @@
let Subjects = SubjectList<[HasFunctionProto]>;
let ParseKind = "Interrupt";
let HasCustomParsing = 1;
- let Documentation = [Undocumented];
+ let Documentation = [AnyX86InterruptDocs];
}
def AnyX86NoCallerSavedRegisters : InheritableAttr,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D159317.555177.patch
Type: text/x-patch
Size: 2576 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20230831/1bb4c2d6/attachment.bin>
More information about the cfe-commits
mailing list