diff options
| -rw-r--r-- | src/core/arm/interpreter/armemu.cpp | 925 | ||||
| -rw-r--r-- | src/core/arm/interpreter/arminit.cpp | 288 | ||||
| -rw-r--r-- | src/core/arm/interpreter/armsupp.cpp | 80 | ||||
| -rw-r--r-- | src/core/arm/skyeye_common/armdefs.h | 212 | ||||
| -rw-r--r-- | src/core/arm/skyeye_common/armemu.h | 5 | ||||
| -rw-r--r-- | src/core/arm/skyeye_common/skyeye_defs.h | 82 | 
6 files changed, 56 insertions, 1536 deletions
| diff --git a/src/core/arm/interpreter/armemu.cpp b/src/core/arm/interpreter/armemu.cpp index adc5c3a05..7114313d6 100644 --- a/src/core/arm/interpreter/armemu.cpp +++ b/src/core/arm/interpreter/armemu.cpp @@ -16,31 +16,11 @@      along with this program; if not, write to the Free Software      Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ -//#include <util.h> // DEBUG() -  #include "core/arm/skyeye_common/arm_regformat.h"  #include "core/arm/skyeye_common/armdefs.h"  #include "core/arm/skyeye_common/armemu.h"  #include "core/hle/hle.h" -//#include "svc.h" - -//ichfly -//#define callstacker 1 - -//#include "skyeye_callback.h" -//#include "skyeye_bus.h" -//#include "sim_control.h" -//#include "skyeye_pref.h" -//#include "skyeye.h" -//#include "skyeye2gdb.h" -//#include "code_cov.h" - -//#include "iwmmxt.h" -//chy 2003-07-11: for debug instrs -//extern int skyeye_instr_debug; -extern FILE *skyeye_logfd; -  static ARMword GetDPRegRHS (ARMul_State *, ARMword);  static ARMword GetDPSRegRHS (ARMul_State *, ARMword);  static void WriteR15 (ARMul_State *, ARMword); @@ -63,25 +43,13 @@ static unsigned MultiplyAdd64 (ARMul_State *, ARMword, int, int);  static void Handle_Load_Double (ARMul_State *, ARMword);  static void Handle_Store_Double (ARMul_State *, ARMword); -static int -handle_v6_insn (ARMul_State * state, ARMword instr); +static int handle_v6_insn (ARMul_State * state, ARMword instr);  #define LUNSIGNED (0)		/* unsigned operation */  #define LSIGNED   (1)		/* signed operation */  #define LDEFAULT  (0)		/* default : do nothing */  #define LSCC      (1)		/* set condition codes on result */ -#ifdef NEED_UI_LOOP_HOOK -/* How often to run the ui_loop update, when in use.  */ -#define UI_LOOP_POLL_INTERVAL 0x32000 - -/* Counter for the ui_loop_hook update.  */ -static int ui_loop_hook_counter = UI_LOOP_POLL_INTERVAL; - -/* Actual hook to call to run through gdb's gui event loop.  */ -extern int (*ui_loop_hook) (int); -#endif /* NEED_UI_LOOP_HOOK */ -  /* Short-hand macros for LDR/STR.  */  /* Store post decrement writeback.  */ @@ -290,20 +258,8 @@ extern int (*ui_loop_hook) (int);       break;                                            		\  } -/*ywc 2005-03-31*/ -//teawater add for arm2x86 2005.02.17------------------------------------------- -#ifdef DBCT -#include "dbct/tb.h" -#include "dbct/arm2x86_self.h" -#endif -//AJ2D-------------------------------------------------------------------------- - -//Diff register -unsigned int mirror_register_file[39]; -  /* EMULATION of ARM6.  */ -extern int debugmode;  int ARMul_ICE_debug(ARMul_State *state,ARMword instr,ARMword addr);  #ifdef MODE32  //chy 2006-04-12, for ICE debug @@ -312,59 +268,14 @@ int ARMul_ICE_debug(ARMul_State *state,ARMword instr,ARMword addr)      return 0;  } -static int dump = 0;  ARMword ARMul_Debug(ARMul_State * state, ARMword pc, ARMword instr)  { -    /*printf("[%08x] ", pc); -    arm11_Disasm32(pc);*/ - -    /*if (pc >= 0x0010303C && pc <= 0x00103050) -    { -    printf("[%08x] = %08X = ", pc, instr); -    arm11_Disasm32(pc); -    arm11_Dump(); -    }*/ - -    //fprintf(stderr,"[%08x]\n", pc); - -    //if (pc == 0x00240C88) -    //    arm11_Dump(); - -    /*if (pc == 0x188e04) -    { -        DEBUG("read %08X %08X %016X %08X %08X from %08X", state->Reg[0], state->Reg[1], state->Reg[2] | state->Reg[3] << 32, mem_Read32(state->Reg[13]), mem_Read32(state->Reg[13] + 4), state->Reg[14]); -    } -    if (pc == 0x21222c) -    { -        arm11_Dump(); -        mem_Dbugdump(); -    }*/ - -    /*if (pc == 0x0022D168) -    { -    int j = 0; -    }*/ - -    /*if (state->Reg[4] == 0x00105734) -    { -    printf("[%08x] ", pc); -    arm11_Disasm32(pc); -    }*/ -      return 0;  } -/* -void chy_debug() -{ -	printf("SkyEye chy_deubeg begin\n"); -} -*/ -ARMword -ARMul_Emulate32 (ARMul_State * state) +ARMword ARMul_Emulate32(ARMul_State* state)  #else -ARMword -ARMul_Emulate26 (ARMul_State * state) +ARMword ARMul_Emulate26(ARMul_State* state)  #endif  {      /* The PC pipeline value depends on whether ARM @@ -383,39 +294,6 @@ ARMul_Emulate26 (ARMul_State * state)      ARMword loaded_addr=0;      ARMword have_bp=0; -#ifdef callstacker -    char a[256]; -#endif -    /* shenoubang */ -    static int instr_sum = 0; -    int reg_index = 0; -#if DIFF_STATE -//initialize all mirror register for follow mode -    for (reg_index = 0; reg_index < 16; reg_index ++) { -        mirror_register_file[reg_index] = state->Reg[reg_index]; -    } -    mirror_register_file[CPSR_REG] = state->Cpsr; -    mirror_register_file[R13_SVC] = state->RegBank[SVCBANK][13]; -    mirror_register_file[R14_SVC] = state->RegBank[SVCBANK][14]; -    mirror_register_file[R13_ABORT] = state->RegBank[ABORTBANK][13]; -    mirror_register_file[R14_ABORT] = state->RegBank[ABORTBANK][14]; -    mirror_register_file[R13_UNDEF] = state->RegBank[UNDEFBANK][13]; -    mirror_register_file[R14_UNDEF] = state->RegBank[UNDEFBANK][14]; -    mirror_register_file[R13_IRQ] = state->RegBank[IRQBANK][13]; -    mirror_register_file[R14_IRQ] = state->RegBank[IRQBANK][14]; -    mirror_register_file[R8_FIRQ] = state->RegBank[FIQBANK][8]; -    mirror_register_file[R9_FIRQ] = state->RegBank[FIQBANK][9]; -    mirror_register_file[R10_FIRQ] = state->RegBank[FIQBANK][10]; -    mirror_register_file[R11_FIRQ] = state->RegBank[FIQBANK][11]; -    mirror_register_file[R12_FIRQ] = state->RegBank[FIQBANK][12]; -    mirror_register_file[R13_FIRQ] = state->RegBank[FIQBANK][13]; -    mirror_register_file[R14_FIRQ] = state->RegBank[FIQBANK][14]; -    mirror_register_file[SPSR_SVC] = state->Spsr[SVCBANK]; -    mirror_register_file[SPSR_ABORT] = state->Spsr[ABORTBANK]; -    mirror_register_file[SPSR_UNDEF] = state->Spsr[UNDEFBANK]; -    mirror_register_file[SPSR_IRQ] = state->Spsr[IRQBANK]; -    mirror_register_file[SPSR_FIRQ] = state->Spsr[FIQBANK]; -#endif      /* Execute the next instruction.  */      if (state->NextInstr < PRIMEPIPE) {          decoded = state->decoded; @@ -533,392 +411,38 @@ ARMul_Emulate26 (ARMul_State * state)              //chy 2006-04-12, for ICE debug              have_bp=ARMul_ICE_debug(state,instr,pc); -#if 0 -            decoded = -                ARMul_LoadInstrS (state, pc + (isize), isize); -#endif +              decoded_addr=pc+isize; -#if 0 -            loaded = ARMul_LoadInstrS (state, pc + (isize * 2), -                                       isize); -#endif +              loaded_addr=pc + isize * 2;              NORMALCYCLE;              if (have_bp) goto  TEST_EMULATE;              break;          } -#if 0 -        int idx = 0; -        printf("pc:%x\n", pc); -        for (; idx < 17; idx ++) { -            printf("R%d:%x\t", idx, state->Reg[idx]); -        } -        printf("\n"); -#endif          instr = ARMul_LoadInstrN (state, pc, isize);          state->last_instr = state->CurrInstr;          state->CurrInstr = instr;          ARMul_Debug(state, pc, instr); -#if 0 -        if((state->NumInstrs % 10000000) == 0) -            printf("---|%p|---  %lld\n", pc, state->NumInstrs); -        if(state->NumInstrs > (3000000000)) { -            static int flag = 0; -            if(pc == 0x8032ccc4) { -                flag = 300; -            } -            if(flag) { -                int idx = 0; -                printf("------------------------------------\n"); -                printf("pc:%x\n", pc); -                for (; idx < 17; idx ++) { -                    printf("R%d:%x\t", idx, state->Reg[idx]); -                } -                printf("\nN:%d\t Z:%d\t C:%d\t V:%d\n", state->NFlag,  state->ZFlag, state->CFlag, state->VFlag); -                printf("\n"); -                printf("------------------------------------\n"); -                flag--; -            } -        } -#endif -#if DIFF_STATE -        fprintf(state->state_log, "PC:0x%x\n", pc); -        if (pc && (pc + 8) != state->Reg[15]) { -            printf("lucky dog\n"); -            printf("pc is %x, R15 is %x\n", pc, state->Reg[15]); -            //exit(-1); -        } -        for (reg_index = 0; reg_index < 16; reg_index ++) { -            if (state->Reg[reg_index] != mirror_register_file[reg_index]) { -                fprintf(state->state_log, "R%d:0x%x\n", reg_index, state->Reg[reg_index]); -                mirror_register_file[reg_index] = state->Reg[reg_index]; -            } -        } -        if (state->Cpsr != mirror_register_file[CPSR_REG]) { -            fprintf(state->state_log, "Cpsr:0x%x\n", state->Cpsr); -            mirror_register_file[CPSR_REG] = state->Cpsr; -        } -        if (state->RegBank[SVCBANK][13] != mirror_register_file[R13_SVC]) { -            fprintf(state->state_log, "R13_SVC:0x%x\n", state->RegBank[SVCBANK][13]); -            mirror_register_file[R13_SVC] = state->RegBank[SVCBANK][13]; -        } -        if (state->RegBank[SVCBANK][14] != mirror_register_file[R14_SVC]) { -            fprintf(state->state_log, "R14_SVC:0x%x\n", state->RegBank[SVCBANK][14]); -            mirror_register_file[R14_SVC] = state->RegBank[SVCBANK][14]; -        } -        if (state->RegBank[ABORTBANK][13] != mirror_register_file[R13_ABORT]) { -            fprintf(state->state_log, "R13_ABORT:0x%x\n", state->RegBank[ABORTBANK][13]); -            mirror_register_file[R13_ABORT] = state->RegBank[ABORTBANK][13]; -        } -        if (state->RegBank[ABORTBANK][14] != mirror_register_file[R14_ABORT]) { -            fprintf(state->state_log, "R14_ABORT:0x%x\n", state->RegBank[ABORTBANK][14]); -            mirror_register_file[R14_ABORT] = state->RegBank[ABORTBANK][14]; -        } -        if (state->RegBank[UNDEFBANK][13] != mirror_register_file[R13_UNDEF]) { -            fprintf(state->state_log, "R13_UNDEF:0x%x\n", state->RegBank[UNDEFBANK][13]); -            mirror_register_file[R13_UNDEF] = state->RegBank[UNDEFBANK][13]; -        } -        if (state->RegBank[UNDEFBANK][14] != mirror_register_file[R14_UNDEF]) { -            fprintf(state->state_log, "R14_UNDEF:0x%x\n", state->RegBank[UNDEFBANK][14]); -            mirror_register_file[R14_UNDEF] = state->RegBank[UNDEFBANK][14]; -        } -        if (state->RegBank[IRQBANK][13] != mirror_register_file[R13_IRQ]) { -            fprintf(state->state_log, "R13_IRQ:0x%x\n", state->RegBank[IRQBANK][13]); -            mirror_register_file[R13_IRQ] = state->RegBank[IRQBANK][13]; -        } -        if (state->RegBank[IRQBANK][14] != mirror_register_file[R14_IRQ]) { -            fprintf(state->state_log, "R14_IRQ:0x%x\n", state->RegBank[IRQBANK][14]); -            mirror_register_file[R14_IRQ] = state->RegBank[IRQBANK][14]; -        } -        if (state->RegBank[FIQBANK][8] != mirror_register_file[R8_FIRQ]) { -            fprintf(state->state_log, "R8_FIRQ:0x%x\n", state->RegBank[FIQBANK][8]); -            mirror_register_file[R8_FIRQ] = state->RegBank[FIQBANK][8]; -        } -        if (state->RegBank[FIQBANK][9] != mirror_register_file[R9_FIRQ]) { -            fprintf(state->state_log, "R9_FIRQ:0x%x\n", state->RegBank[FIQBANK][9]); -            mirror_register_file[R9_FIRQ] = state->RegBank[FIQBANK][9]; -        } -        if (state->RegBank[FIQBANK][10] != mirror_register_file[R10_FIRQ]) { -            fprintf(state->state_log, "R10_FIRQ:0x%x\n", state->RegBank[FIQBANK][10]); -            mirror_register_file[R10_FIRQ] = state->RegBank[FIQBANK][10]; -        } -        if (state->RegBank[FIQBANK][11] != mirror_register_file[R11_FIRQ]) { -            fprintf(state->state_log, "R11_FIRQ:0x%x\n", state->RegBank[FIQBANK][11]); -            mirror_register_file[R11_FIRQ] = state->RegBank[FIQBANK][11]; -        } -        if (state->RegBank[FIQBANK][12] != mirror_register_file[R12_FIRQ]) { -            fprintf(state->state_log, "R12_FIRQ:0x%x\n", state->RegBank[FIQBANK][12]); -            mirror_register_file[R12_FIRQ] = state->RegBank[FIQBANK][12]; -        } -        if (state->RegBank[FIQBANK][13] != mirror_register_file[R13_FIRQ]) { -            fprintf(state->state_log, "R13_FIRQ:0x%x\n", state->RegBank[FIQBANK][13]); -            mirror_register_file[R13_FIRQ] = state->RegBank[FIQBANK][13]; -        } -        if (state->RegBank[FIQBANK][14] != mirror_register_file[R14_FIRQ]) { -            fprintf(state->state_log, "R14_FIRQ:0x%x\n", state->RegBank[FIQBANK][14]); -            mirror_register_file[R14_FIRQ] = state->RegBank[FIQBANK][14]; -        } -        if (state->Spsr[SVCBANK] != mirror_register_file[SPSR_SVC]) { -            fprintf(state->state_log, "SPSR_SVC:0x%x\n", state->Spsr[SVCBANK]); -            mirror_register_file[SPSR_SVC] = state->RegBank[SVCBANK]; -        } -        if (state->Spsr[ABORTBANK] != mirror_register_file[SPSR_ABORT]) { -            fprintf(state->state_log, "SPSR_ABORT:0x%x\n", state->Spsr[ABORTBANK]); -            mirror_register_file[SPSR_ABORT] = state->RegBank[ABORTBANK]; -        } -        if (state->Spsr[UNDEFBANK] != mirror_register_file[SPSR_UNDEF]) { -            fprintf(state->state_log, "SPSR_UNDEF:0x%x\n", state->Spsr[UNDEFBANK]); -            mirror_register_file[SPSR_UNDEF] = state->RegBank[UNDEFBANK]; -        } -        if (state->Spsr[IRQBANK] != mirror_register_file[SPSR_IRQ]) { -            fprintf(state->state_log, "SPSR_IRQ:0x%x\n", state->Spsr[IRQBANK]); -            mirror_register_file[SPSR_IRQ] = state->RegBank[IRQBANK]; -        } -        if (state->Spsr[FIQBANK] != mirror_register_file[SPSR_FIRQ]) { -            fprintf(state->state_log, "SPSR_FIRQ:0x%x\n", state->Spsr[FIQBANK]); -            mirror_register_file[SPSR_FIRQ] = state->RegBank[FIQBANK]; -        } -#endif - -#if 0 -        uint32_t alex = 0; -        static int flagged = 0; -        if ((flagged == 0) && (pc == 0xb224)) { -            flagged++; -        } -        if ((flagged == 1) && (pc == 0x1a800)) { -            flagged++; -        } -        if (flagged == 3) { -            printf("---|%p|---  %x\n", pc, state->NumInstrs); -            for (alex = 0; alex < 15; alex++) { -                printf("R%02d % 8x\n", alex, state->Reg[alex]); -            } -            printf("R%02d % 8x\n", alex, state->Reg[alex] - 8); -            printf("CPS %x%07x\n", (state->NFlag<<3 | state->ZFlag<<2 | state->CFlag<<1 | state->VFlag), state->Cpsr & 0xfffffff); -        } else { -            if (state->NumInstrs < 0x400000) { -                //exit(-1); -            } -        } -#endif - -        /*if (state->EventSet) -                  ARMul_EnvokeEvent (state);*/ - -#if 0 -        /* do profiling for code coverage */ -        if (skyeye_config.code_cov.prof_on) -            cov_prof(EXEC_FLAG, pc); -#endif -//2003-07-11 chy: for test -#if 0 -        if (skyeye_config.log.logon >= 1) { -            if (state->NumInstrs >= skyeye_config.log.start && -                    state->NumInstrs <= skyeye_config.log.end) { -                static int mybegin = 0; -                static int myinstrnum = 0; -                if (mybegin == 0) -                    mybegin = 1; -#if 0 -                if (state->NumInstrs == 3695) { -                    printf ("***********SKYEYE: numinstr = 3695\n"); -                } -                static int mybeg2 = 0; -                static int mybeg3 = 0; -                static int mybeg4 = 0; -                static int mybeg5 = 0; - -                if (pc == 0xa0008000) { -                    //mybegin=1; -                    printf ("************SKYEYE: real vmlinux begin now  numinstr is %llu  ****************\n", state->NumInstrs); -                } -                //chy 2003-09-02 test fiq -                if (state->NumInstrs == 67347000) { -                    printf ("***********SKYEYE: numinstr = 67347000, begin log\n"); -                    mybegin = 1; -                } -                if (pc == 0xc00087b4) {	//numinstr=67348714 -                    mybegin = 1; -                    printf ("************SKYEYE: test irq now  numinstr is %llu  ****************\n", state->NumInstrs); -                } -                if (pc == 0xc00087b8) {	//in start_kernel::sti() -                    mybeg4 = 1; -                    printf ("************SKYEYE: startkerenl: sti now  numinstr is %llu  ********\n", state->NumInstrs); -                } -                /*if (pc==0xc001e4f4||pc==0xc001e4f8||pc==0xc001e4fc||pc==0xc001e500||pc==0xffff0004) { //MRA instr */ -                if (pc == 0xc001e500) {	//MRA instr -                    mybeg5 = 1; -                    printf ("************SKYEYE: MRA instr now  numinstr is %llu  ********\n", state->NumInstrs); -                } -                if (pc >= 0xc0000000 && mybeg2 == 0) { -                    mybeg2 = 1; -                    printf ("************SKYEYE: enable mmu&cache, now numinstr is %llu **************\n", state->NumInstrs); -                    SKYEYE_OUTREGS (stderr); -                    printf ("************************************************************************\n"); -                } -                //chy 2003-09-01 test after tlb-flush -                if (pc == 0xc00261ac) { -                    //sleep(2); -                    mybeg3 = 1; -                    printf ("************SKYEYE: after tlb-flush  numinstr is %llu  ****************\n", state->NumInstrs); -                } -                if (mybeg3 == 1) { -                    SKYEYE_OUTREGS (skyeye_logfd); -                    SKYEYE_OUTMOREREGS (skyeye_logfd); -                    fprintf (skyeye_logfd, "\n"); -                } -#endif -                if (mybegin == 1) { -                    //fprintf(skyeye_logfd,"p %x,i %x,d %x,l %x,",pc,instr,decoded,loaded); -                    //chy for test 20050729 -                    /*if (state->NumInstrs>=3302294) { -                       if (pc==0x100c9d4 && instr==0xe1b0f00e){ -                       chy_debug(); -                       printf("*********************************************\n"); -                       printf("******SKYEYE N %llx :p %x,i %x\n  SKYEYE******\n",state->NumInstrs,pc,instr); -                       printf("*********************************************\n"); -                       } -                     */ -                    if (skyeye_config.log.logon >= 1) -                        /* -                        	fprintf (skyeye_logfd, -                        		 "N %llx :p %x,i %x,", -                        		 state->NumInstrs, pc, -                        #ifdef MODET -                        		 TFLAG ? instr & 0xffff : instr -                        #else -                        		 instr -                        #endif -                        		); -                        */ -                        fprintf(skyeye_logfd, "pc=0x%x,r3=0x%x\n", pc, state->Reg[3]); -                    if (skyeye_config.log.logon >= 2) -                        SKYEYE_OUTREGS (skyeye_logfd); -                    if (skyeye_config.log.logon >= 3) -                        SKYEYE_OUTMOREREGS -                        (skyeye_logfd); -                    //fprintf (skyeye_logfd, "\n"); -                    if (skyeye_config.log.length > 0) { -                        myinstrnum++; -                        if (myinstrnum >= -                                skyeye_config.log. -                                length) { -                            myinstrnum = 0; -                            fflush (skyeye_logfd); -                            fseek (skyeye_logfd, -                                   0L, SEEK_SET); -                        } -                    } -                } -                //SKYEYE_OUTREGS(skyeye_logfd); -                //SKYEYE_OUTMOREREGS(skyeye_logfd); -            } -        } -#endif -#if 0				/* Enable this for a helpful bit of debugging when tracing is needed.  */ -        fprintf (stderr, "pc: %x, instr: %x\n", pc & ~1, instr); -        if (instr == 0) -            abort (); -#endif -#if 0				/* Enable this code to help track down stack alignment bugs.  */ -        { -            static ARMword old_sp = -1; - -            if (old_sp != state->Reg[13]) { -                old_sp = state->Reg[13]; -                fprintf (stderr, -                         "pc: %08x: SP set to %08x%s\n", -                         pc & ~1, old_sp, -                         (old_sp % 8) ? " [UNALIGNED!]" : ""); -            } -        } -#endif          /* Any exceptions ?  */          if (state->NresetSig == LOW) {              ARMul_Abort (state, ARMul_ResetV); - -            /*added energy_prof statement by ksh in 2004-11-26 */ -            //chy 2005-07-28 for standalone -            //ARMul_do_energy(state,instr,pc);              break;          } else if (!state->NfiqSig && !FFLAG) {              ARMul_Abort (state, ARMul_FIQV); -            /*added energy_prof statement by ksh in 2004-11-26 */ -            //chy 2005-07-28 for standalone -            //ARMul_do_energy(state,instr,pc);              break;          } else if (!state->NirqSig && !IFLAG) {              ARMul_Abort (state, ARMul_IRQV); -            /*added energy_prof statement by ksh in 2004-11-26 */ -            //chy 2005-07-28 for standalone -            //ARMul_do_energy(state,instr,pc);              break;          } -//teawater add for arm2x86 2005.04.26------------------------------------------- -#if 0 -//        if (state->pc == 0xc011a868 || state->pc == 0xc011a86c) { -        if (state->NumInstrs == 1671574 || state->NumInstrs == 1671573 || state->NumInstrs == 1671572 -                || state->NumInstrs == 1671575) { -            for (reg_index = 0; reg_index < 16; reg_index ++) { -                printf("R%d:%x\t", reg_index, state->Reg[reg_index]); -            } -            printf("\n"); -        } -#endif -        if (state->tea_pc) { -            int i; - -            if (state->tea_reg_fd) { -                fprintf (state->tea_reg_fd, "\n"); -                for (i = 0; i < 15; i++) { -                    fprintf (state->tea_reg_fd, "%x,", -                             state->Reg[i]); -                } -                fprintf (state->tea_reg_fd, "%x,", pc); -                state->Cpsr = ARMul_GetCPSR (state); -                fprintf (state->tea_reg_fd, "%x\n", -                         state->Cpsr); -            } else { -                printf ("\n"); -                for (i = 0; i < 15; i++) { -                    printf ("%x,", state->Reg[i]); -                } -                printf ("%x,", pc); -                state->Cpsr = ARMul_GetCPSR (state); -                printf ("%x\n", state->Cpsr); -            } -        } -//AJ2D-------------------------------------------------------------------------- - -        /*if (state->CallDebug > 0) { -        	instr = ARMul_Debug (state, pc, instr); -        	if (state->Emulate < ONCE) { -        		state->NextInstr = RESUME; -        		break; -        	} -        	if (state->Debug) { -        		fprintf (stderr, -        			 "sim: At %08lx Instr %08lx Mode %02lx\n", -        			 pc, instr, state->Mode); -        		(void) fgetc (stdin); -        	} -        } -        else*/          if (state->Emulate < ONCE) {              state->NextInstr = RESUME;              break;          } -        //io_do_cycle (state); +          state->NumInstrs++; -#if 0 -        if (state->NumInstrs % 10000000 == 0) { -            printf("10 MIPS instr have been executed\n"); -        } -#endif  #ifdef MODET          /* Provide Thumb instruction decoding. If the processor is in Thumb @@ -990,12 +514,6 @@ ARMul_Emulate26 (ARMul_State * state)                  /* clrex do nothing here temporary */                  if (instr == 0xf57ff01f) {                      //printf("clrex \n"); -#if 0 -                    int i; -                    for(i = 0; i < 128; i++) { -                        state->exclusive_tag_array[i] = 0xffffffff; -                    } -#endif                      /* shenoubang 2012-3-14 refer the dyncom_interpreter */                      state->exclusive_tag_array[0] = 0xFFFFFFFF;                      state->exclusive_access_state = 0; @@ -1169,9 +687,9 @@ mainswitch:                      Rn = BITS(0, 3);                      lsb = BITS(7, 11);                      msb = BITS(16, 20); //-V519 -                    if ((Rd == 15)) { +                    if (Rd == 15) {                          ARMul_UndefInstr (state, instr); -                    } else if ((Rn == 15)) { +                    } else if (Rn == 15) {                          data = state->Reg[Rd];                          tmp_rd = ((ARMword)(data << (31 - lsb)) >> (31 - lsb));                          dst = ((data >> msb) << (msb - lsb)); @@ -3209,16 +2727,6 @@ mainswitch:                      break;                  case 0x6e:	/* Store Byte, WriteBack, Post Inc, Reg.  */ -#if 0 -                    if (state->is_v6) { -                        int Rm = 0; -                        /* utxb */ -                        if (BITS(15, 19) == 0xf && BITS(4, 7) == 0x7) { -                            Rm = (RHS >> (8 * BITS(10, 11))) & 0xff; -                            DEST = Rm; -                        } -                    } -#endif                      if (BIT (4)) {  #ifdef MODE32                          if (state->is_v6 @@ -3656,13 +3164,6 @@ mainswitch:  #endif                      state->Reg[15] = pc + 8 + POSBRANCH;                      FLUSHPIPE; - -#ifdef callstacker -                    memset(a, 0, 256); -                    aufloeser(a, state->Reg[15]); -                    printf("call %08X %08X %s(%08X %08X %08X %08X %08X %08X %08X)\n", state->Reg[14], state->Reg[15], a, state->Reg[0], state->Reg[1], state->Reg[2], state->Reg[3], mem_Read32(state->Reg[13]), mem_Read32(state->Reg[13] - 4),mem_Read32(state->Reg[13] - 8)); -#endif -                      break;                  /* Branch and Link backward.  */ @@ -3682,13 +3183,6 @@ mainswitch:  #endif                      state->Reg[15] = pc + 8 + NEGBRANCH;                      FLUSHPIPE; - -#ifdef callstacker -                    memset(a, 0, 256); -                    aufloeser(a, state->Reg[15]); -                    printf("call %08X %08X %s(%08X %08X %08X %08X %08X %08X %08X)\n", state->Reg[14], state->Reg[15], a, state->Reg[0], state->Reg[1], state->Reg[2], state->Reg[3], mem_Read32(state->Reg[13]), mem_Read32(state->Reg[13] - 4),mem_Read32(state->Reg[13] - 8)); -#endif -                      break;                  /* Co-Processor Data Transfers.  */ @@ -3909,165 +3403,6 @@ mainswitch:  donext:  #endif              state->pc = pc; -#if 0 -            /* shenoubang */ -            instr_sum++; -            int i, j; -            i = j = 0; -            if (instr_sum >= 7388648) { -                //if (pc == 0xc0008ab4) { -                //	printf("instr_sum: %d\n", instr_sum); -                // start_kernel : 0xc000895c -                printf("--------------------------------------------------\n"); -                for (i = 0; i < 16; i++) { -                    printf("[R%02d]:[0x%08x]\t", i, state->Reg[i]); -                    if ((i % 3) == 2) { -                        printf("\n"); -                    } -                } -                printf("[cpr]:[0x%08x]\t[spr0]:[0x%08x]\n", state->Cpsr, state->Spsr[0]); -                for (j = 1; j < 7; j++) { -                    printf("[spr%d]:[0x%08x]\t", j, state->Spsr[j]); -                    if ((j % 4) == 3) { -                        printf("\n"); -                    } -                } -                printf("\n[PC]:[0x%08x]\t[INST]:[0x%08x]\t[COUNT]:[%d]\n", pc, instr, instr_sum); -                printf("--------------------------------------------------\n"); -            } -#endif - -#if 0 -            fprintf(state->state_log, "PC:0x%x\n", pc); -            for (reg_index = 0; reg_index < 16; reg_index ++) { -                if (state->Reg[reg_index] != mirror_register_file[reg_index]) { -                    fprintf(state->state_log, "R%d:0x%x\n", reg_index, state->Reg[reg_index]); -                    mirror_register_file[reg_index] = state->Reg[reg_index]; -                } -            } -            if (state->Cpsr != mirror_register_file[CPSR_REG]) { -                fprintf(state->state_log, "Cpsr:0x%x\n", state->Cpsr); -                mirror_register_file[CPSR_REG] = state->Cpsr; -            } -            if (state->RegBank[SVCBANK][13] != mirror_register_file[R13_SVC]) { -                fprintf(state->state_log, "R13_SVC:0x%x\n", state->RegBank[SVCBANK][13]); -                mirror_register_file[R13_SVC] = state->RegBank[SVCBANK][13]; -            } -            if (state->RegBank[SVCBANK][14] != mirror_register_file[R14_SVC]) { -                fprintf(state->state_log, "R14_SVC:0x%x\n", state->RegBank[SVCBANK][14]); -                mirror_register_file[R14_SVC] = state->RegBank[SVCBANK][14]; -            } -            if (state->RegBank[ABORTBANK][13] != mirror_register_file[R13_ABORT]) { -                fprintf(state->state_log, "R13_ABORT:0x%x\n", state->RegBank[ABORTBANK][13]); -                mirror_register_file[R13_ABORT] = state->RegBank[ABORTBANK][13]; -            } -            if (state->RegBank[ABORTBANK][14] != mirror_register_file[R14_ABORT]) { -                fprintf(state->state_log, "R14_ABORT:0x%x\n", state->RegBank[ABORTBANK][14]); -                mirror_register_file[R14_ABORT] = state->RegBank[ABORTBANK][14]; -            } -            if (state->RegBank[UNDEFBANK][13] != mirror_register_file[R13_UNDEF]) { -                fprintf(state->state_log, "R13_UNDEF:0x%x\n", state->RegBank[UNDEFBANK][13]); -                mirror_register_file[R13_UNDEF] = state->RegBank[UNDEFBANK][13]; -            } -            if (state->RegBank[UNDEFBANK][14] != mirror_register_file[R14_UNDEF]) { -                fprintf(state->state_log, "R14_UNDEF:0x%x\n", state->RegBank[UNDEFBANK][14]); -                mirror_register_file[R14_UNDEF] = state->RegBank[UNDEFBANK][14]; -            } -            if (state->RegBank[IRQBANK][13] != mirror_register_file[R13_IRQ]) { -                fprintf(state->state_log, "R13_IRQ:0x%x\n", state->RegBank[IRQBANK][13]); -                mirror_register_file[R13_IRQ] = state->RegBank[IRQBANK][13]; -            } -            if (state->RegBank[IRQBANK][14] != mirror_register_file[R14_IRQ]) { -                fprintf(state->state_log, "R14_IRQ:0x%x\n", state->RegBank[IRQBANK][14]); -                mirror_register_file[R14_IRQ] = state->RegBank[IRQBANK][14]; -            } -            if (state->RegBank[FIQBANK][8] != mirror_register_file[R8_FIRQ]) { -                fprintf(state->state_log, "R8_FIRQ:0x%x\n", state->RegBank[FIQBANK][8]); -                mirror_register_file[R8_FIRQ] = state->RegBank[FIQBANK][8]; -            } -            if (state->RegBank[FIQBANK][9] != mirror_register_file[R9_FIRQ]) { -                fprintf(state->state_log, "R9_FIRQ:0x%x\n", state->RegBank[FIQBANK][9]); -                mirror_register_file[R9_FIRQ] = state->RegBank[FIQBANK][9]; -            } -            if (state->RegBank[FIQBANK][10] != mirror_register_file[R10_FIRQ]) { -                fprintf(state->state_log, "R10_FIRQ:0x%x\n", state->RegBank[FIQBANK][10]); -                mirror_register_file[R10_FIRQ] = state->RegBank[FIQBANK][10]; -            } -            if (state->RegBank[FIQBANK][11] != mirror_register_file[R11_FIRQ]) { -                fprintf(state->state_log, "R11_FIRQ:0x%x\n", state->RegBank[FIQBANK][11]); -                mirror_register_file[R11_FIRQ] = state->RegBank[FIQBANK][11]; -            } -            if (state->RegBank[FIQBANK][12] != mirror_register_file[R12_FIRQ]) { -                fprintf(state->state_log, "R12_FIRQ:0x%x\n", state->RegBank[FIQBANK][12]); -                mirror_register_file[R12_FIRQ] = state->RegBank[FIQBANK][12]; -            } -            if (state->RegBank[FIQBANK][13] != mirror_register_file[R13_FIRQ]) { -                fprintf(state->state_log, "R13_FIRQ:0x%x\n", state->RegBank[FIQBANK][13]); -                mirror_register_file[R13_FIRQ] = state->RegBank[FIQBANK][13]; -            } -            if (state->RegBank[FIQBANK][14] != mirror_register_file[R14_FIRQ]) { -                fprintf(state->state_log, "R14_FIRQ:0x%x\n", state->RegBank[FIQBANK][14]); -                mirror_register_file[R14_FIRQ] = state->RegBank[FIQBANK][14]; -            } -            if (state->Spsr[SVCBANK] != mirror_register_file[SPSR_SVC]) { -                fprintf(state->state_log, "SPSR_SVC:0x%x\n", state->Spsr[SVCBANK]); -                mirror_register_file[SPSR_SVC] = state->RegBank[SVCBANK]; -            } -            if (state->Spsr[ABORTBANK] != mirror_register_file[SPSR_ABORT]) { -                fprintf(state->state_log, "SPSR_ABORT:0x%x\n", state->Spsr[ABORTBANK]); -                mirror_register_file[SPSR_ABORT] = state->RegBank[ABORTBANK]; -            } -            if (state->Spsr[UNDEFBANK] != mirror_register_file[SPSR_UNDEF]) { -                fprintf(state->state_log, "SPSR_UNDEF:0x%x\n", state->Spsr[UNDEFBANK]); -                mirror_register_file[SPSR_UNDEF] = state->RegBank[UNDEFBANK]; -            } -            if (state->Spsr[IRQBANK] != mirror_register_file[SPSR_IRQ]) { -                fprintf(state->state_log, "SPSR_IRQ:0x%x\n", state->Spsr[IRQBANK]); -                mirror_register_file[SPSR_IRQ] = state->RegBank[IRQBANK]; -            } -            if (state->Spsr[FIQBANK] != mirror_register_file[SPSR_FIRQ]) { -                fprintf(state->state_log, "SPSR_FIRQ:0x%x\n", state->Spsr[FIQBANK]); -                mirror_register_file[SPSR_FIRQ] = state->RegBank[FIQBANK]; -            } - -#endif - -#ifdef NEED_UI_LOOP_HOOK -            if (ui_loop_hook != NULL && ui_loop_hook_counter-- < 0) { -                ui_loop_hook_counter = UI_LOOP_POLL_INTERVAL; -                ui_loop_hook (0); -            } -#endif /* NEED_UI_LOOP_HOOK */ - -            /*added energy_prof statement by ksh in 2004-11-26 */ -            //chy 2005-07-28 for standalone -            //ARMul_do_energy(state,instr,pc); -//teawater add for record reg value to ./reg.txt 2005.07.10--------------------- -            if (state->tea_break_ok && pc == state->tea_break_addr) { -                //ARMul_Debug (state, 0, 0); -                state->tea_break_ok = 0; -            } else { -                state->tea_break_ok = 1; -            } -//AJ2D-------------------------------------------------------------------------- -//chy 2006-04-14 for ctrl-c debug -#if 0 -            if (debugmode) { -                if (instr != ARMul_ABORTWORD) { -                    remote_interrupt_test_time++; -                    //chy 2006-04-14 2000 should be changed in skyeye_conf ???!!! -                    if (remote_interrupt_test_time >= 2000) { -                        remote_interrupt_test_time=0; -                        if (remote_interrupt()) { -                            //for test -                            //printf("SKYEYE: ICE_debug recv Ctrl_C\n"); -                            state->EndCondition = 0; -                            state->Emulate = STOP; -                        } -                    } -                } -            } -#endif              /* jump out every time */              //state->EndCondition = 0; @@ -4076,10 +3411,6 @@ donext:  TEST_EMULATE:              if (state->Emulate == ONCE)                  state->Emulate = STOP; -            //chy: 2003-08-23: should not use CHANGEMODE !!!! -            /* If we have changed mode, allow the PC to advance before stopping.  */ -            //    else if (state->Emulate == CHANGEMODE) -            //        continue;              else if (state->Emulate != RUN)                  break;      } @@ -4096,225 +3427,14 @@ exit:          return pc;      } -//teawater add for arm2x86 2005.02.17------------------------------------------- -    /*ywc 2005-04-01*/ -//#include "tb.h" -//#include "arm2x86_self.h" -      static volatile void (*gen_func) (void); -//static volatile ARMul_State   *tmp_st; -//static volatile ARMul_State   *save_st; +      static volatile uint32_t tmp_st;      static volatile uint32_t save_st;      static volatile uint32_t save_T0;      static volatile uint32_t save_T1;      static volatile uint32_t save_T2; -#ifdef MODE32 -#ifdef DBCT -//teawater change for debug function 2005.07.09--------------------------------- -    ARMword -    ARMul_Emulate32_dbct (ARMul_State * state) { -        static int init = 0; -        static FILE *fd; - -        /*if (!init) { -           fd = fopen("./pc.txt", "w"); -           if (!fd) { -           exit(-1); -           } -           init = 1; -           } */ - -        state->Reg[15] += INSN_SIZE; -        do { -            /*if (skyeye_config.log.logon>=1) { -               if (state->NumInstrs>=skyeye_config.log.start && state->NumInstrs<=skyeye_config.log.end) { -               static int mybegin=0; -               static int myinstrnum=0; - -               if (mybegin==0) mybegin=1; -               if (mybegin==1) { -               state->Reg[15] -= INSN_SIZE; -               if (skyeye_config.log.logon>=1) fprintf(skyeye_logfd,"N %llx :p %x,i %x,",state->NumInstrs, (state->Reg[15] - INSN_SIZE), instr); -               if (skyeye_config.log.logon>=2) SKYEYE_OUTREGS(skyeye_logfd); -               if (skyeye_config.log.logon>=3) SKYEYE_OUTMOREREGS(skyeye_logfd); -               fprintf(skyeye_logfd,"\n"); -               if (skyeye_config.log.length>0) { -               myinstrnum++; -               if (myinstrnum>=skyeye_config.log.length) { -               myinstrnum=0; -               fflush(skyeye_logfd); -               fseek(skyeye_logfd,0L,SEEK_SET); -               } -               } -               state->Reg[15] += INSN_SIZE; -               } -               } -               } */ -            state->trap = 0; -            gen_func = -                (void *) tb_find (state, state->Reg[15] - INSN_SIZE); -            if (!gen_func) { -                //fprintf(stderr, "SKYEYE: tb_find: Error in find the translate block.\n"); -                //exit(-1); -                //TRAP_INSN_ABORT -                //TEA_OUT(printf("\n------------\npc:%x\n", state->Reg[15] - INSN_SIZE)); -                //TEA_OUT(printf("TRAP_INSN_ABORT\n")); -//teawater add for xscale(arm v5) 2005.09.01------------------------------------ -                /*XScale_set_fsr_far(state, ARMul_CP15_R5_MMU_EXCPT, state->Reg[15] - INSN_SIZE); -                   state->Reg[15] += INSN_SIZE; -                   ARMul_Abort(state, ARMul_PrefetchAbortV); -                   state->Reg[15] += INSN_SIZE; -                   goto next; */ -                state->trap = TRAP_INSN_ABORT; -                goto check; -//AJ2D-------------------------------------------------------------------------- -            } - -            save_st = (uint32_t) st; -            save_T0 = T0; -            save_T1 = T1; -            save_T2 = T2; -            tmp_st = (uint32_t) state; -            wmb (); -            st = (ARMul_State *) tmp_st; -            gen_func (); -            st = (ARMul_State *) save_st; -            T0 = save_T0; -            T1 = save_T1; -            T2 = save_T2; - -            /*if (state->trap != TRAP_OUT) { -               state->tea_break_ok = 1; -               } -               if (state->trap <= TRAP_SET_R15) { -               goto next; -               } */ -            //TEA_OUT(printf("\n------------\npc:%x\n", state->Reg[15] - INSN_SIZE)); -//teawater add check thumb 2005.07.21------------------------------------------- -            /*if (TFLAG) { -               state->Reg[15] -= 2; -               return(state->Reg[15]); -               } */ -//AJ2D-------------------------------------------------------------------------- - -//teawater add for xscale(arm v5) 2005.09.01------------------------------------ -check: -//AJ2D-------------------------------------------------------------------------- -            switch (state->trap) { -            case TRAP_RESET: { -                //TEA_OUT(printf("TRAP_RESET\n")); -                ARMul_Abort (state, ARMul_ResetV); -                state->Reg[15] += INSN_SIZE; -            } -            break; -            case TRAP_UNPREDICTABLE: { -                //ARMul_Debug (state, 0, 0); -            } -            break; -            case TRAP_INSN_UNDEF: { -                //TEA_OUT(printf("TRAP_INSN_UNDEF\n")); -                state->Reg[15] += INSN_SIZE; -                ARMul_UndefInstr (state, 0); -                state->Reg[15] += INSN_SIZE; -            } -            break; -            case TRAP_SWI: { -                //TEA_OUT(printf("TRAP_SWI\n")); -                state->Reg[15] += INSN_SIZE; -                ARMul_Abort (state, ARMul_SWIV); -                state->Reg[15] += INSN_SIZE; -            } -            break; -//teawater add for xscale(arm v5) 2005.09.01------------------------------------ -            case TRAP_INSN_ABORT: { -                /*XScale_set_fsr_far (state, -                		    ARMul_CP15_R5_MMU_EXCPT, -                		    state->Reg[15] - -                		    INSN_SIZE);*/ -                state->Reg[15] += INSN_SIZE; -                ARMul_Abort (state, ARMul_PrefetchAbortV); -                state->Reg[15] += INSN_SIZE; -            } -            break; -//AJ2D-------------------------------------------------------------------------- -            case TRAP_DATA_ABORT: { -                //TEA_OUT(printf("TRAP_DATA_ABORT\n")); -                state->Reg[15] += INSN_SIZE; -                ARMul_Abort (state, ARMul_DataAbortV); -                state->Reg[15] += INSN_SIZE; -            } -            break; -            case TRAP_IRQ: { -                //TEA_OUT(printf("TRAP_IRQ\n")); -                state->Reg[15] += INSN_SIZE; -                ARMul_Abort (state, ARMul_IRQV); -                state->Reg[15] += INSN_SIZE; -            } -            break; -            case TRAP_FIQ: { -                //TEA_OUT(printf("TRAP_FIQ\n")); -                state->Reg[15] += INSN_SIZE; -                ARMul_Abort (state, ARMul_FIQV); -                state->Reg[15] += INSN_SIZE; -            } -            break; -            case TRAP_SETS_R15: { -                //TEA_OUT(printf("TRAP_SETS_R15\n")); -                /*if (state->Bank > 0) { -                   state->Cpsr = state->Spsr[state->Bank]; -                   ARMul_CPSRAltered (state); -                   } */ -                WriteSR15 (state, state->Reg[15]); -            } -            break; -            case TRAP_SET_CPSR: { -                //TEA_OUT(printf("TRAP_SET_CPSR\n")); -                //chy 2006-02-15 USERBANK=SYSTEMBANK=0 -                //chy 2006-02-16 should use Mode to test -                //if (state->Bank > 0) { -                if (state->Mode != USER26MODE && state->Mode != USER32MODE) { -                    //ARMul_CPSRAltered (state); -                } -                state->Reg[15] += INSN_SIZE; -            } -            break; -            case TRAP_OUT: { -                //TEA_OUT(printf("TRAP_OUT\n")); -                goto out; -            } -            break; -            case TRAP_BREAKPOINT: { -                //TEA_OUT(printf("TRAP_BREAKPOINT\n")); -                state->Reg[15] -= INSN_SIZE; -                if (!ARMul_OSHandleSWI -                        (state, SWI_Breakpoint)) { -                    ARMul_Abort (state, ARMul_SWIV); -                } -                state->Reg[15] += INSN_SIZE; -            } -            break; -            } - -next: -            if (state->Emulate == ONCE) { -                state->Emulate = STOP; -                break; -            } else if (state->Emulate != RUN) { -                break; -            } -        } while (!state->stop_simulator); - -out: -        state->Reg[15] -= INSN_SIZE; -        return (state->Reg[15]); -    } -#endif -//AJ2D-------------------------------------------------------------------------- -#endif -//AJ2D-------------------------------------------------------------------------- -      /* This routine evaluates most Data Processing register RHS's with the S         bit clear.  It is intended to be called from the macro DPRegRHS, which         filters the common case of an unshifted register with in line code.  */ @@ -4672,21 +3792,6 @@ out:          return BITS (0, 3) | (BITS (8, 11) << 4);      } -    /* This function does the work of loading a word for a LDR instruction.  */ -#define MEM_LOAD_LOG(description) if (skyeye_config.log.memlogon >= 1) { \ -		fprintf(skyeye_logfd, \ -			"m LOAD %s: N %llx :p %x :i %x :a %x :d %x\n", \ -			description, state->NumInstrs, state->pc, instr, \ -			address, dest); \ -	} - -#define MEM_STORE_LOG(description) if (skyeye_config.log.memlogon >= 1) { \ -		fprintf(skyeye_logfd, \ -			"m STORE %s: N %llx :p %x :i %x :a %x :d %x\n", \ -			description, state->NumInstrs, state->pc, instr, \ -			address, DEST); \ -	} -      static unsigned      LoadWord (ARMul_State * state, ARMword instr, ARMword address) {          ARMword dest; @@ -4708,8 +3813,6 @@ out:          WRITEDESTB (dest);          ARMul_Icycles (state, 1, 0L); -        //MEM_LOAD_LOG("WORD"); -          return (DESTReg != LHSReg);      } @@ -4739,8 +3842,6 @@ out:          WRITEDEST (dest);          ARMul_Icycles (state, 1, 0L); -        //MEM_LOAD_LOG("HALFWORD"); -          return (DESTReg != LHSReg);      } @@ -4770,8 +3871,6 @@ out:          WRITEDEST (dest);          ARMul_Icycles (state, 1, 0L); -        //MEM_LOAD_LOG("BYTE"); -          return (DESTReg != LHSReg);      } @@ -4980,8 +4079,6 @@ out:      static unsigned      StoreWord (ARMul_State * state, ARMword instr, ARMword address) { -        //MEM_STORE_LOG("WORD"); -          BUSUSEDINCPCN;  #ifndef MODE32          if (DESTReg == 15) @@ -5009,8 +4106,6 @@ out:      static unsigned      StoreHalfWord (ARMul_State * state, ARMword instr, ARMword address) { -        //MEM_STORE_LOG("HALFWORD"); -          BUSUSEDINCPCN;  #ifndef MODE32 @@ -5041,8 +4136,6 @@ out:      static unsigned      StoreByte (ARMul_State * state, ARMword instr, ARMword address) { -        //MEM_STORE_LOG("BYTE"); -          BUSUSEDINCPCN;  #ifndef MODE32          if (DESTReg == 15) diff --git a/src/core/arm/interpreter/arminit.cpp b/src/core/arm/interpreter/arminit.cpp index 03bca2870..8ab5ef160 100644 --- a/src/core/arm/interpreter/arminit.cpp +++ b/src/core/arm/interpreter/arminit.cpp @@ -15,8 +15,6 @@      along with this program; if not, write to the Free Software      Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ -//#include <unistd.h> -  #include "core/arm/skyeye_common/armdefs.h"  #include "core/arm/skyeye_common/armemu.h" @@ -24,26 +22,21 @@  *                 Definitions for the emulator architecture                 *  \***************************************************************************/ -void ARMul_EmulateInit (void); -ARMul_State *ARMul_NewState (ARMul_State * state); -void ARMul_Reset (ARMul_State * state); -ARMword ARMul_DoCycle (ARMul_State * state); -unsigned ARMul_DoCoPro (ARMul_State * state); -ARMword ARMul_DoProg (ARMul_State * state); -ARMword ARMul_DoInstr (ARMul_State * state); -void ARMul_Abort (ARMul_State * state, ARMword address); +void ARMul_EmulateInit(); +ARMul_State* ARMul_NewState(ARMul_State* state); +void ARMul_Reset (ARMul_State* state); +ARMword ARMul_DoCycle(ARMul_State* state); +unsigned ARMul_DoCoPro(ARMul_State* state); +ARMword ARMul_DoProg(ARMul_State* state); +ARMword ARMul_DoInstr(ARMul_State* state); +void ARMul_Abort(ARMul_State* state, ARMword address);  unsigned ARMul_MultTable[32] = {      1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9,      10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15, 16, 16, 16  }; -ARMword ARMul_ImmedTable[4096];	/* immediate DP LHS values */ -char ARMul_BitList[256];	/* number of bits in a byte table */ - -//chy 2006-02-22 add test debugmode -extern int debugmode; -extern int remote_interrupt( void ); - +ARMword ARMul_ImmedTable[4096]; /* immediate DP LHS values */ +char ARMul_BitList[256];        /* number of bits in a byte table */  void arm_dyncom_Abort(ARMul_State * state, ARMword vector)  { @@ -51,36 +44,10 @@ void arm_dyncom_Abort(ARMul_State * state, ARMword vector)  } -/* ahe-ykl : the following code to initialize user mode -   code is architecture dependent and probably model dependant. */ - -/*#include "skyeye_arch.h" -#include "skyeye_pref.h" -#include "skyeye_exec_info.h" -#include "bank_defs.h"*/ -//#include "armcpu.h" -//#include "skyeye_callback.h" - -/* -		ARM_CPU_State* cpu = get_current_cpu(); -		arm_core_t* core = &cpu->core[0]; - -		uint32_t sp = info->initial_sp; - -		core->Cpsr = 0x10; // User mode -// FIXME: may need to add thumb -core->Reg[13] = sp; -core->Reg[10] = info->start_data; -core->Reg[0] = 0; -bus_read(32, sp + 4, &(core->Reg[1])); -bus_read(32, sp + 8, &(core->Reg[2])); -*/  /***************************************************************************\  *         Call this routine once to set up the emulator's tables.           *  \***************************************************************************/ - -void -ARMul_EmulateInit (void) +void ARMul_EmulateInit()  {      unsigned int i, j; @@ -102,9 +69,7 @@ ARMul_EmulateInit (void)  /***************************************************************************\  *            Returns a new instantiation of the ARMulator's state           *  \***************************************************************************/ - -ARMul_State * -ARMul_NewState (ARMul_State *state) +ARMul_State* ARMul_NewState(ARMul_State* state)  {      unsigned i, j; @@ -120,7 +85,6 @@ ARMul_NewState (ARMul_State *state)          state->Spsr[i] = 0;      state->Mode = 0; -    state->CallDebug = FALSE;      state->Debug = FALSE;      state->VectorCatch = 0;      state->Aborted = FALSE; @@ -128,34 +92,6 @@ ARMul_NewState (ARMul_State *state)      state->Inted = 3;      state->LastInted = 3; -    state->CommandLine = NULL; - -    state->EventSet = 0; -    state->Now = 0; -    state->EventPtr = -        (struct EventNode **) malloc ((unsigned) EVENTLISTSIZE * -                                      sizeof (struct EventNode *)); -#if DIFF_STATE -    state->state_log = fopen("/data/state.log", "w"); -    printf("create pc log file.\n"); -#endif -    if (state->EventPtr == NULL) { -        printf ("SKYEYE: ARMul_NewState malloc state->EventPtr error\n"); -        exit(-1); -        //skyeye_exit (-1); -    } -    for (i = 0; i < EVENTLISTSIZE; i++) -        *(state->EventPtr + i) = NULL; -#if SAVE_LOG -    state->state_log = fopen("/tmp/state.log", "w"); -    printf("create pc log file.\n"); -#else -#if DIFF_LOG -    state->state_log = fopen("/tmp/state.log", "r"); -    printf("loaded pc log file.\n"); -#endif -#endif -  #ifdef ARM61      state->prog32Sig = LOW;      state->data32Sig = LOW; @@ -168,28 +104,19 @@ ARMul_NewState (ARMul_State *state)      state->bigendSig = LOW;      //chy:2003-08-19 -    state->LastTime = 0;      state->CP14R0_CCD = -1; -    /* ahe-ykl: common function for interpret and dyncom */ -    /*sky_pref_t *pref = get_skyeye_pref(); -    if (pref->user_mode_sim) -    	register_callback(arm_user_mode_init, Bootmach_callback); -        */ -      memset(&state->exclusive_tag_array[0], 0xFF, sizeof(state->exclusive_tag_array[0]) * 128);      state->exclusive_access_state = 0; -    //state->cpu = (cpu_config_t *) malloc (sizeof (cpu_config_t)); -    //state->mem_bank = (mem_config_t *) malloc (sizeof (mem_config_t)); -    return (state); + +    return state;  }  /***************************************************************************\  *       Call this routine to set ARMulator to model a certain processor     *  \***************************************************************************/ -void -ARMul_SelectProcessor (ARMul_State * state, unsigned properties) +void ARMul_SelectProcessor(ARMul_State* state, unsigned properties)  {      if (properties & ARM_Fix26_Prop) {          state->prog32Sig = LOW; @@ -198,27 +125,16 @@ ARMul_SelectProcessor (ARMul_State * state, unsigned properties)          state->prog32Sig = HIGH;          state->data32Sig = HIGH;      } -    /* 2004-05-09 chy -    below line sould be in skyeye_mach_XXX.c 's XXX_mach_init function -    */ -    // state->lateabtSig = HIGH; - -    state->is_v4 = -        (properties & (ARM_v4_Prop | ARM_v5_Prop)) ? HIGH : LOW; -    state->is_v5 = (properties & ARM_v5_Prop) ? HIGH : LOW; -    state->is_v5e = (properties & ARM_v5e_Prop) ? HIGH : LOW; +    state->is_v4     = (properties & (ARM_v4_Prop | ARM_v5_Prop)) ? HIGH : LOW; +    state->is_v5     = (properties & ARM_v5_Prop) ? HIGH : LOW; +    state->is_v5e    = (properties & ARM_v5e_Prop) ? HIGH : LOW;      state->is_XScale = (properties & ARM_XScale_Prop) ? HIGH : LOW;      state->is_iWMMXt = (properties & ARM_iWMMXt_Prop) ? HIGH : LOW; -    /* state->is_v6 = LOW */; -    /* jeff.du 2010-08-05 */ -    state->is_v6 = (properties & ARM_v6_Prop) ? HIGH : LOW; +    state->is_v6     = (properties & ARM_v6_Prop) ? HIGH : LOW;      state->is_ep9312 = (properties & ARM_ep9312_Prop) ? HIGH : LOW; -    //chy 2005-09-19      state->is_pxa27x = (properties & ARM_PXA27X_Prop) ? HIGH : LOW; - -    /* shenoubang 2012-3-11 */ -    state->is_v7 = (properties & ARM_v7_Prop) ? HIGH : LOW; +    state->is_v7     = (properties & ARM_v7_Prop) ? HIGH : LOW;      /* Only initialse the coprocessor support once we         know what kind of chip we are dealing with.  */ @@ -229,11 +145,8 @@ ARMul_SelectProcessor (ARMul_State * state, unsigned properties)  /***************************************************************************\  * Call this routine to set up the initial machine state (or perform a RESET *  \***************************************************************************/ - -void -ARMul_Reset (ARMul_State * state) +void ARMul_Reset(ARMul_State* state)  { -    //fprintf(stderr,"armul_reset 0: state->  Cpsr 0x%x, Mode %d\n",state->Cpsr,state->Mode);      state->NextInstr = 0;      if (state->prog32Sig) {          state->Reg[15] = 0; @@ -244,15 +157,13 @@ ARMul_Reset (ARMul_State * state)          state->Cpsr = INTBITS | SVC26MODE;          state->Mode = SVC26MODE;      } -    //fprintf(stderr,"armul_reset 1: state->  Cpsr 0x%x, Mode %d\n",state->Cpsr,state->Mode); -    //ARMul_CPSRAltered (state); +      state->Bank = SVCBANK;      FLUSHPIPE;      state->EndCondition = 0;      state->ErrorCode = 0; -    //fprintf(stderr,"armul_reset 2: state->  Cpsr 0x%x, Mode %d\n",state->Cpsr,state->Mode);      state->NresetSig = HIGH;      state->NfiqSig = HIGH;      state->NirqSig = HIGH; @@ -266,33 +177,6 @@ ARMul_Reset (ARMul_State * state)      state->NumIcycles = 0;      state->NumCcycles = 0;      state->NumFcycles = 0; - -    //fprintf(stderr,"armul_reset 3: state->  Cpsr 0x%x, Mode %d\n",state->Cpsr,state->Mode); -    //mmu_reset (state); -    //fprintf(stderr,"armul_reset 4: state->  Cpsr 0x%x, Mode %d\n",state->Cpsr,state->Mode); - -    //mem_reset (state); /* move to memory/ram.c */ - -    //fprintf(stderr,"armul_reset 5: state->  Cpsr 0x%x, Mode %d\n",state->Cpsr,state->Mode); -    /*remove later. walimis 03.7.17 */ -    //io_reset(state); -    //lcd_disable(state); - -    /*ywc 2005-04-07 move from ARMul_NewState , because skyeye_config.no_dbct will -     *be configured in skyeye_option_init and it is called after ARMul_NewState*/ -    state->tea_break_ok = 0; -    state->tea_break_addr = 0; -    state->tea_pc = 0; -#ifdef DBCT -    if (!skyeye_config.no_dbct) { -        //teawater add for arm2x86 2005.02.14------------------------------------------- -        if (arm2x86_init (state)) { -            printf ("SKYEYE: arm2x86_init error\n"); -            //skyeye_exit (-1); -        } -        //AJ2D-------------------------------------------------------------------------- -    } -#endif  } @@ -301,108 +185,23 @@ ARMul_Reset (ARMul_State * state)  * (Emulate26 for a 26 bit ARM and Emulate32 for a 32 bit ARM), return the   *  * address of the last instruction that is executed.                         *  \***************************************************************************/ - -//teawater add DBCT_TEST_SPEED 2005.10.04--------------------------------------- -#ifdef DBCT_TEST_SPEED -static ARMul_State	*dbct_test_speed_state = NULL; -static void -dbct_test_speed_sig(int signo) -{ -    printf("\n0x%llx %llu\n", dbct_test_speed_state->instr_count, dbct_test_speed_state->instr_count); -    exit(0); -    //skyeye_exit(0); -} -#endif	//DBCT_TEST_SPEED -//AJ2D-------------------------------------------------------------------------- - -ARMword -ARMul_DoProg (ARMul_State * state) +ARMword ARMul_DoProg(ARMul_State* state)  {      ARMword pc = 0; -    /* -     * 2007-01-24 removed the term-io functions by Anthony Lee, -     * moved to "device/uart/skyeye_uart_stdio.c". -     */ - -//teawater add DBCT_TEST_SPEED 2005.10.04--------------------------------------- -#ifdef DBCT_TEST_SPEED -    { -        if (!dbct_test_speed_state) { -            //init timer -            struct itimerval	value; -            struct sigaction	act; - -            dbct_test_speed_state = state; -            state->instr_count = 0; -            act.sa_handler = dbct_test_speed_sig; -            act.sa_flags = SA_RESTART; -            //cygwin don't support ITIMER_VIRTUAL or ITIMER_PROF -#ifndef __CYGWIN__ -            if (sigaction(SIGVTALRM, &act, NULL) == -1) { -#else -            if (sigaction(SIGALRM, &act, NULL) == -1) { -#endif	//__CYGWIN__ -                fprintf(stderr, "init timer error.\n"); -                exit(-1); -                //skyeye_exit(-1); -            } -            if (skyeye_config.dbct_test_speed_sec) { -                value.it_value.tv_sec = skyeye_config.dbct_test_speed_sec; -            } else { -                value.it_value.tv_sec = DBCT_TEST_SPEED_SEC; -            } -            printf("dbct_test_speed_sec = %ld\n", value.it_value.tv_sec); -            value.it_value.tv_usec = 0; -            value.it_interval.tv_sec = 0; -            value.it_interval.tv_usec = 0; -#ifndef __CYGWIN__ -            if (setitimer(ITIMER_VIRTUAL, &value, NULL) == -1) { -#else -            if (setitimer(ITIMER_REAL, &value, NULL) == -1) { -#endif	//__CYGWIN__ -                fprintf(stderr, "init timer error.\n"); -                //skyeye_exit(-1); -            } -        } -    } -#endif	//DBCT_TEST_SPEED -//AJ2D--------------------------------------------------------------------------      state->Emulate = RUN;      while (state->Emulate != STOP) {          state->Emulate = RUN; -        /*ywc 2005-03-31 */          if (state->prog32Sig && ARMul_MODE32BIT) { -#ifdef DBCT -            if (skyeye_config.no_dbct) { -                pc = ARMul_Emulate32 (state); -            } else { -                pc = ARMul_Emulate32_dbct (state); -            } -#else              pc = ARMul_Emulate32 (state); -#endif          } -          else {              //pc = ARMul_Emulate26 (state);          } -        //chy 2006-02-22, should test debugmode first -        //chy 2006-04-14, put below codes in ARMul_Emulate -#if 0 -        if(debugmode) -            if(remote_interrupt()) -                state->Emulate = STOP; -#endif      } -    /* -     * 2007-01-24 removed the term-io functions by Anthony Lee, -     * moved to "device/uart/skyeye_uart_stdio.c". -     */ - -    return (pc); +    return pc;  }  /***************************************************************************\ @@ -410,38 +209,17 @@ ARMul_DoProg (ARMul_State * state)  * (Emulate26 for a 26 bit ARM and Emulate32 for a 32 bit ARM), return the   *  * address of the instruction that is executed.                              *  \***************************************************************************/ - -ARMword -ARMul_DoInstr (ARMul_State * state) +ARMword ARMul_DoInstr(ARMul_State* state)  {      ARMword pc = 0;      state->Emulate = ONCE; -    /*ywc 2005-03-31 */      if (state->prog32Sig && ARMul_MODE32BIT) { -#ifdef DBCT -        if (skyeye_config.no_dbct) { -            pc = ARMul_Emulate32 (state); -        } else { -//teawater add compile switch for DBCT GDB RSP function 2005.10.21-------------- -#ifndef DBCT_GDBRSP -            printf("DBCT GDBRSP function switch is off.\n"); -            printf("To use this function, open \"#define DBCT_GDBRSP\" in arch/arm/common/armdefs.h & recompile skyeye.\n"); -            skyeye_exit(-1); -#endif	//DBCT_GDBRSP -//AJ2D-------------------------------------------------------------------------- -            pc = ARMul_Emulate32_dbct (state); -        } -#else          pc = ARMul_Emulate32 (state); -#endif      } -    //else -    //pc = ARMul_Emulate26 (state); - -    return (pc); +    return pc;  }  /***************************************************************************\ @@ -449,9 +227,7 @@ ARMul_DoInstr (ARMul_State * state)  * mode, register bank, and the saving of registers.  Call with the          *  * appropriate vector's memory address (0,4,8 ....)                          *  \***************************************************************************/ - -void -ARMul_Abort (ARMul_State * state, ARMword vector) +void ARMul_Abort(ARMul_State* state, ARMword vector)  {      ARMword temp;      int isize = INSN_SIZE; @@ -494,21 +270,11 @@ ARMul_Abort (ARMul_State * state, ARMword vector)          SETABORT (IBIT, SVC26MODE, isize);          break;      case ARMul_IRQV:	/* IRQ */ -        //chy 2003-09-02 the if sentence seems no use -#if 0 -        if (!state->is_XScale || !state->CPRead[13] (state, 0, &temp) -                || (temp & ARMul_CP13_R0_IRQ)) -#endif              SETABORT (IBIT,                        state->prog32Sig ? IRQ32MODE : IRQ26MODE,                        esize);          break;      case ARMul_FIQV:	/* FIQ */ -        //chy 2003-09-02 the if sentence seems no use -#if 0 -        if (!state->is_XScale || !state->CPRead[13] (state, 0, &temp) -                || (temp & ARMul_CP13_R0_FIQ)) -#endif              SETABORT (INTBITS,                        state->prog32Sig ? FIQ32MODE : FIQ26MODE,                        esize); diff --git a/src/core/arm/interpreter/armsupp.cpp b/src/core/arm/interpreter/armsupp.cpp index e2626eefb..5a8f09b22 100644 --- a/src/core/arm/interpreter/armsupp.cpp +++ b/src/core/arm/interpreter/armsupp.cpp @@ -22,13 +22,6 @@  static ARMword ModeToBank (ARMword); -static void EnvokeList (ARMul_State *, unsigned int, unsigned int); - -struct EventNode { -    /* An event list node.  */ -    unsigned (*func) (ARMul_State *);	/* The function to call.  */ -    struct EventNode *next; -};  /* This routine returns the value of a register from a mode.  */ @@ -1068,76 +1061,3 @@ ARMul_Align (ARMul_State* state, ARMword address, ARMword data)      address = (address & 3) << 3;	/* Get the word address.  */      return ((data >> address) | (data << (32 - address)));	/* rot right */  } - -/* This routine is used to call another routine after a certain number of -   cycles have been executed. The first parameter is the number of cycles -   delay before the function is called, the second argument is a pointer -   to the function. A delay of zero doesn't work, just call the function.  */ - -void -ARMul_ScheduleEvent (ARMul_State * state, unsigned int delay, -                     unsigned (*what) (ARMul_State *)) -{ -    unsigned int when; -    struct EventNode *event; - -    if (state->EventSet++ == 0) -        state->Now = ARMul_Time (state); -    when = (state->Now + delay) % EVENTLISTSIZE; -    event = (struct EventNode *) malloc (sizeof (struct EventNode)); -    if (!event) { -        printf ("SKYEYE:ARMul_ScheduleEvent: malloc event error\n"); -        exit(-1); -        //skyeye_exit (-1); -    } -    event->func = what; -    event->next = *(state->EventPtr + when); -    *(state->EventPtr + when) = event; -} - -/* This routine is called at the beginning of -   every cycle, to envoke scheduled events.  */ - -void -ARMul_EnvokeEvent (ARMul_State * state) -{ -    static unsigned int then; - -    then = state->Now; -    state->Now = ARMul_Time (state) % EVENTLISTSIZE; -    if (then < state->Now) -        /* Schedule events.  */ -        EnvokeList (state, then, state->Now); -    else if (then > state->Now) { -        /* Need to wrap around the list.  */ -        EnvokeList (state, then, EVENTLISTSIZE - 1L); -        EnvokeList (state, 0L, state->Now); -    } -} - -/* Envokes all the entries in a range.  */ - -static void -EnvokeList (ARMul_State * state, unsigned int from, unsigned int to) -{ -    for (; from <= to; from++) { -        struct EventNode *anevent; - -        anevent = *(state->EventPtr + from); -        while (anevent) { -            (anevent->func) (state); -            state->EventSet--; -            anevent = anevent->next; -        } -        *(state->EventPtr + from) = NULL; -    } -} - -/* This routine is returns the number of clock ticks since the last reset.  */ - -unsigned int -ARMul_Time (ARMul_State * state) -{ -    return (state->NumScycles + state->NumNcycles + -            state->NumIcycles + state->NumCcycles + state->NumFcycles); -} diff --git a/src/core/arm/skyeye_common/armdefs.h b/src/core/arm/skyeye_common/armdefs.h index d5939313b..a9c41ce5a 100644 --- a/src/core/arm/skyeye_common/armdefs.h +++ b/src/core/arm/skyeye_common/armdefs.h @@ -15,8 +15,7 @@      along with this program; if not, write to the Free Software      Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ -#ifndef _ARMDEFS_H_ -#define _ARMDEFS_H_ +#pragma once  #include <cerrno>  #include <csignal> @@ -33,21 +32,6 @@  #include "core/arm/skyeye_common/armmmu.h"  #include "core/arm/skyeye_common/skyeye_defs.h" -#if EMU_PLATFORM == PLATFORM_LINUX -#include <sys/time.h> -#include <unistd.h> -#endif - -#if 0 -#if 0 -#define DIFF_STATE 1 -#define __FOLLOW_MODE__ 0 -#else -#define DIFF_STATE 0 -#define __FOLLOW_MODE__ 1 -#endif -#endif -  #ifndef FALSE  #define FALSE 0  #define TRUE 1 @@ -58,13 +42,6 @@  #define LOWHIGH 1  #define HIGHLOW 2 -//#define DBCT_TEST_SPEED -#define DBCT_TEST_SPEED_SEC    10 - -#define ARM_BYTE_TYPE         0 -#define ARM_HALFWORD_TYPE     1 -#define ARM_WORD_TYPE         2 -  //the define of cachetype  #define NONCACHE  0  #define DATACACHE  1 @@ -73,18 +50,11 @@  #define POS(i) ( (~(i)) >> 31 )  #define NEG(i) ( (i) >> 31 ) -#ifndef __STDC__ -typedef char *VoidStar; -#endif -  typedef u64 ARMdword;  // must be 64 bits wide  typedef u32 ARMword;   // must be 32 bits wide  typedef u16 ARMhword;  // must be 16 bits wide  typedef u8 ARMbyte;    // must be 8 bits wide  typedef struct ARMul_State ARMul_State; -typedef struct ARMul_io ARMul_io; -typedef struct ARMul_Energy ARMul_Energy; -  typedef unsigned ARMul_CPInits(ARMul_State* state);  typedef unsigned ARMul_CPExits(ARMul_State* state); @@ -98,65 +68,6 @@ typedef unsigned ARMul_CDPs(ARMul_State* state, unsigned type, ARMword instr);  typedef unsigned ARMul_CPReads(ARMul_State* state, unsigned reg, ARMword* value);  typedef unsigned ARMul_CPWrites(ARMul_State* state, unsigned reg, ARMword value); - -//added by ksh,2004-3-5 -struct ARMul_io -{ -    ARMword *instr;      // to display the current interrupt state -    ARMword *net_flag;   // to judge if network is enabled -    ARMword *net_int;    // netcard interrupt - -    //ywc,2004-04-01 -    ARMword *ts_int; -    ARMword *ts_is_enable; -    ARMword *ts_addr_begin; -    ARMword *ts_addr_end; -    ARMword *ts_buffer; -}; - -/* added by ksh,2004-11-26,some energy profiling */ -struct ARMul_Energy -{ -    int energy_prof;        /* <tktan>  BUG200103282109 : for energy profiling */ -    int enable_func_energy; /* <tktan> BUG200105181702 */ -    char *func_energy; -    int func_display;       /* <tktan> BUG200103311509 : for function call display */ -    int func_disp_start;    /* <tktan> BUG200104191428 : to start func profiling */ -    char *start_func;       /* <tktan> BUG200104191428 */ - -    FILE *outfile;          /* <tktan> BUG200105201531 : direct console to file */ -    long long tcycle, pcycle; -    float t_energy; -    void *cur_task;         /* <tktan> BUG200103291737 */ -    long long t_mem_cycle, t_idle_cycle, t_uart_cycle; -    long long p_mem_cycle, p_idle_cycle, p_uart_cycle; -    long long p_io_update_tcycle; -    /*record CCCR,to get current core frequency */ -    ARMword cccr; -}; -#if 0 -#define MAX_BANK 8 -#define MAX_STR  1024 - -typedef struct mem_bank -{ -    ARMword (*read_byte) (ARMul_State* state, ARMword addr); -    void (*write_byte) (ARMul_State* state, ARMword addr, ARMword data); -    ARMword (*read_halfword) (ARMul_State* state, ARMword addr); -    void (*write_halfword) (ARMul_State* state, ARMword addr, ARMword data); -    ARMword (*read_word) (ARMul_State* state, ARMword addr); -    void (*write_word) (ARMul_State* state, ARMword addr, ARMword data); -    unsigned int addr, len; -    char filename[MAX_STR]; -    unsigned type;        //chy 2003-09-21: maybe io,ram,rom -} mem_bank_t; -typedef struct -{ -    int bank_num; -    int current_num;    /*current num of bank */ -    mem_bank_t mem_banks[MAX_BANK]; -} mem_config_t; -#endif  #define VFP_REG_NUM 64  struct ARMul_State  { @@ -196,9 +107,8 @@ struct ARMul_State      ARMdword Accumulator;      ARMword NFlag, ZFlag, CFlag, VFlag, IFFlags;    /* dummy flags for speed */ -        unsigned long long int icounter, debug_icounter, kernel_icounter; -        unsigned int shifter_carry_out; -        //ARMword translate_pc; +    unsigned long long int icounter, debug_icounter, kernel_icounter; +    unsigned int shifter_carry_out;      /* add armv6 flags dyf:2010-08-09 */      ARMword GEFlag, EFlag, AFlag, QFlag; @@ -226,9 +136,6 @@ struct ARMul_State      unsigned CanWatch;                      /* set by memory interface if its willing to suffer the                                                 overhead of checking for watchpoints on each memory                                                 access */ -    unsigned int StopHandle; - -    char *CommandLine;                      /* Command Line from ARMsd */      ARMul_CPInits *CPInit[16];              /* coprocessor initialisers */      ARMul_CPExits *CPExit[16];              /* coprocessor finalisers */ @@ -244,10 +151,6 @@ struct ARMul_State      unsigned char *CPData[16];              /* Coprocessor data */      unsigned char const *CPRegWords[16];    /* map of coprocessor register sizes */ -    unsigned EventSet;                      /* the number of events in the queue */ -    unsigned int Now;                       /* time to the nearest cycle */ -    struct EventNode **EventPtr;            /* the event list */ -      unsigned Debug;                         /* show instructions as they are executed */      unsigned NresetSig;                     /* reset the processor */      unsigned NfiqSig; @@ -300,17 +203,9 @@ So, if lateabtSig=1, then it means Late Abort Model(Base Updated Abort Model)      ARMword Base;                /* extra hand for base writeback */      ARMword AbortAddr;           /* to keep track of Prefetch aborts */ -    const struct Dbg_HostosInterface *hostif; -      int verbose;        /* non-zero means print various messages like the banner */      int mmu_inited; -    //mem_state_t mem; -    /*remove io_state to skyeye_mach_*.c files */ -    //io_state_t io; -    /* point to a interrupt pending register. now for skyeye-ne2k.c -     * later should move somewhere. e.g machine_config_t*/ -      //chy: 2003-08-11, for different arm core type      unsigned is_v4;        /* Are we emulating a v4 architecture (or higher) ?  */ @@ -321,44 +216,17 @@ So, if lateabtSig=1, then it means Late Abort Model(Base Updated Abort Model)      unsigned is_XScale;    /* Are we emulating an XScale architecture ?  */      unsigned is_iWMMXt;    /* Are we emulating an iWMMXt co-processor ?  */      unsigned is_ep9312;    /* Are we emulating a Cirrus Maverick co-processor ?  */ -    //chy 2005-09-19      unsigned is_pxa27x;    /* Are we emulating a Intel PXA27x co-processor ?  */ +      //chy: seems only used in xscale's CP14 -    unsigned int LastTime; /* Value of last call to ARMul_Time() */      ARMword CP14R0_CCD;    /* used to count 64 clock cycles with CP14 R0 bit 3 set */ - -    //added by ksh:for handle different machs io 2004-3-5 -    ARMul_io mach_io; - -    /*added by ksh,2004-11-26,some energy profiling*/ -    ARMul_Energy energy; - -    //teawater add for next_dis 2004.10.27----------------------- -    int disassemble; - - -    //teawater add for arm2x86 2005.02.15------------------------------------------- -    u32 trap; -    u32 tea_break_addr; -    u32 tea_break_ok; -    int tea_pc; -      //teawater add for arm2x86 2005.07.05-------------------------------------------      //arm_arm A2-18 -    int abort_model;    //0 Base Restored Abort Model, 1 the Early Abort Model, 2 Base Updated Abort Model  - -    //teawater change for return if running tb dirty 2005.07.09--------------------- -    void *tb_now; - - -    //teawater add for record reg value to ./reg.txt 2005.07.10--------------------- -    FILE *tea_reg_fd; - +    int abort_model;    //0 Base Restored Abort Model, 1 the Early Abort Model, 2 Base Updated Abort Model      /*added by ksh in 2005-10-1*/      cpu_config_t *cpu; -    //mem_config_t *mem_bank;      /* added LPC remap function */      int vector_remap_flag; @@ -367,23 +235,12 @@ So, if lateabtSig=1, then it means Late Abort Model(Base Updated Abort Model)      u32 step;      u32 cycle; -    int stop_simulator; -    conf_object_t *dyncom_cpu; -//teawater add DBCT_TEST_SPEED 2005.10.04--------------------------------------- -#ifdef DBCT_TEST_SPEED -    uint64_t    instr_count; -#endif    //DBCT_TEST_SPEED -//    FILE * state_log; -//diff log -//#if DIFF_STATE -    FILE * state_log; -//#endif +      /* monitored memory for exclusice access */      ARMword exclusive_tag_array[128];      /* 1 means exclusive access and 0 means open access */      ARMword exclusive_access_state; -    memory_space_intf space;          u32 CurrInstr;      u32 last_pc; /* the last pc executed */      u32 last_instr; /* the last inst executed */ @@ -392,7 +249,6 @@ So, if lateabtSig=1, then it means Late Abort Model(Base Updated Abort Model)      u32 WritePc[17];      u32 CurrWrite;  }; -#define DIFF_WRITE 0  typedef ARMul_State arm_core_t; @@ -519,13 +375,6 @@ extern void ARMul_Reset(ARMul_State* state);  extern ARMul_State *ARMul_NewState(ARMul_State* state);  extern ARMword ARMul_DoProg(ARMul_State* state);  extern ARMword ARMul_DoInstr(ARMul_State* state); -/***************************************************************************\ -*                Definitons of things for event handling                    * -\***************************************************************************/ - -extern void ARMul_ScheduleEvent(ARMul_State* state, unsigned int delay, unsigned(*func) ()); -extern void ARMul_EnvokeEvent(ARMul_State* state); -extern unsigned int ARMul_Time(ARMul_State* state);  /***************************************************************************\  *                          Useful support routines                          * @@ -724,56 +573,12 @@ enum ConditionCode {  #define IFFLAGS    state->IFFlags  #endif //VFLAG -#define SKYEYE_OUTREGS(fd) { fprintf ((fd), "R %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,C %x,S %x,%x,%x,%x,%x,%x,%x,M %x,B %x,E %x,I %x,P %x,T %x,L %x,D %x,",\ -                         state->Reg[0],state->Reg[1],state->Reg[2],state->Reg[3], \ -                         state->Reg[4],state->Reg[5],state->Reg[6],state->Reg[7], \ -                         state->Reg[8],state->Reg[9],state->Reg[10],state->Reg[11], \ -                         state->Reg[12],state->Reg[13],state->Reg[14],state->Reg[15], \ -                         state->Cpsr,   state->Spsr[0], state->Spsr[1], state->Spsr[2],\ -                         state->Spsr[3],state->Spsr[4], state->Spsr[5], state->Spsr[6],\ -                         state->Mode,state->Bank,state->ErrorCode,state->instr,state->pc,\ -                         state->temp,state->loaded,state->decoded);} - -#define SKYEYE_OUTMOREREGS(fd) { fprintf ((fd),"\ -RUs %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,\ -RF  %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,\ -RI  %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,\ -RS  %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,\ -RA  %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,\ -RUn %x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x,%x\n",\ -                         state->RegBank[0][0],state->RegBank[0][1],state->RegBank[0][2],state->RegBank[0][3], \ -                         state->RegBank[0][4],state->RegBank[0][5],state->RegBank[0][6],state->RegBank[0][7], \ -                         state->RegBank[0][8],state->RegBank[0][9],state->RegBank[0][10],state->RegBank[0][11], \ -                         state->RegBank[0][12],state->RegBank[0][13],state->RegBank[0][14],state->RegBank[0][15], \ -                         state->RegBank[1][0],state->RegBank[1][1],state->RegBank[1][2],state->RegBank[1][3], \ -                         state->RegBank[1][4],state->RegBank[1][5],state->RegBank[1][6],state->RegBank[1][7], \ -                         state->RegBank[1][8],state->RegBank[1][9],state->RegBank[1][10],state->RegBank[1][11], \ -                         state->RegBank[1][12],state->RegBank[1][13],state->RegBank[1][14],state->RegBank[1][15], \ -                         state->RegBank[2][0],state->RegBank[2][1],state->RegBank[2][2],state->RegBank[2][3], \ -                         state->RegBank[2][4],state->RegBank[2][5],state->RegBank[2][6],state->RegBank[2][7], \ -                         state->RegBank[2][8],state->RegBank[2][9],state->RegBank[2][10],state->RegBank[2][11], \ -                         state->RegBank[2][12],state->RegBank[2][13],state->RegBank[2][14],state->RegBank[2][15], \ -                         state->RegBank[3][0],state->RegBank[3][1],state->RegBank[3][2],state->RegBank[3][3], \ -                         state->RegBank[3][4],state->RegBank[3][5],state->RegBank[3][6],state->RegBank[3][7], \ -                         state->RegBank[3][8],state->RegBank[3][9],state->RegBank[3][10],state->RegBank[3][11], \ -                         state->RegBank[3][12],state->RegBank[3][13],state->RegBank[3][14],state->RegBank[3][15], \ -                         state->RegBank[4][0],state->RegBank[4][1],state->RegBank[4][2],state->RegBank[4][3], \ -                         state->RegBank[4][4],state->RegBank[4][5],state->RegBank[4][6],state->RegBank[4][7], \ -                         state->RegBank[4][8],state->RegBank[4][9],state->RegBank[4][10],state->RegBank[4][11], \ -                         state->RegBank[4][12],state->RegBank[4][13],state->RegBank[4][14],state->RegBank[4][15], \ -                         state->RegBank[5][0],state->RegBank[5][1],state->RegBank[5][2],state->RegBank[5][3], \ -                         state->RegBank[5][4],state->RegBank[5][5],state->RegBank[5][6],state->RegBank[5][7], \ -                         state->RegBank[5][8],state->RegBank[5][9],state->RegBank[5][10],state->RegBank[5][11], \ -                         state->RegBank[5][12],state->RegBank[5][13],state->RegBank[5][14],state->RegBank[5][15] \ -        );} -  extern bool AddOverflow(ARMword, ARMword, ARMword);  extern bool SubOverflow(ARMword, ARMword, ARMword);  extern void ARMul_UndefInstr(ARMul_State*, ARMword);  extern void ARMul_FixCPSR(ARMul_State*, ARMword, ARMword);  extern void ARMul_FixSPSR(ARMul_State*, ARMword, ARMword); -extern void ARMul_ConsolePrint(ARMul_State*, const char*, ...);  extern void ARMul_SelectProcessor(ARMul_State*, unsigned);  extern u32 AddWithCarry(u32, u32, u32, bool*, bool*); @@ -791,8 +596,3 @@ extern u16 ARMul_UnsignedSaturatedSub16(u16, u16);  extern u8 ARMul_UnsignedAbsoluteDifference(u8, u8);  extern u32 ARMul_SignedSatQ(s32, u8, bool*);  extern u32 ARMul_UnsignedSatQ(s32, u8, bool*); - -#define DIFF_LOG 0 -#define SAVE_LOG 0 - -#endif /* _ARMDEFS_H_ */ diff --git a/src/core/arm/skyeye_common/armemu.h b/src/core/arm/skyeye_common/armemu.h index 1dfcc635a..686b2a3f6 100644 --- a/src/core/arm/skyeye_common/armemu.h +++ b/src/core/arm/skyeye_common/armemu.h @@ -575,8 +575,6 @@ extern ARMword ARMul_GetPC (ARMul_State *);  extern ARMword ARMul_GetNextPC (ARMul_State *);  extern ARMword ARMul_GetR15 (ARMul_State *);  extern ARMword ARMul_GetCPSR (ARMul_State *); -extern void ARMul_EnvokeEvent (ARMul_State *); -extern unsigned int ARMul_Time (ARMul_State *);  extern void ARMul_NegZero (ARMul_State *, ARMword);  extern void ARMul_SetPC (ARMul_State *, ARMword);  extern void ARMul_SetR15 (ARMul_State *, ARMword); @@ -603,8 +601,7 @@ extern void ARMul_AddCarry (ARMul_State *, ARMword, ARMword, ARMword);  extern tdstate ARMul_ThumbDecode (ARMul_State *, ARMword, ARMword, ARMword *);  extern ARMword ARMul_GetReg (ARMul_State *, unsigned, unsigned);  extern void ARMul_SetReg (ARMul_State *, unsigned, unsigned, ARMword); -extern void ARMul_ScheduleEvent (ARMul_State *, unsigned int, -				 unsigned (*)(ARMul_State *)); +  /* Coprocessor support functions.  */  extern unsigned ARMul_CoProInit (ARMul_State *);  extern void ARMul_CoProExit (ARMul_State *); diff --git a/src/core/arm/skyeye_common/skyeye_defs.h b/src/core/arm/skyeye_common/skyeye_defs.h index d4088383f..6648e9d66 100644 --- a/src/core/arm/skyeye_common/skyeye_defs.h +++ b/src/core/arm/skyeye_common/skyeye_defs.h @@ -1,5 +1,4 @@ -#ifndef CORE_ARM_SKYEYE_DEFS_H_ -#define CORE_ARM_SKYEYE_DEFS_H_ +#pragma once  #include "common/common.h" @@ -8,21 +7,15 @@  typedef struct  { -	const char *cpu_arch_name;	/*cpu architecture version name.e.g. armv4t */ -	const char *cpu_name;	/*cpu name. e.g. arm7tdmi or arm720t */ -	u32 cpu_val;	/*CPU value; also call MMU ID or processor id;see -				   ARM Architecture Reference Manual B2-6 */ -	u32 cpu_mask;	/*cpu_val's mask. */ -	u32 cachetype;	/*this cpu has what kind of cache */ +	const char *cpu_arch_name; /* CPU architecture version name.e.g. armv4t */ +	const char *cpu_name;      /* CPU name. e.g. arm7tdmi or arm720t */ +	u32 cpu_val;               /*CPU value; also call MMU ID or processor id;see +	                             ARM Architecture Reference Manual B2-6 */ +	u32 cpu_mask;              /* cpu_val's mask. */ +	u32 cachetype;             /* this CPU has what kind of cache */  } cpu_config_t; -typedef struct conf_object_s{ -	char* objname; -	void* obj; -	char* class_name; -}conf_object_t; - -typedef enum{ +typedef enum {  	/* No exception */  	No_exp = 0,  	/* Memory allocation exception */ @@ -44,70 +37,21 @@ typedef enum{  	/* Unknown exception */  	Unknown_exp -}exception_t; +} exception_t;  typedef enum {  	Align = 0,  	UnAlign	 -}align_t; +} align_t;  typedef enum {  	Little_endian = 0,  	Big_endian -}endian_t; -//typedef int exception_t; +} endian_t; -typedef enum{ +typedef enum {  	Phys_addr = 0,  	Virt_addr -}addr_type_t; - -typedef exception_t(*read_byte_t)(conf_object_t* target, u32 addr, void *buf, size_t count); -typedef exception_t(*write_byte_t)(conf_object_t* target, u32 addr, const void *buf, size_t count); - -typedef struct memory_space{ -	conf_object_t* conf_obj; -	read_byte_t read; -	write_byte_t write; -}memory_space_intf; - - -/* - * a running instance for a specific archteciture. - */ -typedef struct generic_arch_s -{ -	char* arch_name; -	void (*init) (void); -	void (*reset) (void); -	void (*step_once) (void); -	void (*set_pc)(u32 addr); -	u32 (*get_pc)(void); -	u32 (*get_step)(void); -	//chy 2004-04-15  -	//int (*ICE_write_byte) (u32 addr, uint8_t v); -	//int (*ICE_read_byte)(u32 addr, uint8_t *pv); -	u32 (*get_regval_by_id)(int id); -	u32 (*get_regnum)(void); -	char* (*get_regname_by_id)(int id); -	exception_t (*set_regval_by_id)(int id, u32 value); -	/* -	 * read a data by virtual address. -	 */ -	exception_t (*mmu_read)(short size, u32 addr, u32 * value); -	/* -	 * write a data by a virtual address. -	 */ -	exception_t (*mmu_write)(short size, u32 addr, u32 value); -	/** -	 * get a signal from external -	 */ -	//exception_t (*signal)(interrupt_signal_t* signal); - -	endian_t endianess; -	align_t alignment; -} generic_arch_t; +} addr_type_t;  typedef u32 addr_t; - -#endif | 
