xref: /aosp_15_r20/external/llvm/test/MC/MachO/relax-jumps.s (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker// RUN: llvm-mc -triple i386-apple-darwin9 %s -filetype=obj -o - | llvm-readobj -s -sd | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker// FIXME: This is a horrible way of checking the output, we need an llvm-mc
4*9880d681SAndroid Build Coastguard Worker// based 'otool'. Use:
5*9880d681SAndroid Build Coastguard Worker//   (f=relax-jumps;
6*9880d681SAndroid Build Coastguard Worker//    llvm-mc -filetype=obj -o $f.mc.o $f.s &&
7*9880d681SAndroid Build Coastguard Worker//    as -arch i386 -o $f.as.o $f.s &&
8*9880d681SAndroid Build Coastguard Worker//    otool -tvr $f.mc.o | tail +2 > $f.mc.dump &&
9*9880d681SAndroid Build Coastguard Worker//    otool -tvr $f.as.o | tail +2 > $f.as.dump &&
10*9880d681SAndroid Build Coastguard Worker//    diff $f.{as,mc}.dump)
11*9880d681SAndroid Build Coastguard Worker// to examine the results in a more sensible fashion.
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard WorkerL1:
14*9880d681SAndroid Build Coastguard Worker        .space 200, 0x90
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Worker        je L1
17*9880d681SAndroid Build Coastguard Worker        jb L2
18*9880d681SAndroid Build Coastguard Worker        ja L1
19*9880d681SAndroid Build Coastguard Worker        jg L2
20*9880d681SAndroid Build Coastguard Worker        js L1
21*9880d681SAndroid Build Coastguard Worker        jae L2
22*9880d681SAndroid Build Coastguard Worker        jns L1
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Worker        .space 200, 0x90
25*9880d681SAndroid Build Coastguard WorkerL2:
26*9880d681SAndroid Build Coastguard Worker
27*9880d681SAndroid Build Coastguard Worker        xorl %eax, %eax
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Worker// CHECK: SectionData (
30*9880d681SAndroid Build Coastguard Worker// CHECK:   00C0: 90909090 90909090 0F8432FF FFFF0F82  |..........2.....|
31*9880d681SAndroid Build Coastguard Worker// CHECK:   00D0: E6000000 0F8726FF FFFF0F8F DA000000  |......&.........|
32*9880d681SAndroid Build Coastguard Worker// CHECK:   00E0: 0F881AFF FFFF0F83 CE000000 0F890EFF  |................|
33*9880d681SAndroid Build Coastguard Worker// CHECK:   00F0: FFFF9090 90909090 90909090 90909090  |................|
34*9880d681SAndroid Build Coastguard Worker// CHECK:   01A0: 90909090 90909090 90909090 90909090  |................|
35*9880d681SAndroid Build Coastguard Worker// CHECK:   01B0: 90909090 90909090 909031C0           |..........1.|
36*9880d681SAndroid Build Coastguard Worker// CHECK: )
37