⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cpu.h

📁 qemu虚拟机代码
💻 H
📖 第 1 页 / 共 3 页
字号:
typedef struct CPUPPCState CPUPPCState;typedef struct opc_handler_t opc_handler_t;typedef struct ppc_tb_t ppc_tb_t;typedef struct ppc_spr_t ppc_spr_t;typedef struct ppc_dcr_t ppc_dcr_t;typedef struct ppc_avr_t ppc_avr_t;/* SPR access micro-ops generations callbacks */struct ppc_spr_t {    void (*uea_read)(void *opaque, int spr_num);    void (*uea_write)(void *opaque, int spr_num);    void (*oea_read)(void *opaque, int spr_num);    void (*oea_write)(void *opaque, int spr_num);    const unsigned char *name;};/* Altivec registers (128 bits) */struct ppc_avr_t {    uint32_t u[4];};/* Software TLB cache */typedef struct ppc_tlb_t ppc_tlb_t;struct ppc_tlb_t {    /* Physical page number */    target_phys_addr_t RPN;    /* Virtual page number */    target_ulong VPN;    /* Page size */    target_ulong size;    /* Protection bits */    int prot;    int is_user;    uint32_t private;    uint32_t flags;};/*****************************************************************************//* Machine state register bits definition                                    */#define MSR_SF   63 /* Sixty-four-bit mode                                   */#define MSR_ISF  61 /* Sixty-four-bit interrupt mode on 630                  */#define MSR_HV   60 /* hypervisor state                                      */#define MSR_VR   25 /* altivec available                                     */#define MSR_AP   23 /* Access privilege state on 602                         */#define MSR_SA   22 /* Supervisor access mode on 602                         */#define MSR_KEY  19 /* key bit on 603e                                       */#define MSR_POW  18 /* Power management                                      */#define MSR_WE   18 /* Wait state enable on embedded PowerPC                 */#define MSR_TGPR 17 /* TGPR usage on 602/603                                 */#define MSR_TLB  17 /* TLB on ?                                              */#define MSR_CE   17 /* Critical interrupt enable on embedded PowerPC         */#define MSR_ILE  16 /* Interrupt little-endian mode                          */#define MSR_EE   15 /* External interrupt enable                             */#define MSR_PR   14 /* Problem state                                         */#define MSR_FP   13 /* Floating point available                              */#define MSR_ME   12 /* Machine check interrupt enable                        */#define MSR_FE0  11 /* Floating point exception mode 0                       */#define MSR_SE   10 /* Single-step trace enable                              */#define MSR_DWE  10 /* Debug wait enable on 405                              */#define MSR_BE   9  /* Branch trace enable                                   */#define MSR_DE   9  /* Debug interrupts enable on embedded PowerPC           */#define MSR_FE1  8  /* Floating point exception mode 1                       */#define MSR_AL   7  /* AL bit on POWER                                       */#define MSR_IP   6  /* Interrupt prefix                                      */#define MSR_IR   5  /* Instruction relocate                                  */#define MSR_IS   5  /* Instruction address space on embedded PowerPC         */#define MSR_DR   4  /* Data relocate                                         */#define MSR_DS   4  /* Data address space on embedded PowerPC                */#define MSR_PE   3  /* Protection enable on 403                              */#define MSR_EP   3  /* Exception prefix on 601                               */#define MSR_PX   2  /* Protection exclusive on 403                           */#define MSR_PMM  2  /* Performance monitor mark on POWER                     */#define MSR_RI   1  /* Recoverable interrupt                                 */#define MSR_LE   0  /* Little-endian mode                                    */#define msr_sf   env->msr[MSR_SF]#define msr_isf  env->msr[MSR_ISF]#define msr_hv   env->msr[MSR_HV]#define msr_vr   env->msr[MSR_VR]#define msr_ap   env->msr[MSR_AP]#define msr_sa   env->msr[MSR_SA]#define msr_key  env->msr[MSR_KEY]#define msr_pow env->msr[MSR_POW]#define msr_we   env->msr[MSR_WE]#define msr_tgpr env->msr[MSR_TGPR]#define msr_tlb  env->msr[MSR_TLB]#define msr_ce   env->msr[MSR_CE]#define msr_ile env->msr[MSR_ILE]#define msr_ee  env->msr[MSR_EE]#define msr_pr  env->msr[MSR_PR]#define msr_fp  env->msr[MSR_FP]#define msr_me  env->msr[MSR_ME]#define msr_fe0 env->msr[MSR_FE0]#define msr_se  env->msr[MSR_SE]#define msr_dwe  env->msr[MSR_DWE]#define msr_be  env->msr[MSR_BE]#define msr_de   env->msr[MSR_DE]#define msr_fe1 env->msr[MSR_FE1]#define msr_al   env->msr[MSR_AL]#define msr_ip  env->msr[MSR_IP]#define msr_ir  env->msr[MSR_IR]#define msr_is   env->msr[MSR_IS]#define msr_dr  env->msr[MSR_DR]#define msr_ds   env->msr[MSR_DS]#define msr_pe   env->msr[MSR_PE]#define msr_ep   env->msr[MSR_EP]#define msr_px   env->msr[MSR_PX]#define msr_pmm  env->msr[MSR_PMM]#define msr_ri  env->msr[MSR_RI]#define msr_le  env->msr[MSR_LE]/*****************************************************************************//* The whole PowerPC CPU context */struct CPUPPCState {    /* First are the most commonly used resources     * during translated code execution     */#if TARGET_LONG_BITS > HOST_LONG_BITS    /* temporary fixed-point registers     * used to emulate 64 bits target on 32 bits hosts     */    target_ulong t0, t1, t2;#endif    /* general purpose registers */    target_ulong gpr[32];    /* LR */    target_ulong lr;    /* CTR */    target_ulong ctr;    /* condition register */    uint8_t crf[8];    /* XER */    /* XXX: We use only 5 fields, but we want to keep the structure aligned */    uint8_t xer[8];    /* Reservation address */    target_ulong reserve;    /* Those ones are used in supervisor mode only */    /* machine state register */    uint8_t msr[64];    /* temporary general purpose registers */    target_ulong tgpr[4]; /* Used to speed-up TLB assist handlers */    /* Floating point execution context */     /* temporary float registers */    float64 ft0;    float64 ft1;    float64 ft2;    float_status fp_status;    /* floating point registers */    float64 fpr[32];    /* floating point status and control register */    uint8_t fpscr[8];    CPU_COMMON    int halted; /* TRUE if the CPU is in suspend state */    int access_type; /* when a memory exception occurs, the access                        type is stored here */    /* MMU context */    /* Address space register */    target_ulong asr;    /* segment registers */    target_ulong sdr1;    target_ulong sr[16];    /* BATs */    int nb_BATs;    target_ulong DBAT[2][8];    target_ulong IBAT[2][8];    /* Other registers */    /* Special purpose registers */    target_ulong spr[1024];    /* Altivec registers */    ppc_avr_t avr[32];    uint32_t vscr;    /* Internal devices resources */    /* Time base and decrementer */    ppc_tb_t *tb_env;    /* Device control registers */    int (*dcr_read)(ppc_dcr_t *dcr_env, int dcr_num, target_ulong *val);    int (*dcr_write)(ppc_dcr_t *dcr_env, int dcr_num, target_ulong val);    ppc_dcr_t *dcr_env;    /* PowerPC TLB registers (for 4xx and 60x software driven TLBs) */    int nb_tlb;    int nb_ways, last_way;    ppc_tlb_t tlb[128];    /* Callbacks for specific checks on some implementations */    int (*tlb_check_more)(CPUPPCState *env, struct ppc_tlb_t *tlb, int *prot,                          target_ulong vaddr, int rw, int acc_type,                          int is_user);    /* 403 dedicated access protection registers */    target_ulong pb[4];    /* Those resources are used during exception processing */    /* CPU model definition */    uint64_t msr_mask;    uint32_t flags;    int exception_index;    int error_code;    int interrupt_request;    /* Those resources are used only during code translation */    /* Next instruction pointer */    target_ulong nip;    /* SPR translation callbacks */    ppc_spr_t spr_cb[1024];    /* opcode handlers */    opc_handler_t *opcodes[0x40];    /* Those resources are used only in Qemu core */    jmp_buf jmp_env;    int user_mode_only; /* user mode only simulation */    uint32_t hflags;    /* Power management */    int power_mode;    /* temporary hack to handle OSI calls (only used if non NULL) */    int (*osi_call)(struct CPUPPCState *env);};/*****************************************************************************/CPUPPCState *cpu_ppc_init(void);int cpu_ppc_exec(CPUPPCState *s);void cpu_ppc_close(CPUPPCState *s);/* you can call this signal handler from your SIGBUS and SIGSEGV   signal handlers to inform the virtual CPU of exceptions. non zero   is returned if the signal was handled by the virtual CPU.  */struct siginfo;int cpu_ppc_signal_handler(int host_signum, struct siginfo *info,                            void *puc);void do_interrupt (CPUPPCState *env);void cpu_loop_exit(void);void dump_stack (CPUPPCState *env);target_ulong do_load_ibatu (CPUPPCState *env, int nr);target_ulong do_load_ibatl (CPUPPCState *env, int nr);void do_store_ibatu (CPUPPCState *env, int nr, target_ulong value);void do_store_ibatl (CPUPPCState *env, int nr, target_ulong value);target_ulong do_load_dbatu (CPUPPCState *env, int nr);target_ulong do_load_dbatl (CPUPPCState *env, int nr);void do_store_dbatu (CPUPPCState *env, int nr, target_ulong value);void do_store_dbatl (CPUPPCState *env, int nr, target_ulong value);target_ulong do_load_nip (CPUPPCState *env);void do_store_nip (CPUPPCState *env, target_ulong value);target_ulong do_load_sdr1 (CPUPPCState *env);void do_store_sdr1 (CPUPPCState *env, target_ulong value);target_ulong do_load_asr (CPUPPCState *env);void do_store_asr (CPUPPCState *env, target_ulong value);target_ulong do_load_sr (CPUPPCState *env, int srnum);void do_store_sr (CPUPPCState *env, int srnum, target_ulong value);uint32_t do_load_cr (CPUPPCState *env);void do_store_cr (CPUPPCState *env, uint32_t value, uint32_t mask);uint32_t do_load_xer (CPUPPCState *env);void do_store_xer (CPUPPCState *env, uint32_t value);target_ulong do_load_msr (CPUPPCState *env);void do_store_msr (CPUPPCState *env, target_ulong value);float64 do_load_fpscr (CPUPPCState *env);void do_store_fpscr (CPUPPCState *env, float64 f, uint32_t mask);void do_compute_hflags (CPUPPCState *env);int ppc_find_by_name (const unsigned char *name, ppc_def_t **def);int ppc_find_by_pvr (uint32_t apvr, ppc_def_t **def);void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...));int cpu_ppc_register (CPUPPCState *env, ppc_def_t *def);/* Time-base and decrementer management */#ifndef NO_CPU_IO_DEFSuint32_t cpu_ppc_load_tbl (CPUPPCState *env);uint32_t cpu_ppc_load_tbu (CPUPPCState *env);void cpu_ppc_store_tbu (CPUPPCState *env, uint32_t value);void cpu_ppc_store_tbl (CPUPPCState *env, uint32_t value);uint32_t cpu_ppc_load_decr (CPUPPCState *env);void cpu_ppc_store_decr (CPUPPCState *env, uint32_t value);#endif#define TARGET_PAGE_BITS 12#include "cpu-all.h"/*****************************************************************************//* Registers definitions */#define ugpr(n) (env->gpr[n])#define XER_SO 31#define XER_OV 30#define XER_CA 29#define XER_CMP 8#define XER_BC 0#define xer_so  env->xer[4]#define xer_ov  env->xer[6]#define xer_ca  env->xer[2]#define xer_cmp env->xer[1]#define xer_bc env->xer[0]/* SPR definitions */#define SPR_MQ         (0x000)#define SPR_XER        (0x001)#define SPR_601_VRTCU  (0x004)#define SPR_601_VRTCL  (0x005)#define SPR_601_UDECR  (0x006)#define SPR_LR         (0x008)#define SPR_CTR        (0x009)#define SPR_DSISR      (0x012)#define SPR_DAR        (0x013)#define SPR_601_RTCU   (0x014)#define SPR_601_RTCL   (0x015)#define SPR_DECR       (0x016)#define SPR_SDR1       (0x019)#define SPR_SRR0       (0x01A)#define SPR_SRR1       (0x01B)#define SPR_440_PID    (0x030)#define SPR_440_DECAR  (0x036)#define SPR_CSRR0      (0x03A)#define SPR_CSRR1      (0x03B)#define SPR_440_DEAR   (0x03D)#define SPR_440_ESR    (0x03E)#define SPR_440_IVPR   (0x03F)#define SPR_8xx_EIE    (0x050)#define SPR_8xx_EID    (0x051)#define SPR_8xx_NRE    (0x052)#define SPR_58x_CMPA   (0x090)#define SPR_58x_CMPB   (0x091)#define SPR_58x_CMPC   (0x092)#define SPR_58x_CMPD   (0x093)#define SPR_58x_ICR    (0x094)#define SPR_58x_DER    (0x094)#define SPR_58x_COUNTA (0x096)#define SPR_58x_COUNTB (0x097)#define SPR_58x_CMPE   (0x098)#define SPR_58x_CMPF   (0x099)#define SPR_58x_CMPG   (0x09A)#define SPR_58x_CMPH   (0x09B)#define SPR_58x_LCTRL1 (0x09C)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -