Silver Millennium driver.

This commit is contained in:
iq_132 2012-04-13 19:20:22 +00:00
parent 9197466590
commit f7f0bd95d8
3 changed files with 711 additions and 4 deletions

View File

@ -54,8 +54,8 @@ drvobj = d_dodonpachi.o d_donpachi.o d_esprade.o d_feversos.o d_gaia.o d_guwang
d_deniam.o d_ddragon3.o d_diverboy.o d_drtomy.o d_egghunt.o d_esd16.o d_f1gp.o d_fstarfrc.o d_funybubl.o d_fuukifg3.o \
d_gaelco.o d_gaiden.o d_galpanic.o d_galspnbl.o d_gotcha.o d_gumbo.o d_hyperpac.o d_jchan.o d_kaneko16.o d_lordgun.o \
d_mcatadv.o d_midas.o d_mugsmash.o d_news.o d_nmg5.o d_nmk16.o d_ohmygod.o d_pass.o d_pirates.o d_powerins.o \
d_pushman.o d_raiden.o d_seta.o d_seta2.o d_shadfrce.o d_silkroad.o d_speedspn.o d_suna16.o d_taotaido.o d_tecmosys.o \
d_tumbleb.o d_unico.o d_vmetal.o d_welltris.o d_wwfwfest.o d_xorworld.o d_yunsun16.o d_zerozone.o \
d_pushman.o d_raiden.o d_seta.o d_seta2.o d_shadfrce.o d_silkroad.o d_silvmil.o d_speedspn.o d_suna16.o d_taotaido.o \
d_tecmosys.o d_tumbleb.o d_unico.o d_vmetal.o d_welltris.o d_wwfwfest.o d_xorworld.o d_yunsun16.o d_zerozone.o \
\
d_parent.o \
\

View File

@ -58,8 +58,9 @@ drvobj = d_dodonpachi.o d_donpachi.o d_esprade.o d_feversos.o d_gaia.o d_guwang
d_deniam.o d_ddragon3.o d_diverboy.o d_drtomy.o d_egghunt.o d_esd16.o d_f1gp.o d_fstarfrc.o d_funybubl.o d_fuukifg3.o \
d_gaelco.o d_gaiden.o d_galpanic.o d_galspnbl.o d_gotcha.o d_gumbo.o d_hyperpac.o d_jchan.o d_kaneko16.o d_lordgun.o \
d_mcatadv.o d_midas.o d_mugsmash.o d_news.o d_nmg5.o d_nmk16.o d_ohmygod.o d_pass.o d_pirates.o d_pktgaldx.o \
d_powerins.o d_pushman.o d_raiden.o d_seta.o d_seta2.o d_shadfrce.o d_silkroad.o d_speedspn.o d_suna16.o d_taotaido.o \
d_tecmosys.o d_tumbleb.o d_unico.o d_vmetal.o d_welltris.o d_wwfwfest.o d_xorworld.o d_yunsun16.o d_zerozone.o \
d_powerins.o d_pushman.o d_raiden.o d_seta.o d_seta2.o d_shadfrce.o d_silkroad.o d_silvmin.o d_speedspn.o d_suna16.o \
d_taotaido.o d_tecmosys.o d_tumbleb.o d_unico.o d_vmetal.o d_welltris.o d_wwfwfest.o d_xorworld.o d_yunsun16.o \
d_zerozone.o \
\
d_parent.o \
\

View File

@ -0,0 +1,706 @@
// FB Alpha Silver Millennium driver module
// Based on MAME driver by David Haywood
#include "tiles_generic.h"
#include "sek.h"
#include "zet.h"
#include "msm6295.h"
#include "burn_ym2151.h"
static UINT8 *AllMem;
static UINT8 *MemEnd;
static UINT8 *AllRam;
static UINT8 *RamEnd;
static UINT8 *Drv68KROM;
static UINT8 *DrvZ80ROM;
static UINT8 *DrvSndROM;
static UINT8 *DrvGfxROM0;
static UINT8 *DrvGfxROM1;
static UINT8 *Drv68KRAM;
static UINT8 *DrvZ80RAM;
static UINT8 *DrvPalRAM;
static UINT8 *DrvFgRAM;
static UINT8 *DrvBgRAM;
static UINT8 *DrvSprRAM;
static UINT32 *DrvPalette;
static UINT8 DrvRecalc;
static UINT8 *tilebanks;
static UINT8 *soundlatch;
static UINT8 *tile_bank;
static UINT16 *fg_scroll_x;
static UINT16 *fg_scroll_y;
static UINT16 *bg_scroll_x;
static UINT16 *bg_scroll_y;
static UINT8 DrvJoy1[16];
static UINT8 DrvJoy2[16];
static UINT8 DrvDips[2];
static UINT8 DrvReset;
static UINT16 DrvInputs[3];
static struct BurnInputInfo SilvmilInputList[] = {
{"P1 Coin", BIT_DIGITAL, DrvJoy2 + 8, "p1 coin" },
{"P1 Start", BIT_DIGITAL, DrvJoy1 + 7, "p1 start" },
{"P1 Up", BIT_DIGITAL, DrvJoy1 + 0, "p1 up" },
{"P1 Down", BIT_DIGITAL, DrvJoy1 + 1, "p1 down" },
{"P1 Left", BIT_DIGITAL, DrvJoy1 + 2, "p1 left" },
{"P1 Right", BIT_DIGITAL, DrvJoy1 + 3, "p1 right" },
{"P1 Button 1", BIT_DIGITAL, DrvJoy1 + 4, "p1 fire 1" },
{"P1 Button 2", BIT_DIGITAL, DrvJoy1 + 5, "p1 fire 2" },
{"P1 Button 3", BIT_DIGITAL, DrvJoy1 + 6, "p1 fire 3" },
{"P2 Coin", BIT_DIGITAL, DrvJoy2 + 9, "p2 coin" },
{"P2 Start", BIT_DIGITAL, DrvJoy1 + 15, "p2 start" },
{"P2 Up", BIT_DIGITAL, DrvJoy1 + 8, "p2 up" },
{"P2 Down", BIT_DIGITAL, DrvJoy1 + 9, "p2 down" },
{"P2 Left", BIT_DIGITAL, DrvJoy1 + 10, "p2 left" },
{"P2 Right", BIT_DIGITAL, DrvJoy1 + 11, "p2 right" },
{"P2 Button 1", BIT_DIGITAL, DrvJoy1 + 12, "p2 fire 1" },
{"P2 Button 2", BIT_DIGITAL, DrvJoy1 + 13, "p2 fire 2" },
{"P2 Button 3", BIT_DIGITAL, DrvJoy1 + 14, "p2 fire 3" },
{"Reset", BIT_DIGITAL, &DrvReset, "reset" },
{"Dip A", BIT_DIPSWITCH, DrvDips + 0, "dip" },
{"Dip B", BIT_DIPSWITCH, DrvDips + 1, "dip" },
};
STDINPUTINFO(Silvmil)
static struct BurnDIPInfo SilvmilDIPList[]=
{
{0x13, 0xff, 0xff, 0xff, NULL },
{0x14, 0xff, 0xff, 0xff, NULL },
{0 , 0xfe, 0 , 2, "DSW1:1" },
{0x13, 0x01, 0x01, 0x01, "Off" },
{0x13, 0x01, 0x01, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:2" },
{0x13, 0x01, 0x02, 0x02, "Off" },
{0x13, 0x01, 0x02, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:3" },
{0x13, 0x01, 0x04, 0x04, "Off" },
{0x13, 0x01, 0x04, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:4" },
{0x13, 0x01, 0x08, 0x08, "Off" },
{0x13, 0x01, 0x08, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:5" },
{0x13, 0x01, 0x10, 0x10, "Off" },
{0x13, 0x01, 0x10, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:6" },
{0x13, 0x01, 0x20, 0x20, "Off" },
{0x13, 0x01, 0x20, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:7" },
{0x13, 0x01, 0x40, 0x40, "Off" },
{0x13, 0x01, 0x40, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW1:8" },
{0x13, 0x01, 0x80, 0x80, "Off" },
{0x13, 0x01, 0x80, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:1" },
{0x14, 0x01, 0x01, 0x01, "Off" },
{0x14, 0x01, 0x01, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:2" },
{0x14, 0x01, 0x02, 0x02, "Off" },
{0x14, 0x01, 0x02, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:3" },
{0x14, 0x01, 0x04, 0x04, "Off" },
{0x14, 0x01, 0x04, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:4" },
{0x14, 0x01, 0x08, 0x08, "Off" },
{0x14, 0x01, 0x08, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:5" },
{0x14, 0x01, 0x10, 0x10, "Off" },
{0x14, 0x01, 0x10, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:6" },
{0x14, 0x01, 0x20, 0x20, "Off" },
{0x14, 0x01, 0x20, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:7" },
{0x14, 0x01, 0x40, 0x40, "Off" },
{0x14, 0x01, 0x40, 0x00, "On" },
{0 , 0xfe, 0 , 2, "DSW2:8" },
{0x14, 0x01, 0x80, 0x80, "Off" },
{0x14, 0x01, 0x80, 0x00, "On" },
};
STDDIPINFO(Silvmil)
static inline void DrvPaletteUpdate(INT32 offset)
{
UINT8 r,g,b;
UINT16 pal = *((UINT16*)(DrvPalRAM + offset))
;
r = (BURN_ENDIAN_SWAP_INT16(pal) >> 10) & 0x1f;
g = (BURN_ENDIAN_SWAP_INT16(pal) >> 5) & 0x1f;
b = (BURN_ENDIAN_SWAP_INT16(pal) >> 0) & 0x1f;
r = (r << 3) | (r >> 2);
g = (g << 3) | (g >> 2);
b = (b << 3) | (b >> 2);
DrvPalette[offset/2] = BurnHighCol(r, g, b, 0);
}
void __fastcall silvmil_write_byte(UINT32 address, UINT8 data)
{
switch (address)
{
case 0x100000:
*tile_bank = data & 0x03;
return;
case 0x10000e:
tilebanks[*tile_bank] = data & 0x1f;
return;
}
}
void __fastcall silvmil_write_word(UINT32 address, UINT16 data)
{
switch (address)
{
case 0x100002:
*fg_scroll_x = data & 0x3ff;
return;
case 0x100004:
*fg_scroll_y = (data + 8) & 0x1ff;
return;
case 0x100006:
*bg_scroll_x = (data + 4) & 0x3ff;
return;
case 0x100008:
*bg_scroll_y = (data + 8) & 0x1ff;
return;
case 0x270000:
*soundlatch = data;
return;
}
}
UINT8 __fastcall silvmil_read_byte(UINT32 address)
{
switch (address)
{
case 0x280002:
return DrvInputs[1] >> 8;
}
return 0;
}
UINT16 __fastcall silvmil_read_word(UINT32 address)
{
switch (address)
{
case 0x280000:
case 0x280002:
case 0x280004:
return DrvInputs[(address >> 1) & 3];
}
return 0;
}
void __fastcall silvmil_palette_write_byte(UINT32 address, UINT8 data)
{
if ((address & 0xffff800) == 0x200000) {
DrvPalRAM[(address & 0x7ff) ^ 1] = data;
DrvPaletteUpdate(address & 0x7fe);
return;
}
}
void __fastcall silvmil_palette_write_word(UINT32 address, UINT16 data)
{
if ((address & 0xffff800) == 0x200000) {
*((unsigned short*)(DrvPalRAM +(address & 0x7fe))) = data;
DrvPaletteUpdate(address & 0x7fe);
return;
}
}
void __fastcall silvmil_sound_write(UINT16 address, UINT8 data)
{
switch (address)
{
case 0xc000:
BurnYM2151SelectRegister(data);
return;
case 0xc001:
BurnYM2151WriteRegister(data);
return;
case 0xc002:
case 0xc003:
MSM6295Command(0, data);
return;
}
}
UINT8 __fastcall silvmil_sound_read(UINT16 address)
{
switch (address)
{
case 0xc001:
return BurnYM2151ReadStatus();
case 0xc002:
case 0xc003:
return MSM6295ReadStatus(0);
case 0xc006:
return *soundlatch;
}
return 0;
}
void silvmilYM2151IrqHandler(INT32 nStatus)
{
ZetSetIRQLine(0, (nStatus) ? ZET_IRQSTATUS_ACK : ZET_IRQSTATUS_NONE);
}
static INT32 DrvDoReset()
{
memset (AllRam, 0, RamEnd - AllRam);
SekOpen(0);
SekReset();
SekClose();
ZetOpen(0);
ZetReset();
ZetClose();
BurnYM2151Reset();
MSM6295Reset(0);
return 0;
}
static INT32 MemIndex()
{
UINT8 *Next; Next = AllMem;
Drv68KROM = Next; Next += 0x100000;
DrvZ80ROM = Next; Next += 0x010000;
DrvGfxROM0 = Next; Next += 0x800000;
DrvGfxROM1 = Next; Next += 0x400000;
MSM6295ROM = Next;
DrvSndROM = Next; Next += 0x040000;
DrvPalette = (UINT32*)Next; Next += 0x0300 * sizeof(UINT32);
AllRam = Next;
Drv68KRAM = Next; Next += 0x010000;
DrvPalRAM = Next; Next += 0x000800;
DrvFgRAM = Next; Next += 0x001000;
DrvBgRAM = Next; Next += 0x001000;
DrvSprRAM = Next; Next += 0x000800;
DrvZ80RAM = Next; Next += 0x000800;
soundlatch = Next; Next += 0x000001;
tile_bank = Next; Next += 0x000001;
tilebanks = Next; Next += 0x000004;
fg_scroll_x = (UINT16*)Next; Next += 0x0001 * sizeof (UINT16);
bg_scroll_x = (UINT16*)Next; Next += 0x0001 * sizeof (UINT16);
fg_scroll_y = (UINT16*)Next; Next += 0x0001 * sizeof (UINT16);
bg_scroll_y = (UINT16*)Next; Next += 0x0001 * sizeof (UINT16);
RamEnd = Next;
MemEnd = Next;
return 0;
}
static INT32 DrvGfxDecode(UINT8 *gfx, INT32 gfxlen)
{
INT32 Planes[4] = { ((gfxlen / 2) * 8) + 8, ((gfxlen / 2) * 8) + 0, 8, 0 };
INT32 XOffs[16] = { STEP8(256, 1), STEP8(0, 1) };
INT32 YOffs[16] = { STEP16(0, 16) };
UINT8 *tmp = (UINT8*)BurnMalloc(gfxlen);
if (tmp == NULL) {
return 1;
}
memcpy (tmp, gfx, gfxlen);
GfxDecode((gfxlen * 2) / (16 * 16), 4, 16, 16, Planes, XOffs, YOffs, 0x200, tmp, gfx);
BurnFree (tmp);
return 0;
}
static INT32 DrvInit()
{
AllMem = NULL;
MemIndex();
INT32 nLen = MemEnd - (UINT8 *)0;
if ((AllMem = (UINT8 *)BurnMalloc(nLen)) == NULL) return 1;
memset(AllMem, 0, nLen);
MemIndex();
{
if (BurnLoadRom(Drv68KROM + 0x000001, 0, 2)) return 1;
if (BurnLoadRom(Drv68KROM + 0x000000, 1, 2)) return 1;
if (BurnLoadRom(DrvZ80ROM + 0x000000, 2, 1)) return 1;
if (BurnLoadRom(DrvSndROM + 0x000000, 3, 1)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x000000, 4, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x000001, 5, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x100000, 6, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x100001, 7, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x200000, 8, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x200001, 9, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x300000, 10, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x300001, 11, 2)) return 1;
for (INT32 i = 0; i < 0x400000; i++) {
DrvGfxROM0[((i & 0x03ffff) ^ 0x20) | ((~i & 0x040000) << 3) | ((i & 0x380000) >> 1)] = DrvGfxROM1[i];
}
if (BurnLoadRom(DrvGfxROM1 + 0x000000, 12, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x000001, 13, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x100000, 14, 2)) return 1;
if (BurnLoadRom(DrvGfxROM1 + 0x100001, 15, 2)) return 1;
DrvGfxDecode(DrvGfxROM0, 0x400000);
DrvGfxDecode(DrvGfxROM1, 0x200000);
}
SekInit(0, 0x68000);
SekOpen(0);
SekMapMemory(Drv68KROM, 0x000000, 0x0fffff, SM_ROM);
SekMapMemory(DrvFgRAM, 0x120000, 0x120fff, SM_RAM);
SekMapMemory(DrvBgRAM, 0x122000, 0x122fff, SM_RAM);
SekMapMemory(DrvPalRAM, 0x200000, 0x2005ff, SM_ROM);
SekMapMemory(DrvSprRAM, 0x210000, 0x2107ff, SM_RAM);
SekMapMemory(Drv68KRAM, 0x300000, 0x30ffff, SM_RAM);
SekSetWriteByteHandler(0, silvmil_write_byte);
SekSetWriteWordHandler(0, silvmil_write_word);
SekSetReadByteHandler(0, silvmil_read_byte);
SekSetReadWordHandler(0, silvmil_read_word);
SekMapHandler(1, 0x200000, 0x2005ff, SM_WRITE);
SekSetWriteByteHandler(1, silvmil_palette_write_byte);
SekSetWriteWordHandler(1, silvmil_palette_write_word);
SekClose();
ZetInit(0);
ZetOpen(0);
ZetMapArea(0x0000, 0xbfff, 0, DrvZ80ROM);
ZetMapArea(0x0000, 0xbfff, 2, DrvZ80ROM);
ZetMapArea(0xd000, 0xd7ff, 0, DrvZ80RAM);
ZetMapArea(0xd000, 0xd7ff, 1, DrvZ80RAM);
ZetMapArea(0xd000, 0xd7ff, 2, DrvZ80RAM);
ZetSetWriteHandler(silvmil_sound_write);
ZetSetReadHandler(silvmil_sound_read);
ZetMemEnd();
ZetClose();
BurnYM2151Init(3427190, 50.0);
BurnYM2151SetIrqHandler(&silvmilYM2151IrqHandler);
MSM6295Init(0, 1000000 / 132, 20.0, 1);
GenericTilesInit();
DrvDoReset();
return 0;
}
static INT32 DrvExit()
{
GenericTilesExit();
BurnYM2151Exit();
MSM6295Exit(0);
MSM6295ROM = NULL;
SekExit();
ZetExit();
BurnFree (AllMem);
return 0;
}
static void draw_layer(UINT8 *src, INT32 colbank, INT32 scrollx, INT32 scrolly, INT32 transp)
{
UINT16 *vram = (UINT16*)src;
for (INT32 offs = 0; offs < 64 * 32; offs++)
{
INT32 sx = (offs & 0x3f) << 4;
INT32 sy = (offs >> 6) << 4;
sx -= scrollx;
if (sx < -15) sx += 0x400;
sy -= scrolly;
if (sy < -15) sy += 0x200;
if (sy >= nScreenHeight || sx >= nScreenWidth) continue;
INT32 data = BURN_ENDIAN_SWAP_INT16(vram[(offs & 0x1f) + ((offs >> 6) << 5) + ((offs & 0x20) << 5)]);
INT32 code = (data & 0x3ff) + (tilebanks[(data & 0x0c00) >> 10] << 10);
INT32 color = (data >> 12) + colbank;
if (transp) {
Render16x16Tile_Mask_Clip(pTransDraw, code, sx, sy, color, 4, 0, 0, DrvGfxROM0);
} else {
Render16x16Tile_Clip(pTransDraw, code, sx, sy, color, 4, 0, DrvGfxROM0);
}
}
}
static void draw_sprites()
{
UINT16 *ram = (UINT16*)DrvSprRAM;
for (INT32 offs = 0;offs < 0x400;offs += 4)
{
INT32 sprite = BURN_ENDIAN_SWAP_INT16(ram[offs + 1]) & 0x3fff;
if (!sprite) continue;
INT32 y = BURN_ENDIAN_SWAP_INT16(ram[offs]);
if ((y & 0x1000) && (GetCurrentFrame() & 1)) continue; // flash
INT32 x = BURN_ENDIAN_SWAP_INT16(ram[offs + 2]);
INT32 color = (x >>9) & 0xf;
INT32 fx = y & 0x2000;
INT32 fy = y & 0x4000;
INT32 multi = (1 << ((y & 0x0600) >> 9)) - 1;
x &= 0x01ff;
y &= 0x01ff;
if (x >= 320) x -= 512;
if (y >= 256) y -= 512;
y = (240 - y) - 7;
x = (304 - x) - 5;
INT32 inc = -1;
if (!fy)
{
sprite += multi;
inc = 1;
}
while (multi >= 0)
{
if (fy) {
if (fx) {
Render16x16Tile_Mask_FlipXY_Clip(pTransDraw, sprite - multi * inc, x, y - 16 * multi, color, 4, 0, 0, DrvGfxROM1);
} else {
Render16x16Tile_Mask_FlipY_Clip(pTransDraw, sprite - multi * inc, x, y - 16 * multi, color, 4, 0, 0, DrvGfxROM1);
}
} else {
if (fx) {
Render16x16Tile_Mask_FlipX_Clip(pTransDraw, sprite - multi * inc, x, y - 16 * multi, color, 4, 0, 0, DrvGfxROM1);
} else {
Render16x16Tile_Mask_Clip(pTransDraw, sprite - multi * inc, x, y - 16 * multi, color, 4, 0, 0, DrvGfxROM1);
}
}
multi--;
}
}
}
static void DrvPaletteRecalc()
{
UINT8 r,g,b;
UINT16 *pal = (UINT16*)DrvPalRAM;
for (INT32 i = 0; i < 0x300; i++) {
r = (BURN_ENDIAN_SWAP_INT16(pal[i]) >> 10) & 0x1f;
g = (BURN_ENDIAN_SWAP_INT16(pal[i]) >> 5) & 0x1f;
b = (BURN_ENDIAN_SWAP_INT16(pal[i]) >> 0) & 0x1f;
r = (r << 3) | (r >> 2);
g = (g << 3) | (g >> 2);
b = (b << 3) | (b >> 2);
DrvPalette[i] = BurnHighCol(r, g, b, 0);
}
}
static INT32 DrvDraw()
{
if (DrvRecalc) {
DrvPaletteRecalc();
DrvRecalc = 0;
}
if (~nBurnLayer & 1) BurnTransferClear();
if ( nBurnLayer & 1) draw_layer(DrvBgRAM, 0x20, *bg_scroll_x, *bg_scroll_y, 0);
if ( nBurnLayer & 2) draw_layer(DrvFgRAM, 0x10, *fg_scroll_x, *fg_scroll_y, 1);
if ( nBurnLayer & 4) draw_sprites();
BurnTransferCopy(DrvPalette);
return 0;
}
static INT32 DrvFrame()
{
if (DrvReset) {
DrvDoReset();
}
SekNewFrame();
ZetNewFrame();
{
DrvInputs[0] = DrvInputs[1] = 0xffff;
for (INT32 i = 0; i < 16; i++) {
DrvInputs[0] ^= (DrvJoy1[i] & 1) << i;
DrvInputs[1] ^= (DrvJoy2[i] & 1) << i;
}
DrvInputs[2] = (DrvDips[1] << 8) | DrvDips[0];
}
INT32 nSegment;
INT32 nSoundBufferPos = 0;
INT32 nInterleave = 10;
INT32 nCyclesTotal[2] = { 14000000 / 60, 14000000 / 4 / 60 };
SekOpen(0);
ZetOpen(0);
for (INT32 i = 0; i < nInterleave; i++)
{
nSegment = nCyclesTotal[0] / nInterleave;
SekRun(nSegment);
ZetRun(nSegment / 4);
if (pBurnSoundOut) {
nSegment = nBurnSoundLen / nInterleave;
BurnYM2151Render(pBurnSoundOut + (nSoundBufferPos << 1), nSegment);
MSM6295Render(0, pBurnSoundOut + (nSoundBufferPos << 1), nSegment);
nSoundBufferPos += nSegment;
}
}
SekSetIRQLine(6, SEK_IRQSTATUS_AUTO);
if (pBurnSoundOut) {
nSegment = nBurnSoundLen - nSoundBufferPos;
if (nSegment > 0) {
BurnYM2151Render(pBurnSoundOut + (nSoundBufferPos << 1), nSegment);
MSM6295Render(0, pBurnSoundOut + (nSoundBufferPos << 1), nSegment);
}
}
ZetClose();
SekClose();
if (pBurnDraw) {
DrvDraw();
}
return 0;
}
static INT32 DrvScan(INT32 nAction,INT32 *pnMin)
{
struct BurnArea ba;
if (pnMin) {
*pnMin = 0x029698;
}
if (nAction & ACB_VOLATILE) {
memset(&ba, 0, sizeof(ba));
ba.Data = AllRam;
ba.nLen = RamEnd - AllRam;
ba.szName = "All Ram";
BurnAcb(&ba);
SekScan(nAction);
ZetScan(nAction);
BurnYM2151Scan(nAction);
MSM6295Scan(0, nAction);
}
return 0;
}
// Silver Millennium
static struct BurnRomInfo silvmilRomDesc[] = {
{ "d-13_u3.bin", 0x40000, 0x46106c59, 1 | BRF_PRG | BRF_ESS }, // 0 68k Code
{ "d-14_u2.bin", 0x40000, 0x65421eca, 1 | BRF_PRG | BRF_ESS }, // 1
{ "d-11_uz02.bin", 0x10000, 0xb41289e6, 2 | BRF_PRG | BRF_ESS }, // 2 Z80 Code
{ "d-12_uz1.bin", 0x40000, 0xa170d8a9, 3 | BRF_SND }, // 3 MSM6295 Samples
{ "d-16_u41.bin", 0x80000, 0xff5ea605, 4 | BRF_GRA }, // 4 Background Tiles
{ "d-15_u42.bin", 0x80000, 0x5f72d6cc, 4 | BRF_GRA }, // 5
{ "d-17_pat11.bin", 0x80000, 0x2facb3f1, 4 | BRF_GRA }, // 6
{ "d-20_pat01.bin", 0x80000, 0xcc4d3b49, 4 | BRF_GRA }, // 7
{ "d-18_pat12.bin", 0x80000, 0xa429b237, 4 | BRF_GRA }, // 8
{ "d-17_pat02.bin", 0x80000, 0xaddc5261, 4 | BRF_GRA }, // 9
{ "d-19_pat13.bin", 0x80000, 0xaf2507ce, 4 | BRF_GRA }, // 10
{ "d-18_pat03.bin", 0x80000, 0x36b9c407, 4 | BRF_GRA }, // 11
{ "d-17_u53.bin", 0x80000, 0x4d177bda, 5 | BRF_GRA }, // 12 Sprites
{ "d-18_u54.bin", 0x80000, 0x218c4471, 5 | BRF_GRA }, // 13
{ "d-19_u55.bin", 0x80000, 0x59507521, 5 | BRF_GRA }, // 14
{ "d-20_u56.bin", 0x80000, 0xe67c2c7d, 5 | BRF_GRA }, // 15
};
STD_ROM_PICK(silvmil)
STD_ROM_FN(silvmil)
struct BurnDriver BurnDrvSilvmil = {
"silvmil", NULL, NULL, NULL, "1995",
"Silver Millennium\0", NULL, "Para", "Miscellaneous",
NULL, NULL, NULL, NULL,
BDF_GAME_WORKING | BDF_ORIENTATION_VERTICAL, 2, HARDWARE_MISC_POST90S, GBF_VERSHOOT, 0,
NULL, silvmilRomInfo, silvmilRomName, NULL, NULL, SilvmilInputInfo, SilvmilDIPInfo,
DrvInit, DrvExit, DrvFrame, DrvDraw, DrvScan, &DrvRecalc, 0x300,
240, 320, 3, 4
};