diff options
author | Kai Nacke <kai.nacke@redstar.de> | 2013-09-15 17:46:46 +0000 |
---|---|---|
committer | Kai Nacke <kai.nacke@redstar.de> | 2013-09-15 17:46:46 +0000 |
commit | 7185bdd88302a67618b2edf51c499d647e5ff492 (patch) | |
tree | 632edb0e5efbff00ac26a421aa166e84665ce0ae /test/MC/COFF/seh.s | |
parent | 19b59e66afa8d19c35444e0a739b467d368725d3 (diff) | |
download | external_llvm-7185bdd88302a67618b2edf51c499d647e5ff492.zip external_llvm-7185bdd88302a67618b2edf51c499d647e5ff492.tar.gz external_llvm-7185bdd88302a67618b2edf51c499d647e5ff492.tar.bz2 |
Generate IMAGE_REL_AMD64_ADDR32NB relocations for SEH
data structures.
The Win64 EH data structures must be of type IMAGE_REL_AMD64_ADDR32NB
instead of IMAGE_REL_AMD64_ADDR32. This is easiely achieved by adding
the VK_COFF_IMGREL32 modifier to the symbol reference.
Change also references to start and end of the SEH range of a function
as offsets to start of the function.
Reviewed by Jim Grosbach, Charles Davis and Nico Rieck.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@190766 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/MC/COFF/seh.s')
-rw-r--r-- | test/MC/COFF/seh.s | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/test/MC/COFF/seh.s b/test/MC/COFF/seh.s index b1e61a9..72d42f4 100644 --- a/test/MC/COFF/seh.s +++ b/test/MC/COFF/seh.s @@ -1,6 +1,6 @@ // This test checks that the SEH directives emit the correct unwind data. -// RUN: llvm-mc -triple x86_64-pc-win32 -filetype=obj %s | llvm-readobj -s -u | FileCheck %s +// RUN: llvm-mc -triple x86_64-pc-win32 -filetype=obj %s | llvm-readobj -s -u -r | FileCheck %s // CHECK: Sections [ // CHECK: Section { @@ -34,6 +34,27 @@ // CHECK-NEXT: } // CHECK-NEXT: ] +// CHECK-NEXT: Relocations [ +// CHECK-NEXT: Section (2) .xdata { +// CHECK-NEXT: 0x14 IMAGE_REL_AMD64_ADDR32NB __C_specific_handler +// CHECK-NEXT: 0x20 IMAGE_REL_AMD64_ADDR32NB func +// CHECK-NEXT: 0x24 IMAGE_REL_AMD64_ADDR32NB func +// CHECK-NEXT: 0x28 IMAGE_REL_AMD64_ADDR32NB .xdata +// CHECK-NEXT: } +// CHECK-NEXT: Section (3) .pdata { +// CHECK-NEXT: 0x0 IMAGE_REL_AMD64_ADDR32NB func +// CHECK-NEXT: 0x4 IMAGE_REL_AMD64_ADDR32NB func +// CHECK-NEXT: 0x8 IMAGE_REL_AMD64_ADDR32NB .xdata +// CHECK-NEXT: 0xC IMAGE_REL_AMD64_ADDR32NB func +// CHECK-NEXT: 0x10 IMAGE_REL_AMD64_ADDR32NB func +// CHECK-NEXT: 0x14 IMAGE_REL_AMD64_ADDR32NB .xdata +// CHECK-NEXT: 0x18 IMAGE_REL_AMD64_ADDR32NB smallFunc +// CHECK-NEXT: 0x1C IMAGE_REL_AMD64_ADDR32NB smallFunc +// CHECK-NEXT: 0x20 IMAGE_REL_AMD64_ADDR32NB .xdata +// CHECK-NEXT: } +// CHECK-NEXT: ] + + // CHECK: UnwindInformation [ // CHECK-NEXT: RuntimeFunction { // CHECK-NEXT: StartAddress: [[CodeSect1:[^ ]+]] [[BeginDisp1:(\+0x[A-F0-9]+)?]] |