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