From 754bbf7a25a8dda49b5d08ef0d0443bbf5af0e36 Mon Sep 17 00:00:00 2001 From: Craig Jennings Date: Sun, 7 Apr 2024 13:41:34 -0500 Subject: new repository --- devdocs/gcc~13/risc-v-function-attributes.html | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 devdocs/gcc~13/risc-v-function-attributes.html (limited to 'devdocs/gcc~13/risc-v-function-attributes.html') diff --git a/devdocs/gcc~13/risc-v-function-attributes.html b/devdocs/gcc~13/risc-v-function-attributes.html new file mode 100644 index 00000000..449d159c --- /dev/null +++ b/devdocs/gcc~13/risc-v-function-attributes.html @@ -0,0 +1,14 @@ +

6.33.25 RISC-V Function Attributes

These function attributes are supported by the RISC-V back end:

+naked +
+

This attribute allows the compiler to construct the requisite function declaration, while allowing the body of the function to be assembly code. The specified function will not have prologue/epilogue sequences generated by the compiler. Only basic asm statements can safely be included in naked functions (see Basic Asm — Assembler Instructions Without Operands). While using extended asm or a mixture of basic asm and C code may appear to work, they cannot be depended upon to work reliably and are not supported.

+interrupt +
+

Use this attribute to indicate that the specified function is an interrupt handler. The compiler generates function entry and exit sequences suitable for use in an interrupt handler when this attribute is present.

You can specify the kind of interrupt to be handled by adding an optional parameter to the interrupt attribute like this:

void f (void) __attribute__ ((interrupt ("user")));
+

Permissible values for this parameter are user, supervisor, and machine. If there is no parameter, then it defaults to machine.

+
+

+ © Free Software Foundation
Licensed under the GNU Free Documentation License, Version 1.3.
+ https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/RISC-V-Function-Attributes.html +

+
-- cgit v1.2.3