[X86] Add a test case showing failure to use the RMW form of ADC when the load is in operand 1 going into isel.

The ADC instruction is commutable, but we only have RMW isel patterns with a load on the left hand side. Nothing will canonicalize loads to the LHS on these ops. So we need two patterns.

llvm-svn: 341605
This commit is contained in:
Craig Topper 2018-09-06 23:55:34 +00:00
parent 8c4db5da5f
commit 37d68e4599
1 changed files with 28 additions and 0 deletions

View File

@ -14,6 +14,34 @@ entry:
ret i128 %0 ret i128 %0
} }
define void @add128_rmw(i128* %a, i128 %b) nounwind {
; CHECK-LABEL: add128_rmw:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: addq %rsi, (%rdi)
; CHECK-NEXT: adcq %rdx, 8(%rdi)
; CHECK-NEXT: retq
entry:
%0 = load i128, i128* %a
%1 = add i128 %0, %b
store i128 %1, i128* %a
ret void
}
define void @add128_rmw2(i128 %a, i128* %b) nounwind {
; CHECK-LABEL: add128_rmw2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: addq (%rdx), %rdi
; CHECK-NEXT: adcq 8(%rdx), %rsi
; CHECK-NEXT: movq %rdi, (%rdx)
; CHECK-NEXT: movq %rsi, 8(%rdx)
; CHECK-NEXT: retq
entry:
%0 = load i128, i128* %b
%1 = add i128 %a, %0
store i128 %1, i128* %b
ret void
}
define i256 @add256(i256 %a, i256 %b) nounwind { define i256 @add256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: add256: ; CHECK-LABEL: add256:
; CHECK: # %bb.0: # %entry ; CHECK: # %bb.0: # %entry