1 /***************************************************************************
2 
3 Ultraman (c) 1991  Banpresto / Bandai
4 
5 Driver by Manuel Abadia <manu@teleline.es>
6 
7 ***************************************************************************/
8 
9 #include "driver.h"
10 #include "cpu/z80/z80.h"
11 #include "cpu/m68000/m68000.h"
12 #include "vidhrdw/generic.h"
13 #include "vidhrdw/konamiic.h"
14 
15 
16 /* from vidhrdw/ultraman.c */
17 WRITE16_HANDLER( ultraman_gfxctrl_w );
18 VIDEO_START( ultraman );
19 VIDEO_UPDATE( ultraman );
20 
21 
22 
READ16_HANDLER(ultraman_K051937_r)23 static READ16_HANDLER( ultraman_K051937_r )
24 {
25 	return K051937_r(offset);
26 }
27 
READ16_HANDLER(ultraman_K051960_r)28 static READ16_HANDLER( ultraman_K051960_r )
29 {
30 	return K051960_r(offset);
31 }
32 
READ16_HANDLER(ultraman_K051316_0_r)33 static READ16_HANDLER( ultraman_K051316_0_r )
34 {
35 	return K051316_0_r(offset);
36 }
37 
READ16_HANDLER(ultraman_K051316_1_r)38 static READ16_HANDLER( ultraman_K051316_1_r )
39 {
40 	return K051316_1_r(offset);
41 }
42 
READ16_HANDLER(ultraman_K051316_2_r)43 static READ16_HANDLER( ultraman_K051316_2_r )
44 {
45 	return K051316_2_r(offset);
46 }
47 
WRITE16_HANDLER(ultraman_K051316_0_w)48 static WRITE16_HANDLER( ultraman_K051316_0_w )
49 {
50 	if (ACCESSING_LSB)
51 		K051316_0_w(offset, data & 0xff);
52 }
53 
WRITE16_HANDLER(ultraman_K051316_1_w)54 static WRITE16_HANDLER( ultraman_K051316_1_w )
55 {
56 	if (ACCESSING_LSB)
57 		K051316_1_w(offset, data & 0xff);
58 }
59 
WRITE16_HANDLER(ultraman_K051316_2_w)60 static WRITE16_HANDLER( ultraman_K051316_2_w )
61 {
62 	if (ACCESSING_LSB)
63 		K051316_2_w(offset, data & 0xff);
64 }
65 
WRITE16_HANDLER(ultraman_K051316_ctrl_0_w)66 static WRITE16_HANDLER( ultraman_K051316_ctrl_0_w )
67 {
68 	if (ACCESSING_LSB)
69 		K051316_ctrl_0_w(offset, data & 0xff);
70 }
71 
WRITE16_HANDLER(ultraman_K051316_ctrl_1_w)72 static WRITE16_HANDLER( ultraman_K051316_ctrl_1_w )
73 {
74 	if (ACCESSING_LSB)
75 		K051316_ctrl_1_w(offset, data & 0xff);
76 
77 }
78 
WRITE16_HANDLER(ultraman_K051316_ctrl_2_w)79 static WRITE16_HANDLER( ultraman_K051316_ctrl_2_w )
80 {
81 	if (ACCESSING_LSB)
82 		K051316_ctrl_2_w(offset, data & 0xff);
83 }
84 
WRITE16_HANDLER(ultraman_K051937_w)85 static WRITE16_HANDLER( ultraman_K051937_w )
86 {
87 	if (ACCESSING_LSB)
88 		K051937_w(offset, data & 0xff);
89 }
90 
WRITE16_HANDLER(ultraman_K051960_w)91 static WRITE16_HANDLER( ultraman_K051960_w )
92 {
93 	if (ACCESSING_LSB)
94 		K051960_w(offset, data & 0xff);
95 }
96 
WRITE16_HANDLER(sound_cmd_w)97 static WRITE16_HANDLER( sound_cmd_w )
98 {
99 	if (ACCESSING_LSB)
100 		soundlatch_w(0,data & 0xff);
101 }
102 
WRITE16_HANDLER(sound_irq_trigger_w)103 static WRITE16_HANDLER( sound_irq_trigger_w )
104 {
105 	if (ACCESSING_LSB)
106 		cpu_set_irq_line(1,IRQ_LINE_NMI,PULSE_LINE);
107 }
108 
109 
110 
MEMORY_READ16_START(ultraman_readmem)111 static MEMORY_READ16_START( ultraman_readmem )
112 	{ 0x000000, 0x03ffff, MRA16_ROM },				/* ROM */
113 	{ 0x080000, 0x08ffff, MRA16_RAM },				/* RAM */
114 	{ 0x180000, 0x183fff, MRA16_RAM },				/* Palette */
115 	{ 0x1c0000, 0x1c0001, input_port_0_word_r },	/* Coins + Service */
116 	{ 0x1c0002, 0x1c0003, input_port_1_word_r },	/* 1P controls */
117 	{ 0x1c0004, 0x1c0005, input_port_2_word_r },	/* 2P controls */
118 	{ 0x1c0006, 0x1c0007, input_port_3_word_r },	/* DIPSW #1 */
119 	{ 0x1c0008, 0x1c0009, input_port_4_word_r },	/* DIPSW #2 */
120 	{ 0x204000, 0x204fff, ultraman_K051316_0_r },	/* K051316 #0 RAM */
121 	{ 0x205000, 0x205fff, ultraman_K051316_1_r },	/* K051316 #1 RAM */
122 	{ 0x206000, 0x206fff, ultraman_K051316_2_r },	/* K051316 #2 RAM */
123 	{ 0x304000, 0x30400f, ultraman_K051937_r },		/* Sprite control */
124 	{ 0x304800, 0x304fff, ultraman_K051960_r },		/* Sprite RAM */
125 MEMORY_END
126 
127 static MEMORY_WRITE16_START( ultraman_writemem )
128 	{ 0x000000, 0x03ffff, MWA16_ROM },					/* ROM */
129 	{ 0x080000, 0x08ffff, MWA16_RAM },					/* RAM */
130 	{ 0x180000, 0x183fff, paletteram16_xRRRRRGGGGGBBBBB_word_w, &paletteram16 },/* Palette */
131 	{ 0x1c0018, 0x1c0019, ultraman_gfxctrl_w },	/* counters + gfx ctrl */
132 	{ 0x1c0020, 0x1c0021, sound_cmd_w },
133 	{ 0x1c0028, 0x1c0029, sound_irq_trigger_w },
134 	{ 0x1c0030, 0x1c0031, watchdog_reset16_w },
135 	{ 0x204000, 0x204fff, ultraman_K051316_0_w },		/* K051316 #0 RAM */
136 	{ 0x205000, 0x205fff, ultraman_K051316_1_w },		/* K051316 #1 RAM */
137 	{ 0x206000, 0x206fff, ultraman_K051316_2_w },		/* K051316 #2 RAM */
138 	{ 0x207f80, 0x207f9f, ultraman_K051316_ctrl_0_w	},	/* K051316 #0 registers  */
139 	{ 0x207fa0, 0x207fbf, ultraman_K051316_ctrl_1_w	},	/* K051316 #1 registers */
140 	{ 0x207fc0, 0x207fdf, ultraman_K051316_ctrl_2_w	},	/* K051316 #2 registers */
141 	{ 0x304000, 0x30400f, ultraman_K051937_w },			/* Sprite control */
142 	{ 0x304800, 0x304fff, ultraman_K051960_w },			/* Sprite RAM */
143 MEMORY_END
144 
145 static MEMORY_READ_START( ultraman_readmem_sound )
146 	{ 0x0000, 0x7fff, MRA_ROM },					/* ROM */
147 	{ 0x8000, 0xbfff, MRA_RAM },					/* RAM */
148 	{ 0xc000, 0xc000, soundlatch_r },				/* Sound latch read */
149 	{ 0xe000, 0xe000, OKIM6295_status_0_r },		/* M6295 */
150 	{ 0xf001, 0xf001, YM2151_status_port_0_r },		/* YM2151 */
151 MEMORY_END
152 
153 static MEMORY_WRITE_START( ultraman_writemem_sound )
154 	{ 0x0000, 0x7fff, MWA_ROM },					/* ROM */
155 	{ 0x8000, 0xbfff, MWA_RAM },					/* RAM */
156 /*	{ 0xd000, 0xd000, MWA_NOP },					 // ??? /*/
157 	{ 0xe000, 0xe000, OKIM6295_data_0_w },			/* M6295 */
158 	{ 0xf000, 0xf000, YM2151_register_port_0_w },	/* YM2151 */
159 	{ 0xf001, 0xf001, YM2151_data_port_0_w },		/* YM2151 */
160 MEMORY_END
161 
162 static PORT_WRITE_START( ultraman_writeport_sound )
163 /*	{ 0x00, 0x00, MWA_NOP },						 // ??? /*/
164 PORT_END
165 
166 
167 INPUT_PORTS_START( ultraman )
168 
169 	PORT_START	/* Coins + Service */
170 	PORT_BIT( 0x0f, IP_ACTIVE_LOW, IPT_UNKNOWN )
171 	PORT_BITX(0x10, IP_ACTIVE_LOW, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
172 	PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_COIN3 )
173 	PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_COIN1 )
174 	PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_COIN2 )
175 
176 	PORT_START	/* IN #1 */
177 	PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_START1 )
178 	PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_UP	  | IPF_8WAY | IPF_PLAYER1 )
179 	PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY | IPF_PLAYER1 )
180 	PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY | IPF_PLAYER1 )
181 	PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY | IPF_PLAYER1 )
182 	PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON1 | IPF_PLAYER1 )
183 	PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_BUTTON2 | IPF_PLAYER1 )
184 	PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_BUTTON3 | IPF_PLAYER1 )
185 
186 	PORT_START	/* IN #2 */
187 	PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_START2 )
188 	PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_UP	  | IPF_8WAY | IPF_PLAYER2 )
189 	PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY | IPF_PLAYER2 )
190 	PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY | IPF_PLAYER2 )
191 	PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY | IPF_PLAYER2 )
192 	PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON1 | IPF_PLAYER2 )
193 	PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_BUTTON2 | IPF_PLAYER2 )
194 	PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_BUTTON3 | IPF_PLAYER2 )
195 
196 	PORT_START	/* DSW #1 */
197 	PORT_DIPNAME( 0x0f, 0x0f, DEF_STR( Coin_A ) )
198 	PORT_DIPSETTING(    0x02, DEF_STR( 4C_1C ) )
199 	PORT_DIPSETTING(    0x05, DEF_STR( 3C_1C ) )
200 	PORT_DIPSETTING(    0x08, DEF_STR( 2C_1C ) )
201 	PORT_DIPSETTING(    0x04, DEF_STR( 3C_2C ) )
202 	PORT_DIPSETTING(    0x01, DEF_STR( 4C_3C ) )
203 	PORT_DIPSETTING(    0x0f, DEF_STR( 1C_1C ) )
204 	PORT_DIPSETTING(    0x03, DEF_STR( 3C_4C ) )
205 	PORT_DIPSETTING(    0x07, DEF_STR( 2C_3C ) )
206 	PORT_DIPSETTING(    0x0e, DEF_STR( 1C_2C ) )
207 	PORT_DIPSETTING(    0x06, DEF_STR( 2C_5C ) )
208 	PORT_DIPSETTING(    0x0d, DEF_STR( 1C_3C ) )
209 	PORT_DIPSETTING(    0x0c, DEF_STR( 1C_4C ) )
210 	PORT_DIPSETTING(    0x0b, DEF_STR( 1C_5C ) )
211 	PORT_DIPSETTING(    0x0a, DEF_STR( 1C_6C ) )
212 	PORT_DIPSETTING(    0x09, DEF_STR( 1C_7C ) )
213 	PORT_DIPSETTING(    0x00, DEF_STR( Free_Play ) )
214 
215 	PORT_DIPNAME( 0xf0, 0xf0, DEF_STR( Coin_B ) )
216 	PORT_DIPSETTING(    0x20, DEF_STR( 4C_1C ) )
217 	PORT_DIPSETTING(    0x50, DEF_STR( 3C_1C ) )
218 	PORT_DIPSETTING(    0x80, DEF_STR( 2C_1C ) )
219 	PORT_DIPSETTING(    0x00, DEF_STR( 5C_3C ) )
220 	PORT_DIPSETTING(    0x40, DEF_STR( 3C_2C ) )
221 	PORT_DIPSETTING(    0x10, DEF_STR( 4C_3C ) )
222 	PORT_DIPSETTING(    0xf0, DEF_STR( 1C_1C ) )
223 	PORT_DIPSETTING(    0x30, DEF_STR( 3C_4C ) )
224 	PORT_DIPSETTING(    0x70, DEF_STR( 2C_3C ) )
225 	PORT_DIPSETTING(    0xe0, DEF_STR( 1C_2C ) )
226 	PORT_DIPSETTING(    0x60, DEF_STR( 2C_5C ) )
227 	PORT_DIPSETTING(    0xd0, DEF_STR( 1C_3C ) )
228 	PORT_DIPSETTING(    0xc0, DEF_STR( 1C_4C ) )
229 	PORT_DIPSETTING(    0xb0, DEF_STR( 1C_5C ) )
230 	PORT_DIPSETTING(    0xa0, DEF_STR( 1C_6C ) )
231 	PORT_DIPSETTING(    0x90, DEF_STR( 1C_7C ) )
232 
233 	PORT_START	/* DSW #2 */
234 	PORT_DIPNAME( 0x01, 0x01, DEF_STR( Unknown ) )
235 	PORT_DIPSETTING(	0x01, DEF_STR( Off ) )
236 	PORT_DIPSETTING(	0x00, DEF_STR( On ) )
237 	PORT_DIPNAME( 0x02, 0x02, DEF_STR( Unknown ) )
238 	PORT_DIPSETTING(	0x02, DEF_STR( Off ) )
239 	PORT_DIPSETTING(	0x00, DEF_STR( On ) )
240 	PORT_DIPNAME( 0x04, 0x04, "Allow Continue" )
241 	PORT_DIPSETTING(	0x00, DEF_STR( No ) )
242 	PORT_DIPSETTING(	0x04, DEF_STR( Yes ) )
243 	PORT_DIPNAME( 0x08, 0x00, DEF_STR( Demo_Sounds ) )
244 	PORT_DIPSETTING(	0x08, DEF_STR( Off ) )
245 	PORT_DIPSETTING(	0x00, DEF_STR( On ) )
246 	PORT_DIPNAME( 0x30, 0x30, DEF_STR( Difficulty ) )
247 	PORT_DIPSETTING(	0x10, "Easy" )
248 	PORT_DIPSETTING(	0x30, "Normal" )
249 	PORT_DIPSETTING(	0x20, "Difficult" )
250 	PORT_DIPSETTING(	0x00, "Very Difficult" )
251 	PORT_DIPNAME( 0x40, 0x40, "Upright Controls" )
252 	PORT_DIPSETTING(	0x40, "Single" )
253 	PORT_DIPSETTING(	0x00, "Dual" )
254 	PORT_DIPNAME( 0x80, 0x00, DEF_STR( Cabinet ) )
255 	PORT_DIPSETTING(	0x00, DEF_STR( Upright ) )
256 	PORT_DIPSETTING(	0x80, DEF_STR( Cocktail ) )
257 INPUT_PORTS_END
258 
259 
260 
261 static struct YM2151interface ym2151_interface =
262 {
263 	1,
264 	24000000/6,	/* 4 MHz (tempo verified against real board) */
265 	{ YM3012_VOL(100,MIXER_PAN_LEFT,100,MIXER_PAN_RIGHT) },
266 	{ 0 },
267 };
268 
269 static struct OKIM6295interface okim6295_interface =
270 {
271 	1,					/* 1 chip */
272 	{ 8000 },			/* 8KHz? */
273 	{ REGION_SOUND1 },	/* memory region */
274 	{ 50 }
275 };
276 
277 
278 
279 static MACHINE_DRIVER_START( ultraman )
280 
281 	/* basic machine hardware */
282 	MDRV_CPU_ADD(M68000,24000000/2)		/* 12 MHz? */
MDRV_CPU_MEMORY(ultraman_readmem,ultraman_writemem)283 	MDRV_CPU_MEMORY(ultraman_readmem,ultraman_writemem)
284 	MDRV_CPU_VBLANK_INT(irq4_line_hold,1)
285 
286 	MDRV_CPU_ADD(Z80,24000000/6)
287 	MDRV_CPU_FLAGS(CPU_AUDIO_CPU)		/* 4 MHz? */
288 	MDRV_CPU_MEMORY(ultraman_readmem_sound,ultraman_writemem_sound)
289 	MDRV_CPU_PORTS(0,ultraman_writeport_sound)
290 
291 	MDRV_FRAMES_PER_SECOND(60)
292 	MDRV_VBLANK_DURATION(DEFAULT_REAL_60HZ_VBLANK_DURATION)
293 	MDRV_INTERLEAVE(10)
294 
295 	/* video hardware */
296 	MDRV_VIDEO_ATTRIBUTES(VIDEO_TYPE_RASTER | VIDEO_HAS_SHADOWS)
297 	MDRV_SCREEN_SIZE(64*8, 32*8)
298 	MDRV_VISIBLE_AREA(14*8, (64-14)*8-1, 2*8, 30*8-1 )
299 	MDRV_PALETTE_LENGTH(8192)
300 
301 	MDRV_VIDEO_START(ultraman)
302 	MDRV_VIDEO_UPDATE(ultraman)
303 
304 	/* sound hardware */
305 	MDRV_SOUND_ATTRIBUTES(SOUND_SUPPORTS_STEREO)
306 	MDRV_SOUND_ADD(YM2151, ym2151_interface)
307 	MDRV_SOUND_ADD(OKIM6295, okim6295_interface)
308 MACHINE_DRIVER_END
309 
310 
311 
312 ROM_START( ultraman )
313 	ROM_REGION( 0x040000, REGION_CPU1, 0 )	/* 68000 code */
314 	ROM_LOAD16_BYTE(	"910-b01.c11",	0x000000, 0x020000, CRC(3d9e4323) SHA1(54ee218c9be1ac029836624839d0845b39e6e30f) )
315 	ROM_LOAD16_BYTE(	"910-b02.d11",	0x000001, 0x020000, CRC(d24c82e9) SHA1(e792e2601e235939546fe98d52bfafe5a95b3491) )
316 
317 	ROM_REGION( 0x010000, REGION_CPU2, 0 )	/* Z80 code */
318 	ROM_LOAD( "910-a05.d05",	0x00000, 0x08000, CRC(ebaef189) SHA1(73e6163466d55ae782f55839ba9c98f06c30876b) )
319 
320 	ROM_REGION( 0x100000, REGION_GFX1, 0 )	/* Sprites */
321 	ROM_LOAD( "910-a19.l04",	0x000000, 0x080000, CRC(2dc9ffdc) SHA1(aa34247c82d48c8d13f5209be292127938a4a682) )
322 	ROM_LOAD( "910-a20.l01",	0x080000, 0x080000, CRC(a4298dce) SHA1(62faf8f0c0490a9562b75ce27909fbee6e84b22a) )
323 
324 	ROM_REGION( 0x080000, REGION_GFX2, 0 )	/* BG 1  */
325 	ROM_LOAD( "910-a07.j15",	0x000000, 0x020000, CRC(8b43a64e) SHA1(e373d0fd88b59fb01782dfaeccb1e13673a35766) )
326 	ROM_LOAD( "910-a08.j16",	0x020000, 0x020000, CRC(c3829826) SHA1(0d383a7afac2a3b5da692375a2b2cd675848861a) )
327 	ROM_LOAD( "910-a09.j18",	0x040000, 0x020000, CRC(ee10b519) SHA1(a34bd7d89bb8a19af7252ed96ffce212788c586b) )
328 	ROM_LOAD( "910-a10.j19",	0x060000, 0x020000, CRC(cffbb0c3) SHA1(e9ebe350289f0436de10a6289b04eed3b6a9f98e) )
329 
330 	ROM_REGION( 0x080000, REGION_GFX3, 0 ) /* BG 2 */
331 	ROM_LOAD( "910-a11.l15",	0x000000, 0x020000, CRC(17a5581d) SHA1(aca5d465a0e181a266a165aeb0112a4696b0cd18) )
332 	ROM_LOAD( "910-a12.l16",	0x020000, 0x020000, CRC(39763fb5) SHA1(0e1795af4bae545a0a2be265398837fb2d623232) )
333 	ROM_LOAD( "910-a13.l18",	0x040000, 0x020000, CRC(66b25a4f) SHA1(954552b005582c90d570ae32c715108ec4b088f1) )
334 	ROM_LOAD( "910-a14.l19",	0x060000, 0x020000, CRC(09fbd412) SHA1(d11587db7b03f3a75ad8964523bb34f4453bbaca) )
335 
336 	ROM_REGION( 0x080000, REGION_GFX4, 0 ) /* BG 3 */
337 	ROM_LOAD( "910-a15.m15",	0x000000, 0x020000, CRC(6d5bfbb7) SHA1(e98c594446b506cb32cc5cc958d2f0de22ebed5e) )
338 	ROM_LOAD( "910-a16.m16",	0x020000, 0x020000, CRC(5f6f8c3d) SHA1(e365836d2263f36aa4602f0618bf7ce693d2e106) )
339 	ROM_LOAD( "910-a17.m18",	0x040000, 0x020000, CRC(1f3ec4ff) SHA1(875f53516f47decc4ce31154cf4694c8429ee4ea) )
340 	ROM_LOAD( "910-a18.m19",	0x060000, 0x020000, CRC(fdc42929) SHA1(079827c1b1a3c32f8547dd91bba8ae37034c16be) )
341 
342 	ROM_REGION( 0x0100, REGION_PROMS, 0 )
343 	ROM_LOAD( "910-a21.f14",	0x000000, 0x000100, CRC(64460fbc) SHA1(b5295e1d3303d5d816ad44da7b011bbfa613f9e4) )	/* priority encoder (not used) */
344 
345 	ROM_REGION( 0x040000, REGION_SOUND1, 0 )	/* M6295 data */
346 	ROM_LOAD( "910-a06.c06",	0x000000, 0x040000, CRC(28fa99c9) SHA1(54663d79ee105ac18d6ba01333a52e3732f2e5fe) )
347 ROM_END
348 
349 
350 
351 static DRIVER_INIT( ultraman )
352 {
353 	konami_rom_deinterleave_2(REGION_GFX1);
354 }
355 
356 
357 GAME( 1991, ultraman, 0, ultraman, ultraman, ultraman, ROT0, "Banpresto/Bandai", "Ultraman (Japan)" )
358