mirror of
https://github.com/holub/mame
synced 2025-04-24 17:30:55 +03:00
riscii: Add the register space (nw)
This commit is contained in:
parent
0601967015
commit
7d4f1b05f9
@ -20,15 +20,27 @@
|
||||
DEFINE_DEVICE_TYPE(RISCII, riscii_series_device, "riscii", "Elan RISC II")
|
||||
|
||||
|
||||
void riscii_series_device::regs_map(address_map &map)
|
||||
{
|
||||
map(0x0000, 0x007f).mirror(m_bankmask << 8).ram(); // TODO: special function registers
|
||||
for (unsigned b = 0; b <= m_maxbank; b++)
|
||||
map(0x0080 | (b << 8), 0x00ff | (b << 8)).ram();
|
||||
}
|
||||
|
||||
std::unique_ptr<util::disasm_interface> riscii_series_device::create_disassembler()
|
||||
{
|
||||
return std::make_unique<riscii_disassembler>();
|
||||
}
|
||||
|
||||
riscii_series_device::riscii_series_device(const machine_config &mconfig, const char *tag, device_t *owner, u32 clock)
|
||||
: cpu_device(mconfig, RISCII, tag, owner, clock)
|
||||
, m_program_config("program", ENDIANNESS_LITTLE, 16, 18, -1)
|
||||
riscii_series_device::riscii_series_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, u32 clock, unsigned prgbits, unsigned bankbits, uint8_t maxbank)
|
||||
: cpu_device(mconfig, type, tag, owner, clock)
|
||||
, m_program_config("program", ENDIANNESS_LITTLE, 16, prgbits, -1)
|
||||
, m_regs_config("register", ENDIANNESS_LITTLE, 8, 8 + bankbits, 0, address_map_constructor(FUNC(riscii_series_device::regs_map), this))
|
||||
, m_program(nullptr)
|
||||
, m_regs(nullptr)
|
||||
, m_prgbits(prgbits)
|
||||
, m_bankmask((1 << bankbits) - 1)
|
||||
, m_maxbank(maxbank)
|
||||
, m_pc(0)
|
||||
, m_acc(0)
|
||||
, m_fsr0(0)
|
||||
@ -43,28 +55,35 @@ riscii_series_device::riscii_series_device(const machine_config &mconfig, const
|
||||
m_prod.w = 0;
|
||||
}
|
||||
|
||||
riscii_series_device::riscii_series_device(const machine_config &mconfig, const char *tag, device_t *owner, u32 clock)
|
||||
: riscii_series_device(mconfig, RISCII, tag, owner, clock, 18, 5, 0x1f)
|
||||
{
|
||||
}
|
||||
|
||||
device_memory_interface::space_config_vector riscii_series_device::memory_space_config() const
|
||||
{
|
||||
return space_config_vector {
|
||||
std::make_pair(AS_PROGRAM, &m_program_config),
|
||||
std::make_pair(AS_DATA, &m_regs_config)
|
||||
};
|
||||
}
|
||||
|
||||
void riscii_series_device::device_start()
|
||||
{
|
||||
m_program = &space(AS_PROGRAM);
|
||||
m_regs = &space(AS_DATA);
|
||||
|
||||
set_icountptr(m_icount);
|
||||
|
||||
state_add(RII_PC, "PC", m_pc).mask(0x3ffff);
|
||||
state_add(RII_PC, "PC", m_pc).mask((1 << m_prgbits) - 1);
|
||||
state_add(STATE_GENPC, "GENPC", m_pc).callimport().noshow();
|
||||
state_add(STATE_GENPCBASE, "CURPC", m_pc).callimport().noshow();
|
||||
state_add(RII_ACC, "ACC", m_acc);
|
||||
state_add(RII_BSR, "BSR", m_bsr).mask(0x1f);
|
||||
state_add(RII_BSR, "BSR", m_bsr).mask(m_bankmask);
|
||||
state_add(RII_FSR0, "FSR0", m_fsr0);
|
||||
state_add(RII_BSR1, "BSR1", m_fsr1.b.h).mask(0x1f);
|
||||
state_add(RII_BSR1, "BSR1", m_fsr1.b.h).mask(m_bankmask);
|
||||
state_add(RII_FSR1, "FSR1", m_fsr1.b.l); // TODO: high bit forced to 1
|
||||
state_add(RII_TABPTR, "TABPTR", m_tabptr).mask(0xffffff);
|
||||
state_add(RII_TABPTR, "TABPTR", m_tabptr).mask(0x800000 + (1 << (m_prgbits + 1)) - 1);
|
||||
state_add(RII_STKPTR, "STKPTR", m_stkptr);
|
||||
state_add(RII_CPUCON, "CPUCON", m_cpucon).mask(0x9f);
|
||||
state_add(RII_STATUS, "STATUS", m_status);
|
||||
|
@ -35,6 +35,8 @@ public:
|
||||
riscii_series_device(const machine_config &mconfig, const char *tag, device_t *owner, u32 clock);
|
||||
|
||||
protected:
|
||||
riscii_series_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, u32 clock, unsigned prgbits, unsigned bankbits, uint8_t maxbank);
|
||||
|
||||
// device-level overrides
|
||||
virtual void device_start() override;
|
||||
virtual void device_reset() override;
|
||||
@ -50,9 +52,18 @@ protected:
|
||||
virtual space_config_vector memory_space_config() const override;
|
||||
|
||||
private:
|
||||
void regs_map(address_map &map);
|
||||
|
||||
// address spaces
|
||||
address_space_config m_program_config;
|
||||
address_space_config m_regs_config;
|
||||
address_space *m_program;
|
||||
address_space *m_regs;
|
||||
|
||||
// model-specific parameters
|
||||
const unsigned m_prgbits;
|
||||
const uint8_t m_bankmask;
|
||||
const uint8_t m_maxbank;
|
||||
|
||||
// internal state
|
||||
u32 m_pc;
|
||||
|
Loading…
Reference in New Issue
Block a user