mirror of
https://github.com/holub/mame
synced 2025-07-01 16:19:38 +03:00
telex1192: Add some more stuff (nw)
This commit is contained in:
parent
4c7506899c
commit
930ff1e1c4
@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
#include "emu.h"
|
#include "emu.h"
|
||||||
#include "cpu/bcp/dp8344.h"
|
#include "cpu/bcp/dp8344.h"
|
||||||
//#include "machine/nvram.h"
|
#include "machine/nvram.h"
|
||||||
//#include "screen.h"
|
//#include "screen.h"
|
||||||
|
|
||||||
class telex1192_state : public driver_device
|
class telex1192_state : public driver_device
|
||||||
@ -17,28 +17,38 @@ public:
|
|||||||
telex1192_state(const machine_config &mconfig, device_type type, const char *tag)
|
telex1192_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||||
: driver_device(mconfig, type, tag)
|
: driver_device(mconfig, type, tag)
|
||||||
, m_bcp(*this, "bcp")
|
, m_bcp(*this, "bcp")
|
||||||
, m_chargen(*this, "chargen")
|
, m_datarom(*this, "datarom")
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void telex1192(machine_config &config);
|
void telex1192(machine_config &config);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
u16 data_r(offs_t offset);
|
||||||
|
|
||||||
void inst_map(address_map &map);
|
void inst_map(address_map &map);
|
||||||
void data_map(address_map &map);
|
void data_map(address_map &map);
|
||||||
|
|
||||||
required_device<dp8344_device> m_bcp;
|
required_device<dp8344_device> m_bcp;
|
||||||
required_region_ptr<u8> m_chargen;
|
required_region_ptr<u8> m_datarom;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
u16 telex1192_state::data_r(offs_t offset)
|
||||||
|
{
|
||||||
|
// FIXME: not how this code is actually loaded (at least addresses are wrong)
|
||||||
|
return m_datarom[offset * 2] | m_datarom[offset * 2 + 1] << 8;
|
||||||
|
}
|
||||||
|
|
||||||
void telex1192_state::inst_map(address_map &map)
|
void telex1192_state::inst_map(address_map &map)
|
||||||
{
|
{
|
||||||
map(0x0000, 0x1fff).rom().region("program", 0);
|
map(0x0000, 0x1fff).rom().region("program", 0);
|
||||||
|
map(0xc000, 0xcfff).r(FUNC(telex1192_state::data_r));
|
||||||
}
|
}
|
||||||
|
|
||||||
void telex1192_state::data_map(address_map &map)
|
void telex1192_state::data_map(address_map &map)
|
||||||
{
|
{
|
||||||
|
map(0xa000, 0xa7ff).ram().share("nvram");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -51,6 +61,8 @@ void telex1192_state::telex1192(machine_config &config)
|
|||||||
DP8344(config, m_bcp, 18.8696_MHz_XTAL);
|
DP8344(config, m_bcp, 18.8696_MHz_XTAL);
|
||||||
m_bcp->set_addrmap(AS_PROGRAM, &telex1192_state::inst_map);
|
m_bcp->set_addrmap(AS_PROGRAM, &telex1192_state::inst_map);
|
||||||
m_bcp->set_addrmap(AS_DATA, &telex1192_state::data_map);
|
m_bcp->set_addrmap(AS_DATA, &telex1192_state::data_map);
|
||||||
|
|
||||||
|
NVRAM(config, "nvram", nvram_device::DEFAULT_ALL_0); // DS1220Y
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -63,7 +75,7 @@ ROM_START(telex1192)
|
|||||||
ROM_LOAD16_BYTE("206252-003.u7", 0x0000, 0x2000, CRC(3632b762) SHA1(a45dbcd96485ad87c60257e95dc58f31d1e4ddee))
|
ROM_LOAD16_BYTE("206252-003.u7", 0x0000, 0x2000, CRC(3632b762) SHA1(a45dbcd96485ad87c60257e95dc58f31d1e4ddee))
|
||||||
ROM_LOAD16_BYTE("206251-003.u8", 0x0001, 0x2000, CRC(2852d830) SHA1(947612957daa441596a547f23c526d20306e6e0d))
|
ROM_LOAD16_BYTE("206251-003.u8", 0x0001, 0x2000, CRC(2852d830) SHA1(947612957daa441596a547f23c526d20306e6e0d))
|
||||||
|
|
||||||
ROM_REGION(0x10000, "chargen", 0)
|
ROM_REGION(0x10000, "datarom", 0)
|
||||||
ROM_LOAD("206253-003.u6", 0x00000, 0x10000, CRC(8d7d9356) SHA1(0b2eda8b04b2a6651f4fbf4cd6cdd129a70110ee))
|
ROM_LOAD("206253-003.u6", 0x00000, 0x10000, CRC(8d7d9356) SHA1(0b2eda8b04b2a6651f4fbf4cd6cdd129a70110ee))
|
||||||
ROM_END
|
ROM_END
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user