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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
# RUN: yaml2obj -format=elf %s | llvm-objdump -d -yaml-cfg=%t - && FileCheck --check-prefix=CFG < %t %s
# REQUIRES: shell
#
# Generated from:
# main:
# movl $48, %eax
# cmpl $3, %edi
# jl .LBB0_2
# movq 8(%rsi), %rax
# movsbl (%rax), %eax
# .LBB0_2:
# ret
#
!ELF
FileHeader:
Class: ELFCLASS64
Data: ELFDATA2LSB
Type: ET_REL
Machine: EM_X86_64
Sections:
- Name: .text
Type: SHT_PROGBITS
Flags: [ SHF_ALLOC, SHF_EXECINSTR ]
Content: "B83000000083FF037C07488B46080FBE00C3"
## 0000000000000000 <main>:
#CFG: Atoms:
#CFG: - StartAddress: 0x0000000000000000
#CFG: Size: 10
## 0: b8 30 00 00 00 mov $0x30,%eax
#CFG: - Inst: MOV32ri
#CFG: Size: 5
#CFG: Ops: [ REAX, I48 ]
## 5: 83 ff 03 cmp $0x3,%edi
#CFG: - Inst: CMP32ri8
#CFG: Size: 3
#CFG: Ops: [ REDI, I3 ]
## 8: 7c 07 jl 11 <main+0x11>
#CFG: - Inst: JL_1
#CFG: Size: 2
#CFG: Ops: [ I7 ]
#CFG: - StartAddress: 0x000000000000000A
#CFG: Size: 7
## a: 48 8b 46 08 mov 0x8(%rsi),%rax
#CFG: - Inst: MOV64rm
#CFG: Size: 4
#CFG: Ops: [ RRAX, RRSI, I1, R, I8, R ]
## e: 0f be 00 movsbl (%rax),%eax
#CFG: - Inst: MOVSX32rm8
#CFG: Size: 3
#CFG: Ops: [ REAX, RRAX, I1, R, I0, R ]
#CFG: - StartAddress: 0x0000000000000011
#CFG: Size: 1
## 11: c3 retq
#CFG: - Inst: RET
#CFG: Size: 1
#CFG: Ops: [ ]
Symbols:
Global:
- Name: main
Type: STT_FUNC
Section: .text
Value: 0x0
Size: 18
#CFG: Functions:
#CFG: BasicBlocks:
#CFG: - Address: 0x0000000000000000
#CFG: Preds: [ ]
#CFG: Succs: [ 0x0000000000000011, 0x000000000000000A ]
#CFG: - Address: 0x0000000000000011
#CFG: Preds: [ 0x0000000000000000, 0x000000000000000A ]
#CFG: Succs: [ ]
#CFG: - Address: 0x000000000000000A
#CFG: Preds: [ 0x0000000000000000 ]
#CFG: Succs: [ 0x0000000000000011 ]
|