mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
3e96531186
Use a dedicated MachO load command to annotate data-in-code regions. This is the same format the linker produces for final executable images, allowing consistency of representation and use of introspection tools for both object and executable files. Data-in-code regions are annotated via ".data_region"/".end_data_region" directive pairs, with an optional region type. data_region_directive := ".data_region" { region_type } region_type := "jt8" | "jt16" | "jt32" | "jta32" end_data_region_directive := ".end_data_region" The previous handling of ARM-style "$d.*" labels was broken and has been removed. Specifically, it didn't handle ARM vs. Thumb mode when marking the end of the section. rdar://11459456 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157062 91177308-0d34-0410-b5e6-96231b3b80d8
34 lines
659 B
ArmAsm
34 lines
659 B
ArmAsm
@ RUN: llvm-mc -triple armv7-apple-darwin10 -filetype=obj -o - < %s | macho-dump | FileCheck %s
|
|
.text
|
|
_foo:
|
|
@ CHECK: # DICE 0
|
|
@ CHECK: ('offset', 0)
|
|
@ CHECK: ('length', 4)
|
|
@ CHECK: ('kind', 1)
|
|
@ CHECK: # DICE 1
|
|
@ CHECK: ('offset', 4)
|
|
@ CHECK: ('length', 4)
|
|
@ CHECK: ('kind', 4)
|
|
@ CHECK: # DICE 2
|
|
@ CHECK: ('offset', 8)
|
|
@ CHECK: ('length', 2)
|
|
@ CHECK: ('kind', 3)
|
|
@ CHECK: # DICE 3
|
|
@ CHECK: ('offset', 10)
|
|
@ CHECK: ('length', 1)
|
|
@ CHECK: ('kind', 2)
|
|
|
|
.data_region
|
|
.long 10
|
|
.end_data_region
|
|
.data_region jt32
|
|
.long 1
|
|
.end_data_region
|
|
.data_region jt16
|
|
.short 2
|
|
.end_data_region
|
|
.data_region jt8
|
|
.byte 3
|
|
.end_data_region
|
|
|