blob: 4f29fd848aed51619eaf2f62fb2d5077532e2b61 [file] [log] [blame]
; 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=mips3 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS3
; RUN: llc -mtriple=mips64-mti-linux-gnu -mcpu=mips64 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS64
; RUN: llc -mtriple=mips64-img-linux-gnu -mcpu=mips64r6 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS64R6
; RUN: llc -mtriple=mips-mti-linux-gnu -mcpu=mips32r2 -mattr=+micromips,+fp64 < %s -asm-show-inst | FileCheck %s --check-prefix=MMR5FP64
; RUN: llc -mtriple=mips-mti-linux-gnu -mcpu=mips32r5 -mattr=+fp64 < %s -asm-show-inst | FileCheck %s --check-prefix=MIPS32R5FP643
; Test subword and word loads. We use -asm-show-inst to test that the produced
; instructions match the expected ISA.
; NOTE: As the -asm-show-inst shows the internal numbering of instructions
; and registers, these numbers have been replaced with wildcard regexes.
@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
@e = common global float 0.0, align 4
@f = common global double 0.0, align 8
define i8 @f1() {
; MIPS32-LABEL: f1:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST1:]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1:]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2:]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2:]]>>
; MIPS32-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST3:]] LBu
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MMR3-LABEL: f1:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST4:]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1:]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5:]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2:]]>>
; MMR3-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST6:]] LBu_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS32R6-LABEL: f1:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST1:]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1:]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7:]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4:]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2:]]>>
; MIPS32R6-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST3:]] LBu
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MMR6-LABEL: f1:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST4:]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1:]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MMR6-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST6:]] LBu_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,a)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8:]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2:]]>>
;
; MIPS3-LABEL: f1:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(a) # <MCInst #[[#MCINST9:]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5:]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,a)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(a) # <MCInst #[[#MCINST10:]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,a)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11:]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2:]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6:]]>>
; MIPS3-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST3:]] LBu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS64-LABEL: f1:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(a) # <MCInst #[[#MCINST9:]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5:]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,a)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(a) # <MCInst #[[#MCINST10:]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,a)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11:]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2:]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6:]]>>
; MIPS64-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST3:]] LBu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS64R6-LABEL: f1:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(a) # <MCInst #[[#MCINST9:]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5:]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,a)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(a) # <MCInst #[[#MCINST10:]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,a)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11:]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12:]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7:]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6:]]>>
; MIPS64R6-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST3:]] LBu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MMR5FP64-LABEL: f1:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST4:]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1:]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5:]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2:]]>>
; MMR5FP64-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST6:]] LBu_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS32R5FP643-LABEL: f1:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST1:]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1:]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2:]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2:]]>>
; MIPS32R5FP643-NEXT: lbu $2, %lo(a)($1) # <MCInst #[[#MCINST3:]] LBu
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3:]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,a)>>
entry:
%0 = load i8, ptr @a
ret i8 %0
}
define i32 @f2() {
; MIPS32-LABEL: f2:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST13:]] LB
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MMR3-LABEL: f2:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST14:]] LB_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS32R6-LABEL: f2:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST13:]] LB
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MMR6-LABEL: f2:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MMR6-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST14:]] LB_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,a)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f2:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(a) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,a)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,a)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST13:]] LB
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS64-LABEL: f2:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(a) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,a)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,a)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST13:]] LB
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS64R6-LABEL: f2:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(a) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,a)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,a)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(a) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST13:]] LB
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MMR5FP64-LABEL: f2:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST14:]] LB_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,a)>>
;
; MIPS32R5FP643-LABEL: f2:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(a) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,a)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: lb $2, %lo(a)($1) # <MCInst #[[#MCINST13:]] LB
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,a)>>
entry:
%0 = load i8, ptr @a
%1 = sext i8 %0 to i32
ret i32 %1
}
define i16 @f3() {
; MIPS32-LABEL: f3:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST15:]] LHu
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MMR3-LABEL: f3:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST16:]] LHu_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS32R6-LABEL: f3:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST15:]] LHu
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MMR6-LABEL: f3:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MMR6-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST16:]] LHu_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,b)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f3:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(b) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,b)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,b)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST15:]] LHu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS64-LABEL: f3:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(b) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,b)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,b)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST15:]] LHu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS64R6-LABEL: f3:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(b) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,b)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,b)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST15:]] LHu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MMR5FP64-LABEL: f3:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST16:]] LHu_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS32R5FP643-LABEL: f3:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: lhu $2, %lo(b)($1) # <MCInst #[[#MCINST15:]] LHu
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,b)>>
entry:
%0 = load i16, ptr @b
ret i16 %0
}
define i32 @f4() {
; MIPS32-LABEL: f4:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST17:]] LH
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MMR3-LABEL: f4:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST18:]] LH_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS32R6-LABEL: f4:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST17:]] LH
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MMR6-LABEL: f4:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MMR6-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST18:]] LH_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,b)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f4:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(b) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,b)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,b)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST17:]] LH
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS64-LABEL: f4:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(b) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,b)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,b)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST17:]] LH
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS64R6-LABEL: f4:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(b) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,b)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,b)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(b) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST17:]] LH
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MMR5FP64-LABEL: f4:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST18:]] LH_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,b)>>
;
; MIPS32R5FP643-LABEL: f4:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(b) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,b)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: lh $2, %lo(b)($1) # <MCInst #[[#MCINST17:]] LH
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,b)>>
entry:
%0 = load i16, ptr @b
%1 = sext i16 %0 to i32
ret i32 %1
}
define i32 @f5() {
; MIPS32-LABEL: f5:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST19:]] LW
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MMR3-LABEL: f5:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST20:]] LW_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS32R6-LABEL: f5:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST19:]] LW
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MMR6-LABEL: f5:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR6-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST20:]] LW_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f5:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST19:]] LW
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS64-LABEL: f5:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST19:]] LW
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS64R6-LABEL: f5:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST19:]] LW
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MMR5FP64-LABEL: f5:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST20:]] LW_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS32R5FP643-LABEL: f5:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST19:]] LW
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,c)>>
entry:
%0 = load i32, ptr @c
ret i32 %0
}
define i64 @f6() {
; MIPS32-LABEL: f6:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST19]] LW
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG8:]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: addiu $2, $zero, 0 # <MCInst #[[#MCINST21:]] ADDiu
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG4:]]>
; MIPS32-NEXT: # <MCOperand Imm:0>>
;
; MMR3-LABEL: f6:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR3-NEXT: li16 $2, 0 # <MCInst #[[#MCINST22:]] LI16_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR3-NEXT: # <MCOperand Imm:0>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST20]] LW_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG8:]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS32R6-LABEL: f6:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32R6-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST19]] LW
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG8:]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: addiu $2, $zero, 0 # <MCInst #[[#MCINST21:]] ADDiu
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Imm:0>>
;
; MMR6-LABEL: f6:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR6-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST20]] LW_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG8:]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MMR6-NEXT: li16 $2, 0 # <MCInst #[[#MCINST22:]] LI16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR6-NEXT: # <MCOperand Imm:0>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f6:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lwu $2, %lo(c)($1) # <MCInst #[[#MCINST23:]] LWu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG9:]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS64-LABEL: f6:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lwu $2, %lo(c)($1) # <MCInst #[[#MCINST23:]] LWu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG9:]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS64R6-LABEL: f6:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lwu $2, %lo(c)($1) # <MCInst #[[#MCINST23:]] LWu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG9:]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MMR5FP64-LABEL: f6:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR5FP64-NEXT: li16 $2, 0 # <MCInst #[[#MCINST22:]] LI16_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR5FP64-NEXT: # <MCOperand Imm:0>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST20]] LW_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG8:]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS32R5FP643-LABEL: f6:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32R5FP643-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST19]] LW
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG8:]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: addiu $2, $zero, 0 # <MCInst #[[#MCINST21:]] ADDiu
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG4:]]>
; MIPS32R5FP643-NEXT: # <MCOperand Imm:0>>
entry:
%0 = load i32, ptr @c
%1 = zext i32 %0 to i64
ret i64 %1
}
define i64 @f7() {
; MIPS32-LABEL: f7:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST19]] LW
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: sra $2, $3, 31 # <MCInst #[[#MCINST24:]] SRA
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MIPS32-NEXT: # <MCOperand Imm:31>>
;
; MMR3-LABEL: f7:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR3-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST20]] LW_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: sra $2, $3, 31 # <MCInst #[[#MCINST25:]] SRA_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MMR3-NEXT: # <MCOperand Imm:31>>
;
; MIPS32R6-LABEL: f7:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32R6-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST19]] LW
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: sra $2, $3, 31 # <MCInst #[[#MCINST24:]] SRA
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MIPS32R6-NEXT: # <MCOperand Imm:31>>
;
; MMR6-LABEL: f7:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR6-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST20]] LW_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MMR6-NEXT: sra $2, $3, 31 # <MCInst #[[#MCINST25:]] SRA_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MMR6-NEXT: # <MCOperand Imm:31>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f7:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST26:]] LW64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG9]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS64-LABEL: f7:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST26:]] LW64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG9]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MIPS64R6-LABEL: f7:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(c) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,c)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,c)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(c) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lw $2, %lo(c)($1) # <MCInst #[[#MCINST26:]] LW64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG9]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,c)>>
;
; MMR5FP64-LABEL: f7:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MMR5FP64-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST20]] LW_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: sra $2, $3, 31 # <MCInst #[[#MCINST25:]] SRA_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MMR5FP64-NEXT: # <MCOperand Imm:31>>
;
; MIPS32R5FP643-LABEL: f7:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(c) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,c)>>
; MIPS32R5FP643-NEXT: lw $3, %lo(c)($1) # <MCInst #[[#MCINST19]] LW
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,c)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: sra $2, $3, 31 # <MCInst #[[#MCINST24:]] SRA
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG3]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG8]]>
; MIPS32R5FP643-NEXT: # <MCOperand Imm:31>>
entry:
%0 = load i32, ptr @c
%1 = sext i32 %0 to i64
ret i64 %1
}
define float @f8() {
; MIPS32-LABEL: f8:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(e) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST27:]] LWC1
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MMR3-LABEL: f8:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(e) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST28:]] LWC1_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MIPS32R6-LABEL: f8:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(e) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST27:]] LWC1
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MMR6-LABEL: f8:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(e) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MMR6-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST28:]] LWC1_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,e)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f8:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(e) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,e)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(e) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,e)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(e) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST27:]] LWC1
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MIPS64-LABEL: f8:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(e) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,e)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(e) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,e)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(e) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST27:]] LWC1
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MIPS64R6-LABEL: f8:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(e) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,e)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(e) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,e)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(e) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST27:]] LWC1
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MMR5FP64-LABEL: f8:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(e) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST28:]] LWC1_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,e)>>
;
; MIPS32R5FP643-LABEL: f8:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(e) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,e)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: lwc1 $f0, %lo(e)($1) # <MCInst #[[#MCINST27:]] LWC1
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG10:]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,e)>>
entry:
%0 = load float, ptr @e
ret float %0
}
define double @f9() {
; MIPS32-LABEL: f9:
; MIPS32: # %bb.0: # %entry
; MIPS32-NEXT: lui $1, %hi(f) # <MCInst #[[#MCINST1]] LUi
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MIPS32-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST29:]] LDC1
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG11:]]>
; MIPS32-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MMR3-LABEL: f9:
; MMR3: # %bb.0: # %entry
; MMR3-NEXT: lui $1, %hi(f) # <MCInst #[[#MCINST4]] LUi_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MMR3-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR3-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST30:]] LDC1_MM_D32
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG11:]]>
; MMR3-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR3-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MIPS32R6-LABEL: f9:
; MIPS32R6: # %bb.0: # %entry
; MIPS32R6-NEXT: lui $1, %hi(f) # <MCInst #[[#MCINST1]] LUi
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MIPS32R6-NEXT: jr $ra # <MCInst #[[#MCINST7]] JALR
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG4]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R6-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST31:]] LDC164
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MIPS32R6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R6-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MMR6-LABEL: f9:
; MMR6: # %bb.0: # %entry
; MMR6-NEXT: lui $1, %hi(f) # <MCInst #[[#MCINST4]] LUi_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MMR6-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST32:]] LDC1_D64_MMR6
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR6-NEXT: # <MCOperand Expr:specifier(4027,f)>>
; MMR6-NEXT: jrc $ra # <MCInst #[[#MCINST8]] JRC16_MM
; MMR6-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
;
; MIPS3-LABEL: f9:
; MIPS3: # %bb.0: # %entry
; MIPS3-NEXT: lui $1, %highest(f) # <MCInst #[[#MCINST9]] LUi64
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4026,f)>>
; MIPS3-NEXT: daddiu $1, $1, %higher(f) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4025,f)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: daddiu $1, $1, %hi(f) # <MCInst #[[#MCINST10]] DADDiu
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MIPS3-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Imm:16>>
; MIPS3-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS3-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST31:]] LDC164
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MIPS3-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS3-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MIPS64-LABEL: f9:
; MIPS64: # %bb.0: # %entry
; MIPS64-NEXT: lui $1, %highest(f) # <MCInst #[[#MCINST9]] LUi64
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4026,f)>>
; MIPS64-NEXT: daddiu $1, $1, %higher(f) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4025,f)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: daddiu $1, $1, %hi(f) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MIPS64-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Imm:16>>
; MIPS64-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST31:]] LDC164
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MIPS64-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MIPS64R6-LABEL: f9:
; MIPS64R6: # %bb.0: # %entry
; MIPS64R6-NEXT: lui $1, %highest(f) # <MCInst #[[#MCINST9]] LUi64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4026,f)>>
; MIPS64R6-NEXT: daddiu $1, $1, %higher(f) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4025,f)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: daddiu $1, $1, %hi(f) # <MCInst #[[#MCINST10]] DADDiu
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MIPS64R6-NEXT: dsll $1, $1, 16 # <MCInst #[[#MCINST11]] DSLL
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Imm:16>>
; MIPS64R6-NEXT: jr $ra # <MCInst #[[#MCINST12]] JALR64
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG7]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG6]]>>
; MIPS64R6-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST31:]] LDC164
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MIPS64R6-NEXT: # <MCOperand Reg:[[#MCREG5]]>
; MIPS64R6-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MMR5FP64-LABEL: f9:
; MMR5FP64: # %bb.0: # %entry
; MMR5FP64-NEXT: lui $1, %hi(f) # <MCInst #[[#MCINST4]] LUi_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MMR5FP64-NEXT: jr $ra # <MCInst #[[#MCINST5]] JR_MM
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MMR5FP64-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST33:]] LDC1_MM_D64
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MMR5FP64-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MMR5FP64-NEXT: # <MCOperand Expr:specifier(4027,f)>>
;
; MIPS32R5FP643-LABEL: f9:
; MIPS32R5FP643: # %bb.0: # %entry
; MIPS32R5FP643-NEXT: lui $1, %hi(f) # <MCInst #[[#MCINST1]] LUi
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4024,f)>>
; MIPS32R5FP643-NEXT: jr $ra # <MCInst #[[#MCINST2]] JR
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG2]]>>
; MIPS32R5FP643-NEXT: ldc1 $f0, %lo(f)($1) # <MCInst #[[#MCINST31:]] LDC164
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG12:]]>
; MIPS32R5FP643-NEXT: # <MCOperand Reg:[[#MCREG1]]>
; MIPS32R5FP643-NEXT: # <MCOperand Expr:specifier(4027,f)>>
entry:
%0 = load double, ptr @f
ret double %0
}