@ RUN: llvm-mc %s -triple=armv7-unknown-linux-gnueabi -filetype=obj -o - \ @ RUN: | llvm-readobj -s -sd | FileCheck %s @ Check for .setfp directive. @ The .setfp directive will track the offset between the frame pointer and @ the stack pointer. This is required for the function that will change @ the stack pointer out of the function prologue. If the exception is thrown, @ then libunwind will reconstruct the stack pointer from the frame pointer. @ The reconstruction code is implemented by two different unwind opcode: @ (i) the unwind opcode to copy stack offset from the other register, and @ (ii) the unwind opcode to add or subtract the stack offset. @ @ This file includes several cases separated by different range of -offset @ @ (-offset) < 0x00 @ (-offset) == 0x00 @ 0x04 <= (-offset) <= 0x100 @ 0x104 <= (-offset) <= 0x200 @ 0x204 <= (-offset) .syntax unified @------------------------------------------------------------------------------- @ TEST1 @------------------------------------------------------------------------------- .section .TEST1 .globl func1 .align 2 .type func1,%function .fnstart func1: .setfp fp, sp, #0 add fp, sp, #0 sub sp, fp, #0 bx lr .personality __gxx_personality_v0 .handlerdata .fnend @------------------------------------------------------------------------------- @ The assembler should emit 0x9B to copy stack pointer from r11. @------------------------------------------------------------------------------- @ CHECK: Section { @ CHECK: Name: .ARM.extab.TEST1 @ CHECK: SectionData ( @ CHECK: 0000: 00000000 B0B09B00 |........| @ CHECK: ) @ CHECK: } @------------------------------------------------------------------------------- @ TEST2 @------------------------------------------------------------------------------- .section .TEST2 .globl func2a .align 2 .type func2a,%function .fnstart func2a: .setfp fp, sp, #-4 add fp, sp, #4 sub sp, fp, #4 bx lr .personality __gxx_personality_v0 .handlerdata .fnend .globl func2b .align 2 .type func2b,%function .fnstart func2b: .setfp fp, sp, #-0x100 add fp, sp, #0x100 sub sp, fp, #0x100 bx lr .personality __gxx_personality_v0 .handlerdata .fnend @------------------------------------------------------------------------------- @ The assembler should emit 0x9B to copy stack pointer from r11. @ The assembler should emit ((-offset - 4) >> 2) for offset. @------------------------------------------------------------------------------- @ CHECK: Section { @ CHECK: Name: .ARM.extab.TEST2 @ CHECK: SectionData ( @ CHECK: 0000: 00000000 B0009B00 00000000 B03F9B00 |.............?..| @ CHECK: ) @ CHECK: } @------------------------------------------------------------------------------- @ TEST3 @------------------------------------------------------------------------------- .section .TEST3 .globl func3a .align 2 .type func3a,%function .fnstart func3a: .setfp fp, sp, #-0x104 sub fp, sp, #0x104 add sp, fp, #0x104 bx lr .personality __gxx_personality_v0 .handlerdata .fnend .globl func3b .align 2 .type func3b,%function .fnstart func3b: .setfp fp, sp, #-0x200 sub fp, sp, #0x200 add sp, fp, #0x200 bx lr .personality __gxx_personality_v0 .handlerdata .fnend @------------------------------------------------------------------------------- @ The assembler should emit 0x9B to copy stack pointer from r11. @ The assembler should emit 0x3F and ((-offset - 0x104) >> 2) for offset. @------------------------------------------------------------------------------- @ CHECK: Section { @ CHECK: Name: .ARM.extab.TEST3 @ CHECK: SectionData ( @ CHECK: 0000: 00000000 3F009B00 00000000 3F3F9B00 |....?.......??..| @ CHECK: ) @ CHECK: } @------------------------------------------------------------------------------- @ TEST4 @------------------------------------------------------------------------------- .section .TEST4 .globl func4a .align 2 .type func4a,%function .fnstart func4a: .setfp fp, sp, #-0x204 sub fp, sp, #0x204 add sp, fp, #0x204 bx lr .personality __gxx_personality_v0 .handlerdata .fnend .globl func4b .align 2 .type func4b,%function .fnstart func4b: .setfp fp, sp, #-0x580 sub fp, sp, #0x580 add sp, fp, #0x580 bx lr .personality __gxx_personality_v0 .handlerdata .fnend @------------------------------------------------------------------------------- @ The assembler should emit 0x9B to copy stack pointer from r11. @ The assembler should emit 0xB2 and the ULEB128 encoding of @ ((-offset - 0x204) >> 2) for offset. @------------------------------------------------------------------------------- @ CHECK: Section { @ CHECK: Name: .ARM.extab.TEST4 @ CHECK: SectionData ( @ CHECK: 0000: 00000000 00B29B00 00000000 DFB29B01 |................| @ CHECK: 0010: B0B0B001 |....| @ CHECK: ) @ CHECK: } @------------------------------------------------------------------------------- @ TEST5 @------------------------------------------------------------------------------- .section .TEST5 .globl func5a .align 2 .type func5a,%function .fnstart func5a: .setfp fp, sp, #0x4 add fp, sp, #0x4 sub sp, fp, #0x4 bx lr .personality __gxx_personality_v0 .handlerdata .fnend .globl func5b .align 2 .type func5b,%function .fnstart func5b: .setfp fp, sp, #0x104 add fp, sp, #0x104 sub sp, fp, #0x104 bx lr .personality __gxx_personality_v0 .handlerdata .fnend .globl func5c .align 2 .type func5c,%function .fnstart func5c: .setfp fp, sp, #0x204 add fp, sp, #0x204 sub sp, fp, #0x204 bx lr .personality __gxx_personality_v0 .handlerdata .fnend @------------------------------------------------------------------------------- @ The assembler should emit 0x9B to copy stack pointer from r11. @ The assembler should emit (0x40 | (offset - 4)) >> 2 for offset. @ If (offset - 4) is greater than 0x3f, then multiple 0x7f should be emitted. @------------------------------------------------------------------------------- @ CHECK: Section { @ CHECK: Name: .ARM.extab.TEST5 @ CHECK: SectionData ( @ CHECK: 0000: 00000000 B0409B00 00000000 7F409B00 |.....@.......@..| @ CHECK: 0010: 00000000 7F409B01 B0B0B07F |.....@......| @ CHECK: ) @ CHECK: }