1 /***************************************************************************
2 
3 Mat Mania
4 Memetron, 1985
5 (copyright Taito, licensed by Technos, distributed by Memetron)
6 
7 driver by Brad Oliver
8 
9 MAIN BOARD:
10 
11 0000-0fff RAM
12 1000-13ff Video RAM
13 1400-17ff Attribute RAM
14 1800-1fff ?? Only used in self-test ??
15 2000-21ff Background video RAM #1
16 2200-23ff Background attribute RAM #1
17 2400-25ff Background video RAM #2
18 2600-27ff Background attribute RAM #2
19 4000-ffff ROM
20 
21 ***************************************************************************/
22 
23 #include "driver.h"
24 #include "vidhrdw/generic.h"
25 #include "cpu/m6502/m6502.h"
26 #include "cpu/m6809/m6809.h"
27 
28 extern unsigned char *matmania_videoram2,*matmania_colorram2;
29 extern size_t matmania_videoram2_size;
30 extern unsigned char *matmania_videoram3,*matmania_colorram3;
31 extern size_t matmania_videoram3_size;
32 extern unsigned char *matmania_scroll;
33 extern unsigned char *matmania_pageselect;
34 
35 WRITE_HANDLER( matmania_paletteram_w );
36 PALETTE_INIT( matmania );
37 VIDEO_UPDATE( matmania );
38 VIDEO_UPDATE( maniach );
39 WRITE_HANDLER( matmania_videoram3_w );
40 WRITE_HANDLER( matmania_colorram3_w );
41 VIDEO_START( matmania );
42 VIDEO_UPDATE( matmania );
43 
44 READ_HANDLER( maniach_68705_portA_r );
45 WRITE_HANDLER( maniach_68705_portA_w );
46 READ_HANDLER( maniach_68705_portB_r );
47 WRITE_HANDLER( maniach_68705_portB_w );
48 READ_HANDLER( maniach_68705_portC_r );
49 WRITE_HANDLER( maniach_68705_portC_w );
50 WRITE_HANDLER( maniach_68705_ddrA_w );
51 WRITE_HANDLER( maniach_68705_ddrB_w );
52 WRITE_HANDLER( maniach_68705_ddrC_w );
53 WRITE_HANDLER( maniach_mcu_w );
54 READ_HANDLER( maniach_mcu_r );
55 READ_HANDLER( maniach_mcu_status_r );
56 
57 
58 
WRITE_HANDLER(matmania_sh_command_w)59 WRITE_HANDLER( matmania_sh_command_w )
60 {
61 	soundlatch_w(offset,data);
62 	cpu_set_irq_line(1,M6502_IRQ_LINE,HOLD_LINE);
63 }
64 
WRITE_HANDLER(matmania_dac_w)65 WRITE_HANDLER( matmania_dac_w )
66 {
67 	DAC_signed_data_w(0,data);
68 }
69 
70 
WRITE_HANDLER(maniach_sh_command_w)71 WRITE_HANDLER( maniach_sh_command_w )
72 {
73 	soundlatch_w(offset,data);
74 	cpu_set_irq_line(1,M6809_IRQ_LINE,HOLD_LINE);
75 }
76 
77 
78 
MEMORY_READ_START(matmania_readmem)79 static MEMORY_READ_START( matmania_readmem )
80 	{ 0x0000, 0x077f, MRA_RAM },
81 	{ 0x1000, 0x17ff, MRA_RAM },
82 	{ 0x2000, 0x27ff, MRA_RAM },
83 	{ 0x3000, 0x3000, input_port_0_r },
84 	{ 0x3010, 0x3010, input_port_1_r },
85 	{ 0x3020, 0x3020, input_port_2_r },
86 	{ 0x3030, 0x3030, input_port_3_r },
87 	{ 0x4000, 0xffff, MRA_ROM },
88 MEMORY_END
89 
90 static MEMORY_WRITE_START( matmania_writemem )
91 	{ 0x0000, 0x077f, MWA_RAM },
92 	{ 0x0780, 0x07df, MWA_RAM, &spriteram, &spriteram_size },
93 	{ 0x1000, 0x13ff, MWA_RAM, &matmania_videoram2, &matmania_videoram2_size },
94 	{ 0x1400, 0x17ff, MWA_RAM, &matmania_colorram2 },
95 	{ 0x2000, 0x21ff, videoram_w, &videoram, &videoram_size },
96 	{ 0x2200, 0x23ff, colorram_w, &colorram },
97 	{ 0x2400, 0x25ff, matmania_videoram3_w, &matmania_videoram3, &matmania_videoram3_size },
98 	{ 0x2600, 0x27ff, matmania_colorram3_w, &matmania_colorram3 },
99 	{ 0x3000, 0x3000, MWA_RAM, &matmania_pageselect },
100 	{ 0x3010, 0x3010, matmania_sh_command_w },
101 	{ 0x3020, 0x3020, MWA_RAM, &matmania_scroll },
102 /*	{ 0x3030, 0x3030, MWA_NOP },	 // ?? /*/
103 	{ 0x3050, 0x307f, matmania_paletteram_w, &paletteram },
104 	{ 0x4000, 0xffff, MWA_ROM },
105 MEMORY_END
106 
107 static MEMORY_READ_START( maniach_readmem )
108 	{ 0x0000, 0x077f, MRA_RAM },
109 	{ 0x1000, 0x17ff, MRA_RAM },
110 	{ 0x2000, 0x27ff, MRA_RAM },
111 	{ 0x3000, 0x3000, input_port_0_r },
112 	{ 0x3010, 0x3010, input_port_1_r },
113 	{ 0x3020, 0x3020, input_port_2_r },
114 	{ 0x3030, 0x3030, input_port_3_r },
115 	{ 0x3040, 0x3040, maniach_mcu_r },
116 	{ 0x3041, 0x3041, maniach_mcu_status_r },
117 	{ 0x4000, 0xffff, MRA_ROM },
118 MEMORY_END
119 
120 static MEMORY_WRITE_START( maniach_writemem )
121 	{ 0x0000, 0x077f, MWA_RAM },
122 	{ 0x0780, 0x07df, MWA_RAM, &spriteram, &spriteram_size },
123 	{ 0x1000, 0x13ff, MWA_RAM, &matmania_videoram2, &matmania_videoram2_size },
124 	{ 0x1400, 0x17ff, MWA_RAM, &matmania_colorram2 },
125 	{ 0x2000, 0x21ff, videoram_w, &videoram, &videoram_size },
126 	{ 0x2200, 0x23ff, colorram_w, &colorram },
127 	{ 0x2400, 0x25ff, matmania_videoram3_w, &matmania_videoram3, &matmania_videoram3_size },
128 	{ 0x2600, 0x27ff, matmania_colorram3_w, &matmania_colorram3 },
129 	{ 0x3000, 0x3000, MWA_RAM, &matmania_pageselect },
130 	{ 0x3010, 0x3010, maniach_sh_command_w },
131 	{ 0x3020, 0x3020, MWA_RAM, &matmania_scroll },
132 	{ 0x3030, 0x3030, MWA_NOP },	/* ?? */
133 	{ 0x3040, 0x3040, maniach_mcu_w },
134 	{ 0x3050, 0x307f, matmania_paletteram_w, &paletteram },
135 	{ 0x4000, 0xffff, MWA_ROM },
136 MEMORY_END
137 
138 static MEMORY_READ_START( sound_readmem )
139 	{ 0x0000, 0x01ff, MRA_RAM },
140 	{ 0x2007, 0x2007, soundlatch_r },
141 	{ 0x8000, 0xffff, MRA_ROM },
142 MEMORY_END
143 
144 static MEMORY_WRITE_START( sound_writemem )
145 	{ 0x0000, 0x01ff, MWA_RAM },
146 	{ 0x2000, 0x2000, AY8910_write_port_0_w },
147 	{ 0x2001, 0x2001, AY8910_control_port_0_w },
148 	{ 0x2002, 0x2002, AY8910_write_port_1_w },
149 	{ 0x2003, 0x2003, AY8910_control_port_1_w },
150 	{ 0x2004, 0x2004, matmania_dac_w },
151 	{ 0x8000, 0xffff, MWA_ROM },
152 MEMORY_END
153 
154 static MEMORY_READ_START( maniach_sound_readmem )
155 	{ 0x0000, 0x0fff, MRA_RAM },
156 	{ 0x2004, 0x2004, soundlatch_r },
157 	{ 0x4000, 0xffff, MRA_ROM },
158 MEMORY_END
159 
160 static MEMORY_WRITE_START( maniach_sound_writemem )
161 	{ 0x0000, 0x0fff, MWA_RAM },
162 	{ 0x2000, 0x2000, YM3526_control_port_0_w },
163 	{ 0x2001, 0x2001, YM3526_write_port_0_w },
164 	{ 0x2002, 0x2002, matmania_dac_w },
165 	{ 0x4000, 0xffff, MWA_ROM },
166 MEMORY_END
167 
168 static MEMORY_READ_START( mcu_readmem )
169 	{ 0x0000, 0x0000, maniach_68705_portA_r },
170 	{ 0x0001, 0x0001, maniach_68705_portB_r },
171 	{ 0x0002, 0x0002, maniach_68705_portC_r },
172 	{ 0x0010, 0x007f, MRA_RAM },
173 	{ 0x0080, 0x07ff, MRA_ROM },
174 MEMORY_END
175 
176 static MEMORY_WRITE_START( mcu_writemem )
177 	{ 0x0000, 0x0000, maniach_68705_portA_w },
178 	{ 0x0001, 0x0001, maniach_68705_portB_w },
179 	{ 0x0002, 0x0002, maniach_68705_portC_w },
180 	{ 0x0004, 0x0004, maniach_68705_ddrA_w },
181 	{ 0x0005, 0x0005, maniach_68705_ddrB_w },
182 	{ 0x0006, 0x0006, maniach_68705_ddrC_w },
183 	{ 0x0010, 0x007f, MWA_RAM },
184 	{ 0x0080, 0x07ff, MWA_ROM },
185 MEMORY_END
186 
187 
188 
189 INPUT_PORTS_START( matmania )
190 	PORT_START	/* IN0 */
191 	PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY )
192 	PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY )
193 	PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_UP    | IPF_8WAY )
194 	PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY )
195 	PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 )
196 	PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 )
197 	PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 1 )
198 	PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN1, 1 )
199 
200 	PORT_START	/* IN1 */
201 	PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY | IPF_PLAYER2 )
202 	PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY | IPF_PLAYER2 )
203 	PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_UP    | IPF_8WAY | IPF_PLAYER2 )
204 	PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY | IPF_PLAYER2 )
205 	PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 | IPF_PLAYER2 )
206 	PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 | IPF_PLAYER2 )
207 	PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_START1 )
208 	PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_START2 )
209 
210 	PORT_START	/* DSW1 */
211 	PORT_DIPNAME(0x03, 0x03, DEF_STR( Difficulty ) )
212 	PORT_DIPSETTING(   0x03, "Easy" )
213 	PORT_DIPSETTING(   0x02, "Medium" )
214 	PORT_DIPSETTING(   0x01, "Hard" )
215 	PORT_DIPSETTING(   0x00, "Hardest" )
216 	PORT_DIPNAME(0x04, 0x04, DEF_STR( Unknown ) )
217 	PORT_DIPSETTING(   0x04, DEF_STR( Off ) )
218 	PORT_DIPSETTING(   0x00, DEF_STR( On ) )
219 	PORT_DIPNAME(0x08, 0x08, DEF_STR( Unknown ) )
220 	PORT_DIPSETTING(   0x08, DEF_STR( Off ) )
221 	PORT_DIPSETTING(   0x00, DEF_STR( On ) )
222 	PORT_DIPNAME(0x10, 0x10, DEF_STR( Unknown ) )
223 	PORT_DIPSETTING(   0x10, DEF_STR( Off ) )
224 	PORT_DIPSETTING(   0x00, DEF_STR( On ) )
225 	PORT_DIPNAME(0x20, 0x20, DEF_STR( Unknown ) )
226 	PORT_DIPSETTING(   0x20, DEF_STR( Off ) )
227 	PORT_DIPSETTING(   0x00, DEF_STR( On ) )
228 	PORT_DIPNAME(0x40, 0x40, DEF_STR( Unknown ) )
229 	PORT_DIPSETTING(   0x40, DEF_STR( Off ) )
230 	PORT_DIPSETTING(   0x00, DEF_STR( On ) )
231 	PORT_DIPNAME(0x80, 0x80, DEF_STR( Unknown ) )
232 	PORT_DIPSETTING(   0x80, DEF_STR( Off ) )
233 	PORT_DIPSETTING(   0x00, DEF_STR( On ) )
234 
235 	PORT_START	/* DSW2 */
236 	PORT_DIPNAME(0x03, 0x03, DEF_STR( Coin_A ) )
237 	PORT_DIPSETTING(   0x00, DEF_STR( 2C_1C ) )
238 	PORT_DIPSETTING(   0x03, DEF_STR( 1C_1C ) )
239 	PORT_DIPSETTING(   0x02, DEF_STR( 1C_2C ) )
240 	PORT_DIPSETTING(   0x01, DEF_STR( 1C_3C ) )
241 	PORT_DIPNAME(0x0c, 0x0c, DEF_STR( Coin_B ) )
242 	PORT_DIPSETTING(   0x00, DEF_STR( 2C_1C ) )
243 	PORT_DIPSETTING(   0x0c, DEF_STR( 1C_1C ) )
244 	PORT_DIPSETTING(   0x08, DEF_STR( 1C_2C ) )
245 	PORT_DIPSETTING(   0x04, DEF_STR( 1C_3C ) )
246 	PORT_DIPNAME(0x10, 0x10, DEF_STR( Demo_Sounds ) )
247 	PORT_DIPSETTING(   0x00, DEF_STR( Off ) )
248 	PORT_DIPSETTING(   0x10, DEF_STR( On ) )
249 	PORT_DIPNAME(0x20, 0x00, DEF_STR( Cabinet ) )
250 	PORT_DIPSETTING(   0x00, DEF_STR( Upright ) )
251 	PORT_DIPSETTING(   0x20, DEF_STR( Cocktail ) )
252 	PORT_SERVICE( 0x40, IP_ACTIVE_LOW )
253 	PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_VBLANK )
254 INPUT_PORTS_END
255 
256 static struct GfxLayout charlayout =
257 {
258 	8,8,	/* 8*8 characters */
259 	1024,	/* 1024 characters */
260 	3,	/* 3 bits per pixel */
261 	{ 2*1024*8*8, 1024*8*8, 0 },	/* the bitplanes are separated */
262 	{ 0, 1, 2, 3, 4, 5, 6, 7 },
263 	{ 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 },
264 	8*8	/* every char takes 8 consecutive bytes */
265 };
266 
267 static struct GfxLayout tilelayout =
268 {
269 	16,16,  /* 16*16 tiles */
270 	512,    /* 512 tiles */
271 	3,	/* 3 bits per pixel */
272 	{ 2*512*16*16, 512*16*16, 0 },	/* the bitplanes are separated */
273 	{ 16*8+0, 16*8+1, 16*8+2, 16*8+3, 16*8+4, 16*8+5, 16*8+6, 16*8+7,
274 			0, 1, 2, 3, 4, 5, 6, 7 },
275 	{ 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8,
276 			8*8, 9*8, 10*8, 11*8, 12*8, 13*8, 14*8, 15*8 },
277 	32*8	/* every tile takes 16 consecutive bytes */
278 };
279 
280 static struct GfxLayout matmania_spritelayout =
281 {
282 	16,16,  /* 16*16 sprites */
283 	3584,    /* 3584 sprites */
284 	3,	/* 3 bits per pixel */
285 	{ 2*3584*16*16, 3584*16*16, 0 },	/* the bitplanes are separated */
286 	{ 16*8+0, 16*8+1, 16*8+2, 16*8+3, 16*8+4, 16*8+5, 16*8+6, 16*8+7,
287 			0, 1, 2, 3, 4, 5, 6, 7 },
288 	{ 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8,
289 			8*8, 9*8, 10*8, 11*8, 12*8, 13*8, 14*8, 15*8 },
290 	32*8	/* every sprite takes 16 consecutive bytes */
291 };
292 
293 static struct GfxLayout maniach_spritelayout =
294 {
295 	16,16,  /* 16*16 sprites */
296 	3584,    /* 3584 sprites */
297 	3,	/* 3 bits per pixel */
298 	{ 0, 3584*16*16, 2*3584*16*16 },	/* the bitplanes are separated */
299 	{ 16*8+0, 16*8+1, 16*8+2, 16*8+3, 16*8+4, 16*8+5, 16*8+6, 16*8+7,
300 			0, 1, 2, 3, 4, 5, 6, 7 },
301 	{ 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8,
302 			8*8, 9*8, 10*8, 11*8, 12*8, 13*8, 14*8, 15*8 },
303 	32*8	/* every sprite takes 16 consecutive bytes */
304 };
305 
306 static struct GfxLayout maniach_tilelayout =
307 {
308 	16,16,  /* 16*16 tiles */
309 	1024,    /* 1024 tiles */
310 	3,	/* 3 bits per pixel */
311 	{ 2*1024*16*16, 1024*16*16, 0 },	/* the bitplanes are separated */
312 	{ 16*8+0, 16*8+1, 16*8+2, 16*8+3, 16*8+4, 16*8+5, 16*8+6, 16*8+7,
313 			0, 1, 2, 3, 4, 5, 6, 7 },
314 	{ 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8,
315 			8*8, 9*8, 10*8, 11*8, 12*8, 13*8, 14*8, 15*8 },
316 	32*8	/* every tile takes 16 consecutive bytes */
317 };
318 
319 static struct GfxDecodeInfo matmania_gfxdecodeinfo[] =
320 {
321 	{ REGION_GFX1, 0, &charlayout,              0, 4 },
322 	{ REGION_GFX2, 0, &tilelayout,            4*8, 4 },
323 	{ REGION_GFX3, 0, &matmania_spritelayout, 8*8, 2 },
324 	{ -1 } /* end of array */
325 };
326 
327 static struct GfxDecodeInfo maniach_gfxdecodeinfo[] =
328 {
329 	{ REGION_GFX1, 0, &charlayout,             0, 4 },
330 	{ REGION_GFX2, 0, &maniach_tilelayout,   4*8, 4 },
331 	{ REGION_GFX3, 0, &maniach_spritelayout, 8*8, 2 },
332 	{ -1 } /* end of array */
333 };
334 
335 
336 
337 static struct AY8910interface ay8910_interface =
338 {
339 	2,	/* 2 chips */
340 	1500000,	/* 1.5 MHz?????? */
341 	{ 30, 30 },
342 	{ 0 },
343 	{ 0 },
344 	{ 0 },
345 	{ 0 }
346 };
347 
348 static struct DACinterface dac_interface =
349 {
350 	1,
351 	{ 40 }
352 };
353 
354 
355 
356 static MACHINE_DRIVER_START( matmania )
357 
358 	/* basic machine hardware */
359 	MDRV_CPU_ADD(M6502, 1500000)	/* 1.5 MHz ???? */
MDRV_CPU_MEMORY(matmania_readmem,matmania_writemem)360 	MDRV_CPU_MEMORY(matmania_readmem,matmania_writemem)
361 	MDRV_CPU_VBLANK_INT(irq0_line_hold,1)
362 
363 	MDRV_CPU_ADD(M6502, 1200000)
364 	MDRV_CPU_FLAGS(CPU_AUDIO_CPU)	/* 1.2 MHz ???? */
365 	MDRV_CPU_MEMORY(sound_readmem,sound_writemem)
366 	MDRV_CPU_VBLANK_INT(nmi_line_pulse,15)	/* ???? */
367 								/* IRQs are caused by the main CPU */
368 	MDRV_FRAMES_PER_SECOND(60)
369 	MDRV_VBLANK_DURATION(DEFAULT_REAL_60HZ_VBLANK_DURATION)
370 	MDRV_INTERLEAVE(10)
371 
372 	/* video hardware */
373 	MDRV_VIDEO_ATTRIBUTES(VIDEO_TYPE_RASTER)
374 	MDRV_SCREEN_SIZE(32*8, 32*8)
375 	MDRV_VISIBLE_AREA(0*8, 32*8-1, 1*8, 31*8-1)
376 	MDRV_GFXDECODE(matmania_gfxdecodeinfo)
377 	MDRV_PALETTE_LENGTH(64+16)
378 	MDRV_COLORTABLE_LENGTH(64+16)
379 
380 	MDRV_PALETTE_INIT(matmania)
381 	MDRV_VIDEO_START(matmania)
382 	MDRV_VIDEO_UPDATE(matmania)
383 
384 	/* sound hardware */
385 	MDRV_SOUND_ADD(AY8910, ay8910_interface)
386 	MDRV_SOUND_ADD(DAC, dac_interface)
387 MACHINE_DRIVER_END
388 
389 
390 
391 /* handler called by the 3526 emulator when the internal timers cause an IRQ */
392 static void irqhandler(int linestate)
393 {
394 	cpu_set_irq_line(1,1,linestate);
395 }
396 
397 static struct YM3526interface ym3526_interface =
398 {
399 	1,			/* 1 chip (no more supported) */
400 	3600000,	/* 3.6 MHz ? */
401 	{ 100 },		/* (not supported) */
402 	{ irqhandler },
403 };
404 
405 
406 static MACHINE_DRIVER_START( maniach )
407 
408 	/* basic machine hardware */
409 	MDRV_CPU_ADD(M6502, 1500000)	/* 1.5 MHz ???? */
410 	MDRV_CPU_MEMORY(maniach_readmem,maniach_writemem)
411 	MDRV_CPU_VBLANK_INT(irq0_line_hold,1)
412 
413 	MDRV_CPU_ADD(M6809, 1500000)
414 	MDRV_CPU_FLAGS(CPU_AUDIO_CPU)	/* 1.5 MHz ???? */
415 	MDRV_CPU_MEMORY(maniach_sound_readmem,maniach_sound_writemem)
416 								/* IRQs are caused by the main CPU */
417 	MDRV_CPU_ADD(M68705, 500000)	/* .5 MHz (don't know really how fast, but it doesn't need to even be this fast) */
418 	MDRV_CPU_MEMORY(mcu_readmem,mcu_writemem)
419 
420 	MDRV_FRAMES_PER_SECOND(60)
421 	MDRV_VBLANK_DURATION(DEFAULT_REAL_60HZ_VBLANK_DURATION)
422 	MDRV_INTERLEAVE(100)	/* 100 CPU slice per frame - high interleaving to sync main and mcu */
423 
424 	/* video hardware */
425 	MDRV_VIDEO_ATTRIBUTES(VIDEO_TYPE_RASTER)
426 	MDRV_SCREEN_SIZE(32*8, 32*8)
427 	MDRV_VISIBLE_AREA(0*8, 32*8-1, 1*8, 31*8-1)
428 	MDRV_GFXDECODE(maniach_gfxdecodeinfo)
429 	MDRV_PALETTE_LENGTH(64+16)
430 	MDRV_COLORTABLE_LENGTH(64+16)
431 
432 	MDRV_PALETTE_INIT(matmania)
433 	MDRV_VIDEO_START(matmania)
434 	MDRV_VIDEO_UPDATE(maniach)
435 
436 	/* sound hardware */
437 	MDRV_SOUND_ADD(YM3526, ym3526_interface)
438 	MDRV_SOUND_ADD(DAC, dac_interface)
439 MACHINE_DRIVER_END
440 
441 /***************************************************************************
442 
443   Mat Mania driver
444 
445 ***************************************************************************/
446 
447 ROM_START( matmania )
448 	ROM_REGION( 0x10000, REGION_CPU1, 0 )	/* 64k for code */
449 	ROM_LOAD( "k0-03",        0x4000, 0x4000, CRC(314ab8a4) SHA1(dc86b2f71a9af8524edad2317343b0d05fe5ef4a) )
450 	ROM_LOAD( "k1-03",        0x8000, 0x4000, CRC(3b3c3f08) SHA1(65f0c5dba0b8eeb5c2d42b050cac37c475e6a398) )
451 	ROM_LOAD( "k2-03",        0xc000, 0x4000, CRC(286c0917) SHA1(50d6133406e7db0694b02858c7d06725744cf243) )
452 
453 	ROM_REGION( 0x10000, REGION_CPU2, 0 )	/* 64k for audio code */
454 	ROM_LOAD( "k4-0",         0x8000, 0x4000, CRC(86dab489) SHA1(27f6eea29b0287e461e0e321fd7bfaada52c39dc) )
455 	ROM_LOAD( "k5-0",         0xc000, 0x4000, CRC(4c41cdba) SHA1(a0af0c019bd6d9456cbbe83ecdeee689bc5f1bea) )
456 
457 	ROM_REGION( 0x06000, REGION_GFX1, ROMREGION_DISPOSE )
458 	ROM_LOAD( "ku-02",        0x00000, 0x2000, CRC(613c8698) SHA1(07acb2fe150a64029fd15d177c8b6481fcd9eb0b) )	/* Character ROMs - 1024 chars, 3 bpp */
459 	ROM_LOAD( "kv-02",        0x02000, 0x2000, CRC(274ce14b) SHA1(58ed8c8fe0cc157d642aae596e41f2099c1ea6b1) )
460 	ROM_LOAD( "kw-02",        0x04000, 0x2000, CRC(7588a9c4) SHA1(0c197a8fea1acb6c9a99071845be54c949ec83b1) )
461 
462 	ROM_REGION( 0x0c000, REGION_GFX2, ROMREGION_DISPOSE )
463 	ROM_LOAD( "kt-02",        0x00000, 0x4000, CRC(5d817c70) SHA1(f7759be40a8850d325440d336241ecd05b80c0bd) )	/* tile set */
464 	ROM_LOAD( "ks-02",        0x04000, 0x4000, CRC(2e9f3ba0) SHA1(21d6686580de6ecfe57e458821fa92e966a42d95) )
465 	ROM_LOAD( "kr-02",        0x08000, 0x4000, CRC(b057d3e3) SHA1(24216b22a69c1ecc7eabd7ae10de381e1ff0afc1) )
466 
467 	ROM_REGION( 0x54000, REGION_GFX3, ROMREGION_DISPOSE )
468 	ROM_LOAD( "k6-00",        0x00000, 0x4000, CRC(294d0878) SHA1(0aaae97e35d504dbf6c479ddf04b981847a23ea6) )	/* sprites */
469 	ROM_LOAD( "k7-00",        0x04000, 0x4000, CRC(0908c2f5) SHA1(acc34c578f9a3521855ad4dd8fbd554e05c3f63c) )
470 	ROM_LOAD( "k8-00",        0x08000, 0x4000, CRC(ae8341e1) SHA1(ca198087b3aec320543a19921015861324ace8a2) )
471 	ROM_LOAD( "k9-00",        0x0c000, 0x4000, CRC(752ac2c6) SHA1(309fe4e396616b569b9b25654e3dc2751d7b1605) )
472 	ROM_LOAD( "ka-00",        0x10000, 0x4000, CRC(46a9cb16) SHA1(35e6bd4f33098c98bf2d0b1dfefec2f9d25444e7) )
473 	ROM_LOAD( "kb-00",        0x14000, 0x4000, CRC(bf016772) SHA1(c901fc2d553622b6dbfaaa9cd94759799d974c39) )
474 	ROM_LOAD( "kc-00",        0x18000, 0x4000, CRC(8d08bce7) SHA1(1433962c837f568cc1eb27464e243dc580a141de) )
475 	ROM_LOAD( "kd-00",        0x1c000, 0x4000, CRC(af1d6a60) SHA1(ae3131e3e1fcc9bb1d59db6b1668f6838849241d) )
476 	ROM_LOAD( "ke-00",        0x20000, 0x4000, CRC(614f19b0) SHA1(67e4687b9be36007c2e1fd504a2eb952fe098d53) )
477 	ROM_LOAD( "kf-00",        0x24000, 0x4000, CRC(bdf58c18) SHA1(a76c6984e4d4f88384e15d0b6b74093c3bc0fcda) )
478 	ROM_LOAD( "kg-00",        0x28000, 0x4000, CRC(2189f5cf) SHA1(48289263f7b9cc5b6d975742d45dd64ba45e38c8) )
479 	ROM_LOAD( "kh-00",        0x2c000, 0x4000, CRC(6b11ed1f) SHA1(8b5c52a14ac3f80ebf630fed8108df17106efd93) )
480 	ROM_LOAD( "ki-00",        0x30000, 0x4000, CRC(d7ac4ec5) SHA1(35b1503147cb521d2fcc756e6f90ef70d62e2d04) )
481 	ROM_LOAD( "kj-00",        0x34000, 0x4000, CRC(2caee05d) SHA1(51e0799312e4737bc6f6ae7b74d02f9e10f91c3b) )
482 	ROM_LOAD( "kk-00",        0x38000, 0x4000, CRC(eb54f010) SHA1(9ed8addd8a542299be2a8f0108447e68b9b33436) )
483 	ROM_LOAD( "kl-00",        0x3c000, 0x4000, CRC(fa4c7e0c) SHA1(365f5b60ac880928b49a254a5a49a9e9a766046d) )
484 	ROM_LOAD( "km-00",        0x40000, 0x4000, CRC(6d2369b6) SHA1(b3071cc27598045167681a00f41bf77b6d4bd5bd) )
485 	ROM_LOAD( "kn-00",        0x44000, 0x4000, CRC(c55733e2) SHA1(b550afd2ceb3b0159c11627ab31f49cc49785809) )
486 	ROM_LOAD( "ko-00",        0x48000, 0x4000, CRC(ed3c3476) SHA1(eb7bc7c72443d4e3bdfc535bfe460524c0f900d3) )
487 	ROM_LOAD( "kp-00",        0x4c000, 0x4000, CRC(9c84a969) SHA1(8492ba523e1c1ca94eeba1e53521dd74df854cb9) )
488 	ROM_LOAD( "kq-00",        0x50000, 0x4000, CRC(fa2f0003) SHA1(7327ce822be8aea360210bbd466a8129788a65c3) )
489 
490 	ROM_REGION( 0x0080, REGION_PROMS, 0 )
491 	ROM_LOAD( "matmania.1",   0x0000, 0x0020, CRC(1b58f01f) SHA1(ffc098d85413777740a25c767096ba5b2aeaf5a8) ) /* char palette red and green components */
492 	ROM_LOAD( "matmania.5",   0x0020, 0x0020, CRC(2029f85f) SHA1(7825d42eed284ea0fe7fd60304b8a27a1b5a4075) ) /* tile palette red and green components */
493 	ROM_LOAD( "matmania.2",   0x0040, 0x0020, CRC(b6ac1fd5) SHA1(e312a8ff7317eb21320308400539a733c27e8fca) ) /* char palette blue component */
494 	ROM_LOAD( "matmania.16",  0x0060, 0x0020, CRC(09325dc2) SHA1(3d9ebdf73840a9603af2acc4bcc4339f3029d284) ) /* tile palette blue component */
495 ROM_END
496 
497 ROM_START( excthour )
498 	ROM_REGION( 0x10000, REGION_CPU1, 0 )	/* 64k for code */
499 	ROM_LOAD( "e29",          0x04000, 0x4000, CRC(c453e855) SHA1(52ce83042ec04e7ba5b45a61316d6281cb10170a) )
500 	ROM_LOAD( "e28",          0x08000, 0x4000, CRC(17b63708) SHA1(01c868b7ea32c4857f7187ce73a4cab5b4def246) )
501 	ROM_LOAD( "e27",          0x0c000, 0x4000, CRC(269ab3bc) SHA1(f2f307c5fc6d50167be8904bef8c7ef21209be50) )
502 
503 	ROM_REGION( 0x10000, REGION_CPU2, 0 )	/* 64k for audio code */
504 	ROM_LOAD( "k4-0",         0x8000, 0x4000, CRC(86dab489) SHA1(27f6eea29b0287e461e0e321fd7bfaada52c39dc) )
505 	ROM_LOAD( "k5-0",         0xc000, 0x4000, CRC(4c41cdba) SHA1(a0af0c019bd6d9456cbbe83ecdeee689bc5f1bea) )
506 
507 	ROM_REGION( 0x06000, REGION_GFX1, ROMREGION_DISPOSE )
508 	ROM_LOAD( "e30",          0x00000, 0x2000, CRC(b2875329) SHA1(b37a8b95eb09f1ddc422cc981184b3ea40a5730d) )	/* Character ROMs - 1024 chars, 3 bpp */
509 	ROM_LOAD( "e31",          0x02000, 0x2000, CRC(c9506de8) SHA1(1036f9acd8b391c03e6408fe1db3406e105373d9) )
510 	ROM_LOAD( "e32",          0x04000, 0x2000, CRC(00d1635f) SHA1(3a7a20ff949d333ec4d3c0287d73e15dcfefdc71) )
511 
512 	ROM_REGION( 0x0c000, REGION_GFX2, ROMREGION_DISPOSE )
513 	ROM_LOAD( "e5",           0x00000, 0x4000, CRC(0604dc55) SHA1(dc4e36dac1a820d4e649132206a8b16603d08192) )	/* tile set */
514 	ROM_LOAD( "ks-02",        0x04000, 0x4000, CRC(2e9f3ba0) SHA1(21d6686580de6ecfe57e458821fa92e966a42d95) )
515 	ROM_LOAD( "e3",           0x08000, 0x4000, CRC(ebd273c6) SHA1(415f68ee10499583f5557aae6a41b5499013b5d2) )
516 
517 	ROM_REGION( 0x54000, REGION_GFX3, ROMREGION_DISPOSE )
518 	ROM_LOAD( "k6-00",        0x00000, 0x4000, CRC(294d0878) SHA1(0aaae97e35d504dbf6c479ddf04b981847a23ea6) )	/* sprites */
519 	ROM_LOAD( "k7-00",        0x04000, 0x4000, CRC(0908c2f5) SHA1(acc34c578f9a3521855ad4dd8fbd554e05c3f63c) )
520 	ROM_LOAD( "k8-00",        0x08000, 0x4000, CRC(ae8341e1) SHA1(ca198087b3aec320543a19921015861324ace8a2) )
521 	ROM_LOAD( "k9-00",        0x0c000, 0x4000, CRC(752ac2c6) SHA1(309fe4e396616b569b9b25654e3dc2751d7b1605) )
522 	ROM_LOAD( "ka-00",        0x10000, 0x4000, CRC(46a9cb16) SHA1(35e6bd4f33098c98bf2d0b1dfefec2f9d25444e7) )
523 	ROM_LOAD( "kb-00",        0x14000, 0x4000, CRC(bf016772) SHA1(c901fc2d553622b6dbfaaa9cd94759799d974c39) )
524 	ROM_LOAD( "kc-00",        0x18000, 0x4000, CRC(8d08bce7) SHA1(1433962c837f568cc1eb27464e243dc580a141de) )
525 	ROM_LOAD( "kd-00",        0x1c000, 0x4000, CRC(af1d6a60) SHA1(ae3131e3e1fcc9bb1d59db6b1668f6838849241d) )
526 	ROM_LOAD( "ke-00",        0x20000, 0x4000, CRC(614f19b0) SHA1(67e4687b9be36007c2e1fd504a2eb952fe098d53) )
527 	ROM_LOAD( "kf-00",        0x24000, 0x4000, CRC(bdf58c18) SHA1(a76c6984e4d4f88384e15d0b6b74093c3bc0fcda) )
528 	ROM_LOAD( "kg-00",        0x28000, 0x4000, CRC(2189f5cf) SHA1(48289263f7b9cc5b6d975742d45dd64ba45e38c8) )
529 	ROM_LOAD( "kh-00",        0x2c000, 0x4000, CRC(6b11ed1f) SHA1(8b5c52a14ac3f80ebf630fed8108df17106efd93) )
530 	ROM_LOAD( "ki-00",        0x30000, 0x4000, CRC(d7ac4ec5) SHA1(35b1503147cb521d2fcc756e6f90ef70d62e2d04) )
531 	ROM_LOAD( "kj-00",        0x34000, 0x4000, CRC(2caee05d) SHA1(51e0799312e4737bc6f6ae7b74d02f9e10f91c3b) )
532 	ROM_LOAD( "kk-00",        0x38000, 0x4000, CRC(eb54f010) SHA1(9ed8addd8a542299be2a8f0108447e68b9b33436) )
533 	ROM_LOAD( "kl-00",        0x3c000, 0x4000, CRC(fa4c7e0c) SHA1(365f5b60ac880928b49a254a5a49a9e9a766046d) )
534 	ROM_LOAD( "km-00",        0x40000, 0x4000, CRC(6d2369b6) SHA1(b3071cc27598045167681a00f41bf77b6d4bd5bd) )
535 	ROM_LOAD( "kn-00",        0x44000, 0x4000, CRC(c55733e2) SHA1(b550afd2ceb3b0159c11627ab31f49cc49785809) )
536 	ROM_LOAD( "ko-00",        0x48000, 0x4000, CRC(ed3c3476) SHA1(eb7bc7c72443d4e3bdfc535bfe460524c0f900d3) )
537 	ROM_LOAD( "kp-00",        0x4c000, 0x4000, CRC(9c84a969) SHA1(8492ba523e1c1ca94eeba1e53521dd74df854cb9) )
538 	ROM_LOAD( "kq-00",        0x50000, 0x4000, CRC(fa2f0003) SHA1(7327ce822be8aea360210bbd466a8129788a65c3) )
539 
540 	ROM_REGION( 0x0080, REGION_PROMS, 0 )
541 	ROM_LOAD( "matmania.1",   0x0000, 0x0020, CRC(1b58f01f) SHA1(ffc098d85413777740a25c767096ba5b2aeaf5a8) ) /* char palette red and green components */
542 	ROM_LOAD( "matmania.5",   0x0020, 0x0020, CRC(2029f85f) SHA1(7825d42eed284ea0fe7fd60304b8a27a1b5a4075) ) /* tile palette red and green components */
543 	ROM_LOAD( "matmania.2",   0x0040, 0x0020, CRC(b6ac1fd5) SHA1(e312a8ff7317eb21320308400539a733c27e8fca) ) /* char palette blue component */
544 	ROM_LOAD( "matmania.16",  0x0060, 0x0020, CRC(09325dc2) SHA1(3d9ebdf73840a9603af2acc4bcc4339f3029d284) ) /* tile palette blue component */
545 ROM_END
546 
547 ROM_START( maniach )
548 	ROM_REGION( 0x10000, REGION_CPU1, 0 )	/* 64k for code */
549 	ROM_LOAD( "mc-mb2.bin",   0x04000, 0x4000, CRC(a6da1ba8) SHA1(d861c1c68b25272205939df43cdcca423ba7c937) )
550 	ROM_LOAD( "mc-ma2.bin",   0x08000, 0x4000, CRC(84583323) SHA1(f1512fec6f3e03dc633a96917a114b0b6369c577) )
551 	ROM_LOAD( "mc-m92.bin",   0x0c000, 0x4000, CRC(e209a500) SHA1(d1a3ab91ffbc321a51c99a2170aca3e217b22576) )
552 
553 	ROM_REGION( 0x10000, REGION_CPU2, 0 )	/* 64k for audio code */
554 	ROM_LOAD( "mc-m50.bin",   0x4000, 0x4000, CRC(ba415d68) SHA1(484af7a1f109cc9546f17d19b53d284c934705db) )
555 	ROM_LOAD( "mc-m40.bin",   0x8000, 0x4000, CRC(2a217ed0) SHA1(b06f7c9a2c96ffe78a7065e5edadfdbf985305a5) )
556 	ROM_LOAD( "mc-m30.bin",   0xc000, 0x4000, CRC(95af1723) SHA1(691ca3f7400d10897e805ff691c904fb2d5bb53a) )
557 
558 	ROM_REGION( 0x0800, REGION_CPU3, 0 )	/* 8k for the microcontroller */
559 	ROM_LOAD( "01",           0x0000, 0x0800, CRC(00c7f80c) SHA1(d2216f660eb8310b1530fa5dc844d26ba90c5e9c) )
560 
561 	ROM_REGION( 0x06000, REGION_GFX1, ROMREGION_DISPOSE )
562 	ROM_LOAD( "mc-m60.bin",   0x00000, 0x2000, CRC(1cdbb117) SHA1(cce99c7380fa2a7ae070c7e2d64866866c976085) )	/* Character ROMs - 1024 chars, 3 bpp */
563 	ROM_LOAD( "mc-m70.bin",   0x02000, 0x2000, CRC(553f0780) SHA1(eacce92ae7b872a35f289f79b33383f5442082d5) )
564 	ROM_LOAD( "mc-m80.bin",   0x04000, 0x2000, CRC(9392ecb7) SHA1(fb4be39fc2f1c826b146bb5b4dd10eb56b23c300) )
565 
566 	ROM_REGION( 0x18000, REGION_GFX2, ROMREGION_DISPOSE )
567 	ROM_LOAD( "mc-m01.bin",   0x00000, 0x8000, CRC(da558e4d) SHA1(0635f4cded061b0b3649ed1497f087ecd53d54a3) )	/* tile set */
568 	ROM_LOAD( "mc-m10.bin",   0x08000, 0x8000, CRC(619a02f8) SHA1(18de76277c263c76b8d8d9093b3c1aebbf2b7ae4) )
569 	ROM_LOAD( "mc-m20.bin",   0x10000, 0x8000, CRC(a617c6c1) SHA1(dccae543daa9987f2778327145fc785472f41228) )
570 
571 	ROM_REGION( 0x54000, REGION_GFX3, ROMREGION_DISPOSE )
572 	ROM_LOAD( "mc-mc0.bin",   0x00000, 0x4000, CRC(133d644f) SHA1(5378e0cb665c0aa65d7ad76c3f7c04a3bc301f64) )	/* sprites */
573 	ROM_LOAD( "mc-md0.bin",   0x04000, 0x4000, CRC(e387b036) SHA1(828a42789d9ced9f9fcdfd08a43530008dcbbf2f) )
574 	ROM_LOAD( "mc-me0.bin",   0x08000, 0x4000, CRC(b36b1283) SHA1(9d12ea9f7a0f12aad532c0f2d3608cf4a86933a6) )
575 	ROM_LOAD( "mc-mf0.bin",   0x0c000, 0x4000, CRC(2584d8a9) SHA1(f24b4cb827421cd51cb35b581622c41646f3f4d8) )
576 	ROM_LOAD( "mc-mg0.bin",   0x10000, 0x4000, CRC(cf31a714) SHA1(9740f36e279fc4404112145abb4ff4d138f46474) )
577 	ROM_LOAD( "mc-mh0.bin",   0x14000, 0x4000, CRC(6292d589) SHA1(a0bf50ebc7712d9bea082834025d3bf816e5afa6) )
578 	ROM_LOAD( "mc-mi0.bin",   0x18000, 0x4000, CRC(ee2e06e3) SHA1(fbe0457322f5ae03e7eb46b27f044a46f3ee36b5) )
579 	ROM_LOAD( "mc-mj0.bin",   0x1c000, 0x4000, CRC(7e73895b) SHA1(76861f16f6845e53b80564eb869cfc6767040aa5) )
580 	ROM_LOAD( "mc-mk0.bin",   0x20000, 0x4000, CRC(66c8bf75) SHA1(071c8635c0264397363d6a33297fd1404f0531a9) )
581 	ROM_LOAD( "mc-ml0.bin",   0x24000, 0x4000, CRC(88138a1d) SHA1(a669620d51495734f0270fe49c75663cc54e2e50) )
582 	ROM_LOAD( "mc-mm0.bin",   0x28000, 0x4000, CRC(a1a4260d) SHA1(fbeeac9929f0b273deb1add39db228d3a6d74e76) )
583 	ROM_LOAD( "mc-mn0.bin",   0x2c000, 0x4000, CRC(6bc61b58) SHA1(dd5e1f8e7299358c6684cb99c4b47b1cf1dc64a7) )
584 	ROM_LOAD( "mc-mo0.bin",   0x30000, 0x4000, CRC(f96ef600) SHA1(f739ae6c45b2d46a587f8ce32d7626669225ad57) )
585 	ROM_LOAD( "mc-mp0.bin",   0x34000, 0x4000, CRC(1259618e) SHA1(9f3169675f7add038746edae2ab83fc0a7746db6) )
586 	ROM_LOAD( "mc-mq0.bin",   0x38000, 0x4000, CRC(102a1666) SHA1(ab052e76a3cef68dd199b5ecf01b73a8abaa32a7) )
587 	ROM_LOAD( "mc-mr0.bin",   0x3c000, 0x4000, CRC(1e854453) SHA1(41d4997361132c63fcd52dba23885a10ae34bf82) )
588 	ROM_LOAD( "mc-ms0.bin",   0x40000, 0x4000, CRC(7bc9d878) SHA1(72689ec3263e179f76c7139ed4a82684781d7bb6) )
589 	ROM_LOAD( "mc-mt0.bin",   0x44000, 0x4000, CRC(09cea985) SHA1(805c58bf73ea19329aa2c8a88a0c35cfaceca985) )
590 	ROM_LOAD( "mc-mu0.bin",   0x48000, 0x4000, CRC(5421769e) SHA1(c662c53711acf28754a60aedb4637d7d528dc5ea) )
591 	ROM_LOAD( "mc-mv0.bin",   0x4c000, 0x4000, CRC(36fc3e2d) SHA1(6cd358f29536ff6d5087570cb3e26fd9e971b888) )
592 	ROM_LOAD( "mc-mw0.bin",   0x50000, 0x4000, CRC(135dce4c) SHA1(3e64a52400137d87b60adf9c307656eadbfe709c) )
593 
594 	ROM_REGION( 0x0080, REGION_PROMS, 0 )
595 	ROM_LOAD( "prom.2",       0x0000, 0x0020, CRC(32db2cf4) SHA1(854b3226a4843a6db94c01c6571294f17a469acf) ) /* char palette red and green components */
596 	ROM_LOAD( "prom.16",      0x0020, 0x0020, CRC(18836d26) SHA1(950e1ea5184355501b41548d40732b96c5516fd7) ) /* tile palette red and green components */
597 	ROM_LOAD( "prom.3",       0x0040, 0x0020, CRC(c7925311) SHA1(6b997803eb630b79886cebbe3bc49db1c1ab3fd9) ) /* char palette blue component */
598 	ROM_LOAD( "prom.17",      0x0060, 0x0020, CRC(41f51d49) SHA1(7cfaf308752cbfddf5a37a31140119afc3febaa7) ) /* tile palette blue component */
599 ROM_END
600 
601 ROM_START( maniach2 )
602 	ROM_REGION( 0x10000, REGION_CPU1, 0 )	/* 64k for code */
603 	ROM_LOAD( "ic40-mb1",     0x04000, 0x4000, CRC(b337a867) SHA1(a615283a70700028267e223df00e70bdd159ec09) )
604 	ROM_LOAD( "ic41-ma1",     0x08000, 0x4000, CRC(85ec8279) SHA1(dada5fa6981573a1fbb235becbc647e1e2d497e1) )
605 	ROM_LOAD( "ic42-m91",     0x0c000, 0x4000, CRC(a14b86dd) SHA1(73172dfeb34846beaa713c8886d56ed691139d06) )
606 
607 	ROM_REGION( 0x10000, REGION_CPU2, 0 )	/* 64k for audio code */
608 	ROM_LOAD( "mc-m50.bin",   0x4000, 0x4000, CRC(ba415d68) SHA1(484af7a1f109cc9546f17d19b53d284c934705db) )
609 	ROM_LOAD( "mc-m40.bin",   0x8000, 0x4000, CRC(2a217ed0) SHA1(b06f7c9a2c96ffe78a7065e5edadfdbf985305a5) )
610 	ROM_LOAD( "mc-m30.bin",   0xc000, 0x4000, CRC(95af1723) SHA1(691ca3f7400d10897e805ff691c904fb2d5bb53a) )
611 
612 	ROM_REGION( 0x0800, REGION_CPU3, 0 )	/* 8k for the microcontroller */
613 	ROM_LOAD( "01",           0x0000, 0x0800, CRC(00c7f80c) SHA1(d2216f660eb8310b1530fa5dc844d26ba90c5e9c) )
614 
615 	ROM_REGION( 0x06000, REGION_GFX1, ROMREGION_DISPOSE )
616 	ROM_LOAD( "mc-m60.bin",   0x00000, 0x2000, CRC(1cdbb117) SHA1(cce99c7380fa2a7ae070c7e2d64866866c976085) )	/* Character ROMs - 1024 chars, 3 bpp */
617 	ROM_LOAD( "mc-m70.bin",   0x02000, 0x2000, CRC(553f0780) SHA1(eacce92ae7b872a35f289f79b33383f5442082d5) )
618 	ROM_LOAD( "mc-m80.bin",   0x04000, 0x2000, CRC(9392ecb7) SHA1(fb4be39fc2f1c826b146bb5b4dd10eb56b23c300) )
619 
620 	ROM_REGION( 0x18000, REGION_GFX2, ROMREGION_DISPOSE )
621 	ROM_LOAD( "mc-m01.bin",   0x00000, 0x8000, CRC(da558e4d) SHA1(0635f4cded061b0b3649ed1497f087ecd53d54a3) )	/* tile set */
622 	ROM_LOAD( "mc-m10.bin",   0x08000, 0x8000, CRC(619a02f8) SHA1(18de76277c263c76b8d8d9093b3c1aebbf2b7ae4) )
623 	ROM_LOAD( "mc-m20.bin",   0x10000, 0x8000, CRC(a617c6c1) SHA1(dccae543daa9987f2778327145fc785472f41228) )
624 
625 	ROM_REGION( 0x54000, REGION_GFX3, ROMREGION_DISPOSE )
626 	ROM_LOAD( "mc-mc0.bin",   0x00000, 0x4000, CRC(133d644f) SHA1(5378e0cb665c0aa65d7ad76c3f7c04a3bc301f64) )	/* sprites */
627 	ROM_LOAD( "mc-md0.bin",   0x04000, 0x4000, CRC(e387b036) SHA1(828a42789d9ced9f9fcdfd08a43530008dcbbf2f) )
628 	ROM_LOAD( "mc-me0.bin",   0x08000, 0x4000, CRC(b36b1283) SHA1(9d12ea9f7a0f12aad532c0f2d3608cf4a86933a6) )
629 	ROM_LOAD( "mc-mf0.bin",   0x0c000, 0x4000, CRC(2584d8a9) SHA1(f24b4cb827421cd51cb35b581622c41646f3f4d8) )
630 	ROM_LOAD( "mc-mg0.bin",   0x10000, 0x4000, CRC(cf31a714) SHA1(9740f36e279fc4404112145abb4ff4d138f46474) )
631 	ROM_LOAD( "mc-mh0.bin",   0x14000, 0x4000, CRC(6292d589) SHA1(a0bf50ebc7712d9bea082834025d3bf816e5afa6) )
632 	ROM_LOAD( "mc-mi0.bin",   0x18000, 0x4000, CRC(ee2e06e3) SHA1(fbe0457322f5ae03e7eb46b27f044a46f3ee36b5) )
633 	ROM_LOAD( "mc-mj0.bin",   0x1c000, 0x4000, CRC(7e73895b) SHA1(76861f16f6845e53b80564eb869cfc6767040aa5) )
634 	ROM_LOAD( "mc-mk0.bin",   0x20000, 0x4000, CRC(66c8bf75) SHA1(071c8635c0264397363d6a33297fd1404f0531a9) )
635 	ROM_LOAD( "mc-ml0.bin",   0x24000, 0x4000, CRC(88138a1d) SHA1(a669620d51495734f0270fe49c75663cc54e2e50) )
636 	ROM_LOAD( "mc-mm0.bin",   0x28000, 0x4000, CRC(a1a4260d) SHA1(fbeeac9929f0b273deb1add39db228d3a6d74e76) )
637 	ROM_LOAD( "mc-mn0.bin",   0x2c000, 0x4000, CRC(6bc61b58) SHA1(dd5e1f8e7299358c6684cb99c4b47b1cf1dc64a7) )
638 	ROM_LOAD( "mc-mo0.bin",   0x30000, 0x4000, CRC(f96ef600) SHA1(f739ae6c45b2d46a587f8ce32d7626669225ad57) )
639 	ROM_LOAD( "mc-mp0.bin",   0x34000, 0x4000, CRC(1259618e) SHA1(9f3169675f7add038746edae2ab83fc0a7746db6) )
640 	ROM_LOAD( "mc-mq0.bin",   0x38000, 0x4000, CRC(102a1666) SHA1(ab052e76a3cef68dd199b5ecf01b73a8abaa32a7) )
641 	ROM_LOAD( "mc-mr0.bin",   0x3c000, 0x4000, CRC(1e854453) SHA1(41d4997361132c63fcd52dba23885a10ae34bf82) )
642 	ROM_LOAD( "mc-ms0.bin",   0x40000, 0x4000, CRC(7bc9d878) SHA1(72689ec3263e179f76c7139ed4a82684781d7bb6) )
643 	ROM_LOAD( "mc-mt0.bin",   0x44000, 0x4000, CRC(09cea985) SHA1(805c58bf73ea19329aa2c8a88a0c35cfaceca985) )
644 	ROM_LOAD( "mc-mu0.bin",   0x48000, 0x4000, CRC(5421769e) SHA1(c662c53711acf28754a60aedb4637d7d528dc5ea) )
645 	ROM_LOAD( "mc-mv0.bin",   0x4c000, 0x4000, CRC(36fc3e2d) SHA1(6cd358f29536ff6d5087570cb3e26fd9e971b888) )
646 	ROM_LOAD( "mc-mw0.bin",   0x50000, 0x4000, CRC(135dce4c) SHA1(3e64a52400137d87b60adf9c307656eadbfe709c) )
647 
648 	ROM_REGION( 0x0080, REGION_PROMS, 0 )
649 	ROM_LOAD( "prom.2",       0x0000, 0x0020, CRC(32db2cf4) SHA1(854b3226a4843a6db94c01c6571294f17a469acf) ) /* char palette red and green components */
650 	ROM_LOAD( "prom.16",      0x0020, 0x0020, CRC(18836d26) SHA1(950e1ea5184355501b41548d40732b96c5516fd7) ) /* tile palette red and green components */
651 	ROM_LOAD( "prom.3",       0x0040, 0x0020, CRC(c7925311) SHA1(6b997803eb630b79886cebbe3bc49db1c1ab3fd9) ) /* char palette blue component */
652 	ROM_LOAD( "prom.17",      0x0060, 0x0020, CRC(41f51d49) SHA1(7cfaf308752cbfddf5a37a31140119afc3febaa7) ) /* tile palette blue component */
653 ROM_END
654 
655 
656 
657 GAME( 1985, matmania, 0,        matmania, matmania, 0, ROT270, "Technos (Taito America license)", "Mat Mania" )
658 GAME( 1985, excthour, matmania, matmania, matmania, 0, ROT270, "Technos (Taito license)", "Exciting Hour" )
659 GAME( 1986, maniach,  0,        maniach,  matmania, 0, ROT270, "Technos (Taito America license)", "Mania Challenge (set 1)" )
660 GAME( 1986, maniach2, maniach,  maniach,  matmania, 0, ROT270, "Technos (Taito America license)", "Mania Challenge (set 2)" )	/* earlier version? */
661