mame/src/mess/includes/sym1.h
2013-01-26 10:27:26 +00:00

91 lines
2.6 KiB
C++

/*****************************************************************************
*
* includes/sym1.h
*
* Synertek Systems Corp. SYM-1
*
* Early driver by PeT <mess@utanet.at>, May 2000
* Rewritten by Dirk Best, October 2007
*
****************************************************************************/
#ifndef SYM1_H_
#define SYM1_H_
#include "machine/6532riot.h"
#include "machine/6522via.h"
#include "machine/74145.h"
#include "machine/ram.h"
/* SYM-1 main (and only) oscillator Y1 */
#define SYM1_CLOCK XTAL_1MHz
class sym1_state : public driver_device
{
public:
sym1_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag)
, m_ram_1k(*this, "ram_1k")
, m_ram_2k(*this, "ram_2k")
, m_ram_3k(*this, "ram_3k")
, m_monitor(*this, "monitor")
, m_riot_ram(*this, "riot_ram")
, m_maincpu(*this, "maincpu")
, m_ram(*this, RAM_TAG)
, m_ttl74145(*this, "ttl74145")
, m_row0(*this, "ROW-0")
, m_row1(*this, "ROW-1")
, m_row2(*this, "ROW-2")
, m_row3(*this, "ROW-3")
, m_wp(*this, "WP")
{ }
required_shared_ptr<UINT8> m_ram_1k;
required_shared_ptr<UINT8> m_ram_2k;
required_shared_ptr<UINT8> m_ram_3k;
required_shared_ptr<UINT8> m_monitor;
required_shared_ptr<UINT8> m_riot_ram;
UINT8 m_riot_port_a;
UINT8 m_riot_port_b;
emu_timer *m_led_update;
DECLARE_DRIVER_INIT(sym1);
virtual void machine_reset();
TIMER_CALLBACK_MEMBER(led_refresh);
DECLARE_WRITE_LINE_MEMBER(sym1_74145_output_0_w);
DECLARE_WRITE_LINE_MEMBER(sym1_74145_output_1_w);
DECLARE_WRITE_LINE_MEMBER(sym1_74145_output_2_w);
DECLARE_WRITE_LINE_MEMBER(sym1_74145_output_3_w);
DECLARE_WRITE_LINE_MEMBER(sym1_74145_output_4_w);
DECLARE_WRITE_LINE_MEMBER(sym1_74145_output_5_w);
DECLARE_READ8_MEMBER(sym1_riot_a_r);
DECLARE_READ8_MEMBER(sym1_riot_b_r);
DECLARE_WRITE8_MEMBER(sym1_riot_a_w);
DECLARE_WRITE8_MEMBER(sym1_riot_b_w);
DECLARE_READ8_MEMBER(sym1_via0_b_r);
DECLARE_WRITE8_MEMBER(sym1_via0_b_w);
DECLARE_WRITE8_MEMBER(sym1_via2_a_w);
DECLARE_WRITE_LINE_MEMBER(sym1_irq);
protected:
required_device<cpu_device> m_maincpu;
required_device<ram_device> m_ram;
required_device<ttl74145_device> m_ttl74145;
required_ioport m_row0;
required_ioport m_row1;
required_ioport m_row2;
required_ioport m_row3;
required_ioport m_wp;
};
/*----------- defined in machine/sym1.c -----------*/
extern const riot6532_interface sym1_r6532_interface;
extern const ttl74145_interface sym1_ttl74145_intf;
extern const via6522_interface sym1_via0;
extern const via6522_interface sym1_via1;
extern const via6522_interface sym1_via2;
#endif /* SYM1_H_ */