mirror of
https://github.com/holub/mame
synced 2025-07-02 16:49:22 +03:00
fruit machine notes / logging. (nw)
This commit is contained in:
parent
ebeaa03ac2
commit
2fd5740e4e
@ -6,6 +6,603 @@
|
||||
#include "mcf5206e.h"
|
||||
|
||||
|
||||
|
||||
static ADDRESS_MAP_START( coldfire_regs_map, AS_0, 32, mcf5206e_peripheral_device )
|
||||
|
||||
|
||||
AM_RANGE(0x014, 0x017) AM_READWRITE8(ICR1_ICR2_ICR3_ICR4_r, ICR1_ICR2_ICR3_ICR4_w, 0xffffffff)
|
||||
|
||||
AM_RANGE(0x01c, 0x01f) AM_READWRITE8(ICR9_ICR10_ICR11_ICR12_r, ICR9_ICR10_ICR11_ICR12_w, 0xffffffff)
|
||||
AM_RANGE(0x020, 0x023) AM_READWRITE8(ICR13_r, ICR13_w, 0xffffffff)
|
||||
|
||||
AM_RANGE(0x034, 0x037) AM_READWRITE16(IMR_r, IMR_w, 0xffffffff)
|
||||
|
||||
/* Chip Select registers */
|
||||
AM_RANGE(0x064, 0x067) AM_READWRITE16(CSAR0_r, CSAR0_w, 0xffffffff)
|
||||
AM_RANGE(0x068, 0x06b) AM_READWRITE (CSMR0_r, CSMR0_w)
|
||||
AM_RANGE(0x06c, 0x06f) AM_READWRITE16(CSCR0_r, CSCR0_w, 0xffffffff)
|
||||
AM_RANGE(0x070, 0x073) AM_READWRITE16(CSAR1_r, CSAR1_w, 0xffffffff)
|
||||
AM_RANGE(0x074, 0x077) AM_READWRITE (CSMR1_r, CSMR1_w)
|
||||
AM_RANGE(0x078, 0x07b) AM_READWRITE16(CSCR1_r, CSCR1_w, 0xffffffff)
|
||||
AM_RANGE(0x07c, 0x07f) AM_READWRITE16(CSAR2_r, CSAR2_w, 0xffffffff)
|
||||
AM_RANGE(0x080, 0x083) AM_READWRITE (CSMR2_r, CSMR2_w)
|
||||
AM_RANGE(0x084, 0x087) AM_READWRITE16(CSCR2_r, CSCR2_w, 0xffffffff)
|
||||
AM_RANGE(0x088, 0x08b) AM_READWRITE16(CSAR3_r, CSAR3_w, 0xffffffff)
|
||||
AM_RANGE(0x08c, 0x08f) AM_READWRITE (CSMR3_r, CSMR3_w)
|
||||
AM_RANGE(0x090, 0x093) AM_READWRITE16(CSCR3_r, CSCR3_w, 0xffffffff)
|
||||
AM_RANGE(0x094, 0x097) AM_READWRITE16(CSAR4_r, CSAR4_w, 0xffffffff)
|
||||
AM_RANGE(0x098, 0x09b) AM_READWRITE (CSMR4_r, CSMR4_w)
|
||||
AM_RANGE(0x09c, 0x09f) AM_READWRITE16(CSCR4_r, CSCR4_w, 0xffffffff)
|
||||
AM_RANGE(0x0a0, 0x0a3) AM_READWRITE16(CSAR5_r, CSAR5_w, 0xffffffff)
|
||||
AM_RANGE(0x0a4, 0x0a7) AM_READWRITE (CSMR5_r, CSMR5_w)
|
||||
AM_RANGE(0x0a8, 0x0ab) AM_READWRITE16(CSCR5_r, CSCR5_w, 0xffffffff)
|
||||
AM_RANGE(0x0ac, 0x0af) AM_READWRITE16(CSAR6_r, CSAR6_w, 0xffffffff)
|
||||
AM_RANGE(0x0b0, 0x0b3) AM_READWRITE (CSMR6_r, CSMR6_w)
|
||||
AM_RANGE(0x0b4, 0x0b7) AM_READWRITE16(CSCR6_r, CSCR6_w, 0xffffffff)
|
||||
AM_RANGE(0x0b8, 0x0bb) AM_READWRITE16(CSAR7_r, CSAR7_w, 0xffffffff)
|
||||
AM_RANGE(0x0bc, 0x0bf) AM_READWRITE (CSMR7_r, CSMR7_w)
|
||||
AM_RANGE(0x0c0, 0x0c3) AM_READWRITE16(CSCR7_r, CSCR7_w, 0xffffffff)
|
||||
|
||||
AM_RANGE(0x0c4, 0x0c7) AM_READWRITE16(DMCR_r, DMCR_w, 0xffffffff)
|
||||
AM_RANGE(0x0c8, 0x0cb) AM_READWRITE16(PAR_r, PAR_w, 0xffffffff)
|
||||
|
||||
AM_RANGE(0x100, 0x103) AM_READWRITE16(TMR1_r, TMR1_w, 0xffffffff)
|
||||
AM_RANGE(0x104, 0x107) AM_READWRITE16(TRR1_r, TRR1_w, 0xffffffff)
|
||||
|
||||
|
||||
AM_RANGE(0x1c4, 0x1c7) AM_READWRITE8(PPDDR_r, PPDDR_w, 0xffffffff)
|
||||
AM_RANGE(0x1c8, 0x1cb) AM_READWRITE8(PPDAT_r, PPDAT_w, 0xffffffff)
|
||||
|
||||
AM_RANGE(0x1e8, 0x1eb) AM_READWRITE8(MBCR_r, MBCR_w, 0xffffffff)
|
||||
AM_RANGE(0x1ec, 0x1ef) AM_READWRITE8(MBSR_r, MBSR_w, 0xffffffff)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::ICR1_ICR2_ICR3_ICR4_r )
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0: // 0x014
|
||||
printf("(External IRQ1/IPL1 Interrupt Vector) ICR1_r\n");
|
||||
return m_ICR1;
|
||||
case 1: // 0x015
|
||||
printf("(External IPL2 Interrupt Vector) ICR2_r\n");
|
||||
return m_ICR2;
|
||||
case 2: // 0x016
|
||||
printf("(External IPL3 Interrupt Vector) ICR3_r\n");
|
||||
return m_ICR3;
|
||||
case 3: // 0x017
|
||||
printf("(External IRQ4/IPL4 Interrupt Vector) ICR4_r\n");
|
||||
return m_ICR4;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::ICR1_ICR2_ICR3_ICR4_w )
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0: // 0x014
|
||||
m_ICR1 = data;
|
||||
printf("(External IRQ1/IPL1 Interrupt Vector) ICR1_w %02x\n",data);
|
||||
break;
|
||||
case 1: // 0x015
|
||||
m_ICR2 = data;
|
||||
printf("(External IPL2 Interrupt Vector) ICR2_w %02x\n",data);
|
||||
break;
|
||||
case 2: // 0x016
|
||||
m_ICR3 = data;
|
||||
printf("(External IPL3 Interrupt Vector) ICR3_w %02x\n",data);
|
||||
break;
|
||||
case 3: // 0x017
|
||||
m_ICR4 = data;
|
||||
printf("(External IRQ4/IPL4 Interrupt Vector) ICR4_w %02x\n",data);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::ICR9_ICR10_ICR11_ICR12_r )
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0: // 0x01c
|
||||
printf("(Timer 1 Interrupt Vector) ICR9_r\n");
|
||||
return m_ICR9;
|
||||
case 1: // 0x01d
|
||||
printf("(Timer 2 Interrupt Vector) ICR10_r\n");
|
||||
return m_ICR10;
|
||||
case 2: // 0x01e
|
||||
printf("(MBUS Interrupt Vector) ICR11_r\n");
|
||||
return m_ICR11;
|
||||
case 3: // 0x01f
|
||||
printf("(UART1 Interrupt Vector) ICR12_r\n");
|
||||
return m_ICR12;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::ICR9_ICR10_ICR11_ICR12_w )
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0: // 0x01c
|
||||
m_ICR9 = data;
|
||||
printf("(Timer 1 Interrupt Vector) ICR9_w %02x\n",data);
|
||||
break;
|
||||
case 1: // 0x01d
|
||||
m_ICR10 = data;
|
||||
printf("(Timer 2 Interrupt Vector) ICR10_w %02x\n",data);
|
||||
break;
|
||||
case 2: // 0x01e
|
||||
m_ICR11 = data;
|
||||
printf("(MBUS Interrupt Vector) ICR11_w %02x\n",data);
|
||||
break;
|
||||
case 3: // 0x01f
|
||||
m_ICR12 = data;
|
||||
printf("(UART1 Interrupt Vector) ICR12_w %02x\n",data);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::ICR13_r )
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0: // 0x020
|
||||
printf("(UART2 Interrupt Vector) ICR13_r\n");
|
||||
return m_ICR13;
|
||||
case 1:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid ICR13_r %d\n", offset);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::ICR13_w )
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0: // 0x020
|
||||
m_ICR13 = data;
|
||||
printf("(UART2 Interrupt Vector) ICR13_w %02x\n",data);
|
||||
break;
|
||||
case 1:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid ICR13_w %d, %02x\n", offset, data);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
inline UINT16 mcf5206e_peripheral_device::CSAR_r(int which, int offset, UINT16 mem_mask)
|
||||
{
|
||||
if (offset==0)
|
||||
{
|
||||
printf("CSAR%d_r\n", which);
|
||||
return m_CSAR[which];
|
||||
}
|
||||
else
|
||||
{
|
||||
logerror("invalid CSAR%d_r with offset %d\n", which, offset);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
inline void mcf5206e_peripheral_device::CSAR_w(int which, int offset, UINT16 data, UINT16 mem_mask)
|
||||
{
|
||||
if (offset==0)
|
||||
{
|
||||
COMBINE_DATA( &m_CSAR[which] );
|
||||
printf("CSAR%d_w %04x\n", which, data);
|
||||
}
|
||||
else
|
||||
{
|
||||
logerror("invalid CSAR%d_w with offset %d %04x\n", which, offset, data);
|
||||
}
|
||||
}
|
||||
|
||||
inline UINT32 mcf5206e_peripheral_device::CSMR_r(int which, UINT32 mem_mask)
|
||||
{
|
||||
printf("CSMR%d_r\n", which);
|
||||
return m_CSMR[0];
|
||||
}
|
||||
|
||||
inline void mcf5206e_peripheral_device::CSMR_w(int which, UINT32 data, UINT32 mem_mask)
|
||||
{
|
||||
COMBINE_DATA( &m_CSMR[0] );
|
||||
printf("CSMR%d_w %08x\n", which, data);
|
||||
}
|
||||
|
||||
inline UINT16 mcf5206e_peripheral_device::CSCR_r(int which, int offset, UINT16 mem_mask)
|
||||
{
|
||||
if (offset==1)
|
||||
{
|
||||
printf("CSCR%d_r\n", which);
|
||||
return m_CSCR[which];
|
||||
}
|
||||
else
|
||||
{
|
||||
logerror("invalid CSCR%d_r with offset %d\n", which, offset);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
inline void mcf5206e_peripheral_device::CSCR_w(int which, int offset, UINT16 data, UINT16 mem_mask)
|
||||
{
|
||||
if (offset==1)
|
||||
{
|
||||
COMBINE_DATA( &m_CSCR[which] );
|
||||
printf("CSCR%d_w %04x\n", which, data);
|
||||
}
|
||||
else
|
||||
{
|
||||
logerror("invalid CSCR%d_r with offset %d %04x\n", which, offset, data);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR0_r) { return CSAR_r(0, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR0_w) { CSAR_w(0, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR0_r) { return CSMR_r(0, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR0_w) { CSMR_w(0, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR0_r) { return CSCR_r(0, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR0_w) { CSCR_w(0, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR1_r) { return CSAR_r(1, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR1_w) { CSAR_w(1, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR1_r) { return CSMR_r(1, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR1_w) { CSMR_w(1, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR1_r) { return CSCR_r(1, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR1_w) { CSCR_w(1, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR2_r) { return CSAR_r(2, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR2_w) { CSAR_w(2, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR2_r) { return CSMR_r(2, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR2_w) { CSMR_w(2, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR2_r) { return CSCR_r(2, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR2_w) { CSCR_w(2, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR3_r) { return CSAR_r(3, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR3_w) { CSAR_w(3, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR3_r) { return CSMR_r(3, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR3_w) { CSMR_w(3, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR3_r) { return CSCR_r(3, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR3_w) { CSCR_w(3, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR4_r) { return CSAR_r(4, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR4_w) { CSAR_w(4, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR4_r) { return CSMR_r(4, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR4_w) { CSMR_w(4, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR4_r) { return CSCR_r(4, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR4_w) { CSCR_w(4, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR5_r) { return CSAR_r(5, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR5_w) { CSAR_w(5, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR5_r) { return CSMR_r(5, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR5_w) { CSMR_w(5, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR5_r) { return CSCR_r(5, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR5_w) { CSCR_w(5, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR6_r) { return CSAR_r(6, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR6_w) { CSAR_w(6, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR6_r) { return CSMR_r(6, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR6_w) { CSMR_w(6, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR6_r) { return CSCR_r(6, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR6_w) { CSCR_w(6, offset, data, mem_mask); };
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSAR7_r) { return CSAR_r(7, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSAR7_w) { CSAR_w(7, offset, data, mem_mask); };
|
||||
READ32_MEMBER( mcf5206e_peripheral_device::CSMR7_r) { return CSMR_r(7, mem_mask); };
|
||||
WRITE32_MEMBER( mcf5206e_peripheral_device::CSMR7_w) { CSMR_w(7, data, mem_mask); };
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::CSCR7_r) { return CSCR_r(7, offset, mem_mask); };
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::CSCR7_w) { CSCR_w(7, offset, data, mem_mask); };
|
||||
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::DMCR_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 1:
|
||||
printf("DMCR_r %04x\n", mem_mask);
|
||||
return m_DMCR;
|
||||
case 0:
|
||||
printf("invalid DMCR_r %d %04x\n", offset, mem_mask);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::DMCR_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 1:
|
||||
COMBINE_DATA(&m_DMCR);
|
||||
printf("DMCR_w %04x %04x\n",data, mem_mask);
|
||||
break;
|
||||
case 0:
|
||||
printf("invalid DMCR_w %d, %04x %04x\n", offset, data, mem_mask);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::PAR_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 1:
|
||||
printf("PAR_r %04x\n", mem_mask);
|
||||
return m_PAR;
|
||||
case 0:
|
||||
printf("invalid PAR_r %d %04x\n", offset, mem_mask);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::PAR_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 1:
|
||||
COMBINE_DATA(&m_PAR);
|
||||
printf("PAR_w %04x %04x\n",data, mem_mask);
|
||||
break;
|
||||
case 0:
|
||||
printf("invalid PAR_w %d, %04x %04x\n", offset, data, mem_mask);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::PPDDR_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid PPDDR_r %d\n", offset);
|
||||
return 0;
|
||||
case 1: // '$1C5'
|
||||
printf("PPDDR_r\n");
|
||||
return m_PPDDR;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::PPDDR_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid PPDDR_w %d %02x\n", offset, data);
|
||||
break;
|
||||
case 1: // '$1C5'
|
||||
m_PPDDR = data;
|
||||
printf("PPDDR_w %02x\n", data);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::PPDAT_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid PPDAT_r %d\n", offset);
|
||||
return 0;
|
||||
case 1: // '$1C9'
|
||||
printf("PPDAT_r\n");
|
||||
return m_PPDAT; // should use a callback.
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::PPDAT_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid PPDAT_w %d, %02x\n", offset, data);
|
||||
break;
|
||||
case 1: // '$1C9'
|
||||
m_PPDAT = data; // should use a callback.
|
||||
printf("PPDAT_w %02x\n", data);
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::MBCR_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
printf("MBCR_r\n");
|
||||
return m_MBCR;
|
||||
case 1:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid MBCR_r %d\n", offset);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::MBCR_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
m_MBCR = data;
|
||||
printf("MBCR_w %02x\n",data);
|
||||
break;
|
||||
case 1:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid MBCR_w %d, %02x\n", offset, data);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
READ8_MEMBER( mcf5206e_peripheral_device::MBSR_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
printf("MBSR_r\n");
|
||||
return m_MBSR;
|
||||
case 1:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid MBSR_r %d\n", offset);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mcf5206e_peripheral_device::MBSR_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
m_MBSR = data;
|
||||
printf("MBSR_w %02x\n",data);
|
||||
break;
|
||||
case 1:
|
||||
case 2:
|
||||
case 3:
|
||||
printf("invalid MBSR_w %d, %02x\n", offset, data);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::IMR_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 1:
|
||||
printf("IMR_r %04x\n", mem_mask);
|
||||
return m_IMR;
|
||||
case 0:
|
||||
printf("invalid IMR_r %d %04x\n", offset, mem_mask);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::IMR_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 1:
|
||||
COMBINE_DATA(&m_IMR);
|
||||
printf("IMR_w %04x %04x\n",data, mem_mask);
|
||||
break;
|
||||
case 0:
|
||||
printf("invalid IMR_w %d, %04x %04x\n", offset, data, mem_mask);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::TMR1_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
printf("TMR1_r %04x\n", mem_mask);
|
||||
return m_TMR1;
|
||||
case 1:
|
||||
printf("invalid TMR1_r %d %04x\n", offset, mem_mask);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::TMR1_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
COMBINE_DATA(&m_TMR1);
|
||||
printf("TMR1_w %04x %04x\n",data, mem_mask);
|
||||
break;
|
||||
case 1:
|
||||
printf("invalid TMR1_w %d, %04x %04x\n", offset, data, mem_mask);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
READ16_MEMBER( mcf5206e_peripheral_device::TRR1_r)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
printf("TRR1_r %04x\n", mem_mask);
|
||||
return m_TRR1;
|
||||
case 1:
|
||||
printf("invalid TRR1_r %d %04x\n", offset, mem_mask);
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE16_MEMBER( mcf5206e_peripheral_device::TRR1_w)
|
||||
{
|
||||
switch (offset)
|
||||
{
|
||||
case 0:
|
||||
COMBINE_DATA(&m_TRR1);
|
||||
printf("TRR1_w %04x %04x\n",data, mem_mask);
|
||||
break;
|
||||
case 1:
|
||||
printf("invalid TRR1_w %d, %04x %04x\n", offset, data, mem_mask);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
//**************************************************************************
|
||||
// LIVE DEVICE
|
||||
//**************************************************************************
|
||||
@ -18,7 +615,10 @@ const device_type MCF5206E_PERIPHERAL = &device_creator<mcf5206e_peripheral_devi
|
||||
//-------------------------------------------------
|
||||
|
||||
mcf5206e_peripheral_device::mcf5206e_peripheral_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock)
|
||||
: device_t(mconfig, MCF5206E_PERIPHERAL, "MCF5206E Peripheral", tag, owner, clock)
|
||||
: device_t(mconfig, MCF5206E_PERIPHERAL, "MCF5206E Peripheral", tag, owner, clock),
|
||||
device_memory_interface(mconfig, *this),
|
||||
m_space_config("coldfire_regs", ENDIANNESS_BIG, 32,10, 0, NULL, *ADDRESS_MAP_NAME(coldfire_regs_map))
|
||||
|
||||
{
|
||||
}
|
||||
|
||||
@ -32,6 +632,10 @@ void mcf5206e_peripheral_device::device_config_complete()
|
||||
{
|
||||
}
|
||||
|
||||
const address_space_config *mcf5206e_peripheral_device::memory_space_config(address_spacenum spacenum) const
|
||||
{
|
||||
return (spacenum == AS_0) ? &m_space_config : NULL;
|
||||
}
|
||||
|
||||
//-------------------------------------------------
|
||||
// device_start - device-specific startup
|
||||
@ -39,17 +643,21 @@ void mcf5206e_peripheral_device::device_config_complete()
|
||||
|
||||
void mcf5206e_peripheral_device::device_start()
|
||||
{
|
||||
init_regs(true);
|
||||
}
|
||||
|
||||
|
||||
|
||||
READ32_MEMBER(mcf5206e_peripheral_device::dev_r)
|
||||
{
|
||||
return 0;
|
||||
address_space ®_space = this->space();
|
||||
return reg_space.read_dword(offset*4, mem_mask);
|
||||
}
|
||||
|
||||
WRITE32_MEMBER(mcf5206e_peripheral_device::dev_w)
|
||||
{
|
||||
address_space ®_space = this->space();
|
||||
reg_space.write_dword(offset*4, data, mem_mask);
|
||||
}
|
||||
|
||||
|
||||
@ -79,26 +687,76 @@ READ32_MEMBER(mcf5206e_peripheral_device::seta2_coldfire_regs_r)
|
||||
return m_coldfire_regs[offset];
|
||||
}
|
||||
|
||||
#define UNINIT 0
|
||||
#define UNINIT_NOTE 0
|
||||
|
||||
void mcf5206e_peripheral_device::init_regs(bool first_init)
|
||||
{
|
||||
m_ICR1 = 0x04;
|
||||
m_ICR2 = 0x08;
|
||||
m_ICR3 = 0x0C;
|
||||
m_ICR4 = 0x10;
|
||||
m_ICR5 = 0x14;
|
||||
m_ICR6 = 0x18;
|
||||
m_ICR7 = 0x1C;
|
||||
m_ICR8 = 0x1C;
|
||||
m_ICR9 = 0x80;
|
||||
m_ICR10 = 0x80;
|
||||
m_ICR11 = 0x80;
|
||||
m_ICR12 = 0x00;
|
||||
m_ICR13 = 0x00;
|
||||
|
||||
m_CSAR[0] = 0x0000;
|
||||
m_CSMR[0] = 0x00000000;
|
||||
m_CSCR[0] = 0x3C1F; /* 3C1F, 3C5F, 3C9F, 3CDF, 3D1F, 3D5F, 3D9F, 3DDF | AA set by IRQ 7 at reset, PS1 set by IRQ 4 at reset, PS0 set by IRQ 1 at reset*/
|
||||
|
||||
if (first_init)
|
||||
{
|
||||
for (int x=1;x<8;x++)
|
||||
{
|
||||
m_CSAR[1] = UNINIT;
|
||||
m_CSMR[1] = UNINIT;
|
||||
m_CSCR[1] = UNINIT_NOTE; // except BRST=ASET=WRAH=RDAH=WR=RD=0
|
||||
}
|
||||
}
|
||||
|
||||
m_DMCR = 0x0000;
|
||||
m_PAR = 0x0000;
|
||||
|
||||
m_TMR1 = 0x0000;
|
||||
m_TRR1 = 0xffff;
|
||||
|
||||
m_PPDDR = 0x00;
|
||||
m_PPDAT = 0x00;
|
||||
|
||||
m_IMR = 0x3FFE;
|
||||
|
||||
m_MBCR = 0x00;
|
||||
m_MBSR = 0x00;
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
ADDRESS REG WIDTH NAME/DESCRIPTION INIT VALUE (MR=Master Reset, NR=Normal Reset) Read or Write access
|
||||
ADDRESS (LE) REG WIDTH NAME/DESCRIPTION INIT VALUE (MR=Master Reset, NR=Normal Reset) Read or Write access
|
||||
* = inited
|
||||
- = skeleton handler
|
||||
|
||||
op MOVEC with $C0F MBAR 32 Module Base Address Register uninit (except V=0) W
|
||||
$003 SIMR 8 SIM Configuration Register C0 R/W
|
||||
$014 ICR1 8 Interrupt Control Register 1 - External IRQ1/IPL1 04 R/W
|
||||
$015 ICR2 8 Interrupt Control Register 2 - External IPL2 08 R/W
|
||||
$016 ICR3 8 Interrupt Control Register 3 - External IPL3 0C R/W
|
||||
$017 ICR4 8 Interrupt Control Register 4 - External IRQ4/IPL4 10 R/W
|
||||
$018 ICR5 8 Interrupt Control Register 5 - External IPL5 14 R/W
|
||||
$019 ICR6 8 Interrupt Control Register 6 - External IPL6 18 R/W
|
||||
$01A ICR7 8 Interrupt Control Register 7 - External IRQ7/IPL7 1C R/W
|
||||
$01B ICR8 8 Interrupt Control Register 8 - SWT 1C R/W
|
||||
$01C ICR9 8 Interrupt Control Register 9 - Timer 1 Interrupt 80 R/W
|
||||
$01D ICR10 8 Interrupt Control Register 10 - Timer 2 Interrupt 80 R/W
|
||||
$01E ICR11 8 Interrupt Control Register 11 - MBUS Interrupt 80 R/W
|
||||
$01F ICR12 8 Interrupt Control Register 12 - UART 1 Interrupt 00 R/W
|
||||
$020 ICR13 8 Interrupt Control Register 13 - UART 2 Interrupt 00 R/W
|
||||
$036 IMR 16 Interrupt Mask Register 3FFE R/W
|
||||
$014*- ICR1 8 Interrupt Control Register 1 - External IRQ1/IPL1 04 R/W
|
||||
$015*- ICR2 8 Interrupt Control Register 2 - External IPL2 08 R/W
|
||||
$016*- ICR3 8 Interrupt Control Register 3 - External IPL3 0C R/W
|
||||
$017*- ICR4 8 Interrupt Control Register 4 - External IRQ4/IPL4 10 R/W
|
||||
$018* ICR5 8 Interrupt Control Register 5 - External IPL5 14 R/W
|
||||
$019* ICR6 8 Interrupt Control Register 6 - External IPL6 18 R/W
|
||||
$01A* ICR7 8 Interrupt Control Register 7 - External IRQ7/IPL7 1C R/W
|
||||
$01B* ICR8 8 Interrupt Control Register 8 - SWT 1C R/W
|
||||
$01C*- ICR9 8 Interrupt Control Register 9 - Timer 1 Interrupt 80 R/W
|
||||
$01D*- ICR10 8 Interrupt Control Register 10 - Timer 2 Interrupt 80 R/W
|
||||
$01E*- ICR11 8 Interrupt Control Register 11 - MBUS Interrupt 80 R/W
|
||||
$01F*- ICR12 8 Interrupt Control Register 12 - UART 1 Interrupt 00 R/W
|
||||
$020*- ICR13 8 Interrupt Control Register 13 - UART 2 Interrupt 00 R/W
|
||||
$036*- IMR 16 Interrupt Mask Register 3FFE R/W
|
||||
$03A IPR 16 Interrupt Pending Register 0000 R
|
||||
$040 RSR 8 Reset Status Register 80 / 20 R/W
|
||||
$041 SYPCR 8 System Protection Control Register 00 R/W
|
||||
@ -113,38 +771,38 @@ $058 DCAR1 16 DRAM Controller 1 Address Register
|
||||
$05C DCMR1 32 DRAM Controller 1 Mask Register MR uninit - NR uninit R/W
|
||||
$063 DCCR1 8 DRAM Controller 1 Control Register MR 00 - NR 00 R/W
|
||||
--------- CHIP SELECTS -----------
|
||||
$064 CSAR0 16 Chip-Select 0 Address Register 0000 R/W
|
||||
$068 CSMR0 32 Chip-Select 0 Mask Register 00000000 R/W
|
||||
$06E CSCR0 16 Chip-Select 0 Control Register 3C1F, 3C5F, 3C9F, 3CDF, 3D1F, 3D5F, 3D9F, 3DDF R/W
|
||||
$064*- CSAR0 16 Chip-Select 0 Address Register 0000 R/W
|
||||
$068*- CSMR0 32 Chip-Select 0 Mask Register 00000000 R/W
|
||||
$06E*- CSCR0 16 Chip-Select 0 Control Register 3C1F, 3C5F, 3C9F, 3CDF, 3D1F, 3D5F, 3D9F, 3DDF R/W
|
||||
AA set by IRQ 7 at reset
|
||||
PS1 set by IRQ 4 at reset
|
||||
PS0 set by IRQ 1 at reset
|
||||
$070 CSAR1 16 Chip-Select 1 Address Register uninit R/W
|
||||
$074 CSMR1 32 Chip-Select 1 Mask Register uninit R/W
|
||||
$07A CSCR1 16 Chip-Select 1 Control Register uninit *1 R/W
|
||||
$07C CSAR2 16 Chip-Select 2 Address Register uninit R/W
|
||||
$080 CSMR2 32 Chip-Select 2 Mask Register uninit R/W
|
||||
$086 CSCR2 16 Chip-Select 2 Control Register uninit *1 R/W
|
||||
$088 CSAR3 16 Chip-Select 3 Address Register uninit R/W
|
||||
$08C CSMR3 32 Chip-Select 3 Mask Register uninit R/W
|
||||
$092 CSCR3 16 Chip-Select 3 Control Register uninit *1 R/W
|
||||
$094 CSAR4 16 Chip-Select 4 Address Register uninit R/W
|
||||
$098 CSMR4 32 Chip-Select 4 Mask Register uninit R/W
|
||||
$09E CSCR4 16 Chip-Select 4 Control Register uninit *1 R/W
|
||||
$0A0 CSAR5 16 Chip-Select 5 Address Register uninit R/W
|
||||
$0A4 CSMR5 32 Chip-Select 5 Mask Register uninit R/W
|
||||
$0AA CSCR5 16 Chip-Select 5 Control Register uninit *1 R/W
|
||||
$0AC CSAR6 16 Chip-Select 6 Address Register uninit R/W
|
||||
$0B0 CSMR6 32 Chip-Select 6 Mask Register uninit R/W
|
||||
$0B6 CSCR6 16 Chip-Select 6 Control Register uninit *1 R/W
|
||||
$0B8 CSAR7 16 Chip-Select 7 Address Register uninit R/W
|
||||
$0BC CSMR7 32 Chip-Select 7 Mask Register uninit R/W
|
||||
$0C2 CSCR7 16 Chip-Select 7 Control Register uninit *1 R/W
|
||||
$0C6 DMCR 16 Default Memory Control Register 0000 R/W
|
||||
$0CA PAR 16 Pin Assignment Register 00 R/W
|
||||
$070*- CSAR1 16 Chip-Select 1 Address Register uninit R/W
|
||||
$074*- CSMR1 32 Chip-Select 1 Mask Register uninit R/W
|
||||
$07A*- CSCR1 16 Chip-Select 1 Control Register uninit *1 R/W
|
||||
$07C*- CSAR2 16 Chip-Select 2 Address Register uninit R/W
|
||||
$080*- CSMR2 32 Chip-Select 2 Mask Register uninit R/W
|
||||
$086*- CSCR2 16 Chip-Select 2 Control Register uninit *1 R/W
|
||||
$088*- CSAR3 16 Chip-Select 3 Address Register uninit R/W
|
||||
$08C*- CSMR3 32 Chip-Select 3 Mask Register uninit R/W
|
||||
$092*- CSCR3 16 Chip-Select 3 Control Register uninit *1 R/W
|
||||
$094*- CSAR4 16 Chip-Select 4 Address Register uninit R/W
|
||||
$098*- CSMR4 32 Chip-Select 4 Mask Register uninit R/W
|
||||
$09E*- CSCR4 16 Chip-Select 4 Control Register uninit *1 R/W
|
||||
$0A0*- CSAR5 16 Chip-Select 5 Address Register uninit R/W
|
||||
$0A4*- CSMR5 32 Chip-Select 5 Mask Register uninit R/W
|
||||
$0AA*- CSCR5 16 Chip-Select 5 Control Register uninit *1 R/W
|
||||
$0AC*- CSAR6 16 Chip-Select 6 Address Register uninit R/W
|
||||
$0B0*- CSMR6 32 Chip-Select 6 Mask Register uninit R/W
|
||||
$0B6*- CSCR6 16 Chip-Select 6 Control Register uninit *1 R/W
|
||||
$0B8*- CSAR7 16 Chip-Select 7 Address Register uninit R/W
|
||||
$0BC*- CSMR7 32 Chip-Select 7 Mask Register uninit R/W
|
||||
$0C2*- CSCR7 16 Chip-Select 7 Control Register uninit *1 R/W
|
||||
$0C6*- DMCR 16 Default Memory Control Register 0000 R/W
|
||||
$0CA*- PAR 16 Pin Assignment Register 00 R/W
|
||||
--------- TIMER MODULE -----------
|
||||
$100 TMR1 16 Timer 1 Mode Register 0000 R/W
|
||||
$104 TRR1 16 Timer 1 Reference Register FFFF R/W
|
||||
$100*- TMR1 16 Timer 1 Mode Register 0000 R/W
|
||||
$104*- TRR1 16 Timer 1 Reference Register FFFF R/W
|
||||
$108 TCR1 16 Timer 1 Capture Register 0000 R
|
||||
$10C TCN1 16 Timer 1 Counter 0000 R/W
|
||||
$111 TER1 8 Timer 1 Event Register 00 R/W
|
||||
@ -188,13 +846,13 @@ $1B4 UIP 8 UART 2 Input Port Register
|
||||
$1B8 UOP1 8 UART 2 Output Port Bit Set CMD UOP1[7-1]=undef; UOP1=0 W
|
||||
$1BC UOP0 8 UART 2 Output Port Bit Reset CMD uninit W
|
||||
|
||||
$1C5 PPDDR 8 Port A Data Direction Register 00 R/W
|
||||
$1C9 PPDAT 8 Port A Data Register 00 R/W
|
||||
$1C5*- PPDDR 8 Port A Data Direction Register 00 R/W
|
||||
$1C9*- PPDAT 8 Port A Data Register 00 R/W
|
||||
------------ MBUS -----------
|
||||
$1E0 MADR 8 M-Bus Address Register 00 R/W
|
||||
$1E4 MFDR 8 M-Bus Frequency Divider Register 00 R/W
|
||||
$1E8 MBCR 8 M-Bus Control Register 00 R/W
|
||||
$1EC MBSR 8 M-Bus Status Register 00 R/W
|
||||
$1E8*- MBCR 8 M-Bus Control Register 00 R/W
|
||||
$1EC*- MBSR 8 M-Bus Status Register 00 R/W
|
||||
$1F0 MBDR 8 M-Bus Data I/O Register 00 R/W
|
||||
------------ DMA Controller -----------
|
||||
$200 DMASAR0 32 Source Address Register 0 00 R/W
|
||||
|
@ -24,11 +24,10 @@
|
||||
TYPE DEFINITIONS
|
||||
***************************************************************************/
|
||||
|
||||
|
||||
|
||||
// ======================> mcf5206e_peripheral_device
|
||||
|
||||
class mcf5206e_peripheral_device : public device_t
|
||||
class mcf5206e_peripheral_device : public device_t,
|
||||
public device_memory_interface
|
||||
{
|
||||
public:
|
||||
// construction/destruction
|
||||
@ -39,6 +38,95 @@ public:
|
||||
DECLARE_READ32_MEMBER( seta2_coldfire_regs_r );
|
||||
DECLARE_WRITE32_MEMBER( seta2_coldfire_regs_w );
|
||||
|
||||
DECLARE_READ8_MEMBER( ICR1_ICR2_ICR3_ICR4_r );
|
||||
DECLARE_WRITE8_MEMBER( ICR1_ICR2_ICR3_ICR4_w );
|
||||
|
||||
DECLARE_READ8_MEMBER( ICR9_ICR10_ICR11_ICR12_r );
|
||||
DECLARE_WRITE8_MEMBER( ICR9_ICR10_ICR11_ICR12_w );
|
||||
DECLARE_READ8_MEMBER( ICR13_r );
|
||||
DECLARE_WRITE8_MEMBER( ICR13_w );
|
||||
|
||||
UINT16 CSAR_r(int which, int offset, UINT16 mem_mask);
|
||||
void CSAR_w(int which, int offset, UINT16 data, UINT16 mem_mask);
|
||||
UINT32 CSMR_r(int which, UINT32 mem_mask);
|
||||
void CSMR_w(int which, UINT32 data, UINT32 mem_mask);
|
||||
UINT16 CSCR_r(int which, int offset, UINT16 mem_mask);
|
||||
void CSCR_w(int which, int offset, UINT16 data, UINT16 mem_mask);
|
||||
|
||||
DECLARE_READ16_MEMBER( CSAR0_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR0_w );
|
||||
DECLARE_READ32_MEMBER( CSMR0_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR0_w );
|
||||
DECLARE_READ16_MEMBER( CSCR0_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR0_w );
|
||||
DECLARE_READ16_MEMBER( CSAR1_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR1_w );
|
||||
DECLARE_READ32_MEMBER( CSMR1_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR1_w );
|
||||
DECLARE_READ16_MEMBER( CSCR1_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR1_w );
|
||||
DECLARE_READ16_MEMBER( CSAR2_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR2_w );
|
||||
DECLARE_READ32_MEMBER( CSMR2_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR2_w );
|
||||
DECLARE_READ16_MEMBER( CSCR2_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR2_w );
|
||||
DECLARE_READ16_MEMBER( CSAR3_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR3_w );
|
||||
DECLARE_READ32_MEMBER( CSMR3_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR3_w );
|
||||
DECLARE_READ16_MEMBER( CSCR3_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR3_w );
|
||||
DECLARE_READ16_MEMBER( CSAR4_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR4_w );
|
||||
DECLARE_READ32_MEMBER( CSMR4_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR4_w );
|
||||
DECLARE_READ16_MEMBER( CSCR4_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR4_w );
|
||||
DECLARE_READ16_MEMBER( CSAR5_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR5_w );
|
||||
DECLARE_READ32_MEMBER( CSMR5_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR5_w );
|
||||
DECLARE_READ16_MEMBER( CSCR5_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR5_w );
|
||||
DECLARE_READ16_MEMBER( CSAR6_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR6_w );
|
||||
DECLARE_READ32_MEMBER( CSMR6_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR6_w );
|
||||
DECLARE_READ16_MEMBER( CSCR6_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR6_w );
|
||||
DECLARE_READ16_MEMBER( CSAR7_r );
|
||||
DECLARE_WRITE16_MEMBER( CSAR7_w );
|
||||
DECLARE_READ32_MEMBER( CSMR7_r );
|
||||
DECLARE_WRITE32_MEMBER( CSMR7_w );
|
||||
DECLARE_READ16_MEMBER( CSCR7_r );
|
||||
DECLARE_WRITE16_MEMBER( CSCR7_w );
|
||||
|
||||
DECLARE_READ16_MEMBER( DMCR_r );
|
||||
DECLARE_WRITE16_MEMBER( DMCR_w );
|
||||
DECLARE_READ16_MEMBER( PAR_r );
|
||||
DECLARE_WRITE16_MEMBER( PAR_w );
|
||||
|
||||
DECLARE_READ16_MEMBER( TMR1_r );
|
||||
DECLARE_WRITE16_MEMBER( TMR1_w );
|
||||
DECLARE_READ16_MEMBER( TRR1_r );
|
||||
DECLARE_WRITE16_MEMBER( TRR1_w );
|
||||
|
||||
DECLARE_READ8_MEMBER( PPDDR_r );
|
||||
DECLARE_WRITE8_MEMBER( PPDDR_w );
|
||||
DECLARE_READ8_MEMBER( PPDAT_r );
|
||||
DECLARE_WRITE8_MEMBER( PPDAT_w );
|
||||
|
||||
DECLARE_READ16_MEMBER( IMR_r );
|
||||
DECLARE_WRITE16_MEMBER( IMR_w );
|
||||
|
||||
|
||||
DECLARE_READ8_MEMBER( MBCR_r );
|
||||
DECLARE_WRITE8_MEMBER( MBCR_w );
|
||||
DECLARE_READ8_MEMBER( MBSR_r );
|
||||
DECLARE_WRITE8_MEMBER( MBSR_w );
|
||||
|
||||
|
||||
protected:
|
||||
// device-level overrides
|
||||
virtual void device_config_complete();
|
||||
@ -46,6 +134,47 @@ protected:
|
||||
virtual void device_reset() { }
|
||||
virtual void device_post_load() { }
|
||||
virtual void device_clock_changed() { }
|
||||
virtual const address_space_config *memory_space_config(address_spacenum spacenum = AS_0) const;
|
||||
address_space_config m_space_config;
|
||||
|
||||
|
||||
private:
|
||||
|
||||
void init_regs(bool first_init);
|
||||
|
||||
UINT8 m_ICR1;
|
||||
UINT8 m_ICR2;
|
||||
UINT8 m_ICR3;
|
||||
UINT8 m_ICR4;
|
||||
UINT8 m_ICR5;
|
||||
UINT8 m_ICR6;
|
||||
UINT8 m_ICR7;
|
||||
UINT8 m_ICR8;
|
||||
UINT8 m_ICR9;
|
||||
UINT8 m_ICR10;
|
||||
UINT8 m_ICR11;
|
||||
UINT8 m_ICR12;
|
||||
UINT8 m_ICR13;
|
||||
|
||||
UINT16 m_CSAR[8];
|
||||
UINT32 m_CSMR[8];
|
||||
UINT16 m_CSCR[8];
|
||||
|
||||
UINT16 m_DMCR;
|
||||
UINT16 m_PAR;
|
||||
|
||||
UINT16 m_TMR1;
|
||||
UINT16 m_TRR1;
|
||||
|
||||
UINT8 m_PPDDR;
|
||||
UINT8 m_PPDAT;
|
||||
|
||||
UINT16 m_IMR;
|
||||
|
||||
UINT8 m_MBCR;
|
||||
UINT8 m_MBSR;
|
||||
|
||||
|
||||
UINT32 m_coldfire_regs[0x400/4];
|
||||
|
||||
private:
|
||||
|
@ -1,6 +1,6 @@
|
||||
/*
|
||||
|
||||
Scorpion 5
|
||||
Adder 5
|
||||
(Scorpion 5 Video Board)
|
||||
|
||||
Skeleton Driver - For note keeping.
|
||||
@ -11,7 +11,7 @@
|
||||
|
||||
#include "emu.h"
|
||||
#include "includes/bfm_ad5.h"
|
||||
|
||||
#include "machine/mcf5206e.h"
|
||||
|
||||
|
||||
extern int find_project_string(running_machine &machine, int addrxor, int mode);
|
||||
@ -54,6 +54,10 @@ static ADDRESS_MAP_START( ad5_map, AS_PROGRAM, 32, adder5_state )
|
||||
AM_RANGE(0x00000000, 0x00ffffff) AM_ROM
|
||||
AM_RANGE(0x01000000, 0x0100ffff) AM_RAM
|
||||
AM_RANGE(0x40000000, 0x40000fff) AM_RAM
|
||||
AM_RANGE(0x80000000, 0x8000ffff) AM_RAM
|
||||
AM_RANGE(0x80800000, 0x8080ffff) AM_RAM
|
||||
|
||||
AM_RANGE(0xffff0000, 0xffff03ff) AM_DEVREADWRITE("maincpu_onboard", mcf5206e_peripheral_device, dev_r, dev_w) // technically this can be moved with MBAR
|
||||
ADDRESS_MAP_END
|
||||
|
||||
INPUT_PORTS_START( bfm_ad5 )
|
||||
@ -69,6 +73,7 @@ MACHINE_CONFIG_START( bfm_ad5, adder5_state )
|
||||
MCFG_CPU_ADD("maincpu", MCF5206E, 40000000) /* MCF5206eFT */
|
||||
MCFG_CPU_PROGRAM_MAP(ad5_map)
|
||||
MCFG_CPU_PERIODIC_INT_DRIVER(adder5_state, ad5_fake_timer_int, 1000)
|
||||
MCFG_MCF5206E_PERIPHERAL_ADD("maincpu_onboard")
|
||||
|
||||
MCFG_SPEAKER_STANDARD_STEREO("lspeaker", "rspeaker")
|
||||
/* unknown sound */
|
||||
|
@ -65,8 +65,7 @@ static ADDRESS_MAP_START( gaminator_map, AS_PROGRAM, 32, gaminator_state )
|
||||
// AM_RANGE(0x440a0000, 0x440a1fff) AM_RAM AM_SHARE("tmapram2") // beetlem (like above, mirror?)
|
||||
|
||||
AM_RANGE(0xe0000000, 0xe00001ff) AM_RAM // nvram?
|
||||
|
||||
AM_RANGE(0xf0000000, 0xf00001ff) AM_RAM // coldfire peripherals?
|
||||
AM_RANGE(0xf0000000, 0xf00003ff) AM_DEVREADWRITE("maincpu_onboard", mcf5206e_peripheral_device, dev_r, dev_w) // technically this can be moved with MBAR
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static INPUT_PORTS_START( gaminator )
|
||||
|
@ -1,12 +1,14 @@
|
||||
/* Unkonwn JPM Platform */
|
||||
/* seems to be Coldfire based */
|
||||
/* only Ker - Chinq has sound roms, they seem to map in cpu space, but are missing from the rest? */
|
||||
/* seems to be Coldfire based (but not the MCF5206E, it writes to peripheral registers that would be invalid?) */
|
||||
/* only Ker - Chinq has sound roms, they seem to map in cpu space, sound roms are probably missing from the rest? */
|
||||
/* Could be Pluto 6? */
|
||||
/* todo - split sets */
|
||||
|
||||
|
||||
|
||||
#include "emu.h"
|
||||
#include "cpu/m68000/m68000.h"
|
||||
#include "machine/mcf5206e.h"
|
||||
|
||||
class jpmsys7_state : public driver_device
|
||||
{
|
||||
@ -29,8 +31,7 @@ static ADDRESS_MAP_START( jpmsys7_map, AS_PROGRAM, 32, jpmsys7_state )
|
||||
AM_RANGE(0x20000018, 0x2000001b) AM_WRITENOP // large data upload like astra/pluto?
|
||||
AM_RANGE(0x50000000, 0x50001fff) AM_RAM
|
||||
|
||||
// AM_RANGE(0xf0000000, 0xf0000fff) AM_RAM
|
||||
|
||||
AM_RANGE(0xf0000000, 0xf00003ff) AM_DEVREADWRITE("maincpu_onboard", mcf5206e_peripheral_device, dev_r, dev_w) // technically this can be moved with MBAR
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static INPUT_PORTS_START( jpmsys7 )
|
||||
@ -39,6 +40,7 @@ INPUT_PORTS_END
|
||||
static MACHINE_CONFIG_START( jpmsys7, jpmsys7_state )
|
||||
MCFG_CPU_ADD("maincpu", MCF5206E, 40000000) // seems to be a Coldfire of some kind
|
||||
MCFG_CPU_PROGRAM_MAP(jpmsys7_map)
|
||||
MCFG_MCF5206E_PERIPHERAL_ADD("maincpu_onboard")
|
||||
|
||||
MCFG_SPEAKER_STANDARD_STEREO("lspeaker", "rspeaker")
|
||||
/* unknown sound (probably DMA driven DAC) */
|
||||
|
Loading…
Reference in New Issue
Block a user