33//
44//@ revisions: MIPS MIPS64 MIPS64EL
55//@ [MIPS] compile-flags: -Copt-level=3 --target mips-unknown-linux-gnu
6+ //@ [MIPS] needs-llvm-components: mips
67//@ [MIPS64] compile-flags: -Copt-level=3 --target mipsisa64r6-unknown-linux-gnuabi64
8+ //@ [MIPS64] needs-llvm-components: mips
79//@ [MIPS64EL] compile-flags: -Copt-level=3 --target mips64el-unknown-linux-gnuabi64
8- //@ needs-llvm-components: mips
10+ //@ [MIPS64EL] needs-llvm-components: mips
911#![ feature( c_variadic, no_core, lang_items, intrinsics, rustc_attrs, asm_experimental_arch) ]
1012#![ no_core]
1113#![ crate_type = "lib" ]
@@ -88,9 +90,9 @@ unsafe extern "C" fn read_i32(ap: &mut VaList<'_>) -> i32 {
8890 // MIPS64EL: ld $1, 0($4)
8991 // MIPS64EL-NEXT: daddiu $2, $1, 8
9092 // MIPS64EL-NEXT: sd $2, 0($4)
91- // MIPS64EL-NEXT: lw $1 , 0($1)
93+ // MIPS64EL-NEXT: lw $2 , 0($1)
9294 // MIPS64EL-NEXT: jr $ra
93- // MIPS64EL-NEXT: sll $2, $1, 0
95+ // MIPS64EL-NEXT: nop
9496 va_arg ( ap)
9597}
9698
@@ -99,17 +101,15 @@ unsafe extern "C" fn read_i64(ap: &mut VaList<'_>) -> i64 {
99101 // CHECK-LABEL: read_i64
100102 //
101103 // MIPS: lw $1, 0($4)
102- // MIPS-NEXT: addiu $2, $zero, 4
103- // MIPS-NEXT: addiu $1, $1, 7
104- // MIPS-NEXT: move $3, $1
105- // MIPS-NEXT: ins $3, $2, 0, 3
106104 // MIPS-NEXT: addiu $2, $zero, -8
105+ // MIPS-NEXT: addiu $1, $1, 7
106+ // MIPS-NEXT: and $2, $1, $2
107+ // MIPS-NEXT: addiu $3, $2, 8
107108 // MIPS-NEXT: sw $3, 0($4)
108- // MIPS-NEXT: and $1, $1, $2
109- // MIPS-NEXT: lw $2, 0($1)
110- // MIPS-NEXT: addiu $1, $3, 4
111- // MIPS-NEXT: sw $1, 0($4)
112- // MIPS-NEXT: lw $3, 0($3)
109+ // MIPS-NEXT: addiu $3, $zero, 4
110+ // MIPS-NEXT: lw $2, 0($2)
111+ // MIPS-NEXT: ins $1, $3, 0, 3
112+ // MIPS-NEXT: lw $3, 0($1)
113113 // MIPS-NEXT: jr $ra
114114 // MIPS-NEXT: nop
115115 //
0 commit comments