diff --git a/lib/Target/SparcV9/SparcV9_F3.td b/lib/Target/SparcV9/SparcV9_F3.td index 294d1d7c6d0..d639ed58c9e 100644 --- a/lib/Target/SparcV9/SparcV9_F3.td +++ b/lib/Target/SparcV9/SparcV9_F3.td @@ -66,7 +66,7 @@ class F3_rs1simm13 : F3_rs1 { // Specific F3 classes... // -class F3_1 opVal, bits<6> op3val, string name> : F3_rdrs1rs2 { +class F3_1 opVal, bits<6> op3val, string name> : F3_rdrs1rs2 { set op = opVal; set op3 = op3val; set Name = name; @@ -74,21 +74,21 @@ class F3_1 opVal, bits<6> op3val, string name> : F3_rdrs1rs2 { //set Inst{12-5} = dontcare; } -class F3_2 opVal, bits<6> op3val, string name> : F3_rdsimm13rs1 { +class F3_2 opVal, bits<6> op3val, string name> : F3_rdsimm13rs1 { set op = opVal; set op3 = op3val; set Name = name; set Inst{13} = 1; // i field = 1 } -class F3_3 opVal, bits<6> op3val, string name> : F3_rs1rs2 { +class F3_3 opVal, bits<6> op3val, string name> : F3_rs1rs2 { set op = opVal; set op3 = op3val; set Name = name; set Inst{13} = 0; } -class F3_4 opVal, bits<6> op3Val, string name> : F3_rs1simm13 { +class F3_4 opVal, bits<6> op3Val, string name> : F3_rs1simm13 { bits<13> simm; set op = opVal; set op3 = op3Val; @@ -98,7 +98,7 @@ class F3_4 opVal, bits<6> op3Val, string name> : F3_rs1simm13 { set Inst{12-0} = simm; } -class F3_11 opVal, bits<6> op3Val, string name> : F3_rdrs1rs2 { +class F3_11 opVal, bits<6> op3Val, string name> : F3_rdrs1rs2 { bit x; set op = opVal; set op3 = op3Val; @@ -108,24 +108,28 @@ class F3_11 opVal, bits<6> op3Val, string name> : F3_rdrs1rs2 { //set Inst{11-5} = dontcare; } -class F3_12 opVal, bits<6> op3Val, string name> : F3_rdrs1 { +class F3_12 opVal, bits<6> op3Val, string name> : F3_rd { bits<5> shcnt; + bits<5> rs1; set op = opVal; set op3 = op3Val; set Name = name; + set Inst{18-14} = rs1; set Inst{13} = 1; // i field = 1 set Inst{12} = 0; // x field = 0 //set Inst{11-5} = dontcare; set Inst{4-0} = shcnt; } -class F3_13 opVal, bits<6> op3Val, string name> : F3_rdrs1 { +class F3_13 opVal, bits<6> op3Val, string name> : F3_rd { bits<6> shcnt; + bits<5> rs1; set op = opVal; set op3 = op3Val; set Name = name; + set Inst{18-14} = rs1; set Inst{13} = 1; // i field = 1 set Inst{12} = 1; // x field = 1 //set Inst{11-6} = dontcare;