From: Misha Brukman Date: Sat, 31 May 2003 06:25:19 +0000 (+0000) Subject: The 'rd' register is consistently mentioned last in instruction definitions. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=33cc12319c02c4be933222f2ed5145d3c80718fd;p=llvm The 'rd' register is consistently mentioned last in instruction definitions. Created new classes from which instructions inherit their ordering of fields. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6461 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/SparcV9/SparcV9_F3.td b/lib/Target/SparcV9/SparcV9_F3.td index 5083dad70ed..ae8d06b33dd 100644 --- a/lib/Target/SparcV9/SparcV9_F3.td +++ b/lib/Target/SparcV9/SparcV9_F3.td @@ -74,6 +74,18 @@ class F3_rs1simm13rd : F3_rs1simm13 { set Inst{29-25} = rd; } +// F3_rs2 - Common class of instructions that don't use an rs1 +class F3_rs2 : F3 { + bits<5> rs2; + set Inst{4-0} = rs2; +} + +// F3_rs2rd - Common class of instructions use rs2 and rd, but not rs1 +class F3_rs2rd : F3_rs2 { + bits<5> rd; + set Inst{29-25} = rd; +} + // Specific F3 classes... // @@ -154,14 +166,14 @@ class F3_12 opVal, bits<6> op3Val, string name> : F3_rd { set Inst{4-0} = shcnt; } -class F3_13 opVal, bits<6> op3Val, string name> : F3_rd { +class F3_13 opVal, bits<6> op3Val, string name> : F3_rs1 { bits<6> shcnt; - bits<5> rs1; + bits<5> rd; set op = opVal; set op3 = op3Val; set Name = name; - set Inst{18-14} = rs1; + set Inst{29-25} = rd; set Inst{13} = 1; // i field = 1 set Inst{12} = 1; // x field = 1 //set Inst{11-6} = dontcare; @@ -169,7 +181,7 @@ class F3_13 opVal, bits<6> op3Val, string name> : F3_rd { } class F3_14 opVal, bits<6> op3Val, - bits<9> opfval, string name> : F3_rdrs1rs2 { + bits<9> opfval, string name> : F3_rs2rd { set op = opVal; set op3 = op3Val; set Name = name;