@@ -3899,7 +3899,8 @@ def MUL : AsMul1I32<0b0000000, (outs GPRnopc:$Rd),
3899
3899
(ins GPRnopc:$Rn, GPRnopc:$Rm),
3900
3900
IIC_iMUL32, "mul", "\t$Rd, $Rn, $Rm",
3901
3901
[(set GPRnopc:$Rd, (mul GPRnopc:$Rn, GPRnopc:$Rm))]>,
3902
- Requires<[IsARM, HasV6]> {
3902
+ Requires<[IsARM, HasV6]>,
3903
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]> {
3903
3904
let Inst{15-12} = 0b0000;
3904
3905
let Unpredictable{15-12} = 0b1111;
3905
3906
}
@@ -3910,14 +3911,16 @@ def MULv5: ARMPseudoExpand<(outs GPRnopc:$Rd), (ins GPRnopc:$Rn, GPRnopc:$Rm,
3910
3911
4, IIC_iMUL32,
3911
3912
[(set GPRnopc:$Rd, (mul GPRnopc:$Rn, GPRnopc:$Rm))],
3912
3913
(MUL GPRnopc:$Rd, GPRnopc:$Rn, GPRnopc:$Rm, pred:$p, cc_out:$s)>,
3913
- Requires<[IsARM, NoV6, UseMulOps]>;
3914
+ Requires<[IsARM, NoV6, UseMulOps]>,
3915
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
3914
3916
}
3915
3917
3916
3918
def MLA : AsMul1I32<0b0000001, (outs GPRnopc:$Rd),
3917
3919
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPRnopc:$Ra),
3918
3920
IIC_iMAC32, "mla", "\t$Rd, $Rn, $Rm, $Ra",
3919
3921
[(set GPRnopc:$Rd, (add (mul GPRnopc:$Rn, GPRnopc:$Rm), GPRnopc:$Ra))]>,
3920
- Requires<[IsARM, HasV6, UseMulOps]> {
3922
+ Requires<[IsARM, HasV6, UseMulOps]>,
3923
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]> {
3921
3924
bits<4> Ra;
3922
3925
let Inst{15-12} = Ra;
3923
3926
}
@@ -3928,12 +3931,14 @@ def MLAv5: ARMPseudoExpand<(outs GPRnopc:$Rd),
3928
3931
pred:$p, cc_out:$s), 4, IIC_iMAC32,
3929
3932
[(set GPRnopc:$Rd, (add (mul GPRnopc:$Rn, GPRnopc:$Rm), GPRnopc:$Ra))],
3930
3933
(MLA GPRnopc:$Rd, GPRnopc:$Rn, GPRnopc:$Rm, GPRnopc:$Ra, pred:$p, cc_out:$s)>,
3931
- Requires<[IsARM, NoV6]>;
3934
+ Requires<[IsARM, NoV6]>,
3935
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
3932
3936
3933
3937
def MLS : AMul1I<0b0000011, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
3934
3938
IIC_iMAC32, "mls", "\t$Rd, $Rn, $Rm, $Ra",
3935
3939
[(set GPR:$Rd, (sub GPR:$Ra, (mul GPR:$Rn, GPR:$Rm)))]>,
3936
- Requires<[IsARM, HasV6T2, UseMulOps]> {
3940
+ Requires<[IsARM, HasV6T2, UseMulOps]>,
3941
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]> {
3937
3942
bits<4> Rd;
3938
3943
bits<4> Rm;
3939
3944
bits<4> Rn;
@@ -3950,43 +3955,50 @@ let isCommutable = 1 in {
3950
3955
def SMULL : AsMul1I64<0b0000110, (outs GPR:$RdLo, GPR:$RdHi),
3951
3956
(ins GPR:$Rn, GPR:$Rm), IIC_iMUL64,
3952
3957
"smull", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
3953
- Requires<[IsARM, HasV6]>;
3958
+ Requires<[IsARM, HasV6]>,
3959
+ Sched<[WriteMUL64Lo, WriteMUL64Hi, ReadMUL, ReadMUL]>;
3954
3960
3955
3961
def UMULL : AsMul1I64<0b0000100, (outs GPR:$RdLo, GPR:$RdHi),
3956
3962
(ins GPR:$Rn, GPR:$Rm), IIC_iMUL64,
3957
3963
"umull", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
3958
- Requires<[IsARM, HasV6]>;
3964
+ Requires<[IsARM, HasV6]>,
3965
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL]>;
3959
3966
3960
3967
let Constraints = "@earlyclobber $RdLo,@earlyclobber $RdHi" in {
3961
3968
def SMULLv5 : ARMPseudoExpand<(outs GPR:$RdLo, GPR:$RdHi),
3962
3969
(ins GPR:$Rn, GPR:$Rm, pred:$p, cc_out:$s),
3963
3970
4, IIC_iMUL64, [],
3964
3971
(SMULL GPR:$RdLo, GPR:$RdHi, GPR:$Rn, GPR:$Rm, pred:$p, cc_out:$s)>,
3965
- Requires<[IsARM, NoV6]>;
3972
+ Requires<[IsARM, NoV6]>,
3973
+ Sched<[WriteMUL64Lo, WriteMUL64Hi, ReadMUL, ReadMUL]>;
3966
3974
3967
3975
def UMULLv5 : ARMPseudoExpand<(outs GPR:$RdLo, GPR:$RdHi),
3968
3976
(ins GPR:$Rn, GPR:$Rm, pred:$p, cc_out:$s),
3969
3977
4, IIC_iMUL64, [],
3970
3978
(UMULL GPR:$RdLo, GPR:$RdHi, GPR:$Rn, GPR:$Rm, pred:$p, cc_out:$s)>,
3971
- Requires<[IsARM, NoV6]>;
3979
+ Requires<[IsARM, NoV6]>,
3980
+ Sched<[WriteMUL64Lo, WriteMUL64Hi, ReadMUL, ReadMUL]>;
3972
3981
}
3973
3982
}
3974
3983
3975
3984
// Multiply + accumulate
3976
3985
def SMLAL : AsMla1I64<0b0000111, (outs GPR:$RdLo, GPR:$RdHi),
3977
3986
(ins GPR:$Rn, GPR:$Rm, GPR:$RLo, GPR:$RHi), IIC_iMAC64,
3978
3987
"smlal", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
3979
- RegConstraint<"$RLo = $RdLo, $RHi = $RdHi">, Requires<[IsARM, HasV6]>;
3988
+ RegConstraint<"$RLo = $RdLo, $RHi = $RdHi">, Requires<[IsARM, HasV6]>,
3989
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
3980
3990
def UMLAL : AsMla1I64<0b0000101, (outs GPR:$RdLo, GPR:$RdHi),
3981
3991
(ins GPR:$Rn, GPR:$Rm, GPR:$RLo, GPR:$RHi), IIC_iMAC64,
3982
3992
"umlal", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
3983
- RegConstraint<"$RLo = $RdLo, $RHi = $RdHi">, Requires<[IsARM, HasV6]>;
3993
+ RegConstraint<"$RLo = $RdLo, $RHi = $RdHi">, Requires<[IsARM, HasV6]>,
3994
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
3984
3995
3985
3996
def UMAAL : AMul1I <0b0000010, (outs GPR:$RdLo, GPR:$RdHi),
3986
3997
(ins GPR:$Rn, GPR:$Rm, GPR:$RLo, GPR:$RHi),
3987
3998
IIC_iMAC64,
3988
3999
"umaal", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
3989
- RegConstraint<"$RLo = $RdLo, $RHi = $RdHi">, Requires<[IsARM, HasV6]> {
4000
+ RegConstraint<"$RLo = $RdLo, $RHi = $RdHi">, Requires<[IsARM, HasV6]>,
4001
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]> {
3990
4002
bits<4> RdLo;
3991
4003
bits<4> RdHi;
3992
4004
bits<4> Rm;
@@ -4004,13 +4016,15 @@ def SMLALv5 : ARMPseudoExpand<(outs GPR:$RdLo, GPR:$RdHi),
4004
4016
4, IIC_iMAC64, [],
4005
4017
(SMLAL GPR:$RdLo, GPR:$RdHi, GPR:$Rn, GPR:$Rm, GPR:$RLo, GPR:$RHi,
4006
4018
pred:$p, cc_out:$s)>,
4007
- Requires<[IsARM, NoV6]>;
4019
+ Requires<[IsARM, NoV6]>,
4020
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4008
4021
def UMLALv5 : ARMPseudoExpand<(outs GPR:$RdLo, GPR:$RdHi),
4009
4022
(ins GPR:$Rn, GPR:$Rm, GPR:$RLo, GPR:$RHi, pred:$p, cc_out:$s),
4010
4023
4, IIC_iMAC64, [],
4011
4024
(UMLAL GPR:$RdLo, GPR:$RdHi, GPR:$Rn, GPR:$Rm, GPR:$RLo, GPR:$RHi,
4012
4025
pred:$p, cc_out:$s)>,
4013
- Requires<[IsARM, NoV6]>;
4026
+ Requires<[IsARM, NoV6]>,
4027
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4014
4028
}
4015
4029
4016
4030
} // hasSideEffects
@@ -4019,71 +4033,83 @@ def UMLALv5 : ARMPseudoExpand<(outs GPR:$RdLo, GPR:$RdHi),
4019
4033
def SMMUL : AMul2I <0b0111010, 0b0001, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4020
4034
IIC_iMUL32, "smmul", "\t$Rd, $Rn, $Rm",
4021
4035
[(set GPR:$Rd, (mulhs GPR:$Rn, GPR:$Rm))]>,
4022
- Requires<[IsARM, HasV6]> {
4036
+ Requires<[IsARM, HasV6]>,
4037
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]> {
4023
4038
let Inst{15-12} = 0b1111;
4024
4039
}
4025
4040
4026
4041
def SMMULR : AMul2I <0b0111010, 0b0011, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4027
4042
IIC_iMUL32, "smmulr", "\t$Rd, $Rn, $Rm", []>,
4028
- Requires<[IsARM, HasV6]> {
4043
+ Requires<[IsARM, HasV6]>,
4044
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]> {
4029
4045
let Inst{15-12} = 0b1111;
4030
4046
}
4031
4047
4032
4048
def SMMLA : AMul2Ia <0b0111010, 0b0001, (outs GPR:$Rd),
4033
4049
(ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
4034
4050
IIC_iMAC32, "smmla", "\t$Rd, $Rn, $Rm, $Ra",
4035
4051
[(set GPR:$Rd, (add (mulhs GPR:$Rn, GPR:$Rm), GPR:$Ra))]>,
4036
- Requires<[IsARM, HasV6, UseMulOps]>;
4052
+ Requires<[IsARM, HasV6, UseMulOps]>,
4053
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
4037
4054
4038
4055
def SMMLAR : AMul2Ia <0b0111010, 0b0011, (outs GPR:$Rd),
4039
4056
(ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
4040
4057
IIC_iMAC32, "smmlar", "\t$Rd, $Rn, $Rm, $Ra", []>,
4041
- Requires<[IsARM, HasV6]>;
4058
+ Requires<[IsARM, HasV6]>,
4059
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
4042
4060
4043
4061
def SMMLS : AMul2Ia <0b0111010, 0b1101, (outs GPR:$Rd),
4044
4062
(ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
4045
4063
IIC_iMAC32, "smmls", "\t$Rd, $Rn, $Rm, $Ra", []>,
4046
- Requires<[IsARM, HasV6, UseMulOps]>;
4064
+ Requires<[IsARM, HasV6, UseMulOps]>,
4065
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
4047
4066
4048
4067
def SMMLSR : AMul2Ia <0b0111010, 0b1111, (outs GPR:$Rd),
4049
4068
(ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
4050
4069
IIC_iMAC32, "smmlsr", "\t$Rd, $Rn, $Rm, $Ra", []>,
4051
- Requires<[IsARM, HasV6]>;
4070
+ Requires<[IsARM, HasV6]>,
4071
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
4052
4072
4053
4073
multiclass AI_smul<string opc> {
4054
4074
def BB : AMulxyI<0b0001011, 0b00, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4055
4075
IIC_iMUL16, !strconcat(opc, "bb"), "\t$Rd, $Rn, $Rm",
4056
4076
[(set GPR:$Rd, (mul (sext_inreg GPR:$Rn, i16),
4057
4077
(sext_inreg GPR:$Rm, i16)))]>,
4058
- Requires<[IsARM, HasV5TE]>;
4078
+ Requires<[IsARM, HasV5TE]>,
4079
+ Sched<[WriteMUL16, ReadMUL, ReadMUL]>;
4059
4080
4060
4081
def BT : AMulxyI<0b0001011, 0b10, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4061
4082
IIC_iMUL16, !strconcat(opc, "bt"), "\t$Rd, $Rn, $Rm",
4062
4083
[(set GPR:$Rd, (mul (sext_inreg GPR:$Rn, i16),
4063
4084
(sra GPR:$Rm, (i32 16))))]>,
4064
- Requires<[IsARM, HasV5TE]>;
4085
+ Requires<[IsARM, HasV5TE]>,
4086
+ Sched<[WriteMUL16, ReadMUL, ReadMUL]>;
4065
4087
4066
4088
def TB : AMulxyI<0b0001011, 0b01, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4067
4089
IIC_iMUL16, !strconcat(opc, "tb"), "\t$Rd, $Rn, $Rm",
4068
4090
[(set GPR:$Rd, (mul (sra GPR:$Rn, (i32 16)),
4069
4091
(sext_inreg GPR:$Rm, i16)))]>,
4070
- Requires<[IsARM, HasV5TE]>;
4092
+ Requires<[IsARM, HasV5TE]>,
4093
+ Sched<[WriteMUL16, ReadMUL, ReadMUL]>;
4071
4094
4072
4095
def TT : AMulxyI<0b0001011, 0b11, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4073
4096
IIC_iMUL16, !strconcat(opc, "tt"), "\t$Rd, $Rn, $Rm",
4074
4097
[(set GPR:$Rd, (mul (sra GPR:$Rn, (i32 16)),
4075
4098
(sra GPR:$Rm, (i32 16))))]>,
4076
- Requires<[IsARM, HasV5TE]>;
4099
+ Requires<[IsARM, HasV5TE]>,
4100
+ Sched<[WriteMUL16, ReadMUL, ReadMUL]>;
4077
4101
4078
4102
def WB : AMulxyI<0b0001001, 0b01, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4079
4103
IIC_iMUL16, !strconcat(opc, "wb"), "\t$Rd, $Rn, $Rm",
4080
4104
[]>,
4081
- Requires<[IsARM, HasV5TE]>;
4105
+ Requires<[IsARM, HasV5TE]>,
4106
+ Sched<[WriteMUL16, ReadMUL, ReadMUL]>;
4082
4107
4083
4108
def WT : AMulxyI<0b0001001, 0b11, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm),
4084
4109
IIC_iMUL16, !strconcat(opc, "wt"), "\t$Rd, $Rn, $Rm",
4085
4110
[]>,
4086
- Requires<[IsARM, HasV5TE]>;
4111
+ Requires<[IsARM, HasV5TE]>,
4112
+ Sched<[WriteMUL16, ReadMUL, ReadMUL]>;
4087
4113
}
4088
4114
4089
4115
@@ -4095,43 +4121,49 @@ multiclass AI_smla<string opc> {
4095
4121
[(set GPRnopc:$Rd, (add GPR:$Ra,
4096
4122
(mul (sext_inreg GPRnopc:$Rn, i16),
4097
4123
(sext_inreg GPRnopc:$Rm, i16))))]>,
4098
- Requires<[IsARM, HasV5TE, UseMulOps]>;
4124
+ Requires<[IsARM, HasV5TE, UseMulOps]>,
4125
+ Sched<[WriteMAC16, ReadMUL, ReadMUL, ReadMAC]>;
4099
4126
4100
4127
def BT : AMulxyIa<0b0001000, 0b10, (outs GPRnopc:$Rd),
4101
4128
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4102
4129
IIC_iMAC16, !strconcat(opc, "bt"), "\t$Rd, $Rn, $Rm, $Ra",
4103
4130
[(set GPRnopc:$Rd,
4104
4131
(add GPR:$Ra, (mul (sext_inreg GPRnopc:$Rn, i16),
4105
4132
(sra GPRnopc:$Rm, (i32 16)))))]>,
4106
- Requires<[IsARM, HasV5TE, UseMulOps]>;
4133
+ Requires<[IsARM, HasV5TE, UseMulOps]>,
4134
+ Sched<[WriteMAC16, ReadMUL, ReadMUL, ReadMAC]>;
4107
4135
4108
4136
def TB : AMulxyIa<0b0001000, 0b01, (outs GPRnopc:$Rd),
4109
4137
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4110
4138
IIC_iMAC16, !strconcat(opc, "tb"), "\t$Rd, $Rn, $Rm, $Ra",
4111
4139
[(set GPRnopc:$Rd,
4112
4140
(add GPR:$Ra, (mul (sra GPRnopc:$Rn, (i32 16)),
4113
4141
(sext_inreg GPRnopc:$Rm, i16))))]>,
4114
- Requires<[IsARM, HasV5TE, UseMulOps]>;
4142
+ Requires<[IsARM, HasV5TE, UseMulOps]>,
4143
+ Sched<[WriteMAC16, ReadMUL, ReadMUL, ReadMAC]>;
4115
4144
4116
4145
def TT : AMulxyIa<0b0001000, 0b11, (outs GPRnopc:$Rd),
4117
4146
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4118
4147
IIC_iMAC16, !strconcat(opc, "tt"), "\t$Rd, $Rn, $Rm, $Ra",
4119
4148
[(set GPRnopc:$Rd,
4120
4149
(add GPR:$Ra, (mul (sra GPRnopc:$Rn, (i32 16)),
4121
4150
(sra GPRnopc:$Rm, (i32 16)))))]>,
4122
- Requires<[IsARM, HasV5TE, UseMulOps]>;
4151
+ Requires<[IsARM, HasV5TE, UseMulOps]>,
4152
+ Sched<[WriteMAC16, ReadMUL, ReadMUL, ReadMAC]>;
4123
4153
4124
4154
def WB : AMulxyIa<0b0001001, 0b00, (outs GPRnopc:$Rd),
4125
4155
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4126
4156
IIC_iMAC16, !strconcat(opc, "wb"), "\t$Rd, $Rn, $Rm, $Ra",
4127
4157
[]>,
4128
- Requires<[IsARM, HasV5TE, UseMulOps]>;
4158
+ Requires<[IsARM, HasV5TE, UseMulOps]>,
4159
+ Sched<[WriteMAC16, ReadMUL, ReadMUL, ReadMAC]>;
4129
4160
4130
4161
def WT : AMulxyIa<0b0001001, 0b10, (outs GPRnopc:$Rd),
4131
4162
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4132
4163
IIC_iMAC16, !strconcat(opc, "wt"), "\t$Rd, $Rn, $Rm, $Ra",
4133
4164
[]>,
4134
- Requires<[IsARM, HasV5TE, UseMulOps]>;
4165
+ Requires<[IsARM, HasV5TE, UseMulOps]>,
4166
+ Sched<[WriteMAC16, ReadMUL, ReadMUL, ReadMAC]>;
4135
4167
}
4136
4168
}
4137
4169
@@ -4142,22 +4174,26 @@ defm SMLA : AI_smla<"smla">;
4142
4174
def SMLALBB : AMulxyI64<0b0001010, 0b00, (outs GPRnopc:$RdLo, GPRnopc:$RdHi),
4143
4175
(ins GPRnopc:$Rn, GPRnopc:$Rm),
4144
4176
IIC_iMAC64, "smlalbb", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
4145
- Requires<[IsARM, HasV5TE]>;
4177
+ Requires<[IsARM, HasV5TE]>,
4178
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4146
4179
4147
4180
def SMLALBT : AMulxyI64<0b0001010, 0b10, (outs GPRnopc:$RdLo, GPRnopc:$RdHi),
4148
4181
(ins GPRnopc:$Rn, GPRnopc:$Rm),
4149
4182
IIC_iMAC64, "smlalbt", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
4150
- Requires<[IsARM, HasV5TE]>;
4183
+ Requires<[IsARM, HasV5TE]>,
4184
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4151
4185
4152
4186
def SMLALTB : AMulxyI64<0b0001010, 0b01, (outs GPRnopc:$RdLo, GPRnopc:$RdHi),
4153
4187
(ins GPRnopc:$Rn, GPRnopc:$Rm),
4154
4188
IIC_iMAC64, "smlaltb", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
4155
- Requires<[IsARM, HasV5TE]>;
4189
+ Requires<[IsARM, HasV5TE]>,
4190
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4156
4191
4157
4192
def SMLALTT : AMulxyI64<0b0001010, 0b11, (outs GPRnopc:$RdLo, GPRnopc:$RdHi),
4158
4193
(ins GPRnopc:$Rn, GPRnopc:$Rm),
4159
4194
IIC_iMAC64, "smlaltt", "\t$RdLo, $RdHi, $Rn, $Rm", []>,
4160
- Requires<[IsARM, HasV5TE]>;
4195
+ Requires<[IsARM, HasV5TE]>,
4196
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4161
4197
4162
4198
// Helper class for AI_smld.
4163
4199
class AMulDualIbase<bit long, bit sub, bit swap, dag oops, dag iops,
@@ -4203,19 +4239,23 @@ multiclass AI_smld<bit sub, string opc> {
4203
4239
4204
4240
def D : AMulDualIa<0, sub, 0, (outs GPRnopc:$Rd),
4205
4241
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4206
- NoItinerary, !strconcat(opc, "d"), "\t$Rd, $Rn, $Rm, $Ra">;
4242
+ NoItinerary, !strconcat(opc, "d"), "\t$Rd, $Rn, $Rm, $Ra">,
4243
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
4207
4244
4208
4245
def DX: AMulDualIa<0, sub, 1, (outs GPRnopc:$Rd),
4209
4246
(ins GPRnopc:$Rn, GPRnopc:$Rm, GPR:$Ra),
4210
- NoItinerary, !strconcat(opc, "dx"), "\t$Rd, $Rn, $Rm, $Ra">;
4247
+ NoItinerary, !strconcat(opc, "dx"), "\t$Rd, $Rn, $Rm, $Ra">,
4248
+ Sched<[WriteMAC32, ReadMUL, ReadMUL, ReadMAC]>;
4211
4249
4212
4250
def LD: AMulDualI64<1, sub, 0, (outs GPRnopc:$RdLo, GPRnopc:$RdHi),
4213
4251
(ins GPRnopc:$Rn, GPRnopc:$Rm), NoItinerary,
4214
- !strconcat(opc, "ld"), "\t$RdLo, $RdHi, $Rn, $Rm">;
4252
+ !strconcat(opc, "ld"), "\t$RdLo, $RdHi, $Rn, $Rm">,
4253
+ Sched<[WriteMAC64Lo, WriteMAC64Hi, ReadMUL, ReadMUL, ReadMAC, ReadMAC]>;
4215
4254
4216
4255
def LDX : AMulDualI64<1, sub, 1, (outs GPRnopc:$RdLo, GPRnopc:$RdHi),
4217
4256
(ins GPRnopc:$Rn, GPRnopc:$Rm), NoItinerary,
4218
- !strconcat(opc, "ldx"),"\t$RdLo, $RdHi, $Rn, $Rm">;
4257
+ !strconcat(opc, "ldx"),"\t$RdLo, $RdHi, $Rn, $Rm">,
4258
+ Sched<[WriteMUL64Lo, WriteMUL64Hi, ReadMUL, ReadMUL]>;
4219
4259
4220
4260
}
4221
4261
@@ -4225,9 +4265,11 @@ defm SMLS : AI_smld<1, "smls">;
4225
4265
multiclass AI_sdml<bit sub, string opc> {
4226
4266
4227
4267
def D:AMulDualI<0, sub, 0, (outs GPRnopc:$Rd), (ins GPRnopc:$Rn, GPRnopc:$Rm),
4228
- NoItinerary, !strconcat(opc, "d"), "\t$Rd, $Rn, $Rm">;
4268
+ NoItinerary, !strconcat(opc, "d"), "\t$Rd, $Rn, $Rm">,
4269
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
4229
4270
def DX:AMulDualI<0, sub, 1, (outs GPRnopc:$Rd),(ins GPRnopc:$Rn, GPRnopc:$Rm),
4230
- NoItinerary, !strconcat(opc, "dx"), "\t$Rd, $Rn, $Rm">;
4271
+ NoItinerary, !strconcat(opc, "dx"), "\t$Rd, $Rn, $Rm">,
4272
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
4231
4273
}
4232
4274
4233
4275
defm SMUA : AI_sdml<0, "smua">;
@@ -4239,12 +4281,14 @@ defm SMUS : AI_sdml<1, "smus">;
4239
4281
def SDIV : ADivA1I<0b001, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm), IIC_iDIV,
4240
4282
"sdiv", "\t$Rd, $Rn, $Rm",
4241
4283
[(set GPR:$Rd, (sdiv GPR:$Rn, GPR:$Rm))]>,
4242
- Requires<[IsARM, HasDivideInARM]>;
4284
+ Requires<[IsARM, HasDivideInARM]>,
4285
+ Sched<[WriteDIV]>;
4243
4286
4244
4287
def UDIV : ADivA1I<0b011, (outs GPR:$Rd), (ins GPR:$Rn, GPR:$Rm), IIC_iDIV,
4245
4288
"udiv", "\t$Rd, $Rn, $Rm",
4246
4289
[(set GPR:$Rd, (udiv GPR:$Rn, GPR:$Rm))]>,
4247
- Requires<[IsARM, HasDivideInARM]>;
4290
+ Requires<[IsARM, HasDivideInARM]>,
4291
+ Sched<[WriteDIV]>;
4248
4292
4249
4293
//===----------------------------------------------------------------------===//
4250
4294
// Misc. Arithmetic Instructions.
@@ -5526,20 +5570,26 @@ def : ARMPat<(extloadi16 addrmodepc:$addr), (PICLDRH addrmodepc:$addr)>;
5526
5570
5527
5571
// smul* and smla*
5528
5572
def : ARMV5TEPat<(mul sext_16_node:$a, sext_16_node:$b),
5529
- (SMULBB GPR:$a, GPR:$b)>;
5573
+ (SMULBB GPR:$a, GPR:$b)>,
5574
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
5530
5575
def : ARMV5TEPat<(mul sext_16_node:$a, (sra GPR:$b, (i32 16))),
5531
- (SMULBT GPR:$a, GPR:$b)>;
5576
+ (SMULBT GPR:$a, GPR:$b)>,
5577
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
5532
5578
def : ARMV5TEPat<(mul (sra GPR:$a, (i32 16)), sext_16_node:$b),
5533
- (SMULTB GPR:$a, GPR:$b)>;
5579
+ (SMULTB GPR:$a, GPR:$b)>,
5580
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
5534
5581
def : ARMV5MOPat<(add GPR:$acc,
5535
5582
(mul sext_16_node:$a, sext_16_node:$b)),
5536
- (SMLABB GPR:$a, GPR:$b, GPR:$acc)>;
5583
+ (SMLABB GPR:$a, GPR:$b, GPR:$acc)>,
5584
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
5537
5585
def : ARMV5MOPat<(add GPR:$acc,
5538
5586
(mul sext_16_node:$a, (sra GPR:$b, (i32 16)))),
5539
- (SMLABT GPR:$a, GPR:$b, GPR:$acc)>;
5587
+ (SMLABT GPR:$a, GPR:$b, GPR:$acc)>,
5588
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
5540
5589
def : ARMV5MOPat<(add GPR:$acc,
5541
5590
(mul (sra GPR:$a, (i32 16)), sext_16_node:$b)),
5542
- (SMLATB GPR:$a, GPR:$b, GPR:$acc)>;
5591
+ (SMLATB GPR:$a, GPR:$b, GPR:$acc)>,
5592
+ Sched<[WriteMUL32, ReadMUL, ReadMUL]>;
5543
5593
5544
5594
// Pre-v7 uses MCR for synchronization barriers.
5545
5595
def : ARMPat<(ARMMemBarrierMCR GPR:$zero), (MCR 15, 0, GPR:$zero, 7, 10, 5)>,
0 commit comments