From fd0f63de7216ccc7cb6a670db38fa27c68f16ea3 Mon Sep 17 00:00:00 2001 From: Angelo Salese Date: Sun, 14 Feb 2010 22:56:03 +0000 Subject: [PATCH] new working ----------- MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Uncle Poo [Team Europe, Dumping Union, René Single, David Haywood, Angelo Salese] --- .gitattributes | 1 + src/mame/drivers/poo.c | 379 +++++++++++++++++++++++++++++++++++++++++ src/mame/mame.mak | 1 + src/mame/mamedriv.c | 3 + 4 files changed, 384 insertions(+) create mode 100644 src/mame/drivers/poo.c diff --git a/.gitattributes b/.gitattributes index 38461eb7fd4..1253e4ab4f3 100644 --- a/.gitattributes +++ b/.gitattributes @@ -1978,6 +1978,7 @@ src/mame/drivers/pokechmp.c svneol=native#text/plain src/mame/drivers/polepos.c svneol=native#text/plain src/mame/drivers/policetr.c svneol=native#text/plain src/mame/drivers/polyplay.c svneol=native#text/plain +src/mame/drivers/poo.c svneol=native#text/plain src/mame/drivers/poolshrk.c svneol=native#text/plain src/mame/drivers/pooyan.c svneol=native#text/plain src/mame/drivers/popeye.c svneol=native#text/plain diff --git a/src/mame/drivers/poo.c b/src/mame/drivers/poo.c new file mode 100644 index 00000000000..8cd8459108b --- /dev/null +++ b/src/mame/drivers/poo.c @@ -0,0 +1,379 @@ +/******************************************************************************************* + +Uncle Poo (c) 1983 Diatec + +actually a bootleg / hack of something else? + +driver by David Haywood and Angelo Salese + +TODO: +-sound +-accurate game speed (controlled by an irq) +-title screen colors are wrong? But I can't see how I could fix it without breaking anything + else +-a bunch of unmapped read / writes +-writes to ROM regions + +*******************************************************************************************/ + +#include "emu.h" +#include "cpu/z80/z80.h" +#include "sound/ay8910.h" + +static UINT8 *poo_vram, *poo_scrolly, *poo_sprites; + +VIDEO_START(unclepoo) +{ + +} + +VIDEO_UPDATE(unclepoo) +{ + int y,x; + int count; + const gfx_element *gfx = screen->machine->gfx[0]; + + count = 0; + + for (x=0;x<32;x++) + { + for (y=0;y<32;y++) + { + int tile = poo_vram[count+0x000] | ((poo_vram[count+0x400] & 3) <<8); + int color = (poo_vram[count+0x400] & 0xf8) >> 3; + int scrolly = (poo_scrolly[x*4]); + + drawgfx_opaque(bitmap,cliprect,gfx,tile,color,0,0,x*8,256-(y*8)+scrolly); + drawgfx_opaque(bitmap,cliprect,gfx,tile,color,0,0,x*8,0-(y*8)+scrolly); + + count++; + } + } + + { + int spr_offs,x,y,col,fx,fy,i; + + for(i=0;i<0x80;i+=4) + { + spr_offs = poo_sprites[i+2] | (poo_sprites[i+3] & 3) << 8; + y = poo_sprites[i+0]+8; + x = poo_sprites[i+1]; + col = (poo_sprites[i+3] & 0xf8) >> 3; + fx = 0; + fy = 0; + + drawgfx_transpen(bitmap,cliprect,gfx,spr_offs,col,fx,fy,x,y,0); + } + } + + return 0; +} + +static READ8_HANDLER( unk_inp_r ) +{ + return 0x00;//mame_rand(space->machine); +} + +#if 0 + +static READ8_HANDLER( unk_inp2_r ) +{ + return 0xff; +} + +static READ8_HANDLER( unk_inp3_r ) +{ + return mame_rand(space->machine); +} +#endif + + +static WRITE8_HANDLER( unk_w ) +{ + +} + +/* soundlatch write */ +static WRITE8_HANDLER( test_w ) +{ + popmessage("%02x",data); + //soundlatch_w(space, 0, (data & 0xff)); + cputag_set_input_line(space->machine, "subcpu", 0, HOLD_LINE); +} + +static WRITE8_HANDLER( test2_w ) +{ + popmessage("%02x",data); + //soundlatch2_w(space, 0, (data & 0xff)); + cputag_set_input_line(space->machine, "subcpu", 0, HOLD_LINE); +} + +static ADDRESS_MAP_START( unclepoo_main_map, ADDRESS_SPACE_PROGRAM, 8 ) + AM_RANGE(0x0000, 0x7fff) AM_ROM + AM_RANGE(0x8000, 0x8fff) AM_RAM + AM_RANGE(0x9000, 0x97ff) AM_RAM + AM_RANGE(0xb000, 0xb07f) AM_RAM AM_BASE(&poo_sprites) + AM_RANGE(0xb080, 0xb0ff) AM_RAM AM_BASE(&poo_scrolly) + + AM_RANGE(0x9800, 0x9801) AM_READ(unk_inp_r) AM_WRITE( unk_w ) + + AM_RANGE(0xb400, 0xb400) AM_WRITE(test_w) + + AM_RANGE(0xb500, 0xb500) AM_READ_PORT("DSW1") + AM_RANGE(0xb501, 0xb501) AM_READ_PORT("DSW2") + AM_RANGE(0xb502, 0xb502) AM_READ_PORT("P1") + AM_RANGE(0xb503, 0xb503) AM_READ_PORT("P2") + AM_RANGE(0xb504, 0xb504) AM_READ_PORT("SYSTEM") + + AM_RANGE(0xb700, 0xb700) AM_WRITE(test2_w) + + AM_RANGE(0xb800, 0xbfff) AM_RAM AM_BASE(&poo_vram) + +ADDRESS_MAP_END + +static ADDRESS_MAP_START( unclepoo_main_portmap, ADDRESS_SPACE_IO, 8 ) + ADDRESS_MAP_GLOBAL_MASK(0xff) + +ADDRESS_MAP_END + +#if 0 +static WRITE8_HANDLER( mem_w ) +{ + +} +#endif + +static ADDRESS_MAP_START( unclepoo_sub_map, ADDRESS_SPACE_PROGRAM, 8 ) + AM_RANGE(0x0000, 0x0fff) AM_ROM + + AM_RANGE(0x4000, 0x43ff) AM_RAM + +// AM_RANGE(0x6000, 0x6000) AM_WRITE(soundlatch_clear_w) + +ADDRESS_MAP_END + + + +static ADDRESS_MAP_START( unclepoo_sub_portmap, ADDRESS_SPACE_IO, 8 ) + ADDRESS_MAP_GLOBAL_MASK(0xff) + + AM_RANGE(0x40, 0x40) AM_DEVREADWRITE("ay", ay8910_r, ay8910_data_w) + AM_RANGE(0x80, 0x80) AM_DEVWRITE("ay", ay8910_address_w) +ADDRESS_MAP_END + + +static INPUT_PORTS_START( unclepoo ) + PORT_START("P1") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) + PORT_BIT( 0xc0, IP_ACTIVE_HIGH, IPT_UNUSED ) + + PORT_START("P2") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(2) + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(2) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(2) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(2) + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(2) + PORT_BIT( 0xc0, IP_ACTIVE_HIGH, IPT_UNUSED ) + + PORT_START("SYSTEM") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_COIN1 ) + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_COIN2 ) + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_START1 ) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START2 ) + PORT_DIPNAME( 0x10, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x10, DEF_STR( On ) ) + PORT_DIPNAME( 0x20, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x20, DEF_STR( On ) ) + PORT_DIPNAME( 0x40, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x40, DEF_STR( On ) ) + PORT_DIPNAME( 0x80, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x80, DEF_STR( On ) ) + + PORT_START("DSW1") + PORT_DIPNAME( 0x01, 0x00, "IN0" ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x01, DEF_STR( On ) ) + PORT_DIPNAME( 0x02, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x02, DEF_STR( On ) ) + PORT_DIPNAME( 0x04, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x04, DEF_STR( On ) ) + PORT_DIPNAME( 0x08, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x08, DEF_STR( On ) ) + PORT_DIPNAME( 0x10, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x10, DEF_STR( On ) ) + PORT_DIPNAME( 0x20, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x20, DEF_STR( On ) ) + PORT_DIPNAME( 0x40, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x40, DEF_STR( On ) ) + PORT_DIPNAME( 0x80, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x80, DEF_STR( On ) ) + + PORT_START("DSW2") + PORT_DIPNAME( 0x01, 0x00, "IN0" ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x01, DEF_STR( On ) ) + PORT_DIPNAME( 0x02, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x02, DEF_STR( On ) ) + PORT_DIPNAME( 0x04, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x04, DEF_STR( On ) ) + PORT_DIPNAME( 0x08, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x08, DEF_STR( On ) ) + PORT_DIPNAME( 0x10, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x10, DEF_STR( On ) ) + PORT_DIPNAME( 0x20, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x20, DEF_STR( On ) ) + PORT_DIPNAME( 0x40, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x40, DEF_STR( On ) ) + PORT_DIPNAME( 0x80, 0x00, DEF_STR( Unknown ) ) + PORT_DIPSETTING( 0x00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x80, DEF_STR( On ) ) + + +INPUT_PORTS_END + +static const gfx_layout tiles8x8_layout = +{ + 8,8, + RGN_FRAC(1,3), + 3, + { RGN_FRAC(2,3), RGN_FRAC(1,3), RGN_FRAC(0,3) }, + { 0, 1,2,3,4,5,6,7 }, + { 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 }, + 8*8 +}; + +static GFXDECODE_START( unclepoo ) + GFXDECODE_ENTRY( "gfx", 0, tiles8x8_layout, 0, 0x20 ) +GFXDECODE_END + +static PALETTE_INIT( unclepoo ) +{ + int i,r,g,b,val; + int bit0,bit1,bit2; + + for (i = 0; i < 0x200; i++) + { + val = (color_prom[i+0x100]) | (color_prom[i+0x000]<<4); + + bit0 = 0; + bit1 = (val >> 6) & 0x01; + bit2 = (val >> 7) & 0x01; + b = 0x21 * bit0 + 0x47 * bit1 + 0x97 * bit2; + bit0 = (val >> 3) & 0x01; + bit1 = (val >> 4) & 0x01; + bit2 = (val >> 5) & 0x01; + g = 0x21 * bit0 + 0x47 * bit1 + 0x97 * bit2; + bit0 = (val >> 0) & 0x01; + bit1 = (val >> 1) & 0x01; + bit2 = (val >> 2) & 0x01; + r = 0x21 * bit0 + 0x47 * bit1 + 0x97 * bit2; + + palette_set_color(machine, i, MAKE_RGB(r, g, b)); + } +} + +/* ??? */ +#if 0 + +static READ8_HANDLER( test_r ) +{ + return 0xf6; +} + +/* soundlatch */ +static READ8_HANDLER( test2_r ) +{ + return 0x00; +} +#endif + +static const ay8910_interface ay8910_config = +{ + AY8910_LEGACY_OUTPUT, + AY8910_DEFAULT_LOADS, + DEVCB_MEMORY_HANDLER("subcpu", PROGRAM, unk_inp_r), + DEVCB_MEMORY_HANDLER("subcpu", PROGRAM, unk_inp_r), + DEVCB_NULL, + DEVCB_NULL +}; + +static MACHINE_DRIVER_START( unclepoo ) + /* basic machine hardware */ + MDRV_CPU_ADD("maincpu", Z80,8000000) /* ? MHz */ + MDRV_CPU_PROGRAM_MAP(unclepoo_main_map) + MDRV_CPU_IO_MAP(unclepoo_main_portmap) + MDRV_CPU_VBLANK_INT("screen", nmi_line_pulse) + MDRV_CPU_PERIODIC_INT(irq0_line_hold,120) // controls game speed + + MDRV_CPU_ADD("subcpu", Z80,8000000) /* ? MHz */ + MDRV_CPU_PROGRAM_MAP(unclepoo_sub_map) + MDRV_CPU_IO_MAP(unclepoo_sub_portmap) +// MDRV_CPU_VBLANK_INT("screen", irq0_line_hold) + + /* video hardware */ + MDRV_SCREEN_ADD("screen", RASTER) + MDRV_SCREEN_REFRESH_RATE(60) + MDRV_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0)) + MDRV_SCREEN_FORMAT(BITMAP_FORMAT_INDEXED16) + MDRV_SCREEN_SIZE(256, 256) + MDRV_SCREEN_VISIBLE_AREA(0, 256-1, 0, 256-1) + + MDRV_GFXDECODE(unclepoo) + MDRV_PALETTE_LENGTH(0x100) + MDRV_PALETTE_INIT(unclepoo) + + MDRV_VIDEO_START(unclepoo) + MDRV_VIDEO_UPDATE(unclepoo) + + MDRV_SPEAKER_STANDARD_MONO("mono") + MDRV_SOUND_ADD("ay", AY8910, 8000000/8) /* ? Mhz */ + MDRV_SOUND_CONFIG(ay8910_config) + MDRV_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50) +MACHINE_DRIVER_END + + + +ROM_START( unclepoo ) + ROM_REGION( 0x8000, "maincpu", 0 ) + ROM_LOAD( "01.f17", 0x00000, 0x2000, CRC(92fb238c) SHA1(e9476c5c1a0bf9e8c6c364ac022ed1d97ae66d2e) ) + ROM_LOAD( "02.f14", 0x02000, 0x2000, CRC(b99214ef) SHA1(c8e4af0efbc5ea543277b2764dc6f119aae477ca) ) + ROM_LOAD( "03.f11", 0x04000, 0x2000, CRC(a136af97) SHA1(cfa610bf357870053617fed8aef6bb30bd996422) ) + ROM_LOAD( "04.f09", 0x06000, 0x2000, CRC(c4bcd414) SHA1(df3125358530f5fb8d202bddcb0ef5e322fabb7b) ) + + ROM_REGION( 0x1000, "subcpu", 0 ) + ROM_LOAD( "08.c15", 0x00000, 0x1000, CRC(fd84106b) SHA1(891853d2b39850a981016108b74ca20337d2cdd8) ) + + ROM_REGION( 0x6000, "gfx", 0 ) + ROM_LOAD( "05.k04", 0x0000, 0x2000, CRC(64026934) SHA1(a5342335d02d34fa6ba2b29484ed71ecc96292f2) ) + ROM_LOAD( "06.j04", 0x2000, 0x2000, CRC(94b5f676) SHA1(32c27854726636c4ce03bb6a83b32d04ed6c42af) ) + ROM_LOAD( "07.h04", 0x4000, 0x2000, CRC(e2f73e99) SHA1(61cb09ff424ba63b892b4822e7ed916af73412f1) ) + + ROM_REGION( 0x200, "proms", 0 ) + ROM_LOAD( "diatec_h.bin", 0x000, 0x100, CRC(938601b1) SHA1(8213284989bebb5f7375878181840de8079dc1f3) ) + ROM_LOAD( "diatec_l.bin", 0x100, 0x100, CRC(b04d466a) SHA1(1438abeae76ef807ba34bd6d3e4c44f707dbde6e) ) +ROM_END + +GAME( 1983, unclepoo, 0, unclepoo, unclepoo, 0, ROT90, "Diatec", "Uncle Poo", GAME_NO_SOUND ) diff --git a/src/mame/mame.mak b/src/mame/mame.mak index 9ca3659ae9c..6e7ddaf7a2a 100644 --- a/src/mame/mame.mak +++ b/src/mame/mame.mak @@ -1606,6 +1606,7 @@ $(MAMEOBJ)/misc.a: \ $(DRIVERS)/pntnpuzl.o \ $(DRIVERS)/policetr.o $(VIDEO)/policetr.o \ $(DRIVERS)/polyplay.o $(AUDIO)/polyplay.o $(VIDEO)/polyplay.o \ + $(DRIVERS)/poo.o \ $(DRIVERS)/quakeat.o \ $(DRIVERS)/queen.o \ $(DRIVERS)/quizo.o \ diff --git a/src/mame/mamedriv.c b/src/mame/mamedriv.c index 6ff197cf878..96986373ed5 100644 --- a/src/mame/mamedriv.c +++ b/src/mame/mamedriv.c @@ -10007,4 +10007,7 @@ Other Sun games DRIVER( pinkiri8 ) DRIVER( neptunp2 ) + /* Diatec */ + DRIVER( unclepoo ) + #endif /* DRIVER_RECURSIVE */