1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
#include "symbol.h"
#include "target.h"
#include "machine.h"
static void init_riscv(const struct target *self)
{
if (arch_cmodel == CMODEL_UNKNOWN)
arch_cmodel = CMODEL_MEDLOW;
if (fpic)
arch_cmodel = CMODEL_PIC;
}
static void predefine_riscv(const struct target *self)
{
static const char *cmodels[CMODEL_LAST] = {
[CMODEL_MEDANY] = "medany",
[CMODEL_MEDLOW] = "medlow",
[CMODEL_PIC] = "pic",
};
const char *cmodel = cmodels[arch_cmodel];
predefine("__riscv", 1, "1");
predefine("__riscv_xlen", 1, "%d", ptr_ctype.bit_size);
if (cmodel)
predefine_strong("__riscv_cmodel_%s", cmodel);
}
const struct target target_riscv32 = {
.mach = MACH_RISCV32,
.bitness = ARCH_LP32,
.big_endian = 0,
.unsigned_char = 1,
.target_64bit = &target_riscv64,
.init = init_riscv,
.predefine = predefine_riscv,
};
const struct target target_riscv64 = {
.mach = MACH_RISCV64,
.bitness = ARCH_LP64,
.big_endian = 0,
.unsigned_char = 1,
.has_int128 = 1,
.target_32bit = &target_riscv32,
.init = init_riscv,
.predefine = predefine_riscv,
};
|