summaryrefslogtreecommitdiff
path: root/risc-v/hgen/lexer.hgen
blob: 1888d42b3d444d776d15abf0d049f6c80e5e96f7 (plain)
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
54
55
56
57
58
59
60
61
"lwu"   , UTYPE { op=RISCVLUI   };
"auipc" , UTYPE { op=RISCVAUIPC };

"jal",  JAL ();
"jalr", JALR ();

"beq",  BTYPE {op=RISCVBEQ};
"bne",  BTYPE {op=RISCVBNE};
"blt",  BTYPE {op=RISCVBLT};
"bge",  BTYPE {op=RISCVBGE};
"bltu", BTYPE {op=RISCVBLTU};
"bgeu", BTYPE {op=RISCVBGEU};

"addi",  ITYPE {op=RISCVADDI};
"stli",  ITYPE {op=RISCVSLTI};
"sltiu", ITYPE {op=RISCVSLTIU};
"xori",  ITYPE {op=RISCVXORI};
"ori",   ITYPE {op=RISCVORI};
"andi",  ITYPE {op=RISCVANDI};

"slli", SHIFTIOP{op=RISCVSLLI};
"srli", SHIFTIOP{op=RISCVSRLI};
"srai", SHIFTIOP{op=RISCVSRAI};

"add",  RTYPE{op=RISCVADD};
"sub",  RTYPE{op=RISCVSUB};
"sll",  RTYPE{op=RISCVSLL};
"slt",  RTYPE{op=RISCVSLT};
"sltu", RTYPE{op=RISCVSLT};
"xor",  RTYPE{op=RISCVXOR};
"srl",  RTYPE{op=RISCVSRL};
"sra",  RTYPE{op=RISCVSRA};
"or",   RTYPE{op=RISCVOR};
"and",  RTYPE{op=RISCVAND};

"lb",  LOAD{unsigned=false; width=RISCVBYTE};
"lbu", LOAD{unsigned=true;  width=RISCVBYTE};
"lh",  LOAD{unsigned=false; width=RISCVHALF};
"lhu", LOAD{unsigned=true;  width=RISCVHALF};
"lw",  LOAD{unsigned=false; width=RISCVWORD};
"lwu", LOAD{unsigned=true;  width=RISCVWORD};
"ld",  LOAD{unsigned=false; width=RISCVDOUBLE};

"sb", STORE{width=RISCVBYTE};
"sh", STORE{width=RISCVHALF};
"sw", STORE{width=RISCVWORD};
"sd", STORE{width=RISCVDOUBLE};

"addiw", ADDIW ();

"slliw", SHIFTW{op=RISCVSLLI};
"srliw", SHIFTW{op=RISCVSRLI};
"sraiw", SHIFTW{op=RISCVSRAI};

"addw", RTYPEW{op=RISCVADDW};
"subw", RTYPEW{op=RISCVSUBW};
"sslw", RTYPEW{op=RISCVSLLW};
"srlw", RTYPEW{op=RISCVSRLW};
"sraw", RTYPEW{op=RISCVSRAW};

"fence", FENCE ();