diff options
-rw-r--r-- | sim/common/ChangeLog | 8 | ||||
-rw-r--r-- | sim/common/sim-gx.c | 44 |
2 files changed, 48 insertions, 4 deletions
diff --git a/sim/common/ChangeLog b/sim/common/ChangeLog index eb82a7b..c2cf5b4 100644 --- a/sim/common/ChangeLog +++ b/sim/common/ChangeLog @@ -1,3 +1,11 @@ +start-sanitize-gxsim +1998-11-21 Frank Ch. Eigler <fche@elastic.org> + + * sim-gx.c (sim_gx_block_translate): Generate computed + goto for __GNUC__ instead of plain switch() for gx block + entry. Lose "-g" compile option for gx block. + +end-sanitize-gxsim 1998-11-18 Doug Evans <devans@casey.cygnus.com> * Make-common.in (cgen-utils.o): Depend on cgen-engine.h. diff --git a/sim/common/sim-gx.c b/sim/common/sim-gx.c index d8d3487..c2966fe 100644 --- a/sim/common/sim-gx.c +++ b/sim/common/sim-gx.c @@ -7,7 +7,6 @@ #include "sim-gx.h" #include "config.h" -/* #include "cconfig.h" */ /* shared object functions */ #ifdef HAVE_DLFCN_H @@ -576,6 +575,29 @@ sim_gx_block_translate(sim_gx_block* gx, int optimized) if(! optimized) fprintf(block->source_file, " unsigned int insn_count = 0;\n"); + /* emit threaded goto vector for __GNUC__ */ + fprintf(block->source_file, "#ifdef __GNUC__\n"); + fprintf(block->source_file, " static void* jump_table[] =\n"); + fprintf(block->source_file, " {\n"); + gx_cia = gx->origin; + while(GX_PC_INCLUDES(gx,gx_cia)) + { + sim_cia next_gx_cia; + if((! optimized) || + (GX_PC_FLAGS(gx, gx_cia) & GX_PCF_JUMPTARGET)) + { + fprintf(block->source_file, " && gx_label_%ld,\n", + ((gx_cia - gx->origin) / gx->divisor)); + } + else + { + fprintf(block->source_file, " && gx_label_default,\n"); + } + gx_cia = gx_cia + gx->divisor; + } + fprintf(block->source_file, " };\n"); + fprintf(block->source_file, "#endif /*__GNUC__*/\n"); + /* pre-block gunk: register load */ tgx_emit_load_block(gx, optimized); @@ -605,13 +627,22 @@ sim_gx_block_translate(sim_gx_block* gx, int optimized) /* emit PC switch, use compressed case numbers */ fprintf(block->source_file, "\n"); + fprintf(block->source_file, "#ifdef __GNUC__\n"); + fprintf(block->source_file, " goto * jump_table[((pc - 0x%08x) / %u)];\n", + (unsigned)gx->origin, gx->divisor); + fprintf(block->source_file, "#else /* ! __GNUC__*/\n"); fprintf(block->source_file, " switch((pc - 0x%08x) / %u)\n", (unsigned)gx->origin, gx->divisor); + fprintf(block->source_file, "#endif /*__GNUC__*/\n"); fprintf(block->source_file, " {\n"); /* handle bad-PC event */ fprintf(block->source_file, " /* handle unknown jump target */\n"); + fprintf(block->source_file, "#ifdef __GNUC__\n"); + fprintf(block->source_file, " gx_label_default:\n"); + fprintf(block->source_file, "#else /* ! __GNUC__*/\n"); fprintf(block->source_file, " default:\n"); + fprintf(block->source_file, "#endif /*__GNUC__*/\n"); fprintf(block->source_file, " rc = %d;\n", GX_F_NONPC); fprintf(block->source_file, " npc = pc;\n"); fprintf(block->source_file, " goto save;\n"); @@ -653,8 +684,13 @@ sim_gx_block_translate(sim_gx_block* gx, int optimized) if((! optimized) || (GX_PC_FLAGS(gx, gx_cia) & GX_PCF_JUMPTARGET)) { + fprintf(block->source_file, "#ifdef __GNUC__\n"); + fprintf(block->source_file, " gx_label_%ld:\n", + ((gx_cia - gx->origin) / gx->divisor)); + fprintf(block->source_file, "#else /* ! __GNUC__*/\n"); fprintf(block->source_file, " case %ld:\n", ((gx_cia - gx->origin) / gx->divisor)); + fprintf(block->source_file, "#endif /*__GNUC__*/\n"); } /* translate breakpoint check & exit */ @@ -732,8 +768,8 @@ sim_gx_block_translate(sim_gx_block* gx, int optimized) /* compile source & produce shared object */ sprintf(compile_command, - "gxtool --silent --mode=compile gcc -c -g %s %s", - (optimized ? "-O3" : "-O"), block->source_name); + "gxtool --silent --mode=compile gcc -c %s %s", + (optimized ? "-O9 -fomit-frame-pointer" : "-O"), block->source_name); rc = system(compile_command); if(rc != 0) @@ -745,7 +781,7 @@ sim_gx_block_translate(sim_gx_block* gx, int optimized) /* link source */ sprintf(compile_command, - "gxtool --silent --mode=link gcc -export-dynamic -rpath %s -g -o lib%s.la %s.lo", + "gxtool --silent --mode=link gcc -export-dynamic -rpath %s -o lib%s.la %s.lo", dir_name, base_name, base_name); rc = system(compile_command); |