22//@ assembly-output: emit-asm
33//@ compile-flags: --crate-type=lib -O -C target-cpu=x86-64-v4
44//@ 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
58
69#![ no_std]
710#![ feature( bigint_helper_methods) ]
@@ -20,12 +23,16 @@ pub unsafe extern "sysv64" fn bigint_chain_carrying_add(
2023 n : usize ,
2124 mut carry : bool ,
2225) -> bool {
23- // CHECK: mov [[TEMP:r..]], qword ptr [rsi + 8*[[IND:r..]] + 8]
24- // CHECK: adc [[TEMP]], qword ptr [rdx + 8*[[IND]] + 8]
25- // CHECK: mov qword ptr [rdi + 8*[[IND]] + 8], [[TEMP]]
26- // CHECK: mov [[TEMP]], qword ptr [rsi + 8*[[IND]] + 16]
27- // CHECK: adc [[TEMP]], qword ptr [rdx + 8*[[IND]] + 16]
28- // CHECK: mov qword ptr [rdi + 8*[[IND]] + 16], [[TEMP]]
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]
2936 for i in 0 ..n {
3037 ( * dest. add ( i) , carry) = u64:: carrying_add ( * src1. add ( i) , * src2. add ( i) , carry) ;
3138 }
0 commit comments