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