MAME/src/mame/trs/coco.h
Vas Crabb c47028689c emu/driver.cpp: Marked several device_t overrides as final.
There's too much opportunity for confusion if these are overridden
further down the tree.
2026-05-24 04:31:13 +10:00

264 lines
8.0 KiB
C++

// license:BSD-3-Clause
// copyright-holders:Nathan Woods
/***************************************************************************
coco.h
TRS-80 Radio Shack Color Computer Family
***************************************************************************/
#ifndef MAME_TRS_COCO_H
#define MAME_TRS_COCO_H
#pragma once
#include "coco_vhd.h"
#include "bus/coco/coco_dwsock.h"
#include "bus/coco/cococart.h"
#include "bus/rs232/rs232.h"
#include "imagedev/cassette.h"
#include "machine/6821pia.h"
#include "machine/bankdev.h"
#include "machine/input_merger.h"
#include "machine/ram.h"
#include "sound/dac.h"
#include "screen.h"
//**************************************************************************
// MACROS / CONSTANTS
//**************************************************************************
INPUT_PORTS_EXTERN( coco_analog_control );
INPUT_PORTS_EXTERN( coco_joystick );
INPUT_PORTS_EXTERN( coco_beckerport );
void coco_cart(device_slot_interface &device);
// constants
#define JOYSTICK_DELTA 10
#define JOYSTICK_SENSITIVITY 100
// devices
#define MAINCPU_TAG "maincpu"
#define RS232_TAG "rs232"
// inputs
#define CTRL_SEL_TAG "ctrl_sel"
#define HIRES_INTF_TAG "hires_intf"
#define BECKERPORT_TAG "beckerport"
#define JOYSTICK_RX_TAG "joystick_rx"
#define JOYSTICK_RY_TAG "joystick_ry"
#define JOYSTICK_LX_TAG "joystick_lx"
#define JOYSTICK_LY_TAG "joystick_ly"
#define JOYSTICK_BUTTONS_TAG "joystick_buttons"
#define RAT_MOUSE_RX_TAG "rat_mouse_rx"
#define RAT_MOUSE_RY_TAG "rat_mouse_ry"
#define RAT_MOUSE_LX_TAG "rat_mouse_lx"
#define RAT_MOUSE_LY_TAG "rat_mouse_ly"
#define RAT_MOUSE_BUTTONS_TAG "rat_mouse_buttons"
#define DIECOM_LIGHTGUN_RX_TAG "dclg_rx"
#define DIECOM_LIGHTGUN_RY_TAG "dclg_ry"
#define DIECOM_LIGHTGUN_LX_TAG "dclg_lx"
#define DIECOM_LIGHTGUN_LY_TAG "dclg_ly"
#define DIECOM_LIGHTGUN_BUTTONS_TAG "dclg_triggers"
//**************************************************************************
// TYPE DEFINITIONS
//**************************************************************************
class coco_state : public driver_device, public device_cococart_host_interface
{
public:
coco_state(const machine_config &mconfig, device_type type, const char *tag);
// driver update handlers
virtual DECLARE_INPUT_CHANGED_MEMBER(keyboard_changed);
DECLARE_INPUT_CHANGED_MEMBER(joystick_mode_changed);
// IO
virtual void ff20_write(offs_t offset, uint8_t data);
virtual uint8_t ff40_read(offs_t offset);
virtual void ff40_write(offs_t offset, uint8_t data);
uint8_t ff60_read(offs_t offset);
void ff60_write(offs_t offset, uint8_t data);
// PIA0
void pia0_pa_w(uint8_t data);
void pia0_pb_w(uint8_t data);
void pia0_ca2_w(int state);
void pia0_cb2_w(int state);
// PIA1
uint8_t pia1_pa_r();
uint8_t pia1_pb_r();
void pia1_pa_w(uint8_t data);
void pia1_pb_w(uint8_t data);
void pia1_ca2_w(int state);
void pia1_cb2_w(int state);
// floating bus & "space"
uint8_t floating_bus_r() { return floating_bus_read(); }
uint8_t floating_space_read(offs_t offset);
void floating_space_write(offs_t offset, uint8_t data);
// cartridge stuff
void cart_w(int state) { cart_w((bool) state); }
virtual address_space &cartridge_space() override;
// disassembly override
static offs_t os9_dasm_override(std::ostream &stream, offs_t pc, const util::disasm_interface::data_buffer &opcodes, const util::disasm_interface::data_buffer &params);
offs_t dasm_override(std::ostream &stream, offs_t pc, const util::disasm_interface::data_buffer &opcodes, const util::disasm_interface::data_buffer &params);
void coco_sound(machine_config &config);
void coco_floating(machine_config &config);
void coco_floating_map(address_map &map) ATTR_COLD;
protected:
virtual void machine_start() override ATTR_COLD;
virtual void machine_reset() override ATTR_COLD;
// changed handlers
virtual void pia1_pa_changed(uint8_t data);
virtual void pia1_pb_changed(uint8_t data);
TIMER_CALLBACK_MEMBER(diecom_lightgun_hit);
TIMER_CALLBACK_MEMBER(joystick_update);
// accessors
pia6821_device &pia_0() { return *m_pia_0; }
pia6821_device &pia_1() { return *m_pia_1; }
cococart_slot_device &cococart() { return *m_cococart; }
ram_device &ram() { return *m_ram; }
// miscellaneous
void update_keyboard_input(uint8_t value);
virtual void cart_w(bool state);
virtual void update_cart_base(uint8_t *cart_base) { }
protected:
enum soundmux_status_t
{
SOUNDMUX_SEL1 = 1,
SOUNDMUX_SEL2 = 2,
SOUNDMUX_ENABLE = 4
};
enum joystick_type_t
{
JOYSTICK_NONE = 0x00,
JOYSTICK_NORMAL = 0x01,
JOYSTICK_RAT_MOUSE = 0x02,
JOYSTICK_DIECOM_LIGHT_GUN = 0x03
};
enum hires_type_t
{
HIRES_NONE = 0x00,
HIRES_RIGHT = 0x01,
HIRES_RIGHT_COCOMAX3 = 0x02,
HIRES_LEFT = 0x03,
HIRES_LEFT_COCOMAX3 = 0x04
};
struct analog_input_t
{
ioport_port *m_input[2][2]{};
ioport_port *m_buttons{};
uint32_t input(int joystick, int axis) const { return m_input[joystick][axis] ? m_input[joystick][axis]->read() : 0x00; }
uint8_t buttons() const { return m_buttons ? m_buttons->read() : 0x00; }
};
void analog_port_start(analog_input_t *analog, const char *rx_tag, const char *ry_tag, const char *lx_tag, const char *ly_tag, const char *buttons_tag);
// wrappers for configuration
joystick_type_t joystick_type(int index);
hires_type_t hires_interface_type();
bool is_joystick_hires(int joystick_index);
soundmux_status_t soundmux_status();
void update_sound();
bool poll_joystick();
uint8_t poll_joystick_buttons();
void poll_keyboard();
void poll_hires_joystick();
void update_cassout(int cassout);
void update_prinout(bool prinout);
void diecom_lightgun_clock();
// thin wrappers for PIA output
uint8_t dac_output() { return m_dac_output; } // PA drives the DAC
bool sel1() { return m_pia_0->ca2_output() ? true : false; }
bool sel2() { return m_pia_0->cb2_output() ? true : false; }
bool snden() { return m_pia_1->cb2_output() ? true : false; }
// VHD selection
coco_vhd_image_device *current_vhd();
// floating bus
uint8_t floating_bus_read();
// devices
required_device<cpu_device> m_maincpu;
required_device<pia6821_device> m_pia_0;
required_device<pia6821_device> m_pia_1;
required_device<dac_byte_interface> m_dac;
required_device<dac_1bit_device> m_sbs;
optional_device<screen_device> m_screen;
required_device<cococart_slot_device> m_cococart;
required_device<ram_device> m_ram;
required_device<cassette_image_device> m_cassette;
required_device<address_map_bank_device> m_floating;
optional_device<rs232_port_device> m_rs232;
optional_device<coco_vhd_image_device> m_vhd_0;
optional_device<coco_vhd_image_device> m_vhd_1;
optional_device<beckerport_device> m_beckerport;
optional_ioport m_beckerportconfig;
required_device<input_merger_device> m_irqs;
required_device<input_merger_device> m_firqs;
// input ports
required_ioport_array<7> m_keyboard;
optional_ioport m_joystick_type_control;
optional_ioport m_joystick_hires_control;
analog_input_t m_joystick{};
analog_input_t m_rat_mouse{};
analog_input_t m_diecom_lightgun{};
// DAC output
uint8_t m_dac_output = 0U;
// remember the last audio sample level from the analog sources (DAC, cart, cassette) so that we don't
// introduce step changes when the audio output is enabled/disabled via PIA1 CB2
uint8_t m_analog_audio_level = 0U;
// hires interface
emu_timer *m_hiresjoy_transition_timer[2]{};
bool m_hiresjoy_ca = false;
// diecom lightgun
emu_timer *m_diecom_lightgun_timer = nullptr;
bool m_dclg_previous_bit = false;
uint8_t m_dclg_output_h = 0U;
uint8_t m_dclg_output_v = 0U;
uint32_t m_dclg_state = 0U;
uint32_t m_dclg_timer = 0U;
// VHD selection
uint8_t m_vhd_select = 0U;
// address space for "floating access"
//address_space m_floating_space;
// safety to prevent stack overflow when reading floating bus
bool m_in_floating_bus_read = false;
};
#endif // MAME_TRS_COCO_H