target: Use forward declared type instead of structure type

The CPU / CPU state are forward declared.

  $ git grep -E 'struct [A-Za-z]+CPU\ \*'
  target/arm/hvf_arm.h:16:void hvf_arm_set_cpu_features_from_host(struct ARMCPU *cpu);
  target/openrisc/cpu.h:234:    int (*cpu_openrisc_map_address_code)(struct OpenRISCCPU *cpu,
  target/openrisc/cpu.h:238:    int (*cpu_openrisc_map_address_data)(struct OpenRISCCPU *cpu,

  $ git grep -E 'struct CPU[A-Za-z0-9]+State\ \*'
  target/mips/internal.h:137:    int (*map_address)(struct CPUMIPSState *env, hwaddr *physical, int *prot,
  target/mips/internal.h:139:    void (*helper_tlbwi)(struct CPUMIPSState *env);
  target/mips/internal.h:140:    void (*helper_tlbwr)(struct CPUMIPSState *env);
  target/mips/internal.h:141:    void (*helper_tlbp)(struct CPUMIPSState *env);
  target/mips/internal.h:142:    void (*helper_tlbr)(struct CPUMIPSState *env);
  target/mips/internal.h:143:    void (*helper_tlbinv)(struct CPUMIPSState *env);
  target/mips/internal.h:144:    void (*helper_tlbinvf)(struct CPUMIPSState *env);
  target/xtensa/cpu.h:347:    struct CPUXtensaState *env;
  ...

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220214183144.27402-12-f4bug@amsat.org>
This commit is contained in:
Philippe Mathieu-Daudé 2022-02-07 13:17:56 +01:00
parent a01bab6507
commit 3686119875
8 changed files with 93 additions and 93 deletions

View File

@ -13,6 +13,6 @@
#include "cpu.h" #include "cpu.h"
void hvf_arm_set_cpu_features_from_host(struct ARMCPU *cpu); void hvf_arm_set_cpu_features_from_host(ARMCPU *cpu);
#endif #endif

View File

@ -171,12 +171,12 @@ void write_val_to_reg(target_ulong reg_ptr, target_ulong val, int size)
} }
} }
static bool is_host_reg(struct CPUX86State *env, target_ulong ptr) static bool is_host_reg(CPUX86State *env, target_ulong ptr)
{ {
return (ptr - (target_ulong)&env->regs[0]) < sizeof(env->regs); return (ptr - (target_ulong)&env->regs[0]) < sizeof(env->regs);
} }
void write_val_ext(struct CPUX86State *env, target_ulong ptr, target_ulong val, int size) void write_val_ext(CPUX86State *env, target_ulong ptr, target_ulong val, int size)
{ {
if (is_host_reg(env, ptr)) { if (is_host_reg(env, ptr)) {
write_val_to_reg(ptr, val, size); write_val_to_reg(ptr, val, size);
@ -185,14 +185,14 @@ void write_val_ext(struct CPUX86State *env, target_ulong ptr, target_ulong val,
vmx_write_mem(env_cpu(env), ptr, &val, size); vmx_write_mem(env_cpu(env), ptr, &val, size);
} }
uint8_t *read_mmio(struct CPUX86State *env, target_ulong ptr, int bytes) uint8_t *read_mmio(CPUX86State *env, target_ulong ptr, int bytes)
{ {
vmx_read_mem(env_cpu(env), env->hvf_mmio_buf, ptr, bytes); vmx_read_mem(env_cpu(env), env->hvf_mmio_buf, ptr, bytes);
return env->hvf_mmio_buf; return env->hvf_mmio_buf;
} }
target_ulong read_val_ext(struct CPUX86State *env, target_ulong ptr, int size) target_ulong read_val_ext(CPUX86State *env, target_ulong ptr, int size)
{ {
target_ulong val; target_ulong val;
uint8_t *mmio_ptr; uint8_t *mmio_ptr;
@ -222,7 +222,7 @@ target_ulong read_val_ext(struct CPUX86State *env, target_ulong ptr, int size)
return val; return val;
} }
static void fetch_operands(struct CPUX86State *env, struct x86_decode *decode, static void fetch_operands(CPUX86State *env, struct x86_decode *decode,
int n, bool val_op0, bool val_op1, bool val_op2) int n, bool val_op0, bool val_op1, bool val_op2)
{ {
int i; int i;
@ -261,7 +261,7 @@ static void fetch_operands(struct CPUX86State *env, struct x86_decode *decode,
} }
} }
static void exec_mov(struct CPUX86State *env, struct x86_decode *decode) static void exec_mov(CPUX86State *env, struct x86_decode *decode)
{ {
fetch_operands(env, decode, 2, false, true, false); fetch_operands(env, decode, 2, false, true, false);
write_val_ext(env, decode->op[0].ptr, decode->op[1].val, write_val_ext(env, decode->op[0].ptr, decode->op[1].val,
@ -270,49 +270,49 @@ static void exec_mov(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_add(struct CPUX86State *env, struct x86_decode *decode) static void exec_add(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, +, SET_FLAGS_OSZAPC_ADD, true); EXEC_2OP_FLAGS_CMD(env, decode, +, SET_FLAGS_OSZAPC_ADD, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_or(struct CPUX86State *env, struct x86_decode *decode) static void exec_or(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, |, SET_FLAGS_OSZAPC_LOGIC, true); EXEC_2OP_FLAGS_CMD(env, decode, |, SET_FLAGS_OSZAPC_LOGIC, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_adc(struct CPUX86State *env, struct x86_decode *decode) static void exec_adc(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, +get_CF(env)+, SET_FLAGS_OSZAPC_ADD, true); EXEC_2OP_FLAGS_CMD(env, decode, +get_CF(env)+, SET_FLAGS_OSZAPC_ADD, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_sbb(struct CPUX86State *env, struct x86_decode *decode) static void exec_sbb(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, -get_CF(env)-, SET_FLAGS_OSZAPC_SUB, true); EXEC_2OP_FLAGS_CMD(env, decode, -get_CF(env)-, SET_FLAGS_OSZAPC_SUB, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_and(struct CPUX86State *env, struct x86_decode *decode) static void exec_and(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, &, SET_FLAGS_OSZAPC_LOGIC, true); EXEC_2OP_FLAGS_CMD(env, decode, &, SET_FLAGS_OSZAPC_LOGIC, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_sub(struct CPUX86State *env, struct x86_decode *decode) static void exec_sub(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, -, SET_FLAGS_OSZAPC_SUB, true); EXEC_2OP_FLAGS_CMD(env, decode, -, SET_FLAGS_OSZAPC_SUB, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_xor(struct CPUX86State *env, struct x86_decode *decode) static void exec_xor(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, ^, SET_FLAGS_OSZAPC_LOGIC, true); EXEC_2OP_FLAGS_CMD(env, decode, ^, SET_FLAGS_OSZAPC_LOGIC, true);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_neg(struct CPUX86State *env, struct x86_decode *decode) static void exec_neg(CPUX86State *env, struct x86_decode *decode)
{ {
/*EXEC_2OP_FLAGS_CMD(env, decode, -, SET_FLAGS_OSZAPC_SUB, false);*/ /*EXEC_2OP_FLAGS_CMD(env, decode, -, SET_FLAGS_OSZAPC_SUB, false);*/
int32_t val; int32_t val;
@ -335,13 +335,13 @@ static void exec_neg(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_cmp(struct CPUX86State *env, struct x86_decode *decode) static void exec_cmp(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, -, SET_FLAGS_OSZAPC_SUB, false); EXEC_2OP_FLAGS_CMD(env, decode, -, SET_FLAGS_OSZAPC_SUB, false);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_inc(struct CPUX86State *env, struct x86_decode *decode) static void exec_inc(CPUX86State *env, struct x86_decode *decode)
{ {
decode->op[1].type = X86_VAR_IMMEDIATE; decode->op[1].type = X86_VAR_IMMEDIATE;
decode->op[1].val = 0; decode->op[1].val = 0;
@ -351,7 +351,7 @@ static void exec_inc(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_dec(struct CPUX86State *env, struct x86_decode *decode) static void exec_dec(CPUX86State *env, struct x86_decode *decode)
{ {
decode->op[1].type = X86_VAR_IMMEDIATE; decode->op[1].type = X86_VAR_IMMEDIATE;
decode->op[1].val = 0; decode->op[1].val = 0;
@ -360,13 +360,13 @@ static void exec_dec(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_tst(struct CPUX86State *env, struct x86_decode *decode) static void exec_tst(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, &, SET_FLAGS_OSZAPC_LOGIC, false); EXEC_2OP_FLAGS_CMD(env, decode, &, SET_FLAGS_OSZAPC_LOGIC, false);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_not(struct CPUX86State *env, struct x86_decode *decode) static void exec_not(CPUX86State *env, struct x86_decode *decode)
{ {
fetch_operands(env, decode, 1, true, false, false); fetch_operands(env, decode, 1, true, false, false);
@ -375,7 +375,7 @@ static void exec_not(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
void exec_movzx(struct CPUX86State *env, struct x86_decode *decode) void exec_movzx(CPUX86State *env, struct x86_decode *decode)
{ {
int src_op_size; int src_op_size;
int op_size = decode->operand_size; int op_size = decode->operand_size;
@ -395,7 +395,7 @@ void exec_movzx(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_out(struct CPUX86State *env, struct x86_decode *decode) static void exec_out(CPUX86State *env, struct x86_decode *decode)
{ {
switch (decode->opcode[0]) { switch (decode->opcode[0]) {
case 0xe6: case 0xe6:
@ -419,7 +419,7 @@ static void exec_out(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_in(struct CPUX86State *env, struct x86_decode *decode) static void exec_in(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong val = 0; target_ulong val = 0;
switch (decode->opcode[0]) { switch (decode->opcode[0]) {
@ -455,7 +455,7 @@ static void exec_in(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static inline void string_increment_reg(struct CPUX86State *env, int reg, static inline void string_increment_reg(CPUX86State *env, int reg,
struct x86_decode *decode) struct x86_decode *decode)
{ {
target_ulong val = read_reg(env, reg, decode->addressing_size); target_ulong val = read_reg(env, reg, decode->addressing_size);
@ -467,8 +467,8 @@ static inline void string_increment_reg(struct CPUX86State *env, int reg,
write_reg(env, reg, val, decode->addressing_size); write_reg(env, reg, val, decode->addressing_size);
} }
static inline void string_rep(struct CPUX86State *env, struct x86_decode *decode, static inline void string_rep(CPUX86State *env, struct x86_decode *decode,
void (*func)(struct CPUX86State *env, void (*func)(CPUX86State *env,
struct x86_decode *ins), int rep) struct x86_decode *ins), int rep)
{ {
target_ulong rcx = read_reg(env, R_ECX, decode->addressing_size); target_ulong rcx = read_reg(env, R_ECX, decode->addressing_size);
@ -484,7 +484,7 @@ static inline void string_rep(struct CPUX86State *env, struct x86_decode *decode
} }
} }
static void exec_ins_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_ins_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong addr = linear_addr_size(env_cpu(env), RDI(env), target_ulong addr = linear_addr_size(env_cpu(env), RDI(env),
decode->addressing_size, R_ES); decode->addressing_size, R_ES);
@ -497,7 +497,7 @@ static void exec_ins_single(struct CPUX86State *env, struct x86_decode *decode)
string_increment_reg(env, R_EDI, decode); string_increment_reg(env, R_EDI, decode);
} }
static void exec_ins(struct CPUX86State *env, struct x86_decode *decode) static void exec_ins(CPUX86State *env, struct x86_decode *decode)
{ {
if (decode->rep) { if (decode->rep) {
string_rep(env, decode, exec_ins_single, 0); string_rep(env, decode, exec_ins_single, 0);
@ -508,7 +508,7 @@ static void exec_ins(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_outs_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_outs_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong addr = decode_linear_addr(env, decode, RSI(env), R_DS); target_ulong addr = decode_linear_addr(env, decode, RSI(env), R_DS);
@ -520,7 +520,7 @@ static void exec_outs_single(struct CPUX86State *env, struct x86_decode *decode)
string_increment_reg(env, R_ESI, decode); string_increment_reg(env, R_ESI, decode);
} }
static void exec_outs(struct CPUX86State *env, struct x86_decode *decode) static void exec_outs(CPUX86State *env, struct x86_decode *decode)
{ {
if (decode->rep) { if (decode->rep) {
string_rep(env, decode, exec_outs_single, 0); string_rep(env, decode, exec_outs_single, 0);
@ -531,7 +531,7 @@ static void exec_outs(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_movs_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_movs_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong src_addr; target_ulong src_addr;
target_ulong dst_addr; target_ulong dst_addr;
@ -548,7 +548,7 @@ static void exec_movs_single(struct CPUX86State *env, struct x86_decode *decode)
string_increment_reg(env, R_EDI, decode); string_increment_reg(env, R_EDI, decode);
} }
static void exec_movs(struct CPUX86State *env, struct x86_decode *decode) static void exec_movs(CPUX86State *env, struct x86_decode *decode)
{ {
if (decode->rep) { if (decode->rep) {
string_rep(env, decode, exec_movs_single, 0); string_rep(env, decode, exec_movs_single, 0);
@ -559,7 +559,7 @@ static void exec_movs(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_cmps_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_cmps_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong src_addr; target_ulong src_addr;
target_ulong dst_addr; target_ulong dst_addr;
@ -579,7 +579,7 @@ static void exec_cmps_single(struct CPUX86State *env, struct x86_decode *decode)
string_increment_reg(env, R_EDI, decode); string_increment_reg(env, R_EDI, decode);
} }
static void exec_cmps(struct CPUX86State *env, struct x86_decode *decode) static void exec_cmps(CPUX86State *env, struct x86_decode *decode)
{ {
if (decode->rep) { if (decode->rep) {
string_rep(env, decode, exec_cmps_single, decode->rep); string_rep(env, decode, exec_cmps_single, decode->rep);
@ -590,7 +590,7 @@ static void exec_cmps(struct CPUX86State *env, struct x86_decode *decode)
} }
static void exec_stos_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_stos_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong addr; target_ulong addr;
target_ulong val; target_ulong val;
@ -604,7 +604,7 @@ static void exec_stos_single(struct CPUX86State *env, struct x86_decode *decode)
} }
static void exec_stos(struct CPUX86State *env, struct x86_decode *decode) static void exec_stos(CPUX86State *env, struct x86_decode *decode)
{ {
if (decode->rep) { if (decode->rep) {
string_rep(env, decode, exec_stos_single, 0); string_rep(env, decode, exec_stos_single, 0);
@ -615,7 +615,7 @@ static void exec_stos(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_scas_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_scas_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong addr; target_ulong addr;
@ -628,7 +628,7 @@ static void exec_scas_single(struct CPUX86State *env, struct x86_decode *decode)
string_increment_reg(env, R_EDI, decode); string_increment_reg(env, R_EDI, decode);
} }
static void exec_scas(struct CPUX86State *env, struct x86_decode *decode) static void exec_scas(CPUX86State *env, struct x86_decode *decode)
{ {
decode->op[0].type = X86_VAR_REG; decode->op[0].type = X86_VAR_REG;
decode->op[0].reg = R_EAX; decode->op[0].reg = R_EAX;
@ -641,7 +641,7 @@ static void exec_scas(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_lods_single(struct CPUX86State *env, struct x86_decode *decode) static void exec_lods_single(CPUX86State *env, struct x86_decode *decode)
{ {
target_ulong addr; target_ulong addr;
target_ulong val = 0; target_ulong val = 0;
@ -653,7 +653,7 @@ static void exec_lods_single(struct CPUX86State *env, struct x86_decode *decode)
string_increment_reg(env, R_ESI, decode); string_increment_reg(env, R_ESI, decode);
} }
static void exec_lods(struct CPUX86State *env, struct x86_decode *decode) static void exec_lods(CPUX86State *env, struct x86_decode *decode)
{ {
if (decode->rep) { if (decode->rep) {
string_rep(env, decode, exec_lods_single, 0); string_rep(env, decode, exec_lods_single, 0);
@ -760,7 +760,7 @@ void simulate_rdmsr(struct CPUState *cpu)
RDX(env) = (uint32_t)(val >> 32); RDX(env) = (uint32_t)(val >> 32);
} }
static void exec_rdmsr(struct CPUX86State *env, struct x86_decode *decode) static void exec_rdmsr(CPUX86State *env, struct x86_decode *decode)
{ {
simulate_rdmsr(env_cpu(env)); simulate_rdmsr(env_cpu(env));
env->eip += decode->len; env->eip += decode->len;
@ -855,7 +855,7 @@ void simulate_wrmsr(struct CPUState *cpu)
printf("write msr %llx\n", RCX(cpu));*/ printf("write msr %llx\n", RCX(cpu));*/
} }
static void exec_wrmsr(struct CPUX86State *env, struct x86_decode *decode) static void exec_wrmsr(CPUX86State *env, struct x86_decode *decode)
{ {
simulate_wrmsr(env_cpu(env)); simulate_wrmsr(env_cpu(env));
env->eip += decode->len; env->eip += decode->len;
@ -865,7 +865,7 @@ static void exec_wrmsr(struct CPUX86State *env, struct x86_decode *decode)
* flag: * flag:
* 0 - bt, 1 - btc, 2 - bts, 3 - btr * 0 - bt, 1 - btc, 2 - bts, 3 - btr
*/ */
static void do_bt(struct CPUX86State *env, struct x86_decode *decode, int flag) static void do_bt(CPUX86State *env, struct x86_decode *decode, int flag)
{ {
int32_t displacement; int32_t displacement;
uint8_t index; uint8_t index;
@ -911,31 +911,31 @@ static void do_bt(struct CPUX86State *env, struct x86_decode *decode, int flag)
set_CF(env, cf); set_CF(env, cf);
} }
static void exec_bt(struct CPUX86State *env, struct x86_decode *decode) static void exec_bt(CPUX86State *env, struct x86_decode *decode)
{ {
do_bt(env, decode, 0); do_bt(env, decode, 0);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_btc(struct CPUX86State *env, struct x86_decode *decode) static void exec_btc(CPUX86State *env, struct x86_decode *decode)
{ {
do_bt(env, decode, 1); do_bt(env, decode, 1);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_btr(struct CPUX86State *env, struct x86_decode *decode) static void exec_btr(CPUX86State *env, struct x86_decode *decode)
{ {
do_bt(env, decode, 3); do_bt(env, decode, 3);
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_bts(struct CPUX86State *env, struct x86_decode *decode) static void exec_bts(CPUX86State *env, struct x86_decode *decode)
{ {
do_bt(env, decode, 2); do_bt(env, decode, 2);
env->eip += decode->len; env->eip += decode->len;
} }
void exec_shl(struct CPUX86State *env, struct x86_decode *decode) void exec_shl(CPUX86State *env, struct x86_decode *decode)
{ {
uint8_t count; uint8_t count;
int of = 0, cf = 0; int of = 0, cf = 0;
@ -1022,7 +1022,7 @@ void exec_movsx(CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
void exec_ror(struct CPUX86State *env, struct x86_decode *decode) void exec_ror(CPUX86State *env, struct x86_decode *decode)
{ {
uint8_t count; uint8_t count;
@ -1100,7 +1100,7 @@ void exec_ror(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
void exec_rol(struct CPUX86State *env, struct x86_decode *decode) void exec_rol(CPUX86State *env, struct x86_decode *decode)
{ {
uint8_t count; uint8_t count;
@ -1182,7 +1182,7 @@ void exec_rol(struct CPUX86State *env, struct x86_decode *decode)
} }
void exec_rcl(struct CPUX86State *env, struct x86_decode *decode) void exec_rcl(CPUX86State *env, struct x86_decode *decode)
{ {
uint8_t count; uint8_t count;
int of = 0, cf = 0; int of = 0, cf = 0;
@ -1267,7 +1267,7 @@ void exec_rcl(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
void exec_rcr(struct CPUX86State *env, struct x86_decode *decode) void exec_rcr(CPUX86State *env, struct x86_decode *decode)
{ {
uint8_t count; uint8_t count;
int of = 0, cf = 0; int of = 0, cf = 0;
@ -1342,7 +1342,7 @@ void exec_rcr(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_xchg(struct CPUX86State *env, struct x86_decode *decode) static void exec_xchg(CPUX86State *env, struct x86_decode *decode)
{ {
fetch_operands(env, decode, 2, true, true, false); fetch_operands(env, decode, 2, true, true, false);
@ -1354,7 +1354,7 @@ static void exec_xchg(struct CPUX86State *env, struct x86_decode *decode)
env->eip += decode->len; env->eip += decode->len;
} }
static void exec_xadd(struct CPUX86State *env, struct x86_decode *decode) static void exec_xadd(CPUX86State *env, struct x86_decode *decode)
{ {
EXEC_2OP_FLAGS_CMD(env, decode, +, SET_FLAGS_OSZAPC_ADD, true); EXEC_2OP_FLAGS_CMD(env, decode, +, SET_FLAGS_OSZAPC_ADD, true);
write_val_ext(env, decode->op[1].ptr, decode->op[0].val, write_val_ext(env, decode->op[1].ptr, decode->op[0].val,
@ -1365,7 +1365,7 @@ static void exec_xadd(struct CPUX86State *env, struct x86_decode *decode)
static struct cmd_handler { static struct cmd_handler {
enum x86_decode_cmd cmd; enum x86_decode_cmd cmd;
void (*handler)(struct CPUX86State *env, struct x86_decode *ins); void (*handler)(CPUX86State *env, struct x86_decode *ins);
} handlers[] = { } handlers[] = {
{X86_DECODE_CMD_INVL, NULL,}, {X86_DECODE_CMD_INVL, NULL,},
{X86_DECODE_CMD_MOV, exec_mov}, {X86_DECODE_CMD_MOV, exec_mov},
@ -1465,7 +1465,7 @@ void store_regs(struct CPUState *cpu)
macvm_set_rip(cpu, env->eip); macvm_set_rip(cpu, env->eip);
} }
bool exec_instruction(struct CPUX86State *env, struct x86_decode *ins) bool exec_instruction(CPUX86State *env, struct x86_decode *ins)
{ {
/*if (hvf_vcpu_id(cpu)) /*if (hvf_vcpu_id(cpu))
printf("%d, %llx: exec_instruction %s\n", hvf_vcpu_id(cpu), env->eip, printf("%d, %llx: exec_instruction %s\n", hvf_vcpu_id(cpu), env->eip,

View File

@ -24,7 +24,7 @@
#include "cpu.h" #include "cpu.h"
void init_emu(void); void init_emu(void);
bool exec_instruction(struct CPUX86State *env, struct x86_decode *ins); bool exec_instruction(CPUX86State *env, struct x86_decode *ins);
void load_regs(struct CPUState *cpu); void load_regs(struct CPUState *cpu);
void store_regs(struct CPUState *cpu); void store_regs(struct CPUState *cpu);
@ -36,15 +36,15 @@ target_ulong read_reg(CPUX86State *env, int reg, int size);
void write_reg(CPUX86State *env, int reg, target_ulong val, int size); void write_reg(CPUX86State *env, int reg, target_ulong val, int size);
target_ulong read_val_from_reg(target_ulong reg_ptr, int size); target_ulong read_val_from_reg(target_ulong reg_ptr, int size);
void write_val_to_reg(target_ulong reg_ptr, target_ulong val, int size); void write_val_to_reg(target_ulong reg_ptr, target_ulong val, int size);
void write_val_ext(struct CPUX86State *env, target_ulong ptr, target_ulong val, int size); void write_val_ext(CPUX86State *env, target_ulong ptr, target_ulong val, int size);
uint8_t *read_mmio(struct CPUX86State *env, target_ulong ptr, int bytes); uint8_t *read_mmio(CPUX86State *env, target_ulong ptr, int bytes);
target_ulong read_val_ext(struct CPUX86State *env, target_ulong ptr, int size); target_ulong read_val_ext(CPUX86State *env, target_ulong ptr, int size);
void exec_movzx(struct CPUX86State *env, struct x86_decode *decode); void exec_movzx(CPUX86State *env, struct x86_decode *decode);
void exec_shl(struct CPUX86State *env, struct x86_decode *decode); void exec_shl(CPUX86State *env, struct x86_decode *decode);
void exec_movsx(struct CPUX86State *env, struct x86_decode *decode); void exec_movsx(CPUX86State *env, struct x86_decode *decode);
void exec_ror(struct CPUX86State *env, struct x86_decode *decode); void exec_ror(CPUX86State *env, struct x86_decode *decode);
void exec_rol(struct CPUX86State *env, struct x86_decode *decode); void exec_rol(CPUX86State *env, struct x86_decode *decode);
void exec_rcl(struct CPUX86State *env, struct x86_decode *decode); void exec_rcl(CPUX86State *env, struct x86_decode *decode);
void exec_rcr(struct CPUX86State *env, struct x86_decode *decode); void exec_rcr(CPUX86State *env, struct x86_decode *decode);
#endif #endif

View File

@ -85,7 +85,7 @@ nvmm_set_segment(struct nvmm_x64_state_seg *nseg, const SegmentCache *qseg)
static void static void
nvmm_set_registers(CPUState *cpu) nvmm_set_registers(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
struct nvmm_machine *mach = get_nvmm_mach(); struct nvmm_machine *mach = get_nvmm_mach();
struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu); struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu);
struct nvmm_vcpu *vcpu = &qcpu->vcpu; struct nvmm_vcpu *vcpu = &qcpu->vcpu;
@ -222,7 +222,7 @@ nvmm_get_segment(SegmentCache *qseg, const struct nvmm_x64_state_seg *nseg)
static void static void
nvmm_get_registers(CPUState *cpu) nvmm_get_registers(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
struct nvmm_machine *mach = get_nvmm_mach(); struct nvmm_machine *mach = get_nvmm_mach();
struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu); struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu);
struct nvmm_vcpu *vcpu = &qcpu->vcpu; struct nvmm_vcpu *vcpu = &qcpu->vcpu;
@ -347,7 +347,7 @@ nvmm_get_registers(CPUState *cpu)
static bool static bool
nvmm_can_take_int(CPUState *cpu) nvmm_can_take_int(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu); struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu);
struct nvmm_vcpu *vcpu = &qcpu->vcpu; struct nvmm_vcpu *vcpu = &qcpu->vcpu;
struct nvmm_machine *mach = get_nvmm_mach(); struct nvmm_machine *mach = get_nvmm_mach();
@ -394,7 +394,7 @@ nvmm_can_take_nmi(CPUState *cpu)
static void static void
nvmm_vcpu_pre_run(CPUState *cpu) nvmm_vcpu_pre_run(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
struct nvmm_machine *mach = get_nvmm_mach(); struct nvmm_machine *mach = get_nvmm_mach();
struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu); struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu);
struct nvmm_vcpu *vcpu = &qcpu->vcpu; struct nvmm_vcpu *vcpu = &qcpu->vcpu;
@ -480,7 +480,7 @@ static void
nvmm_vcpu_post_run(CPUState *cpu, struct nvmm_vcpu_exit *exit) nvmm_vcpu_post_run(CPUState *cpu, struct nvmm_vcpu_exit *exit)
{ {
struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu); struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu);
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
uint64_t tpr; uint64_t tpr;
@ -652,7 +652,7 @@ static int
nvmm_handle_halted(struct nvmm_machine *mach, CPUState *cpu, nvmm_handle_halted(struct nvmm_machine *mach, CPUState *cpu,
struct nvmm_vcpu_exit *exit) struct nvmm_vcpu_exit *exit)
{ {
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
int ret = 0; int ret = 0;
qemu_mutex_lock_iothread(); qemu_mutex_lock_iothread();
@ -685,7 +685,7 @@ nvmm_inject_ud(struct nvmm_machine *mach, struct nvmm_vcpu *vcpu)
static int static int
nvmm_vcpu_loop(CPUState *cpu) nvmm_vcpu_loop(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)cpu->env_ptr; CPUX86State *env = (CPUArchState *)cpu->env_ptr;
struct nvmm_machine *mach = get_nvmm_mach(); struct nvmm_machine *mach = get_nvmm_mach();
struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu); struct qemu_vcpu *qcpu = get_qemu_vcpu(cpu);
struct nvmm_vcpu *vcpu = &qcpu->vcpu; struct nvmm_vcpu *vcpu = &qcpu->vcpu;

View File

@ -221,7 +221,7 @@ static SegmentCache whpx_seg_h2q(const WHV_X64_SEGMENT_REGISTER *hs)
static int whpx_set_tsc(CPUState *cpu) static int whpx_set_tsc(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
WHV_REGISTER_NAME tsc_reg = WHvX64RegisterTsc; WHV_REGISTER_NAME tsc_reg = WHvX64RegisterTsc;
WHV_REGISTER_VALUE tsc_val; WHV_REGISTER_VALUE tsc_val;
HRESULT hr; HRESULT hr;
@ -260,7 +260,7 @@ static void whpx_set_registers(CPUState *cpu, int level)
{ {
struct whpx_state *whpx = &whpx_global; struct whpx_state *whpx = &whpx_global;
struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu); struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu);
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
struct whpx_register_set vcxt; struct whpx_register_set vcxt;
HRESULT hr; HRESULT hr;
@ -428,7 +428,7 @@ static void whpx_set_registers(CPUState *cpu, int level)
static int whpx_get_tsc(CPUState *cpu) static int whpx_get_tsc(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
WHV_REGISTER_NAME tsc_reg = WHvX64RegisterTsc; WHV_REGISTER_NAME tsc_reg = WHvX64RegisterTsc;
WHV_REGISTER_VALUE tsc_val; WHV_REGISTER_VALUE tsc_val;
HRESULT hr; HRESULT hr;
@ -449,7 +449,7 @@ static void whpx_get_registers(CPUState *cpu)
{ {
struct whpx_state *whpx = &whpx_global; struct whpx_state *whpx = &whpx_global;
struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu); struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu);
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
struct whpx_register_set vcxt; struct whpx_register_set vcxt;
uint64_t tpr, apic_base; uint64_t tpr, apic_base;
@ -760,7 +760,7 @@ static int whpx_handle_portio(CPUState *cpu,
static int whpx_handle_halt(CPUState *cpu) static int whpx_handle_halt(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
int ret = 0; int ret = 0;
qemu_mutex_lock_iothread(); qemu_mutex_lock_iothread();
@ -781,7 +781,7 @@ static void whpx_vcpu_pre_run(CPUState *cpu)
HRESULT hr; HRESULT hr;
struct whpx_state *whpx = &whpx_global; struct whpx_state *whpx = &whpx_global;
struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu); struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu);
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
int irq; int irq;
uint8_t tpr; uint8_t tpr;
@ -903,7 +903,7 @@ static void whpx_vcpu_pre_run(CPUState *cpu)
static void whpx_vcpu_post_run(CPUState *cpu) static void whpx_vcpu_post_run(CPUState *cpu)
{ {
struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu); struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu);
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
env->eflags = vcpu->exit_ctx.VpContext.Rflags; env->eflags = vcpu->exit_ctx.VpContext.Rflags;
@ -927,7 +927,7 @@ static void whpx_vcpu_post_run(CPUState *cpu)
static void whpx_vcpu_process_async_events(CPUState *cpu) static void whpx_vcpu_process_async_events(CPUState *cpu)
{ {
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu); struct whpx_vcpu *vcpu = get_whpx_vcpu(cpu);
@ -1333,7 +1333,7 @@ int whpx_init_vcpu(CPUState *cpu)
struct whpx_state *whpx = &whpx_global; struct whpx_state *whpx = &whpx_global;
struct whpx_vcpu *vcpu = NULL; struct whpx_vcpu *vcpu = NULL;
Error *local_error = NULL; Error *local_error = NULL;
struct CPUX86State *env = (CPUArchState *)(cpu->env_ptr); CPUX86State *env = (CPUArchState *)(cpu->env_ptr);
X86CPU *x86_cpu = X86_CPU(cpu); X86CPU *x86_cpu = X86_CPU(cpu);
UINT64 freq = 0; UINT64 freq = 0;
int ret; int ret;

View File

@ -134,14 +134,14 @@ struct r4k_tlb_t {
struct CPUMIPSTLBContext { struct CPUMIPSTLBContext {
uint32_t nb_tlb; uint32_t nb_tlb;
uint32_t tlb_in_use; uint32_t tlb_in_use;
int (*map_address)(struct CPUMIPSState *env, hwaddr *physical, int *prot, int (*map_address)(CPUMIPSState *env, hwaddr *physical, int *prot,
target_ulong address, MMUAccessType access_type); target_ulong address, MMUAccessType access_type);
void (*helper_tlbwi)(struct CPUMIPSState *env); void (*helper_tlbwi)(CPUMIPSState *env);
void (*helper_tlbwr)(struct CPUMIPSState *env); void (*helper_tlbwr)(CPUMIPSState *env);
void (*helper_tlbp)(struct CPUMIPSState *env); void (*helper_tlbp)(CPUMIPSState *env);
void (*helper_tlbr)(struct CPUMIPSState *env); void (*helper_tlbr)(CPUMIPSState *env);
void (*helper_tlbinv)(struct CPUMIPSState *env); void (*helper_tlbinv)(CPUMIPSState *env);
void (*helper_tlbinvf)(struct CPUMIPSState *env); void (*helper_tlbinvf)(CPUMIPSState *env);
union { union {
struct { struct {
r4k_tlb_t tlb[MIPS_TLB_MAX]; r4k_tlb_t tlb[MIPS_TLB_MAX];

View File

@ -231,11 +231,11 @@ typedef struct CPUOpenRISCTLBContext {
OpenRISCTLBEntry itlb[TLB_SIZE]; OpenRISCTLBEntry itlb[TLB_SIZE];
OpenRISCTLBEntry dtlb[TLB_SIZE]; OpenRISCTLBEntry dtlb[TLB_SIZE];
int (*cpu_openrisc_map_address_code)(struct OpenRISCCPU *cpu, int (*cpu_openrisc_map_address_code)(OpenRISCCPU *cpu,
hwaddr *physical, hwaddr *physical,
int *prot, int *prot,
target_ulong address, int rw); target_ulong address, int rw);
int (*cpu_openrisc_map_address_data)(struct OpenRISCCPU *cpu, int (*cpu_openrisc_map_address_data)(OpenRISCCPU *cpu,
hwaddr *physical, hwaddr *physical,
int *prot, int *prot,
target_ulong address, int rw); target_ulong address, int rw);

View File

@ -344,7 +344,7 @@ typedef struct XtensaGdbRegmap {
} XtensaGdbRegmap; } XtensaGdbRegmap;
typedef struct XtensaCcompareTimer { typedef struct XtensaCcompareTimer {
struct CPUXtensaState *env; CPUXtensaState *env;
QEMUTimer *timer; QEMUTimer *timer;
} XtensaCcompareTimer; } XtensaCcompareTimer;