llvm-6502/test/MC/MachO/ARM/data-in-code.s
Jim Grosbach 3e96531186 Refactor data-in-code annotations.
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
2012-05-18 19:12:01 +00:00

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