mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 17:32:49 +00:00
6eb3e87df0
Before this patch, when you objdump an LLVM-compiled file, objdump tried to decode data-in-code sections as if they were code. This patch adds the missing Mapping Symbols, as defined by "ELF for the ARM Architecture" (ARM IHI 0044D). Patch based on work by Greg Fitzgerald. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169609 91177308-0d34-0410-b5e6-96231b3b80d8
38 lines
1.1 KiB
LLVM
38 lines
1.1 KiB
LLVM
; RUN: llc %s -mtriple=thumbv7-linux-gnueabi -relocation-model=pic \
|
|
; RUN: -filetype=obj -o - | elf-dump --dump-section-data | \
|
|
; RUN: FileCheck %s
|
|
|
|
; FIXME: This file needs to be in .s form!
|
|
; We wanna test relocatable thumb function call,
|
|
; but ARMAsmParser cannot handle "bl foo(PLT)" yet
|
|
|
|
target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:64:128-a0:0:32-n32"
|
|
target triple = "thumbv7-none--gnueabi"
|
|
|
|
define void @foo() nounwind {
|
|
entry:
|
|
ret void
|
|
}
|
|
|
|
define void @bar() nounwind {
|
|
entry:
|
|
call void @foo()
|
|
ret void
|
|
}
|
|
|
|
|
|
; make sure that bl 0 <foo> (fff7feff) is correctly encoded
|
|
; CHECK: '_section_data', '704700bf 2de90048 fff7feff bde80088'
|
|
|
|
; Offset Info Type Sym.Value Sym. Name
|
|
; 00000008 0000070a R_ARM_THM_CALL 00000001 foo
|
|
; CHECK: Relocation 0
|
|
; CHECK-NEXT: 'r_offset', 0x00000008
|
|
; CHECK-NEXT: 'r_sym', 0x000009
|
|
; CHECK-NEXT: 'r_type', 0x0a
|
|
|
|
; make sure foo is thumb function: bit 0 = 1
|
|
; CHECK: Symbol 9
|
|
; CHECK-NEXT: 'foo'
|
|
; CHECK-NEXT: 'st_value', 0x00000001
|