|  | ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | 
|  | ; RUN: llc -ppc-asm-full-reg-names -verify-machineinstrs \ | 
|  | ; RUN:   -mtriple=powerpc64le-linux-gnu < %s | FileCheck \ | 
|  | ; RUN:   -check-prefix=CHECK-LE %s | 
|  | ; RUN: llc -ppc-asm-full-reg-names -verify-machineinstrs \ | 
|  | ; RUN:   -mtriple=powerpc64-linux-gnu -mcpu=ppc < %s | FileCheck \ | 
|  | ; RUN:   -check-prefix=CHECK-BE %s | 
|  | ; RUN: llc -ppc-asm-full-reg-names -verify-machineinstrs \ | 
|  | ; RUN:   -mtriple=powerpc-linux-gnu < %s | FileCheck \ | 
|  | ; RUN:   -check-prefix=CHECK-32 %s | 
|  |  | 
|  | ; Free probe | 
|  | define i8 @f0() #0 nounwind { | 
|  | ; CHECK-LE-LABEL: f0: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, -64(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, -64(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f0: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, -64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, -64(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f0: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    stwu r1, -80(r1) | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    addi r1, r1, 80 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 64 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | define i8 @f1() #0 "stack-probe-size"="0" { | 
|  | ; CHECK-LE-LABEL: f1: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    mr r0, r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-LE-NEXT:    li r12, 259 | 
|  | ; CHECK-LE-NEXT:    mtctr r12 | 
|  | ; CHECK-LE-NEXT:  .LBB1_1: # %entry | 
|  | ; CHECK-LE-NEXT:    # | 
|  | ; CHECK-LE-NEXT:    stdu r0, -16(r1) | 
|  | ; CHECK-LE-NEXT:    bdnz .LBB1_1 | 
|  | ; CHECK-LE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 4144 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    addi r1, r1, 4144 | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f1: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    mr r0, r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-BE-NEXT:    li r12, 260 | 
|  | ; CHECK-BE-NEXT:    mtctr r12 | 
|  | ; CHECK-BE-NEXT:  .LBB1_1: # %entry | 
|  | ; CHECK-BE-NEXT:    # | 
|  | ; CHECK-BE-NEXT:    stdu r0, -16(r1) | 
|  | ; CHECK-BE-NEXT:    bdnz .LBB1_1 | 
|  | ; CHECK-BE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 4160 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    addi r1, r1, 4160 | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f1: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-32-NEXT:    li r12, 257 | 
|  | ; CHECK-32-NEXT:    mtctr r12 | 
|  | ; CHECK-32-NEXT:  .LBB1_1: # %entry | 
|  | ; CHECK-32-NEXT:    # | 
|  | ; CHECK-32-NEXT:    stwu r0, -16(r1) | 
|  | ; CHECK-32-NEXT:    bdnz .LBB1_1 | 
|  | ; CHECK-32-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 4112 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    addi r1, r1, 4112 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 4096 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | define i8 @f2() #0 { | 
|  | ; CHECK-LE-LABEL: f2: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    mr r0, r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-LE-NEXT:    stdu r0, -48(r1) | 
|  | ; CHECK-LE-NEXT:    li r12, 16 | 
|  | ; CHECK-LE-NEXT:    mtctr r12 | 
|  | ; CHECK-LE-NEXT:  .LBB2_1: # %entry | 
|  | ; CHECK-LE-NEXT:    # | 
|  | ; CHECK-LE-NEXT:    stdu r0, -4096(r1) | 
|  | ; CHECK-LE-NEXT:    bdnz .LBB2_1 | 
|  | ; CHECK-LE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 65584 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f2: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    mr r0, r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-BE-NEXT:    stdu r0, -64(r1) | 
|  | ; CHECK-BE-NEXT:    li r12, 16 | 
|  | ; CHECK-BE-NEXT:    mtctr r12 | 
|  | ; CHECK-BE-NEXT:  .LBB2_1: # %entry | 
|  | ; CHECK-BE-NEXT:    # | 
|  | ; CHECK-BE-NEXT:    stdu r0, -4096(r1) | 
|  | ; CHECK-BE-NEXT:    bdnz .LBB2_1 | 
|  | ; CHECK-BE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 65600 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f2: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-32-NEXT:    stwu r0, -16(r1) | 
|  | ; CHECK-32-NEXT:    li r12, 16 | 
|  | ; CHECK-32-NEXT:    mtctr r12 | 
|  | ; CHECK-32-NEXT:  .LBB2_1: # %entry | 
|  | ; CHECK-32-NEXT:    # | 
|  | ; CHECK-32-NEXT:    stwu r0, -4096(r1) | 
|  | ; CHECK-32-NEXT:    bdnz .LBB2_1 | 
|  | ; CHECK-32-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 65552 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 65536 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | define i8 @f3() #0 "stack-probe-size"="32768" { | 
|  | ; CHECK-LE-LABEL: f3: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    mr r0, r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-LE-NEXT:    stdu r0, -48(r1) | 
|  | ; CHECK-LE-NEXT:    stdu r0, -32768(r1) | 
|  | ; CHECK-LE-NEXT:    stdu r0, -32768(r1) | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 65584 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f3: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    mr r0, r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-BE-NEXT:    stdu r0, -64(r1) | 
|  | ; CHECK-BE-NEXT:    stdu r0, -32768(r1) | 
|  | ; CHECK-BE-NEXT:    stdu r0, -32768(r1) | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 65600 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f3: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-32-NEXT:    stwu r0, -16(r1) | 
|  | ; CHECK-32-NEXT:    stwu r0, -32768(r1) | 
|  | ; CHECK-32-NEXT:    stwu r0, -32768(r1) | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 65552 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 65536 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | ; Same as f2, but without protection. | 
|  | define i8 @f4() { | 
|  | ; CHECK-LE-LABEL: f4: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    lis r0, -2 | 
|  | ; CHECK-LE-NEXT:    ori r0, r0, 65488 | 
|  | ; CHECK-LE-NEXT:    stdux r1, r1, r0 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 65584 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f4: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    lis r0, -2 | 
|  | ; CHECK-BE-NEXT:    ori r0, r0, 65472 | 
|  | ; CHECK-BE-NEXT:    stdux r1, r1, r0 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 65600 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f4: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    lis r0, -2 | 
|  | ; CHECK-32-NEXT:    ori r0, r0, 65520 | 
|  | ; CHECK-32-NEXT:    stwux r1, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 65552 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 65536 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | define i8 @f5() #0 "stack-probe-size"="65536" { | 
|  | ; CHECK-LE-LABEL: f5: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    mr r0, r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-LE-NEXT:    stdu r0, -48(r1) | 
|  | ; CHECK-LE-NEXT:    li r12, 16 | 
|  | ; CHECK-LE-NEXT:    mtctr r12 | 
|  | ; CHECK-LE-NEXT:    lis r12, -1 | 
|  | ; CHECK-LE-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-LE-NEXT:  .LBB5_1: # %entry | 
|  | ; CHECK-LE-NEXT:    # | 
|  | ; CHECK-LE-NEXT:    stdux r0, r1, r12 | 
|  | ; CHECK-LE-NEXT:    bdnz .LBB5_1 | 
|  | ; CHECK-LE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 1048624 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f5: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    mr r0, r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-BE-NEXT:    stdu r0, -64(r1) | 
|  | ; CHECK-BE-NEXT:    li r12, 16 | 
|  | ; CHECK-BE-NEXT:    mtctr r12 | 
|  | ; CHECK-BE-NEXT:    lis r12, -1 | 
|  | ; CHECK-BE-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-BE-NEXT:  .LBB5_1: # %entry | 
|  | ; CHECK-BE-NEXT:    # | 
|  | ; CHECK-BE-NEXT:    stdux r0, r1, r12 | 
|  | ; CHECK-BE-NEXT:    bdnz .LBB5_1 | 
|  | ; CHECK-BE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 1048640 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f5: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-32-NEXT:    stwu r0, -16(r1) | 
|  | ; CHECK-32-NEXT:    li r12, 16 | 
|  | ; CHECK-32-NEXT:    mtctr r12 | 
|  | ; CHECK-32-NEXT:    lis r12, -1 | 
|  | ; CHECK-32-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-32-NEXT:  .LBB5_1: # %entry | 
|  | ; CHECK-32-NEXT:    # | 
|  | ; CHECK-32-NEXT:    stwux r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    bdnz .LBB5_1 | 
|  | ; CHECK-32-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 1048592 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 1048576 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | define i8 @f6() #0 { | 
|  | ; CHECK-LE-LABEL: f6: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    mr r0, r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-LE-NEXT:    stdu r0, -48(r1) | 
|  | ; CHECK-LE-NEXT:    lis r12, 4 | 
|  | ; CHECK-LE-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-LE-NEXT:    mtctr r12 | 
|  | ; CHECK-LE-NEXT:  .LBB6_1: # %entry | 
|  | ; CHECK-LE-NEXT:    # | 
|  | ; CHECK-LE-NEXT:    stdu r0, -4096(r1) | 
|  | ; CHECK-LE-NEXT:    bdnz .LBB6_1 | 
|  | ; CHECK-LE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 1073741872 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 48(r1) | 
|  | ; CHECK-LE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f6: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    mr r0, r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-BE-NEXT:    stdu r0, -64(r1) | 
|  | ; CHECK-BE-NEXT:    lis r12, 4 | 
|  | ; CHECK-BE-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-BE-NEXT:    mtctr r12 | 
|  | ; CHECK-BE-NEXT:  .LBB6_1: # %entry | 
|  | ; CHECK-BE-NEXT:    # | 
|  | ; CHECK-BE-NEXT:    stdu r0, -4096(r1) | 
|  | ; CHECK-BE-NEXT:    bdnz .LBB6_1 | 
|  | ; CHECK-BE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 1073741888 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f6: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-32-NEXT:    stwu r0, -16(r1) | 
|  | ; CHECK-32-NEXT:    lis r12, 4 | 
|  | ; CHECK-32-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-32-NEXT:    mtctr r12 | 
|  | ; CHECK-32-NEXT:  .LBB6_1: # %entry | 
|  | ; CHECK-32-NEXT:    # | 
|  | ; CHECK-32-NEXT:    stwu r0, -4096(r1) | 
|  | ; CHECK-32-NEXT:    bdnz .LBB6_1 | 
|  | ; CHECK-32-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 1073741840 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lbz r3, 16(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 1073741824 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 63 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | define i8 @f7() #0 "stack-probe-size"="65536" { | 
|  | ; CHECK-LE-LABEL: f7: | 
|  | ; CHECK-LE:       # %bb.0: # %entry | 
|  | ; CHECK-LE-NEXT:    mr r0, r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-LE-NEXT:    lis r12, -1 | 
|  | ; CHECK-LE-NEXT:    ori r12, r12, 13776 | 
|  | ; CHECK-LE-NEXT:    stdux r0, r1, r12 | 
|  | ; CHECK-LE-NEXT:    li r12, 15258 | 
|  | ; CHECK-LE-NEXT:    mtctr r12 | 
|  | ; CHECK-LE-NEXT:    lis r12, -1 | 
|  | ; CHECK-LE-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-LE-NEXT:  .LBB7_1: # %entry | 
|  | ; CHECK-LE-NEXT:    # | 
|  | ; CHECK-LE-NEXT:    stdux r0, r1, r12 | 
|  | ; CHECK-LE-NEXT:    bdnz .LBB7_1 | 
|  | ; CHECK-LE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_offset 1000000048 | 
|  | ; CHECK-LE-NEXT:    li r3, 3 | 
|  | ; CHECK-LE-NEXT:    stb r3, 41(r1) | 
|  | ; CHECK-LE-NEXT:    lbz r3, 41(r1) | 
|  | ; CHECK-LE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f7: | 
|  | ; CHECK-BE:       # %bb.0: # %entry | 
|  | ; CHECK-BE-NEXT:    mr r0, r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-BE-NEXT:    lis r12, -1 | 
|  | ; CHECK-BE-NEXT:    ori r12, r12, 13760 | 
|  | ; CHECK-BE-NEXT:    stdux r0, r1, r12 | 
|  | ; CHECK-BE-NEXT:    li r12, 15258 | 
|  | ; CHECK-BE-NEXT:    mtctr r12 | 
|  | ; CHECK-BE-NEXT:    lis r12, -1 | 
|  | ; CHECK-BE-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-BE-NEXT:  .LBB7_1: # %entry | 
|  | ; CHECK-BE-NEXT:    # | 
|  | ; CHECK-BE-NEXT:    stdux r0, r1, r12 | 
|  | ; CHECK-BE-NEXT:    bdnz .LBB7_1 | 
|  | ; CHECK-BE-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_offset 1000000064 | 
|  | ; CHECK-BE-NEXT:    li r3, 3 | 
|  | ; CHECK-BE-NEXT:    stb r3, 57(r1) | 
|  | ; CHECK-BE-NEXT:    lbz r3, 57(r1) | 
|  | ; CHECK-BE-NEXT:    ld r1, 0(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f7: | 
|  | ; CHECK-32:       # %bb.0: # %entry | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa r0, 0 | 
|  | ; CHECK-32-NEXT:    lis r12, -1 | 
|  | ; CHECK-32-NEXT:    ori r12, r12, 13808 | 
|  | ; CHECK-32-NEXT:    stwux r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    li r12, 15258 | 
|  | ; CHECK-32-NEXT:    mtctr r12 | 
|  | ; CHECK-32-NEXT:    lis r12, -1 | 
|  | ; CHECK-32-NEXT:    ori r12, r12, 0 | 
|  | ; CHECK-32-NEXT:  .LBB7_1: # %entry | 
|  | ; CHECK-32-NEXT:    # | 
|  | ; CHECK-32-NEXT:    stwux r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    bdnz .LBB7_1 | 
|  | ; CHECK-32-NEXT:  # %bb.2: # %entry | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r1 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_offset 1000000016 | 
|  | ; CHECK-32-NEXT:    li r3, 3 | 
|  | ; CHECK-32-NEXT:    stb r3, 9(r1) | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lbz r3, 9(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | entry: | 
|  | %a = alloca i8, i64 1000000007 | 
|  | %b = getelementptr inbounds i8, ptr %a, i64 101 | 
|  | store volatile i8 3, ptr %a | 
|  | %c = load volatile i8, ptr %a | 
|  | ret i8 %c | 
|  | } | 
|  |  | 
|  | ; alloca + align < probe_size | 
|  | define i32 @f8(i64 %i) local_unnamed_addr #0 { | 
|  | ; CHECK-LE-LABEL: f8: | 
|  | ; CHECK-LE:       # %bb.0: | 
|  | ; CHECK-LE-NEXT:    clrldi r0, r1, 58 | 
|  | ; CHECK-LE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    mr r30, r1 | 
|  | ; CHECK-LE-NEXT:    subfic r0, r0, -896 | 
|  | ; CHECK-LE-NEXT:    stdux r1, r1, r0 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-LE-NEXT:    sldi r3, r3, 2 | 
|  | ; CHECK-LE-NEXT:    addi r4, r1, 64 | 
|  | ; CHECK-LE-NEXT:    li r5, 1 | 
|  | ; CHECK-LE-NEXT:    stwx r5, r4, r3 | 
|  | ; CHECK-LE-NEXT:    lwz r3, 64(r1) | 
|  | ; CHECK-LE-NEXT:    mr r1, r30 | 
|  | ; CHECK-LE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f8: | 
|  | ; CHECK-BE:       # %bb.0: | 
|  | ; CHECK-BE-NEXT:    clrldi r0, r1, 58 | 
|  | ; CHECK-BE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    mr r30, r1 | 
|  | ; CHECK-BE-NEXT:    subfic r0, r0, -896 | 
|  | ; CHECK-BE-NEXT:    stdux r1, r1, r0 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-BE-NEXT:    addi r4, r1, 64 | 
|  | ; CHECK-BE-NEXT:    li r5, 1 | 
|  | ; CHECK-BE-NEXT:    sldi r3, r3, 2 | 
|  | ; CHECK-BE-NEXT:    stwx r5, r4, r3 | 
|  | ; CHECK-BE-NEXT:    lwz r3, 64(r1) | 
|  | ; CHECK-BE-NEXT:    mr r1, r30 | 
|  | ; CHECK-BE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f8: | 
|  | ; CHECK-32:       # %bb.0: | 
|  | ; CHECK-32-NEXT:    clrlwi r0, r1, 26 | 
|  | ; CHECK-32-NEXT:    subfic r0, r0, -896 | 
|  | ; CHECK-32-NEXT:    stwux r1, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    addic r0, r0, -8 | 
|  | ; CHECK-32-NEXT:    stwx r30, 0, r0 | 
|  | ; CHECK-32-NEXT:    addic r30, r0, 8 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-32-NEXT:    .cfi_offset r30, -8 | 
|  | ; CHECK-32-NEXT:    addi r3, r1, 64 | 
|  | ; CHECK-32-NEXT:    li r5, 1 | 
|  | ; CHECK-32-NEXT:    slwi r4, r4, 2 | 
|  | ; CHECK-32-NEXT:    stwx r5, r3, r4 | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lwz r3, 64(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    lwz r30, -8(r31) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | %a = alloca i32, i32 200, align 64 | 
|  | %b = getelementptr inbounds i32, ptr %a, i64 %i | 
|  | store volatile i32 1, ptr %b | 
|  | %c = load volatile i32, ptr %a | 
|  | ret i32 %c | 
|  | } | 
|  |  | 
|  | ; alloca > probe_size, align > probe_size | 
|  | define i32 @f9(i64 %i) local_unnamed_addr #0 { | 
|  | ; CHECK-LE-LABEL: f9: | 
|  | ; CHECK-LE:       # %bb.0: | 
|  | ; CHECK-LE-NEXT:    clrldi r12, r1, 53 | 
|  | ; CHECK-LE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    mr r30, r1 | 
|  | ; CHECK-LE-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-LE-NEXT:    li r12, -10240 | 
|  | ; CHECK-LE-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-LE-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-LE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-LE-NEXT:    bge cr0, .LBB9_2 | 
|  | ; CHECK-LE-NEXT:  .LBB9_1: | 
|  | ; CHECK-LE-NEXT:    stdu r30, -4096(r1) | 
|  | ; CHECK-LE-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-LE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-LE-NEXT:    blt cr0, .LBB9_1 | 
|  | ; CHECK-LE-NEXT:  .LBB9_2: | 
|  | ; CHECK-LE-NEXT:    stdux r30, r1, r12 | 
|  | ; CHECK-LE-NEXT:    mr r0, r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-LE-NEXT:    sldi r3, r3, 2 | 
|  | ; CHECK-LE-NEXT:    addi r4, r1, 2048 | 
|  | ; CHECK-LE-NEXT:    li r5, 1 | 
|  | ; CHECK-LE-NEXT:    stwx r5, r4, r3 | 
|  | ; CHECK-LE-NEXT:    lwz r3, 2048(r1) | 
|  | ; CHECK-LE-NEXT:    mr r1, r30 | 
|  | ; CHECK-LE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f9: | 
|  | ; CHECK-BE:       # %bb.0: | 
|  | ; CHECK-BE-NEXT:    clrldi r12, r1, 53 | 
|  | ; CHECK-BE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    mr r30, r1 | 
|  | ; CHECK-BE-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-BE-NEXT:    li r12, -10240 | 
|  | ; CHECK-BE-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-BE-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-BE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-BE-NEXT:    bge cr0, .LBB9_2 | 
|  | ; CHECK-BE-NEXT:  .LBB9_1: | 
|  | ; CHECK-BE-NEXT:    stdu r30, -4096(r1) | 
|  | ; CHECK-BE-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-BE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-BE-NEXT:    blt cr0, .LBB9_1 | 
|  | ; CHECK-BE-NEXT:  .LBB9_2: | 
|  | ; CHECK-BE-NEXT:    stdux r30, r1, r12 | 
|  | ; CHECK-BE-NEXT:    mr r0, r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-BE-NEXT:    addi r4, r1, 2048 | 
|  | ; CHECK-BE-NEXT:    li r5, 1 | 
|  | ; CHECK-BE-NEXT:    sldi r3, r3, 2 | 
|  | ; CHECK-BE-NEXT:    stwx r5, r4, r3 | 
|  | ; CHECK-BE-NEXT:    lwz r3, 2048(r1) | 
|  | ; CHECK-BE-NEXT:    mr r1, r30 | 
|  | ; CHECK-BE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f9: | 
|  | ; CHECK-32:       # %bb.0: | 
|  | ; CHECK-32-NEXT:    clrlwi r12, r1, 21 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    li r12, -10240 | 
|  | ; CHECK-32-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-32-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    cmpwi r12, -4096 | 
|  | ; CHECK-32-NEXT:    bge cr0, .LBB9_2 | 
|  | ; CHECK-32-NEXT:  .LBB9_1: | 
|  | ; CHECK-32-NEXT:    stwu r0, -4096(r1) | 
|  | ; CHECK-32-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-32-NEXT:    cmpwi r12, -4096 | 
|  | ; CHECK-32-NEXT:    blt cr0, .LBB9_1 | 
|  | ; CHECK-32-NEXT:  .LBB9_2: | 
|  | ; CHECK-32-NEXT:    stwux r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    addic r0, r0, -8 | 
|  | ; CHECK-32-NEXT:    stwx r30, 0, r0 | 
|  | ; CHECK-32-NEXT:    addic r30, r0, 8 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-32-NEXT:    .cfi_offset r30, -8 | 
|  | ; CHECK-32-NEXT:    addi r3, r1, 2048 | 
|  | ; CHECK-32-NEXT:    li r5, 1 | 
|  | ; CHECK-32-NEXT:    slwi r4, r4, 2 | 
|  | ; CHECK-32-NEXT:    stwx r5, r3, r4 | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lwz r3, 2048(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    lwz r30, -8(r31) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | %a = alloca i32, i32 2000, align 2048 | 
|  | %b = getelementptr inbounds i32, ptr %a, i64 %i | 
|  | store volatile i32 1, ptr %b | 
|  | %c = load volatile i32, ptr %a | 
|  | ret i32 %c | 
|  | } | 
|  |  | 
|  | ; alloca < probe_size, align < probe_size, alloca + align > probe_size | 
|  | define i32 @f10(i64 %i) local_unnamed_addr #0 { | 
|  | ; CHECK-LE-LABEL: f10: | 
|  | ; CHECK-LE:       # %bb.0: | 
|  | ; CHECK-LE-NEXT:    clrldi r12, r1, 54 | 
|  | ; CHECK-LE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    mr r30, r1 | 
|  | ; CHECK-LE-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-LE-NEXT:    li r12, -5120 | 
|  | ; CHECK-LE-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-LE-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-LE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-LE-NEXT:    bge cr0, .LBB10_2 | 
|  | ; CHECK-LE-NEXT:  .LBB10_1: | 
|  | ; CHECK-LE-NEXT:    stdu r30, -4096(r1) | 
|  | ; CHECK-LE-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-LE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-LE-NEXT:    blt cr0, .LBB10_1 | 
|  | ; CHECK-LE-NEXT:  .LBB10_2: | 
|  | ; CHECK-LE-NEXT:    stdux r30, r1, r12 | 
|  | ; CHECK-LE-NEXT:    mr r0, r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-LE-NEXT:    sldi r3, r3, 2 | 
|  | ; CHECK-LE-NEXT:    addi r4, r1, 1024 | 
|  | ; CHECK-LE-NEXT:    li r5, 1 | 
|  | ; CHECK-LE-NEXT:    stwx r5, r4, r3 | 
|  | ; CHECK-LE-NEXT:    lwz r3, 1024(r1) | 
|  | ; CHECK-LE-NEXT:    mr r1, r30 | 
|  | ; CHECK-LE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f10: | 
|  | ; CHECK-BE:       # %bb.0: | 
|  | ; CHECK-BE-NEXT:    clrldi r12, r1, 54 | 
|  | ; CHECK-BE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    mr r30, r1 | 
|  | ; CHECK-BE-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-BE-NEXT:    li r12, -5120 | 
|  | ; CHECK-BE-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-BE-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-BE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-BE-NEXT:    bge cr0, .LBB10_2 | 
|  | ; CHECK-BE-NEXT:  .LBB10_1: | 
|  | ; CHECK-BE-NEXT:    stdu r30, -4096(r1) | 
|  | ; CHECK-BE-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-BE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-BE-NEXT:    blt cr0, .LBB10_1 | 
|  | ; CHECK-BE-NEXT:  .LBB10_2: | 
|  | ; CHECK-BE-NEXT:    stdux r30, r1, r12 | 
|  | ; CHECK-BE-NEXT:    mr r0, r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-BE-NEXT:    addi r4, r1, 1024 | 
|  | ; CHECK-BE-NEXT:    li r5, 1 | 
|  | ; CHECK-BE-NEXT:    sldi r3, r3, 2 | 
|  | ; CHECK-BE-NEXT:    stwx r5, r4, r3 | 
|  | ; CHECK-BE-NEXT:    lwz r3, 1024(r1) | 
|  | ; CHECK-BE-NEXT:    mr r1, r30 | 
|  | ; CHECK-BE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f10: | 
|  | ; CHECK-32:       # %bb.0: | 
|  | ; CHECK-32-NEXT:    clrlwi r12, r1, 22 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    li r12, -5120 | 
|  | ; CHECK-32-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-32-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    cmpwi r12, -4096 | 
|  | ; CHECK-32-NEXT:    bge cr0, .LBB10_2 | 
|  | ; CHECK-32-NEXT:  .LBB10_1: | 
|  | ; CHECK-32-NEXT:    stwu r0, -4096(r1) | 
|  | ; CHECK-32-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-32-NEXT:    cmpwi r12, -4096 | 
|  | ; CHECK-32-NEXT:    blt cr0, .LBB10_1 | 
|  | ; CHECK-32-NEXT:  .LBB10_2: | 
|  | ; CHECK-32-NEXT:    stwux r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    addic r0, r0, -8 | 
|  | ; CHECK-32-NEXT:    stwx r30, 0, r0 | 
|  | ; CHECK-32-NEXT:    addic r30, r0, 8 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-32-NEXT:    .cfi_offset r30, -8 | 
|  | ; CHECK-32-NEXT:    addi r3, r1, 1024 | 
|  | ; CHECK-32-NEXT:    li r5, 1 | 
|  | ; CHECK-32-NEXT:    slwi r4, r4, 2 | 
|  | ; CHECK-32-NEXT:    stwx r5, r3, r4 | 
|  | ; CHECK-32-NEXT:    mr r0, r31 | 
|  | ; CHECK-32-NEXT:    lwz r3, 1024(r1) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    lwz r30, -8(r31) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | %a = alloca i32, i32 1000, align 1024 | 
|  | %b = getelementptr inbounds i32, ptr %a, i64 %i | 
|  | store volatile i32 1, ptr %b | 
|  | %c = load volatile i32, ptr %a | 
|  | ret i32 %c | 
|  | } | 
|  |  | 
|  | define void @f11(i32 %vla_size, i64 %i) #0 { | 
|  | ; CHECK-LE-LABEL: f11: | 
|  | ; CHECK-LE:       # %bb.0: | 
|  | ; CHECK-LE-NEXT:    clrldi r12, r1, 49 | 
|  | ; CHECK-LE-NEXT:    std r31, -8(r1) | 
|  | ; CHECK-LE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    mr r30, r1 | 
|  | ; CHECK-LE-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-LE-NEXT:    lis r12, -2 | 
|  | ; CHECK-LE-NEXT:    ori r12, r12, 32768 | 
|  | ; CHECK-LE-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-LE-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-LE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-LE-NEXT:    bge cr0, .LBB11_2 | 
|  | ; CHECK-LE-NEXT:  .LBB11_1: | 
|  | ; CHECK-LE-NEXT:    stdu r30, -4096(r1) | 
|  | ; CHECK-LE-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-LE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-LE-NEXT:    blt cr0, .LBB11_1 | 
|  | ; CHECK-LE-NEXT:  .LBB11_2: | 
|  | ; CHECK-LE-NEXT:    stdux r30, r1, r12 | 
|  | ; CHECK-LE-NEXT:    mr r0, r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-LE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-LE-NEXT:    .cfi_offset r31, -8 | 
|  | ; CHECK-LE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-LE-NEXT:    clrldi r3, r3, 32 | 
|  | ; CHECK-LE-NEXT:    lis r5, 1 | 
|  | ; CHECK-LE-NEXT:    mr r31, r1 | 
|  | ; CHECK-LE-NEXT:    li r6, 1 | 
|  | ; CHECK-LE-NEXT:    sldi r4, r4, 2 | 
|  | ; CHECK-LE-NEXT:    addi r3, r3, 15 | 
|  | ; CHECK-LE-NEXT:    ori r5, r5, 0 | 
|  | ; CHECK-LE-NEXT:    rldicl r3, r3, 60, 4 | 
|  | ; CHECK-LE-NEXT:    add r5, r31, r5 | 
|  | ; CHECK-LE-NEXT:    rldicl r3, r3, 4, 31 | 
|  | ; CHECK-LE-NEXT:    stwx r6, r5, r4 | 
|  | ; CHECK-LE-NEXT:    li r4, -32768 | 
|  | ; CHECK-LE-NEXT:    li r6, -4096 | 
|  | ; CHECK-LE-NEXT:    neg r5, r3 | 
|  | ; CHECK-LE-NEXT:    ld r3, 0(r1) | 
|  | ; CHECK-LE-NEXT:    and r4, r5, r4 | 
|  | ; CHECK-LE-NEXT:    mr r5, r4 | 
|  | ; CHECK-LE-NEXT:    divd r7, r5, r6 | 
|  | ; CHECK-LE-NEXT:    add r4, r1, r5 | 
|  | ; CHECK-LE-NEXT:    mulld r6, r7, r6 | 
|  | ; CHECK-LE-NEXT:    sub r5, r5, r6 | 
|  | ; CHECK-LE-NEXT:    stdux r3, r1, r5 | 
|  | ; CHECK-LE-NEXT:    cmpd r1, r4 | 
|  | ; CHECK-LE-NEXT:    beq cr0, .LBB11_4 | 
|  | ; CHECK-LE-NEXT:  .LBB11_3: | 
|  | ; CHECK-LE-NEXT:    stdu r3, -4096(r1) | 
|  | ; CHECK-LE-NEXT:    cmpd r1, r4 | 
|  | ; CHECK-LE-NEXT:    bne cr0, .LBB11_3 | 
|  | ; CHECK-LE-NEXT:  .LBB11_4: | 
|  | ; CHECK-LE-NEXT:    addi r3, r1, -32768 | 
|  | ; CHECK-LE-NEXT:    lbz r3, 0(r3) | 
|  | ; CHECK-LE-NEXT:    mr r1, r30 | 
|  | ; CHECK-LE-NEXT:    ld r31, -8(r1) | 
|  | ; CHECK-LE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-LE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-BE-LABEL: f11: | 
|  | ; CHECK-BE:       # %bb.0: | 
|  | ; CHECK-BE-NEXT:    clrldi r12, r1, 49 | 
|  | ; CHECK-BE-NEXT:    std r31, -8(r1) | 
|  | ; CHECK-BE-NEXT:    std r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    mr r30, r1 | 
|  | ; CHECK-BE-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-BE-NEXT:    lis r12, -2 | 
|  | ; CHECK-BE-NEXT:    ori r12, r12, 32768 | 
|  | ; CHECK-BE-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-BE-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-BE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-BE-NEXT:    bge cr0, .LBB11_2 | 
|  | ; CHECK-BE-NEXT:  .LBB11_1: | 
|  | ; CHECK-BE-NEXT:    stdu r30, -4096(r1) | 
|  | ; CHECK-BE-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-BE-NEXT:    cmpdi r12, -4096 | 
|  | ; CHECK-BE-NEXT:    blt cr0, .LBB11_1 | 
|  | ; CHECK-BE-NEXT:  .LBB11_2: | 
|  | ; CHECK-BE-NEXT:    stdux r30, r1, r12 | 
|  | ; CHECK-BE-NEXT:    mr r0, r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-BE-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-BE-NEXT:    .cfi_offset r31, -8 | 
|  | ; CHECK-BE-NEXT:    .cfi_offset r30, -16 | 
|  | ; CHECK-BE-NEXT:    clrldi r3, r3, 32 | 
|  | ; CHECK-BE-NEXT:    lis r5, 1 | 
|  | ; CHECK-BE-NEXT:    addi r3, r3, 15 | 
|  | ; CHECK-BE-NEXT:    mr r31, r1 | 
|  | ; CHECK-BE-NEXT:    ori r5, r5, 0 | 
|  | ; CHECK-BE-NEXT:    rldicl r3, r3, 60, 4 | 
|  | ; CHECK-BE-NEXT:    add r5, r31, r5 | 
|  | ; CHECK-BE-NEXT:    sldi r4, r4, 2 | 
|  | ; CHECK-BE-NEXT:    li r6, 1 | 
|  | ; CHECK-BE-NEXT:    rldicl r3, r3, 4, 31 | 
|  | ; CHECK-BE-NEXT:    stwx r6, r5, r4 | 
|  | ; CHECK-BE-NEXT:    neg r7, r3 | 
|  | ; CHECK-BE-NEXT:    li r4, -32768 | 
|  | ; CHECK-BE-NEXT:    and r4, r7, r4 | 
|  | ; CHECK-BE-NEXT:    ld r3, 0(r1) | 
|  | ; CHECK-BE-NEXT:    mr r7, r4 | 
|  | ; CHECK-BE-NEXT:    li r4, -4096 | 
|  | ; CHECK-BE-NEXT:    divd r5, r7, r4 | 
|  | ; CHECK-BE-NEXT:    mulld r4, r5, r4 | 
|  | ; CHECK-BE-NEXT:    sub r5, r7, r4 | 
|  | ; CHECK-BE-NEXT:    add r4, r1, r7 | 
|  | ; CHECK-BE-NEXT:    stdux r3, r1, r5 | 
|  | ; CHECK-BE-NEXT:    cmpd r1, r4 | 
|  | ; CHECK-BE-NEXT:    beq cr0, .LBB11_4 | 
|  | ; CHECK-BE-NEXT:  .LBB11_3: | 
|  | ; CHECK-BE-NEXT:    stdu r3, -4096(r1) | 
|  | ; CHECK-BE-NEXT:    cmpd r1, r4 | 
|  | ; CHECK-BE-NEXT:    bne cr0, .LBB11_3 | 
|  | ; CHECK-BE-NEXT:  .LBB11_4: | 
|  | ; CHECK-BE-NEXT:    addi r3, r1, -32768 | 
|  | ; CHECK-BE-NEXT:    lbz r3, 0(r3) | 
|  | ; CHECK-BE-NEXT:    mr r1, r30 | 
|  | ; CHECK-BE-NEXT:    ld r31, -8(r1) | 
|  | ; CHECK-BE-NEXT:    ld r30, -16(r1) | 
|  | ; CHECK-BE-NEXT:    blr | 
|  | ; | 
|  | ; CHECK-32-LABEL: f11: | 
|  | ; CHECK-32:       # %bb.0: | 
|  | ; CHECK-32-NEXT:    clrlwi r12, r1, 17 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    lis r12, -2 | 
|  | ; CHECK-32-NEXT:    ori r12, r12, 32768 | 
|  | ; CHECK-32-NEXT:    add r0, r12, r0 | 
|  | ; CHECK-32-NEXT:    sub r12, r0, r1 | 
|  | ; CHECK-32-NEXT:    mr r0, r1 | 
|  | ; CHECK-32-NEXT:    cmpwi r12, -4096 | 
|  | ; CHECK-32-NEXT:    bge cr0, .LBB11_2 | 
|  | ; CHECK-32-NEXT:  .LBB11_1: | 
|  | ; CHECK-32-NEXT:    stwu r0, -4096(r1) | 
|  | ; CHECK-32-NEXT:    addi r12, r12, 4096 | 
|  | ; CHECK-32-NEXT:    cmpwi r12, -4096 | 
|  | ; CHECK-32-NEXT:    blt cr0, .LBB11_1 | 
|  | ; CHECK-32-NEXT:  .LBB11_2: | 
|  | ; CHECK-32-NEXT:    stwux r0, r1, r12 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    sub r0, r1, r0 | 
|  | ; CHECK-32-NEXT:    addic r0, r0, -4 | 
|  | ; CHECK-32-NEXT:    stwx r31, 0, r0 | 
|  | ; CHECK-32-NEXT:    addic r0, r0, -4 | 
|  | ; CHECK-32-NEXT:    stwx r30, 0, r0 | 
|  | ; CHECK-32-NEXT:    addic r30, r0, 8 | 
|  | ; CHECK-32-NEXT:    .cfi_def_cfa_register r30 | 
|  | ; CHECK-32-NEXT:    .cfi_offset r31, -4 | 
|  | ; CHECK-32-NEXT:    .cfi_offset r30, -8 | 
|  | ; CHECK-32-NEXT:    lis r4, 1 | 
|  | ; CHECK-32-NEXT:    mr r31, r1 | 
|  | ; CHECK-32-NEXT:    ori r4, r4, 0 | 
|  | ; CHECK-32-NEXT:    addi r3, r3, 15 | 
|  | ; CHECK-32-NEXT:    add r4, r31, r4 | 
|  | ; CHECK-32-NEXT:    li r5, 1 | 
|  | ; CHECK-32-NEXT:    slwi r6, r6, 2 | 
|  | ; CHECK-32-NEXT:    rlwinm r3, r3, 0, 0, 27 | 
|  | ; CHECK-32-NEXT:    neg r7, r3 | 
|  | ; CHECK-32-NEXT:    stwx r5, r4, r6 | 
|  | ; CHECK-32-NEXT:    li r4, -32768 | 
|  | ; CHECK-32-NEXT:    and r4, r7, r4 | 
|  | ; CHECK-32-NEXT:    lwz r3, 0(r1) | 
|  | ; CHECK-32-NEXT:    mr r7, r4 | 
|  | ; CHECK-32-NEXT:    li r4, -4096 | 
|  | ; CHECK-32-NEXT:    divw r5, r7, r4 | 
|  | ; CHECK-32-NEXT:    mullw r4, r5, r4 | 
|  | ; CHECK-32-NEXT:    sub r5, r7, r4 | 
|  | ; CHECK-32-NEXT:    add r4, r1, r7 | 
|  | ; CHECK-32-NEXT:    stwux r3, r1, r5 | 
|  | ; CHECK-32-NEXT:    cmpw r1, r4 | 
|  | ; CHECK-32-NEXT:    beq cr0, .LBB11_4 | 
|  | ; CHECK-32-NEXT:  .LBB11_3: | 
|  | ; CHECK-32-NEXT:    stwu r3, -4096(r1) | 
|  | ; CHECK-32-NEXT:    cmpw r1, r4 | 
|  | ; CHECK-32-NEXT:    bne cr0, .LBB11_3 | 
|  | ; CHECK-32-NEXT:  .LBB11_4: | 
|  | ; CHECK-32-NEXT:    addi r3, r1, -32768 | 
|  | ; CHECK-32-NEXT:    lbz r3, 0(r3) | 
|  | ; CHECK-32-NEXT:    lwz r31, 0(r1) | 
|  | ; CHECK-32-NEXT:    lwz r0, -4(r31) | 
|  | ; CHECK-32-NEXT:    lwz r30, -8(r31) | 
|  | ; CHECK-32-NEXT:    mr r1, r31 | 
|  | ; CHECK-32-NEXT:    mr r31, r0 | 
|  | ; CHECK-32-NEXT:    blr | 
|  | %a = alloca i32, i32 4096, align 32768 | 
|  | %b = getelementptr inbounds i32, ptr %a, i64 %i | 
|  | store volatile i32 1, ptr %b | 
|  | %1 = zext i32 %vla_size to i64 | 
|  | %vla = alloca i8, i64 %1, align 2048 | 
|  | %2 = load volatile i8, ptr %vla, align 2048 | 
|  | ret void | 
|  | } | 
|  |  | 
|  | attributes #0 = { "probe-stack"="inline-asm" } |