blob: ced3765c4f4445daf3d1d8db2851af6955978ca5 [file] [log] [blame]
Thomas Gleixner1ccea772019-05-19 15:51:43 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Josh Poimboeuf442f04c2016-02-28 22:22:41 -06002/*
3 * Copyright (C) 2015 Josh Poimboeuf <jpoimboe@redhat.com>
Josh Poimboeuf442f04c2016-02-28 22:22:41 -06004 */
5
6#ifndef _ARCH_H
7#define _ARCH_H
8
9#include <stdbool.h>
Josh Poimboeufbaa41462017-06-28 10:11:07 -050010#include <linux/list.h>
Josh Poimboeuf442f04c2016-02-28 22:22:41 -060011#include "elf.h"
Josh Poimboeufbaa41462017-06-28 10:11:07 -050012#include "cfi.h"
Josh Poimboeuf442f04c2016-02-28 22:22:41 -060013
Josh Poimboeuf9fe7b762019-07-17 20:36:56 -050014enum insn_type {
15 INSN_JUMP_CONDITIONAL,
16 INSN_JUMP_UNCONDITIONAL,
17 INSN_JUMP_DYNAMIC,
Josh Poimboeufb68b9902019-07-17 20:36:57 -050018 INSN_JUMP_DYNAMIC_CONDITIONAL,
Josh Poimboeuf9fe7b762019-07-17 20:36:56 -050019 INSN_CALL,
20 INSN_CALL_DYNAMIC,
21 INSN_RETURN,
22 INSN_CONTEXT_SWITCH,
23 INSN_STACK,
24 INSN_BUG,
25 INSN_NOP,
26 INSN_STAC,
27 INSN_CLAC,
28 INSN_STD,
29 INSN_CLD,
30 INSN_OTHER,
31};
Josh Poimboeuf442f04c2016-02-28 22:22:41 -060032
Josh Poimboeufbaa41462017-06-28 10:11:07 -050033enum op_dest_type {
34 OP_DEST_REG,
35 OP_DEST_REG_INDIRECT,
36 OP_DEST_MEM,
37 OP_DEST_PUSH,
Peter Zijlstraea242132019-02-25 12:50:09 +010038 OP_DEST_PUSHF,
Josh Poimboeufbaa41462017-06-28 10:11:07 -050039 OP_DEST_LEAVE,
40};
41
42struct op_dest {
43 enum op_dest_type type;
44 unsigned char reg;
45 int offset;
46};
47
48enum op_src_type {
49 OP_SRC_REG,
50 OP_SRC_REG_INDIRECT,
51 OP_SRC_CONST,
52 OP_SRC_POP,
Peter Zijlstraea242132019-02-25 12:50:09 +010053 OP_SRC_POPF,
Josh Poimboeufbaa41462017-06-28 10:11:07 -050054 OP_SRC_ADD,
55 OP_SRC_AND,
56};
57
58struct op_src {
59 enum op_src_type type;
60 unsigned char reg;
61 int offset;
62};
63
64struct stack_op {
65 struct op_dest dest;
66 struct op_src src;
67};
68
69void arch_initial_func_cfi_state(struct cfi_state *state);
70
Josh Poimboeuf442f04c2016-02-28 22:22:41 -060071int arch_decode_instruction(struct elf *elf, struct section *sec,
72 unsigned long offset, unsigned int maxlen,
Josh Poimboeuf9fe7b762019-07-17 20:36:56 -050073 unsigned int *len, enum insn_type *type,
Josh Poimboeufbaa41462017-06-28 10:11:07 -050074 unsigned long *immediate, struct stack_op *op);
75
76bool arch_callee_saved_reg(unsigned char reg);
Josh Poimboeuf442f04c2016-02-28 22:22:41 -060077
78#endif /* _ARCH_H */