1*c4ce967eSTim Northover# RUN: llc -mtriple=thumbv6m-apple-unknown-macho --run-pass=arm-cp-islands -o - %s | FileCheck %s 2*c4ce967eSTim Northover--- | 3*c4ce967eSTim Northover ; ModuleID = 'test.ll' 4*c4ce967eSTim Northover source_filename = "simple.ll" 5*c4ce967eSTim Northover target datalayout = "e-m:o-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64" 6*c4ce967eSTim Northover target triple = "thumbv6m-apple-unknown-macho" 7*c4ce967eSTim Northover 8*c4ce967eSTim Northover define i32 @foo(i32 %in) !dbg !5 { 9*c4ce967eSTim Northover call void @llvm.dbg.value(metadata i32 0, metadata !9, metadata !DIExpression()), !dbg !11 10*c4ce967eSTim Northover switch i32 %in, label %default [ 11*c4ce967eSTim Northover i32 0, label %l0 12*c4ce967eSTim Northover i32 1, label %l1 13*c4ce967eSTim Northover i32 2, label %l2 14*c4ce967eSTim Northover i32 3, label %l3 15*c4ce967eSTim Northover ], !dbg !11 16*c4ce967eSTim Northover 17*c4ce967eSTim Northover default: ; preds = %0 18*c4ce967eSTim Northover ret i32 42, !dbg !12 19*c4ce967eSTim Northover 20*c4ce967eSTim Northover l0: ; preds = %0 21*c4ce967eSTim Northover ret i32 0, !dbg !13 22*c4ce967eSTim Northover 23*c4ce967eSTim Northover l1: ; preds = %0 24*c4ce967eSTim Northover ret i32 1, !dbg !14 25*c4ce967eSTim Northover 26*c4ce967eSTim Northover l2: ; preds = %0 27*c4ce967eSTim Northover ret i32 2, !dbg !15 28*c4ce967eSTim Northover 29*c4ce967eSTim Northover l3: ; preds = %0 30*c4ce967eSTim Northover ret i32 3, !dbg !16 31*c4ce967eSTim Northover } 32*c4ce967eSTim Northover 33*c4ce967eSTim Northover ; Function Attrs: nocallback nofree nosync nounwind speculatable willreturn memory(none) 34*c4ce967eSTim Northover declare void @llvm.dbg.value(metadata, metadata, metadata) #0 35*c4ce967eSTim Northover 36*c4ce967eSTim Northover attributes #0 = { nocallback nofree nosync nounwind speculatable willreturn memory(none) } 37*c4ce967eSTim Northover 38*c4ce967eSTim Northover !llvm.dbg.cu = !{!0} 39*c4ce967eSTim Northover !llvm.debugify = !{!2, !3} 40*c4ce967eSTim Northover !llvm.module.flags = !{!4} 41*c4ce967eSTim Northover 42*c4ce967eSTim Northover !0 = distinct !DICompileUnit(language: DW_LANG_C, file: !1, producer: "debugify", isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug) 43*c4ce967eSTim Northover !1 = !DIFile(filename: "simple.ll", directory: "/") 44*c4ce967eSTim Northover !2 = !{i32 6} 45*c4ce967eSTim Northover !3 = !{i32 1} 46*c4ce967eSTim Northover !4 = !{i32 2, !"Debug Info Version", i32 3} 47*c4ce967eSTim Northover !5 = distinct !DISubprogram(name: "foo", linkageName: "foo", scope: null, file: !1, line: 1, type: !6, scopeLine: 1, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0, retainedNodes: !8) 48*c4ce967eSTim Northover !6 = !DISubroutineType(types: !7) 49*c4ce967eSTim Northover !7 = !{} 50*c4ce967eSTim Northover !8 = !{!9} 51*c4ce967eSTim Northover !9 = !DILocalVariable(name: "1", scope: !5, file: !1, line: 1, type: !10) 52*c4ce967eSTim Northover !10 = !DIBasicType(name: "ty32", size: 32, encoding: DW_ATE_unsigned) 53*c4ce967eSTim Northover !11 = !DILocation(line: 1, column: 1, scope: !5) 54*c4ce967eSTim Northover !12 = !DILocation(line: 2, column: 1, scope: !5) 55*c4ce967eSTim Northover !13 = !DILocation(line: 3, column: 1, scope: !5) 56*c4ce967eSTim Northover !14 = !DILocation(line: 4, column: 1, scope: !5) 57*c4ce967eSTim Northover !15 = !DILocation(line: 5, column: 1, scope: !5) 58*c4ce967eSTim Northover !16 = !DILocation(line: 6, column: 1, scope: !5) 59*c4ce967eSTim Northover 60*c4ce967eSTim Northover... 61*c4ce967eSTim Northover--- 62*c4ce967eSTim Northovername: foo 63*c4ce967eSTim Northoveralignment: 2 64*c4ce967eSTim NorthoverexposesReturnsTwice: false 65*c4ce967eSTim Northoverlegalized: false 66*c4ce967eSTim NorthoverregBankSelected: false 67*c4ce967eSTim Northoverselected: false 68*c4ce967eSTim NorthoverfailedISel: false 69*c4ce967eSTim NorthovertracksRegLiveness: true 70*c4ce967eSTim NorthoverhasWinCFI: false 71*c4ce967eSTim NorthovercallsEHReturn: false 72*c4ce967eSTim NorthovercallsUnwindInit: false 73*c4ce967eSTim NorthoverhasEHCatchret: false 74*c4ce967eSTim NorthoverhasEHScopes: false 75*c4ce967eSTim NorthoverhasEHFunclets: false 76*c4ce967eSTim NorthoverdebugInstrRef: false 77*c4ce967eSTim NorthoverfailsVerification: false 78*c4ce967eSTim NorthovertracksDebugUserValues: true 79*c4ce967eSTim Northoverregisters: [] 80*c4ce967eSTim Northoverliveins: 81*c4ce967eSTim Northover - { reg: '$r0', virtual-reg: '' } 82*c4ce967eSTim NorthoverframeInfo: 83*c4ce967eSTim Northover isFrameAddressTaken: false 84*c4ce967eSTim Northover isReturnAddressTaken: false 85*c4ce967eSTim Northover hasStackMap: false 86*c4ce967eSTim Northover hasPatchPoint: false 87*c4ce967eSTim Northover stackSize: 0 88*c4ce967eSTim Northover offsetAdjustment: 0 89*c4ce967eSTim Northover maxAlignment: 1 90*c4ce967eSTim Northover adjustsStack: false 91*c4ce967eSTim Northover hasCalls: false 92*c4ce967eSTim Northover stackProtector: '' 93*c4ce967eSTim Northover functionContext: '' 94*c4ce967eSTim Northover maxCallFrameSize: 0 95*c4ce967eSTim Northover cvBytesOfCalleeSavedRegisters: 0 96*c4ce967eSTim Northover hasOpaqueSPAdjustment: false 97*c4ce967eSTim Northover hasVAStart: false 98*c4ce967eSTim Northover hasMustTailInVarArgFunc: false 99*c4ce967eSTim Northover hasTailCall: false 100*c4ce967eSTim Northover localFrameSize: 0 101*c4ce967eSTim Northover savePoint: '' 102*c4ce967eSTim Northover restorePoint: '' 103*c4ce967eSTim NorthoverfixedStack: [] 104*c4ce967eSTim Northoverstack: [] 105*c4ce967eSTim NorthovercallSites: [] 106*c4ce967eSTim NorthoverdebugValueSubstitutions: [] 107*c4ce967eSTim Northoverconstants: [] 108*c4ce967eSTim NorthovermachineFunctionInfo: {} 109*c4ce967eSTim NorthoverjumpTable: 110*c4ce967eSTim Northover kind: inline 111*c4ce967eSTim Northover entries: 112*c4ce967eSTim Northover - id: 0 113*c4ce967eSTim Northover blocks: [ '%bb.3', '%bb.4', '%bb.5', '%bb.6' ] 114*c4ce967eSTim Northoverbody: | 115*c4ce967eSTim Northover bb.0 (%ir-block.0): 116*c4ce967eSTim Northover successors: %bb.2(0x19999998), %bb.1(0x66666668) 117*c4ce967eSTim Northover liveins: $r0 118*c4ce967eSTim Northover 119*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 120*c4ce967eSTim Northover tCMPi8 renamable $r0, 3, 14 /* CC::al */, $noreg, implicit-def $cpsr, debug-location !11 121*c4ce967eSTim Northover tBcc %bb.2, 8 /* CC::hi */, killed $cpsr, debug-location !11 122*c4ce967eSTim Northover 123*c4ce967eSTim Northover bb.1 (%ir-block.0): 124*c4ce967eSTim Northover successors: %bb.3(0x20000000), %bb.4(0x20000000), %bb.5(0x20000000), %bb.6(0x20000000) 125*c4ce967eSTim Northover liveins: $r0 126*c4ce967eSTim Northover 127*c4ce967eSTim Northover renamable $r0, dead $cpsr = tLSLri killed renamable $r0, 2, 14 /* CC::al */, $noreg 128*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 129*c4ce967eSTim Northover renamable $r1 = tLEApcrelJT %jump-table.0, 14 /* CC::al */, $noreg 130*c4ce967eSTim Northover renamable $r0 = tLDRr renamable $r1, killed renamable $r0, 14 /* CC::al */, $noreg :: (load (s32) from jump-table) 131*c4ce967eSTim Northover renamable $r0, dead $cpsr = tADDrr killed renamable $r1, killed renamable $r0, 14 /* CC::al */, $noreg 132*c4ce967eSTim Northover tBR_JTr killed renamable $r0, %jump-table.0 133*c4ce967eSTim Northover ; CHECK: tTBB_JT 134*c4ce967eSTim Northover 135*c4ce967eSTim Northover bb.3.l0: 136*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 137*c4ce967eSTim Northover renamable $r0, dead $cpsr = tMOVi8 0, 14 /* CC::al */, $noreg 138*c4ce967eSTim Northover tBX_RET 14 /* CC::al */, $noreg, implicit $r0, debug-location !13 139*c4ce967eSTim Northover 140*c4ce967eSTim Northover bb.2.default: 141*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 142*c4ce967eSTim Northover renamable $r0, dead $cpsr = tMOVi8 42, 14 /* CC::al */, $noreg 143*c4ce967eSTim Northover tBX_RET 14 /* CC::al */, $noreg, implicit $r0, debug-location !12 144*c4ce967eSTim Northover 145*c4ce967eSTim Northover bb.4.l1: 146*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 147*c4ce967eSTim Northover renamable $r0, dead $cpsr = tMOVi8 1, 14 /* CC::al */, $noreg 148*c4ce967eSTim Northover tBX_RET 14 /* CC::al */, $noreg, implicit $r0, debug-location !14 149*c4ce967eSTim Northover 150*c4ce967eSTim Northover bb.5.l2: 151*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 152*c4ce967eSTim Northover renamable $r0, dead $cpsr = tMOVi8 2, 14 /* CC::al */, $noreg 153*c4ce967eSTim Northover tBX_RET 14 /* CC::al */, $noreg, implicit $r0, debug-location !15 154*c4ce967eSTim Northover 155*c4ce967eSTim Northover bb.6.l3: 156*c4ce967eSTim Northover DBG_VALUE 0, $noreg, !9, !DIExpression(), debug-location !11 157*c4ce967eSTim Northover renamable $r0, dead $cpsr = tMOVi8 3, 14 /* CC::al */, $noreg 158*c4ce967eSTim Northover tBX_RET 14 /* CC::al */, $noreg, implicit $r0, debug-location !16 159*c4ce967eSTim Northover 160*c4ce967eSTim Northover... 161