1*9880d681SAndroid Build Coastguard Worker# RUN: llc -start-after=dead-mi-elimination -stop-after=twoaddressinstruction -o - %s | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker--- | 4*9880d681SAndroid Build Coastguard Worker target datalayout = "E-m:e-i64:64-n32:64" 5*9880d681SAndroid Build Coastguard Worker target triple = "powerpc64-unknown-linux-gnu" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker @d = global i32 15, align 4 8*9880d681SAndroid Build Coastguard Worker @b = global i32* @d, align 8 9*9880d681SAndroid Build Coastguard Worker @a = common global i32 0, align 4 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker ; Function Attrs: nounwind 12*9880d681SAndroid Build Coastguard Worker define signext i32 @main() #0 { 13*9880d681SAndroid Build Coastguard Worker entry: 14*9880d681SAndroid Build Coastguard Worker %0 = load i32*, i32** @b, align 8 15*9880d681SAndroid Build Coastguard Worker %1 = load i32, i32* @a, align 4 16*9880d681SAndroid Build Coastguard Worker %lnot = icmp eq i32 %1, 0 17*9880d681SAndroid Build Coastguard Worker %lnot.ext = zext i1 %lnot to i32 18*9880d681SAndroid Build Coastguard Worker %shr.i = lshr i32 2072, %lnot.ext 19*9880d681SAndroid Build Coastguard Worker %call.lobit = lshr i32 %shr.i, 7 20*9880d681SAndroid Build Coastguard Worker %2 = and i32 %call.lobit, 1 21*9880d681SAndroid Build Coastguard Worker %3 = load i32, i32* %0, align 4 22*9880d681SAndroid Build Coastguard Worker %or = or i32 %2, %3 23*9880d681SAndroid Build Coastguard Worker store i32 %or, i32* %0, align 4 24*9880d681SAndroid Build Coastguard Worker %4 = load i32, i32* @a, align 4 25*9880d681SAndroid Build Coastguard Worker %lnot.1 = icmp eq i32 %4, 0 26*9880d681SAndroid Build Coastguard Worker %lnot.ext.1 = zext i1 %lnot.1 to i32 27*9880d681SAndroid Build Coastguard Worker %shr.i.1 = lshr i32 2072, %lnot.ext.1 28*9880d681SAndroid Build Coastguard Worker %call.lobit.1 = lshr i32 %shr.i.1, 7 29*9880d681SAndroid Build Coastguard Worker %5 = and i32 %call.lobit.1, 1 30*9880d681SAndroid Build Coastguard Worker %or.1 = or i32 %5, %or 31*9880d681SAndroid Build Coastguard Worker store i32 %or.1, i32* %0, align 4 32*9880d681SAndroid Build Coastguard Worker ret i32 %or.1 33*9880d681SAndroid Build Coastguard Worker } 34*9880d681SAndroid Build Coastguard Worker 35*9880d681SAndroid Build Coastguard Worker attributes #0 = { nounwind "target-cpu"="ppc64" } 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Worker... 38*9880d681SAndroid Build Coastguard Worker--- 39*9880d681SAndroid Build Coastguard Workername: main 40*9880d681SAndroid Build Coastguard Workeralignment: 2 41*9880d681SAndroid Build Coastguard WorkerexposesReturnsTwice: false 42*9880d681SAndroid Build Coastguard WorkerhasInlineAsm: false 43*9880d681SAndroid Build Coastguard WorkerisSSA: true 44*9880d681SAndroid Build Coastguard WorkertracksRegLiveness: true 45*9880d681SAndroid Build Coastguard WorkertracksSubRegLiveness: false 46*9880d681SAndroid Build Coastguard Workerregisters: 47*9880d681SAndroid Build Coastguard Worker - { id: 0, class: g8rc_and_g8rc_nox0 } 48*9880d681SAndroid Build Coastguard Worker - { id: 1, class: g8rc_and_g8rc_nox0 } 49*9880d681SAndroid Build Coastguard Worker - { id: 2, class: gprc } 50*9880d681SAndroid Build Coastguard Worker - { id: 3, class: gprc } 51*9880d681SAndroid Build Coastguard Worker - { id: 4, class: gprc } 52*9880d681SAndroid Build Coastguard Worker - { id: 5, class: g8rc_and_g8rc_nox0 } 53*9880d681SAndroid Build Coastguard Worker - { id: 6, class: g8rc_and_g8rc_nox0 } 54*9880d681SAndroid Build Coastguard Worker - { id: 7, class: gprc } 55*9880d681SAndroid Build Coastguard Worker - { id: 8, class: gprc } 56*9880d681SAndroid Build Coastguard Worker - { id: 9, class: gprc } 57*9880d681SAndroid Build Coastguard Worker - { id: 10, class: g8rc } 58*9880d681SAndroid Build Coastguard WorkerframeInfo: 59*9880d681SAndroid Build Coastguard Worker isFrameAddressTaken: false 60*9880d681SAndroid Build Coastguard Worker isReturnAddressTaken: false 61*9880d681SAndroid Build Coastguard Worker hasStackMap: false 62*9880d681SAndroid Build Coastguard Worker hasPatchPoint: false 63*9880d681SAndroid Build Coastguard Worker stackSize: 0 64*9880d681SAndroid Build Coastguard Worker offsetAdjustment: 0 65*9880d681SAndroid Build Coastguard Worker maxAlignment: 0 66*9880d681SAndroid Build Coastguard Worker adjustsStack: false 67*9880d681SAndroid Build Coastguard Worker hasCalls: false 68*9880d681SAndroid Build Coastguard Worker maxCallFrameSize: 0 69*9880d681SAndroid Build Coastguard Worker hasOpaqueSPAdjustment: false 70*9880d681SAndroid Build Coastguard Worker hasVAStart: false 71*9880d681SAndroid Build Coastguard Worker hasMustTailInVarArgFunc: false 72*9880d681SAndroid Build Coastguard Workerbody: | 73*9880d681SAndroid Build Coastguard Worker bb.0.entry: 74*9880d681SAndroid Build Coastguard Worker liveins: %x2 75*9880d681SAndroid Build Coastguard Worker 76*9880d681SAndroid Build Coastguard Worker %0 = ADDIStocHA %x2, @b 77*9880d681SAndroid Build Coastguard Worker %1 = LD target-flags(ppc-toc-lo) @b, killed %0 :: (load 8 from @b) 78*9880d681SAndroid Build Coastguard Worker %2 = LWZ 0, %1 :: (load 4 from %ir.0) 79*9880d681SAndroid Build Coastguard Worker %3 = LI 0 80*9880d681SAndroid Build Coastguard Worker %4 = RLWIMI %3, killed %2, 0, 0, 31 81*9880d681SAndroid Build Coastguard Worker ; CHECK-LABEL: name: main 82*9880d681SAndroid Build Coastguard Worker ; CHECK: %[[REG1:[0-9]+]] = LI 0 83*9880d681SAndroid Build Coastguard Worker ; CHECK: %[[REG2:[0-9]+]] = COPY %[[REG1]] 84*9880d681SAndroid Build Coastguard Worker ; CHECK: %[[REG2]] = RLWIMI %[[REG2]], killed %2, 0, 0, 31 85*9880d681SAndroid Build Coastguard Worker %8 = RLWIMI %3, %4, 0, 0, 31 86*9880d681SAndroid Build Coastguard Worker STW %4, 0, %1 :: (store 4 into %ir.0) 87*9880d681SAndroid Build Coastguard Worker %10 = EXTSW_32_64 %8 88*9880d681SAndroid Build Coastguard Worker STW %8, 0, %1 :: (store 4 into %ir.0) 89*9880d681SAndroid Build Coastguard Worker %x3 = COPY %10 90*9880d681SAndroid Build Coastguard Worker BLR8 implicit %x3, implicit %lr8, implicit %rm 91*9880d681SAndroid Build Coastguard Worker 92*9880d681SAndroid Build Coastguard Worker... 93