aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/target-mips.c
diff options
context:
space:
mode:
Diffstat (limited to 'target-mips.c')
-rw-r--r--target-mips.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/target-mips.c b/target-mips.c
new file mode 100644
index 00000000..3d73236f
--- /dev/null
+++ b/target-mips.c
@@ -0,0 +1,53 @@
+#include "symbol.h"
+#include "target.h"
+#include "machine.h"
+
+
+static void predefine_mips(const struct target *self)
+{
+ predefine("__mips__", 1, "1");
+ predefine("__mips", 1, "%d", ptr_ctype.bit_size);
+ predefine("_MIPS_SZINT", 1, "%d", int_ctype.bit_size);
+ predefine("_MIPS_SZLONG", 1, "%d", long_ctype.bit_size);
+ predefine("_MIPS_SZPTR", 1, "%d", ptr_ctype.bit_size);
+}
+
+
+static void predefine_mips32(const struct target *self)
+{
+ predefine_mips(self);
+}
+
+const struct target target_mips32 = {
+ .mach = MACH_MIPS32,
+ .bitness = ARCH_LP32,
+ .big_endian = 1,
+ .unsigned_char = 0,
+
+ .bits_in_longdouble = 64,
+ .max_fp_alignment = 8,
+
+ .target_64bit = &target_mips64,
+
+ .predefine = predefine_mips32,
+};
+
+
+static void predefine_mips64(const struct target *self)
+{
+ predefine("__mips64", 1, "64");
+
+ predefine_mips(self);
+}
+
+const struct target target_mips64 = {
+ .mach = MACH_MIPS64,
+ .bitness = ARCH_LP64,
+ .big_endian = 1,
+ .unsigned_char = 0,
+ .has_int128 = 1,
+
+ .target_32bit = &target_mips32,
+
+ .predefine = predefine_mips64,
+};