mirror of
https://github.com/holub/mame
synced 2025-07-05 01:48:29 +03:00
new not working machine
-------------------------------------- unknown Chang Yu Electronic gambling game [TeamEurope]
This commit is contained in:
parent
e355b54262
commit
1ba8223dfa
@ -136,7 +136,6 @@ CPUS["DSPP"] = true
|
||||
CPUS["HPC"] = true
|
||||
--CPUS["RII"] = true
|
||||
--CPUS["BCP"] = true
|
||||
CPUS["F2MC16"] = true
|
||||
|
||||
--------------------------------------------------
|
||||
-- specify available sound cores
|
||||
@ -4619,6 +4618,7 @@ files {
|
||||
MAME_DIR .. "src/mame/machine/cdicdic.cpp",
|
||||
MAME_DIR .. "src/mame/machine/cdicdic.h",
|
||||
MAME_DIR .. "src/mame/drivers/chance32.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/changyu.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/chexx.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/chicago.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/chsuper.cpp",
|
||||
|
@ -211,6 +211,7 @@ champbwl.cpp
|
||||
chanbara.cpp
|
||||
chance32.cpp
|
||||
changela.cpp
|
||||
changyu.cpp
|
||||
cheekyms.cpp
|
||||
chexx.cpp
|
||||
chicago.cpp
|
||||
|
190
src/mame/drivers/changyu.cpp
Normal file
190
src/mame/drivers/changyu.cpp
Normal file
@ -0,0 +1,190 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:
|
||||
|
||||
/*
|
||||
main components:
|
||||
|
||||
main PCB (FAN-21 sticker):
|
||||
1 x R6502P
|
||||
1 x 12 MHz XTAL
|
||||
3 x 8-dip banks
|
||||
1 x XILINK XC2064-33 (originally covered by a black box)
|
||||
1 x HD46505RP-2
|
||||
1 x AY-3-8910A
|
||||
1 x UM5100
|
||||
|
||||
small sub PCB (HY-8902):
|
||||
1 x D8751H
|
||||
1 x 8 MHz XTAL
|
||||
1 x TIBPAL16L8
|
||||
*/
|
||||
|
||||
#include "emu.h"
|
||||
#include "emupal.h"
|
||||
#include "screen.h"
|
||||
#include "speaker.h"
|
||||
#include "cpu/m6502/m6502.h"
|
||||
#include "cpu/mcs51/mcs51.h"
|
||||
#include "sound/ay8910.h"
|
||||
#include "sound/hc55516.h"
|
||||
#include "video/mc6845.h"
|
||||
|
||||
class changyu_state : public driver_device
|
||||
{
|
||||
public:
|
||||
changyu_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag)
|
||||
{
|
||||
}
|
||||
|
||||
void changyu(machine_config &config);
|
||||
|
||||
private:
|
||||
|
||||
uint32_t screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
|
||||
|
||||
void io_map(address_map &map);
|
||||
void main_map(address_map &map);
|
||||
|
||||
virtual void machine_start() override;
|
||||
};
|
||||
|
||||
uint32_t changyu_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
void changyu_state::main_map(address_map &map)
|
||||
{
|
||||
map(0x8000, 0xffff).rom().region("maincpu", 0x0000);
|
||||
}
|
||||
|
||||
|
||||
static INPUT_PORTS_START( changyu )
|
||||
PORT_START("IN0")
|
||||
PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
|
||||
PORT_START("IN1")
|
||||
PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_UNKNOWN )
|
||||
|
||||
PORT_START("DSW0") // dips' listing available
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x01, 0x01, "SW0:1")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x02, 0x02, "SW0:2")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x04, 0x04, "SW0:3")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x08, 0x08, "SW0:4")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x10, 0x10, "SW0:5")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x20, 0x20, "SW0:6")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x40, 0x40, "SW0:7")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x80, 0x80, "SW0:8")
|
||||
|
||||
PORT_START("DSW1")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x01, 0x01, "SW1:1")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x02, 0x02, "SW1:2")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x04, 0x04, "SW1:3")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x08, 0x08, "SW1:4")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x10, 0x10, "SW1:5")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x20, 0x20, "SW1:6")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x40, 0x40, "SW1:7")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x80, 0x80, "SW1:8")
|
||||
|
||||
PORT_START("DSW2")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x01, 0x01, "SW2:1")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x02, 0x02, "SW2:2")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x04, 0x04, "SW2:3")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x08, 0x08, "SW2:4")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x10, 0x10, "SW2:5")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x20, 0x20, "SW2:6")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x40, 0x40, "SW2:7")
|
||||
PORT_DIPUNKNOWN_DIPLOC(0x80, 0x80, "SW2:8")
|
||||
INPUT_PORTS_END
|
||||
|
||||
|
||||
void changyu_state::machine_start()
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
|
||||
void changyu_state::changyu(machine_config &config)
|
||||
{
|
||||
/* basic machine hardware */
|
||||
m6502_device &maincpu(M6502(config, "maincpu", XTAL(12'000'000) / 6)); // R6502P, divisor not verified
|
||||
maincpu.set_addrmap(AS_PROGRAM, &changyu_state::main_map);
|
||||
|
||||
I8751(config, "mcu", XTAL(8'000'000));
|
||||
|
||||
// all wrong
|
||||
screen_device &screen(SCREEN(config, "screen", SCREEN_TYPE_RASTER));
|
||||
screen.set_refresh_hz(60);
|
||||
screen.set_vblank_time(ATTOSECONDS_IN_USEC(0));
|
||||
screen.set_size(64*8, 32*8);
|
||||
screen.set_visarea_full();
|
||||
screen.set_screen_update(FUNC(changyu_state::screen_update));
|
||||
screen.set_palette("palette");
|
||||
|
||||
PALETTE(config, "palette").set_entries(0x100);
|
||||
|
||||
mc6845_device &crtc(MC6845(config, "crtc", XTAL(12'000'000) / 6)); // HD46505RP-2, divisor not verified
|
||||
crtc.set_screen("screen");
|
||||
|
||||
/* sound hardware */
|
||||
SPEAKER(config, "mono").front_center();
|
||||
|
||||
AY8910(config, "ay", XTAL(12'000'000 / 6)).add_route(ALL_OUTPUTS, "mono", 1.00); // divisor not verified
|
||||
|
||||
HC55516(config, "voice", XTAL(12'000'000 / 6)).add_route(ALL_OUTPUTS, "mono", 1.00); // UM5100 is a HC55536 with ROM hook-up, divisor not verified
|
||||
}
|
||||
|
||||
|
||||
ROM_START( changyu )
|
||||
ROM_REGION(0x8000, "maincpu", 0)
|
||||
ROM_LOAD( "23h.u29", 0x00000, 0x8000, CRC(df0a7417) SHA1(9be2be664ed688dc9d5a1803b7f4d9bc2a0b1fae) ) // 27C256
|
||||
|
||||
ROM_REGION(0x1000, "mcu", 0)
|
||||
ROM_LOAD( "15a.sub", 0x00000, 0x1000, CRC(c7c24394) SHA1(e290f0b49f3bb536e1bc0cd06e04ed9e99f12e47) )
|
||||
|
||||
ROM_REGION(0x100000, "unsorted", 0)
|
||||
ROM_LOAD( "1.u1", 0x00000, 0x08000, CRC(8d60cb76) SHA1(f33e14549ceb6511509be16dd1c238512e6ae758) ) // 27C256
|
||||
ROM_LOAD( "2.u2", 0x08000, 0x08000, CRC(b9d78664) SHA1(763876f075f2b5b07e96b36b4e670dc466808f08) ) // 27C256
|
||||
ROM_LOAD( "3.u3", 0x10000, 0x08000, CRC(17cc6716) SHA1(df8af0fbe93b8f92219721a35772ef93bca7adb5) ) // 27C256
|
||||
ROM_LOAD( "4.u4", 0x18000, 0x08000, CRC(31b76c13) SHA1(c46da02aff8f57c0277e493c82e01970c0acd4fb) ) // 27C256
|
||||
|
||||
ROM_LOAD( "5.u21", 0x20000, 0x08000, CRC(25b23b14) SHA1(cb42442c09475941ffcb9940d130f9b2188ce79e) ) // 27C256
|
||||
ROM_LOAD( "6.u20", 0x28000, 0x08000, CRC(35bcfdef) SHA1(5c4173ddf55a3bf4731d819be267f738dfe9fd29) ) // 27C256
|
||||
ROM_LOAD( "7.u19", 0x30000, 0x08000, CRC(ed69d69d) SHA1(adbcea3045bec61aef9ee2ee8425f429bf5e0fc8) ) // 27C256
|
||||
|
||||
ROM_LOAD( "8.u42", 0x38000, 0x08000, CRC(4013b219) SHA1(735c64647595285fc0c79c617cd6833c473daa12) ) // 27C256
|
||||
|
||||
ROM_LOAD( "9a.u74", 0x40000, 0x10000, CRC(12f3fd7a) SHA1(e220694b8fa5cfc172bf23149fceaeeb6d0b6230) ) // 27C512
|
||||
ROM_LOAD( "10a.u61", 0x50000, 0x10000, CRC(8869968b) SHA1(fbab29436acde19d7d559160ef2394d43a6ebb87) ) // 27C512
|
||||
ROM_LOAD( "11a.u62", 0x60000, 0x10000, CRC(d05e6348) SHA1(5b8bd4c94631aed46cbf7cd4db749e4855d4516c) ) // 27C512
|
||||
|
||||
ROM_LOAD( "14.u70", 0x70000, 0x08000, CRC(cdfdfe11) SHA1(b170f9a6e2c77ce3ae01aabc8a963a11eb7fe74e) ) // under the sub board and near an empty socket (u77), program for a removed second CPU? or for the first?
|
||||
|
||||
// u9 and u63 not populated
|
||||
|
||||
ROM_REGION(0x220, "proms", 0)
|
||||
ROM_LOAD( "63s281n.u48", 0x000, 0x100, CRC(eb75e89b) SHA1(d3d6843c2cb6fb94e39d51de92205863745efdc1) )
|
||||
ROM_LOAD( "63s281n.u49", 0x100, 0x100, CRC(137e2d9c) SHA1(4e498e4fb73cad869789b902fc74d31ee3aa259f) )
|
||||
ROM_LOAD( "82s123.u44", 0x200, 0x020, CRC(cbd7e5d4) SHA1(c7d96ee7f6fb0129630fdd4b079c4ed1eabda7c5) )
|
||||
|
||||
ROM_REGION(0x104, "pals", 0)
|
||||
ROM_LOAD( "tibpal16l8-25cn.sub", 0x000, 0x104, NO_DUMP )
|
||||
ROM_END
|
||||
|
||||
|
||||
GAME( 1989, changyu, 0, changyu, changyu, changyu_state, empty_init, ROT0, "Chang Yu Electronic", "unknown Chang Yu Electronic gambling game", MACHINE_IS_SKELETON ) // year taken from start of maincpu ROM
|
@ -9817,6 +9817,9 @@ chance32 // (c) 19?? PAL Company
|
||||
@source:changela.cpp
|
||||
changela // ??? (c) 1983 Taito Corporation
|
||||
|
||||
@source:changyu.cpp
|
||||
changyu
|
||||
|
||||
@source:channelf.cpp
|
||||
channelf // Fairchild Channel F VES - 1976
|
||||
channlf2 // Fairchild Channel F II - 1978
|
||||
|
Loading…
Reference in New Issue
Block a user