1 // license:BSD-3-Clause 2 // copyright-holders:Angelo Salese, Roberto Fresca 3 #ifndef MAME_INCLUDES_NORAUTP_H 4 #define MAME_INCLUDES_NORAUTP_H 5 6 #pragma once 7 8 #include "machine/i8255.h" 9 #include "sound/discrete.h" 10 #include "emupal.h" 11 #include "screen.h" 12 13 14 /* Discrete Sound Input Nodes */ 15 #define NORAUTP_SND_EN NODE_01 16 #define NORAUTP_FREQ_DATA NODE_02 17 18 19 class norautp_state : public driver_device 20 { 21 public: norautp_state(const machine_config & mconfig,device_type type,const char * tag)22 norautp_state(const machine_config &mconfig, device_type type, const char *tag) : 23 driver_device(mconfig, type, tag), 24 m_maincpu(*this, "maincpu"), 25 m_ppi8255(*this, "ppi8255_%u", 0), 26 m_discrete(*this, "discrete"), 27 m_gfxdecode(*this, "gfxdecode"), 28 m_screen(*this, "screen"), 29 m_palette(*this, "palette"), 30 m_lamps(*this, "lamp%u", 0U) 31 { } 32 33 void noraut_base(machine_config &config); 34 void kimble(machine_config &config); 35 void kimbldhl(machine_config &config); 36 void norautp(machine_config &config); 37 void norautx4(machine_config &config); 38 void norautpl(machine_config &config); 39 void newhilop(machine_config &config); 40 void dphltest(machine_config &config); 41 void nortest1(machine_config &config); 42 void ssjkrpkr(machine_config &config); 43 void dphl(machine_config &config); 44 void dphla(machine_config &config); 45 void drhl(machine_config &config); 46 void norautxp(machine_config &config); 47 void cgidjp(machine_config &config); 48 void cdrawpkr(machine_config &config); 49 50 void init_ssa(); 51 void init_enc(); 52 void init_deb(); 53 54 protected: machine_start()55 virtual void machine_start() override { m_lamps.resolve(); } 56 virtual void video_start() override; 57 58 private: 59 DECLARE_WRITE_LINE_MEMBER(ppi2_obf_w); 60 TIMER_CALLBACK_MEMBER(ppi2_ack); 61 uint8_t test2_r(); 62 void mainlamps_w(uint8_t data); 63 void soundlamps_w(uint8_t data); 64 void counterlamps_w(uint8_t data); 65 void norautp_palette(palette_device &palette) const; 66 uint32_t screen_update_norautp(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); 67 void cgidjp_map(address_map &map); 68 void cgidjp_opcodes_map(address_map &map); 69 void dphl_map(address_map &map); 70 void dphla_map(address_map &map); 71 void dphltest_map(address_map &map); 72 void drhl_map(address_map &map); 73 void kimbldhl_map(address_map &map); 74 void kimble_map(address_map &map); 75 void newhilop_map(address_map &map); 76 void norautp_map(address_map &map); 77 void norautp_portmap(address_map &map); 78 void norautx4_map(address_map &map); 79 void norautx8_map(address_map &map); 80 void norautxp_map(address_map &map); 81 void norautxp_portmap(address_map &map); 82 void nortest1_map(address_map &map); 83 void ssjkrpkr_map(address_map &map); 84 85 std::unique_ptr<uint16_t[]> m_np_vram; 86 required_device<cpu_device> m_maincpu; 87 required_device_array<i8255_device, 3> m_ppi8255; 88 required_device<discrete_sound_device> m_discrete; 89 required_device<gfxdecode_device> m_gfxdecode; 90 required_device<screen_device> m_screen; 91 required_device<palette_device> m_palette; 92 output_finder<12> m_lamps; 93 }; 94 95 /*----------- defined in audio/norautp.c -----------*/ 96 DISCRETE_SOUND_EXTERN( norautp_discrete ); 97 DISCRETE_SOUND_EXTERN( dphl_discrete ); 98 DISCRETE_SOUND_EXTERN( kimble_discrete ); 99 100 #endif // MAME_INCLUDES_NORAUTP_H 101