Fill-out d10v enum so that there are no ``=''.
This commit is contained in:
parent
4700754efc
commit
18c0df9e1b
4 changed files with 178 additions and 76 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2002-06-01 Andrew Cagney <ac131313@redhat.com>
|
||||||
|
|
||||||
|
* sim-d10v.h (sim_d10v_regs): Expand to include all registers.
|
||||||
|
Update copyright.
|
||||||
|
|
||||||
2002-05-23 Andrew Cagney <ac131313@redhat.com>
|
2002-05-23 Andrew Cagney <ac131313@redhat.com>
|
||||||
|
|
||||||
* sim-d10v.h: New file. Moved from include/sim-d10v.h.
|
* sim-d10v.h: New file. Moved from include/sim-d10v.h.
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/* This file defines the interface between the d10v simulator and gdb.
|
/* This file defines the interface between the d10v simulator and gdb.
|
||||||
Copyright 1999 Free Software Foundation, Inc.
|
|
||||||
|
Copyright 1999, 2002 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This file is part of GDB.
|
This file is part of GDB.
|
||||||
|
|
||||||
|
@ -75,26 +76,61 @@ extern unsigned long sim_d10v_translate_addr
|
||||||
|
|
||||||
/* The simulator makes use of the following register information. */
|
/* The simulator makes use of the following register information. */
|
||||||
|
|
||||||
|
enum sim_d10v_regs
|
||||||
|
{
|
||||||
|
SIM_D10V_R0_REGNUM,
|
||||||
|
SIM_D10V_R1_REGNUM,
|
||||||
|
SIM_D10V_R2_REGNUM,
|
||||||
|
SIM_D10V_R3_REGNUM,
|
||||||
|
SIM_D10V_R4_REGNUM,
|
||||||
|
SIM_D10V_R5_REGNUM,
|
||||||
|
SIM_D10V_R6_REGNUM,
|
||||||
|
SIM_D10V_R7_REGNUM,
|
||||||
|
SIM_D10V_R8_REGNUM,
|
||||||
|
SIM_D10V_R9_REGNUM,
|
||||||
|
SIM_D10V_R10_REGNUM,
|
||||||
|
SIM_D10V_R11_REGNUM,
|
||||||
|
SIM_D10V_R12_REGNUM,
|
||||||
|
SIM_D10V_R13_REGNUM,
|
||||||
|
SIM_D10V_R14_REGNUM,
|
||||||
|
SIM_D10V_R15_REGNUM,
|
||||||
|
SIM_D10V_CR0_REGNUM,
|
||||||
|
SIM_D10V_CR1_REGNUM,
|
||||||
|
SIM_D10V_CR2_REGNUM,
|
||||||
|
SIM_D10V_CR3_REGNUM,
|
||||||
|
SIM_D10V_CR4_REGNUM,
|
||||||
|
SIM_D10V_CR5_REGNUM,
|
||||||
|
SIM_D10V_CR6_REGNUM,
|
||||||
|
SIM_D10V_CR7_REGNUM,
|
||||||
|
SIM_D10V_CR8_REGNUM,
|
||||||
|
SIM_D10V_CR9_REGNUM,
|
||||||
|
SIM_D10V_CR10_REGNUM,
|
||||||
|
SIM_D10V_CR11_REGNUM,
|
||||||
|
SIM_D10V_CR12_REGNUM,
|
||||||
|
SIM_D10V_CR13_REGNUM,
|
||||||
|
SIM_D10V_CR14_REGNUM,
|
||||||
|
SIM_D10V_CR15_REGNUM,
|
||||||
|
SIM_D10V_A0_REGNUM,
|
||||||
|
SIM_D10V_A1_REGNUM,
|
||||||
|
SIM_D10V_SPI_REGNUM,
|
||||||
|
SIM_D10V_SPU_REGNUM,
|
||||||
|
SIM_D10V_IMAP0_REGNUM,
|
||||||
|
SIM_D10V_IMAP1_REGNUM,
|
||||||
|
SIM_D10V_DMAP0_REGNUM,
|
||||||
|
SIM_D10V_DMAP1_REGNUM,
|
||||||
|
SIM_D10V_DMAP2_REGNUM,
|
||||||
|
SIM_D10V_DMAP3_REGNUM,
|
||||||
|
SIM_D10V_TS2_DMAP_REGNUM
|
||||||
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
SIM_D10V_R0_REGNUM = 0,
|
SIM_D10V_NR_R_REGS = 16,
|
||||||
SIM_D10V_CR0_REGNUM = 16,
|
SIM_D10V_NR_A_REGS = 2,
|
||||||
SIM_D10V_A0_REGNUM = 32,
|
SIM_D10V_NR_IMAP_REGS = 2,
|
||||||
SIM_D10V_SPI_REGNUM = 34,
|
SIM_D10V_NR_DMAP_REGS = 4,
|
||||||
SIM_D10V_SPU_REGNUM = 35,
|
SIM_D10V_NR_CR_REGS = 16
|
||||||
SIM_D10V_IMAP0_REGNUM = 36,
|
};
|
||||||
SIM_D10V_DMAP0_REGNUM = 38,
|
|
||||||
SIM_D10V_TS2_DMAP_REGNUM = 40
|
|
||||||
};
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
SIM_D10V_NR_R_REGS = 16,
|
|
||||||
SIM_D10V_NR_A_REGS = 2,
|
|
||||||
SIM_D10V_NR_IMAP_REGS = 2,
|
|
||||||
SIM_D10V_NR_DMAP_REGS = 4,
|
|
||||||
SIM_D10V_NR_CR_REGS = 16
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,8 @@
|
||||||
|
2002-06-01 Andrew Cagney <ac131313@redhat.com>
|
||||||
|
|
||||||
|
* interp.c (sim_fetch_register, sim_store_register): Use a switch
|
||||||
|
statement and enums from "sim-d10v.h".
|
||||||
|
|
||||||
2002-05-28 Elena Zannoni <ezannoni@redhat.com>
|
2002-05-28 Elena Zannoni <ezannoni@redhat.com>
|
||||||
|
|
||||||
* interp.c (sim_create_inferior): Add comment.
|
* interp.c (sim_create_inferior): Add comment.
|
||||||
|
|
|
@ -1307,54 +1307,82 @@ sim_fetch_register (sd, rn, memory, length)
|
||||||
int length;
|
int length;
|
||||||
{
|
{
|
||||||
int size;
|
int size;
|
||||||
if (rn < 0)
|
switch ((enum gdb_d10v_regs) rn)
|
||||||
size = 0;
|
|
||||||
else if (rn >= SIM_D10V_R0_REGNUM
|
|
||||||
&& rn < SIM_D10V_R0_REGNUM + SIM_D10V_NR_R_REGS)
|
|
||||||
{
|
{
|
||||||
|
case SIM_D10V_R0_REGNUM:
|
||||||
|
case SIM_D10V_R1_REGNUM:
|
||||||
|
case SIM_D10V_R2_REGNUM:
|
||||||
|
case SIM_D10V_R3_REGNUM:
|
||||||
|
case SIM_D10V_R4_REGNUM:
|
||||||
|
case SIM_D10V_R5_REGNUM:
|
||||||
|
case SIM_D10V_R6_REGNUM:
|
||||||
|
case SIM_D10V_R7_REGNUM:
|
||||||
|
case SIM_D10V_R8_REGNUM:
|
||||||
|
case SIM_D10V_R9_REGNUM:
|
||||||
|
case SIM_D10V_R10_REGNUM:
|
||||||
|
case SIM_D10V_R11_REGNUM:
|
||||||
|
case SIM_D10V_R12_REGNUM:
|
||||||
|
case SIM_D10V_R13_REGNUM:
|
||||||
|
case SIM_D10V_R14_REGNUM:
|
||||||
|
case SIM_D10V_R15_REGNUM:
|
||||||
WRITE_16 (memory, GPR (rn - SIM_D10V_R0_REGNUM));
|
WRITE_16 (memory, GPR (rn - SIM_D10V_R0_REGNUM));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_CR0_REGNUM
|
case SIM_D10V_CR0_REGNUM:
|
||||||
&& rn < SIM_D10V_CR0_REGNUM + SIM_D10V_NR_CR_REGS)
|
case SIM_D10V_CR1_REGNUM:
|
||||||
{
|
case SIM_D10V_CR2_REGNUM:
|
||||||
|
case SIM_D10V_CR3_REGNUM:
|
||||||
|
case SIM_D10V_CR4_REGNUM:
|
||||||
|
case SIM_D10V_CR5_REGNUM:
|
||||||
|
case SIM_D10V_CR6_REGNUM:
|
||||||
|
case SIM_D10V_CR7_REGNUM:
|
||||||
|
case SIM_D10V_CR8_REGNUM:
|
||||||
|
case SIM_D10V_CR9_REGNUM:
|
||||||
|
case SIM_D10V_CR10_REGNUM:
|
||||||
|
case SIM_D10V_CR11_REGNUM:
|
||||||
|
case SIM_D10V_CR12_REGNUM:
|
||||||
|
case SIM_D10V_CR13_REGNUM:
|
||||||
|
case SIM_D10V_CR14_REGNUM:
|
||||||
|
case SIM_D10V_CR15_REGNUM:
|
||||||
WRITE_16 (memory, CREG (rn - SIM_D10V_CR0_REGNUM));
|
WRITE_16 (memory, CREG (rn - SIM_D10V_CR0_REGNUM));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_A0_REGNUM
|
case SIM_D10V_A0_REGNUM:
|
||||||
&& rn < SIM_D10V_A0_REGNUM + SIM_D10V_NR_A_REGS)
|
case SIM_D10V_A1_REGNUM:
|
||||||
{
|
|
||||||
WRITE_64 (memory, ACC (rn - SIM_D10V_A0_REGNUM));
|
WRITE_64 (memory, ACC (rn - SIM_D10V_A0_REGNUM));
|
||||||
size = 8;
|
size = 8;
|
||||||
}
|
break;
|
||||||
else if (rn == SIM_D10V_SPI_REGNUM)
|
case SIM_D10V_SPI_REGNUM:
|
||||||
{
|
|
||||||
/* PSW_SM indicates that the current SP is the USER
|
/* PSW_SM indicates that the current SP is the USER
|
||||||
stack-pointer. */
|
stack-pointer. */
|
||||||
WRITE_16 (memory, spi_register ());
|
WRITE_16 (memory, spi_register ());
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn == SIM_D10V_SPU_REGNUM)
|
case SIM_D10V_SPU_REGNUM:
|
||||||
{
|
|
||||||
/* PSW_SM indicates that the current SP is the USER
|
/* PSW_SM indicates that the current SP is the USER
|
||||||
stack-pointer. */
|
stack-pointer. */
|
||||||
WRITE_16 (memory, spu_register ());
|
WRITE_16 (memory, spu_register ());
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_IMAP0_REGNUM
|
case SIM_D10V_IMAP0_REGNUM:
|
||||||
&& rn < SIM_D10V_IMAP0_REGNUM + SIM_D10V_NR_IMAP_REGS)
|
case SIM_D10V_IMAP1_REGNUM:
|
||||||
{
|
|
||||||
WRITE_16 (memory, imap_register (rn - SIM_D10V_IMAP0_REGNUM));
|
WRITE_16 (memory, imap_register (rn - SIM_D10V_IMAP0_REGNUM));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_DMAP0_REGNUM
|
case SIM_D10V_DMAP0_REGNUM:
|
||||||
&& rn < SIM_D10V_DMAP0_REGNUM + SIM_D10V_NR_DMAP_REGS)
|
case SIM_D10V_DMAP1_REGNUM:
|
||||||
{
|
case SIM_D10V_DMAP2_REGNUM:
|
||||||
|
case SIM_D10V_DMAP3_REGNUM:
|
||||||
WRITE_16 (memory, dmap_register (rn - SIM_D10V_DMAP0_REGNUM));
|
WRITE_16 (memory, dmap_register (rn - SIM_D10V_DMAP0_REGNUM));
|
||||||
size = 2;
|
size = 2;
|
||||||
|
break;
|
||||||
|
case SIM_D10V_TS2_DMAP_REGNUM:
|
||||||
|
size = 0;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
size = 0;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
size = 0;
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1366,52 +1394,80 @@ sim_store_register (sd, rn, memory, length)
|
||||||
int length;
|
int length;
|
||||||
{
|
{
|
||||||
int size;
|
int size;
|
||||||
if (rn < 0)
|
switch ((enum sim_d10v_reg) rn)
|
||||||
size = 0;
|
|
||||||
else if (rn >= SIM_D10V_R0_REGNUM
|
|
||||||
&& rn < SIM_D10V_R0_REGNUM + SIM_D10V_NR_R_REGS)
|
|
||||||
{
|
{
|
||||||
|
case SIM_D10V_R0_REGNUM:
|
||||||
|
case SIM_D10V_R1_REGNUM:
|
||||||
|
case SIM_D10V_R2_REGNUM:
|
||||||
|
case SIM_D10V_R3_REGNUM:
|
||||||
|
case SIM_D10V_R4_REGNUM:
|
||||||
|
case SIM_D10V_R5_REGNUM:
|
||||||
|
case SIM_D10V_R6_REGNUM:
|
||||||
|
case SIM_D10V_R7_REGNUM:
|
||||||
|
case SIM_D10V_R8_REGNUM:
|
||||||
|
case SIM_D10V_R9_REGNUM:
|
||||||
|
case SIM_D10V_R10_REGNUM:
|
||||||
|
case SIM_D10V_R11_REGNUM:
|
||||||
|
case SIM_D10V_R12_REGNUM:
|
||||||
|
case SIM_D10V_R13_REGNUM:
|
||||||
|
case SIM_D10V_R14_REGNUM:
|
||||||
|
case SIM_D10V_R15_REGNUM:
|
||||||
SET_GPR (rn - SIM_D10V_R0_REGNUM, READ_16 (memory));
|
SET_GPR (rn - SIM_D10V_R0_REGNUM, READ_16 (memory));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_CR0_REGNUM
|
case SIM_D10V_CR0_REGNUM:
|
||||||
&& rn < SIM_D10V_CR0_REGNUM + SIM_D10V_NR_CR_REGS)
|
case SIM_D10V_CR1_REGNUM:
|
||||||
{
|
case SIM_D10V_CR2_REGNUM:
|
||||||
|
case SIM_D10V_CR3_REGNUM:
|
||||||
|
case SIM_D10V_CR4_REGNUM:
|
||||||
|
case SIM_D10V_CR5_REGNUM:
|
||||||
|
case SIM_D10V_CR6_REGNUM:
|
||||||
|
case SIM_D10V_CR7_REGNUM:
|
||||||
|
case SIM_D10V_CR8_REGNUM:
|
||||||
|
case SIM_D10V_CR9_REGNUM:
|
||||||
|
case SIM_D10V_CR10_REGNUM:
|
||||||
|
case SIM_D10V_CR11_REGNUM:
|
||||||
|
case SIM_D10V_CR12_REGNUM:
|
||||||
|
case SIM_D10V_CR13_REGNUM:
|
||||||
|
case SIM_D10V_CR14_REGNUM:
|
||||||
|
case SIM_D10V_CR15_REGNUM:
|
||||||
SET_CREG (rn - SIM_D10V_CR0_REGNUM, READ_16 (memory));
|
SET_CREG (rn - SIM_D10V_CR0_REGNUM, READ_16 (memory));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_A0_REGNUM
|
case SIM_D10V_A0_REGNUM:
|
||||||
&& rn < SIM_D10V_A0_REGNUM + SIM_D10V_NR_A_REGS)
|
case SIM_D10V_A1_REGNUM:
|
||||||
{
|
|
||||||
SET_ACC (rn - SIM_D10V_A0_REGNUM, READ_64 (memory) & MASK40);
|
SET_ACC (rn - SIM_D10V_A0_REGNUM, READ_64 (memory) & MASK40);
|
||||||
size = 8;
|
size = 8;
|
||||||
}
|
break;
|
||||||
else if (rn == SIM_D10V_SPI_REGNUM)
|
case SIM_D10V_SPI_REGNUM:
|
||||||
{
|
|
||||||
/* PSW_SM indicates that the current SP is the USER
|
/* PSW_SM indicates that the current SP is the USER
|
||||||
stack-pointer. */
|
stack-pointer. */
|
||||||
set_spi_register (READ_16 (memory));
|
set_spi_register (READ_16 (memory));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn == SIM_D10V_SPU_REGNUM)
|
case SIM_D10V_SPU_REGNUM:
|
||||||
{
|
|
||||||
set_spu_register (READ_16 (memory));
|
set_spu_register (READ_16 (memory));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_IMAP0_REGNUM
|
case SIM_D10V_IMAP0_REGNUM:
|
||||||
&& rn < SIM_D10V_IMAP0_REGNUM + SIM_D10V_NR_IMAP_REGS)
|
case SIM_D10V_IMAP1_REGNUM:
|
||||||
{
|
|
||||||
set_imap_register (rn - SIM_D10V_IMAP0_REGNUM, READ_16(memory));
|
set_imap_register (rn - SIM_D10V_IMAP0_REGNUM, READ_16(memory));
|
||||||
size = 2;
|
size = 2;
|
||||||
}
|
break;
|
||||||
else if (rn >= SIM_D10V_DMAP0_REGNUM
|
case SIM_D10V_DMAP0_REGNUM:
|
||||||
&& rn < SIM_D10V_DMAP0_REGNUM + SIM_D10V_NR_DMAP_REGS)
|
case SIM_D10V_DMAP1_REGNUM:
|
||||||
{
|
case SIM_D10V_DMAP2_REGNUM:
|
||||||
|
case SIM_D10V_DMAP3_REGNUM:
|
||||||
set_dmap_register (rn - SIM_D10V_DMAP0_REGNUM, READ_16(memory));
|
set_dmap_register (rn - SIM_D10V_DMAP0_REGNUM, READ_16(memory));
|
||||||
size = 2;
|
size = 2;
|
||||||
|
break;
|
||||||
|
case SIM_D10V_TS2_DMAP_REGNUM:
|
||||||
|
size = 0;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
size = 0;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
size = 0;
|
|
||||||
SLOT_FLUSH ();
|
SLOT_FLUSH ();
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue