File: data-in-code-section-ordering.s

package info (click to toggle)
llvm-toolchain-20 1%3A20.1.8-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 2,111,696 kB
  • sloc: cpp: 7,438,781; ansic: 1,393,871; asm: 1,012,926; python: 241,771; f90: 86,635; objc: 75,411; lisp: 42,144; pascal: 17,286; sh: 8,596; ml: 5,082; perl: 4,730; makefile: 3,591; awk: 3,523; javascript: 2,251; xml: 892; fortran: 672
file content (39 lines) | stat: -rw-r--r-- 1,354 bytes parent folder | download | duplicates (16)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# REQUIRES: x86
# RUN: rm -rf %t; split-file %s %t

## Check that data-in-code information is sorted even if
## sections are reordered compared to the input order.

# RUN: sed -e s/SYM/_first/ %t/input.s | \
# RUN:   llvm-mc -filetype=obj --triple=x86_64-apple-darwin -o %t/first.o
# RUN: sed -e s/SYM/_second/ %t/input.s | \
# RUN:   llvm-mc -filetype=obj --triple=x86_64-apple-darwin -o %t/second.o
# RUN: sed -e s/SYM/_third/ %t/input.s | \
# RUN:   llvm-mc -filetype=obj --triple=x86_64-apple-darwin -o %t/third.o
# RUN: %lld -dylib -lSystem -order_file %t/order.txt %t/first.o %t/second.o %t/third.o -o %t/out
# RUN: llvm-objdump --macho --syms %t/out > %t/dump.txt
# RUN: llvm-objdump --macho --data-in-code %t/out >> %t/dump.txt
# RUN: FileCheck %s < %t/dump.txt

# CHECK-LABEL: SYMBOL TABLE:
# CHECK-DAG:   [[#%x, SECOND:]] g     F __TEXT,__text _second
# CHECK-DAG:   [[#%x, FIRST:]]  g     F __TEXT,__text _first
# CHECK-DAG:   [[#%x, THIRD:]]  g     F __TEXT,__text _third

# CHECK-LABEL: Data in code table (3 entries)
# CHECK-NEXT:  offset              length kind
# CHECK-NEXT:  0x[[#%.8x, SECOND]] 4      JUMP_TABLE32
# CHECK-NEXT:  0x[[#%.8x, FIRST]]  4      JUMP_TABLE32
# CHECK-NEXT:  0x[[#%.8x, THIRD]]  4      JUMP_TABLE32

#--- order.txt
_second
_first
_third

#--- input.s
.globl SYM
SYM:
.data_region jt32
.long 0
.end_data_region