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

« back to all changes in this revision

Viewing changes to mess/src/mame/drivers/dynadice.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
 
Dynamic Dice (??)
3
 
 
4
 
Driver by
5
 
    Tomasz Slanina
6
 
    Pierpaolo Prazzoli
7
 
--
8
 
Old, rusty, not working pcb :
9
 
 
10
 
 
11
 
Main PCB :
12
 
 
13
 
m5l8080ap (8080)
14
 
 
15
 
dy_1.bin (1H)
16
 
dy_2.bin (1L)
17
 
dy_3.bin (1P)
18
 
 
19
 
dip 6x  (all off)
20
 
 
21
 
xtal 18.432 mhz
22
 
 
23
 
--
24
 
Sub PCB  DYNA-529-81ST :
25
 
 
26
 
AY-3-8910
27
 
Z80
28
 
 
29
 
dy_4.bin
30
 
dy_5.bin
31
 
dy_6.bin (near Z80)
32
 
*/
33
 
 
34
 
#include "emu.h"
35
 
#include "cpu/z80/z80.h"
36
 
#include "cpu/i8085/i8085.h"
37
 
#include "sound/ay8910.h"
38
 
#include "machine/nvram.h"
39
 
 
40
 
 
41
 
class dynadice_state : public driver_device
42
 
{
43
 
public:
44
 
        dynadice_state(const machine_config &mconfig, device_type type, const char *tag)
45
 
                : driver_device(mconfig, type, tag) { }
46
 
 
47
 
        /* memory pointers */
48
 
        UINT8 *  m_videoram;
49
 
//  UINT8 *  m_nvram;     // currently this uses generic nvram handling
50
 
//  UINT8 *  m_paletteram;    // currently this uses generic palette handling
51
 
 
52
 
        /* video-related */
53
 
        tilemap_t  *m_bg_tilemap;
54
 
        tilemap_t  *m_top_tilemap;
55
 
 
56
 
        /* misc */
57
 
        int      m_ay_data;
58
 
};
59
 
 
60
 
 
61
 
static WRITE8_HANDLER( dynadice_videoram_w )
62
 
{
63
 
        dynadice_state *state = space->machine().driver_data<dynadice_state>();
64
 
        state->m_videoram[offset] = data;
65
 
        tilemap_mark_tile_dirty(state->m_bg_tilemap, offset);
66
 
        tilemap_mark_all_tiles_dirty(state->m_top_tilemap);
67
 
}
68
 
 
69
 
static WRITE8_HANDLER( sound_data_w )
70
 
{
71
 
        dynadice_state *state = space->machine().driver_data<dynadice_state>();
72
 
        state->m_ay_data = data;
73
 
}
74
 
 
75
 
static WRITE8_DEVICE_HANDLER( sound_control_w )
76
 
{
77
 
        dynadice_state *state = device->machine().driver_data<dynadice_state>();
78
 
/*
79
 
    AY 3-8910 :
80
 
 
81
 
    D0 - BC1
82
 
    D1 - BC2
83
 
    D2 - BDIR
84
 
    D3 - /Reset
85
 
 
86
 
*/
87
 
        if ((data & 7) == 7)
88
 
                ay8910_address_w(device, 0, state->m_ay_data);
89
 
 
90
 
        if ((data & 7) == 6)
91
 
                ay8910_data_w(device, 0, state->m_ay_data);
92
 
}
93
 
 
94
 
 
95
 
static ADDRESS_MAP_START( dynadice_map, AS_PROGRAM, 8 )
96
 
        AM_RANGE(0x0000, 0x1fff) AM_ROM
97
 
        AM_RANGE(0x2000, 0x23ff) AM_RAM_WRITE(dynadice_videoram_w) AM_BASE_MEMBER(dynadice_state, m_videoram)
98
 
        AM_RANGE(0x4000, 0x40ff) AM_RAM AM_SHARE("nvram")
99
 
ADDRESS_MAP_END
100
 
 
101
 
static ADDRESS_MAP_START( dynadice_io_map, AS_IO, 8 )
102
 
        AM_RANGE(0x50, 0x50) AM_READ_PORT("IN0")
103
 
        AM_RANGE(0x51, 0x51) AM_READ_PORT("IN1")
104
 
        AM_RANGE(0x52, 0x52) AM_READ_PORT("DSW")
105
 
        AM_RANGE(0x62, 0x62) AM_WRITENOP
106
 
        AM_RANGE(0x63, 0x63) AM_WRITE(soundlatch_w)
107
 
        AM_RANGE(0x70, 0x77) AM_WRITENOP
108
 
ADDRESS_MAP_END
109
 
 
110
 
static ADDRESS_MAP_START( dynadice_sound_map, AS_PROGRAM, 8 )
111
 
        AM_RANGE(0x0000, 0x07ff) AM_ROM
112
 
        AM_RANGE(0x2000, 0x23ff) AM_RAM
113
 
ADDRESS_MAP_END
114
 
 
115
 
static ADDRESS_MAP_START( dynadice_sound_io_map, AS_IO, 8 )
116
 
        ADDRESS_MAP_GLOBAL_MASK(0xff)
117
 
        AM_RANGE(0x00, 0x00) AM_READ(soundlatch_r)
118
 
        AM_RANGE(0x01, 0x01) AM_WRITE(soundlatch_clear_w)
119
 
        AM_RANGE(0x02, 0x02) AM_WRITE(sound_data_w)
120
 
        AM_RANGE(0x03, 0x03) AM_DEVWRITE("aysnd", sound_control_w)
121
 
ADDRESS_MAP_END
122
 
 
123
 
static INPUT_PORTS_START( dynadice )
124
 
        PORT_START("IN0")
125
 
        PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_COIN1 )
126
 
        PORT_DIPNAME( 0x02, 0x02, "Initialize NVRAM" )
127
 
        PORT_DIPSETTING(    0x02, DEF_STR( Off ) )
128
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
129
 
        PORT_BIT( 0x30, IP_ACTIVE_LOW, IPT_UNKNOWN )
130
 
 
131
 
        PORT_START("IN1")
132
 
        PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_BUTTON1 ) /* increase number of coins */
133
 
        PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_BUTTON2 ) /* decrease number of coins */
134
 
        PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_START1 )  /* start /stop */
135
 
 
136
 
        PORT_START("DSW")
137
 
        PORT_DIPNAME( 0x1c, 0x1c, DEF_STR( Coinage ) )
138
 
        PORT_DIPSETTING(    0x00, DEF_STR( 5C_1C ))
139
 
        PORT_DIPSETTING(    0x04, DEF_STR( 4C_1C ))
140
 
        PORT_DIPSETTING(    0x08, DEF_STR( 3C_1C ))
141
 
        PORT_DIPSETTING(    0x0c, DEF_STR( 2C_1C ))
142
 
        PORT_DIPSETTING(    0x1c, DEF_STR( 1C_1C ))
143
 
        PORT_DIPSETTING(    0x18, DEF_STR( 1C_2C ))
144
 
        PORT_DIPSETTING(    0x14, DEF_STR( 1C_3C ))
145
 
        PORT_DIPSETTING(    0x10, DEF_STR( 1C_4C ))
146
 
 
147
 
        PORT_DIPNAME( 0x01, 0x01, "DSW 1-0" )
148
 
        PORT_DIPSETTING(    0x01, DEF_STR( Off ) )
149
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
150
 
        PORT_DIPNAME( 0x02, 0x02, "DSW 1-1" )
151
 
        PORT_DIPSETTING(    0x02, DEF_STR( Off ) )
152
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
153
 
        PORT_DIPNAME( 0x20, 0x20, "DSW 1-5" )
154
 
        PORT_DIPSETTING(    0x20, DEF_STR( Off ) )
155
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
156
 
        PORT_DIPNAME( 0x40, 0x40, "DSW 1-6" )
157
 
        PORT_DIPSETTING(    0x40, DEF_STR( Off ) )
158
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
159
 
        PORT_DIPNAME( 0x80, 0x80, "DSW 1-7" )
160
 
        PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
161
 
        PORT_DIPSETTING(    0x00, DEF_STR( On ) )
162
 
INPUT_PORTS_END
163
 
 
164
 
static const gfx_layout charlayout =
165
 
{
166
 
        8,8,
167
 
        RGN_FRAC(1,1),
168
 
        1,
169
 
        { 0 },
170
 
        { 0, 1, 2, 3, 4, 5, 6, 7 },
171
 
        { 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 },
172
 
        8*8
173
 
};
174
 
 
175
 
static const gfx_layout charlayout2 =
176
 
{
177
 
        8,8,
178
 
        RGN_FRAC(1,1),
179
 
        3,
180
 
        { 5,6,7 },
181
 
        { 0, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 },
182
 
        { 0*8*8, 1*8*8, 2*8*8, 3*8*8, 4*8*8, 5*8*8, 6*8*8, 7*8*8 },
183
 
        8*8*8
184
 
};
185
 
 
186
 
 
187
 
static GFXDECODE_START( dynadice )
188
 
        GFXDECODE_ENTRY( "gfx1", 0, charlayout,   0, 1 ) /* 1bpp */
189
 
        GFXDECODE_ENTRY( "gfx2", 0, charlayout2,  0, 1 ) /* 3bpp */
190
 
GFXDECODE_END
191
 
 
192
 
static TILE_GET_INFO( get_tile_info )
193
 
{
194
 
        dynadice_state *state = machine.driver_data<dynadice_state>();
195
 
        int code = state->m_videoram[tile_index];
196
 
        SET_TILE_INFO(1, code, 0, 0);
197
 
}
198
 
 
199
 
static VIDEO_START( dynadice )
200
 
{
201
 
        dynadice_state *state = machine.driver_data<dynadice_state>();
202
 
 
203
 
        /* pacman - style videoram layout */
204
 
        state->m_bg_tilemap = tilemap_create(machine, get_tile_info, tilemap_scan_rows, 8, 8, 32, 32);
205
 
        state->m_top_tilemap = tilemap_create(machine, get_tile_info, tilemap_scan_cols, 8, 8, 2, 32);
206
 
        tilemap_set_scrollx(state->m_bg_tilemap, 0, -16);
207
 
}
208
 
 
209
 
static SCREEN_UPDATE( dynadice )
210
 
{
211
 
        dynadice_state *state = screen->machine().driver_data<dynadice_state>();
212
 
        rectangle myclip = *cliprect;
213
 
        myclip.max_x = 15;
214
 
        tilemap_draw(bitmap, cliprect, state->m_bg_tilemap, 0, 0);
215
 
        tilemap_draw(bitmap, &myclip, state->m_top_tilemap, 0, 0);
216
 
        return 0;
217
 
}
218
 
 
219
 
static PALETTE_INIT( dynadice )
220
 
{
221
 
        int i;
222
 
        for(i = 0; i < 8; i++)
223
 
                palette_set_color_rgb(machine, i, pal1bit(i >> 1), pal1bit(i >> 2), pal1bit(i >> 0));
224
 
}
225
 
 
226
 
static MACHINE_START( dynadice )
227
 
{
228
 
        dynadice_state *state = machine.driver_data<dynadice_state>();
229
 
        state->save_item(NAME(state->m_ay_data));
230
 
}
231
 
 
232
 
static MACHINE_RESET( dynadice )
233
 
{
234
 
        dynadice_state *state = machine.driver_data<dynadice_state>();
235
 
        state->m_ay_data = 0;
236
 
}
237
 
 
238
 
static MACHINE_CONFIG_START( dynadice, dynadice_state )
239
 
 
240
 
        /* basic machine hardware */
241
 
        MCFG_CPU_ADD("maincpu", I8080,18432000/8)
242
 
        MCFG_CPU_PROGRAM_MAP(dynadice_map)
243
 
        MCFG_CPU_IO_MAP(dynadice_io_map)
244
 
 
245
 
        MCFG_CPU_ADD("audiocpu", Z80,18432000/6)
246
 
        MCFG_CPU_PROGRAM_MAP(dynadice_sound_map)
247
 
        MCFG_CPU_IO_MAP(dynadice_sound_io_map)
248
 
 
249
 
        MCFG_MACHINE_START(dynadice)
250
 
        MCFG_MACHINE_RESET(dynadice)
251
 
 
252
 
        MCFG_NVRAM_ADD_0FILL("nvram")
253
 
 
254
 
        /* video hardware */
255
 
        MCFG_SCREEN_ADD("screen", RASTER)
256
 
        MCFG_SCREEN_REFRESH_RATE(60)
257
 
        MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
258
 
        MCFG_SCREEN_FORMAT(BITMAP_FORMAT_INDEXED16)
259
 
        MCFG_SCREEN_SIZE(256+16, 256)
260
 
        MCFG_SCREEN_VISIBLE_AREA(0*8, 34*8-1, 3*8, 28*8-1)
261
 
        MCFG_SCREEN_UPDATE(dynadice)
262
 
 
263
 
        MCFG_GFXDECODE(dynadice)
264
 
        MCFG_PALETTE_LENGTH(8)
265
 
        MCFG_PALETTE_INIT(dynadice)
266
 
 
267
 
        MCFG_VIDEO_START(dynadice)
268
 
 
269
 
        MCFG_SPEAKER_STANDARD_MONO("mono")
270
 
 
271
 
        MCFG_SOUND_ADD("aysnd", AY8910, 2000000)
272
 
        MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 1.0)
273
 
MACHINE_CONFIG_END
274
 
 
275
 
ROM_START( dynadice )
276
 
        ROM_REGION( 0x10000, "maincpu", 0 )
277
 
        ROM_LOAD( "dy_1.bin",     0x0000, 0x1000, CRC(4ad18724) SHA1(78151b02a727f4272eff72765883df9ca09606c3) )
278
 
        ROM_LOAD( "dy_2.bin",     0x1000, 0x0800, CRC(82cb1873) SHA1(661f33af4a536b7929d432d755ab44f9280f82db) )
279
 
        ROM_LOAD( "dy_3.bin",     0x1800, 0x0800, CRC(a8edad20) SHA1(b812141f216355c986047969326bd1e036be71e6) )
280
 
 
281
 
        ROM_REGION( 0x10000, "audiocpu", 0 )
282
 
        ROM_LOAD( "dy_6.bin",     0x0000, 0x0800, CRC(d4e6e6a3) SHA1(84c0fcfd8326a4301accbd192df6e372b98ae537) )
283
 
 
284
 
        ROM_REGION( 0x0800, "gfx1", 0 )
285
 
        ROM_LOAD( "dy_4.bin",     0x0000, 0x0800, CRC(306b851b) SHA1(bf69ed126d32b31e1711ff23c5a75b8a8bd28207) )
286
 
 
287
 
        ROM_REGION( 0x0800*8, "gfx2", ROMREGION_ERASE00 )
288
 
        /* gfx data will be rearranged here for 8x8 3bpp tiles */
289
 
 
290
 
        ROM_REGION( 0x0800, "user1",0 )
291
 
        ROM_LOAD( "dy_5.bin",     0x0000, 0x0800, CRC(e4799462) SHA1(5cd0f003572540522d72706bc5a8fa6588553031) )
292
 
ROM_END
293
 
 
294
 
static DRIVER_INIT( dynadice )
295
 
{
296
 
        int i, j;
297
 
        UINT8 *usr1 = machine.region("user1")->base();
298
 
        UINT8 *cpu2 = machine.region("audiocpu")->base();
299
 
        UINT8 *gfx1 = machine.region("gfx1")->base();
300
 
        UINT8 *gfx2 = machine.region("gfx2")->base();
301
 
 
302
 
        cpu2[0x0b] = 0x23;      /* bug in game code  Dec HL -> Inc HL*/
303
 
 
304
 
        /* 1bpp tiles -> 3bpp tiles (dy_5.bin  contains bg/fg color data for each tile line) */
305
 
        for (i = 0; i < 0x800; i++)
306
 
                for (j = 0; j < 8; j++)
307
 
                        gfx2[(i << 3) + j] = (gfx1[i] & (0x80 >> j)) ? (usr1[i] & 7) : (usr1[i] >> 4);
308
 
}
309
 
 
310
 
GAME( 19??, dynadice, 0, dynadice, dynadice, dynadice, ROT90, "<unknown>", "Dynamic Dice", GAME_SUPPORTS_SAVE )