target/xtensa: extract core opcode translators

Move implementations of core opcodes into separate translation
functions. Introduce data structures for mapping opcode name to
translator function. Make an array of core opcode/translator structures.

Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
This commit is contained in:
Max Filippov 2017-11-03 18:29:27 -07:00
parent 7f709ce739
commit 168c12b024
2 changed files with 3145 additions and 0 deletions

View File

@ -37,6 +37,7 @@
#include "cpu-qom.h" #include "cpu-qom.h"
#include "exec/cpu-defs.h" #include "exec/cpu-defs.h"
#include "fpu/softfloat.h" #include "fpu/softfloat.h"
#include "xtensa-isa.h"
#define NB_MMU_MODES 4 #define NB_MMU_MODES 4
@ -205,6 +206,8 @@ enum {
#define MEMCTL_DSNP 0x2 #define MEMCTL_DSNP 0x2
#define MEMCTL_IL0EN 0x1 #define MEMCTL_IL0EN 0x1
#define MAX_INSN_LENGTH 64
#define MAX_OPCODE_ARGS 16
#define MAX_NAREG 64 #define MAX_NAREG 64
#define MAX_NINTERRUPT 32 #define MAX_NINTERRUPT 32
#define MAX_NLEVEL 6 #define MAX_NLEVEL 6
@ -330,6 +333,23 @@ typedef struct XtensaMemory {
} location[MAX_NMEMORY]; } location[MAX_NMEMORY];
} XtensaMemory; } XtensaMemory;
typedef struct DisasContext DisasContext;
typedef void (*XtensaOpcodeOp)(DisasContext *dc, const uint32_t arg[],
const uint32_t par[]);
typedef struct XtensaOpcodeOps {
const char *name;
XtensaOpcodeOp translate;
const uint32_t *par;
} XtensaOpcodeOps;
typedef struct XtensaOpcodeTranslators {
unsigned num_opcodes;
const XtensaOpcodeOps *opcode;
} XtensaOpcodeTranslators;
extern const XtensaOpcodeTranslators xtensa_core_opcodes;
struct XtensaConfig { struct XtensaConfig {
const char *name; const char *name;
uint64_t options; uint64_t options;
@ -370,6 +390,8 @@ struct XtensaConfig {
uint32_t configid[2]; uint32_t configid[2];
void *isa_internal;
uint32_t clock_freq_khz; uint32_t clock_freq_khz;
xtensa_tlb itlb; xtensa_tlb itlb;
@ -522,6 +544,8 @@ static inline void xtensa_select_static_vectors(CPUXtensaState *env,
env->static_vectors = n; env->static_vectors = n;
} }
void xtensa_runstall(CPUXtensaState *env, bool runstall); void xtensa_runstall(CPUXtensaState *env, bool runstall);
XtensaOpcodeOps *xtensa_find_opcode_ops(const XtensaOpcodeTranslators *t,
const char *opcode);
#define XTENSA_OPTION_BIT(opt) (((uint64_t)1) << (opt)) #define XTENSA_OPTION_BIT(opt) (((uint64_t)1) << (opt))
#define XTENSA_OPTION_ALL (~(uint64_t)0) #define XTENSA_OPTION_ALL (~(uint64_t)0)

File diff suppressed because it is too large Load Diff