mirror of
https://github.com/holub/mame
synced 2025-05-29 17:13:05 +03:00
Dumped bios for ALG 3DO based arcade games [Mr Invader]
This commit is contained in:
parent
43d4b6ba36
commit
e1cd796465
@ -2,7 +2,7 @@
|
||||
// copyright-holders:Angelo Salese, Wilbert Pol
|
||||
/***************************************************************************
|
||||
|
||||
3do.c
|
||||
3do.cpp
|
||||
|
||||
Driver file to handle emulation of the 3DO systems
|
||||
|
||||
@ -99,7 +99,6 @@ Part list of Goldstar 3DO Interactive Multiplayer
|
||||
#include "cpu/arm/arm.h"
|
||||
#include "cpu/arm7/arm7.h"
|
||||
#include "imagedev/chd_cd.h"
|
||||
#include "screen.h"
|
||||
|
||||
|
||||
#define X2_CLOCK_PAL 59000000
|
||||
@ -107,17 +106,17 @@ Part list of Goldstar 3DO Interactive Multiplayer
|
||||
#define X601_CLOCK XTAL(16'934'400)
|
||||
|
||||
|
||||
void _3do_state::_3do_mem(address_map &map)
|
||||
void _3do_state::main_mem(address_map &map)
|
||||
{
|
||||
map(0x00000000, 0x001FFFFF).bankrw("bank1").share("dram"); /* DRAM */
|
||||
map(0x00200000, 0x003FFFFF).ram().share("vram"); /* VRAM */
|
||||
map(0x03000000, 0x030FFFFF).bankr("bank2"); /* BIOS */
|
||||
map(0x00000000, 0x001FFFFF).bankrw(m_bank1).share(m_dram); /* DRAM */
|
||||
map(0x00200000, 0x003FFFFF).ram().share(m_vram); /* VRAM */
|
||||
map(0x03000000, 0x030FFFFF).bankr(m_bank2); /* BIOS */
|
||||
map(0x03100000, 0x0313FFFF).ram(); /* Brooktree? */
|
||||
map(0x03140000, 0x0315FFFF).rw(FUNC(_3do_state::_3do_nvarea_r), FUNC(_3do_state::_3do_nvarea_w)).umask32(0x000000ff); /* NVRAM */
|
||||
map(0x03180000, 0x031BFFFF).rw(FUNC(_3do_state::_3do_slow2_r), FUNC(_3do_state::_3do_slow2_w)); /* Slow bus - additional expansion */
|
||||
map(0x03200000, 0x0320FFFF).rw(FUNC(_3do_state::_3do_svf_r), FUNC(_3do_state::_3do_svf_w)); /* special vram access1 */
|
||||
map(0x03300000, 0x033FFFFF).rw(FUNC(_3do_state::_3do_madam_r), FUNC(_3do_state::_3do_madam_w)); /* address decoder */
|
||||
map(0x03400000, 0x034FFFFF).rw(FUNC(_3do_state::_3do_clio_r), FUNC(_3do_state::_3do_clio_w)); /* io controller */
|
||||
map(0x03140000, 0x0315FFFF).rw(FUNC(_3do_state::nvarea_r), FUNC(_3do_state::nvarea_w)).umask32(0x000000ff); /* NVRAM */
|
||||
map(0x03180000, 0x031BFFFF).rw(FUNC(_3do_state::slow2_r), FUNC(_3do_state::slow2_w)); /* Slow bus - additional expansion */
|
||||
map(0x03200000, 0x0320FFFF).rw(FUNC(_3do_state::svf_r), FUNC(_3do_state::svf_w)); /* special vram access1 */
|
||||
map(0x03300000, 0x033FFFFF).rw(FUNC(_3do_state::madam_r), FUNC(_3do_state::madam_w)); /* address decoder */
|
||||
map(0x03400000, 0x034FFFFF).rw(FUNC(_3do_state::clio_r), FUNC(_3do_state::clio_w)); /* io controller */
|
||||
}
|
||||
|
||||
|
||||
@ -142,9 +141,9 @@ void _3do_state::machine_start()
|
||||
m_bank1->configure_entry(0, m_dram);
|
||||
m_bank1->configure_entry(1, memregion("user1")->base());
|
||||
|
||||
m_3do_slow2_init();
|
||||
m_3do_madam_init();
|
||||
m_3do_clio_init( downcast<screen_device *>(machine().device("screen")));
|
||||
m_slow2_init();
|
||||
m_madam_init();
|
||||
m_clio_init();
|
||||
}
|
||||
|
||||
void _3do_state::machine_reset()
|
||||
@ -158,16 +157,16 @@ void _3do_state::machine_reset()
|
||||
MACHINE_CONFIG_START(_3do_state::_3do)
|
||||
|
||||
/* Basic machine hardware */
|
||||
MCFG_DEVICE_ADD( "maincpu", ARM7_BE, XTAL(50'000'000)/4 )
|
||||
MCFG_DEVICE_PROGRAM_MAP( _3do_mem)
|
||||
MCFG_DEVICE_ADD( m_maincpu, ARM7_BE, XTAL(50'000'000)/4 )
|
||||
MCFG_DEVICE_PROGRAM_MAP( main_mem)
|
||||
|
||||
MCFG_NVRAM_ADD_1FILL("nvram")
|
||||
MCFG_NVRAM_ADD_1FILL(m_nvram)
|
||||
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("timer_x16", _3do_state, timer_x16_cb, attotime::from_hz(12000)) // TODO: timing
|
||||
|
||||
MCFG_SCREEN_ADD("screen", RASTER)
|
||||
MCFG_SCREEN_ADD(m_screen, RASTER)
|
||||
MCFG_SCREEN_RAW_PARAMS( X2_CLOCK_NTSC / 2, 1592, 254, 1534, 263, 22, 262 )
|
||||
MCFG_SCREEN_UPDATE_DRIVER(_3do_state, screen_update__3do)
|
||||
MCFG_SCREEN_UPDATE_DRIVER(_3do_state, screen_update)
|
||||
|
||||
MCFG_CDROM_ADD("cdrom")
|
||||
MACHINE_CONFIG_END
|
||||
@ -176,16 +175,16 @@ MACHINE_CONFIG_END
|
||||
MACHINE_CONFIG_START(_3do_state::_3do_pal)
|
||||
|
||||
/* Basic machine hardware */
|
||||
MCFG_DEVICE_ADD("maincpu", ARM7_BE, XTAL(50'000'000)/4 )
|
||||
MCFG_DEVICE_PROGRAM_MAP( _3do_mem)
|
||||
MCFG_DEVICE_ADD(m_maincpu, ARM7_BE, XTAL(50'000'000)/4 )
|
||||
MCFG_DEVICE_PROGRAM_MAP( main_mem)
|
||||
|
||||
MCFG_NVRAM_ADD_1FILL("nvram")
|
||||
MCFG_NVRAM_ADD_1FILL(m_nvram)
|
||||
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("timer_x16", _3do_state, timer_x16_cb, attotime::from_hz(12000)) // TODO: timing
|
||||
|
||||
MCFG_SCREEN_ADD("screen", RASTER)
|
||||
MCFG_SCREEN_ADD(m_screen, RASTER)
|
||||
MCFG_SCREEN_RAW_PARAMS( X2_CLOCK_PAL / 2, 1592, 254, 1534, 263, 22, 262 ) // TODO: proper params
|
||||
MCFG_SCREEN_UPDATE_DRIVER(_3do_state, screen_update__3do)
|
||||
MCFG_SCREEN_UPDATE_DRIVER(_3do_state, screen_update)
|
||||
|
||||
MCFG_CDROM_ADD("cdrom")
|
||||
MACHINE_CONFIG_END
|
||||
@ -241,6 +240,14 @@ ROM_START(orbatak)
|
||||
DISK_IMAGE_READONLY( "orbatak", 0, SHA1(25cb3b889cf09dbe5faf2b0ca4aae5e03453da00) )
|
||||
ROM_END
|
||||
|
||||
ROM_START(md23do)
|
||||
ROM_REGION32_BE( 0x200000, "user1", 0 )
|
||||
ROM_LOAD( "soat_rom2.bin", 0x000000, 0x80000, CRC(b832da9a) SHA1(520d3d1b5897800af47f92efd2444a26b7a7dead) ) // TC544000AF-150, 1xxxxxxxxxxxxxxxxxx = 0xFF
|
||||
|
||||
DISK_REGION( "cdrom" )
|
||||
DISK_IMAGE_READONLY( "md23do", 0, NO_DUMP )
|
||||
ROM_END
|
||||
|
||||
/***************************************************************************
|
||||
|
||||
Game driver(s)
|
||||
@ -254,3 +261,5 @@ CONS( 1991, 3do_pal, 3do, 0, _3do_pal, 3do, _3do_state, empty_init,
|
||||
/* YEAR NAME PARENT MACHINE INPUT STATE INIT MONITOR COMPANY FULLNAME FLAGS */
|
||||
GAME( 1991, 3dobios, 0, _3do, 3do, _3do_state, empty_init, ROT0, "The 3DO Company", "3DO Bios", MACHINE_NOT_WORKING | MACHINE_NO_SOUND | MACHINE_IS_BIOS_ROOT )
|
||||
GAME( 199?, orbatak, 3dobios, _3do, 3do, _3do_state, empty_init, ROT0, "<unknown>", "Orbatak (prototype)", MACHINE_NOT_WORKING | MACHINE_NO_SOUND )
|
||||
GAME( 199?, md23do, 0, _3do, 3do, _3do_state, empty_init, ROT0, "American Laser Games", "Mad Dog II: The Lost Gold (3DO hardware)", MACHINE_NOT_WORKING | MACHINE_NO_SOUND )
|
||||
|
||||
|
@ -11,9 +11,32 @@
|
||||
|
||||
#include "machine/nvram.h"
|
||||
#include "machine/timer.h"
|
||||
#include "screen.h"
|
||||
|
||||
|
||||
struct SLOW2 {
|
||||
class _3do_state : public driver_device
|
||||
{
|
||||
public:
|
||||
_3do_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_dram(*this, "dram"),
|
||||
m_vram(*this, "vram"),
|
||||
m_nvram(*this, "nvram"),
|
||||
m_screen(*this, "screen"),
|
||||
m_bank1(*this, "bank1"),
|
||||
m_bank2(*this, "bank2") { }
|
||||
|
||||
void _3do(machine_config &config);
|
||||
void _3do_pal(machine_config &config);
|
||||
|
||||
protected:
|
||||
virtual void machine_start() override;
|
||||
virtual void machine_reset() override;
|
||||
virtual void video_start() override;
|
||||
|
||||
private:
|
||||
struct SLOW2 {
|
||||
/* 03180000 - 0318003f - configuration group */
|
||||
/* 03180040 - 0318007f - diagnostic UART */
|
||||
|
||||
@ -21,10 +44,10 @@ struct SLOW2 {
|
||||
uint8_t cg_w_count;
|
||||
uint32_t cg_input;
|
||||
uint32_t cg_output;
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
struct MADAM {
|
||||
struct MADAM {
|
||||
uint32_t revision; /* 03300000 */
|
||||
uint32_t msysbits; /* 03300004 */
|
||||
uint32_t mctl; /* 03300008 */
|
||||
@ -57,10 +80,10 @@ struct MADAM {
|
||||
uint32_t mult[40]; /* 03300600-0330069c */
|
||||
uint32_t mult_control; /* 033007f0-033007f4 */
|
||||
uint32_t mult_status; /* 033007f8 */
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
struct CLIO {
|
||||
struct CLIO {
|
||||
screen_device *screen;
|
||||
|
||||
uint32_t revision; /* 03400000 */
|
||||
@ -123,36 +146,28 @@ struct CLIO {
|
||||
uint32_t uncle_soft_rev; /* 0340c004 */
|
||||
uint32_t uncle_addr; /* 0340c008 */
|
||||
uint32_t uncle_rom; /* 0340c00c */
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
struct SVF {
|
||||
struct SVF {
|
||||
uint32_t sport[512];
|
||||
uint32_t color;
|
||||
};
|
||||
};
|
||||
|
||||
struct DSPP {
|
||||
struct DSPP {
|
||||
std::unique_ptr<uint16_t[]> N;
|
||||
std::unique_ptr<uint16_t[]> EI;
|
||||
std::unique_ptr<uint16_t[]> EO;
|
||||
};
|
||||
|
||||
class _3do_state : public driver_device
|
||||
{
|
||||
public:
|
||||
_3do_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_dram(*this, "dram"),
|
||||
m_vram(*this, "vram"),
|
||||
m_nvram(*this, "nvram"),
|
||||
m_bank1(*this, "bank1"),
|
||||
m_bank2(*this, "bank2") { }
|
||||
};
|
||||
|
||||
required_device<cpu_device> m_maincpu;
|
||||
required_shared_ptr<uint32_t> m_dram;
|
||||
required_shared_ptr<uint32_t> m_vram;
|
||||
required_device<nvram_device> m_nvram;
|
||||
required_device<screen_device> m_screen;
|
||||
required_memory_bank m_bank1;
|
||||
required_memory_bank m_bank2;
|
||||
|
||||
SLOW2 m_slow2;
|
||||
MADAM m_madam;
|
||||
CLIO m_clio;
|
||||
@ -161,41 +176,28 @@ public:
|
||||
uint8_t m_nvmem[0x8000];
|
||||
|
||||
// uint8_t m_video_bits[512];
|
||||
DECLARE_READ8_MEMBER(_3do_nvarea_r);
|
||||
DECLARE_WRITE8_MEMBER(_3do_nvarea_w);
|
||||
DECLARE_READ32_MEMBER(_3do_slow2_r);
|
||||
DECLARE_WRITE32_MEMBER(_3do_slow2_w);
|
||||
DECLARE_READ32_MEMBER(_3do_svf_r);
|
||||
DECLARE_WRITE32_MEMBER(_3do_svf_w);
|
||||
DECLARE_READ32_MEMBER(_3do_madam_r);
|
||||
DECLARE_WRITE32_MEMBER(_3do_madam_w);
|
||||
DECLARE_READ32_MEMBER(_3do_clio_r);
|
||||
DECLARE_WRITE32_MEMBER(_3do_clio_w);
|
||||
uint32_t screen_update__3do(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect);
|
||||
DECLARE_READ8_MEMBER(nvarea_r);
|
||||
DECLARE_WRITE8_MEMBER(nvarea_w);
|
||||
DECLARE_READ32_MEMBER(slow2_r);
|
||||
DECLARE_WRITE32_MEMBER(slow2_w);
|
||||
DECLARE_READ32_MEMBER(svf_r);
|
||||
DECLARE_WRITE32_MEMBER(svf_w);
|
||||
DECLARE_READ32_MEMBER(madam_r);
|
||||
DECLARE_WRITE32_MEMBER(madam_w);
|
||||
DECLARE_READ32_MEMBER(clio_r);
|
||||
DECLARE_WRITE32_MEMBER(clio_w);
|
||||
uint32_t screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect);
|
||||
|
||||
TIMER_DEVICE_CALLBACK_MEMBER( timer_x16_cb );
|
||||
|
||||
void _3do(machine_config &config);
|
||||
void _3do_pal(machine_config &config);
|
||||
void _3do_mem(address_map &map);
|
||||
void main_mem(address_map &map);
|
||||
|
||||
protected:
|
||||
virtual void machine_start() override;
|
||||
virtual void machine_reset() override;
|
||||
virtual void video_start() override;
|
||||
void m_slow2_init( void );
|
||||
void m_madam_init( void );
|
||||
void m_clio_init( void );
|
||||
|
||||
required_memory_bank m_bank1;
|
||||
required_memory_bank m_bank2;
|
||||
|
||||
private:
|
||||
void m_3do_slow2_init( void );
|
||||
void m_3do_madam_init( void );
|
||||
void m_3do_clio_init( screen_device *screen );
|
||||
|
||||
void m_3do_request_fiq(uint32_t irq_req, uint8_t type);
|
||||
void m_request_fiq(uint32_t irq_req, uint8_t type);
|
||||
};
|
||||
|
||||
/*----------- defined in machine/3do.c -----------*/
|
||||
|
||||
|
||||
#endif // MAME_INCLUDES_3DO_H
|
||||
|
@ -106,7 +106,7 @@ IRQ1
|
||||
0x00000001 DMA Player bus
|
||||
|
||||
*/
|
||||
void _3do_state::m_3do_request_fiq(uint32_t irq_req, uint8_t type)
|
||||
void _3do_state::m_request_fiq(uint32_t irq_req, uint8_t type)
|
||||
{
|
||||
if(type)
|
||||
m_clio.irq1 |= irq_req;
|
||||
@ -153,7 +153,7 @@ TIMER_DEVICE_CALLBACK_MEMBER( _3do_state::timer_x16_cb )
|
||||
if(m_clio.timer_count[i] == 0xffffffff) // timer hit
|
||||
{
|
||||
if(i & 1) // odd timer irq fires
|
||||
m_3do_request_fiq(8 << (7-(i >> 1)),0);
|
||||
m_request_fiq(8 << (7-(i >> 1)),0);
|
||||
|
||||
carry_val = 1;
|
||||
|
||||
@ -170,8 +170,8 @@ TIMER_DEVICE_CALLBACK_MEMBER( _3do_state::timer_x16_cb )
|
||||
}
|
||||
}
|
||||
|
||||
READ8_MEMBER(_3do_state::_3do_nvarea_r) { return m_nvmem[offset]; }
|
||||
WRITE8_MEMBER(_3do_state::_3do_nvarea_w) { m_nvmem[offset] = data; }
|
||||
READ8_MEMBER(_3do_state::nvarea_r) { return m_nvmem[offset]; }
|
||||
WRITE8_MEMBER(_3do_state::nvarea_w) { m_nvmem[offset] = data; }
|
||||
|
||||
|
||||
|
||||
@ -200,7 +200,7 @@ WRITE8_MEMBER(_3do_state::_3do_nvarea_w) { m_nvmem[offset] = data; }
|
||||
3022630
|
||||
*/
|
||||
|
||||
READ32_MEMBER(_3do_state::_3do_slow2_r){
|
||||
READ32_MEMBER(_3do_state::slow2_r){
|
||||
uint32_t data = 0;
|
||||
|
||||
logerror( "%08X: UNK_318 read offset = %08X\n", m_maincpu->pc(), offset );
|
||||
@ -215,7 +215,7 @@ READ32_MEMBER(_3do_state::_3do_slow2_r){
|
||||
}
|
||||
|
||||
|
||||
WRITE32_MEMBER(_3do_state::_3do_slow2_w)
|
||||
WRITE32_MEMBER(_3do_state::slow2_w)
|
||||
{
|
||||
logerror( "%08X: UNK_318 write offset = %08X, data = %08X, mask = %08X\n", m_maincpu->pc(), offset, data, mem_mask );
|
||||
|
||||
@ -237,7 +237,7 @@ WRITE32_MEMBER(_3do_state::_3do_slow2_w)
|
||||
|
||||
|
||||
|
||||
READ32_MEMBER(_3do_state::_3do_svf_r)
|
||||
READ32_MEMBER(_3do_state::svf_r)
|
||||
{
|
||||
uint32_t addr = ( offset & ( 0x07fc / 4 ) ) << 9;
|
||||
uint32_t *p = m_vram + addr;
|
||||
@ -262,7 +262,7 @@ READ32_MEMBER(_3do_state::_3do_svf_r)
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE32_MEMBER(_3do_state::_3do_svf_w)
|
||||
WRITE32_MEMBER(_3do_state::svf_w)
|
||||
{
|
||||
uint32_t addr = ( offset & ( 0x07fc / 4 ) ) << 9;
|
||||
uint32_t *p = m_vram + addr;
|
||||
@ -302,7 +302,7 @@ WRITE32_MEMBER(_3do_state::_3do_svf_w)
|
||||
|
||||
|
||||
|
||||
READ32_MEMBER(_3do_state::_3do_madam_r){
|
||||
READ32_MEMBER(_3do_state::madam_r){
|
||||
logerror( "%08X: MADAM read offset = %08X\n", m_maincpu->pc(), offset*4 );
|
||||
|
||||
switch( offset ) {
|
||||
@ -461,7 +461,7 @@ READ32_MEMBER(_3do_state::_3do_madam_r){
|
||||
}
|
||||
|
||||
|
||||
WRITE32_MEMBER(_3do_state::_3do_madam_w){
|
||||
WRITE32_MEMBER(_3do_state::madam_w){
|
||||
if(offset == 0)
|
||||
{
|
||||
if(data == 0x0a)
|
||||
@ -655,7 +655,7 @@ WRITE32_MEMBER(_3do_state::_3do_madam_w){
|
||||
|
||||
|
||||
|
||||
READ32_MEMBER(_3do_state::_3do_clio_r)
|
||||
READ32_MEMBER(_3do_state::clio_r)
|
||||
{
|
||||
if (!machine().side_effects_disabled())
|
||||
{
|
||||
@ -782,7 +782,7 @@ READ32_MEMBER(_3do_state::_3do_clio_r)
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE32_MEMBER(_3do_state::_3do_clio_w)
|
||||
WRITE32_MEMBER(_3do_state::clio_w)
|
||||
{
|
||||
if(offset != 0x200/4 && offset != 0x40/4 && offset != 0x44/4 && offset != 0x48/4 && offset != 0x4c/4 &&
|
||||
offset != 0x118/4 && offset != 0x11c/4)
|
||||
@ -856,22 +856,22 @@ WRITE32_MEMBER(_3do_state::_3do_clio_w)
|
||||
case 0x0040/4:
|
||||
LOG(("%08x PEND0\n",data));
|
||||
m_clio.irq0 |= data;
|
||||
m_3do_request_fiq(0,0);
|
||||
m_request_fiq(0,0);
|
||||
break;
|
||||
case 0x0044/4:
|
||||
//LOG(("%08x PEND0 CLEAR\n",data));
|
||||
m_clio.irq0 &= ~data;
|
||||
m_3do_request_fiq(0,0);
|
||||
m_request_fiq(0,0);
|
||||
break;
|
||||
case 0x0048/4:
|
||||
LOG(("%08x MASK0\n",data));
|
||||
m_clio.irq0_enable |= data;
|
||||
m_3do_request_fiq(0,0);
|
||||
m_request_fiq(0,0);
|
||||
break;
|
||||
case 0x004c/4:
|
||||
LOG(("%08x MASK0 CLEAR\n",data));
|
||||
m_clio.irq0_enable &= ~data;
|
||||
m_3do_request_fiq(0,0);
|
||||
m_request_fiq(0,0);
|
||||
break;
|
||||
case 0x0050/4:
|
||||
m_clio.mode |= data;
|
||||
@ -888,22 +888,22 @@ WRITE32_MEMBER(_3do_state::_3do_clio_w)
|
||||
case 0x0060/4:
|
||||
LOG(("%08x PEND1\n",data));
|
||||
m_clio.irq1 |= data;
|
||||
m_3do_request_fiq(0,1);
|
||||
m_request_fiq(0,1);
|
||||
break;
|
||||
case 0x0064/4:
|
||||
LOG(("%08x PEND1 CLEAR\n",data));
|
||||
m_clio.irq1 &= ~data;
|
||||
m_3do_request_fiq(0,1);
|
||||
m_request_fiq(0,1);
|
||||
break;
|
||||
case 0x0068/4:
|
||||
LOG(("%08x MASK1\n",data));
|
||||
m_clio.irq1_enable |= data;
|
||||
m_3do_request_fiq(0,1);
|
||||
m_request_fiq(0,1);
|
||||
break;
|
||||
case 0x006c/4:
|
||||
LOG(("%08x MASK1 CLEAR\n",data));
|
||||
m_clio.irq1_enable &= ~data;
|
||||
m_3do_request_fiq(0,1);
|
||||
m_request_fiq(0,1);
|
||||
break;
|
||||
case 0x0080/4:
|
||||
m_clio.hdelay = data;
|
||||
@ -1040,7 +1040,7 @@ void _3do_state::video_start()
|
||||
}
|
||||
|
||||
|
||||
uint32_t _3do_state::screen_update__3do(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect)
|
||||
uint32_t _3do_state::screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect)
|
||||
{
|
||||
uint32_t *source_p = m_vram + 0x1c0000 / 4;
|
||||
|
||||
@ -1096,23 +1096,23 @@ uint32_t _3do_state::screen_update__3do(screen_device &screen, bitmap_rgb32 &bit
|
||||
*
|
||||
*/
|
||||
|
||||
void _3do_state::m_3do_madam_init( void )
|
||||
void _3do_state::m_madam_init( void )
|
||||
{
|
||||
memset( &m_madam, 0, sizeof(MADAM) );
|
||||
m_madam.revision = 0x01020000;
|
||||
m_madam.msysbits = 0x51;
|
||||
}
|
||||
|
||||
void _3do_state::m_3do_slow2_init( void )
|
||||
void _3do_state::m_slow2_init( void )
|
||||
{
|
||||
m_slow2.cg_input = 0;
|
||||
m_slow2.cg_output = 0x00000005 - 1;
|
||||
}
|
||||
|
||||
void _3do_state::m_3do_clio_init( screen_device *screen )
|
||||
void _3do_state::m_clio_init()
|
||||
{
|
||||
memset( &m_clio, 0, sizeof(CLIO) );
|
||||
m_clio.screen = screen;
|
||||
m_clio.screen = m_screen;
|
||||
m_clio.revision = 0x02022000 /* 0x04000000 */;
|
||||
m_clio.unclerev = 0x03800000;
|
||||
m_clio.expctl = 0x80; /* ARM has the expansion bus */
|
||||
|
@ -70,6 +70,7 @@ flagrall // ?
|
||||
3do // 3DO consoles
|
||||
3do_pal //
|
||||
3dobios //
|
||||
md23do //
|
||||
orbatak //
|
||||
|
||||
@source:3x3puzzl.cpp
|
||||
|
Loading…
Reference in New Issue
Block a user