Some DC cleanup (no whatsnew)

This commit is contained in:
Miodrag Milanovic 2012-10-03 14:54:09 +00:00
parent 99ffca1069
commit 13450f8c75
5 changed files with 72 additions and 59 deletions

3
.gitattributes vendored
View File

@ -5635,7 +5635,7 @@ src/mess/drivers/czk80.c svneol=native#text/plain
src/mess/drivers/d6800.c svneol=native#text/plain
src/mess/drivers/d6809.c svneol=native#text/plain
src/mess/drivers/dai.c svneol=native#text/plain
src/mess/drivers/dc.c svneol=native#text/plain
src/mess/drivers/dccons.c svneol=native#text/plain
src/mess/drivers/dct11em.c svneol=native#text/plain
src/mess/drivers/dectalk.c svneol=native#text/plain
src/mess/drivers/dgn_beta.c svneol=native#text/plain
@ -6098,6 +6098,7 @@ src/mess/includes/crvision.h svneol=native#text/plain
src/mess/includes/cxhumax.h svneol=native#text/plain
src/mess/includes/cybiko.h svneol=native#text/plain
src/mess/includes/dai.h svneol=native#text/plain
src/mess/includes/dccons.h svneol=native#text/plain
src/mess/includes/dgn_beta.h svneol=native#text/plain
src/mess/includes/dgnalpha.h svneol=native#text/plain
src/mess/includes/dm7000.h svneol=native#text/plain

View File

@ -89,9 +89,6 @@ class dc_state : public driver_device
DECLARE_DRIVER_INIT(vf4evoct);
DECLARE_DRIVER_INIT(naomi_mp);
DECLARE_DRIVER_INIT(mvsc2);
DECLARE_DRIVER_INIT(dc);
DECLARE_DRIVER_INIT(dcus);
DECLARE_DRIVER_INIT(dcjp);
virtual void machine_start();
virtual void machine_reset();
virtual void video_start();

View File

@ -25,6 +25,7 @@
#include "cpu/arm7/arm7core.h"
#include "sound/aica.h"
#include "includes/dc.h"
#include "includes/dccons.h"
#include "imagedev/chd_cd.h"
#include "machine/maple-dc.h"
#include "machine/dc-ctrl.h"
@ -40,45 +41,44 @@ extern DECLARE_WRITE64_HANDLER( dc_mess_gdrom_w );
extern DECLARE_READ64_HANDLER( dc_mess_g1_ctrl_r );
extern DECLARE_WRITE64_HANDLER( dc_mess_g1_ctrl_w );
static READ64_HANDLER( dcus_idle_skip_r )
READ64_MEMBER(dc_cons_state::dcus_idle_skip_r )
{
if (space.device().safe_pc()==0xc0ba52a)
space.device().execute().spin_until_time(attotime::from_usec(2500));
// device_spinuntil_int(&space.device());
return space.machine().driver_data<dc_state>()->dc_ram[0x2303b0/8];
return dc_ram[0x2303b0/8];
}
static READ64_HANDLER( dcjp_idle_skip_r )
READ64_MEMBER(dc_cons_state::dcjp_idle_skip_r )
{
if (space.device().safe_pc()==0xc0bac62)
space.device().execute().spin_until_time(attotime::from_usec(2500));
// device_spinuntil_int(&space.device());
return space.machine().driver_data<dc_state>()->dc_ram[0x2302f8/8];
return dc_ram[0x2302f8/8];
}
DRIVER_INIT_MEMBER(dc_state,dc)
DRIVER_INIT_MEMBER(dc_cons_state,dc)
{
dreamcast_atapi_init(machine());
}
DRIVER_INIT_MEMBER(dc_state,dcus)
DRIVER_INIT_MEMBER(dc_cons_state,dcus)
{
machine().device("maincpu")->memory().space(AS_PROGRAM).install_legacy_read_handler(0xc2303b0, 0xc2303b7, FUNC(dcus_idle_skip_r));
machine().device("maincpu")->memory().space(AS_PROGRAM).install_read_handler(0xc2303b0, 0xc2303b7, read64_delegate(FUNC(dc_cons_state::dcus_idle_skip_r),this));
DRIVER_INIT_CALL(dc);
}
DRIVER_INIT_MEMBER(dc_state,dcjp)
DRIVER_INIT_MEMBER(dc_cons_state,dcjp)
{
machine().device("maincpu")->memory().space(AS_PROGRAM).install_legacy_read_handler(0xc2302f8, 0xc2302ff, FUNC(dcjp_idle_skip_r));
machine().device("maincpu")->memory().space(AS_PROGRAM).install_read_handler(0xc2302f8, 0xc2302ff, read64_delegate(FUNC(dc_cons_state::dcjp_idle_skip_r),this));
DRIVER_INIT_CALL(dc);
}
static UINT64 PDTRA, PCTRA;
static READ64_HANDLER( dc_pdtra_r )
READ64_MEMBER(dc_cons_state::dc_pdtra_r )
{
UINT64 out = PCTRA<<32;
@ -102,62 +102,54 @@ static READ64_HANDLER( dc_pdtra_r )
return out;
}
static WRITE64_HANDLER( dc_pdtra_w )
WRITE64_MEMBER(dc_cons_state::dc_pdtra_w )
{
PCTRA = (data>>16) & 0xffff;
PDTRA = (data & 0xffff);
}
static READ64_HANDLER( dc_arm_r )
READ64_MEMBER(dc_cons_state::dc_arm_r )
{
dc_state *state = space.machine().driver_data<dc_state>();
return *((UINT64 *)state->dc_sound_ram.target()+offset);
return *((UINT64 *)dc_sound_ram.target()+offset);
}
static WRITE64_HANDLER( dc_arm_w )
WRITE64_MEMBER(dc_cons_state::dc_arm_w )
{
dc_state *state = space.machine().driver_data<dc_state>();
COMBINE_DATA((UINT64 *)state->dc_sound_ram.target() + offset);
COMBINE_DATA((UINT64 *)dc_sound_ram.target() + offset);
}
// SB_LMMODE0
static WRITE64_HANDLER( ta_texture_directpath0_w )
WRITE64_MEMBER(dc_cons_state::ta_texture_directpath0_w )
{
dc_state *state = space.machine().driver_data<dc_state>();
int mode = state->pvrctrl_regs[SB_LMMODE0]&1;
int mode = pvrctrl_regs[SB_LMMODE0]&1;
if (mode&1)
{
printf("ta_texture_directpath0_w 32-bit access!\n");
COMBINE_DATA(&state->dc_framebuffer_ram[offset]);
COMBINE_DATA(&dc_framebuffer_ram[offset]);
}
else
{
COMBINE_DATA(&state->dc_texture_ram[offset]);
COMBINE_DATA(&dc_texture_ram[offset]);
}
}
// SB_LMMODE1
static WRITE64_HANDLER( ta_texture_directpath1_w )
WRITE64_MEMBER(dc_cons_state::ta_texture_directpath1_w )
{
dc_state *state = space.machine().driver_data<dc_state>();
int mode = state->pvrctrl_regs[SB_LMMODE1]&1;
int mode = pvrctrl_regs[SB_LMMODE1]&1;
if (mode&1)
{
printf("ta_texture_directpath1_w 32-bit access!\n");
COMBINE_DATA(&state->dc_framebuffer_ram[offset]);
COMBINE_DATA(&dc_framebuffer_ram[offset]);
}
else
{
COMBINE_DATA(&state->dc_texture_ram[offset]);
COMBINE_DATA(&dc_texture_ram[offset]);
}
}
static ADDRESS_MAP_START( dc_map, AS_PROGRAM, 64, dc_state )
static ADDRESS_MAP_START( dc_map, AS_PROGRAM, 64, dc_cons_state )
AM_RANGE(0x00000000, 0x001fffff) AM_ROM AM_WRITENOP // BIOS
AM_RANGE(0x00200000, 0x0021ffff) AM_ROM AM_REGION("maincpu", 0x200000) // flash
AM_RANGE(0x005f6800, 0x005f69ff) AM_READWRITE_LEGACY(dc_sysctrl_r, dc_sysctrl_w )
@ -170,7 +162,7 @@ static ADDRESS_MAP_START( dc_map, AS_PROGRAM, 64, dc_state )
AM_RANGE(0x00600000, 0x006007ff) AM_READWRITE_LEGACY(dc_modem_r, dc_modem_w )
AM_RANGE(0x00700000, 0x00707fff) AM_READWRITE(dc_aica_reg_r, dc_aica_reg_w )
AM_RANGE(0x00710000, 0x0071000f) AM_READWRITE_LEGACY(dc_rtc_r, dc_rtc_w )
AM_RANGE(0x00800000, 0x009fffff) AM_READWRITE_LEGACY(dc_arm_r, dc_arm_w )
AM_RANGE(0x00800000, 0x009fffff) AM_READWRITE(dc_arm_r, dc_arm_w )
/* Area 1 */
AM_RANGE(0x04000000, 0x04ffffff) AM_RAM AM_SHARE("dc_texture_ram") // texture memory 64 bit access
@ -185,34 +177,32 @@ static ADDRESS_MAP_START( dc_map, AS_PROGRAM, 64, dc_state )
/* Area 4 */
AM_RANGE(0x10000000, 0x107fffff) AM_WRITE_LEGACY(ta_fifo_poly_w )
AM_RANGE(0x10800000, 0x10ffffff) AM_WRITE_LEGACY(ta_fifo_yuv_w )
AM_RANGE(0x11000000, 0x117fffff) AM_WRITE_LEGACY(ta_texture_directpath0_w ) AM_MIRROR(0x00800000) // access to texture / fraembfufer memory (either 32-bit or 64-bit area depending on SB_LMMODE0 register - cannot be written directly, only through dma / store queue
AM_RANGE(0x11000000, 0x117fffff) AM_WRITE(ta_texture_directpath0_w ) AM_MIRROR(0x00800000) // access to texture / fraembfufer memory (either 32-bit or 64-bit area depending on SB_LMMODE0 register - cannot be written directly, only through dma / store queue
AM_RANGE(0x12000000, 0x127fffff) AM_WRITE_LEGACY(ta_fifo_poly_w )
AM_RANGE(0x12800000, 0x12ffffff) AM_WRITE_LEGACY(ta_fifo_yuv_w )
AM_RANGE(0x13000000, 0x137fffff) AM_WRITE_LEGACY(ta_texture_directpath1_w ) AM_MIRROR(0x00800000) // access to texture / fraembfufer memory (either 32-bit or 64-bit area depending on SB_LMMODE1 register - cannot be written directly, only through dma / store queue
AM_RANGE(0x13000000, 0x137fffff) AM_WRITE(ta_texture_directpath1_w ) AM_MIRROR(0x00800000) // access to texture / fraembfufer memory (either 32-bit or 64-bit area depending on SB_LMMODE1 register - cannot be written directly, only through dma / store queue
AM_RANGE(0x8c000000, 0x8cffffff) AM_RAM AM_SHARE("dc_ram") // another RAM mirror
AM_RANGE(0xa0000000, 0xa01fffff) AM_ROM AM_REGION("maincpu", 0)
ADDRESS_MAP_END
static ADDRESS_MAP_START( dc_port, AS_IO, 64, dc_state )
AM_RANGE(0x00000000, 0x00000007) AM_READWRITE_LEGACY(dc_pdtra_r, dc_pdtra_w )
static ADDRESS_MAP_START( dc_port, AS_IO, 64, dc_cons_state )
AM_RANGE(0x00000000, 0x00000007) AM_READWRITE(dc_pdtra_r, dc_pdtra_w )
ADDRESS_MAP_END
static ADDRESS_MAP_START( dc_audio_map, AS_PROGRAM, 32, dc_state )
static ADDRESS_MAP_START( dc_audio_map, AS_PROGRAM, 32, dc_cons_state )
AM_RANGE(0x00000000, 0x001fffff) AM_RAM AM_SHARE("dc_sound_ram") /* shared with SH-4 */
AM_RANGE(0x00800000, 0x00807fff) AM_READWRITE(dc_arm_aica_r, dc_arm_aica_w)
ADDRESS_MAP_END
static MACHINE_RESET( dc_console )
MACHINE_RESET_MEMBER(dc_cons_state,dc_console)
{
dc_state *state = machine.driver_data<dc_state>();
device_t *aica = machine.device("aica");
state->machine_reset();
aica_set_ram_base(aica, state->dc_sound_ram, 2*1024*1024);
dreamcast_atapi_reset(machine);
device_t *aica = machine().device("aica");
dc_state::machine_reset();
aica_set_ram_base(aica, dc_sound_ram, 2*1024*1024);
dreamcast_atapi_reset(machine());
}
static void aica_irq(device_t *device, int irq)
@ -229,7 +219,7 @@ static const aica_interface dc_aica_interface =
static const struct sh4_config sh4cpu_config = { 1, 0, 1, 0, 0, 0, 1, 1, 0, CPU_CLOCK };
static MACHINE_CONFIG_START( dc, dc_state )
static MACHINE_CONFIG_START( dc, dc_cons_state )
/* basic machine hardware */
MCFG_CPU_ADD("maincpu", SH4LE, CPU_CLOCK)
MCFG_CPU_CONFIG(sh4cpu_config)
@ -239,7 +229,7 @@ static MACHINE_CONFIG_START( dc, dc_state )
MCFG_CPU_ADD("soundcpu", ARM7, ((XTAL_33_8688MHz*2)/3)/8) // AICA bus clock is 2/3rds * 33.8688. ARM7 gets 1 bus cycle out of each 8.
MCFG_CPU_PROGRAM_MAP(dc_audio_map)
MCFG_MACHINE_RESET( dc_console )
MCFG_MACHINE_RESET_OVERRIDE(dc_cons_state,dc_console )
MCFG_MAPLE_DC_ADD( "maple_dc", "maincpu", dc_maple_irq )
MCFG_DC_CONTROLLER_ADD("dcctrl0", "maple_dc", 0, "P1:0", "P1:1", "P1:A0", "P1:A1", "P1:A2", "P1:A3", "P1:A4", "P1:A5")
@ -253,7 +243,7 @@ static MACHINE_CONFIG_START( dc, dc_state )
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500) /* not accurate */)
MCFG_SCREEN_SIZE(640, 480)
MCFG_SCREEN_VISIBLE_AREA(0, 640-1, 0, 480-1)
MCFG_SCREEN_UPDATE_DRIVER(dc_state, screen_update_dc)
MCFG_SCREEN_UPDATE_DRIVER(dc_cons_state, screen_update_dc)
MCFG_PALETTE_LENGTH(0x1000)
@ -383,9 +373,9 @@ INPUT_PORTS_END
/* YEAR NAME PARENT COMPAT MACHINE INPUT INIT COMPANY FULLNAME */
CONS( 1999, dc, dcjp, 0, dc, dc, dc_state, dcus, "Sega", "Dreamcast (USA, NTSC)", GAME_NOT_WORKING )
CONS( 1998, dcjp, 0, 0, dc, dc, dc_state, dcjp, "Sega", "Dreamcast (Japan, NTSC)", GAME_NOT_WORKING )
CONS( 1999, dceu, dcjp, 0, dc, dc, dc_state, dcus, "Sega", "Dreamcast (Europe, PAL)", GAME_NOT_WORKING )
CONS( 1998, dcdev, dcjp, 0, dc, dc, dc_state, dc, "Sega", "HKT-0120 Sega Dreamcast Development Box", GAME_NOT_WORKING )
CONS( 1998, dcprt, dcjp, 0, dc, dc, dc_state, dcjp, "Sega", "Katana Set 5 Prototype", GAME_NOT_WORKING )
CONS( 1999, dc, dcjp, 0, dc, dc, dc_cons_state, dcus, "Sega", "Dreamcast (USA, NTSC)", GAME_NOT_WORKING )
CONS( 1998, dcjp, 0, 0, dc, dc, dc_cons_state, dcjp, "Sega", "Dreamcast (Japan, NTSC)", GAME_NOT_WORKING )
CONS( 1999, dceu, dcjp, 0, dc, dc, dc_cons_state, dcus, "Sega", "Dreamcast (Europe, PAL)", GAME_NOT_WORKING )
CONS( 1998, dcdev, dcjp, 0, dc, dc, dc_cons_state, dc, "Sega", "HKT-0120 Sega Dreamcast Development Box", GAME_NOT_WORKING )
CONS( 1998, dcprt, dcjp, 0, dc, dc, dc_cons_state, dcjp, "Sega", "Katana Set 5 Prototype", GAME_NOT_WORKING )

View File

@ -0,0 +1,25 @@
class dc_cons_state : public dc_state
{
public:
dc_cons_state(const machine_config &mconfig, device_type type, const char *tag)
: dc_state(mconfig, type, tag)
{ }
DECLARE_DRIVER_INIT(dc);
DECLARE_DRIVER_INIT(dcus);
DECLARE_DRIVER_INIT(dcjp);
DECLARE_READ64_MEMBER(dcus_idle_skip_r);
DECLARE_READ64_MEMBER(dcjp_idle_skip_r);
DECLARE_MACHINE_RESET(dc_console);
DECLARE_READ64_MEMBER(dc_pdtra_r);
DECLARE_WRITE64_MEMBER(dc_pdtra_w);
DECLARE_READ64_MEMBER(dc_arm_r);
DECLARE_WRITE64_MEMBER(dc_arm_w);
DECLARE_WRITE64_MEMBER(ta_texture_directpath0_w);
DECLARE_WRITE64_MEMBER(ta_texture_directpath1_w);
private:
UINT64 PDTRA, PCTRA;
};

View File

@ -1567,7 +1567,7 @@ $(MESSOBJ)/sega.a: \
$(MESS_DRIVERS)/sg1000.o \
$(MAME_MACHINE)/md_cart.o \
$(MESS_DRIVERS)/megadriv.o \
$(MESS_DRIVERS)/dc.o \
$(MESS_DRIVERS)/dccons.o \
$(MAME_MACHINE)/gdrom.o \
$(MESS_MACHINE)/dccons.o \
$(MESS_MACHINE)/sms.o \