Commit | Line | Data |
---|---|---|
92df71f0 | 1 | /* Disassemble support for GDB. |
b811d2c2 | 2 | Copyright (C) 2002-2020 Free Software Foundation, Inc. |
92df71f0 FN |
3 | |
4 | This file is part of GDB. | |
5 | ||
6 | This program is free software; you can redistribute it and/or modify | |
7 | it under the terms of the GNU General Public License as published by | |
a9762ec7 | 8 | the Free Software Foundation; either version 3 of the License, or |
92df71f0 FN |
9 | (at your option) any later version. |
10 | ||
11 | This program is distributed in the hope that it will be useful, | |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | GNU General Public License for more details. | |
15 | ||
16 | You should have received a copy of the GNU General Public License | |
a9762ec7 | 17 | along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
92df71f0 FN |
18 | |
19 | #ifndef DISASM_H | |
20 | #define DISASM_H | |
21 | ||
d55e5aa6 | 22 | #include "dis-asm.h" |
268a13a5 | 23 | #include "gdbsupport/enum-flags.h" |
9a24775b PA |
24 | |
25 | enum gdb_disassembly_flag | |
26 | { | |
27 | DISASSEMBLY_SOURCE_DEPRECATED = (0x1 << 0), | |
28 | DISASSEMBLY_RAW_INSN = (0x1 << 1), | |
29 | DISASSEMBLY_OMIT_FNAME = (0x1 << 2), | |
30 | DISASSEMBLY_FILENAME = (0x1 << 3), | |
31 | DISASSEMBLY_OMIT_PC = (0x1 << 4), | |
32 | DISASSEMBLY_SOURCE = (0x1 << 5), | |
33 | DISASSEMBLY_SPECULATIVE = (0x1 << 6), | |
34 | }; | |
35 | DEF_ENUM_FLAGS_TYPE (enum gdb_disassembly_flag, gdb_disassembly_flags); | |
e6158f16 | 36 | |
ed3ef339 | 37 | struct gdbarch; |
da3331ec | 38 | struct ui_out; |
30e221b4 | 39 | struct ui_file; |
da3331ec | 40 | |
e47ad6c0 YQ |
41 | class gdb_disassembler |
42 | { | |
43 | using di_read_memory_ftype = decltype (disassemble_info::read_memory_func); | |
44 | ||
45 | public: | |
46 | gdb_disassembler (struct gdbarch *gdbarch, struct ui_file *file) | |
47 | : gdb_disassembler (gdbarch, file, dis_asm_read_memory) | |
48 | {} | |
49 | ||
4d89c1c7 TT |
50 | ~gdb_disassembler (); |
51 | ||
52 | DISABLE_COPY_AND_ASSIGN (gdb_disassembler); | |
53 | ||
e47ad6c0 YQ |
54 | int print_insn (CORE_ADDR memaddr, int *branch_delay_insns = NULL); |
55 | ||
e47ad6c0 YQ |
56 | /* Return the gdbarch of gdb_disassembler. */ |
57 | struct gdbarch *arch () | |
58 | { return m_gdbarch; } | |
59 | ||
60 | protected: | |
61 | gdb_disassembler (struct gdbarch *gdbarch, struct ui_file *file, | |
62 | di_read_memory_ftype func); | |
63 | ||
64 | struct ui_file *stream () | |
65 | { return (struct ui_file *) m_di.stream; } | |
66 | ||
67 | private: | |
68 | struct gdbarch *m_gdbarch; | |
69 | ||
70 | /* Stores data required for disassembling instructions in | |
71 | opcodes. */ | |
72 | struct disassemble_info m_di; | |
471b9d15 MR |
73 | |
74 | /* If we own the string in `m_di.disassembler_options', we do so | |
75 | using this field. */ | |
76 | std::string m_disassembler_options_holder; | |
77 | ||
d8b49cf0 | 78 | CORE_ADDR m_err_memaddr; |
e47ad6c0 YQ |
79 | |
80 | static int dis_asm_read_memory (bfd_vma memaddr, gdb_byte *myaddr, | |
81 | unsigned int len, | |
82 | struct disassemble_info *info); | |
83 | static void dis_asm_memory_error (int err, bfd_vma memaddr, | |
84 | struct disassemble_info *info); | |
85 | static void dis_asm_print_address (bfd_vma addr, | |
86 | struct disassemble_info *info); | |
87 | }; | |
88 | ||
a50a4026 MM |
89 | /* An instruction to be disassembled. */ |
90 | ||
91 | struct disasm_insn | |
92 | { | |
93 | /* The address of the memory containing the instruction. */ | |
94 | CORE_ADDR addr; | |
95 | ||
96 | /* An optional instruction number. If non-zero, it is printed first. */ | |
97 | unsigned int number; | |
98 | ||
99 | /* True if the instruction was executed speculatively. */ | |
100 | unsigned int is_speculative:1; | |
101 | }; | |
102 | ||
13274fc3 | 103 | extern void gdb_disassembly (struct gdbarch *gdbarch, struct ui_out *uiout, |
9a24775b | 104 | gdb_disassembly_flags flags, int how_many, |
9c419145 | 105 | CORE_ADDR low, CORE_ADDR high); |
92bf2b80 | 106 | |
a4642986 MR |
107 | /* Print the instruction at address MEMADDR in debugged memory, |
108 | on STREAM. Returns the length of the instruction, in bytes, | |
109 | and, if requested, the number of branch delay slot instructions. */ | |
92bf2b80 | 110 | |
13274fc3 UW |
111 | extern int gdb_print_insn (struct gdbarch *gdbarch, CORE_ADDR memaddr, |
112 | struct ui_file *stream, int *branch_delay_insns); | |
92bf2b80 | 113 | |
c99cc448 | 114 | /* Class used to pretty-print instructions. */ |
187808b0 | 115 | |
8b172ce7 PA |
116 | class gdb_pretty_print_disassembler |
117 | { | |
118 | public: | |
046bebe1 TT |
119 | explicit gdb_pretty_print_disassembler (struct gdbarch *gdbarch, |
120 | struct ui_out *uiout) | |
121 | : m_uiout (uiout), | |
122 | m_insn_stb (uiout->can_emit_style_escape ()), | |
123 | m_di (gdbarch, &m_insn_stb) | |
8b172ce7 PA |
124 | {} |
125 | ||
046bebe1 TT |
126 | /* Prints the instruction INSN into the saved ui_out and returns the |
127 | length of the printed instruction in bytes. */ | |
128 | int pretty_print_insn (const struct disasm_insn *insn, | |
9a24775b | 129 | gdb_disassembly_flags flags); |
8b172ce7 PA |
130 | |
131 | private: | |
132 | /* Returns the architecture used for disassembling. */ | |
133 | struct gdbarch *arch () { return m_di.arch (); } | |
134 | ||
046bebe1 TT |
135 | /* The ui_out that is used by pretty_print_insn. */ |
136 | struct ui_out *m_uiout; | |
8b172ce7 PA |
137 | |
138 | /* The buffer used to build the instruction string. The | |
139 | disassembler is initialized with this stream. */ | |
140 | string_file m_insn_stb; | |
141 | ||
046bebe1 TT |
142 | /* The disassembler used for instruction printing. */ |
143 | gdb_disassembler m_di; | |
144 | ||
8b172ce7 PA |
145 | /* The buffer used to build the raw opcodes string. */ |
146 | string_file m_opcode_stb; | |
147 | }; | |
187808b0 | 148 | |
eda5a4d7 PA |
149 | /* Return the length in bytes of the instruction at address MEMADDR in |
150 | debugged memory. */ | |
151 | ||
152 | extern int gdb_insn_length (struct gdbarch *gdbarch, CORE_ADDR memaddr); | |
153 | ||
154 | /* Return the length in bytes of INSN, originally at MEMADDR. MAX_LEN | |
155 | is the size of the buffer containing INSN. */ | |
156 | ||
157 | extern int gdb_buffered_insn_length (struct gdbarch *gdbarch, | |
158 | const gdb_byte *insn, int max_len, | |
159 | CORE_ADDR memaddr); | |
160 | ||
65b48a81 PB |
161 | /* Returns GDBARCH's disassembler options. */ |
162 | ||
163 | extern char *get_disassembler_options (struct gdbarch *gdbarch); | |
164 | ||
165 | /* Sets the active gdbarch's disassembler options to OPTIONS. */ | |
166 | ||
167 | extern void set_disassembler_options (char *options); | |
168 | ||
92df71f0 | 169 | #endif |