hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
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
#!/bin/awk -f
# SPDX-License-Identifier: GPL-2.0
# Usage: objdump -d a.out | awk -f objdump_reformat.awk | ./insn_decoder_test
# Reformats the disassembly as follows:
# - Removes all lines except the disassembled instructions.
# - For instructions that exceed 1 line (7 bytes), crams all the hex bytes
# into a single line.
# - Remove bad(or prefix only) instructions
 
BEGIN {
   prev_addr = ""
   prev_hex = ""
   prev_mnemonic = ""
   bad_expr = "(\\(bad\\)|^rex|^.byte|^rep(z|nz)$|^lock$|^es$|^cs$|^ss$|^ds$|^fs$|^gs$|^data(16|32)$|^addr(16|32|64))"
   fwait_expr = "^9b "
   fwait_str="9b\tfwait"
}
 
/^ *[0-9a-f]+ <[^>]*>:/ {
   # Symbol entry
   printf("%s%s\n", $2, $1)
}
 
/^ *[0-9a-f]+:/ {
   if (split($0, field, "\t") < 3) {
       # This is a continuation of the same insn.
       prev_hex = prev_hex field[2]
   } else {
       # Skip bad instructions
       if (match(prev_mnemonic, bad_expr))
           prev_addr = ""
       # Split fwait from other f* instructions
       if (match(prev_hex, fwait_expr) && prev_mnemonic != "fwait") {
           printf "%s\t%s\n", prev_addr, fwait_str
           sub(fwait_expr, "", prev_hex)
       }
       if (prev_addr != "")
           printf "%s\t%s\t%s\n", prev_addr, prev_hex, prev_mnemonic
       prev_addr = field[1]
       prev_hex = field[2]
       prev_mnemonic = field[3]
   }
}
 
END {
   if (prev_addr != "")
       printf "%s\t%s\t%s\n", prev_addr, prev_hex, prev_mnemonic
}