aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/target-nios2.c
diff options
context:
space:
mode:
Diffstat (limited to 'target-nios2.c')
-rw-r--r--target-nios2.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/target-nios2.c b/target-nios2.c
new file mode 100644
index 00000000..05f0926e
--- /dev/null
+++ b/target-nios2.c
@@ -0,0 +1,31 @@
+#include "symbol.h"
+#include "target.h"
+#include "machine.h"
+#include "builtin.h"
+
+
+static void predefine_nios2(const struct target *self)
+{
+ predefine("__NIOS2__", 1, "1");
+ predefine("__nios2__", 1, "1");
+
+ if (arch_big_endian)
+ predefine("__nios2_big_endian__", 1, "1");
+ else
+ predefine("__nios2_little_endian__", 1, "1");
+}
+
+static const struct builtin_fn builtins_nios2[] = {
+ { "__builtin_rdctl", &int_ctype, 0, { &int_ctype }},
+ { "__builtin_wrctl", &void_ctype, 0, { &int_ctype, &int_ctype }},
+ { "__builtin_custom_ini", &int_ctype, 0, { &int_ctype }},
+ { }
+};
+
+const struct target target_nios2 = {
+ .mach = MACH_NIOS2,
+ .bitness = ARCH_LP32,
+
+ .predefine = predefine_nios2,
+ .builtins = builtins_nios2,
+};