; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mtriple=mips-mti-linux-gnu -mcpu=mips32r2 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS32 ; RUN: llc -mtriple=mips-mti-linux-gnu -mcpu=mips32r2 -mattr=+micromips < %s -asm-show-inst | FileCheck %s --check-prefix=MMR3 ; RUN: llc -mtriple=mips-img-linux-gnu -mcpu=mips32r6 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS32R6 ; RUN: llc -mtriple=mips-img-linux-gnu -mcpu=mips32r6 -mattr=+micromips < %s -asm-show-inst | FileCheck %s --check-prefix=MMR6 ; RUN: llc -mtriple=mips64-mti-linux-gnu -mcpu=mips4 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS4 ; RUN: llc -mtriple=mips64-img-linux-gnu -mcpu=mips64r6 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS64R6 ; Test subword and word stores. @a = common global i8 0, align 4 @b = common global i16 0, align 4 @c = common global i32 0, align 4 @d = common global i64 0, align 8 define void @f1(i8 %a) { ; MIPS32-LABEL: f1: ; MIPS32: # %bb.0: ; MIPS32-NEXT: lui $1, %hi(a) # ; MIPS32-NEXT: # > ; MIPS32-NEXT: jr $ra # > ; MIPS32-NEXT: sb $4, %lo(a)($1) # ; MIPS32-NEXT: # ; MIPS32-NEXT: # > ; ; MMR3-LABEL: f1: ; MMR3: # %bb.0: ; MMR3-NEXT: lui $1, %hi(a) # ; MMR3-NEXT: # > ; MMR3-NEXT: jr $ra # > ; MMR3-NEXT: sb $4, %lo(a)($1) # ; MMR3-NEXT: # ; MMR3-NEXT: # > ; ; MIPS32R6-LABEL: f1: ; MIPS32R6: # %bb.0: ; MIPS32R6-NEXT: lui $1, %hi(a) # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: jr $ra # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: sb $4, %lo(a)($1) # ; MIPS32R6-NEXT: # ; MIPS32R6-NEXT: # > ; ; MMR6-LABEL: f1: ; MMR6: # %bb.0: ; MMR6-NEXT: lui $1, %hi(a) # ; MMR6-NEXT: # > ; MMR6-NEXT: sb $4, %lo(a)($1) # ; MMR6-NEXT: # ; MMR6-NEXT: # > ; MMR6-NEXT: jrc $ra # > ; ; MIPS4-LABEL: f1: ; MIPS4: # %bb.0: ; MIPS4-NEXT: lui $1, %highest(a) # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $1, $1, %higher(a) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $1, $1, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $1, $1, %hi(a) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $1, $1, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: jr $ra # > ; MIPS4-NEXT: sb $4, %lo(a)($1) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; ; MIPS64R6-LABEL: f1: ; MIPS64R6: # %bb.0: ; MIPS64R6-NEXT: lui $1, %highest(a) # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $1, $1, %higher(a) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $1, $1, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $1, $1, %hi(a) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $1, $1, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: jr $ra # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: sb $4, %lo(a)($1) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > store i8 %a, i8 * @a ret void } define void @f2(i16 %a) { ; MIPS32-LABEL: f2: ; MIPS32: # %bb.0: ; MIPS32-NEXT: lui $1, %hi(b) # ; MIPS32-NEXT: # > ; MIPS32-NEXT: jr $ra # > ; MIPS32-NEXT: sh $4, %lo(b)($1) # ; MIPS32-NEXT: # ; MIPS32-NEXT: # > ; ; MMR3-LABEL: f2: ; MMR3: # %bb.0: ; MMR3-NEXT: lui $1, %hi(b) # ; MMR3-NEXT: # > ; MMR3-NEXT: jr $ra # > ; MMR3-NEXT: sh $4, %lo(b)($1) # ; MMR3-NEXT: # ; MMR3-NEXT: # > ; ; MIPS32R6-LABEL: f2: ; MIPS32R6: # %bb.0: ; MIPS32R6-NEXT: lui $1, %hi(b) # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: jr $ra # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: sh $4, %lo(b)($1) # ; MIPS32R6-NEXT: # ; MIPS32R6-NEXT: # > ; ; MMR6-LABEL: f2: ; MMR6: # %bb.0: ; MMR6-NEXT: lui $1, %hi(b) # ; MMR6-NEXT: # > ; MMR6-NEXT: sh $4, %lo(b)($1) # ; MMR6-NEXT: # ; MMR6-NEXT: # > ; MMR6-NEXT: jrc $ra # > ; ; MIPS4-LABEL: f2: ; MIPS4: # %bb.0: ; MIPS4-NEXT: lui $1, %highest(b) # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $1, $1, %higher(b) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $1, $1, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $1, $1, %hi(b) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $1, $1, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: jr $ra # > ; MIPS4-NEXT: sh $4, %lo(b)($1) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; ; MIPS64R6-LABEL: f2: ; MIPS64R6: # %bb.0: ; MIPS64R6-NEXT: lui $1, %highest(b) # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $1, $1, %higher(b) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $1, $1, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $1, $1, %hi(b) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $1, $1, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: jr $ra # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: sh $4, %lo(b)($1) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > store i16 %a, i16 * @b ret void } define void @f3(i32 %a) { ; MIPS32-LABEL: f3: ; MIPS32: # %bb.0: ; MIPS32-NEXT: lui $1, %hi(c) # ; MIPS32-NEXT: # > ; MIPS32-NEXT: jr $ra # > ; MIPS32-NEXT: sw $4, %lo(c)($1) # ; MIPS32-NEXT: # ; MIPS32-NEXT: # > ; ; MMR3-LABEL: f3: ; MMR3: # %bb.0: ; MMR3-NEXT: lui $1, %hi(c) # ; MMR3-NEXT: # > ; MMR3-NEXT: jr $ra # > ; MMR3-NEXT: sw $4, %lo(c)($1) # ; MMR3-NEXT: # ; MMR3-NEXT: # > ; ; MIPS32R6-LABEL: f3: ; MIPS32R6: # %bb.0: ; MIPS32R6-NEXT: lui $1, %hi(c) # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: jr $ra # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: sw $4, %lo(c)($1) # ; MIPS32R6-NEXT: # ; MIPS32R6-NEXT: # > ; ; MMR6-LABEL: f3: ; MMR6: # %bb.0: ; MMR6-NEXT: lui $1, %hi(c) # ; MMR6-NEXT: # > ; MMR6-NEXT: sw $4, %lo(c)($1) # ; MMR6-NEXT: # ; MMR6-NEXT: # > ; MMR6-NEXT: jrc $ra # > ; ; MIPS4-LABEL: f3: ; MIPS4: # %bb.0: ; MIPS4-NEXT: sll $1, $4, 0 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: lui $2, %highest(c) # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $2, $2, %higher(c) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $2, $2, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $2, $2, %hi(c) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $2, $2, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: jr $ra # > ; MIPS4-NEXT: sw $1, %lo(c)($2) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; ; MIPS64R6-LABEL: f3: ; MIPS64R6: # %bb.0: ; MIPS64R6-NEXT: sll $1, $4, 0 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: lui $2, %highest(c) # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $2, $2, %higher(c) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $2, $2, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $2, $2, %hi(c) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $2, $2, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: jr $ra # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: sw $1, %lo(c)($2) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > store i32 %a, i32 * @c ret void } define void @f4(i64 %a) { ; MIPS32-LABEL: f4: ; MIPS32: # %bb.0: ; MIPS32-NEXT: lui $1, %hi(d) # ; MIPS32-NEXT: # > ; MIPS32-NEXT: sw $4, %lo(d)($1) # ; MIPS32-NEXT: # ; MIPS32-NEXT: # > ; MIPS32-NEXT: addiu $1, $1, %lo(d) # ; MIPS32-NEXT: # ; MIPS32-NEXT: # > ; MIPS32-NEXT: jr $ra # > ; MIPS32-NEXT: sw $5, 4($1) # ; MIPS32-NEXT: # ; MIPS32-NEXT: # > ; ; MMR3-LABEL: f4: ; MMR3: # %bb.0: ; MMR3-NEXT: lui $1, %hi(d) # ; MMR3-NEXT: # > ; MMR3-NEXT: sw $4, %lo(d)($1) # ; MMR3-NEXT: # ; MMR3-NEXT: # > ; MMR3-NEXT: addiu $2, $1, %lo(d) # ; MMR3-NEXT: # ; MMR3-NEXT: # > ; MMR3-NEXT: sw16 $5, 4($2) # ; MMR3-NEXT: # ; MMR3-NEXT: # > ; MMR3-NEXT: jrc $ra # > ; ; MIPS32R6-LABEL: f4: ; MIPS32R6: # %bb.0: ; MIPS32R6-NEXT: lui $1, %hi(d) # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: sw $4, %lo(d)($1) # ; MIPS32R6-NEXT: # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: addiu $1, $1, %lo(d) # ; MIPS32R6-NEXT: # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: jr $ra # ; MIPS32R6-NEXT: # > ; MIPS32R6-NEXT: sw $5, 4($1) # ; MIPS32R6-NEXT: # ; MIPS32R6-NEXT: # > ; ; MMR6-LABEL: f4: ; MMR6: # %bb.0: ; MMR6-NEXT: lui $1, %hi(d) # ; MMR6-NEXT: # > ; MMR6-NEXT: sw $4, %lo(d)($1) # ; MMR6-NEXT: # ; MMR6-NEXT: # > ; MMR6-NEXT: addiu $2, $1, %lo(d) # ; MMR6-NEXT: # ; MMR6-NEXT: # > ; MMR6-NEXT: sw16 $5, 4($2) # ; MMR6-NEXT: # ; MMR6-NEXT: # > ; MMR6-NEXT: jrc $ra # > ; ; MIPS4-LABEL: f4: ; MIPS4: # %bb.0: ; MIPS4-NEXT: lui $1, %highest(d) # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $1, $1, %higher(d) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $1, $1, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: daddiu $1, $1, %hi(d) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: dsll $1, $1, 16 # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; MIPS4-NEXT: jr $ra # > ; MIPS4-NEXT: sd $4, %lo(d)($1) # ; MIPS4-NEXT: # ; MIPS4-NEXT: # > ; ; MIPS64R6-LABEL: f4: ; MIPS64R6: # %bb.0: ; MIPS64R6-NEXT: lui $1, %highest(d) # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $1, $1, %higher(d) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $1, $1, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: daddiu $1, $1, %hi(d) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: dsll $1, $1, 16 # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: jr $ra # ; MIPS64R6-NEXT: # > ; MIPS64R6-NEXT: sd $4, %lo(d)($1) # ; MIPS64R6-NEXT: # ; MIPS64R6-NEXT: # > store i64 %a, i64 * @d ret void }