2 * Copyright (C) 2017 Josh Poimboeuf <jpoimboe@redhat.com>
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; either version 2
7 * of the License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, see <http://www.gnu.org/licenses/>.
25 #include <linux/hashtable.h>
29 struct cfi_reg regs
[CFI_NUM_REGS
];
37 struct list_head list
;
38 struct hlist_node hash
;
43 unsigned long immediate
;
44 bool alt_group
, visited
, dead_end
, ignore
;
45 struct symbol
*call_dest
;
46 struct instruction
*jump_dest
;
47 struct list_head alts
;
49 struct stack_op stack_op
;
50 struct insn_state state
;
55 struct list_head insn_list
;
56 DECLARE_HASHTABLE(insn_hash
, 16);
57 struct section
*rodata
, *whitelist
;
58 bool ignore_unreachables
, c_file
;
61 int check(const char *objname
, bool nofp
);
63 #define for_each_insn(file, insn) \
64 list_for_each_entry(insn, &file->insn_list, list)