~ubuntu-branches/ubuntu/raring/mame/raring-proposed

« back to all changes in this revision

Viewing changes to mess/src/mame/drivers/lastduel.c

  • Committer: Package Import Robot
  • Author(s): Jordi Mallach, Jordi Mallach, Emmanuel Kasper
  • Date: 2011-12-19 22:56:27 UTC
  • mfrom: (0.1.2)
  • Revision ID: package-import@ubuntu.com-20111219225627-ub5oga1oys4ogqzm
Tags: 0.144-1
[ Jordi Mallach ]
* Fix syntax errors in DEP5 copyright file (lintian).
* Use a versioned copyright Format specification field.
* Update Vcs-* URLs.
* Move transitional packages to the new metapackages section, and make
  them priority extra.
* Remove references to GNU/Linux and MESS sources from copyright.
* Add build variables for s390x.
* Use .xz tarballs as it cuts 4MB for the upstream sources.
* Add nplayers.ini as a patch. Update copyright file to add CC-BY-SA-3.0.

[ Emmanuel Kasper ]
* New upstream release. Closes: #651538.
* Add Free Desktop compliant png icons of various sizes taken from
  the hydroxygen iconset
* Mess is now built from a new source package, to avoid possible source
  incompatibilities between mame and the mess overlay.
* Mame-tools are not built from the mame source package anymore, but
  from the mess source package

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/**************************************************************************
2
 
 
3
 
  Last Duel                       - Capcom, 1988
4
 
  LED Storm                       - Capcom, 1988
5
 
  LED Storm Rally 2011            - Capcom, 1988
6
 
  Mad Gear                        - Capcom, 1989
7
 
 
8
 
  Emulation by Bryan McPhail, mish@tendril.co.uk
9
 
 
10
 
  Trivia ;)  The Mad Gear pcb has an unused pad on the board for an i8751
11
 
microcontroller.
12
 
 
13
 
TODO:
14
 
- The seem to be minor priority issues in Mad Gear, but the game might just
15
 
  be like that. The priority PROM is dumped but currently not used.
16
 
- visible area might be wrong
17
 
 
18
 
 
19
 
PCB Numbers:
20
 
 Mad Gear / LED Storm     Top:87616A-5 / Bottom:87616B-5
21
 
 Last Duel                Top:87615A-4 / Bottom:87615B-3
22
 
 
23
 
**************************************************************************
24
 
 
25
 
Led Storm Rally 2011
26
 
Capcom, 1988
27
 
 
28
 
PCB Layout
29
 
----------
30
 
 
31
 
87616A-5
32
 
       |-----------|     |------------|     |-----------|
33
 
|------|-----------|-----|------------|-----|-----------|------|
34
 
|                                                              |
35
 
|      43256   CPU1.2D     DEC.2F            VR2.2J DL-0100-103|
36
 
|      43256        CPU3.3E                  VR1.3J    24MHz   |
37
 
|                          6116                                |
38
 
|      LS-01.5B            6116                                |
39
 
|                    DSWA                                      |
40
 
|J     LS-02.6B      DSWB                    6116              |
41
 
|A                   DSWC                                      |
42
 
|M     LSU-03.7B                             6116              |
43
 
|M                                                             |
44
 
|A     LSU-04.8B          10MHz       6116                     |
45
 
|                         3.579545MHz                          |
46
 
|      68000                          6116          LS-08.10K  |
47
 
|                        LS-05.10E CPU2.11G         VR3.11K    |
48
 
|                  M6295 LS-06.12E                             |
49
 
|    VOL   5218   YM3014           6116                        |
50
 
|          5218  5218   YM2203               LS-07.14J         |
51
 
| HA13001  5218  5218   YM2203     SOUND.15G Z80               |
52
 
|--------------------------------------------------------------|
53
 
Notes:
54
 
      5218          - Mitsubishi 5218 Op Amp (DIP8)
55
 
      HA13001       - Main power AMP (SIP9)
56
 
      68000         - Clock 10.000MHz (DIP64)
57
 
      Z80           - Clock 3.579545MHz (DIP40)
58
 
      YM3014        - Yamaha YM3014 DAC (DIP8)
59
 
      YM2203        - Clock 3.579545MHz (both, DIP40)
60
 
      M6295         - Oki M6295, clock 1.000MHz [10/10]. Pin 7 HIGH (QFP44)
61
 
      CPU*         \
62
 
      DEC*          | PALs (DIP20)
63
 
      VR*           |
64
 
      SOUND*       /
65
 
      43256         - 32kx8 SRAM (DIP28)
66
 
      6116          - 2kx8 SRAM (DIP24)
67
 
      DL-0100-103   - NEC custom (SDIP64)
68
 
      ROMs          -
69
 
                      LS-07    - 27C512 EPROM (DIP28)
70
 
                      LS-08    - 27C256 EPROM (DIP28)
71
 
                      LS-05/06 - 128kx8 mask ROM (DIP28)
72
 
                      LS-01 thru 04 - 27C1000 EPROM (DIP32)
73
 
      Measurements  -
74
 
                      VSync 57.4444Hz
75
 
                      HSync 15.1432kHz
76
 
                      OSC1  23.99985MHz
77
 
                      OSC2  9.99993MHz
78
 
                      OSC3  3.57943MHz
79
 
 
80
 
87616B-5
81
 
       |-----------|     |------------|     |-----------|
82
 
|------|-----------|-----|------------|-----|-----------|------|
83
 
|               OB7.15J     6116                        81301  |
84
 
|       29.14K      OB3.14G 6116                               |
85
 
|                           6116                      LS-10.13A|
86
 
|       PR10.12K            6116                  6116         |
87
 
|                           OB4                   6116         |
88
 
|       OB10.10K            6116                               |
89
 
|                           6116   OB8.10D                     |
90
 
|       OB11.9K             6116          OB9.9C               |
91
 
|                           6116   OB2.8D                      |
92
 
|       OB12.8K                           OB1.8C        OB6.8A |
93
 
|81301              SCA1.7H OB5.7F SCB3.7D              81301  |
94
 
|LS-12.7L                                                      |
95
 
|       SCB1.5K                                        LS-09.5A|
96
 
|                                2063                          |
97
 
|       SCB2.4K                  2063                          |
98
 
|81301                                                         |
99
 
|       SCA4.2K                  2063                   SCA2.3A|
100
 
|LS-11.2L  SCA3.1K               2063                          |
101
 
|--------------------------------------------------------------|
102
 
Notes:
103
 
      OB*      \
104
 
      SC*       | - PALs
105
 
      PR*      /
106
 
      LS-09/10/12 - NEC 23C2000 256kx8 mask ROM (QFP52)
107
 
      LS-11       - NEC 23C4000 512kx8 mask ROM (QFP64)
108
 
      2063        - 8kx8 SRAM (DIP28)
109
 
      6116        - 2kx8 SRAM (DIP24)
110
 
      81301       - ? (SDIP28)
111
 
      29          - 63S141 bipolar PROM (DIP16)
112
 
 
113
 
 
114
 
 
115
 
**************************************************************************/
116
 
 
117
 
#include "emu.h"
118
 
#include "cpu/z80/z80.h"
119
 
#include "cpu/m68000/m68000.h"
120
 
#include "deprecat.h"
121
 
#include "sound/2203intf.h"
122
 
#include "sound/okim6295.h"
123
 
#include "includes/lastduel.h"
124
 
 
125
 
 
126
 
/******************************************************************************/
127
 
 
128
 
static WRITE16_HANDLER( lastduel_sound_w )
129
 
{
130
 
        if (ACCESSING_BITS_0_7)
131
 
                soundlatch_w(space, 0, data & 0xff);
132
 
}
133
 
 
134
 
/******************************************************************************/
135
 
 
136
 
static ADDRESS_MAP_START( lastduel_map, AS_PROGRAM, 16 )
137
 
        AM_RANGE(0x000000, 0x05ffff) AM_ROM
138
 
        AM_RANGE(0xfc0000, 0xfc0003) AM_WRITENOP /* Written rarely */
139
 
        AM_RANGE(0xfc0800, 0xfc0fff) AM_RAM AM_BASE_SIZE_GENERIC(spriteram)
140
 
        AM_RANGE(0xfc4000, 0xfc4001) AM_READ_PORT("P1_P2") AM_WRITE(lastduel_flip_w)
141
 
        AM_RANGE(0xfc4002, 0xfc4003) AM_READ_PORT("SYSTEM") AM_WRITE(lastduel_sound_w)
142
 
        AM_RANGE(0xfc4004, 0xfc4005) AM_READ_PORT("DSW1")
143
 
        AM_RANGE(0xfc4006, 0xfc4007) AM_READ_PORT("DSW2")
144
 
        AM_RANGE(0xfc8000, 0xfc800f) AM_WRITE(lastduel_scroll_w)
145
 
        AM_RANGE(0xfcc000, 0xfcdfff) AM_RAM_WRITE(lastduel_vram_w) AM_BASE_MEMBER(lastduel_state, m_vram)
146
 
        AM_RANGE(0xfd0000, 0xfd3fff) AM_RAM_WRITE(lastduel_scroll1_w) AM_BASE_MEMBER(lastduel_state, m_scroll1)
147
 
        AM_RANGE(0xfd4000, 0xfd7fff) AM_RAM_WRITE(lastduel_scroll2_w) AM_BASE_MEMBER(lastduel_state, m_scroll2)
148
 
        AM_RANGE(0xfd8000, 0xfd87ff) AM_RAM_WRITE(lastduel_palette_word_w) AM_BASE_MEMBER(lastduel_state, m_paletteram)
149
 
        AM_RANGE(0xfe0000, 0xffffff) AM_RAM
150
 
ADDRESS_MAP_END
151
 
 
152
 
static ADDRESS_MAP_START( madgear_map, AS_PROGRAM, 16 )
153
 
        AM_RANGE(0x000000, 0x07ffff) AM_ROM
154
 
        AM_RANGE(0xfc1800, 0xfc1fff) AM_RAM AM_BASE_SIZE_GENERIC(spriteram)
155
 
        AM_RANGE(0xfc4000, 0xfc4001) AM_READ_PORT("DSW1") AM_WRITE(lastduel_flip_w)
156
 
        AM_RANGE(0xfc4002, 0xfc4003) AM_READ_PORT("DSW2") AM_WRITE(lastduel_sound_w)
157
 
        AM_RANGE(0xfc4004, 0xfc4005) AM_READ_PORT("P1_P2")
158
 
        AM_RANGE(0xfc4006, 0xfc4007) AM_READ_PORT("SYSTEM")
159
 
        AM_RANGE(0xfc8000, 0xfc9fff) AM_RAM_WRITE(lastduel_vram_w) AM_BASE_MEMBER(lastduel_state, m_vram)
160
 
        AM_RANGE(0xfcc000, 0xfcc7ff) AM_RAM_WRITE(lastduel_palette_word_w) AM_BASE_MEMBER(lastduel_state, m_paletteram)
161
 
        AM_RANGE(0xfd0000, 0xfd000f) AM_WRITE(lastduel_scroll_w)
162
 
        AM_RANGE(0xfd4000, 0xfd7fff) AM_RAM_WRITE(madgear_scroll1_w) AM_BASE_MEMBER(lastduel_state, m_scroll1)
163
 
        AM_RANGE(0xfd8000, 0xfdffff) AM_RAM_WRITE(madgear_scroll2_w) AM_BASE_MEMBER(lastduel_state, m_scroll2)
164
 
        AM_RANGE(0xff0000, 0xffffff) AM_RAM
165
 
ADDRESS_MAP_END
166
 
 
167
 
/******************************************************************************/
168
 
 
169
 
static ADDRESS_MAP_START( sound_map, AS_PROGRAM, 8 )
170
 
        AM_RANGE(0x0000, 0xdfff) AM_ROM
171
 
        AM_RANGE(0xe000, 0xe7ff) AM_RAM
172
 
        AM_RANGE(0xe800, 0xe801) AM_DEVREADWRITE("ym1", ym2203_r,ym2203_w)
173
 
        AM_RANGE(0xf000, 0xf001) AM_DEVREADWRITE("ym2", ym2203_r,ym2203_w)
174
 
        AM_RANGE(0xf800, 0xf800) AM_READ(soundlatch_r)
175
 
ADDRESS_MAP_END
176
 
 
177
 
static WRITE8_HANDLER( mg_bankswitch_w )
178
 
{
179
 
        memory_set_bank(space->machine(), "bank1", data & 0x01);
180
 
}
181
 
 
182
 
static ADDRESS_MAP_START( madgear_sound_map, AS_PROGRAM, 8 )
183
 
        AM_RANGE(0x0000, 0x7fff) AM_ROM
184
 
        AM_RANGE(0x8000, 0xcfff) AM_ROMBANK("bank1")
185
 
        AM_RANGE(0xd000, 0xd7ff) AM_RAM
186
 
        AM_RANGE(0xf000, 0xf001) AM_DEVREADWRITE("ym1", ym2203_r,ym2203_w)
187
 
        AM_RANGE(0xf002, 0xf003) AM_DEVREADWRITE("ym2", ym2203_r,ym2203_w)
188
 
        AM_RANGE(0xf004, 0xf004) AM_DEVWRITE_MODERN("oki", okim6295_device, write)
189
 
        AM_RANGE(0xf006, 0xf006) AM_READ(soundlatch_r)
190
 
        AM_RANGE(0xf00a, 0xf00a) AM_WRITE(mg_bankswitch_w)
191
 
ADDRESS_MAP_END
192
 
 
193
 
/******************************************************************************/
194
 
 
195
 
static INPUT_PORTS_START( lastduel )
196
 
        PORT_START("P1_P2")
197
 
        PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY
198
 
        PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY
199
 
        PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY
200
 
        PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY
201
 
        PORT_BIT( 0x0010, IP_ACTIVE_LOW, IPT_BUTTON1 )
202
 
        PORT_BIT( 0x0020, IP_ACTIVE_LOW, IPT_BUTTON2 )
203
 
        PORT_BIT( 0x0040, IP_ACTIVE_LOW, IPT_UNUSED )
204
 
        PORT_BIT( 0x0080, IP_ACTIVE_LOW, IPT_UNUSED )
205
 
        PORT_BIT( 0x0100, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY PORT_COCKTAIL
206
 
        PORT_BIT( 0x0200, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY PORT_COCKTAIL
207
 
        PORT_BIT( 0x0400, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY PORT_COCKTAIL
208
 
        PORT_BIT( 0x0800, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY PORT_COCKTAIL
209
 
        PORT_BIT( 0x1000, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_COCKTAIL
210
 
        PORT_BIT( 0x2000, IP_ACTIVE_LOW, IPT_BUTTON2 ) PORT_COCKTAIL
211
 
        PORT_BIT( 0x4000, IP_ACTIVE_LOW, IPT_UNUSED )
212
 
        PORT_BIT( 0x8000, IP_ACTIVE_LOW, IPT_UNUSED )
213
 
 
214
 
        PORT_START("SYSTEM")
215
 
        PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_START1 )
216
 
        PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_START2 )
217
 
        PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_UNKNOWN )
218
 
        PORT_SERVICE( 0x08, IP_ACTIVE_LOW )
219
 
        PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_UNKNOWN )
220
 
        PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_SERVICE1 )
221
 
        PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_COIN2 )
222
 
        PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_COIN1 )
223
 
 
224
 
        PORT_START("DSW1")
225
 
        PORT_DIPNAME( 0x0007, 0x0007, DEF_STR( Coin_B ) ) PORT_DIPLOCATION("SW1:1,2,3")
226
 
        PORT_DIPSETTING(      0x0000, DEF_STR( 4C_1C ) )
227
 
        PORT_DIPSETTING(      0x0001, DEF_STR( 3C_1C ) )
228
 
        PORT_DIPSETTING(      0x0002, DEF_STR( 2C_1C ) )
229
 
        PORT_DIPSETTING(      0x0007, DEF_STR( 1C_1C ) )
230
 
        PORT_DIPSETTING(      0x0006, DEF_STR( 1C_2C ) )
231
 
        PORT_DIPSETTING(      0x0005, DEF_STR( 1C_3C ) )
232
 
        PORT_DIPSETTING(      0x0004, DEF_STR( 1C_4C ) )
233
 
        PORT_DIPSETTING(      0x0003, DEF_STR( 1C_6C ) )
234
 
        PORT_DIPNAME( 0x0038, 0x0038, DEF_STR( Coin_A ) ) PORT_DIPLOCATION("SW1:4,5,6")
235
 
        PORT_DIPSETTING(      0x0000, DEF_STR( 4C_1C ) )
236
 
        PORT_DIPSETTING(      0x0008, DEF_STR( 3C_1C ) )
237
 
        PORT_DIPSETTING(      0x0010, DEF_STR( 2C_1C ) )
238
 
        PORT_DIPSETTING(      0x0038, DEF_STR( 1C_1C ) )
239
 
        PORT_DIPSETTING(      0x0030, DEF_STR( 1C_2C ) )
240
 
        PORT_DIPSETTING(      0x0028, DEF_STR( 1C_3C ) )
241
 
        PORT_DIPSETTING(      0x0020, DEF_STR( 1C_4C ) )
242
 
        PORT_DIPSETTING(      0x0018, DEF_STR( 1C_6C ) )
243
 
        PORT_DIPUNUSED_DIPLOC( 0x0040, 0x0040, "SW1:7" ) /* Manual states this DIP is unused */
244
 
        PORT_DIPUNUSED_DIPLOC( 0x0080, 0x0080, "SW1:8" ) /* Manual states this DIP is unused */
245
 
        PORT_DIPNAME( 0x0300, 0x0300, DEF_STR( Difficulty ) ) PORT_DIPLOCATION("SW2:1,2")
246
 
        PORT_DIPSETTING(      0x0200, DEF_STR( Easy ) )
247
 
        PORT_DIPSETTING(      0x0300, DEF_STR( Normal ) )
248
 
        PORT_DIPSETTING(      0x0100, DEF_STR( Difficult ) )
249
 
        PORT_DIPSETTING(      0x0000, DEF_STR( Very_Difficult ) )
250
 
        PORT_DIPUNUSED_DIPLOC( 0x0400, 0x0400, "SW2:3" ) /* Manual states this DIP is unused */         /* Could be cabinet type? */
251
 
        PORT_DIPUNUSED_DIPLOC( 0x0800, 0x0800, "SW2:4" ) /* Manual states this DIP is unused */
252
 
        PORT_DIPNAME( 0x3000, 0x3000, DEF_STR( Bonus_Life ) ) PORT_DIPLOCATION("SW2:5,6")
253
 
        PORT_DIPSETTING(      0x2000, "20000 60000 80000" )
254
 
        PORT_DIPSETTING(      0x3000, "30000 80000 80000" )
255
 
        PORT_DIPSETTING(      0x1000, "40000 80000 80000" )
256
 
        PORT_DIPSETTING(      0x0000, "40000 80000 100000" )
257
 
        PORT_DIPUNUSED_DIPLOC( 0x4000, 0x4000, "SW2:7" ) /* Manual states this DIP is unused */
258
 
        PORT_DIPUNUSED_DIPLOC( 0x8000, 0x8000, "SW2:8" ) /* Manual states this DIP is unused */
259
 
 
260
 
        PORT_START("DSW2")
261
 
        PORT_DIPNAME( 0x03, 0x03, DEF_STR( Lives ) ) PORT_DIPLOCATION("SW3:1,2")
262
 
        PORT_DIPSETTING(    0x03, "3" )
263
 
        PORT_DIPSETTING(    0x02, "4" )
264
 
        PORT_DIPSETTING(    0x01, "6" )
265
 
        PORT_DIPSETTING(    0x00, "8" )
266
 
        PORT_DIPNAME( 0x04, 0x04, "Stage select" ) PORT_DIPLOCATION("SW3:3")
267
 
        PORT_DIPSETTING(    0x04, "Start from Auto Stage" )
268
 
        PORT_DIPSETTING(    0x00, "Start from Plane Stage" )
269
 
        PORT_DIPUNUSED_DIPLOC( 0x0008, 0x0008, "SW3:4" ) /* Manual states this DIP is unused */
270
 
        PORT_DIPUNUSED_DIPLOC( 0x0010, 0x0010, "SW3:5" ) /* Manual states this DIP is unused */
271
 
        PORT_DIPNAME( 0x20, 0x20, DEF_STR( Demo_Sounds ) ) PORT_DIPLOCATION("SW3:6")
272
 
        PORT_DIPSETTING(    0x00, DEF_STR( Off ) )
273
 
        PORT_DIPSETTING(    0x20, DEF_STR( On ) )
274
 
        PORT_DIPNAME( 0x40, 0x40, DEF_STR( Allow_Continue ) ) PORT_DIPLOCATION("SW3:7")
275
 
        PORT_DIPSETTING(    0x00, DEF_STR( No ) )
276
 
        PORT_DIPSETTING(    0x40, DEF_STR( Yes ) )
277
 
        PORT_DIPNAME( 0x80, 0x80, DEF_STR( Flip_Screen ) ) PORT_DIPLOCATION("SW3:8")
278
 
        PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
279
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
280
 
INPUT_PORTS_END
281
 
 
282
 
static INPUT_PORTS_START( madgear )
283
 
        PORT_START("DSW1")
284
 
        PORT_DIPNAME( 0x0001, 0x0001, DEF_STR( Allow_Continue ) ) PORT_DIPLOCATION("SW1:1")
285
 
        PORT_DIPSETTING(      0x0000, DEF_STR( No ) )
286
 
        PORT_DIPSETTING(      0x0001, DEF_STR( Yes ) )
287
 
        PORT_DIPNAME( 0x0002, 0x0002, DEF_STR( Flip_Screen ) ) PORT_DIPLOCATION("SW1:2")
288
 
        PORT_DIPSETTING(      0x0002, DEF_STR( Off ) )
289
 
        PORT_DIPSETTING(      0x0000, DEF_STR( On ) )
290
 
        PORT_DIPNAME( 0x000c, 0x000c, DEF_STR( Difficulty ) ) PORT_DIPLOCATION("SW1:3,4")
291
 
        PORT_DIPSETTING(      0x0008, DEF_STR( Easy ) )
292
 
        PORT_DIPSETTING(      0x000c, DEF_STR( Normal ) )
293
 
        PORT_DIPSETTING(      0x0004, DEF_STR( Difficult ) )
294
 
        PORT_DIPSETTING(      0x0000, DEF_STR( Very_Difficult ) )
295
 
        PORT_DIPNAME( 0x0030, 0x0030, DEF_STR( Cabinet ) ) PORT_DIPLOCATION("SW1:5,6")
296
 
        PORT_DIPSETTING(      0x0030, "Upright One Player" )
297
 
        PORT_DIPSETTING(      0x0000, "Upright Two Players" )
298
 
        PORT_DIPSETTING(      0x0010, DEF_STR( Cocktail ) )
299
 
/*  PORT_DIPSETTING(      0x0020, "Upright One Player" ) */
300
 
        PORT_DIPNAME( 0x0040, 0x0040, DEF_STR( Demo_Sounds ) ) PORT_DIPLOCATION("SW1:7")
301
 
        PORT_DIPSETTING(      0x0000, DEF_STR( Off ) )
302
 
        PORT_DIPSETTING(      0x0040, DEF_STR( On ) )
303
 
        PORT_DIPNAME( 0x0080, 0x0080, "Background Music" ) PORT_DIPLOCATION("SW1:8")
304
 
        PORT_DIPSETTING(      0x0000, DEF_STR( Off ) )
305
 
        PORT_DIPSETTING(      0x0080, DEF_STR( On ) )
306
 
        PORT_BIT( 0x7f00, IP_ACTIVE_LOW, IPT_UNUSED )
307
 
        PORT_SERVICE( 0x8000, IP_ACTIVE_LOW )
308
 
 
309
 
        PORT_START("DSW2") /* Free play is COIN B all off, COIN A all on */
310
 
        PORT_DIPNAME( 0x0f00, 0x0f00, DEF_STR( Coin_B ) ) PORT_DIPLOCATION("SW2:1,2,3,4")
311
 
        PORT_DIPSETTING(      0x0200, DEF_STR( 6C_1C ) )
312
 
        PORT_DIPSETTING(      0x0400, DEF_STR( 5C_1C ) )
313
 
        PORT_DIPSETTING(      0x0500, DEF_STR( 4C_1C ) )
314
 
        PORT_DIPSETTING(      0x0700, DEF_STR( 3C_1C ) )
315
 
        PORT_DIPSETTING(      0x0100, DEF_STR( 8C_3C ) )
316
 
        PORT_DIPSETTING(      0x0900, DEF_STR( 2C_1C ) )
317
 
        PORT_DIPSETTING(      0x0300, DEF_STR( 5C_3C ) )
318
 
        PORT_DIPSETTING(      0x0600, DEF_STR( 3C_2C ) )
319
 
        PORT_DIPSETTING(      0x0f00, DEF_STR( 1C_1C ) )
320
 
//  PORT_DIPSETTING(      0x0000, DEF_STR( 1C_1C ) )
321
 
        PORT_DIPSETTING(      0x0800, DEF_STR( 2C_3C ) )
322
 
        PORT_DIPSETTING(      0x0e00, DEF_STR( 1C_2C ) )
323
 
        PORT_DIPSETTING(      0x0d00, DEF_STR( 1C_3C ) )
324
 
        PORT_DIPSETTING(      0x0c00, DEF_STR( 1C_4C ) )
325
 
        PORT_DIPSETTING(      0x0b00, DEF_STR( 1C_5C ) )
326
 
        PORT_DIPSETTING(      0x0a00, DEF_STR( 1C_6C ) )
327
 
        PORT_DIPNAME( 0xf000, 0xf000, DEF_STR( Coin_A ) ) PORT_DIPLOCATION("SW2:5,6,7,8")
328
 
        PORT_DIPSETTING(      0x2000, DEF_STR( 6C_1C ) )
329
 
        PORT_DIPSETTING(      0x4000, DEF_STR( 5C_1C ) )
330
 
        PORT_DIPSETTING(      0x5000, DEF_STR( 4C_1C ) )
331
 
        PORT_DIPSETTING(      0x7000, DEF_STR( 3C_1C ) )
332
 
        PORT_DIPSETTING(      0x1000, DEF_STR( 8C_3C ) )
333
 
        PORT_DIPSETTING(      0x9000, DEF_STR( 2C_1C ) )
334
 
        PORT_DIPSETTING(      0x3000, DEF_STR( 5C_3C ) )
335
 
        PORT_DIPSETTING(      0x6000, DEF_STR( 3C_2C ) )
336
 
        PORT_DIPSETTING(      0xf000, DEF_STR( 1C_1C ) )
337
 
        PORT_DIPSETTING(      0x8000, DEF_STR( 2C_3C ) )
338
 
        PORT_DIPSETTING(      0xe000, DEF_STR( 1C_2C ) )
339
 
        PORT_DIPSETTING(      0xd000, DEF_STR( 1C_3C ) )
340
 
        PORT_DIPSETTING(      0xc000, DEF_STR( 1C_4C ) )
341
 
        PORT_DIPSETTING(      0xb000, DEF_STR( 1C_5C ) )
342
 
        PORT_DIPSETTING(      0xa000, DEF_STR( 1C_6C ) )
343
 
        PORT_DIPSETTING(      0x0000, DEF_STR( Free_Play ) )
344
 
 
345
 
        PORT_START("P1_P2")
346
 
        PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_UNUSED )
347
 
        PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_UNUSED )
348
 
        PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_UNUSED )
349
 
        PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_COCKTAIL
350
 
        PORT_BIT( 0x0010, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY PORT_COCKTAIL
351
 
        PORT_BIT( 0x0020, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY PORT_COCKTAIL
352
 
        PORT_BIT( 0x0040, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY PORT_COCKTAIL
353
 
        PORT_BIT( 0x0080, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY PORT_COCKTAIL
354
 
        PORT_BIT( 0x0100, IP_ACTIVE_LOW, IPT_UNUSED )
355
 
        PORT_BIT( 0x0200, IP_ACTIVE_LOW, IPT_UNUSED )
356
 
        PORT_BIT( 0x0400, IP_ACTIVE_LOW, IPT_UNUSED )
357
 
        PORT_BIT( 0x0800, IP_ACTIVE_LOW, IPT_BUTTON1 )
358
 
        PORT_BIT( 0x1000, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY
359
 
        PORT_BIT( 0x2000, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY
360
 
        PORT_BIT( 0x4000, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY
361
 
        PORT_BIT( 0x8000, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY
362
 
 
363
 
        PORT_START("SYSTEM")
364
 
        PORT_BIT( 0x0100, IP_ACTIVE_LOW, IPT_UNKNOWN )
365
 
        PORT_BIT( 0x0200, IP_ACTIVE_LOW, IPT_START2 )
366
 
        PORT_BIT( 0x0400, IP_ACTIVE_LOW, IPT_START1 )
367
 
        PORT_BIT( 0x0800, IP_ACTIVE_LOW, IPT_COIN2 )
368
 
        PORT_BIT( 0x1000, IP_ACTIVE_LOW, IPT_COIN1 )
369
 
        PORT_BIT( 0x2000, IP_ACTIVE_LOW, IPT_UNKNOWN )
370
 
        PORT_BIT( 0x4000, IP_ACTIVE_LOW, IPT_UNKNOWN )
371
 
        PORT_BIT( 0x8000, IP_ACTIVE_LOW, IPT_SERVICE1 )
372
 
INPUT_PORTS_END
373
 
 
374
 
/******************************************************************************/
375
 
 
376
 
static const gfx_layout sprite_layout =
377
 
{
378
 
        16,16,
379
 
        RGN_FRAC(1,4),
380
 
        4,
381
 
        { RGN_FRAC(0,4), RGN_FRAC(1,4), RGN_FRAC(2,4), RGN_FRAC(3,4) },
382
 
        { 0, 1, 2, 3, 4, 5, 6, 7,
383
 
                        16*8+0, 16*8+1, 16*8+2, 16*8+3, 16*8+4, 16*8+5, 16*8+6, 16*8+7 },
384
 
        { 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8,
385
 
                        8*8, 9*8, 10*8, 11*8, 12*8, 13*8, 14*8, 15*8 },
386
 
        32*8
387
 
};
388
 
 
389
 
static const gfx_layout text_layout =
390
 
{
391
 
        8,8,
392
 
        RGN_FRAC(1,1),
393
 
        2,
394
 
        { 4, 0 },
395
 
        { 0, 1, 2, 3, 8+0, 8+1, 8+2, 8+3 },
396
 
        { 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16 },
397
 
        16*8
398
 
};
399
 
 
400
 
static const gfx_layout madgear_tile =
401
 
{
402
 
        16,16,
403
 
        RGN_FRAC(1,1),
404
 
        4,
405
 
        { 3*4, 2*4, 1*4, 0*4 },
406
 
        { 0, 1, 2, 3, 16+0, 16+1, 16+2, 16+3,
407
 
                        32*16+0, 32*16+1, 32*16+2, 32*16+3, 32*16+16+0, 32*16+16+1, 32*16+16+2, 32*16+16+3 },
408
 
        { 0*32, 1*32, 2*32, 3*32, 4*32, 5*32, 6*32, 7*32,
409
 
                        8*32, 9*32, 10*32, 11*32, 12*32, 13*32, 14*32, 15*32 },
410
 
        64*16
411
 
};
412
 
 
413
 
static const gfx_layout madgear_tile2 =
414
 
{
415
 
        16,16,
416
 
        RGN_FRAC(1,1),
417
 
        4,
418
 
        { 1*4, 3*4, 0*4, 2*4 },
419
 
        { 0, 1, 2, 3, 16+0, 16+1, 16+2, 16+3,
420
 
                        32*16+0, 32*16+1, 32*16+2, 32*16+3, 32*16+16+0, 32*16+16+1, 32*16+16+2, 32*16+16+3 },
421
 
        { 0*32, 1*32, 2*32, 3*32, 4*32, 5*32, 6*32, 7*32,
422
 
                        8*32, 9*32, 10*32, 11*32, 12*32, 13*32, 14*32, 15*32 },
423
 
        64*16
424
 
};
425
 
 
426
 
static GFXDECODE_START( lastduel )
427
 
        GFXDECODE_ENTRY( "gfx1", 0, sprite_layout, 0x200, 16 )  /* colors 0x200-0x2ff */
428
 
        GFXDECODE_ENTRY( "gfx2", 0, text_layout,   0x300, 16 )  /* colors 0x300-0x33f */
429
 
        GFXDECODE_ENTRY( "gfx3", 0, madgear_tile,  0x000, 16 )  /* colors 0x000-0x0ff */
430
 
        GFXDECODE_ENTRY( "gfx4", 0, madgear_tile,  0x100, 16 )  /* colors 0x100-0x1ff */
431
 
GFXDECODE_END
432
 
 
433
 
static GFXDECODE_START( madgear )
434
 
        GFXDECODE_ENTRY( "gfx1", 0, sprite_layout, 0x200, 16 )  /* colors 0x200-0x2ff */
435
 
        GFXDECODE_ENTRY( "gfx2", 0, text_layout,   0x300, 16 )  /* colors 0x300-0x33f */
436
 
        GFXDECODE_ENTRY( "gfx3", 0, madgear_tile,  0x000, 16 )  /* colors 0x000-0x0ff */
437
 
        GFXDECODE_ENTRY( "gfx4", 0, madgear_tile2, 0x100, 16 )  /* colors 0x100-0x1ff */
438
 
GFXDECODE_END
439
 
 
440
 
/******************************************************************************/
441
 
 
442
 
/* handler called by the 2203 emulator when the internal timers cause an IRQ */
443
 
static void irqhandler( device_t *device, int irq )
444
 
{
445
 
        lastduel_state *state = device->machine().driver_data<lastduel_state>();
446
 
        device_set_input_line(state->m_audiocpu, 0, irq ? ASSERT_LINE : CLEAR_LINE);
447
 
}
448
 
 
449
 
static const ym2203_interface ym2203_config =
450
 
{
451
 
        {
452
 
                AY8910_LEGACY_OUTPUT,
453
 
                AY8910_DEFAULT_LOADS,
454
 
                DEVCB_NULL, DEVCB_NULL, DEVCB_NULL, DEVCB_NULL,
455
 
        },
456
 
        irqhandler
457
 
};
458
 
 
459
 
static INTERRUPT_GEN( lastduel_interrupt )
460
 
{
461
 
        if (cpu_getiloops(device) == 0)
462
 
                device_set_input_line(device, 2, HOLD_LINE); /* VBL */
463
 
        else
464
 
                device_set_input_line(device, 4, HOLD_LINE); /* Controls */
465
 
}
466
 
 
467
 
static INTERRUPT_GEN( madgear_interrupt )
468
 
{
469
 
        if (cpu_getiloops(device) == 0)
470
 
                device_set_input_line(device, 5, HOLD_LINE); /* VBL */
471
 
        else
472
 
                device_set_input_line(device, 6, HOLD_LINE); /* Controls */
473
 
}
474
 
 
475
 
static MACHINE_START( lastduel )
476
 
{
477
 
        lastduel_state *state = machine.driver_data<lastduel_state>();
478
 
 
479
 
        state->m_audiocpu = machine.device("audiocpu");
480
 
 
481
 
        state->save_item(NAME(state->m_tilemap_priority));
482
 
        state->save_item(NAME(state->m_scroll));
483
 
}
484
 
 
485
 
static MACHINE_START( madgear )
486
 
{
487
 
        UINT8 *ROM = machine.region("audiocpu")->base();
488
 
 
489
 
        memory_configure_bank(machine, "bank1", 0, 2, &ROM[0x10000], 0x4000);
490
 
 
491
 
        MACHINE_START_CALL(lastduel);
492
 
}
493
 
 
494
 
static MACHINE_RESET( lastduel )
495
 
{
496
 
        lastduel_state *state = machine.driver_data<lastduel_state>();
497
 
        int i;
498
 
 
499
 
        state->m_tilemap_priority = 0;
500
 
 
501
 
        for (i = 0; i < 8; i++)
502
 
                state->m_scroll[i] = 0;
503
 
}
504
 
 
505
 
static MACHINE_CONFIG_START( lastduel, lastduel_state )
506
 
 
507
 
        /* basic machine hardware */
508
 
        MCFG_CPU_ADD("maincpu", M68000, 10000000) /* Could be 8 MHz */
509
 
        MCFG_CPU_PROGRAM_MAP(lastduel_map)
510
 
        MCFG_CPU_VBLANK_INT_HACK(lastduel_interrupt,3)  /* 1 for vbl, 2 for control reads?? */
511
 
 
512
 
        MCFG_CPU_ADD("audiocpu", Z80, 3579545) /* Accurate */
513
 
        MCFG_CPU_PROGRAM_MAP(sound_map)
514
 
 
515
 
        MCFG_MACHINE_START(lastduel)
516
 
        MCFG_MACHINE_RESET(lastduel)
517
 
 
518
 
        /* video hardware */
519
 
        MCFG_VIDEO_ATTRIBUTES(VIDEO_UPDATE_BEFORE_VBLANK | VIDEO_BUFFERS_SPRITERAM)
520
 
 
521
 
        MCFG_SCREEN_ADD("screen", RASTER)
522
 
        MCFG_SCREEN_REFRESH_RATE(60)
523
 
        MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
524
 
        MCFG_SCREEN_FORMAT(BITMAP_FORMAT_INDEXED16)
525
 
        MCFG_SCREEN_SIZE(64*8, 32*8)
526
 
        MCFG_SCREEN_VISIBLE_AREA(8*8, (64-8)*8-1, 1*8, 31*8-1 )
527
 
        MCFG_SCREEN_UPDATE(lastduel)
528
 
        MCFG_SCREEN_EOF(lastduel)
529
 
 
530
 
        MCFG_GFXDECODE(lastduel)
531
 
        MCFG_PALETTE_LENGTH(1024)
532
 
 
533
 
        MCFG_VIDEO_START(lastduel)
534
 
 
535
 
        /* sound hardware */
536
 
        MCFG_SPEAKER_STANDARD_MONO("mono")
537
 
 
538
 
        MCFG_SOUND_ADD("ym1", YM2203, 3579545)
539
 
        MCFG_SOUND_CONFIG(ym2203_config)
540
 
        MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.40)
541
 
 
542
 
        MCFG_SOUND_ADD("ym2", YM2203, 3579545)
543
 
        MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.40)
544
 
MACHINE_CONFIG_END
545
 
 
546
 
 
547
 
static MACHINE_CONFIG_START( madgear, lastduel_state )
548
 
 
549
 
        /* basic machine hardware */
550
 
        MCFG_CPU_ADD("maincpu", M68000, 10000000) /* Accurate */
551
 
        MCFG_CPU_PROGRAM_MAP(madgear_map)
552
 
        MCFG_CPU_VBLANK_INT_HACK(madgear_interrupt,3)   /* 1 for vbl, 2 for control reads?? */
553
 
 
554
 
        MCFG_CPU_ADD("audiocpu", Z80, XTAL_3_579545MHz) /* verified on pcb */
555
 
        MCFG_CPU_PROGRAM_MAP(madgear_sound_map)
556
 
 
557
 
        MCFG_MACHINE_START(madgear)
558
 
        MCFG_MACHINE_RESET(lastduel)
559
 
 
560
 
        /* video hardware */
561
 
        MCFG_VIDEO_ATTRIBUTES(VIDEO_UPDATE_BEFORE_VBLANK | VIDEO_BUFFERS_SPRITERAM)
562
 
 
563
 
        MCFG_SCREEN_ADD("screen", RASTER)
564
 
        MCFG_SCREEN_REFRESH_RATE(60)
565
 
        MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
566
 
        MCFG_SCREEN_FORMAT(BITMAP_FORMAT_INDEXED16)
567
 
        MCFG_SCREEN_SIZE(64*8, 32*8)
568
 
        MCFG_SCREEN_VISIBLE_AREA(8*8, (64-8)*8-1, 1*8, 31*8-1 )
569
 
        MCFG_SCREEN_UPDATE(madgear)
570
 
        MCFG_SCREEN_EOF(lastduel)
571
 
 
572
 
        MCFG_GFXDECODE(madgear)
573
 
        MCFG_PALETTE_LENGTH(1024)
574
 
 
575
 
        MCFG_VIDEO_START(madgear)
576
 
 
577
 
        /* sound hardware */
578
 
        MCFG_SPEAKER_STANDARD_MONO("mono")
579
 
 
580
 
        MCFG_SOUND_ADD("ym1", YM2203, XTAL_3_579545MHz) /* verified on pcb */
581
 
        MCFG_SOUND_CONFIG(ym2203_config)
582
 
        MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.40)
583
 
 
584
 
        MCFG_SOUND_ADD("ym2", YM2203, XTAL_3_579545MHz) /* verified on pcb */
585
 
        MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.40)
586
 
 
587
 
        MCFG_OKIM6295_ADD("oki", XTAL_10MHz/10, OKIM6295_PIN7_HIGH) /* verified on pcb */
588
 
        MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.98)
589
 
MACHINE_CONFIG_END
590
 
 
591
 
/******************************************************************************/
592
 
 
593
 
ROM_START( lastduel )
594
 
        ROM_REGION( 0x60000, "maincpu", 0 )     /* 68000 code */
595
 
        ROM_LOAD16_BYTE( "ldu_06b.13k",   0x00000, 0x20000, CRC(0e71acaf) SHA1(e804c77bfd768ae2fc1917bcec1fd0ec7418b780) )
596
 
        ROM_LOAD16_BYTE( "ldu_05b.12k",   0x00001, 0x20000, CRC(47a85bea) SHA1(9d6b2a4e27c84ffce8ed58aa1b314c67c7314932) )
597
 
        ROM_LOAD16_BYTE( "ldu_04b.11k",   0x40000, 0x10000, CRC(aa4bf001) SHA1(3f14b174016c6fa4c82011d3d0f1c957096d6d93) )
598
 
        ROM_LOAD16_BYTE( "ldu_03b.9k",    0x40001, 0x10000, CRC(bbaac8ab) SHA1(3c5773e39e7a96ef62da7b846ce4099222b3e66b) )
599
 
 
600
 
        ROM_REGION( 0x10000 , "audiocpu", 0 ) /* audio CPU */
601
 
        ROM_LOAD( "ld_02.16h",    0x0000, 0x10000, CRC(91834d0c) SHA1(aaa63b8470fc19b82c25028ab27675a7837ab9a1) )
602
 
 
603
 
        ROM_REGION( 0x80000, "gfx1", 0 )
604
 
        ROM_LOAD( "ld-11.12b",    0x000000, 0x20000, CRC(49d4dbbd) SHA1(e58ebda9e9ad37a6990f2aca2a312d55cdaca979) ) /* sprites */
605
 
        ROM_LOAD( "ld-09.12a",    0x020000, 0x20000, CRC(6efadb74) SHA1(b00ddd33c08557940610570b1fd8c9a84dcaf063) )
606
 
        ROM_LOAD( "ld-12.17b",    0x040000, 0x20000, CRC(313e5338) SHA1(beceeb5ae9de6a41d3fde06767b8a23fc9f42259) )
607
 
        ROM_LOAD( "ld-10.17a",    0x060000, 0x20000, CRC(b8d3b2e3) SHA1(a08ef780c798b59bb1e1582d82317421a3353887) )
608
 
 
609
 
        ROM_REGION( 0x08000, "gfx2", 0 )
610
 
        ROM_LOAD( "ld_01.12f",    0x000000, 0x08000, CRC(ad3c6f87) SHA1(1a5ef003c0eb641484921dc0c11450c53ee315f5) ) /* 8x8 text */
611
 
 
612
 
        ROM_REGION( 0x40000, "gfx3", 0 )
613
 
        ROM_LOAD16_BYTE( "ld-15.6p",     0x000001, 0x20000, CRC(d977a175) SHA1(e3cb482ede10d2204f8352b10623e442a4ae99d2) ) /* tiles */
614
 
        ROM_LOAD16_BYTE( "ld-13.6m",     0x000000, 0x20000, CRC(bc25729f) SHA1(7a6e8a4158bf4c804e87b11c15deb6d0f09fa538) )
615
 
 
616
 
        ROM_REGION( 0x80000, "gfx4", 0 )
617
 
        ROM_LOAD( "ld-14.15n",    0x000000, 0x80000, CRC(d0653739) SHA1(8278e8601e82470d785a8ffef48a1b5f70bc2a9b) ) /* tiles */
618
 
 
619
 
        ROM_REGION( 0x0100, "proms", 0 )
620
 
        ROM_LOAD( "ld.3d",        0x0000, 0x0100, CRC(729a1ddc) SHA1(eb1d48785a0f187a4cb9c164e6c82481268b3174) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
621
 
ROM_END
622
 
 
623
 
ROM_START( lastduelo )
624
 
        ROM_REGION( 0x60000, "maincpu", 0 )     /* 68000 code */
625
 
        ROM_LOAD16_BYTE( "ldu_06.13k",  0x00000, 0x20000, CRC(4228a00b) SHA1(8c23f74f682ba2074da9f3306600c881ce41e50f) )
626
 
        ROM_LOAD16_BYTE( "ldu_05.12k",  0x00001, 0x20000, CRC(7260434f) SHA1(55eeb12977efb3c6afd86d68612782ba526c9055) )
627
 
        ROM_LOAD16_BYTE( "ldu_04.11k",  0x40000, 0x10000, CRC(429fb964) SHA1(78769b05e62c190d846dd08214427d1abbbe2bba) )
628
 
        ROM_LOAD16_BYTE( "ldu_03.9k",   0x40001, 0x10000, CRC(5aa4df72) SHA1(9e7315b793f09c8b422bad1ce776588e3a48d80c) )
629
 
 
630
 
        ROM_REGION( 0x10000 , "audiocpu", 0 ) /* audio CPU */
631
 
        ROM_LOAD( "ld_02.16h",    0x0000, 0x10000, CRC(91834d0c) SHA1(aaa63b8470fc19b82c25028ab27675a7837ab9a1) )
632
 
 
633
 
        ROM_REGION( 0x80000, "gfx1", 0 )
634
 
        ROM_LOAD( "ld-11.12b",    0x000000, 0x20000, CRC(49d4dbbd) SHA1(e58ebda9e9ad37a6990f2aca2a312d55cdaca979) ) /* sprites */
635
 
        ROM_LOAD( "ld-09.12a",    0x020000, 0x20000, CRC(6efadb74) SHA1(b00ddd33c08557940610570b1fd8c9a84dcaf063) )
636
 
        ROM_LOAD( "ld-12.17b",    0x040000, 0x20000, CRC(313e5338) SHA1(beceeb5ae9de6a41d3fde06767b8a23fc9f42259) )
637
 
        ROM_LOAD( "ld-10.17a",    0x060000, 0x20000, CRC(b8d3b2e3) SHA1(a08ef780c798b59bb1e1582d82317421a3353887) )
638
 
 
639
 
        ROM_REGION( 0x08000, "gfx2", 0 )
640
 
        ROM_LOAD( "ld_01.12f",    0x000000, 0x08000, CRC(ad3c6f87) SHA1(1a5ef003c0eb641484921dc0c11450c53ee315f5) ) /* 8x8 text */
641
 
 
642
 
        ROM_REGION( 0x40000, "gfx3", 0 )
643
 
        ROM_LOAD16_BYTE( "ld-15.6p",     0x000001, 0x20000, CRC(d977a175) SHA1(e3cb482ede10d2204f8352b10623e442a4ae99d2) ) /* tiles */
644
 
        ROM_LOAD16_BYTE( "ld-13.6m",     0x000000, 0x20000, CRC(bc25729f) SHA1(7a6e8a4158bf4c804e87b11c15deb6d0f09fa538) )
645
 
 
646
 
        ROM_REGION( 0x80000, "gfx4", 0 )
647
 
        ROM_LOAD( "ld-14.15n",    0x000000, 0x80000, CRC(d0653739) SHA1(8278e8601e82470d785a8ffef48a1b5f70bc2a9b) ) /* tiles */
648
 
 
649
 
        ROM_REGION( 0x0100, "proms", 0 )
650
 
        ROM_LOAD( "ld.3d",        0x0000, 0x0100, CRC(729a1ddc) SHA1(eb1d48785a0f187a4cb9c164e6c82481268b3174) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
651
 
ROM_END
652
 
 
653
 
ROM_START( lastduelj )
654
 
        ROM_REGION( 0x60000, "maincpu", 0 )     /* 68000 code */
655
 
        ROM_LOAD16_BYTE( "ld_06.13k",  0x00000, 0x20000, CRC(58a9e12b) SHA1(bd0b8226271ef0aaff381604455866e0d42fd791) )
656
 
        ROM_LOAD16_BYTE( "ld_05.12k",  0x00001, 0x20000, CRC(14685d78) SHA1(6f6c2431366868df268857d65f6f1325f6c91b89) )
657
 
        ROM_LOAD16_BYTE( "ld_04.11k",  0x40000, 0x10000, CRC(aa4bf001) SHA1(3f14b174016c6fa4c82011d3d0f1c957096d6d93) )
658
 
        ROM_LOAD16_BYTE( "ld_03.9k",   0x40001, 0x10000, CRC(bbaac8ab) SHA1(3c5773e39e7a96ef62da7b846ce4099222b3e66b) )
659
 
 
660
 
        ROM_REGION( 0x10000 , "audiocpu", 0 ) /* audio CPU */
661
 
        ROM_LOAD( "ld_02.16h",    0x0000, 0x10000, CRC(91834d0c) SHA1(aaa63b8470fc19b82c25028ab27675a7837ab9a1) )
662
 
 
663
 
        ROM_REGION( 0x80000, "gfx1", 0 )
664
 
        ROM_LOAD( "ld-11.12b",    0x000000, 0x20000, CRC(49d4dbbd) SHA1(e58ebda9e9ad37a6990f2aca2a312d55cdaca979) ) /* sprites */
665
 
        ROM_LOAD( "ld-09.12a",    0x020000, 0x20000, CRC(6efadb74) SHA1(b00ddd33c08557940610570b1fd8c9a84dcaf063) )
666
 
        ROM_LOAD( "ld-12.17b",    0x040000, 0x20000, CRC(313e5338) SHA1(beceeb5ae9de6a41d3fde06767b8a23fc9f42259) )
667
 
        ROM_LOAD( "ld-10.17a",    0x060000, 0x20000, CRC(b8d3b2e3) SHA1(a08ef780c798b59bb1e1582d82317421a3353887) )
668
 
 
669
 
        ROM_REGION( 0x08000, "gfx2", 0 )
670
 
        ROM_LOAD( "ld_01.12f",    0x000000, 0x08000, CRC(ad3c6f87) SHA1(1a5ef003c0eb641484921dc0c11450c53ee315f5) ) /* 8x8 text */
671
 
 
672
 
        ROM_REGION( 0x40000, "gfx3", 0 )
673
 
        ROM_LOAD16_BYTE( "ld-15.6p",     0x000001, 0x20000, CRC(d977a175) SHA1(e3cb482ede10d2204f8352b10623e442a4ae99d2) ) /* tiles */
674
 
        ROM_LOAD16_BYTE( "ld-13.6m",     0x000000, 0x20000, CRC(bc25729f) SHA1(7a6e8a4158bf4c804e87b11c15deb6d0f09fa538) )
675
 
 
676
 
        ROM_REGION( 0x80000, "gfx4", 0 )
677
 
        ROM_LOAD( "ld-14.15n",    0x000000, 0x80000, CRC(d0653739) SHA1(8278e8601e82470d785a8ffef48a1b5f70bc2a9b) ) /* tiles */
678
 
 
679
 
        ROM_REGION( 0x0100, "proms", 0 )
680
 
        ROM_LOAD( "ld.3d",        0x0000, 0x0100, CRC(729a1ddc) SHA1(eb1d48785a0f187a4cb9c164e6c82481268b3174) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
681
 
ROM_END
682
 
 
683
 
ROM_START( lastduelb )
684
 
        ROM_REGION( 0x60000, "maincpu", 0 )     /* 68000 code */
685
 
        ROM_LOAD16_BYTE( "ld_08.bin",    0x00000, 0x10000, CRC(43811a96) SHA1(79db50c941d8845f1642f2257c610768172923a3) )
686
 
        ROM_LOAD16_BYTE( "ld_07.bin",    0x00001, 0x10000, CRC(63c30946) SHA1(cab7374839a68483b3f94821144546cc3eb1528e) )
687
 
        ROM_LOAD16_BYTE( "ld_04.bin",    0x20000, 0x10000, CRC(46a4e0f8) SHA1(7d5fac209357090c5faeee3834c19f1d8125aac5) )
688
 
        ROM_LOAD16_BYTE( "ld_03.bin",    0x20001, 0x10000, CRC(8d5f204a) SHA1(0415b8a836a62aee1f430bc124996cb8c12ed5cf) )
689
 
        ROM_LOAD16_BYTE( "ldu-04.rom",   0x40000, 0x10000, CRC(429fb964) SHA1(78769b05e62c190d846dd08214427d1abbbe2bba) )
690
 
        ROM_LOAD16_BYTE( "ldu-03.rom",   0x40001, 0x10000, CRC(5aa4df72) SHA1(9e7315b793f09c8b422bad1ce776588e3a48d80c) )
691
 
 
692
 
        ROM_REGION( 0x10000 , "audiocpu", 0 ) /* audio CPU */
693
 
        ROM_LOAD( "ld_02.bin",    0x0000, 0x10000, CRC(91834d0c) SHA1(aaa63b8470fc19b82c25028ab27675a7837ab9a1) )
694
 
 
695
 
        ROM_REGION( 0x80000, "gfx1", 0 )
696
 
        ROM_LOAD( "ld_09.bin",    0x000000, 0x10000, CRC(f8fd5243) SHA1(fad80d8959f50a83eb2e47788a8183284d19bea6) ) /* sprites */
697
 
        ROM_LOAD( "ld_10.bin",    0x010000, 0x10000, CRC(b49ad746) SHA1(4e609982d60155b0df13a156c37bdf2a25626632) )
698
 
        ROM_LOAD( "ld_11.bin",    0x020000, 0x10000, CRC(1a0d180e) SHA1(a68a7f5d00da99a8068876fd2d61c726047aca80) )
699
 
        ROM_LOAD( "ld_12.bin",    0x030000, 0x10000, CRC(b2745e26) SHA1(b511631fe4e21f3d2dc7440b3f69cd5edb43d20e) )
700
 
        ROM_LOAD( "ld_15.bin",    0x040000, 0x10000, CRC(96b13bbc) SHA1(f2df8d4f11e9192063063ff2e9e4fe76971c5b24) )
701
 
        ROM_LOAD( "ld_16.bin",    0x050000, 0x10000, CRC(9d80f7e6) SHA1(ce7c10eba6a9f6a1fad655c7de6b487aef6d7d64) )
702
 
        ROM_LOAD( "ld_13.bin",    0x060000, 0x10000, CRC(a1a598ac) SHA1(a0d24d9125cd502b57adf9167cb61e8864d521ce) )
703
 
        ROM_LOAD( "ld_14.bin",    0x070000, 0x10000, CRC(edf515cc) SHA1(8dc68d1d4e480afe9614ea85e2eced3fd3917484) )
704
 
 
705
 
        ROM_REGION( 0x08000, "gfx2", 0 )
706
 
        ROM_LOAD( "ld_01.bin",    0x000000, 0x08000, CRC(ad3c6f87) SHA1(1a5ef003c0eb641484921dc0c11450c53ee315f5) ) /* 8x8 text */
707
 
 
708
 
        ROM_REGION( 0x40000, "gfx3", 0 )
709
 
        ROM_LOAD16_BYTE( "ld_17.bin",    0x000001, 0x10000, CRC(7188bfdd) SHA1(26c47af6abb4e6f5e11e2dd6b56113a54c0e6269) ) /* tiles */
710
 
        ROM_LOAD16_BYTE( "ld_18.bin",    0x020001, 0x10000, CRC(a62af66a) SHA1(240dafcb03011cf51bfe9d01bec4aceac64d5760) )
711
 
        ROM_LOAD16_BYTE( "ld_19.bin",    0x000000, 0x10000, CRC(4b762e50) SHA1(95b3413f67d2e9ebea2a8331945a572a3d824cc1) )
712
 
        ROM_LOAD16_BYTE( "ld_20.bin",    0x020000, 0x10000, CRC(b140188e) SHA1(491af082789a11c809c2798da6ae5e52a2b1d986) )
713
 
 
714
 
        ROM_REGION( 0x80000, "gfx4", 0 ) /* the maskrom is split into smaller roms on the bootleg */
715
 
        ROM_LOAD16_BYTE( "ld_28.bin",    0x000001, 0x10000, CRC(06778248) SHA1(09663db5f07961a432feb4f82847a2f9741b34ad) ) /* tiles */
716
 
        ROM_LOAD16_BYTE( "ld_27.bin",    0x000000, 0x10000, CRC(48c78675) SHA1(27b03cd1a5335b60953e5dc4888264598e63c147) )
717
 
        ROM_LOAD16_BYTE( "ld_26.bin",    0x020001, 0x10000, CRC(b0edac81) SHA1(2ba1f864b7f8047b20206063d4e9956ef1d1ad34) )
718
 
        ROM_LOAD16_BYTE( "ld_25.bin",    0x020000, 0x10000, CRC(c541ae9a) SHA1(b1d6acab76cba77ea6b9fe6fc770b6a6d6960a77) )
719
 
        ROM_LOAD16_BYTE( "ld_24.bin",    0x040001, 0x10000, CRC(66eac4df) SHA1(b2604f6fd443071deb2729f4381e6fe3a2069a33) )
720
 
        ROM_LOAD16_BYTE( "ld_23.bin",    0x040000, 0x10000, CRC(d817332c) SHA1(c1c3d70a42eb01237bcbe8e274f7022e74c8c715) )
721
 
        ROM_LOAD16_BYTE( "ld_22.bin",    0x060001, 0x10000, CRC(f80f8812) SHA1(2483b272b51ab15c47eb0b48df68b7c3b05d4d35) )
722
 
        ROM_LOAD16_BYTE( "ld_21.bin",    0x060000, 0x10000, CRC(b74f0c0e) SHA1(866e3c65fd5dd7099423baefd09eb2b7da7e8392) )
723
 
 
724
 
        ROM_REGION( 0x0100, "proms", 0 )
725
 
        ROM_LOAD( "ld.3d",        0x0000, 0x0100, CRC(729a1ddc) SHA1(eb1d48785a0f187a4cb9c164e6c82481268b3174) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
726
 
ROM_END
727
 
 
728
 
ROM_START( madgear )
729
 
        ROM_REGION( 0x80000, "maincpu", 0 )     /* 256K for 68000 code */
730
 
        ROM_LOAD16_BYTE( "mg_04.8b",    0x00000, 0x20000, CRC(b112257d) SHA1(4acfd8ba0fe8d68ca7c9b0fde2b13ce0c9104258) )
731
 
        ROM_LOAD16_BYTE( "mg_03.7b",    0x00001, 0x20000, CRC(b2672465) SHA1(96d10046e67181160daebb2b07c867c08f8600dc) )
732
 
        ROM_LOAD16_BYTE( "mg_02.6b",    0x40000, 0x20000, CRC(9f5ebe16) SHA1(2183cb807157d48204d8d4d4b7555c9a7772ddfd) )
733
 
        ROM_LOAD16_BYTE( "mg_01.5b",    0x40001, 0x20000, CRC(1cea2af0) SHA1(9f4642ed2d21fa525e9fecaac6235a3653df3030) )
734
 
 
735
 
        ROM_REGION( 0x18000 , "audiocpu", 0 ) /* audio CPU */
736
 
        ROM_LOAD( "mg_05.14j",   0x00000,  0x08000, CRC(2fbfc945) SHA1(8066516dcf9261abee1edd103bdbe0cc18913ed3) )
737
 
        ROM_CONTINUE(            0x10000,  0x08000 )
738
 
 
739
 
        ROM_REGION( 0x80000, "gfx1", 0 ) /* CN-SUB daughter cards replace unused NEC 23C2000 mask ROMS (QFP52) at 5A & 13A */
740
 
        ROM_LOAD( "mg_m11.rom0",   0x000000, 0x10000, CRC(ee319a64) SHA1(ce8d65fdac3ec1009b22764807c03dd96b340660) )    /* Interleaved sprites */
741
 
        ROM_LOAD( "mg_m07.rom2",   0x010000, 0x10000, CRC(e5c0b211) SHA1(dc4a92061c686a9d211a7b95aab2e41219508d67) )
742
 
        ROM_LOAD( "mg_m12.rom1",   0x020000, 0x10000, CRC(887ef120) SHA1(9d57b497334d64df9a4ab7f15824dcc6a333f73d) )
743
 
        ROM_LOAD( "mg_m08.rom3",   0x030000, 0x10000, CRC(59709aa3) SHA1(384641da58c8b5198ad4fa51cd5fd9a628bcb888) )    /* Mask roms 07, 08, 11 & 12 located on first CN-SUB daughter card */
744
 
        ROM_LOAD( "mg_m13.rom0",   0x040000, 0x10000, CRC(eae07db4) SHA1(59c4ff48d906b2bb101fbebe06383940fdff064f) )
745
 
        ROM_LOAD( "mg_m09.rom2",   0x050000, 0x10000, CRC(40ee83eb) SHA1(35e11fcb3b75ada99df23715ecb955bd40e10da8) )
746
 
        ROM_LOAD( "mg_m14.rom1",   0x060000, 0x10000, CRC(21e5424c) SHA1(2f7c5d974c847bb14eaf278545bca653919110ba) )
747
 
        ROM_LOAD( "mg_m10.rom3",   0x070000, 0x10000, CRC(b64afb54) SHA1(5fdd4f67e6b7440448adf395b61c79b79b4f86e7) )    /* Mask roms 09, 10, 13 & 14 located on second CN-SUB daughter card */
748
 
 
749
 
        ROM_REGION( 0x08000, "gfx2", 0 )
750
 
        ROM_LOAD( "mg_06.10k",    0x000000, 0x08000, CRC(382ee59b) SHA1(a1da439f0585f5cafe2fb7024f1ae0527e34cd92) )     /* 8x8 text */
751
 
 
752
 
        ROM_REGION( 0x40000, "gfx3", 0 )
753
 
        ROM_LOAD( "ls-12.7l",     0x000000, 0x40000, CRC(6c1b2c6c) SHA1(18f22129f13c6bfa7e285f0e09a35644272f6ecb) )     /* NEC 23C2000 256kx8 mask ROM (QFP52) */
754
 
 
755
 
        ROM_REGION( 0x80000, "gfx4", 0 )
756
 
        ROM_LOAD( "ls-11.2l",     0x000000, 0x80000, CRC(6bf81c64) SHA1(2289978c6bdb6e4f86e7094e861df147e757e249) )     /* NEC 23C4000 512kx8 mask ROM (QFP64) */
757
 
 
758
 
        ROM_REGION( 0x40000, "oki", 0 ) /* ADPCM */
759
 
        ROM_LOAD( "ls-06.10e",    0x00000, 0x20000, CRC(88d39a5b) SHA1(8fb2d1d26e2ffb93dfc9cf8f23bb81eb64496c2b) )
760
 
        ROM_LOAD( "ls-05.12e",    0x20000, 0x20000, CRC(b06e03b5) SHA1(7d17e5cfb57866c60146bea1a4535e961c73327c) )
761
 
 
762
 
        ROM_REGION( 0x0100, "proms", 0 )
763
 
        ROM_LOAD( "29.14k",   0x0000, 0x0100, CRC(7f862e1e) SHA1(7134c4f741463007a177d55922e1284d132f60e3) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
764
 
ROM_END
765
 
 
766
 
ROM_START( madgearj )
767
 
        ROM_REGION( 0x80000, "maincpu", 0 )     /* 256K for 68000 code */
768
 
        ROM_LOAD16_BYTE( "mdj_04.8b",  0x00000, 0x20000, CRC(9ebbebb1) SHA1(84a2b146c10c1635b11c3af0242fd4680994eb5a) )
769
 
        ROM_LOAD16_BYTE( "mdj_03.7b",  0x00001, 0x20000, CRC(a5579c2d) SHA1(789dcb1cdf5cae20ab497c75460ad98c33d1a046) )
770
 
        ROM_LOAD16_BYTE( "mg_02.6b",   0x40000, 0x20000, CRC(9f5ebe16) SHA1(2183cb807157d48204d8d4d4b7555c9a7772ddfd) )
771
 
        ROM_LOAD16_BYTE( "mg_01.5b",   0x40001, 0x20000, CRC(1cea2af0) SHA1(9f4642ed2d21fa525e9fecaac6235a3653df3030) )
772
 
 
773
 
        ROM_REGION(  0x18000 , "audiocpu", 0 ) /* audio CPU */
774
 
        ROM_LOAD( "mg_05.14j",   0x00000,  0x08000, CRC(2fbfc945) SHA1(8066516dcf9261abee1edd103bdbe0cc18913ed3) )
775
 
        ROM_CONTINUE(            0x10000,  0x08000 )
776
 
 
777
 
        ROM_REGION( 0x80000, "gfx1", 0 ) /* CN-SUB daughter cards replace unused NEC 23C2000 mask ROMS (QFP52) at 5A & 13A */
778
 
        ROM_LOAD( "mg_m11.rom0",   0x000000, 0x10000, CRC(ee319a64) SHA1(ce8d65fdac3ec1009b22764807c03dd96b340660) )    /* Interleaved sprites */
779
 
        ROM_LOAD( "mg_m07.rom2",   0x010000, 0x10000, CRC(e5c0b211) SHA1(dc4a92061c686a9d211a7b95aab2e41219508d67) )
780
 
        ROM_LOAD( "mg_m12.rom1",   0x020000, 0x10000, CRC(887ef120) SHA1(9d57b497334d64df9a4ab7f15824dcc6a333f73d) )
781
 
        ROM_LOAD( "mg_m08.rom3",   0x030000, 0x10000, CRC(59709aa3) SHA1(384641da58c8b5198ad4fa51cd5fd9a628bcb888) )    /* Mask roms 07, 08, 11 & 12 located on first CN-SUB daughter card */
782
 
        ROM_LOAD( "mg_m13.rom0",   0x040000, 0x10000, CRC(eae07db4) SHA1(59c4ff48d906b2bb101fbebe06383940fdff064f) )
783
 
        ROM_LOAD( "mg_m09.rom2",   0x050000, 0x10000, CRC(40ee83eb) SHA1(35e11fcb3b75ada99df23715ecb955bd40e10da8) )
784
 
        ROM_LOAD( "mg_m14.rom1",   0x060000, 0x10000, CRC(21e5424c) SHA1(2f7c5d974c847bb14eaf278545bca653919110ba) )
785
 
        ROM_LOAD( "mg_m10.rom3",   0x070000, 0x10000, CRC(b64afb54) SHA1(5fdd4f67e6b7440448adf395b61c79b79b4f86e7) )    /* Mask roms 09, 10, 13 & 14 located on second CN-SUB daughter card */
786
 
 
787
 
        ROM_REGION( 0x08000, "gfx2", 0 )
788
 
        ROM_LOAD( "mg_06.10k",    0x000000, 0x08000, CRC(382ee59b) SHA1(a1da439f0585f5cafe2fb7024f1ae0527e34cd92) )     /* 8x8 text */
789
 
 
790
 
        ROM_REGION( 0x40000, "gfx3", 0 )
791
 
        ROM_LOAD( "ls-12.7l",     0x000000, 0x40000, CRC(6c1b2c6c) SHA1(18f22129f13c6bfa7e285f0e09a35644272f6ecb) )     /* NEC 23C2000 256kx8 mask ROM (QFP52) */
792
 
 
793
 
        ROM_REGION( 0x80000, "gfx4", 0 )
794
 
        ROM_LOAD( "ls-11.2l",     0x000000, 0x80000, CRC(6bf81c64) SHA1(2289978c6bdb6e4f86e7094e861df147e757e249) )     /* NEC 23C4000 512kx8 mask ROM (QFP64) */
795
 
 
796
 
        ROM_REGION( 0x40000, "oki", 0 ) /* ADPCM */
797
 
        ROM_LOAD( "ls-06.10e",    0x00000, 0x20000, CRC(88d39a5b) SHA1(8fb2d1d26e2ffb93dfc9cf8f23bb81eb64496c2b) )
798
 
        ROM_LOAD( "ls-05.12e",    0x20000, 0x20000, CRC(b06e03b5) SHA1(7d17e5cfb57866c60146bea1a4535e961c73327c) )
799
 
 
800
 
        ROM_REGION( 0x0100, "proms", 0 )
801
 
        ROM_LOAD( "29.14k",   0x0000, 0x0100, CRC(7f862e1e) SHA1(7134c4f741463007a177d55922e1284d132f60e3) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
802
 
ROM_END
803
 
 
804
 
ROM_START( ledstorm )
805
 
        ROM_REGION( 0x80000, "maincpu", 0 )     /* 256K for 68000 code */
806
 
        ROM_LOAD16_BYTE( "mdu_04.8b",  0x00000, 0x20000, CRC(7f7f8329) SHA1(9b7ecb7f5cc3f2c80e05da3b9055e2fbd64bf0ce) )
807
 
        ROM_LOAD16_BYTE( "mdu_03.7b",  0x00001, 0x20000, CRC(11fa542f) SHA1(1cedfc471058e0d0502a1eeafcab479dca4fea41) )
808
 
        ROM_LOAD16_BYTE( "mde_02.6b",  0x40000, 0x20000, CRC(9f5ebe16) SHA1(2183cb807157d48204d8d4d4b7555c9a7772ddfd) )
809
 
        ROM_LOAD16_BYTE( "mde_01.5b",  0x40001, 0x20000, CRC(1cea2af0) SHA1(9f4642ed2d21fa525e9fecaac6235a3653df3030) )
810
 
 
811
 
        ROM_REGION(  0x18000 , "audiocpu", 0 ) /* audio CPU */
812
 
        ROM_LOAD( "mde_05.14j",   0x00000,  0x08000, CRC(2fbfc945) SHA1(8066516dcf9261abee1edd103bdbe0cc18913ed3) )
813
 
        ROM_CONTINUE(             0x10000,  0x08000 )
814
 
 
815
 
        ROM_REGION( 0x80000, "gfx1", 0 ) /* CN-SUB daughter cards replace unused NEC 23C2000 mask ROMS (QFP52) at 5A & 13A */
816
 
        ROM_LOAD( "11.rom0",   0x000000, 0x10000, CRC(ee319a64) SHA1(ce8d65fdac3ec1009b22764807c03dd96b340660) )        /* Interleaved sprites */
817
 
        ROM_LOAD( "07u.rom2",  0x010000, 0x10000, CRC(7152b212) SHA1(b021496e8b3c22c018907e6e374a7401d3843570) )
818
 
        ROM_LOAD( "12.rom1",   0x020000, 0x10000, CRC(887ef120) SHA1(9d57b497334d64df9a4ab7f15824dcc6a333f73d) )
819
 
        ROM_LOAD( "08u.rom3",  0x030000, 0x10000, CRC(72e5d525) SHA1(209def4206e9b66be9879f0105d3f04980f156da) )        /* Mask roms 07, 08, 11 & 12 located on first CN-SUB daughter card */
820
 
        ROM_LOAD( "13.rom0",   0x040000, 0x10000, CRC(eae07db4) SHA1(59c4ff48d906b2bb101fbebe06383940fdff064f) )
821
 
        ROM_LOAD( "09u.rom2",  0x050000, 0x10000, CRC(7b5175cb) SHA1(8d8d4953dd787308bed75345af6789899d2afded) )
822
 
        ROM_LOAD( "14.rom1",   0x060000, 0x10000, CRC(21e5424c) SHA1(2f7c5d974c847bb14eaf278545bca653919110ba) )
823
 
        ROM_LOAD( "10u.rom3",  0x070000, 0x10000, CRC(6db7ca64) SHA1(389cc93b9bfe2824a0de9796e79c6d452d09567e) )        /* Mask roms 09, 10, 13 & 14 located on second CN-SUB daughter card */
824
 
 
825
 
        ROM_REGION( 0x08000, "gfx2", 0 )
826
 
        ROM_LOAD( "mdu_06.10k",   0x000000, 0x08000, CRC(54bfdc02) SHA1(480ef755425aed9e0149bdb90bf30ddaef2be192) )     /* 8x8 text */
827
 
 
828
 
        ROM_REGION( 0x40000, "gfx3", 0 )
829
 
        ROM_LOAD( "ls-12.7l",     0x000000, 0x40000, CRC(6c1b2c6c) SHA1(18f22129f13c6bfa7e285f0e09a35644272f6ecb) )     /* NEC 23C2000 256kx8 mask ROM (QFP52) */
830
 
 
831
 
        ROM_REGION( 0x80000, "gfx4", 0 )
832
 
        ROM_LOAD( "ls-11.2l",     0x000000, 0x80000, CRC(6bf81c64) SHA1(2289978c6bdb6e4f86e7094e861df147e757e249) )     /* NEC 23C4000 512kx8 mask ROM (QFP64) */
833
 
 
834
 
        ROM_REGION( 0x40000, "oki", 0 ) /* ADPCM */
835
 
        ROM_LOAD( "ls-06.10e",    0x00000, 0x20000, CRC(88d39a5b) SHA1(8fb2d1d26e2ffb93dfc9cf8f23bb81eb64496c2b) )
836
 
        ROM_LOAD( "ls-05.12e",    0x20000, 0x20000, CRC(b06e03b5) SHA1(7d17e5cfb57866c60146bea1a4535e961c73327c) )
837
 
 
838
 
        ROM_REGION( 0x0100, "proms", 0 )
839
 
        ROM_LOAD( "29.14k",   0x0000, 0x0100, CRC(7f862e1e) SHA1(7134c4f741463007a177d55922e1284d132f60e3) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
840
 
ROM_END
841
 
 
842
 
ROM_START( ledstorm2 )
843
 
        ROM_REGION( 0x80000, "maincpu", 0 )     /* 256K for 68000 code */
844
 
        ROM_LOAD16_BYTE( "lsu-04.8b", 0x00000, 0x20000, CRC(56a2f079) SHA1(da581c117d92ac5c1e8e44324f1aed2858a3cdc8) )
845
 
        ROM_LOAD16_BYTE( "lsu-03.7b", 0x00001, 0x20000, CRC(9b6408c0) SHA1(8ef8349f58c62a2d626b1053eae2032d168d602c) )
846
 
        ROM_LOAD16_BYTE( "ls-02.6b",  0x40000, 0x20000, CRC(05c0285e) SHA1(b155d2d0c41f614bd324813c5d3d87a6765ad812) )
847
 
        ROM_LOAD16_BYTE( "ls-01.5b",  0x40001, 0x20000, CRC(8bf934dd) SHA1(f2287a4361af4986eb010dfbfb6de3a3d4124937) )
848
 
 
849
 
        ROM_REGION(  0x18000 , "audiocpu", 0 ) /* audio CPU */
850
 
        ROM_LOAD( "ls-07.14j",    0x00000,  0x08000, CRC(98af7838) SHA1(a0b87b9ce3c1b0e5d7696ffaab9cea483b9ee928) )
851
 
        ROM_CONTINUE(             0x10000,  0x08000 )
852
 
 
853
 
        ROM_REGION( 0x80000, "gfx1", 0 )
854
 
        ROM_LOAD( "ls-09.5a",     0x000000, 0x40000, BAD_DUMP CRC(80875e1d) SHA1(6f53694a0617bf3b4f65a0cf71750b0e65e49b46) )    /* NEC 23C2000 256kx8 mask ROM (QFP52) */
855
 
        ROM_LOAD( "ls-10.13a",    0x040000, 0x40000, BAD_DUMP CRC(c5993f93) SHA1(29c565c112edb003c7d4adc5ac52e98e034bd1a1) )    /* NEC 23C2000 256kx8 mask ROM (QFP52) */
856
 
 
857
 
        ROM_REGION( 0x08000, "gfx2", 0 )
858
 
        ROM_LOAD( "ls-08.10k",    0x000000, 0x08000, CRC(8803cf49) SHA1(7a01a05f760d8e2472fdbc1d10b53094babe295e) )     /* 8x8 text */
859
 
 
860
 
        ROM_REGION( 0x40000, "gfx3", 0 )
861
 
        ROM_LOAD( "ls-12.7l",     0x000000, 0x40000, CRC(6c1b2c6c) SHA1(18f22129f13c6bfa7e285f0e09a35644272f6ecb) )     /* NEC 23C2000 256kx8 mask ROM (QFP52) */
862
 
 
863
 
        ROM_REGION( 0x80000, "gfx4", 0 )
864
 
        ROM_LOAD( "ls-11.2l",     0x000000, 0x80000, CRC(6bf81c64) SHA1(2289978c6bdb6e4f86e7094e861df147e757e249) )     /* NEC 23C4000 512kx8 mask ROM (QFP64) */
865
 
 
866
 
        ROM_REGION( 0x40000, "oki", 0 ) /* ADPCM */
867
 
        ROM_LOAD( "ls-06.10e",    0x00000, 0x20000, CRC(88d39a5b) SHA1(8fb2d1d26e2ffb93dfc9cf8f23bb81eb64496c2b) )
868
 
        ROM_LOAD( "ls-05.12e",    0x20000, 0x20000, CRC(b06e03b5) SHA1(7d17e5cfb57866c60146bea1a4535e961c73327c) )
869
 
 
870
 
        ROM_REGION( 0x0100, "proms", 0 )
871
 
        ROM_LOAD( "29.14k",   0x0000, 0x0100, CRC(7f862e1e) SHA1(7134c4f741463007a177d55922e1284d132f60e3) ) /* priority (not used) BPROM type 63S141 or compatible like 82S129A */
872
 
ROM_END
873
 
 
874
 
/******************************************************************************/
875
 
 
876
 
GAME( 1988, lastduel,  0,        lastduel, lastduel, 0, ROT270, "Capcom",  "Last Duel (US New Ver.)", GAME_SUPPORTS_SAVE )
877
 
GAME( 1988, lastduelo, lastduel, lastduel, lastduel, 0, ROT270, "Capcom",  "Last Duel (US Old Ver.)", GAME_SUPPORTS_SAVE )
878
 
GAME( 1988, lastduelj, lastduel, lastduel, lastduel, 0, ROT270, "Capcom",  "Last Duel (Japan)", GAME_SUPPORTS_SAVE )
879
 
GAME( 1988, lastduelb, lastduel, lastduel, lastduel, 0, ROT270, "bootleg", "Last Duel (bootleg)", GAME_SUPPORTS_SAVE )
880
 
GAME( 1989, madgear,   0,        madgear,  madgear,  0, ROT270, "Capcom",  "Mad Gear (US)", GAME_SUPPORTS_SAVE )
881
 
GAME( 1989, madgearj,  madgear,  madgear,  madgear,  0, ROT270, "Capcom",  "Mad Gear (Japan)", GAME_SUPPORTS_SAVE )
882
 
GAME( 1988, ledstorm,  madgear,  madgear,  madgear,  0, ROT270, "Capcom",  "Led Storm (US)", GAME_SUPPORTS_SAVE )
883
 
GAME( 1988, ledstorm2, madgear,  madgear,  madgear,  0, ROT270, "Capcom",  "Led Storm Rally 2011 (US)", GAME_IMPERFECT_GRAPHICS | GAME_SUPPORTS_SAVE ) /* game still has wrong sprite issues */