mirror of
https://github.com/holub/mame
synced 2025-05-29 00:53:09 +03:00
288 lines
9.1 KiB
C
288 lines
9.1 KiB
C
/*******************************************************************************************
|
|
|
|
Fever Soccer (c) 2000 Seibu
|
|
|
|
A down-grade of the Seibu SPI Hardware with SH-2 as main cpu.
|
|
|
|
driver by Angelo Salese & Nicola Salmoria
|
|
|
|
TODO:
|
|
- Add eeprom emulation;
|
|
- Real Time Clock emulation (uses a JRC 6355E / NJU6355E)
|
|
|
|
============================================================================
|
|
|
|
Fever Soccer (JAMMA based Gambling Game)
|
|
|
|
Seibu Kaihatsu Inc.
|
|
|
|
PCB (c) 2000 SYS_SH2B + SYS_SH2B Rom Board
|
|
|
|
Very simple PCB contains:
|
|
|
|
CPU: Hatachi SH-2 (HD6417604F28)
|
|
Audio: OKI 6295 (rebaged as AD-65)
|
|
GFX CHIP: RISE11 (custom graphics chip with programmable decryption)
|
|
EEPROM: ST93C56A
|
|
OSC: 28.63636MHz
|
|
DSW: Single 4 switch
|
|
|
|
Other: Battery (CR2032)
|
|
Sigma XLINX 9572
|
|
JRC 6355E Serial Real Time Clock (connected to a 32.768KHz OSC)
|
|
|
|
RAM: BSI BS62LV1024SC-70 (x2)
|
|
EtronTech EM51256C-15J (x4)
|
|
|
|
|
|
PRG0.U0139 ST M27C1001 (PCB can handle up to 27C080)
|
|
PRG1.U0140 ST M27C1001
|
|
|
|
PCM.U0743 ST M27C4001
|
|
|
|
On the SYS_SH2B ROM BOARD:
|
|
OBJ1.U011 ST M27C160
|
|
OBJ2.U012 ST M27C160
|
|
OBJ3.U013 ST M27C160
|
|
|
|
Not used / unpopulated:
|
|
|
|
U0145 LH28F800SU (Alt program ROM near SH-2)
|
|
|
|
U0744 LH28F800SU (Alt PCM ROM near AD-65)
|
|
|
|
U0561 LH28F800SU OBJ1-1 (near ROM BOARD connector & RISE11 chip)
|
|
U0562 LH28F800SU OBJ2-1
|
|
U0563 LH28F800SU OBJ3-1
|
|
U0564 LH28F800SU OBJ4-1
|
|
|
|
*******************************************************************************************/
|
|
|
|
#include "driver.h"
|
|
#include "cpu/sh2/sh2.h"
|
|
#include "includes/seibuspi.h"
|
|
#include "sound/okim6295.h"
|
|
|
|
#define MASTER_CLOCK XTAL_28_63636MHz
|
|
|
|
VIDEO_START( feversoc )
|
|
{
|
|
|
|
}
|
|
|
|
VIDEO_UPDATE( feversoc )
|
|
{
|
|
int offs,spr_offs,colour,sx,sy,h,w,dx,dy;
|
|
|
|
bitmap_fill(bitmap, cliprect, screen->machine->pens[0]); //black pen
|
|
|
|
for(offs=(0x2000/4)-2;offs>-1;offs-=2)
|
|
{
|
|
spr_offs = (spriteram32[offs+0] & 0x3fff);
|
|
if(spr_offs == 0)
|
|
continue;
|
|
sy = (spriteram32[offs+1] & 0x01ff);
|
|
sx = (spriteram32[offs+1] & 0x01ff0000)>>16;
|
|
colour = (spriteram32[offs+0] & 0x003f0000)>>16;
|
|
w = ((spriteram32[offs+0] & 0x07000000)>>24)+1;
|
|
h = ((spriteram32[offs+0] & 0x70000000)>>28)+1;
|
|
|
|
if( sy & 0x100)
|
|
sy-=0x200;
|
|
|
|
for(dx=0;dx<w;dx++)
|
|
for(dy=0;dy<h;dy++)
|
|
drawgfx(bitmap,screen->machine->gfx[0],spr_offs++,colour,0,0,(sx+dx*16),(sy+dy*16),cliprect,TRANSPARENCY_PEN,0x3f);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static WRITE32_HANDLER( fs_paletteram_w )
|
|
{
|
|
int r,g,b;
|
|
COMBINE_DATA(&paletteram32[offset]);
|
|
|
|
r = ((paletteram32[offset] & 0x001f0000)>>16) << 3;
|
|
g = ((paletteram32[offset] & 0x03e00000)>>16) >> 2;
|
|
b = ((paletteram32[offset] & 0x7c000000)>>16) >> 7;
|
|
|
|
palette_set_color(space->machine,offset*2+0,MAKE_RGB(r,g,b));
|
|
|
|
r = (paletteram32[offset] & 0x001f) << 3;
|
|
g = (paletteram32[offset] & 0x03e0) >> 2;
|
|
b = (paletteram32[offset] & 0x7c00) >> 7;
|
|
|
|
palette_set_color(space->machine,offset*2+1,MAKE_RGB(r,g,b));
|
|
}
|
|
|
|
static READ32_HANDLER( in0_r )
|
|
{
|
|
static UINT16 x;
|
|
|
|
x^=0x40; //vblank? eeprom read bit?
|
|
return (input_port_read(space->machine, "IN0") | x) | (input_port_read(space->machine, "IN1")<<16);
|
|
}
|
|
|
|
static WRITE32_HANDLER( output_w )
|
|
{
|
|
if(ACCESSING_BITS_16_31)
|
|
{
|
|
/* probably eeprom stuff too */
|
|
coin_lockout_w(0,~data>>16 & 0x40);
|
|
coin_lockout_w(1,~data>>16 & 0x40);
|
|
coin_counter_w(0,data>>16 & 1);
|
|
//data>>16 & 2 coin out
|
|
coin_counter_w(1,data>>16 & 4);
|
|
//data>>16 & 8 coin hopper
|
|
okim6295_set_bank_base(devtag_get_device(space->machine, SOUND, "oki"), 0x40000 * (((data>>16) & 0x20)>>5));
|
|
}
|
|
if(ACCESSING_BITS_0_15)
|
|
{
|
|
/* -xxx xxxx lamps*/
|
|
coin_counter_w(2,data & 0x2000); //key in
|
|
//data & 0x4000 key out
|
|
}
|
|
}
|
|
|
|
static ADDRESS_MAP_START( feversoc_map, ADDRESS_SPACE_PROGRAM, 32 )
|
|
AM_RANGE(0x00000000, 0x0003ffff) AM_ROM
|
|
AM_RANGE(0x02000000, 0x0203dfff) AM_RAM //work ram
|
|
AM_RANGE(0x0203e000, 0x0203ffff) AM_RAM AM_BASE(&spriteram32)
|
|
AM_RANGE(0x06000000, 0x06000003) AM_WRITE(output_w)
|
|
AM_RANGE(0x06000004, 0x06000007) AM_WRITENOP //???
|
|
AM_RANGE(0x06000008, 0x0600000b) AM_READ(in0_r)
|
|
AM_RANGE(0x0600000c, 0x0600000f) AM_DEVREADWRITE8(SOUND, "oki", okim6295_r, okim6295_w, 0x00ff0000)
|
|
// AM_RANGE(0x06010000, 0x06017fff) AM_RAM //contains RISE11 keys and other related stuff.
|
|
AM_RANGE(0x06018000, 0x06019fff) AM_RAM_WRITE(fs_paletteram_w) AM_BASE(&paletteram32)
|
|
ADDRESS_MAP_END
|
|
|
|
static const gfx_layout spi_spritelayout =
|
|
{
|
|
16,16,
|
|
RGN_FRAC(1,3),
|
|
6,
|
|
{ RGN_FRAC(0,3)+0,RGN_FRAC(0,3)+8,RGN_FRAC(1,3)+0,RGN_FRAC(1,3)+8,RGN_FRAC(2,3)+0,RGN_FRAC(2,3)+8 },
|
|
{
|
|
7,6,5,4,3,2,1,0,23,22,21,20,19,18,17,16
|
|
},
|
|
{
|
|
0*32,1*32,2*32,3*32,4*32,5*32,6*32,7*32,8*32,9*32,10*32,11*32,12*32,13*32,14*32,15*32
|
|
},
|
|
16*32
|
|
};
|
|
|
|
|
|
static GFXDECODE_START( feversoc )
|
|
GFXDECODE_ENTRY( "gfx1", 0, spi_spritelayout, 0, 0x40 )
|
|
GFXDECODE_END
|
|
|
|
static INPUT_PORTS_START( feversoc )
|
|
PORT_START("IN0")
|
|
PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_START1 )
|
|
PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_COIN2 )
|
|
PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_SERVICE )
|
|
PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_SERVICE1 )
|
|
PORT_BIT( 0x0010, IP_ACTIVE_LOW, IPT_COIN1 )
|
|
PORT_DIPNAME( 0x20, 0x20, DEF_STR( Unknown ) ) //hopper i/o
|
|
PORT_DIPSETTING( 0x20, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
|
// PORT_DIPNAME( 0x40, 0x40, DEF_STR( Unknown ) ) //vblank/eeprom read bit?
|
|
// PORT_DIPSETTING( 0x40, DEF_STR( Off ) )
|
|
// PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
|
PORT_BIT( 0x0080, IP_ACTIVE_LOW, IPT_UNUSED ) //PORT_NAME("Slottle") PORT_CODE(KEYCODE_Z)
|
|
PORT_DIPNAME( 0x0100, 0x0100, "DIP 1-1" )
|
|
PORT_DIPSETTING( 0x0100, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x0200, 0x0200, "DIP 1-2" )
|
|
PORT_DIPSETTING( 0x0200, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x0400, 0x0400, "DIP 1-3" )
|
|
PORT_DIPSETTING( 0x0400, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x0800, 0x0800, "DIP 1-4" )
|
|
PORT_DIPSETTING( 0x0800, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x1000, 0x1000, "DIP 1-5" )
|
|
PORT_DIPSETTING( 0x1000, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x2000, 0x2000, "DIP 1-6" )
|
|
PORT_DIPSETTING( 0x2000, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x4000, 0x4000, "DIP 1-7" )
|
|
PORT_DIPSETTING( 0x4000, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_DIPNAME( 0x8000, 0x8000, "DIP 1-8" )
|
|
PORT_DIPSETTING( 0x8000, DEF_STR( Off ) )
|
|
PORT_DIPSETTING( 0x0000, DEF_STR( On ) )
|
|
PORT_START("IN1")
|
|
PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_CODE(KEYCODE_Z)
|
|
PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_BUTTON2 ) PORT_CODE(KEYCODE_X)
|
|
PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_BUTTON3 ) PORT_CODE(KEYCODE_C)
|
|
PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_BUTTON4 ) PORT_CODE(KEYCODE_V)
|
|
PORT_BIT( 0x0010, IP_ACTIVE_LOW, IPT_BUTTON5 ) PORT_CODE(KEYCODE_B)
|
|
PORT_BIT( 0x0020, IP_ACTIVE_LOW, IPT_BUTTON6 ) PORT_CODE(KEYCODE_N)
|
|
PORT_BIT( 0x0040, IP_ACTIVE_LOW, IPT_BUTTON7 ) PORT_CODE(KEYCODE_M)
|
|
PORT_BIT( 0x0080, IP_ACTIVE_LOW, IPT_SERVICE2 ) PORT_NAME("Reset")
|
|
PORT_BIT( 0xff00, IP_ACTIVE_LOW, IPT_UNUSED )
|
|
INPUT_PORTS_END
|
|
|
|
static INTERRUPT_GEN( feversoc_irq )
|
|
{
|
|
cpu_set_input_line(device->machine->cpu[0], 8, HOLD_LINE );
|
|
}
|
|
|
|
static MACHINE_DRIVER_START( feversoc )
|
|
|
|
/* basic machine hardware */
|
|
MDRV_CPU_ADD("main",SH2,MASTER_CLOCK)
|
|
MDRV_CPU_PROGRAM_MAP(feversoc_map,0)
|
|
MDRV_CPU_VBLANK_INT("main",feversoc_irq)
|
|
|
|
/* video hardware */
|
|
MDRV_SCREEN_ADD("main", RASTER)
|
|
MDRV_SCREEN_REFRESH_RATE(60)
|
|
MDRV_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
|
|
MDRV_SCREEN_FORMAT(BITMAP_FORMAT_INDEXED16)
|
|
MDRV_SCREEN_SIZE(40*8, 32*8)
|
|
MDRV_SCREEN_VISIBLE_AREA(0*8, 40*8-1, 0*8, 30*8-1) //dynamic resolution?
|
|
MDRV_GFXDECODE(feversoc)
|
|
MDRV_PALETTE_LENGTH(0x1000)
|
|
|
|
MDRV_VIDEO_START(feversoc)
|
|
MDRV_VIDEO_UPDATE(feversoc)
|
|
|
|
/* sound hardware */
|
|
MDRV_SPEAKER_STANDARD_MONO("mono")
|
|
MDRV_SOUND_ADD("oki", OKIM6295, MASTER_CLOCK/16) //pin 7 & frequency not verified (clock should be 28,6363 / n)
|
|
MDRV_SOUND_CONFIG(okim6295_interface_pin7low)
|
|
MDRV_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.6)
|
|
MACHINE_DRIVER_END
|
|
|
|
/***************************************************************************
|
|
|
|
Game driver(s)
|
|
|
|
***************************************************************************/
|
|
|
|
ROM_START( feversoc )
|
|
ROM_REGION32_BE( 0x40000, "main", 0 )
|
|
ROM_LOAD16_BYTE( "prog0.u0139", 0x00001, 0x20000, CRC(fa699503) SHA1(96a834d4f7d5b764aa51db745afc2cd9a7c9783d) )
|
|
ROM_LOAD16_BYTE( "prog1.u0140", 0x00000, 0x20000, CRC(fd4d7943) SHA1(d7d782f878656bc79d70589f9df2cbcfff0adb5e) )
|
|
|
|
ROM_REGION( 0x600000, "gfx1", 0) /* text */
|
|
ROM_LOAD("obj1.u011", 0x000000, 0x200000, CRC(d8c8dde7) SHA1(3ef815fb1e21a0bd907ee835bc7a32d80f6a9d28) )
|
|
ROM_LOAD("obj2.u012", 0x200000, 0x200000, CRC(8e93bfda) SHA1(3b4740cefb164efc320fb69f58e8800d2646fea6) )
|
|
ROM_LOAD("obj3.u013", 0x400000, 0x200000, CRC(8c8c6e8b) SHA1(bed4990d6eebb7aefa200ad2bed9b7e71e6bd064) )
|
|
|
|
ROM_REGION( 0x80000, "oki", 0 )
|
|
ROM_LOAD( "pcm.u0743", 0x00000, 0x80000, CRC(20b0c0e3) SHA1(dcf2f620a8fe695688057dbaf5c431a32a832440) )
|
|
ROM_END
|
|
|
|
static DRIVER_INIT( feversoc )
|
|
{
|
|
seibuspi_rise11_sprite_decrypt_feversoc(memory_region(machine, "gfx1"), 0x200000);
|
|
}
|
|
|
|
GAME( 2004, feversoc, 0, feversoc, feversoc, feversoc, ROT0, "Seibu", "Fever Soccer", 0 )
|