mirror of
https://github.com/holub/mame
synced 2025-04-24 09:20:02 +03:00
Merge branch 'master' of https://github.com/mamedev/mame.git
This commit is contained in:
commit
fd8ab966b5
@ -593,10 +593,10 @@ void ui_menu_remove_folder::handle()
|
||||
if (m_event != nullptr && m_event->itemref != nullptr && m_event->iptkey == IPT_UI_SELECT)
|
||||
{
|
||||
std::string tmppath, error_string;
|
||||
m_folders.erase(m_folders.begin() + selected);
|
||||
for (int x = 0; x < m_folders.size(); ++x)
|
||||
{
|
||||
if (x != selected)
|
||||
tmppath.append(m_folders[x]);
|
||||
tmppath.append(m_folders[x]);
|
||||
if (x < m_folders.size() - 1)
|
||||
tmppath.append(";");
|
||||
}
|
||||
|
@ -27,7 +27,9 @@
|
||||
|
||||
|
||||
#include "emu.h"
|
||||
#include "bus/rs232/rs232.h"
|
||||
#include "cpu/z80/z80.h"
|
||||
#include "machine/ins8250.h"
|
||||
#include "machine/rp5c01.h"
|
||||
#include "machine/bankdev.h"
|
||||
#include "machine/ram.h"
|
||||
@ -57,19 +59,27 @@ public:
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_ram(*this, RAM_TAG),
|
||||
m_beep(*this, "beeper"),
|
||||
m_uart(*this, "ns16550"),
|
||||
m_bankdev0(*this, "bank0"),
|
||||
m_bankdev1(*this, "bank1"),
|
||||
m_flash0b(*this, "flash0b"),
|
||||
m_nvram(*this, "nvram")
|
||||
m_nvram(*this, "nvram"),
|
||||
m_battery(*this, "BATTERY"),
|
||||
m_pen_x(*this, "PENX"),
|
||||
m_pen_y(*this, "PENY")
|
||||
{ }
|
||||
|
||||
required_device<cpu_device> m_maincpu;
|
||||
required_device<ram_device> m_ram;
|
||||
required_device<beep_device> m_beep;
|
||||
required_device<ns16550_device> m_uart;
|
||||
required_device<address_map_bank_device> m_bankdev0;
|
||||
required_device<address_map_bank_device> m_bankdev1;
|
||||
optional_device<intelfsh8_device> m_flash0b;
|
||||
required_shared_ptr<UINT8> m_nvram;
|
||||
required_ioport m_battery;
|
||||
optional_ioport m_pen_x;
|
||||
optional_ioport m_pen_y;
|
||||
|
||||
UINT8 m_bank[4];
|
||||
UINT8 m_beep_io[5];
|
||||
@ -82,6 +92,7 @@ public:
|
||||
UINT8 m_irq_flag;
|
||||
UINT8 m_port6;
|
||||
UINT8 m_beep_mode;
|
||||
UINT8 m_power_on;
|
||||
|
||||
virtual void machine_start() override;
|
||||
virtual void machine_reset() override;
|
||||
@ -100,6 +111,7 @@ public:
|
||||
DECLARE_READ8_MEMBER( touchscreen_r );
|
||||
DECLARE_WRITE8_MEMBER( touchscreen_w );
|
||||
DECLARE_WRITE_LINE_MEMBER( alarm_irq );
|
||||
DECLARE_WRITE_LINE_MEMBER( serial_irq );
|
||||
|
||||
DECLARE_PALETTE_INIT(rex6000);
|
||||
DECLARE_INPUT_CHANGED_MEMBER(trigger_irq);
|
||||
@ -110,6 +122,31 @@ public:
|
||||
};
|
||||
|
||||
|
||||
class oz750_state : public rex6000_state
|
||||
{
|
||||
public:
|
||||
oz750_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: rex6000_state(mconfig, type, tag),
|
||||
m_keyboard(*this, "COL")
|
||||
{ }
|
||||
|
||||
optional_ioport_array<10> m_keyboard;
|
||||
|
||||
DECLARE_READ8_MEMBER( kb_status_r );
|
||||
DECLARE_READ8_MEMBER( kb_data_r );
|
||||
DECLARE_WRITE8_MEMBER( kb_mask_w );
|
||||
DECLARE_INPUT_CHANGED_MEMBER(trigger_on_irq);
|
||||
DECLARE_QUICKLOAD_LOAD_MEMBER(oz750);
|
||||
|
||||
virtual void machine_reset() override;
|
||||
UINT32 screen_update_oz(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
|
||||
|
||||
private:
|
||||
int oz_wzd_extract_tag(const dynamic_buffer &data, const char *tag, char *dest_buf);
|
||||
|
||||
UINT16 m_kb_mask;
|
||||
};
|
||||
|
||||
|
||||
READ8_MEMBER( rex6000_state::bankswitch_r )
|
||||
{
|
||||
@ -254,14 +291,17 @@ WRITE8_MEMBER( rex6000_state::irq_w )
|
||||
case 2: //irq mask
|
||||
m_irq_mask = data;
|
||||
break;
|
||||
case 3: //power control
|
||||
m_power_on = data & 1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
READ8_MEMBER( rex6000_state::touchscreen_r )
|
||||
{
|
||||
UINT16 x = ioport("PENX")->read();
|
||||
UINT16 y = ioport("PENY")->read();
|
||||
UINT16 battery = ioport("BATTERY")->read();
|
||||
UINT16 x = m_pen_x->read();
|
||||
UINT16 y = m_pen_y->read();
|
||||
UINT16 battery = m_battery->read();
|
||||
|
||||
switch (offset)
|
||||
{
|
||||
@ -291,6 +331,32 @@ WRITE8_MEMBER( rex6000_state::touchscreen_w )
|
||||
m_touchscreen[offset&0x0f] = data;
|
||||
}
|
||||
|
||||
READ8_MEMBER( oz750_state::kb_status_r )
|
||||
{
|
||||
UINT8 data = 0x6b;
|
||||
if (m_battery->read() & 0x01) data |= 0x80;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
READ8_MEMBER( oz750_state::kb_data_r )
|
||||
{
|
||||
UINT8 data = 0;
|
||||
for(int i=0; i<10; i++)
|
||||
{
|
||||
if (m_kb_mask & (1<<i))
|
||||
data |= m_keyboard[i]->read();
|
||||
}
|
||||
|
||||
return data;
|
||||
}
|
||||
WRITE8_MEMBER( oz750_state::kb_mask_w )
|
||||
{
|
||||
if (offset)
|
||||
m_kb_mask = (m_kb_mask & 0x00ff) | (data << 8);
|
||||
else
|
||||
m_kb_mask = (m_kb_mask & 0xff00) | data;
|
||||
}
|
||||
|
||||
static ADDRESS_MAP_START(rex6000_banked_map, AS_PROGRAM, 8, rex6000_state)
|
||||
AM_RANGE( 0x0000000, 0x00fffff ) AM_DEVREADWRITE("flash0a", intelfsh8_device, read, write)
|
||||
@ -302,6 +368,13 @@ static ADDRESS_MAP_START(rex6000_banked_map, AS_PROGRAM, 8, rex6000_state)
|
||||
AM_RANGE( 0x2000000, 0x2007fff ) AM_RAM AM_SHARE("nvram")
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static ADDRESS_MAP_START(oz750_banked_map, AS_PROGRAM, 8, oz750_state)
|
||||
AM_RANGE( 0x0000000, 0x01fffff ) AM_DEVREADWRITE("flash0a", intelfsh8_device, read, write)
|
||||
AM_RANGE( 0x0200000, 0x02fffff ) AM_MIRROR(0x100000) AM_DEVREADWRITE("flash1a", intelfsh8_device, read, write)
|
||||
AM_RANGE( 0x0600000, 0x07fffff ) AM_READWRITE(lcd_io_r, lcd_io_w)
|
||||
AM_RANGE( 0x0800000, 0x083ffff ) AM_MIRROR(0x1c0000) AM_RAM AM_SHARE("nvram")
|
||||
AM_RANGE( 0x0a00000, 0x0a3ffff ) AM_MIRROR(0x1c0000) AM_RAM
|
||||
ADDRESS_MAP_END
|
||||
|
||||
|
||||
static ADDRESS_MAP_START(rex6000_mem, AS_PROGRAM, 8, rex6000_state)
|
||||
@ -321,10 +394,22 @@ static ADDRESS_MAP_START( rex6000_io, AS_IO, 8, rex6000_state)
|
||||
AM_RANGE( 0x15, 0x19 ) AM_READWRITE(beep_r, beep_w)
|
||||
AM_RANGE( 0x22, 0x23 ) AM_READWRITE(lcd_base_r, lcd_base_w)
|
||||
AM_RANGE( 0x30, 0x3f ) AM_DEVREADWRITE(TC8521_TAG, rp5c01_device, read, write)
|
||||
AM_RANGE( 0x40, 0x47 ) AM_MIRROR(0x08) AM_NOP //SIO
|
||||
AM_RANGE( 0x40, 0x47 ) AM_MIRROR(0x08) AM_DEVREADWRITE("ns16550", ns16550_device, ins8250_r, ins8250_w )
|
||||
AM_RANGE( 0x50, 0x51 ) AM_READWRITE(lcd_io_r, lcd_io_w)
|
||||
AM_RANGE( 0x60, 0x6f ) AM_READWRITE(touchscreen_r, touchscreen_w)
|
||||
//AM_RANGE( 0x00, 0xff ) AM_RAM
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static ADDRESS_MAP_START( oz750_io, AS_IO, 8, oz750_state)
|
||||
ADDRESS_MAP_UNMAP_HIGH
|
||||
ADDRESS_MAP_GLOBAL_MASK(0xff)
|
||||
AM_RANGE( 0x01, 0x04 ) AM_READWRITE(bankswitch_r, bankswitch_w)
|
||||
AM_RANGE( 0x05, 0x08 ) AM_READWRITE(irq_r, irq_w)
|
||||
AM_RANGE( 0x10, 0x10 ) AM_READ(kb_data_r)
|
||||
AM_RANGE( 0x11, 0x12 ) AM_READWRITE(kb_status_r, kb_mask_w)
|
||||
AM_RANGE( 0x15, 0x19 ) AM_READWRITE(beep_r, beep_w)
|
||||
AM_RANGE( 0x22, 0x23 ) AM_READWRITE(lcd_base_r, lcd_base_w)
|
||||
AM_RANGE( 0x30, 0x3f ) AM_DEVREADWRITE(TC8521_TAG, rp5c01_device, read, write)
|
||||
AM_RANGE( 0x40, 0x47 ) AM_MIRROR(0x08) AM_DEVREADWRITE("ns16550", ns16550_device, ins8250_r, ins8250_w )
|
||||
ADDRESS_MAP_END
|
||||
|
||||
INPUT_CHANGED_MEMBER(rex6000_state::trigger_irq)
|
||||
@ -337,6 +422,18 @@ INPUT_CHANGED_MEMBER(rex6000_state::trigger_irq)
|
||||
}
|
||||
}
|
||||
|
||||
INPUT_CHANGED_MEMBER(oz750_state::trigger_on_irq)
|
||||
{
|
||||
m_uart->cts_w(!newval);
|
||||
|
||||
if (!(m_irq_mask & IRQ_FLAG_EVENT))
|
||||
{
|
||||
m_irq_flag |= IRQ_FLAG_EVENT;
|
||||
|
||||
m_maincpu->set_input_line(0, HOLD_LINE);
|
||||
}
|
||||
}
|
||||
|
||||
/* Input ports */
|
||||
INPUT_PORTS_START( rex6000 )
|
||||
PORT_START("BATTERY")
|
||||
@ -359,6 +456,116 @@ INPUT_PORTS_START( rex6000 )
|
||||
PORT_BIT(0x3ff, 0x00, IPT_LIGHTGUN_Y) PORT_NAME("Pen Y") PORT_CROSSHAIR(Y, 1, 0, 0) PORT_SENSITIVITY(50) PORT_KEYDELTA(10) PORT_INVERT
|
||||
INPUT_PORTS_END
|
||||
|
||||
INPUT_PORTS_START( oz750 )
|
||||
PORT_START("BATTERY")
|
||||
PORT_CONFNAME( 0x01, 0x01, "Battery Status" )
|
||||
PORT_CONFSETTING( 0x01, "Normal operating mode" )
|
||||
PORT_CONFSETTING( 0x00, "Replace battery mode" )
|
||||
|
||||
PORT_START("ON")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_0_PAD) PORT_NAME("ON") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_on_irq, 0)
|
||||
|
||||
PORT_START("COL.0")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ESC) PORT_CHAR(UCHAR_MAMEKEY(ESC)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Q) PORT_CHAR('Q') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_G) PORT_CHAR('G') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_A) PORT_CHAR('A') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LSHIFT) PORT_CHAR(UCHAR_MAMEKEY(LSHIFT)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LCONTROL) PORT_CHAR(UCHAR_MAMEKEY(LCONTROL)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.1")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_V) PORT_CHAR('V') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y) PORT_CHAR('Y') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_H) PORT_CHAR('H') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_S) PORT_CHAR('S') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z) PORT_CHAR('Z') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F1) PORT_NAME("MENU") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.2")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_E) PORT_CHAR('E') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_U) PORT_CHAR('U') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_J) PORT_CHAR('J') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_D) PORT_CHAR('D') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_X) PORT_CHAR('X') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F2) PORT_NAME("NEW") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.3")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_R) PORT_CHAR('R') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_I) PORT_CHAR('I') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_K) PORT_CHAR('K') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F) PORT_CHAR('F') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_C) PORT_CHAR('C') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F3) PORT_CHAR(UCHAR_MAMEKEY(F3)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.4")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_T) PORT_CHAR('T') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_O) PORT_CHAR('O') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_L) PORT_CHAR('L') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_V) PORT_CHAR('V') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.5")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_P) PORT_CHAR('P') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ENTER_PAD) PORT_NAME("RETURN") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_B) PORT_CHAR('B') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.6")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_6) PORT_CHAR('5') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_9) PORT_CHAR('8') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_DEL) PORT_CHAR(UCHAR_MAMEKEY(DEL)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_RSHIFT) PORT_CHAR(UCHAR_MAMEKEY(RSHIFT)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_N) PORT_CHAR('N') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.7")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_COMMA) PORT_CHAR(',') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_M) PORT_CHAR('M') PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.8")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F4) PORT_NAME("MENU Screen") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F5) PORT_NAME("ESC Screen") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F6) PORT_NAME("ENTER Screen") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_PGUP) PORT_CHAR(UCHAR_MAMEKEY(PGUP)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_PGDN) PORT_CHAR(UCHAR_MAMEKEY(PGDN)) PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
|
||||
PORT_START("COL.9")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F7) PORT_NAME("MAIN") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F8) PORT_NAME("TEL") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F9) PORT_NAME("SCHEDULE") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F10) PORT_NAME("MEMO") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F11) PORT_NAME("My Programs") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F12) PORT_NAME("Backlight") PORT_CHANGED_MEMBER(DEVICE_SELF, oz750_state, trigger_irq, 0)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED)
|
||||
INPUT_PORTS_END
|
||||
|
||||
void rex6000_state::machine_start()
|
||||
{
|
||||
membank("ram")->set_base((UINT8*)m_nvram + 0x4000);
|
||||
@ -376,6 +583,13 @@ void rex6000_state::machine_reset()
|
||||
m_irq_flag = 0;
|
||||
m_port6 = 0;
|
||||
m_beep_mode = 0;
|
||||
m_power_on = 0;
|
||||
}
|
||||
|
||||
void oz750_state::machine_reset()
|
||||
{
|
||||
rex6000_state::machine_reset();
|
||||
m_kb_mask = 0;
|
||||
}
|
||||
|
||||
UINT32 rex6000_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
|
||||
@ -404,6 +618,32 @@ UINT32 rex6000_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap,
|
||||
return 0;
|
||||
}
|
||||
|
||||
UINT32 oz750_state::screen_update_oz(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
|
||||
{
|
||||
UINT16 lcd_bank = MAKE_BANK(m_lcd_base[0], m_lcd_base[1]);
|
||||
|
||||
if (m_lcd_enabled && m_power_on)
|
||||
{
|
||||
for (int y=0; y<=cliprect.max_y; y++)
|
||||
for (int x=0; x<30; x++)
|
||||
{
|
||||
UINT8 data = m_bankdev0->space(AS_PROGRAM).read_byte((lcd_bank << 13) + y*30 + x);
|
||||
|
||||
for (int b=0; b<8; b++)
|
||||
{
|
||||
bitmap.pix16(y, (x * 8) + b) = BIT(data, 0);
|
||||
data >>= 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
bitmap.fill(0, cliprect);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
TIMER_DEVICE_CALLBACK_MEMBER(rex6000_state::irq_timer1)
|
||||
{
|
||||
if (!(m_irq_mask & IRQ_FLAG_IRQ2))
|
||||
@ -444,6 +684,14 @@ WRITE_LINE_MEMBER( rex6000_state::alarm_irq )
|
||||
}
|
||||
}
|
||||
|
||||
WRITE_LINE_MEMBER( rex6000_state::serial_irq )
|
||||
{
|
||||
if (!(m_irq_mask & IRQ_FLAG_SERIAL))
|
||||
{
|
||||
m_irq_flag |= IRQ_FLAG_SERIAL;
|
||||
m_maincpu->set_input_line(0, HOLD_LINE);
|
||||
}
|
||||
}
|
||||
|
||||
PALETTE_INIT_MEMBER(rex6000_state, rex6000)
|
||||
{
|
||||
@ -472,6 +720,104 @@ QUICKLOAD_LOAD_MEMBER( rex6000_state,rex6000)
|
||||
return IMAGE_INIT_PASS;
|
||||
}
|
||||
|
||||
int oz750_state::oz_wzd_extract_tag(const dynamic_buffer &data, const char *tag, char *dest_buf)
|
||||
{
|
||||
int tag_len = strlen(tag);
|
||||
UINT32 img_start = 0;
|
||||
for (img_start=0; img_start < data.size() - tag_len; img_start++)
|
||||
if (data[img_start] && !memcmp(&data[img_start], tag, tag_len))
|
||||
break;
|
||||
|
||||
if (img_start >= data.size() - tag_len)
|
||||
{
|
||||
if (dest_buf)
|
||||
strcpy(dest_buf, "NONE");
|
||||
return 0;
|
||||
}
|
||||
|
||||
img_start += tag_len;
|
||||
|
||||
while(data[img_start] == '\r' || data[img_start] == '\n')
|
||||
img_start++;
|
||||
|
||||
if (dest_buf)
|
||||
{
|
||||
UINT32 i;
|
||||
for (i=0; data[img_start + i] != 0 && data[img_start + i] != '\n' && data[img_start + i] != '\r'; i++)
|
||||
dest_buf[i] = data[img_start + i];
|
||||
|
||||
dest_buf[i] = '\0';
|
||||
}
|
||||
|
||||
return img_start;
|
||||
}
|
||||
|
||||
QUICKLOAD_LOAD_MEMBER(oz750_state,oz750)
|
||||
{
|
||||
address_space* flash = &machine().device("flash0a")->memory().space(0);
|
||||
dynamic_buffer data(image.length());
|
||||
image.fread(&data[0], image.length());
|
||||
|
||||
const char *fs_type = "BSIC";
|
||||
char data_type[0x100];
|
||||
char app_name[0x100];
|
||||
char file_name[0x100];
|
||||
|
||||
oz_wzd_extract_tag(data, "<DATA TYPE>", data_type);
|
||||
if (strcmp(data_type, "MY PROGRAMS"))
|
||||
return IMAGE_INIT_FAIL;
|
||||
|
||||
oz_wzd_extract_tag(data, "<TITLE>", app_name);
|
||||
oz_wzd_extract_tag(data, "<DATA>", file_name);
|
||||
if (!strncmp(file_name, "PFILE:", 6))
|
||||
strcpy(file_name, file_name + 6);
|
||||
|
||||
UINT32 img_start = oz_wzd_extract_tag(data, "<BIN>", NULL);
|
||||
|
||||
if (img_start == 0)
|
||||
return IMAGE_INIT_FAIL;
|
||||
|
||||
UINT16 icon_size = data[img_start++];
|
||||
|
||||
UINT32 pos = 0xc0000;
|
||||
flash->write_byte(pos++, 0x4f);
|
||||
|
||||
for (int i=0; fs_type[i]; i++)
|
||||
flash->write_byte(pos++, fs_type[i]); // file type
|
||||
|
||||
flash->write_byte(pos++, 0xff);
|
||||
flash->write_byte(pos++, 0xff);
|
||||
flash->write_byte(pos++, 0xff);
|
||||
flash->write_byte(pos++, 0x10 + icon_size); // filename offset LSB
|
||||
flash->write_byte(pos++, 0x00); // filename offset MSB
|
||||
flash->write_byte(pos++, 0x11 + icon_size + strlen(file_name)); // title offset LSB
|
||||
flash->write_byte(pos++, 0x00); // title offset MSB
|
||||
flash->write_byte(pos++, 0x12 + icon_size + strlen(file_name) + strlen(app_name)); // data offset LSB
|
||||
flash->write_byte(pos++, 0x00); // data offset MSB
|
||||
flash->write_byte(pos++, 1);
|
||||
flash->write_byte(pos++, 1);
|
||||
|
||||
flash->write_byte(pos++, icon_size); // icon size
|
||||
|
||||
for (int i=0; i<icon_size; i++)
|
||||
flash->write_byte(pos++, data[img_start++]); // icon data
|
||||
|
||||
for (int i=0, slen = strlen(file_name); i <= slen; i++)
|
||||
flash->write_byte(pos++, file_name[i]); // filename
|
||||
|
||||
for (int i=0, slen = strlen(app_name); i <= slen; i++)
|
||||
flash->write_byte(pos++, app_name[i]); // title
|
||||
|
||||
UINT16 size = (UINT16)image.length() - img_start;
|
||||
flash->write_byte(pos++, size); // data size LSB
|
||||
flash->write_byte(pos++, size >> 8); // data size MSB
|
||||
|
||||
for (int i=img_start; i<image.length(); i++)
|
||||
flash->write_byte(pos++, data[i]); // data
|
||||
|
||||
return IMAGE_INIT_PASS;
|
||||
}
|
||||
|
||||
|
||||
/* F4 Character Displayer */
|
||||
static const gfx_layout rex6000_bold_charlayout =
|
||||
@ -557,6 +903,19 @@ static MACHINE_CONFIG_START( rex6000, rex6000_state )
|
||||
MCFG_ADDRESS_MAP_BANK_DATABUS_WIDTH(8)
|
||||
MCFG_ADDRESS_MAP_BANK_STRIDE(0x2000)
|
||||
|
||||
MCFG_DEVICE_ADD( "ns16550", NS16550, XTAL_1_8432MHz )
|
||||
MCFG_INS8250_OUT_TX_CB(DEVWRITELINE("serport", rs232_port_device, write_txd))
|
||||
MCFG_INS8250_OUT_DTR_CB(DEVWRITELINE("serport", rs232_port_device, write_dtr))
|
||||
MCFG_INS8250_OUT_RTS_CB(DEVWRITELINE("serport", rs232_port_device, write_rts))
|
||||
MCFG_INS8250_OUT_INT_CB(WRITELINE(rex6000_state, serial_irq))
|
||||
|
||||
MCFG_RS232_PORT_ADD( "serport", default_rs232_devices, nullptr )
|
||||
MCFG_RS232_RXD_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, rx_w))
|
||||
MCFG_RS232_DCD_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, dcd_w))
|
||||
MCFG_RS232_DSR_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, dsr_w))
|
||||
MCFG_RS232_RI_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, ri_w))
|
||||
MCFG_RS232_CTS_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, cts_w))
|
||||
|
||||
/* quickload */
|
||||
MCFG_QUICKLOAD_ADD("quickload", rex6000_state, rex6000, "rex,ds2", 0)
|
||||
|
||||
@ -585,6 +944,73 @@ static MACHINE_CONFIG_START( rex6000, rex6000_state )
|
||||
MCFG_SOUND_ROUTE( ALL_OUTPUTS, "mono", 1.00 )
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
static MACHINE_CONFIG_START( oz750, oz750_state )
|
||||
/* basic machine hardware */
|
||||
MCFG_CPU_ADD("maincpu",Z80, XTAL_9_8304MHz) //Toshiba microprocessor Z80 compatible at 9.8MHz
|
||||
MCFG_CPU_PROGRAM_MAP(rex6000_mem)
|
||||
MCFG_CPU_IO_MAP(oz750_io)
|
||||
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("sec_timer", rex6000_state, sec_timer, attotime::from_hz(1))
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("irq_timer1", rex6000_state, irq_timer1, attotime::from_hz(64))
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("irq_timer2", rex6000_state, irq_timer2, attotime::from_hz(8192))
|
||||
|
||||
MCFG_DEVICE_ADD( "ns16550", NS16550, XTAL_9_8304MHz / 4 )
|
||||
MCFG_INS8250_OUT_TX_CB(DEVWRITELINE("serport", rs232_port_device, write_txd))
|
||||
MCFG_INS8250_OUT_DTR_CB(DEVWRITELINE("serport", rs232_port_device, write_dtr))
|
||||
MCFG_INS8250_OUT_RTS_CB(DEVWRITELINE("serport", rs232_port_device, write_rts))
|
||||
MCFG_INS8250_OUT_INT_CB(WRITELINE(rex6000_state, serial_irq))
|
||||
|
||||
MCFG_RS232_PORT_ADD( "serport", default_rs232_devices, NULL )
|
||||
MCFG_RS232_RXD_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, rx_w))
|
||||
MCFG_RS232_DCD_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, dcd_w))
|
||||
MCFG_RS232_DSR_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, dsr_w))
|
||||
MCFG_RS232_RI_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, ri_w))
|
||||
//MCFG_RS232_CTS_HANDLER(DEVWRITELINE("ns16550", ins8250_uart_device, cts_w))
|
||||
|
||||
/* video hardware */
|
||||
MCFG_SCREEN_ADD("screen", LCD)
|
||||
MCFG_SCREEN_REFRESH_RATE(50)
|
||||
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500)) /* not accurate */
|
||||
MCFG_SCREEN_UPDATE_DRIVER(oz750_state, screen_update_oz)
|
||||
MCFG_SCREEN_SIZE(240, 80)
|
||||
MCFG_SCREEN_VISIBLE_AREA(0, 240-1, 0, 80-1)
|
||||
MCFG_SCREEN_PALETTE("palette")
|
||||
|
||||
MCFG_DEFAULT_LAYOUT(layout_lcd)
|
||||
MCFG_PALETTE_ADD("palette", 2)
|
||||
MCFG_PALETTE_INIT_OWNER(rex6000_state, rex6000)
|
||||
|
||||
MCFG_DEVICE_ADD("bank0", ADDRESS_MAP_BANK, 0)
|
||||
MCFG_DEVICE_PROGRAM_MAP(oz750_banked_map)
|
||||
MCFG_ADDRESS_MAP_BANK_ENDIANNESS(ENDIANNESS_LITTLE)
|
||||
MCFG_ADDRESS_MAP_BANK_DATABUS_WIDTH(8)
|
||||
MCFG_ADDRESS_MAP_BANK_STRIDE(0x2000)
|
||||
|
||||
MCFG_DEVICE_ADD("bank1", ADDRESS_MAP_BANK, 0)
|
||||
MCFG_DEVICE_PROGRAM_MAP(oz750_banked_map)
|
||||
MCFG_ADDRESS_MAP_BANK_ENDIANNESS(ENDIANNESS_LITTLE)
|
||||
MCFG_ADDRESS_MAP_BANK_DATABUS_WIDTH(8)
|
||||
MCFG_ADDRESS_MAP_BANK_STRIDE(0x2000)
|
||||
|
||||
/* quickload */
|
||||
MCFG_QUICKLOAD_ADD("quickload", oz750_state, oz750, "wzd", 0)
|
||||
|
||||
MCFG_DEVICE_ADD(TC8521_TAG, RP5C01, XTAL_32_768kHz)
|
||||
MCFG_RP5C01_OUT_ALARM_CB(WRITELINE(rex6000_state, alarm_irq))
|
||||
|
||||
MCFG_SHARP_LH28F016S_ADD("flash0a")
|
||||
MCFG_SHARP_LH28F016S_ADD("flash1a")
|
||||
|
||||
/* internal ram */
|
||||
MCFG_RAM_ADD(RAM_TAG)
|
||||
MCFG_RAM_DEFAULT_SIZE("512K")
|
||||
|
||||
/* sound hardware */
|
||||
MCFG_SPEAKER_STANDARD_MONO( "mono" )
|
||||
MCFG_SOUND_ADD( "beeper", BEEP, 0 )
|
||||
MCFG_SOUND_ROUTE( ALL_OUTPUTS, "mono", 1.00 )
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
/* ROM definition */
|
||||
ROM_START( rex6000 )
|
||||
ROM_REGION( 0x200000, "flash0a", ROMREGION_ERASE )
|
||||
@ -614,8 +1040,17 @@ ROM_START( ds2 )
|
||||
ROM_LOAD( "ds2_3.dat", 0x0000, 0x100000, BAD_DUMP CRC(64f7c189) SHA1(a47d3413ddb879083c3aec03a42fe357d3a3c10a))
|
||||
ROM_END
|
||||
|
||||
ROM_START( oz750 )
|
||||
ROM_REGION( 0x200000, "flash0a", ROMREGION_ERASEFF )
|
||||
ROM_LOAD( "oz750_0.bin", 0x0000, 0x200000, CRC(bf321bab) SHA1(2fb44a870b26aebf4b949b5de84fb39cd9205191))
|
||||
|
||||
ROM_REGION( 0x200000, "flash1a", ROMREGION_ERASEFF )
|
||||
ROM_LOAD( "oz750_1.bin", 0x0000, 0x100000, CRC(d74e97d7) SHA1(19d17393a9af85e07773feaf1aed5e2cfa80f7cc))
|
||||
ROM_END
|
||||
|
||||
/* Driver */
|
||||
|
||||
/* YEAR NAME PARENT COMPAT MACHINE INPUT INIT COMPANY FULLNAME FLAGS */
|
||||
COMP( 199?, oz750, 0, 0, oz750 , oz750, driver_device, 0, "Sharp", "Wizard OZ-750", MACHINE_NOT_WORKING | MACHINE_NO_SOUND)
|
||||
COMP( 2000, rex6000, 0, 0, rex6000, rex6000, driver_device, 0, "Xircom / Intel", "REX 6000", MACHINE_NOT_WORKING | MACHINE_NO_SOUND)
|
||||
COMP( 2000, ds2, rex6000, 0, rex6000, rex6000, driver_device, 0, "Citizen", "DataSlim 2", MACHINE_NOT_WORKING | MACHINE_NO_SOUND)
|
||||
|
@ -30805,6 +30805,7 @@ retofinv2 // bootleg
|
||||
|
||||
//@source:rex6000.cpp
|
||||
ds2 //
|
||||
oz750 // 199? Sharp Wizard OZ-750
|
||||
rex6000 //
|
||||
|
||||
//@source:rgum.cpp
|
||||
|
Loading…
Reference in New Issue
Block a user