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