diff --git a/sim/ppc/ChangeLog b/sim/ppc/ChangeLog index 6f124d72a8..78b371b268 100644 --- a/sim/ppc/ChangeLog +++ b/sim/ppc/ChangeLog @@ -1,3 +1,16 @@ +2004-08-04 Andrew Cagney + Jim Blandy + + * sim_callbacks.h (simulator): Declare. + * Makefile.in (gdb-sim.o): New rule. + (MAIN_SRC, GDB_OBJ): Add gdb-sim.o, gdb-sim.c. + (DEFS_H): Delete. + (GDB_SIM_PPC_H): Define. + * gdb-sim.c: New file. + * sim_calls.c: Do not include "defs.h". + (simulator): Drop static. + (sim_store_register, sim_fetch_register): Delete. + 2004-08-04 Andrew Cagney * Back out accidently committed change. diff --git a/sim/ppc/Makefile.in b/sim/ppc/Makefile.in index 5e00a43c3a..efef1340f2 100644 --- a/sim/ppc/Makefile.in +++ b/sim/ppc/Makefile.in @@ -172,9 +172,9 @@ all: run $(TARGETLIB) $(GDB_OBJ) # Headers outside sim/ppc. ANSIDECL_H = $(srcroot)/include/ansidecl.h BFD_H = ../../bfd/bfd.h -DEFS_H = $(srcroot)/gdb/defs.h GDB_CALLBACK_H = $(srcroot)/include/gdb/callback.h GDB_REMOTE_SIM_H = $(srcroot)/include/gdb/remote-sim.h +GDB_SIM_PPC_H = $(srcroot)/include/gdb/sim-ppc.h COMMON_SIM_BASE_H = $(srcroot)/sim/common/sim-base.h COMMON_SIM_BASICS_H = $(srcroot)/sim/common/sim-basics.h COMMON_SIM_FPU_H = $(srcroot)/sim/common/sim-fpu.h @@ -498,6 +498,7 @@ LIB_SRC = \ MAIN_SRC = \ main.c \ + gdb-sim.c \ sim_calls.c @@ -539,7 +540,7 @@ LIB_OBJ = \ options.o -GDB_OBJ = sim_calls.o @sim_callback@ +GDB_OBJ = gdb-sim.o sim_calls.o @sim_callback@ HW_SRC = @sim_hw_src@ HW_OBJ = @sim_hw_obj@ @@ -599,6 +600,8 @@ events.o: events.c $(BASICS_H) $(EVENTS_H) sim_calls.o: sim_calls.c $(PSIM_H) $(OPTIONS_H) $(DEFS_H) $(BFD_H) $(GDB_CALLBACK_H) $(GDB_REMOTE_SIM_H) +gdb-sim.o: gdb-sim.c $(PSIM_H) $(OPTIONS_H) $(REGISTERS_H) $(GDB_REMOTE_SIM_H) $(GDB_SIM_PPC_H) $(SIM_CALLBACK_H) + spreg.o: spreg.c $(BASICS_H) $(SPREG_H) main.o: main.c $(PSIM_H) $(OPTIONS_H) $(DEVICE_H) $(EVENTS_H) $(BFD_H) $(GDB_CALLBACK_H) $(GDB_REMOTE_SIM_H) diff --git a/sim/ppc/gdb-sim.c b/sim/ppc/gdb-sim.c new file mode 100644 index 0000000000..648d8ef128 --- /dev/null +++ b/sim/ppc/gdb-sim.c @@ -0,0 +1,1295 @@ +/* This file is part of GDB. + + Copyright 2004 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + + */ + + +#include "psim.h" +#include "options.h" +#include "registers.h" + +#include "ansidecl.h" +#include "sim_callbacks.h" +#include "gdb/callback.h" +#include "gdb/remote-sim.h" +#include "gdb/sim-ppc.h" + +/* Return the name of the register whose number is REGNUM, or zero if + REGNUM is an invalid register number. */ + +static const char * +regnum2spr (int spr) +{ + if (spr_is_valid (spr)) + return spr_name (spr); + else + return NULL; +} + +static const char * +regnum2name (int regnum) +{ + switch (regnum) + { + case sim_ppc_r0_regnum: return "r0"; + case sim_ppc_r1_regnum: return "r1"; + case sim_ppc_r2_regnum: return "r2"; + case sim_ppc_r3_regnum: return "r3"; + case sim_ppc_r4_regnum: return "r4"; + case sim_ppc_r5_regnum: return "r5"; + case sim_ppc_r6_regnum: return "r6"; + case sim_ppc_r7_regnum: return "r7"; + case sim_ppc_r8_regnum: return "r8"; + case sim_ppc_r9_regnum: return "r9"; + case sim_ppc_r10_regnum: return "r10"; + case sim_ppc_r11_regnum: return "r11"; + case sim_ppc_r12_regnum: return "r12"; + case sim_ppc_r13_regnum: return "r13"; + case sim_ppc_r14_regnum: return "r14"; + case sim_ppc_r15_regnum: return "r15"; + case sim_ppc_r16_regnum: return "r16"; + case sim_ppc_r17_regnum: return "r17"; + case sim_ppc_r18_regnum: return "r18"; + case sim_ppc_r19_regnum: return "r19"; + case sim_ppc_r20_regnum: return "r20"; + case sim_ppc_r21_regnum: return "r21"; + case sim_ppc_r22_regnum: return "r22"; + case sim_ppc_r23_regnum: return "r23"; + case sim_ppc_r24_regnum: return "r24"; + case sim_ppc_r25_regnum: return "r25"; + case sim_ppc_r26_regnum: return "r26"; + case sim_ppc_r27_regnum: return "r27"; + case sim_ppc_r28_regnum: return "r28"; + case sim_ppc_r29_regnum: return "r29"; + case sim_ppc_r30_regnum: return "r30"; + case sim_ppc_r31_regnum: return "r31"; + + case sim_ppc_f0_regnum: return "f0"; + case sim_ppc_f1_regnum: return "f1"; + case sim_ppc_f2_regnum: return "f2"; + case sim_ppc_f3_regnum: return "f3"; + case sim_ppc_f4_regnum: return "f4"; + case sim_ppc_f5_regnum: return "f5"; + case sim_ppc_f6_regnum: return "f6"; + case sim_ppc_f7_regnum: return "f7"; + case sim_ppc_f8_regnum: return "f8"; + case sim_ppc_f9_regnum: return "f9"; + case sim_ppc_f10_regnum: return "f10"; + case sim_ppc_f11_regnum: return "f11"; + case sim_ppc_f12_regnum: return "f12"; + case sim_ppc_f13_regnum: return "f13"; + case sim_ppc_f14_regnum: return "f14"; + case sim_ppc_f15_regnum: return "f15"; + case sim_ppc_f16_regnum: return "f16"; + case sim_ppc_f17_regnum: return "f17"; + case sim_ppc_f18_regnum: return "f18"; + case sim_ppc_f19_regnum: return "f19"; + case sim_ppc_f20_regnum: return "f20"; + case sim_ppc_f21_regnum: return "f21"; + case sim_ppc_f22_regnum: return "f22"; + case sim_ppc_f23_regnum: return "f23"; + case sim_ppc_f24_regnum: return "f24"; + case sim_ppc_f25_regnum: return "f25"; + case sim_ppc_f26_regnum: return "f26"; + case sim_ppc_f27_regnum: return "f27"; + case sim_ppc_f28_regnum: return "f28"; + case sim_ppc_f29_regnum: return "f29"; + case sim_ppc_f30_regnum: return "f30"; + case sim_ppc_f31_regnum: return "f31"; + + case sim_ppc_vr0_regnum: return "vr0"; + case sim_ppc_vr1_regnum: return "vr1"; + case sim_ppc_vr2_regnum: return "vr2"; + case sim_ppc_vr3_regnum: return "vr3"; + case sim_ppc_vr4_regnum: return "vr4"; + case sim_ppc_vr5_regnum: return "vr5"; + case sim_ppc_vr6_regnum: return "vr6"; + case sim_ppc_vr7_regnum: return "vr7"; + case sim_ppc_vr8_regnum: return "vr8"; + case sim_ppc_vr9_regnum: return "vr9"; + case sim_ppc_vr10_regnum: return "vr10"; + case sim_ppc_vr11_regnum: return "vr11"; + case sim_ppc_vr12_regnum: return "vr12"; + case sim_ppc_vr13_regnum: return "vr13"; + case sim_ppc_vr14_regnum: return "vr14"; + case sim_ppc_vr15_regnum: return "vr15"; + case sim_ppc_vr16_regnum: return "vr16"; + case sim_ppc_vr17_regnum: return "vr17"; + case sim_ppc_vr18_regnum: return "vr18"; + case sim_ppc_vr19_regnum: return "vr19"; + case sim_ppc_vr20_regnum: return "vr20"; + case sim_ppc_vr21_regnum: return "vr21"; + case sim_ppc_vr22_regnum: return "vr22"; + case sim_ppc_vr23_regnum: return "vr23"; + case sim_ppc_vr24_regnum: return "vr24"; + case sim_ppc_vr25_regnum: return "vr25"; + case sim_ppc_vr26_regnum: return "vr26"; + case sim_ppc_vr27_regnum: return "vr27"; + case sim_ppc_vr28_regnum: return "vr28"; + case sim_ppc_vr29_regnum: return "vr29"; + case sim_ppc_vr30_regnum: return "vr30"; + case sim_ppc_vr31_regnum: return "vr31"; + case sim_ppc_rh0_regnum: return "rh0"; + case sim_ppc_rh1_regnum: return "rh1"; + case sim_ppc_rh2_regnum: return "rh2"; + case sim_ppc_rh3_regnum: return "rh3"; + case sim_ppc_rh4_regnum: return "rh4"; + case sim_ppc_rh5_regnum: return "rh5"; + case sim_ppc_rh6_regnum: return "rh6"; + case sim_ppc_rh7_regnum: return "rh7"; + case sim_ppc_rh8_regnum: return "rh8"; + case sim_ppc_rh9_regnum: return "rh9"; + case sim_ppc_rh10_regnum: return "rh10"; + case sim_ppc_rh11_regnum: return "rh11"; + case sim_ppc_rh12_regnum: return "rh12"; + case sim_ppc_rh13_regnum: return "rh13"; + case sim_ppc_rh14_regnum: return "rh14"; + case sim_ppc_rh15_regnum: return "rh15"; + case sim_ppc_rh16_regnum: return "rh16"; + case sim_ppc_rh17_regnum: return "rh17"; + case sim_ppc_rh18_regnum: return "rh18"; + case sim_ppc_rh19_regnum: return "rh19"; + case sim_ppc_rh20_regnum: return "rh20"; + case sim_ppc_rh21_regnum: return "rh21"; + case sim_ppc_rh22_regnum: return "rh22"; + case sim_ppc_rh23_regnum: return "rh23"; + case sim_ppc_rh24_regnum: return "rh24"; + case sim_ppc_rh25_regnum: return "rh25"; + case sim_ppc_rh26_regnum: return "rh26"; + case sim_ppc_rh27_regnum: return "rh27"; + case sim_ppc_rh28_regnum: return "rh28"; + case sim_ppc_rh29_regnum: return "rh29"; + case sim_ppc_rh30_regnum: return "rh30"; + case sim_ppc_rh31_regnum: return "rh31"; + + case sim_ppc_ev0_regnum: return "ev0"; + case sim_ppc_ev1_regnum: return "ev1"; + case sim_ppc_ev2_regnum: return "ev2"; + case sim_ppc_ev3_regnum: return "ev3"; + case sim_ppc_ev4_regnum: return "ev4"; + case sim_ppc_ev5_regnum: return "ev5"; + case sim_ppc_ev6_regnum: return "ev6"; + case sim_ppc_ev7_regnum: return "ev7"; + case sim_ppc_ev8_regnum: return "ev8"; + case sim_ppc_ev9_regnum: return "ev9"; + case sim_ppc_ev10_regnum: return "ev10"; + case sim_ppc_ev11_regnum: return "ev11"; + case sim_ppc_ev12_regnum: return "ev12"; + case sim_ppc_ev13_regnum: return "ev13"; + case sim_ppc_ev14_regnum: return "ev14"; + case sim_ppc_ev15_regnum: return "ev15"; + case sim_ppc_ev16_regnum: return "ev16"; + case sim_ppc_ev17_regnum: return "ev17"; + case sim_ppc_ev18_regnum: return "ev18"; + case sim_ppc_ev19_regnum: return "ev19"; + case sim_ppc_ev20_regnum: return "ev20"; + case sim_ppc_ev21_regnum: return "ev21"; + case sim_ppc_ev22_regnum: return "ev22"; + case sim_ppc_ev23_regnum: return "ev23"; + case sim_ppc_ev24_regnum: return "ev24"; + case sim_ppc_ev25_regnum: return "ev25"; + case sim_ppc_ev26_regnum: return "ev26"; + case sim_ppc_ev27_regnum: return "ev27"; + case sim_ppc_ev28_regnum: return "ev28"; + case sim_ppc_ev29_regnum: return "ev29"; + case sim_ppc_ev30_regnum: return "ev30"; + case sim_ppc_ev31_regnum: return "ev31"; + + case sim_ppc_sr0_regnum: return "sr0"; + case sim_ppc_sr1_regnum: return "sr1"; + case sim_ppc_sr2_regnum: return "sr2"; + case sim_ppc_sr3_regnum: return "sr3"; + case sim_ppc_sr4_regnum: return "sr4"; + case sim_ppc_sr5_regnum: return "sr5"; + case sim_ppc_sr6_regnum: return "sr6"; + case sim_ppc_sr7_regnum: return "sr7"; + case sim_ppc_sr8_regnum: return "sr8"; + case sim_ppc_sr9_regnum: return "sr9"; + case sim_ppc_sr10_regnum: return "sr10"; + case sim_ppc_sr11_regnum: return "sr11"; + case sim_ppc_sr12_regnum: return "sr12"; + case sim_ppc_sr13_regnum: return "sr13"; + case sim_ppc_sr14_regnum: return "sr14"; + case sim_ppc_sr15_regnum: return "sr15"; + + case sim_ppc_pc_regnum: return "pc"; + case sim_ppc_ps_regnum: return "ps"; + case sim_ppc_cr_regnum: return "cr"; + case sim_ppc_fpscr_regnum: return "fpscr"; + case sim_ppc_acc_regnum: return "acc"; + case sim_ppc_vscr_regnum: return "vscr"; + + case sim_ppc_spr0_regnum: return regnum2spr (0); + case sim_ppc_spr1_regnum: return regnum2spr (1); + case sim_ppc_spr2_regnum: return regnum2spr (2); + case sim_ppc_spr3_regnum: return regnum2spr (3); + case sim_ppc_spr4_regnum: return regnum2spr (4); + case sim_ppc_spr5_regnum: return regnum2spr (5); + case sim_ppc_spr6_regnum: return regnum2spr (6); + case sim_ppc_spr7_regnum: return regnum2spr (7); + case sim_ppc_spr8_regnum: return regnum2spr (8); + case sim_ppc_spr9_regnum: return regnum2spr (9); + case sim_ppc_spr10_regnum: return regnum2spr (10); + case sim_ppc_spr11_regnum: return regnum2spr (11); + case sim_ppc_spr12_regnum: return regnum2spr (12); + case sim_ppc_spr13_regnum: return regnum2spr (13); + case sim_ppc_spr14_regnum: return regnum2spr (14); + case sim_ppc_spr15_regnum: return regnum2spr (15); + case sim_ppc_spr16_regnum: return regnum2spr (16); + case sim_ppc_spr17_regnum: return regnum2spr (17); + case sim_ppc_spr18_regnum: return regnum2spr (18); + case sim_ppc_spr19_regnum: return regnum2spr (19); + case sim_ppc_spr20_regnum: return regnum2spr (20); + case sim_ppc_spr21_regnum: return regnum2spr (21); + case sim_ppc_spr22_regnum: return regnum2spr (22); + case sim_ppc_spr23_regnum: return regnum2spr (23); + case sim_ppc_spr24_regnum: return regnum2spr (24); + case sim_ppc_spr25_regnum: return regnum2spr (25); + case sim_ppc_spr26_regnum: return regnum2spr (26); + case sim_ppc_spr27_regnum: return regnum2spr (27); + case sim_ppc_spr28_regnum: return regnum2spr (28); + case sim_ppc_spr29_regnum: return regnum2spr (29); + case sim_ppc_spr30_regnum: return regnum2spr (30); + case sim_ppc_spr31_regnum: return regnum2spr (31); + case sim_ppc_spr32_regnum: return regnum2spr (32); + case sim_ppc_spr33_regnum: return regnum2spr (33); + case sim_ppc_spr34_regnum: return regnum2spr (34); + case sim_ppc_spr35_regnum: return regnum2spr (35); + case sim_ppc_spr36_regnum: return regnum2spr (36); + case sim_ppc_spr37_regnum: return regnum2spr (37); + case sim_ppc_spr38_regnum: return regnum2spr (38); + case sim_ppc_spr39_regnum: return regnum2spr (39); + case sim_ppc_spr40_regnum: return regnum2spr (40); + case sim_ppc_spr41_regnum: return regnum2spr (41); + case sim_ppc_spr42_regnum: return regnum2spr (42); + case sim_ppc_spr43_regnum: return regnum2spr (43); + case sim_ppc_spr44_regnum: return regnum2spr (44); + case sim_ppc_spr45_regnum: return regnum2spr (45); + case sim_ppc_spr46_regnum: return regnum2spr (46); + case sim_ppc_spr47_regnum: return regnum2spr (47); + case sim_ppc_spr48_regnum: return regnum2spr (48); + case sim_ppc_spr49_regnum: return regnum2spr (49); + case sim_ppc_spr50_regnum: return regnum2spr (50); + case sim_ppc_spr51_regnum: return regnum2spr (51); + case sim_ppc_spr52_regnum: return regnum2spr (52); + case sim_ppc_spr53_regnum: return regnum2spr (53); + case sim_ppc_spr54_regnum: return regnum2spr (54); + case sim_ppc_spr55_regnum: return regnum2spr (55); + case sim_ppc_spr56_regnum: return regnum2spr (56); + case sim_ppc_spr57_regnum: return regnum2spr (57); + case sim_ppc_spr58_regnum: return regnum2spr (58); + case sim_ppc_spr59_regnum: return regnum2spr (59); + case sim_ppc_spr60_regnum: return regnum2spr (60); + case sim_ppc_spr61_regnum: return regnum2spr (61); + case sim_ppc_spr62_regnum: return regnum2spr (62); + case sim_ppc_spr63_regnum: return regnum2spr (63); + case sim_ppc_spr64_regnum: return regnum2spr (64); + case sim_ppc_spr65_regnum: return regnum2spr (65); + case sim_ppc_spr66_regnum: return regnum2spr (66); + case sim_ppc_spr67_regnum: return regnum2spr (67); + case sim_ppc_spr68_regnum: return regnum2spr (68); + case sim_ppc_spr69_regnum: return regnum2spr (69); + case sim_ppc_spr70_regnum: return regnum2spr (70); + case sim_ppc_spr71_regnum: return regnum2spr (71); + case sim_ppc_spr72_regnum: return regnum2spr (72); + case sim_ppc_spr73_regnum: return regnum2spr (73); + case sim_ppc_spr74_regnum: return regnum2spr (74); + case sim_ppc_spr75_regnum: return regnum2spr (75); + case sim_ppc_spr76_regnum: return regnum2spr (76); + case sim_ppc_spr77_regnum: return regnum2spr (77); + case sim_ppc_spr78_regnum: return regnum2spr (78); + case sim_ppc_spr79_regnum: return regnum2spr (79); + case sim_ppc_spr80_regnum: return regnum2spr (80); + case sim_ppc_spr81_regnum: return regnum2spr (81); + case sim_ppc_spr82_regnum: return regnum2spr (82); + case sim_ppc_spr83_regnum: return regnum2spr (83); + case sim_ppc_spr84_regnum: return regnum2spr (84); + case sim_ppc_spr85_regnum: return regnum2spr (85); + case sim_ppc_spr86_regnum: return regnum2spr (86); + case sim_ppc_spr87_regnum: return regnum2spr (87); + case sim_ppc_spr88_regnum: return regnum2spr (88); + case sim_ppc_spr89_regnum: return regnum2spr (89); + case sim_ppc_spr90_regnum: return regnum2spr (90); + case sim_ppc_spr91_regnum: return regnum2spr (91); + case sim_ppc_spr92_regnum: return regnum2spr (92); + case sim_ppc_spr93_regnum: return regnum2spr (93); + case sim_ppc_spr94_regnum: return regnum2spr (94); + case sim_ppc_spr95_regnum: return regnum2spr (95); + case sim_ppc_spr96_regnum: return regnum2spr (96); + case sim_ppc_spr97_regnum: return regnum2spr (97); + case sim_ppc_spr98_regnum: return regnum2spr (98); + case sim_ppc_spr99_regnum: return regnum2spr (99); + case sim_ppc_spr100_regnum: return regnum2spr (100); + case sim_ppc_spr101_regnum: return regnum2spr (101); + case sim_ppc_spr102_regnum: return regnum2spr (102); + case sim_ppc_spr103_regnum: return regnum2spr (103); + case sim_ppc_spr104_regnum: return regnum2spr (104); + case sim_ppc_spr105_regnum: return regnum2spr (105); + case sim_ppc_spr106_regnum: return regnum2spr (106); + case sim_ppc_spr107_regnum: return regnum2spr (107); + case sim_ppc_spr108_regnum: return regnum2spr (108); + case sim_ppc_spr109_regnum: return regnum2spr (109); + case sim_ppc_spr110_regnum: return regnum2spr (110); + case sim_ppc_spr111_regnum: return regnum2spr (111); + case sim_ppc_spr112_regnum: return regnum2spr (112); + case sim_ppc_spr113_regnum: return regnum2spr (113); + case sim_ppc_spr114_regnum: return regnum2spr (114); + case sim_ppc_spr115_regnum: return regnum2spr (115); + case sim_ppc_spr116_regnum: return regnum2spr (116); + case sim_ppc_spr117_regnum: return regnum2spr (117); + case sim_ppc_spr118_regnum: return regnum2spr (118); + case sim_ppc_spr119_regnum: return regnum2spr (119); + case sim_ppc_spr120_regnum: return regnum2spr (120); + case sim_ppc_spr121_regnum: return regnum2spr (121); + case sim_ppc_spr122_regnum: return regnum2spr (122); + case sim_ppc_spr123_regnum: return regnum2spr (123); + case sim_ppc_spr124_regnum: return regnum2spr (124); + case sim_ppc_spr125_regnum: return regnum2spr (125); + case sim_ppc_spr126_regnum: return regnum2spr (126); + case sim_ppc_spr127_regnum: return regnum2spr (127); + case sim_ppc_spr128_regnum: return regnum2spr (128); + case sim_ppc_spr129_regnum: return regnum2spr (129); + case sim_ppc_spr130_regnum: return regnum2spr (130); + case sim_ppc_spr131_regnum: return regnum2spr (131); + case sim_ppc_spr132_regnum: return regnum2spr (132); + case sim_ppc_spr133_regnum: return regnum2spr (133); + case sim_ppc_spr134_regnum: return regnum2spr (134); + case sim_ppc_spr135_regnum: return regnum2spr (135); + case sim_ppc_spr136_regnum: return regnum2spr (136); + case sim_ppc_spr137_regnum: return regnum2spr (137); + case sim_ppc_spr138_regnum: return regnum2spr (138); + case sim_ppc_spr139_regnum: return regnum2spr (139); + case sim_ppc_spr140_regnum: return regnum2spr (140); + case sim_ppc_spr141_regnum: return regnum2spr (141); + case sim_ppc_spr142_regnum: return regnum2spr (142); + case sim_ppc_spr143_regnum: return regnum2spr (143); + case sim_ppc_spr144_regnum: return regnum2spr (144); + case sim_ppc_spr145_regnum: return regnum2spr (145); + case sim_ppc_spr146_regnum: return regnum2spr (146); + case sim_ppc_spr147_regnum: return regnum2spr (147); + case sim_ppc_spr148_regnum: return regnum2spr (148); + case sim_ppc_spr149_regnum: return regnum2spr (149); + case sim_ppc_spr150_regnum: return regnum2spr (150); + case sim_ppc_spr151_regnum: return regnum2spr (151); + case sim_ppc_spr152_regnum: return regnum2spr (152); + case sim_ppc_spr153_regnum: return regnum2spr (153); + case sim_ppc_spr154_regnum: return regnum2spr (154); + case sim_ppc_spr155_regnum: return regnum2spr (155); + case sim_ppc_spr156_regnum: return regnum2spr (156); + case sim_ppc_spr157_regnum: return regnum2spr (157); + case sim_ppc_spr158_regnum: return regnum2spr (158); + case sim_ppc_spr159_regnum: return regnum2spr (159); + case sim_ppc_spr160_regnum: return regnum2spr (160); + case sim_ppc_spr161_regnum: return regnum2spr (161); + case sim_ppc_spr162_regnum: return regnum2spr (162); + case sim_ppc_spr163_regnum: return regnum2spr (163); + case sim_ppc_spr164_regnum: return regnum2spr (164); + case sim_ppc_spr165_regnum: return regnum2spr (165); + case sim_ppc_spr166_regnum: return regnum2spr (166); + case sim_ppc_spr167_regnum: return regnum2spr (167); + case sim_ppc_spr168_regnum: return regnum2spr (168); + case sim_ppc_spr169_regnum: return regnum2spr (169); + case sim_ppc_spr170_regnum: return regnum2spr (170); + case sim_ppc_spr171_regnum: return regnum2spr (171); + case sim_ppc_spr172_regnum: return regnum2spr (172); + case sim_ppc_spr173_regnum: return regnum2spr (173); + case sim_ppc_spr174_regnum: return regnum2spr (174); + case sim_ppc_spr175_regnum: return regnum2spr (175); + case sim_ppc_spr176_regnum: return regnum2spr (176); + case sim_ppc_spr177_regnum: return regnum2spr (177); + case sim_ppc_spr178_regnum: return regnum2spr (178); + case sim_ppc_spr179_regnum: return regnum2spr (179); + case sim_ppc_spr180_regnum: return regnum2spr (180); + case sim_ppc_spr181_regnum: return regnum2spr (181); + case sim_ppc_spr182_regnum: return regnum2spr (182); + case sim_ppc_spr183_regnum: return regnum2spr (183); + case sim_ppc_spr184_regnum: return regnum2spr (184); + case sim_ppc_spr185_regnum: return regnum2spr (185); + case sim_ppc_spr186_regnum: return regnum2spr (186); + case sim_ppc_spr187_regnum: return regnum2spr (187); + case sim_ppc_spr188_regnum: return regnum2spr (188); + case sim_ppc_spr189_regnum: return regnum2spr (189); + case sim_ppc_spr190_regnum: return regnum2spr (190); + case sim_ppc_spr191_regnum: return regnum2spr (191); + case sim_ppc_spr192_regnum: return regnum2spr (192); + case sim_ppc_spr193_regnum: return regnum2spr (193); + case sim_ppc_spr194_regnum: return regnum2spr (194); + case sim_ppc_spr195_regnum: return regnum2spr (195); + case sim_ppc_spr196_regnum: return regnum2spr (196); + case sim_ppc_spr197_regnum: return regnum2spr (197); + case sim_ppc_spr198_regnum: return regnum2spr (198); + case sim_ppc_spr199_regnum: return regnum2spr (199); + case sim_ppc_spr200_regnum: return regnum2spr (200); + case sim_ppc_spr201_regnum: return regnum2spr (201); + case sim_ppc_spr202_regnum: return regnum2spr (202); + case sim_ppc_spr203_regnum: return regnum2spr (203); + case sim_ppc_spr204_regnum: return regnum2spr (204); + case sim_ppc_spr205_regnum: return regnum2spr (205); + case sim_ppc_spr206_regnum: return regnum2spr (206); + case sim_ppc_spr207_regnum: return regnum2spr (207); + case sim_ppc_spr208_regnum: return regnum2spr (208); + case sim_ppc_spr209_regnum: return regnum2spr (209); + case sim_ppc_spr210_regnum: return regnum2spr (210); + case sim_ppc_spr211_regnum: return regnum2spr (211); + case sim_ppc_spr212_regnum: return regnum2spr (212); + case sim_ppc_spr213_regnum: return regnum2spr (213); + case sim_ppc_spr214_regnum: return regnum2spr (214); + case sim_ppc_spr215_regnum: return regnum2spr (215); + case sim_ppc_spr216_regnum: return regnum2spr (216); + case sim_ppc_spr217_regnum: return regnum2spr (217); + case sim_ppc_spr218_regnum: return regnum2spr (218); + case sim_ppc_spr219_regnum: return regnum2spr (219); + case sim_ppc_spr220_regnum: return regnum2spr (220); + case sim_ppc_spr221_regnum: return regnum2spr (221); + case sim_ppc_spr222_regnum: return regnum2spr (222); + case sim_ppc_spr223_regnum: return regnum2spr (223); + case sim_ppc_spr224_regnum: return regnum2spr (224); + case sim_ppc_spr225_regnum: return regnum2spr (225); + case sim_ppc_spr226_regnum: return regnum2spr (226); + case sim_ppc_spr227_regnum: return regnum2spr (227); + case sim_ppc_spr228_regnum: return regnum2spr (228); + case sim_ppc_spr229_regnum: return regnum2spr (229); + case sim_ppc_spr230_regnum: return regnum2spr (230); + case sim_ppc_spr231_regnum: return regnum2spr (231); + case sim_ppc_spr232_regnum: return regnum2spr (232); + case sim_ppc_spr233_regnum: return regnum2spr (233); + case sim_ppc_spr234_regnum: return regnum2spr (234); + case sim_ppc_spr235_regnum: return regnum2spr (235); + case sim_ppc_spr236_regnum: return regnum2spr (236); + case sim_ppc_spr237_regnum: return regnum2spr (237); + case sim_ppc_spr238_regnum: return regnum2spr (238); + case sim_ppc_spr239_regnum: return regnum2spr (239); + case sim_ppc_spr240_regnum: return regnum2spr (240); + case sim_ppc_spr241_regnum: return regnum2spr (241); + case sim_ppc_spr242_regnum: return regnum2spr (242); + case sim_ppc_spr243_regnum: return regnum2spr (243); + case sim_ppc_spr244_regnum: return regnum2spr (244); + case sim_ppc_spr245_regnum: return regnum2spr (245); + case sim_ppc_spr246_regnum: return regnum2spr (246); + case sim_ppc_spr247_regnum: return regnum2spr (247); + case sim_ppc_spr248_regnum: return regnum2spr (248); + case sim_ppc_spr249_regnum: return regnum2spr (249); + case sim_ppc_spr250_regnum: return regnum2spr (250); + case sim_ppc_spr251_regnum: return regnum2spr (251); + case sim_ppc_spr252_regnum: return regnum2spr (252); + case sim_ppc_spr253_regnum: return regnum2spr (253); + case sim_ppc_spr254_regnum: return regnum2spr (254); + case sim_ppc_spr255_regnum: return regnum2spr (255); + case sim_ppc_spr256_regnum: return regnum2spr (256); + case sim_ppc_spr257_regnum: return regnum2spr (257); + case sim_ppc_spr258_regnum: return regnum2spr (258); + case sim_ppc_spr259_regnum: return regnum2spr (259); + case sim_ppc_spr260_regnum: return regnum2spr (260); + case sim_ppc_spr261_regnum: return regnum2spr (261); + case sim_ppc_spr262_regnum: return regnum2spr (262); + case sim_ppc_spr263_regnum: return regnum2spr (263); + case sim_ppc_spr264_regnum: return regnum2spr (264); + case sim_ppc_spr265_regnum: return regnum2spr (265); + case sim_ppc_spr266_regnum: return regnum2spr (266); + case sim_ppc_spr267_regnum: return regnum2spr (267); + case sim_ppc_spr268_regnum: return regnum2spr (268); + case sim_ppc_spr269_regnum: return regnum2spr (269); + case sim_ppc_spr270_regnum: return regnum2spr (270); + case sim_ppc_spr271_regnum: return regnum2spr (271); + case sim_ppc_spr272_regnum: return regnum2spr (272); + case sim_ppc_spr273_regnum: return regnum2spr (273); + case sim_ppc_spr274_regnum: return regnum2spr (274); + case sim_ppc_spr275_regnum: return regnum2spr (275); + case sim_ppc_spr276_regnum: return regnum2spr (276); + case sim_ppc_spr277_regnum: return regnum2spr (277); + case sim_ppc_spr278_regnum: return regnum2spr (278); + case sim_ppc_spr279_regnum: return regnum2spr (279); + case sim_ppc_spr280_regnum: return regnum2spr (280); + case sim_ppc_spr281_regnum: return regnum2spr (281); + case sim_ppc_spr282_regnum: return regnum2spr (282); + case sim_ppc_spr283_regnum: return regnum2spr (283); + case sim_ppc_spr284_regnum: return regnum2spr (284); + case sim_ppc_spr285_regnum: return regnum2spr (285); + case sim_ppc_spr286_regnum: return regnum2spr (286); + case sim_ppc_spr287_regnum: return regnum2spr (287); + case sim_ppc_spr288_regnum: return regnum2spr (288); + case sim_ppc_spr289_regnum: return regnum2spr (289); + case sim_ppc_spr290_regnum: return regnum2spr (290); + case sim_ppc_spr291_regnum: return regnum2spr (291); + case sim_ppc_spr292_regnum: return regnum2spr (292); + case sim_ppc_spr293_regnum: return regnum2spr (293); + case sim_ppc_spr294_regnum: return regnum2spr (294); + case sim_ppc_spr295_regnum: return regnum2spr (295); + case sim_ppc_spr296_regnum: return regnum2spr (296); + case sim_ppc_spr297_regnum: return regnum2spr (297); + case sim_ppc_spr298_regnum: return regnum2spr (298); + case sim_ppc_spr299_regnum: return regnum2spr (299); + case sim_ppc_spr300_regnum: return regnum2spr (300); + case sim_ppc_spr301_regnum: return regnum2spr (301); + case sim_ppc_spr302_regnum: return regnum2spr (302); + case sim_ppc_spr303_regnum: return regnum2spr (303); + case sim_ppc_spr304_regnum: return regnum2spr (304); + case sim_ppc_spr305_regnum: return regnum2spr (305); + case sim_ppc_spr306_regnum: return regnum2spr (306); + case sim_ppc_spr307_regnum: return regnum2spr (307); + case sim_ppc_spr308_regnum: return regnum2spr (308); + case sim_ppc_spr309_regnum: return regnum2spr (309); + case sim_ppc_spr310_regnum: return regnum2spr (310); + case sim_ppc_spr311_regnum: return regnum2spr (311); + case sim_ppc_spr312_regnum: return regnum2spr (312); + case sim_ppc_spr313_regnum: return regnum2spr (313); + case sim_ppc_spr314_regnum: return regnum2spr (314); + case sim_ppc_spr315_regnum: return regnum2spr (315); + case sim_ppc_spr316_regnum: return regnum2spr (316); + case sim_ppc_spr317_regnum: return regnum2spr (317); + case sim_ppc_spr318_regnum: return regnum2spr (318); + case sim_ppc_spr319_regnum: return regnum2spr (319); + case sim_ppc_spr320_regnum: return regnum2spr (320); + case sim_ppc_spr321_regnum: return regnum2spr (321); + case sim_ppc_spr322_regnum: return regnum2spr (322); + case sim_ppc_spr323_regnum: return regnum2spr (323); + case sim_ppc_spr324_regnum: return regnum2spr (324); + case sim_ppc_spr325_regnum: return regnum2spr (325); + case sim_ppc_spr326_regnum: return regnum2spr (326); + case sim_ppc_spr327_regnum: return regnum2spr (327); + case sim_ppc_spr328_regnum: return regnum2spr (328); + case sim_ppc_spr329_regnum: return regnum2spr (329); + case sim_ppc_spr330_regnum: return regnum2spr (330); + case sim_ppc_spr331_regnum: return regnum2spr (331); + case sim_ppc_spr332_regnum: return regnum2spr (332); + case sim_ppc_spr333_regnum: return regnum2spr (333); + case sim_ppc_spr334_regnum: return regnum2spr (334); + case sim_ppc_spr335_regnum: return regnum2spr (335); + case sim_ppc_spr336_regnum: return regnum2spr (336); + case sim_ppc_spr337_regnum: return regnum2spr (337); + case sim_ppc_spr338_regnum: return regnum2spr (338); + case sim_ppc_spr339_regnum: return regnum2spr (339); + case sim_ppc_spr340_regnum: return regnum2spr (340); + case sim_ppc_spr341_regnum: return regnum2spr (341); + case sim_ppc_spr342_regnum: return regnum2spr (342); + case sim_ppc_spr343_regnum: return regnum2spr (343); + case sim_ppc_spr344_regnum: return regnum2spr (344); + case sim_ppc_spr345_regnum: return regnum2spr (345); + case sim_ppc_spr346_regnum: return regnum2spr (346); + case sim_ppc_spr347_regnum: return regnum2spr (347); + case sim_ppc_spr348_regnum: return regnum2spr (348); + case sim_ppc_spr349_regnum: return regnum2spr (349); + case sim_ppc_spr350_regnum: return regnum2spr (350); + case sim_ppc_spr351_regnum: return regnum2spr (351); + case sim_ppc_spr352_regnum: return regnum2spr (352); + case sim_ppc_spr353_regnum: return regnum2spr (353); + case sim_ppc_spr354_regnum: return regnum2spr (354); + case sim_ppc_spr355_regnum: return regnum2spr (355); + case sim_ppc_spr356_regnum: return regnum2spr (356); + case sim_ppc_spr357_regnum: return regnum2spr (357); + case sim_ppc_spr358_regnum: return regnum2spr (358); + case sim_ppc_spr359_regnum: return regnum2spr (359); + case sim_ppc_spr360_regnum: return regnum2spr (360); + case sim_ppc_spr361_regnum: return regnum2spr (361); + case sim_ppc_spr362_regnum: return regnum2spr (362); + case sim_ppc_spr363_regnum: return regnum2spr (363); + case sim_ppc_spr364_regnum: return regnum2spr (364); + case sim_ppc_spr365_regnum: return regnum2spr (365); + case sim_ppc_spr366_regnum: return regnum2spr (366); + case sim_ppc_spr367_regnum: return regnum2spr (367); + case sim_ppc_spr368_regnum: return regnum2spr (368); + case sim_ppc_spr369_regnum: return regnum2spr (369); + case sim_ppc_spr370_regnum: return regnum2spr (370); + case sim_ppc_spr371_regnum: return regnum2spr (371); + case sim_ppc_spr372_regnum: return regnum2spr (372); + case sim_ppc_spr373_regnum: return regnum2spr (373); + case sim_ppc_spr374_regnum: return regnum2spr (374); + case sim_ppc_spr375_regnum: return regnum2spr (375); + case sim_ppc_spr376_regnum: return regnum2spr (376); + case sim_ppc_spr377_regnum: return regnum2spr (377); + case sim_ppc_spr378_regnum: return regnum2spr (378); + case sim_ppc_spr379_regnum: return regnum2spr (379); + case sim_ppc_spr380_regnum: return regnum2spr (380); + case sim_ppc_spr381_regnum: return regnum2spr (381); + case sim_ppc_spr382_regnum: return regnum2spr (382); + case sim_ppc_spr383_regnum: return regnum2spr (383); + case sim_ppc_spr384_regnum: return regnum2spr (384); + case sim_ppc_spr385_regnum: return regnum2spr (385); + case sim_ppc_spr386_regnum: return regnum2spr (386); + case sim_ppc_spr387_regnum: return regnum2spr (387); + case sim_ppc_spr388_regnum: return regnum2spr (388); + case sim_ppc_spr389_regnum: return regnum2spr (389); + case sim_ppc_spr390_regnum: return regnum2spr (390); + case sim_ppc_spr391_regnum: return regnum2spr (391); + case sim_ppc_spr392_regnum: return regnum2spr (392); + case sim_ppc_spr393_regnum: return regnum2spr (393); + case sim_ppc_spr394_regnum: return regnum2spr (394); + case sim_ppc_spr395_regnum: return regnum2spr (395); + case sim_ppc_spr396_regnum: return regnum2spr (396); + case sim_ppc_spr397_regnum: return regnum2spr (397); + case sim_ppc_spr398_regnum: return regnum2spr (398); + case sim_ppc_spr399_regnum: return regnum2spr (399); + case sim_ppc_spr400_regnum: return regnum2spr (400); + case sim_ppc_spr401_regnum: return regnum2spr (401); + case sim_ppc_spr402_regnum: return regnum2spr (402); + case sim_ppc_spr403_regnum: return regnum2spr (403); + case sim_ppc_spr404_regnum: return regnum2spr (404); + case sim_ppc_spr405_regnum: return regnum2spr (405); + case sim_ppc_spr406_regnum: return regnum2spr (406); + case sim_ppc_spr407_regnum: return regnum2spr (407); + case sim_ppc_spr408_regnum: return regnum2spr (408); + case sim_ppc_spr409_regnum: return regnum2spr (409); + case sim_ppc_spr410_regnum: return regnum2spr (410); + case sim_ppc_spr411_regnum: return regnum2spr (411); + case sim_ppc_spr412_regnum: return regnum2spr (412); + case sim_ppc_spr413_regnum: return regnum2spr (413); + case sim_ppc_spr414_regnum: return regnum2spr (414); + case sim_ppc_spr415_regnum: return regnum2spr (415); + case sim_ppc_spr416_regnum: return regnum2spr (416); + case sim_ppc_spr417_regnum: return regnum2spr (417); + case sim_ppc_spr418_regnum: return regnum2spr (418); + case sim_ppc_spr419_regnum: return regnum2spr (419); + case sim_ppc_spr420_regnum: return regnum2spr (420); + case sim_ppc_spr421_regnum: return regnum2spr (421); + case sim_ppc_spr422_regnum: return regnum2spr (422); + case sim_ppc_spr423_regnum: return regnum2spr (423); + case sim_ppc_spr424_regnum: return regnum2spr (424); + case sim_ppc_spr425_regnum: return regnum2spr (425); + case sim_ppc_spr426_regnum: return regnum2spr (426); + case sim_ppc_spr427_regnum: return regnum2spr (427); + case sim_ppc_spr428_regnum: return regnum2spr (428); + case sim_ppc_spr429_regnum: return regnum2spr (429); + case sim_ppc_spr430_regnum: return regnum2spr (430); + case sim_ppc_spr431_regnum: return regnum2spr (431); + case sim_ppc_spr432_regnum: return regnum2spr (432); + case sim_ppc_spr433_regnum: return regnum2spr (433); + case sim_ppc_spr434_regnum: return regnum2spr (434); + case sim_ppc_spr435_regnum: return regnum2spr (435); + case sim_ppc_spr436_regnum: return regnum2spr (436); + case sim_ppc_spr437_regnum: return regnum2spr (437); + case sim_ppc_spr438_regnum: return regnum2spr (438); + case sim_ppc_spr439_regnum: return regnum2spr (439); + case sim_ppc_spr440_regnum: return regnum2spr (440); + case sim_ppc_spr441_regnum: return regnum2spr (441); + case sim_ppc_spr442_regnum: return regnum2spr (442); + case sim_ppc_spr443_regnum: return regnum2spr (443); + case sim_ppc_spr444_regnum: return regnum2spr (444); + case sim_ppc_spr445_regnum: return regnum2spr (445); + case sim_ppc_spr446_regnum: return regnum2spr (446); + case sim_ppc_spr447_regnum: return regnum2spr (447); + case sim_ppc_spr448_regnum: return regnum2spr (448); + case sim_ppc_spr449_regnum: return regnum2spr (449); + case sim_ppc_spr450_regnum: return regnum2spr (450); + case sim_ppc_spr451_regnum: return regnum2spr (451); + case sim_ppc_spr452_regnum: return regnum2spr (452); + case sim_ppc_spr453_regnum: return regnum2spr (453); + case sim_ppc_spr454_regnum: return regnum2spr (454); + case sim_ppc_spr455_regnum: return regnum2spr (455); + case sim_ppc_spr456_regnum: return regnum2spr (456); + case sim_ppc_spr457_regnum: return regnum2spr (457); + case sim_ppc_spr458_regnum: return regnum2spr (458); + case sim_ppc_spr459_regnum: return regnum2spr (459); + case sim_ppc_spr460_regnum: return regnum2spr (460); + case sim_ppc_spr461_regnum: return regnum2spr (461); + case sim_ppc_spr462_regnum: return regnum2spr (462); + case sim_ppc_spr463_regnum: return regnum2spr (463); + case sim_ppc_spr464_regnum: return regnum2spr (464); + case sim_ppc_spr465_regnum: return regnum2spr (465); + case sim_ppc_spr466_regnum: return regnum2spr (466); + case sim_ppc_spr467_regnum: return regnum2spr (467); + case sim_ppc_spr468_regnum: return regnum2spr (468); + case sim_ppc_spr469_regnum: return regnum2spr (469); + case sim_ppc_spr470_regnum: return regnum2spr (470); + case sim_ppc_spr471_regnum: return regnum2spr (471); + case sim_ppc_spr472_regnum: return regnum2spr (472); + case sim_ppc_spr473_regnum: return regnum2spr (473); + case sim_ppc_spr474_regnum: return regnum2spr (474); + case sim_ppc_spr475_regnum: return regnum2spr (475); + case sim_ppc_spr476_regnum: return regnum2spr (476); + case sim_ppc_spr477_regnum: return regnum2spr (477); + case sim_ppc_spr478_regnum: return regnum2spr (478); + case sim_ppc_spr479_regnum: return regnum2spr (479); + case sim_ppc_spr480_regnum: return regnum2spr (480); + case sim_ppc_spr481_regnum: return regnum2spr (481); + case sim_ppc_spr482_regnum: return regnum2spr (482); + case sim_ppc_spr483_regnum: return regnum2spr (483); + case sim_ppc_spr484_regnum: return regnum2spr (484); + case sim_ppc_spr485_regnum: return regnum2spr (485); + case sim_ppc_spr486_regnum: return regnum2spr (486); + case sim_ppc_spr487_regnum: return regnum2spr (487); + case sim_ppc_spr488_regnum: return regnum2spr (488); + case sim_ppc_spr489_regnum: return regnum2spr (489); + case sim_ppc_spr490_regnum: return regnum2spr (490); + case sim_ppc_spr491_regnum: return regnum2spr (491); + case sim_ppc_spr492_regnum: return regnum2spr (492); + case sim_ppc_spr493_regnum: return regnum2spr (493); + case sim_ppc_spr494_regnum: return regnum2spr (494); + case sim_ppc_spr495_regnum: return regnum2spr (495); + case sim_ppc_spr496_regnum: return regnum2spr (496); + case sim_ppc_spr497_regnum: return regnum2spr (497); + case sim_ppc_spr498_regnum: return regnum2spr (498); + case sim_ppc_spr499_regnum: return regnum2spr (499); + case sim_ppc_spr500_regnum: return regnum2spr (500); + case sim_ppc_spr501_regnum: return regnum2spr (501); + case sim_ppc_spr502_regnum: return regnum2spr (502); + case sim_ppc_spr503_regnum: return regnum2spr (503); + case sim_ppc_spr504_regnum: return regnum2spr (504); + case sim_ppc_spr505_regnum: return regnum2spr (505); + case sim_ppc_spr506_regnum: return regnum2spr (506); + case sim_ppc_spr507_regnum: return regnum2spr (507); + case sim_ppc_spr508_regnum: return regnum2spr (508); + case sim_ppc_spr509_regnum: return regnum2spr (509); + case sim_ppc_spr510_regnum: return regnum2spr (510); + case sim_ppc_spr511_regnum: return regnum2spr (511); + case sim_ppc_spr512_regnum: return regnum2spr (512); + case sim_ppc_spr513_regnum: return regnum2spr (513); + case sim_ppc_spr514_regnum: return regnum2spr (514); + case sim_ppc_spr515_regnum: return regnum2spr (515); + case sim_ppc_spr516_regnum: return regnum2spr (516); + case sim_ppc_spr517_regnum: return regnum2spr (517); + case sim_ppc_spr518_regnum: return regnum2spr (518); + case sim_ppc_spr519_regnum: return regnum2spr (519); + case sim_ppc_spr520_regnum: return regnum2spr (520); + case sim_ppc_spr521_regnum: return regnum2spr (521); + case sim_ppc_spr522_regnum: return regnum2spr (522); + case sim_ppc_spr523_regnum: return regnum2spr (523); + case sim_ppc_spr524_regnum: return regnum2spr (524); + case sim_ppc_spr525_regnum: return regnum2spr (525); + case sim_ppc_spr526_regnum: return regnum2spr (526); + case sim_ppc_spr527_regnum: return regnum2spr (527); + case sim_ppc_spr528_regnum: return regnum2spr (528); + case sim_ppc_spr529_regnum: return regnum2spr (529); + case sim_ppc_spr530_regnum: return regnum2spr (530); + case sim_ppc_spr531_regnum: return regnum2spr (531); + case sim_ppc_spr532_regnum: return regnum2spr (532); + case sim_ppc_spr533_regnum: return regnum2spr (533); + case sim_ppc_spr534_regnum: return regnum2spr (534); + case sim_ppc_spr535_regnum: return regnum2spr (535); + case sim_ppc_spr536_regnum: return regnum2spr (536); + case sim_ppc_spr537_regnum: return regnum2spr (537); + case sim_ppc_spr538_regnum: return regnum2spr (538); + case sim_ppc_spr539_regnum: return regnum2spr (539); + case sim_ppc_spr540_regnum: return regnum2spr (540); + case sim_ppc_spr541_regnum: return regnum2spr (541); + case sim_ppc_spr542_regnum: return regnum2spr (542); + case sim_ppc_spr543_regnum: return regnum2spr (543); + case sim_ppc_spr544_regnum: return regnum2spr (544); + case sim_ppc_spr545_regnum: return regnum2spr (545); + case sim_ppc_spr546_regnum: return regnum2spr (546); + case sim_ppc_spr547_regnum: return regnum2spr (547); + case sim_ppc_spr548_regnum: return regnum2spr (548); + case sim_ppc_spr549_regnum: return regnum2spr (549); + case sim_ppc_spr550_regnum: return regnum2spr (550); + case sim_ppc_spr551_regnum: return regnum2spr (551); + case sim_ppc_spr552_regnum: return regnum2spr (552); + case sim_ppc_spr553_regnum: return regnum2spr (553); + case sim_ppc_spr554_regnum: return regnum2spr (554); + case sim_ppc_spr555_regnum: return regnum2spr (555); + case sim_ppc_spr556_regnum: return regnum2spr (556); + case sim_ppc_spr557_regnum: return regnum2spr (557); + case sim_ppc_spr558_regnum: return regnum2spr (558); + case sim_ppc_spr559_regnum: return regnum2spr (559); + case sim_ppc_spr560_regnum: return regnum2spr (560); + case sim_ppc_spr561_regnum: return regnum2spr (561); + case sim_ppc_spr562_regnum: return regnum2spr (562); + case sim_ppc_spr563_regnum: return regnum2spr (563); + case sim_ppc_spr564_regnum: return regnum2spr (564); + case sim_ppc_spr565_regnum: return regnum2spr (565); + case sim_ppc_spr566_regnum: return regnum2spr (566); + case sim_ppc_spr567_regnum: return regnum2spr (567); + case sim_ppc_spr568_regnum: return regnum2spr (568); + case sim_ppc_spr569_regnum: return regnum2spr (569); + case sim_ppc_spr570_regnum: return regnum2spr (570); + case sim_ppc_spr571_regnum: return regnum2spr (571); + case sim_ppc_spr572_regnum: return regnum2spr (572); + case sim_ppc_spr573_regnum: return regnum2spr (573); + case sim_ppc_spr574_regnum: return regnum2spr (574); + case sim_ppc_spr575_regnum: return regnum2spr (575); + case sim_ppc_spr576_regnum: return regnum2spr (576); + case sim_ppc_spr577_regnum: return regnum2spr (577); + case sim_ppc_spr578_regnum: return regnum2spr (578); + case sim_ppc_spr579_regnum: return regnum2spr (579); + case sim_ppc_spr580_regnum: return regnum2spr (580); + case sim_ppc_spr581_regnum: return regnum2spr (581); + case sim_ppc_spr582_regnum: return regnum2spr (582); + case sim_ppc_spr583_regnum: return regnum2spr (583); + case sim_ppc_spr584_regnum: return regnum2spr (584); + case sim_ppc_spr585_regnum: return regnum2spr (585); + case sim_ppc_spr586_regnum: return regnum2spr (586); + case sim_ppc_spr587_regnum: return regnum2spr (587); + case sim_ppc_spr588_regnum: return regnum2spr (588); + case sim_ppc_spr589_regnum: return regnum2spr (589); + case sim_ppc_spr590_regnum: return regnum2spr (590); + case sim_ppc_spr591_regnum: return regnum2spr (591); + case sim_ppc_spr592_regnum: return regnum2spr (592); + case sim_ppc_spr593_regnum: return regnum2spr (593); + case sim_ppc_spr594_regnum: return regnum2spr (594); + case sim_ppc_spr595_regnum: return regnum2spr (595); + case sim_ppc_spr596_regnum: return regnum2spr (596); + case sim_ppc_spr597_regnum: return regnum2spr (597); + case sim_ppc_spr598_regnum: return regnum2spr (598); + case sim_ppc_spr599_regnum: return regnum2spr (599); + case sim_ppc_spr600_regnum: return regnum2spr (600); + case sim_ppc_spr601_regnum: return regnum2spr (601); + case sim_ppc_spr602_regnum: return regnum2spr (602); + case sim_ppc_spr603_regnum: return regnum2spr (603); + case sim_ppc_spr604_regnum: return regnum2spr (604); + case sim_ppc_spr605_regnum: return regnum2spr (605); + case sim_ppc_spr606_regnum: return regnum2spr (606); + case sim_ppc_spr607_regnum: return regnum2spr (607); + case sim_ppc_spr608_regnum: return regnum2spr (608); + case sim_ppc_spr609_regnum: return regnum2spr (609); + case sim_ppc_spr610_regnum: return regnum2spr (610); + case sim_ppc_spr611_regnum: return regnum2spr (611); + case sim_ppc_spr612_regnum: return regnum2spr (612); + case sim_ppc_spr613_regnum: return regnum2spr (613); + case sim_ppc_spr614_regnum: return regnum2spr (614); + case sim_ppc_spr615_regnum: return regnum2spr (615); + case sim_ppc_spr616_regnum: return regnum2spr (616); + case sim_ppc_spr617_regnum: return regnum2spr (617); + case sim_ppc_spr618_regnum: return regnum2spr (618); + case sim_ppc_spr619_regnum: return regnum2spr (619); + case sim_ppc_spr620_regnum: return regnum2spr (620); + case sim_ppc_spr621_regnum: return regnum2spr (621); + case sim_ppc_spr622_regnum: return regnum2spr (622); + case sim_ppc_spr623_regnum: return regnum2spr (623); + case sim_ppc_spr624_regnum: return regnum2spr (624); + case sim_ppc_spr625_regnum: return regnum2spr (625); + case sim_ppc_spr626_regnum: return regnum2spr (626); + case sim_ppc_spr627_regnum: return regnum2spr (627); + case sim_ppc_spr628_regnum: return regnum2spr (628); + case sim_ppc_spr629_regnum: return regnum2spr (629); + case sim_ppc_spr630_regnum: return regnum2spr (630); + case sim_ppc_spr631_regnum: return regnum2spr (631); + case sim_ppc_spr632_regnum: return regnum2spr (632); + case sim_ppc_spr633_regnum: return regnum2spr (633); + case sim_ppc_spr634_regnum: return regnum2spr (634); + case sim_ppc_spr635_regnum: return regnum2spr (635); + case sim_ppc_spr636_regnum: return regnum2spr (636); + case sim_ppc_spr637_regnum: return regnum2spr (637); + case sim_ppc_spr638_regnum: return regnum2spr (638); + case sim_ppc_spr639_regnum: return regnum2spr (639); + case sim_ppc_spr640_regnum: return regnum2spr (640); + case sim_ppc_spr641_regnum: return regnum2spr (641); + case sim_ppc_spr642_regnum: return regnum2spr (642); + case sim_ppc_spr643_regnum: return regnum2spr (643); + case sim_ppc_spr644_regnum: return regnum2spr (644); + case sim_ppc_spr645_regnum: return regnum2spr (645); + case sim_ppc_spr646_regnum: return regnum2spr (646); + case sim_ppc_spr647_regnum: return regnum2spr (647); + case sim_ppc_spr648_regnum: return regnum2spr (648); + case sim_ppc_spr649_regnum: return regnum2spr (649); + case sim_ppc_spr650_regnum: return regnum2spr (650); + case sim_ppc_spr651_regnum: return regnum2spr (651); + case sim_ppc_spr652_regnum: return regnum2spr (652); + case sim_ppc_spr653_regnum: return regnum2spr (653); + case sim_ppc_spr654_regnum: return regnum2spr (654); + case sim_ppc_spr655_regnum: return regnum2spr (655); + case sim_ppc_spr656_regnum: return regnum2spr (656); + case sim_ppc_spr657_regnum: return regnum2spr (657); + case sim_ppc_spr658_regnum: return regnum2spr (658); + case sim_ppc_spr659_regnum: return regnum2spr (659); + case sim_ppc_spr660_regnum: return regnum2spr (660); + case sim_ppc_spr661_regnum: return regnum2spr (661); + case sim_ppc_spr662_regnum: return regnum2spr (662); + case sim_ppc_spr663_regnum: return regnum2spr (663); + case sim_ppc_spr664_regnum: return regnum2spr (664); + case sim_ppc_spr665_regnum: return regnum2spr (665); + case sim_ppc_spr666_regnum: return regnum2spr (666); + case sim_ppc_spr667_regnum: return regnum2spr (667); + case sim_ppc_spr668_regnum: return regnum2spr (668); + case sim_ppc_spr669_regnum: return regnum2spr (669); + case sim_ppc_spr670_regnum: return regnum2spr (670); + case sim_ppc_spr671_regnum: return regnum2spr (671); + case sim_ppc_spr672_regnum: return regnum2spr (672); + case sim_ppc_spr673_regnum: return regnum2spr (673); + case sim_ppc_spr674_regnum: return regnum2spr (674); + case sim_ppc_spr675_regnum: return regnum2spr (675); + case sim_ppc_spr676_regnum: return regnum2spr (676); + case sim_ppc_spr677_regnum: return regnum2spr (677); + case sim_ppc_spr678_regnum: return regnum2spr (678); + case sim_ppc_spr679_regnum: return regnum2spr (679); + case sim_ppc_spr680_regnum: return regnum2spr (680); + case sim_ppc_spr681_regnum: return regnum2spr (681); + case sim_ppc_spr682_regnum: return regnum2spr (682); + case sim_ppc_spr683_regnum: return regnum2spr (683); + case sim_ppc_spr684_regnum: return regnum2spr (684); + case sim_ppc_spr685_regnum: return regnum2spr (685); + case sim_ppc_spr686_regnum: return regnum2spr (686); + case sim_ppc_spr687_regnum: return regnum2spr (687); + case sim_ppc_spr688_regnum: return regnum2spr (688); + case sim_ppc_spr689_regnum: return regnum2spr (689); + case sim_ppc_spr690_regnum: return regnum2spr (690); + case sim_ppc_spr691_regnum: return regnum2spr (691); + case sim_ppc_spr692_regnum: return regnum2spr (692); + case sim_ppc_spr693_regnum: return regnum2spr (693); + case sim_ppc_spr694_regnum: return regnum2spr (694); + case sim_ppc_spr695_regnum: return regnum2spr (695); + case sim_ppc_spr696_regnum: return regnum2spr (696); + case sim_ppc_spr697_regnum: return regnum2spr (697); + case sim_ppc_spr698_regnum: return regnum2spr (698); + case sim_ppc_spr699_regnum: return regnum2spr (699); + case sim_ppc_spr700_regnum: return regnum2spr (700); + case sim_ppc_spr701_regnum: return regnum2spr (701); + case sim_ppc_spr702_regnum: return regnum2spr (702); + case sim_ppc_spr703_regnum: return regnum2spr (703); + case sim_ppc_spr704_regnum: return regnum2spr (704); + case sim_ppc_spr705_regnum: return regnum2spr (705); + case sim_ppc_spr706_regnum: return regnum2spr (706); + case sim_ppc_spr707_regnum: return regnum2spr (707); + case sim_ppc_spr708_regnum: return regnum2spr (708); + case sim_ppc_spr709_regnum: return regnum2spr (709); + case sim_ppc_spr710_regnum: return regnum2spr (710); + case sim_ppc_spr711_regnum: return regnum2spr (711); + case sim_ppc_spr712_regnum: return regnum2spr (712); + case sim_ppc_spr713_regnum: return regnum2spr (713); + case sim_ppc_spr714_regnum: return regnum2spr (714); + case sim_ppc_spr715_regnum: return regnum2spr (715); + case sim_ppc_spr716_regnum: return regnum2spr (716); + case sim_ppc_spr717_regnum: return regnum2spr (717); + case sim_ppc_spr718_regnum: return regnum2spr (718); + case sim_ppc_spr719_regnum: return regnum2spr (719); + case sim_ppc_spr720_regnum: return regnum2spr (720); + case sim_ppc_spr721_regnum: return regnum2spr (721); + case sim_ppc_spr722_regnum: return regnum2spr (722); + case sim_ppc_spr723_regnum: return regnum2spr (723); + case sim_ppc_spr724_regnum: return regnum2spr (724); + case sim_ppc_spr725_regnum: return regnum2spr (725); + case sim_ppc_spr726_regnum: return regnum2spr (726); + case sim_ppc_spr727_regnum: return regnum2spr (727); + case sim_ppc_spr728_regnum: return regnum2spr (728); + case sim_ppc_spr729_regnum: return regnum2spr (729); + case sim_ppc_spr730_regnum: return regnum2spr (730); + case sim_ppc_spr731_regnum: return regnum2spr (731); + case sim_ppc_spr732_regnum: return regnum2spr (732); + case sim_ppc_spr733_regnum: return regnum2spr (733); + case sim_ppc_spr734_regnum: return regnum2spr (734); + case sim_ppc_spr735_regnum: return regnum2spr (735); + case sim_ppc_spr736_regnum: return regnum2spr (736); + case sim_ppc_spr737_regnum: return regnum2spr (737); + case sim_ppc_spr738_regnum: return regnum2spr (738); + case sim_ppc_spr739_regnum: return regnum2spr (739); + case sim_ppc_spr740_regnum: return regnum2spr (740); + case sim_ppc_spr741_regnum: return regnum2spr (741); + case sim_ppc_spr742_regnum: return regnum2spr (742); + case sim_ppc_spr743_regnum: return regnum2spr (743); + case sim_ppc_spr744_regnum: return regnum2spr (744); + case sim_ppc_spr745_regnum: return regnum2spr (745); + case sim_ppc_spr746_regnum: return regnum2spr (746); + case sim_ppc_spr747_regnum: return regnum2spr (747); + case sim_ppc_spr748_regnum: return regnum2spr (748); + case sim_ppc_spr749_regnum: return regnum2spr (749); + case sim_ppc_spr750_regnum: return regnum2spr (750); + case sim_ppc_spr751_regnum: return regnum2spr (751); + case sim_ppc_spr752_regnum: return regnum2spr (752); + case sim_ppc_spr753_regnum: return regnum2spr (753); + case sim_ppc_spr754_regnum: return regnum2spr (754); + case sim_ppc_spr755_regnum: return regnum2spr (755); + case sim_ppc_spr756_regnum: return regnum2spr (756); + case sim_ppc_spr757_regnum: return regnum2spr (757); + case sim_ppc_spr758_regnum: return regnum2spr (758); + case sim_ppc_spr759_regnum: return regnum2spr (759); + case sim_ppc_spr760_regnum: return regnum2spr (760); + case sim_ppc_spr761_regnum: return regnum2spr (761); + case sim_ppc_spr762_regnum: return regnum2spr (762); + case sim_ppc_spr763_regnum: return regnum2spr (763); + case sim_ppc_spr764_regnum: return regnum2spr (764); + case sim_ppc_spr765_regnum: return regnum2spr (765); + case sim_ppc_spr766_regnum: return regnum2spr (766); + case sim_ppc_spr767_regnum: return regnum2spr (767); + case sim_ppc_spr768_regnum: return regnum2spr (768); + case sim_ppc_spr769_regnum: return regnum2spr (769); + case sim_ppc_spr770_regnum: return regnum2spr (770); + case sim_ppc_spr771_regnum: return regnum2spr (771); + case sim_ppc_spr772_regnum: return regnum2spr (772); + case sim_ppc_spr773_regnum: return regnum2spr (773); + case sim_ppc_spr774_regnum: return regnum2spr (774); + case sim_ppc_spr775_regnum: return regnum2spr (775); + case sim_ppc_spr776_regnum: return regnum2spr (776); + case sim_ppc_spr777_regnum: return regnum2spr (777); + case sim_ppc_spr778_regnum: return regnum2spr (778); + case sim_ppc_spr779_regnum: return regnum2spr (779); + case sim_ppc_spr780_regnum: return regnum2spr (780); + case sim_ppc_spr781_regnum: return regnum2spr (781); + case sim_ppc_spr782_regnum: return regnum2spr (782); + case sim_ppc_spr783_regnum: return regnum2spr (783); + case sim_ppc_spr784_regnum: return regnum2spr (784); + case sim_ppc_spr785_regnum: return regnum2spr (785); + case sim_ppc_spr786_regnum: return regnum2spr (786); + case sim_ppc_spr787_regnum: return regnum2spr (787); + case sim_ppc_spr788_regnum: return regnum2spr (788); + case sim_ppc_spr789_regnum: return regnum2spr (789); + case sim_ppc_spr790_regnum: return regnum2spr (790); + case sim_ppc_spr791_regnum: return regnum2spr (791); + case sim_ppc_spr792_regnum: return regnum2spr (792); + case sim_ppc_spr793_regnum: return regnum2spr (793); + case sim_ppc_spr794_regnum: return regnum2spr (794); + case sim_ppc_spr795_regnum: return regnum2spr (795); + case sim_ppc_spr796_regnum: return regnum2spr (796); + case sim_ppc_spr797_regnum: return regnum2spr (797); + case sim_ppc_spr798_regnum: return regnum2spr (798); + case sim_ppc_spr799_regnum: return regnum2spr (799); + case sim_ppc_spr800_regnum: return regnum2spr (800); + case sim_ppc_spr801_regnum: return regnum2spr (801); + case sim_ppc_spr802_regnum: return regnum2spr (802); + case sim_ppc_spr803_regnum: return regnum2spr (803); + case sim_ppc_spr804_regnum: return regnum2spr (804); + case sim_ppc_spr805_regnum: return regnum2spr (805); + case sim_ppc_spr806_regnum: return regnum2spr (806); + case sim_ppc_spr807_regnum: return regnum2spr (807); + case sim_ppc_spr808_regnum: return regnum2spr (808); + case sim_ppc_spr809_regnum: return regnum2spr (809); + case sim_ppc_spr810_regnum: return regnum2spr (810); + case sim_ppc_spr811_regnum: return regnum2spr (811); + case sim_ppc_spr812_regnum: return regnum2spr (812); + case sim_ppc_spr813_regnum: return regnum2spr (813); + case sim_ppc_spr814_regnum: return regnum2spr (814); + case sim_ppc_spr815_regnum: return regnum2spr (815); + case sim_ppc_spr816_regnum: return regnum2spr (816); + case sim_ppc_spr817_regnum: return regnum2spr (817); + case sim_ppc_spr818_regnum: return regnum2spr (818); + case sim_ppc_spr819_regnum: return regnum2spr (819); + case sim_ppc_spr820_regnum: return regnum2spr (820); + case sim_ppc_spr821_regnum: return regnum2spr (821); + case sim_ppc_spr822_regnum: return regnum2spr (822); + case sim_ppc_spr823_regnum: return regnum2spr (823); + case sim_ppc_spr824_regnum: return regnum2spr (824); + case sim_ppc_spr825_regnum: return regnum2spr (825); + case sim_ppc_spr826_regnum: return regnum2spr (826); + case sim_ppc_spr827_regnum: return regnum2spr (827); + case sim_ppc_spr828_regnum: return regnum2spr (828); + case sim_ppc_spr829_regnum: return regnum2spr (829); + case sim_ppc_spr830_regnum: return regnum2spr (830); + case sim_ppc_spr831_regnum: return regnum2spr (831); + case sim_ppc_spr832_regnum: return regnum2spr (832); + case sim_ppc_spr833_regnum: return regnum2spr (833); + case sim_ppc_spr834_regnum: return regnum2spr (834); + case sim_ppc_spr835_regnum: return regnum2spr (835); + case sim_ppc_spr836_regnum: return regnum2spr (836); + case sim_ppc_spr837_regnum: return regnum2spr (837); + case sim_ppc_spr838_regnum: return regnum2spr (838); + case sim_ppc_spr839_regnum: return regnum2spr (839); + case sim_ppc_spr840_regnum: return regnum2spr (840); + case sim_ppc_spr841_regnum: return regnum2spr (841); + case sim_ppc_spr842_regnum: return regnum2spr (842); + case sim_ppc_spr843_regnum: return regnum2spr (843); + case sim_ppc_spr844_regnum: return regnum2spr (844); + case sim_ppc_spr845_regnum: return regnum2spr (845); + case sim_ppc_spr846_regnum: return regnum2spr (846); + case sim_ppc_spr847_regnum: return regnum2spr (847); + case sim_ppc_spr848_regnum: return regnum2spr (848); + case sim_ppc_spr849_regnum: return regnum2spr (849); + case sim_ppc_spr850_regnum: return regnum2spr (850); + case sim_ppc_spr851_regnum: return regnum2spr (851); + case sim_ppc_spr852_regnum: return regnum2spr (852); + case sim_ppc_spr853_regnum: return regnum2spr (853); + case sim_ppc_spr854_regnum: return regnum2spr (854); + case sim_ppc_spr855_regnum: return regnum2spr (855); + case sim_ppc_spr856_regnum: return regnum2spr (856); + case sim_ppc_spr857_regnum: return regnum2spr (857); + case sim_ppc_spr858_regnum: return regnum2spr (858); + case sim_ppc_spr859_regnum: return regnum2spr (859); + case sim_ppc_spr860_regnum: return regnum2spr (860); + case sim_ppc_spr861_regnum: return regnum2spr (861); + case sim_ppc_spr862_regnum: return regnum2spr (862); + case sim_ppc_spr863_regnum: return regnum2spr (863); + case sim_ppc_spr864_regnum: return regnum2spr (864); + case sim_ppc_spr865_regnum: return regnum2spr (865); + case sim_ppc_spr866_regnum: return regnum2spr (866); + case sim_ppc_spr867_regnum: return regnum2spr (867); + case sim_ppc_spr868_regnum: return regnum2spr (868); + case sim_ppc_spr869_regnum: return regnum2spr (869); + case sim_ppc_spr870_regnum: return regnum2spr (870); + case sim_ppc_spr871_regnum: return regnum2spr (871); + case sim_ppc_spr872_regnum: return regnum2spr (872); + case sim_ppc_spr873_regnum: return regnum2spr (873); + case sim_ppc_spr874_regnum: return regnum2spr (874); + case sim_ppc_spr875_regnum: return regnum2spr (875); + case sim_ppc_spr876_regnum: return regnum2spr (876); + case sim_ppc_spr877_regnum: return regnum2spr (877); + case sim_ppc_spr878_regnum: return regnum2spr (878); + case sim_ppc_spr879_regnum: return regnum2spr (879); + case sim_ppc_spr880_regnum: return regnum2spr (880); + case sim_ppc_spr881_regnum: return regnum2spr (881); + case sim_ppc_spr882_regnum: return regnum2spr (882); + case sim_ppc_spr883_regnum: return regnum2spr (883); + case sim_ppc_spr884_regnum: return regnum2spr (884); + case sim_ppc_spr885_regnum: return regnum2spr (885); + case sim_ppc_spr886_regnum: return regnum2spr (886); + case sim_ppc_spr887_regnum: return regnum2spr (887); + case sim_ppc_spr888_regnum: return regnum2spr (888); + case sim_ppc_spr889_regnum: return regnum2spr (889); + case sim_ppc_spr890_regnum: return regnum2spr (890); + case sim_ppc_spr891_regnum: return regnum2spr (891); + case sim_ppc_spr892_regnum: return regnum2spr (892); + case sim_ppc_spr893_regnum: return regnum2spr (893); + case sim_ppc_spr894_regnum: return regnum2spr (894); + case sim_ppc_spr895_regnum: return regnum2spr (895); + case sim_ppc_spr896_regnum: return regnum2spr (896); + case sim_ppc_spr897_regnum: return regnum2spr (897); + case sim_ppc_spr898_regnum: return regnum2spr (898); + case sim_ppc_spr899_regnum: return regnum2spr (899); + case sim_ppc_spr900_regnum: return regnum2spr (900); + case sim_ppc_spr901_regnum: return regnum2spr (901); + case sim_ppc_spr902_regnum: return regnum2spr (902); + case sim_ppc_spr903_regnum: return regnum2spr (903); + case sim_ppc_spr904_regnum: return regnum2spr (904); + case sim_ppc_spr905_regnum: return regnum2spr (905); + case sim_ppc_spr906_regnum: return regnum2spr (906); + case sim_ppc_spr907_regnum: return regnum2spr (907); + case sim_ppc_spr908_regnum: return regnum2spr (908); + case sim_ppc_spr909_regnum: return regnum2spr (909); + case sim_ppc_spr910_regnum: return regnum2spr (910); + case sim_ppc_spr911_regnum: return regnum2spr (911); + case sim_ppc_spr912_regnum: return regnum2spr (912); + case sim_ppc_spr913_regnum: return regnum2spr (913); + case sim_ppc_spr914_regnum: return regnum2spr (914); + case sim_ppc_spr915_regnum: return regnum2spr (915); + case sim_ppc_spr916_regnum: return regnum2spr (916); + case sim_ppc_spr917_regnum: return regnum2spr (917); + case sim_ppc_spr918_regnum: return regnum2spr (918); + case sim_ppc_spr919_regnum: return regnum2spr (919); + case sim_ppc_spr920_regnum: return regnum2spr (920); + case sim_ppc_spr921_regnum: return regnum2spr (921); + case sim_ppc_spr922_regnum: return regnum2spr (922); + case sim_ppc_spr923_regnum: return regnum2spr (923); + case sim_ppc_spr924_regnum: return regnum2spr (924); + case sim_ppc_spr925_regnum: return regnum2spr (925); + case sim_ppc_spr926_regnum: return regnum2spr (926); + case sim_ppc_spr927_regnum: return regnum2spr (927); + case sim_ppc_spr928_regnum: return regnum2spr (928); + case sim_ppc_spr929_regnum: return regnum2spr (929); + case sim_ppc_spr930_regnum: return regnum2spr (930); + case sim_ppc_spr931_regnum: return regnum2spr (931); + case sim_ppc_spr932_regnum: return regnum2spr (932); + case sim_ppc_spr933_regnum: return regnum2spr (933); + case sim_ppc_spr934_regnum: return regnum2spr (934); + case sim_ppc_spr935_regnum: return regnum2spr (935); + case sim_ppc_spr936_regnum: return regnum2spr (936); + case sim_ppc_spr937_regnum: return regnum2spr (937); + case sim_ppc_spr938_regnum: return regnum2spr (938); + case sim_ppc_spr939_regnum: return regnum2spr (939); + case sim_ppc_spr940_regnum: return regnum2spr (940); + case sim_ppc_spr941_regnum: return regnum2spr (941); + case sim_ppc_spr942_regnum: return regnum2spr (942); + case sim_ppc_spr943_regnum: return regnum2spr (943); + case sim_ppc_spr944_regnum: return regnum2spr (944); + case sim_ppc_spr945_regnum: return regnum2spr (945); + case sim_ppc_spr946_regnum: return regnum2spr (946); + case sim_ppc_spr947_regnum: return regnum2spr (947); + case sim_ppc_spr948_regnum: return regnum2spr (948); + case sim_ppc_spr949_regnum: return regnum2spr (949); + case sim_ppc_spr950_regnum: return regnum2spr (950); + case sim_ppc_spr951_regnum: return regnum2spr (951); + case sim_ppc_spr952_regnum: return regnum2spr (952); + case sim_ppc_spr953_regnum: return regnum2spr (953); + case sim_ppc_spr954_regnum: return regnum2spr (954); + case sim_ppc_spr955_regnum: return regnum2spr (955); + case sim_ppc_spr956_regnum: return regnum2spr (956); + case sim_ppc_spr957_regnum: return regnum2spr (957); + case sim_ppc_spr958_regnum: return regnum2spr (958); + case sim_ppc_spr959_regnum: return regnum2spr (959); + case sim_ppc_spr960_regnum: return regnum2spr (960); + case sim_ppc_spr961_regnum: return regnum2spr (961); + case sim_ppc_spr962_regnum: return regnum2spr (962); + case sim_ppc_spr963_regnum: return regnum2spr (963); + case sim_ppc_spr964_regnum: return regnum2spr (964); + case sim_ppc_spr965_regnum: return regnum2spr (965); + case sim_ppc_spr966_regnum: return regnum2spr (966); + case sim_ppc_spr967_regnum: return regnum2spr (967); + case sim_ppc_spr968_regnum: return regnum2spr (968); + case sim_ppc_spr969_regnum: return regnum2spr (969); + case sim_ppc_spr970_regnum: return regnum2spr (970); + case sim_ppc_spr971_regnum: return regnum2spr (971); + case sim_ppc_spr972_regnum: return regnum2spr (972); + case sim_ppc_spr973_regnum: return regnum2spr (973); + case sim_ppc_spr974_regnum: return regnum2spr (974); + case sim_ppc_spr975_regnum: return regnum2spr (975); + case sim_ppc_spr976_regnum: return regnum2spr (976); + case sim_ppc_spr977_regnum: return regnum2spr (977); + case sim_ppc_spr978_regnum: return regnum2spr (978); + case sim_ppc_spr979_regnum: return regnum2spr (979); + case sim_ppc_spr980_regnum: return regnum2spr (980); + case sim_ppc_spr981_regnum: return regnum2spr (981); + case sim_ppc_spr982_regnum: return regnum2spr (982); + case sim_ppc_spr983_regnum: return regnum2spr (983); + case sim_ppc_spr984_regnum: return regnum2spr (984); + case sim_ppc_spr985_regnum: return regnum2spr (985); + case sim_ppc_spr986_regnum: return regnum2spr (986); + case sim_ppc_spr987_regnum: return regnum2spr (987); + case sim_ppc_spr988_regnum: return regnum2spr (988); + case sim_ppc_spr989_regnum: return regnum2spr (989); + case sim_ppc_spr990_regnum: return regnum2spr (990); + case sim_ppc_spr991_regnum: return regnum2spr (991); + case sim_ppc_spr992_regnum: return regnum2spr (992); + case sim_ppc_spr993_regnum: return regnum2spr (993); + case sim_ppc_spr994_regnum: return regnum2spr (994); + case sim_ppc_spr995_regnum: return regnum2spr (995); + case sim_ppc_spr996_regnum: return regnum2spr (996); + case sim_ppc_spr997_regnum: return regnum2spr (997); + case sim_ppc_spr998_regnum: return regnum2spr (998); + case sim_ppc_spr999_regnum: return regnum2spr (999); + case sim_ppc_spr1000_regnum: return regnum2spr (1000); + case sim_ppc_spr1001_regnum: return regnum2spr (1001); + case sim_ppc_spr1002_regnum: return regnum2spr (1002); + case sim_ppc_spr1003_regnum: return regnum2spr (1003); + case sim_ppc_spr1004_regnum: return regnum2spr (1004); + case sim_ppc_spr1005_regnum: return regnum2spr (1005); + case sim_ppc_spr1006_regnum: return regnum2spr (1006); + case sim_ppc_spr1007_regnum: return regnum2spr (1007); + case sim_ppc_spr1008_regnum: return regnum2spr (1008); + case sim_ppc_spr1009_regnum: return regnum2spr (1009); + case sim_ppc_spr1010_regnum: return regnum2spr (1010); + case sim_ppc_spr1011_regnum: return regnum2spr (1011); + case sim_ppc_spr1012_regnum: return regnum2spr (1012); + case sim_ppc_spr1013_regnum: return regnum2spr (1013); + case sim_ppc_spr1014_regnum: return regnum2spr (1014); + case sim_ppc_spr1015_regnum: return regnum2spr (1015); + case sim_ppc_spr1016_regnum: return regnum2spr (1016); + case sim_ppc_spr1017_regnum: return regnum2spr (1017); + case sim_ppc_spr1018_regnum: return regnum2spr (1018); + case sim_ppc_spr1019_regnum: return regnum2spr (1019); + case sim_ppc_spr1020_regnum: return regnum2spr (1020); + case sim_ppc_spr1021_regnum: return regnum2spr (1021); + case sim_ppc_spr1022_regnum: return regnum2spr (1022); + case sim_ppc_spr1023_regnum: return regnum2spr (1023); + default: + /* Not a valid register number at all. */ + return NULL; + } +} + + +int +sim_fetch_register (SIM_DESC sd, int regno, unsigned char *buf, int length) +{ + const char *regname = regnum2name (regno); + + if (simulator == NULL || regname == NULL) + return -1; + + TRACE(trace_gdb, ("sim_fetch_register(regno=%d(%s), buf=0x%lx)\n", + regno, regname, (long)buf)); + return psim_read_register(simulator, MAX_NR_PROCESSORS, + buf, regname, raw_transfer); +} + + +int +sim_store_register (SIM_DESC sd, int regno, unsigned char *buf, int length) +{ + const char *regname = regnum2name (regno); + + if (simulator == NULL || regname == NULL) + return -1; + + TRACE(trace_gdb, ("sim_store_register(regno=%d(%s), buf=0x%lx)\n", + regno, regname, (long)buf)); + return psim_write_register(simulator, MAX_NR_PROCESSORS, + buf, regname, raw_transfer); +} diff --git a/sim/ppc/sim_callbacks.h b/sim/ppc/sim_callbacks.h index 322af9de8a..9fb815b468 100644 --- a/sim/ppc/sim_callbacks.h +++ b/sim/ppc/sim_callbacks.h @@ -103,6 +103,10 @@ void sim_io_flush_stdoutput (void); +/* Simulator instance. */ +extern psim *simulator; + + /* Memory management with an allocator that clears memory before use. */ void *zalloc diff --git a/sim/ppc/sim_calls.c b/sim/ppc/sim_calls.c index 040ce83320..ae74593dd6 100644 --- a/sim/ppc/sim_calls.c +++ b/sim/ppc/sim_calls.c @@ -40,7 +40,6 @@ #endif #endif -#include "defs.h" #include "bfd.h" #include "gdb/callback.h" #include "gdb/remote-sim.h" @@ -55,33 +54,10 @@ static int poll_quit_count = POLL_QUIT_INTERVAL; /* Structures used by the simulator, for gdb just have static structures */ -static psim *simulator; +psim *simulator; static device *root_device; static host_callback *callbacks; -/* We use GDB's gdbarch_register_name function to map GDB register - numbers onto names, which we can then look up in the register - table. Since the `set architecture' command can select a new - processor variant at run-time, the meanings of the register numbers - can change, so we need to make sure the sim uses the same - name/number mapping that GDB uses. - - (We don't use the REGISTER_NAME macro, which is a wrapper for - gdbarch_register_name. We #include GDB's "defs.h", which tries to - #include GDB's "config.h", but gets ours instead, and REGISTER_NAME - ends up not getting defined. Simpler to just use - gdbarch_register_name directly.) - - We used to just use the REGISTER_NAMES macro from GDB's - target-dependent header files, which expanded into an initializer - for an array of strings. That was kind of nice, because it meant - that libsim.a had only a compile-time dependency on GDB; using - gdbarch_register_name directly means that there are now link-time - and run-time dependencies too. - - Perhaps the host_callback structure could provide a function for - retrieving register names; that would be cleaner. */ - SIM_DESC sim_open (SIM_OPEN_KIND kind, host_callback *callback, @@ -176,54 +152,6 @@ sim_write (SIM_DESC sd, SIM_ADDR mem, unsigned char *buf, int length) return result; } - -int -sim_fetch_register (SIM_DESC sd, int regno, unsigned char *buf, int length) -{ - const char *regname; - - if (simulator == NULL) { - return 0; - } - - /* GDB will sometimes ask for the contents of a register named ""; - we ignore such requests, and leave garbage in *BUF. In GDB - terms, the empty string means "the register with this number is - not present in the currently selected architecture variant." - That's following the kludge we're using for the MIPS processors. - But there are loops that just walk through the entire list of - names and try to get everything. */ - regname = gdbarch_register_name (current_gdbarch, regno); - if (! regname || regname[0] == '\0') - return -1; - - TRACE(trace_gdb, ("sim_fetch_register(regno=%d(%s), buf=0x%lx)\n", - regno, regname, (long)buf)); - return psim_read_register(simulator, MAX_NR_PROCESSORS, - buf, regname, raw_transfer); -} - - -int -sim_store_register (SIM_DESC sd, int regno, unsigned char *buf, int length) -{ - const char *regname; - - if (simulator == NULL) - return 0; - - /* See comments in sim_fetch_register, above. */ - regname = gdbarch_register_name (current_gdbarch, regno); - if (! regname || regname[0] == '\0') - return -1; - - TRACE(trace_gdb, ("sim_store_register(regno=%d(%s), buf=0x%lx)\n", - regno, regname, (long)buf)); - return psim_write_register(simulator, MAX_NR_PROCESSORS, - buf, regname, raw_transfer); -} - - void sim_info (SIM_DESC sd, int verbose) {