diff --git a/scripts/src/bus.lua b/scripts/src/bus.lua index bf5aef132eb..4892fd8b9b1 100644 --- a/scripts/src/bus.lua +++ b/scripts/src/bus.lua @@ -2232,6 +2232,19 @@ if (BUSES["PSION_HONDA"]~=null) then end +--------------------------------------------------- +-- +--@src/devices/bus/psion/module/slot.h,BUSES["PSION_MODULE"] = true +--------------------------------------------------- + +if (BUSES["PSION_MODULE"]~=null) then + files { + MAME_DIR .. "src/devices/bus/psion/module/slot.cpp", + MAME_DIR .. "src/devices/bus/psion/module/slot.h", + } +end + + --------------------------------------------------- -- --@src/devices/bus/psion/sibo/slot.h,BUSES["PSION_SIBO"] = true diff --git a/src/devices/bus/psion/module/slot.cpp b/src/devices/bus/psion/module/slot.cpp new file mode 100644 index 00000000000..b2f8787f49e --- /dev/null +++ b/src/devices/bus/psion/module/slot.cpp @@ -0,0 +1,116 @@ +// license:BSD-3-Clause +// copyright-holders:Nigel Barnes +/********************************************************************** + + Psion Extended Internal Expansion slot emulation + + This port is on Series MC/HC machines only. + +**********************************************************************/ + +#include "emu.h" +#include "slot.h" + + +//************************************************************************** +// DEVICE DEFINITIONS +//************************************************************************** + +DEFINE_DEVICE_TYPE(PSION_MODULE_SLOT, psion_module_slot_device, "psion_module_slot", "Psion Extended Internal Expansion slot") + + +//************************************************************************** +// DEVICE PSION_EXP PORT INTERFACE +//************************************************************************** + +//------------------------------------------------- +// device_psion_module_interface - constructor +//------------------------------------------------- + +device_psion_module_interface::device_psion_module_interface(const machine_config &mconfig, device_t &device) : + device_interface(device, "psionmodule") +{ + m_slot = dynamic_cast(device.owner()); +} + + +//************************************************************************** +// LIVE DEVICE +//************************************************************************** + +//------------------------------------------------- +// psion_module_slot_device - constructor +//------------------------------------------------- + +psion_module_slot_device::psion_module_slot_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock) + : device_t(mconfig, PSION_MODULE_SLOT, tag, owner, clock) + , device_single_card_slot_interface(mconfig, *this) + , m_card(nullptr) + , m_intr_cb(*this) +{ +} + + +//------------------------------------------------- +// device_start - device-specific startup +//------------------------------------------------- + +void psion_module_slot_device::device_start() +{ + m_card = get_card_device(); + + // resolve callbacks + m_intr_cb.resolve_safe(); +} + + +//------------------------------------------------- +// read +//------------------------------------------------- + +uint8_t psion_module_slot_device::data_r() +{ + return m_card ? m_card->data_r() : 0x00; +} + +uint8_t psion_module_slot_device::io_r(offs_t offset) +{ + if (m_card) + return m_card->io_r(offset); + else + return 0x00; +} + + +//------------------------------------------------- +// write +//------------------------------------------------- + +void psion_module_slot_device::data_w(uint16_t data) +{ + if (m_card) + m_card->data_w(data); +} + +void psion_module_slot_device::io_w(offs_t offset, uint8_t data) +{ + if (m_card) + m_card->io_w(offset, data); +} + + +//------------------------------------------------- +// SLOT_INTERFACE( psion_module_devices ) +//------------------------------------------------- + +// slot devices +//#include "rs232parallel" +//#include "rs232ttl" + +void psion_hcmodule_devices(device_slot_interface &device) +{ +} + +void psion_mcmodule_devices(device_slot_interface &device) +{ +} diff --git a/src/devices/bus/psion/module/slot.h b/src/devices/bus/psion/module/slot.h new file mode 100644 index 00000000000..6ba31dff0f6 --- /dev/null +++ b/src/devices/bus/psion/module/slot.h @@ -0,0 +1,116 @@ +// license:BSD-3-Clause +// copyright-holders:Nigel Barnes +/********************************************************************** + + Psion Extended Internal Expansion slot emulation + +********************************************************************** + + Pin Name Comments + + 1 GND Should mate first when device inserted + 2 GND Should mate first when device inserted + 3 AD0 8 bit multiplexed address and data bus pulled low + 4 AD1 + 5 AD2 + 6 AD3 + 7 AD4 + 8 AD5 + 9 AD6 + 10 AD7 + 11 ALE Address latch enable - high when valid address on AD0-AD7 + 12 IOWR I/O write strobe - active high, data valid on falling edge + 13 IORD I/O read strobe - high when device can place valid data on AD0-AD7 + 14 EES External Expansion Select - high during I/O cycles to expansion device + 15 SCLX 512 KHz SCL signal for SLD bus - usually Hi-Z and pulled low + 16 DNC For future expansion - do not use + 17 THERM Connected to thermistor + 18 VB1 Connected to internal NiCd battery + 19 Vsup Unregulated battery voltage - present all the time + 20 INTR Active high interrupt input + 21 _EXON Active low input pulled up to Vcc1 - pull low to switch machine on + 22 SD SIBO serial protocol data line - pulled low + 23 SCLK SIBO serial protocol clock line - Hi-Z in standby needs a pull down + 24 GND 0v + 25 Vcc2 +5 volt supply, switched off in standby + +**********************************************************************/ + +#ifndef MAME_BUS_PSION_MODULE_SLOT_H +#define MAME_BUS_PSION_MODULE_SLOT_H + +#pragma once + + +//************************************************************************** +// TYPE DEFINITIONS +//************************************************************************** + +// ======================> psion_module_slot_device + +class device_psion_module_interface; + +class psion_module_slot_device : public device_t, public device_single_card_slot_interface +{ +public: + // construction/destruction + template + psion_module_slot_device(machine_config const &mconfig, char const *tag, device_t *owner, T &&slot_options, const char *default_option) + : psion_module_slot_device(mconfig, tag, owner) + { + option_reset(); + slot_options(*this); + set_default_option(default_option); + set_fixed(false); + } + + psion_module_slot_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock = 0); + + // callbacks + auto intr_cb() { return m_intr_cb.bind(); } + + uint8_t io_r(offs_t offset); + void io_w(offs_t offset, uint8_t data); + + uint8_t data_r(); + void data_w(uint16_t data); + + DECLARE_WRITE_LINE_MEMBER( intr_w ) { m_intr_cb(state); } + +protected: + // device-level overrides + virtual void device_start() override; + + device_psion_module_interface *m_card; + +private: + devcb_write_line m_intr_cb; +}; + + +// ======================> device_psion_module_interface + +class device_psion_module_interface : public device_interface +{ +public: + virtual uint8_t io_r(offs_t offset) { return 0x00; } + virtual void io_w(offs_t offset, uint8_t data) { } + + virtual uint8_t data_r() { return 0x00; } + virtual void data_w(uint16_t data) { } + +protected: + device_psion_module_interface(const machine_config &mconfig, device_t &device); + + psion_module_slot_device *m_slot; +}; + + +// device type definition +DECLARE_DEVICE_TYPE(PSION_MODULE_SLOT, psion_module_slot_device) + +void psion_hcmodule_devices(device_slot_interface &device); +void psion_mcmodule_devices(device_slot_interface &device); + + +#endif // MAME_BUS_PSION_MODULE_SLOT_H diff --git a/src/mame/mame.lst b/src/mame/mame.lst index 7923afd3d58..38b29e4fee6 100755 --- a/src/mame/mame.lst +++ b/src/mame/mame.lst @@ -37735,7 +37735,12 @@ psion3c // 1996 Psion Series 3c psion3mx // 1998 Psion Series 3mx @source:psion/psion5.cpp -psion5mx // +psion5mx // 1999 Psion Series 5mx + +@source:psion/psionhc.cpp +psionhc100 // 1991 Psion HC 100 +psionhc110 // 1991 Psion HC 110 +psionhc120 // 1991 Psion HC 120 @source:psion/siena.cpp siena // 1996 Psion Siena diff --git a/src/mame/psion/psionhc.cpp b/src/mame/psion/psionhc.cpp new file mode 100644 index 00000000000..3810bc8e699 --- /dev/null +++ b/src/mame/psion/psionhc.cpp @@ -0,0 +1,377 @@ +// license:BSD-3-Clause +// copyright-holders:Nigel Barnes +/****************************************************************************** + + Psion HC Series + + TODO: + - battery backed RAM + +******************************************************************************/ + +#include "emu.h" +#include "cpu/nec/nec.h" +#include "machine/psion_asic1.h" +#include "machine/psion_asic2.h" +#include "machine/psion_asic3.h" +#include "machine/psion_ssd.h" +#include "machine/ram.h" +#include "sound/spkrdev.h" +#include "bus/psion/module/slot.h" + +#include "emupal.h" +#include "screen.h" +#include "softlist_dev.h" +#include "speaker.h" +#include "utf8.h" + + +namespace { + +class psionhc_state : public driver_device +{ +public: + psionhc_state(const machine_config &mconfig, device_type type, const char *tag) + : driver_device(mconfig, type, tag) + , m_maincpu(*this, "maincpu") + , m_asic1(*this, "asic1") + , m_asic2(*this, "asic2") + , m_asic3(*this, "asic3") + , m_ram(*this, "ram") + , m_palette(*this, "palette") + , m_keyboard(*this, "COL%u", 0U) + , m_speaker(*this, "speaker") + , m_ssd(*this, "ssd%u", 1U) + , m_exp(*this, "exp%u", 0U) + { } + + void psionhc100(machine_config &config); + void psionhc110(machine_config &config); + void psionhc120(machine_config &config); + + DECLARE_INPUT_CHANGED_MEMBER(key_on); + +protected: + virtual void machine_start() override; + virtual void machine_reset() override; + +private: + required_device m_maincpu; + required_device m_asic1; + required_device m_asic2; + required_device m_asic3; + required_device m_ram; + required_device m_palette; + required_ioport_array<8> m_keyboard; + required_device m_speaker; + required_device_array m_ssd; + required_device_array m_exp; + + void palette_init(palette_device &palette); + + void mem_map(address_map &map); + void io_map(address_map &map); + void asic1_map(address_map &map); + + int m_dr = 0; +}; + + +void psionhc_state::machine_start() +{ + m_asic1->space(0).install_ram(0, m_ram->mask(), m_ram->pointer()); +} + +void psionhc_state::machine_reset() +{ +} + + +void psionhc_state::mem_map(address_map &map) +{ + map(0x00000, 0xfffff).rw(m_asic1, FUNC(psion_asic1_device::mem_r), FUNC(psion_asic1_device::mem_w)); +} + +void psionhc_state::io_map(address_map &map) +{ + map(0x0000, 0x001f).rw(m_asic1, FUNC(psion_asic1_device::io_r), FUNC(psion_asic1_device::io_w)); + map(0x0080, 0x008f).rw(m_asic2, FUNC(psion_asic2_device::io_r), FUNC(psion_asic2_device::io_w)).umask16(0x00ff); + map(0x0100, 0x01ff).rw(m_exp[0], FUNC(psion_module_slot_device::io_r), FUNC(psion_module_slot_device::io_w)); + map(0x0200, 0x02ff).rw(m_exp[1], FUNC(psion_module_slot_device::io_r), FUNC(psion_module_slot_device::io_w)); +} + +void psionhc_state::asic1_map(address_map &map) +{ + map(0x80000, 0xfffff).rom().region("flash", 0); +} + + +static INPUT_PORTS_START( psionhc_uk ) + PORT_START("COL0") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT)) PORT_NAME(UTF8_RIGHT" Info") + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT)) PORT_NAME(UTF8_LEFT" Task") + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN)) PORT_NAME(UTF8_DOWN" PG Dn") + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) PORT_NAME(UTF8_UP" Pg Up") + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Menu") + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ESC) PORT_CHAR(UCHAR_MAMEKEY(ESC)) PORT_NAME("Esc") + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_EQUALS) PORT_CHAR('+') PORT_CHAR('=') + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Off") + + PORT_START("COL1") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F) PORT_CHAR('f') PORT_CHAR('F') + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_E) PORT_CHAR('e') PORT_CHAR('E') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_D) PORT_CHAR('d') PORT_CHAR('D') + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_C) PORT_CHAR('c') PORT_CHAR('C') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_B) PORT_CHAR('b') PORT_CHAR('B') + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_A) PORT_CHAR('a') PORT_CHAR('A') + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("COL2") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_L) PORT_CHAR('l') PORT_CHAR('L') + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_K) PORT_CHAR('k') PORT_CHAR('K') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_J) PORT_CHAR('j') PORT_CHAR('J') + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_I) PORT_CHAR('i') PORT_CHAR('I') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_H) PORT_CHAR('h') PORT_CHAR('H') + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_G) PORT_CHAR('g') PORT_CHAR('G') + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CHAR(',') + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("COL3") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_R) PORT_CHAR('r') PORT_CHAR('R') + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Q) PORT_CHAR('q') PORT_CHAR('Q') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_P) PORT_CHAR('p') PORT_CHAR('P') + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_O) PORT_CHAR('o') PORT_CHAR('O') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N') PORT_NAME("n N No") + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_M) PORT_CHAR('m') PORT_CHAR('M') + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') PORT_NAME("Space") + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("COL4") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X') + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_W) PORT_CHAR('w') PORT_CHAR('W') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_V) PORT_CHAR('v') PORT_CHAR('V') + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_U) PORT_CHAR('u') PORT_CHAR('U') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_T) PORT_CHAR('t') PORT_CHAR('T') + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_S) PORT_CHAR('s') PORT_CHAR('S') + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LSHIFT) PORT_CHAR(UCHAR_SHIFT_1) PORT_NAME("Shift") + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("COL5") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y) PORT_CHAR('y') PORT_CHAR('Y') PORT_NAME("y Y Yes") + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') PORT_CHAR('%') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CHAR(')') + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CHAR('(') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CHAR('&') + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_TAB) PORT_CHAR(0x09) PORT_NAME("Tab") + PORT_BIT(0xc0, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("COL6") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z') + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CHAR('*') PORT_CHAR('@') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CHAR(':') + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CHAR('?') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CHAR('$') + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_BACKSPACE) PORT_CHAR(0x08) PORT_NAME("Del") + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Backlight") + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("COL7") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13) PORT_NAME("Enter") + PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CHAR('\\') + PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CHAR(0xa3) + PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHAR('\'') + PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHAR('!') + PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LALT) PORT_CHAR(UCHAR_MAMEKEY(LALT)) PORT_NAME("Psion Lock") + PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Contrast") + PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) + + PORT_START("ON_OFF") + PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F12) PORT_CHAR(UCHAR_MAMEKEY(F12)) PORT_NAME("On Off") PORT_CHANGED_MEMBER(DEVICE_SELF, psionhc_state, key_on, 0) +INPUT_PORTS_END + +//static INPUT_PORTS_START( psionhc_num ) +// PORT_START("COL0") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N') PORT_NAME("No") +// PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_UNUSED) +// PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) PORT_NAME(UTF8_UP) +// PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN)) PORT_NAME(UTF8_DOWN) +// PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_BACKSPACE) PORT_CHAR(0x08) PORT_NAME("Del") +// PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ESC) PORT_CHAR(UCHAR_MAMEKEY(ESC)) PORT_NAME("C") +// PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_EQUALS) PORT_CHAR('+') +// PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Off") +// +// PORT_START("COL1") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') +// PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_0) PORT_CHAR('0') +// PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CHAR('*') +// PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CHAR('%') +// PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Info") +// PORT_BIT(0xe0, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("COL2") +// PORT_BIT(0xff, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("COL3") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F1) PORT_CHAR(UCHAR_MAMEKEY(F1)) PORT_NAME("F1") +// PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F2) PORT_CHAR(UCHAR_MAMEKEY(F2)) PORT_NAME("F2") +// PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F3) PORT_CHAR(UCHAR_MAMEKEY(F3)) PORT_NAME("F3") +// PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F4) PORT_CHAR(UCHAR_MAMEKEY(F4)) PORT_NAME("F4") +// PORT_BIT(0xf0, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("COL4") +// PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LSHIFT) PORT_CHAR(UCHAR_SHIFT_1) PORT_NAME("Shift") +// PORT_BIT(0xbf, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("COL5") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') +// PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT)) PORT_NAME(UTF8_LEFT) +// PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_9) PORT_CHAR('9') +// PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_8) PORT_CHAR('8') +// PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_7) PORT_CHAR('7') +// PORT_BIT(0xe0, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("COL6") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_UNUSED)// +// PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT)) PORT_NAME(UTF8_RIGHT) +// PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_6) PORT_CHAR('6') +// PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_5) PORT_CHAR('5') +// PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_4) PORT_CHAR('4') +// PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') +// PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Backlight") +// PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("COL7") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13) PORT_NAME("Enter") +// PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y) PORT_CHAR('y') PORT_CHAR('Y') PORT_NAME("Yes") +// PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_3) PORT_CHAR('3') +// PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_2) PORT_CHAR('2') +// PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_1) PORT_CHAR('1') +// PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_UNUSED) +// PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Contrast") +// PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_UNUSED) +// +// PORT_START("ON_OFF") +// PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F12) PORT_CHAR(UCHAR_MAMEKEY(F12)) PORT_NAME("On Off") PORT_CHANGED_MEMBER(DEVICE_SELF, psionhc_state, key_on, 0) +//INPUT_PORTS_END + +INPUT_CHANGED_MEMBER(psionhc_state::key_on) +{ + if (newval) + { + m_asic2->on_clr_w(newval); + } +} + + +void psionhc_state::palette_init(palette_device &palette) +{ + palette.set_pen_color(0, rgb_t(131, 136, 139)); + palette.set_pen_color(1, rgb_t(92, 83, 88)); +} + + +void psionhc_state::psionhc100(machine_config &config) +{ + V30(config, m_maincpu, 7.68_MHz_XTAL / 2); + m_maincpu->set_addrmap(AS_PROGRAM, &psionhc_state::mem_map); + m_maincpu->set_addrmap(AS_IO, &psionhc_state::io_map); + m_maincpu->set_irq_acknowledge_callback(m_asic1, FUNC(psion_asic1_device::inta_cb)); + + RAM(config, m_ram).set_default_size("128K"); + + screen_device &screen(SCREEN(config, "screen", SCREEN_TYPE_LCD)); + screen.set_size(160, 80); + screen.set_visarea_full(); + screen.set_refresh_hz(66); + screen.set_screen_update(m_asic1, FUNC(psion_asic1_device::screen_update_single)); + screen.set_palette(m_palette); + PALETTE(config, "palette", FUNC(psionhc_state::palette_init), 2); + + PSION_ASIC1(config, m_asic1, 7.68_MHz_XTAL); + m_asic1->set_laptop_mode(false); + m_asic1->set_addrmap(0, &psionhc_state::asic1_map); + m_asic1->int_cb().set_inputline(m_maincpu, INPUT_LINE_IRQ0); + m_asic1->nmi_cb().set_inputline(m_maincpu, INPUT_LINE_NMI); + m_asic1->frcovl_cb().set(m_asic2, FUNC(psion_asic2_device::frcovl_w)); + + PSION_ASIC2(config, m_asic2, 7.68_MHz_XTAL); + m_asic2->int_cb().set(m_asic1, FUNC(psion_asic1_device::eint3_w)); + m_asic2->nmi_cb().set(m_asic1, FUNC(psion_asic1_device::enmi_w)); + m_asic2->cbusy_cb().set_inputline(m_maincpu, NEC_INPUT_LINE_POLL); + m_asic2->buz_cb().set(m_speaker, FUNC(speaker_sound_device::level_w)); + m_asic2->buzvol_cb().set([this](int state) { m_speaker->set_output_gain(ALL_OUTPUTS, state ? 1.0 : 0.25); }); + m_asic2->dr_cb().set([this](int state) { m_dr = state; }); + m_asic2->col_cb().set([this](uint8_t data) { return m_keyboard[data & 7]->read(); }); + m_asic2->data_r<0>().set(m_asic3, FUNC(psion_asic3_device::data_r)); // Power supply (ASIC3) + m_asic2->data_w<0>().set(m_asic3, FUNC(psion_asic3_device::data_w)); + m_asic2->data_r<1>().set(m_ssd[0], FUNC(psion_ssd_device::data_r)); // SSD + m_asic2->data_w<1>().set(m_ssd[0], FUNC(psion_ssd_device::data_w)); + m_asic2->data_r<2>().set(m_ssd[1], FUNC(psion_ssd_device::data_r)); // SSD + m_asic2->data_w<2>().set(m_ssd[1], FUNC(psion_ssd_device::data_w)); + m_asic2->data_r<5>().set(m_exp[0], FUNC(psion_module_slot_device::data_r)); // Expansion port A + m_asic2->data_w<5>().set(m_exp[0], FUNC(psion_module_slot_device::data_w)); + m_asic2->data_r<6>().set(m_exp[1], FUNC(psion_module_slot_device::data_r)); // Expansion port B + m_asic2->data_w<6>().set(m_exp[1], FUNC(psion_module_slot_device::data_w)); + m_asic2->data_r<7>().set(m_exp[2], FUNC(psion_module_slot_device::data_r)); // Expansion port C + m_asic2->data_w<7>().set(m_exp[2], FUNC(psion_module_slot_device::data_w)); + + PSION_ASIC3(config, m_asic3); + + SPEAKER(config, "mono").front_center(); + SPEAKER_SOUND(config, m_speaker).add_route(ALL_OUTPUTS, "mono", 1.00); // Piezo buzzer + + PSION_SSD(config, m_ssd[0]); + m_ssd[0]->door_cb().set(m_asic2, FUNC(psion_asic2_device::dnmi_w)); + PSION_SSD(config, m_ssd[1]); + m_ssd[1]->door_cb().set(m_asic2, FUNC(psion_asic2_device::dnmi_w)); + + PSION_MODULE_SLOT(config, m_exp[0], psion_hcmodule_devices, nullptr); // RS232/Parallel + m_exp[0]->intr_cb().set(m_asic1, FUNC(psion_asic1_device::eint1_w)); + PSION_MODULE_SLOT(config, m_exp[1], psion_hcmodule_devices, nullptr); + m_exp[1]->intr_cb().set(m_asic1, FUNC(psion_asic1_device::eint2_w)); + PSION_MODULE_SLOT(config, m_exp[2], psion_hcmodule_devices, nullptr); + + SOFTWARE_LIST(config, "ssd_list").set_original("psion_ssd").set_filter("HC"); +} + +void psionhc_state::psionhc110(machine_config &config) +{ + psionhc100(config); + + m_ram->set_default_size("256K"); +} + +void psionhc_state::psionhc120(machine_config &config) +{ + psionhc100(config); + + m_ram->set_default_size("512K"); +} + + +ROM_START( psionhc120 ) + ROM_REGION16_LE(0x80000, "flash", ROMREGION_ERASEFF) + // 2 x 28F010 128k flash chips, V1.51F 050592, V1.62F, V1.64F, V1.71F also known to exist + ROM_SYSTEM_BIOS(0, "172f", "V1.72F") + ROMX_LOAD("v172f_1.bin", 0x00000, 0x20000, CRC(5ba21d09) SHA1(a9348eeb223cdc767e434ec34beae546defab108), ROM_BIOS(0)) + ROM_RELOAD(0x20000, 0x20000) + ROMX_LOAD("v172f_2.bin", 0x40000, 0x20000, CRC(4436f332) SHA1(c6154cd948260729e079c47dea47def5cdc99a36), ROM_BIOS(0)) + ROM_RELOAD(0x60000, 0x20000) + ROM_SYSTEM_BIOS(1, "170f", "V1.70F") + ROMX_LOAD("v170f_1.bin", 0x00000, 0x20000, CRC(f733a7ab) SHA1(e49273a3d97d5ffb9f9b5958ad031aeedb40af01), ROM_BIOS(1)) + ROM_RELOAD(0x20000, 0x20000) + ROMX_LOAD("v170f_2.bin", 0x40000, 0x20000, CRC(edd6a78d) SHA1(61344cd38928183b0e2c58ebfe92984518d8e731), ROM_BIOS(1)) + ROM_RELOAD(0x60000, 0x20000) +ROM_END + +#define rom_psionhc100 rom_psionhc120 +#define rom_psionhc110 rom_psionhc120 + +} // anonymous namespace + + +// YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME FLAGS +COMP( 1991, psionhc100, psionhc120, 0, psionhc100, psionhc_uk, psionhc_state, empty_init, "Psion", "HC 100", 0 ) +COMP( 1991, psionhc110, psionhc120, 0, psionhc110, psionhc_uk, psionhc_state, empty_init, "Psion", "HC 110", 0 ) +COMP( 1991, psionhc120, 0, 0, psionhc120, psionhc_uk, psionhc_state, empty_init, "Psion", "HC 120", 0 )