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:
parent
7f709ce739
commit
168c12b024
@ -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
Loading…
Reference in New Issue
Block a user