2
2
//@ assembly-output: emit-asm
3
3
//@ compile-flags: --crate-type=lib -Copt-level=3 -C target-cpu=x86-64-v4
4
4
//@ compile-flags: -C llvm-args=-x86-asm-syntax=intel
5
- //@ revisions: llvm-pre-20 llvm-20
6
- //@ [llvm-20] min-llvm-version: 20
7
- //@ [llvm-pre-20] max-llvm-major-version: 19
5
+ //@ min-llvm-version: 20
8
6
9
7
#![ no_std]
10
8
#![ feature( bigint_helper_methods) ]
@@ -23,16 +21,15 @@ pub unsafe extern "sysv64" fn bigint_chain_carrying_add(
23
21
n : usize ,
24
22
mut carry : bool ,
25
23
) -> bool {
26
- // llvm-pre-20: mov [[TEMP:r..]], qword ptr [rsi + 8*[[IND:r..]] + 8]
27
- // llvm-pre-20: adc [[TEMP]], qword ptr [rdx + 8*[[IND]] + 8]
28
- // llvm-pre-20: mov qword ptr [rdi + 8*[[IND]] + 8], [[TEMP]]
29
- // llvm-pre-20: mov [[TEMP]], qword ptr [rsi + 8*[[IND]] + 16]
30
- // llvm-pre-20: adc [[TEMP]], qword ptr [rdx + 8*[[IND]] + 16]
31
- // llvm-pre-20: mov qword ptr [rdi + 8*[[IND]] + 16], [[TEMP]]
32
- // llvm-20: adc [[TEMP:r..]], qword ptr [rdx + 8*[[IND:r..]]]
33
- // llvm-20: mov qword ptr [rdi + 8*[[IND]]], [[TEMP]]
34
- // llvm-20: mov [[TEMP]], qword ptr [rsi + 8*[[IND]] + 8]
35
- // llvm-20: adc [[TEMP]], qword ptr [rdx + 8*[[IND]] + 8]
24
+ // Even if we emit A+B, LLVM will sometimes reorder that to B+A, so this
25
+ // test doesn't actually check which register is mov vs which is adc.
26
+
27
+ // CHECK: mov [[TEMP1:.+]], qword ptr [{{rdx|rsi}} + 8*[[IND:.+]] + 8]
28
+ // CHECK: adc [[TEMP1]], qword ptr [{{rdx|rsi}} + 8*[[IND]] + 8]
29
+ // CHECK: mov qword ptr [rdi + 8*[[IND]] + 8], [[TEMP1]]
30
+ // CHECK: mov [[TEMP2:.+]], qword ptr [{{rdx|rsi}} + 8*[[IND]] + 16]
31
+ // CHECK: adc [[TEMP2]], qword ptr [{{rdx|rsi}} + 8*[[IND]] + 16]
32
+ // CHECK: mov qword ptr [rdi + 8*[[IND]] + 16], [[TEMP2]]
36
33
for i in 0 ..n {
37
34
( * dest. add ( i) , carry) = u64:: carrying_add ( * src1. add ( i) , * src2. add ( i) , carry) ;
38
35
}
0 commit comments