Death to sei_crtc dummy device, state-ized Sengoku Mahjong and Good e Jan video functions, skelly for Seibu CRTC, nw (for now ...)

This commit is contained in:
Angelo Salese 2013-07-11 23:10:25 +00:00
parent 5919be052a
commit 083463dab8
11 changed files with 830 additions and 376 deletions

3
.gitattributes vendored
View File

@ -5805,7 +5805,8 @@ src/mame/video/segas24.c svneol=native#text/plain
src/mame/video/segas32.c svneol=native#text/plain
src/mame/video/segaxbd.c svneol=native#text/plain
src/mame/video/segaybd.c svneol=native#text/plain
src/mame/video/sei_crtc.c svneol=native#text/plain
src/mame/video/seibu_crtc.c svneol=native#text/plain
src/mame/video/seibu_crtc.h svneol=native#text/plain
src/mame/video/seibuspi.c svneol=native#text/plain
src/mame/video/seicross.c svneol=native#text/plain
src/mame/video/senjyo.c svneol=native#text/plain

View File

@ -75,7 +75,7 @@ void k053252_device::device_config_complete()
const k053252_interface *intf = reinterpret_cast<const k053252_interface *>(static_config());
if (intf != NULL)
*static_cast<k053252_interface *>(this) = *intf;
// or initialize to defaults if none provided
else
{
@ -115,7 +115,7 @@ void k053252_device::device_reset()
m_regs[i] = 0;
m_regs[0x08] = 1; // Xexex apparently does a wrong assignment for VC (sets up the INT enable register instead)
m_hc=0;
m_hfp=0;
m_hbp=0;

View File

@ -19,23 +19,23 @@ struct k053252_interface
};
class k053252_device : public device_t,
public k053252_interface
public k053252_interface
{
public:
k053252_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
~k053252_device() {}
DECLARE_READ8_MEMBER( read ); // CCU registers
DECLARE_WRITE8_MEMBER( write );
void res_change();
protected:
// device-level overrides
virtual void device_config_complete();
virtual void device_start();
virtual void device_reset();
private:
// internal state
UINT8 m_regs[16];

View File

@ -144,7 +144,7 @@ const address_space_config *m50458_device::memory_space_config(address_spacenum
//**************************************************************************
//-------------------------------------------------
// readbyte - read a byte at the given address
// read_word - read a word at the given address
//-------------------------------------------------
inline UINT16 m50458_device::read_word(offs_t address)
@ -153,7 +153,7 @@ inline UINT16 m50458_device::read_word(offs_t address)
}
//-------------------------------------------------
// writebyte - write a byte at the given address
// write_word - write a word at the given address
//-------------------------------------------------
inline void m50458_device::write_word(offs_t address, UINT16 data)

View File

@ -54,7 +54,7 @@ Notes:
#include "cpu/nec/nec.h"
#include "audio/seibu.h"
#include "sound/3812intf.h"
#include "includes/sei_crtc.h"
//#include "includes/sei_crtc.h"
class goodejan_state : public driver_device
@ -62,16 +62,276 @@ class goodejan_state : public driver_device
public:
goodejan_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag),
m_sc0_vram(*this, "sc0_vram"),
m_sc1_vram(*this, "sc1_vram"),
m_sc2_vram(*this, "sc2_vram"),
m_sc3_vram(*this, "sc3_vram"),
m_seibucrtc_vregs(*this, "crtc_vregs"),
m_spriteram16(*this, "sprite_ram"),
m_maincpu(*this, "maincpu") { }
required_shared_ptr<UINT16> m_sc0_vram;
required_shared_ptr<UINT16> m_sc1_vram;
required_shared_ptr<UINT16> m_sc2_vram;
required_shared_ptr<UINT16> m_sc3_vram;
required_shared_ptr<UINT16> m_seibucrtc_vregs;
required_shared_ptr<UINT16> m_spriteram16;
required_device<cpu_device> m_maincpu;
tilemap_t *m_sc0_tilemap;
tilemap_t *m_sc1_tilemap;
tilemap_t *m_sc2_tilemap;
tilemap_t *m_sc3_tilemap_0;
tilemap_t *m_sc3_tilemap_1;
UINT16 m_mux_data;
UINT16 m_seibucrtc_sc0bank;
DECLARE_WRITE16_MEMBER(goodejan_gfxbank_w);
DECLARE_READ16_MEMBER(mahjong_panel_r);
DECLARE_WRITE16_MEMBER(mahjong_panel_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc0vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc1vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc2vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc3vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_vregs_w);
TILE_GET_INFO_MEMBER(seibucrtc_sc0_tile_info);
TILE_GET_INFO_MEMBER(seibucrtc_sc1_tile_info);
TILE_GET_INFO_MEMBER(seibucrtc_sc2_tile_info);
TILE_GET_INFO_MEMBER(seibucrtc_sc3_tile_info);
INTERRUPT_GEN_MEMBER(goodejan_irq);
required_device<cpu_device> m_maincpu;
void seibucrtc_sc0bank_w(UINT16 data);
void draw_sprites(running_machine &machine, bitmap_ind16 &bitmap,const rectangle &cliprect,int pri);
virtual void video_start();
UINT32 screen_update_goodejan(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
};
/*******************************
*
* Macros for the video registers
*
*******************************/
/*******************************
* 0x1a - Layer Dynamic Paging?
*******************************/
#define SEIBU_CRTC_DYN_PAGING (m_seibucrtc_vregs[0x001a/2])
#define SEIBU_CRTC_SC3_PAGE_SEL (SEIBU_CRTC_DYN_PAGING & 0x0002)
/*******************************
* 0x1c - Layer Enable
*******************************/
#define SEIBU_CRTC_LAYER_EN (m_seibucrtc_vregs[0x001c/2])
#define SEIBU_CRTC_ENABLE_SC0 (!(SEIBU_CRTC_LAYER_EN & 0x0001))
#define SEIBU_CRTC_ENABLE_SC2 (!(SEIBU_CRTC_LAYER_EN & 0x0002))
#define SEIBU_CRTC_ENABLE_SC1 (!(SEIBU_CRTC_LAYER_EN & 0x0004))
#define SEIBU_CRTC_ENABLE_SC3 (!(SEIBU_CRTC_LAYER_EN & 0x0008))
#define SEIBU_CRTC_ENABLE_SPR (!(SEIBU_CRTC_LAYER_EN & 0x0010))
/************************************
* 0x20 - Screen 0 (BG) scroll x
************************************/
#define SEIBU_CRTC_SC0_SX (m_seibucrtc_vregs[0x0020/2])
/************************************
* 0x22 - Screen 0 (BG) scroll y
************************************/
#define SEIBU_CRTC_SC0_SY (m_seibucrtc_vregs[0x0022/2])
/************************************
* 0x24 - Screen 1 (FG) scroll x
************************************/
#define SEIBU_CRTC_SC1_SX (m_seibucrtc_vregs[0x0028/2])
/************************************
* 0x26 - Screen 1 (FG) scroll y
************************************/
#define SEIBU_CRTC_SC1_SY (m_seibucrtc_vregs[0x002a/2])
/************************************
* 0x28 - Screen 2 (MD) scroll x
************************************/
#define SEIBU_CRTC_SC2_SX (m_seibucrtc_vregs[0x0024/2])
/************************************
* 0x2a - Screen 2 (MD) scroll y
************************************/
#define SEIBU_CRTC_SC2_SY (m_seibucrtc_vregs[0x0026/2])
/************************************
* 0x2c - Fix screen scroll x (global)
************************************/
#define SEIBU_CRTC_FIX_SX (m_seibucrtc_vregs[0x002c/2])
/************************************
* 0x2e - Fix screen scroll y (global)
************************************/
#define SEIBU_CRTC_FIX_SY (m_seibucrtc_vregs[0x002e/2])
/*******************************
*
* Write RAM accesses
*
*******************************/
WRITE16_MEMBER( goodejan_state::seibucrtc_sc0vram_w )
{
COMBINE_DATA(&m_sc0_vram[offset]);
m_sc0_tilemap->mark_tile_dirty(offset);
}
WRITE16_MEMBER( goodejan_state::seibucrtc_sc2vram_w )
{
COMBINE_DATA(&m_sc2_vram[offset]);
m_sc2_tilemap->mark_tile_dirty(offset);
}
WRITE16_MEMBER( goodejan_state::seibucrtc_sc1vram_w )
{
COMBINE_DATA(&m_sc1_vram[offset]);
m_sc1_tilemap->mark_tile_dirty(offset);
}
WRITE16_MEMBER( goodejan_state::seibucrtc_sc3vram_w )
{
COMBINE_DATA(&m_sc3_vram[offset]);
m_sc3_tilemap_0->mark_tile_dirty(offset);
m_sc3_tilemap_1->mark_tile_dirty(offset);
}
WRITE16_MEMBER( goodejan_state::seibucrtc_vregs_w )
{
COMBINE_DATA(&m_seibucrtc_vregs[offset]);
}
/* Actually external from the CRTC */
void goodejan_state::seibucrtc_sc0bank_w(UINT16 data)
{
m_seibucrtc_sc0bank = data & 1;
m_sc0_tilemap->mark_all_dirty();
}
/*******************************
*
* Tilemap info accesses
*
*******************************/
TILE_GET_INFO_MEMBER( goodejan_state::seibucrtc_sc0_tile_info )
{
int tile = m_sc0_vram[tile_index] & 0xfff;
int color = (m_sc0_vram[tile_index] >> 12) & 0x0f;
tile+=(m_seibucrtc_sc0bank<<12);
SET_TILE_INFO_MEMBER(1, tile, color, 0);
}
TILE_GET_INFO_MEMBER( goodejan_state::seibucrtc_sc2_tile_info )
{
int tile = m_sc2_vram[tile_index] & 0xfff;
int color = (m_sc2_vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO_MEMBER(2, tile, color, 0);
}
TILE_GET_INFO_MEMBER( goodejan_state::seibucrtc_sc1_tile_info )
{
int tile = m_sc1_vram[tile_index] & 0xfff;
int color = (m_sc1_vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO_MEMBER(3, tile, color, 0);
}
TILE_GET_INFO_MEMBER( goodejan_state::seibucrtc_sc3_tile_info )
{
int tile = m_sc3_vram[tile_index] & 0xfff;
int color = (m_sc3_vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO_MEMBER(4, tile, color, 0);
}
void goodejan_state::draw_sprites(running_machine &machine, bitmap_ind16 &bitmap,const rectangle &cliprect,int pri)
{
int offs,fx,fy,x,y,color,sprite;
int dx,dy,ax,ay;
for (offs = 0x400-4;offs >= 0;offs -= 4)
{
if ((m_spriteram16[offs+0]&0x8000)!=0x8000) continue;
sprite = m_spriteram16[offs+1];
if ((sprite>>14)!=pri) continue;
sprite &= 0x1fff;
y = m_spriteram16[offs+3];
x = m_spriteram16[offs+2];
if (x&0x8000) x=0-(0x200-(x&0x1ff));
else x&=0x1ff;
if (y&0x8000) y=0-(0x200-(y&0x1ff));
else y&=0x1ff;
color = m_spriteram16[offs+0]&0x3f;
fx = m_spriteram16[offs+0]&0x4000;
fy = m_spriteram16[offs+0]&0x2000;
dy=((m_spriteram16[offs+0]&0x0380)>>7)+1;
dx=((m_spriteram16[offs+0]&0x1c00)>>10)+1;
for (ax=0; ax<dx; ax++)
for (ay=0; ay<dy; ay++) {
if (!fx)
drawgfx_transpen(bitmap,cliprect,machine.gfx[0],
sprite++,
color,fx,fy,x+ax*16,y+ay*16,15);
else
drawgfx_transpen(bitmap,cliprect,machine.gfx[0],
sprite++,
color,fx,fy,x+(dx-1-ax)*16,y+ay*16,15);
}
}
}
/***********************************
*
* VIDEO_START/VIDEO_UPDATE functions
*
***********************************/
void goodejan_state::video_start()
{
m_sc0_tilemap = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(goodejan_state::seibucrtc_sc0_tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32);
m_sc2_tilemap = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(goodejan_state::seibucrtc_sc2_tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32);
m_sc1_tilemap = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(goodejan_state::seibucrtc_sc1_tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32);
m_sc3_tilemap_0 = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(goodejan_state::seibucrtc_sc3_tile_info),this),TILEMAP_SCAN_ROWS,8,8,32,32);
m_sc3_tilemap_1 = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(goodejan_state::seibucrtc_sc3_tile_info),this),TILEMAP_SCAN_ROWS,8,8,64,32);
m_sc2_tilemap->set_transparent_pen(15);
m_sc1_tilemap->set_transparent_pen(15);
m_sc3_tilemap_0->set_transparent_pen(15);
m_sc3_tilemap_1->set_transparent_pen(15);
m_seibucrtc_sc0bank = 0;
}
UINT32 goodejan_state::screen_update_goodejan(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
{
bitmap.fill(screen.machine().pens[0x7ff], cliprect); //black pen
m_sc0_tilemap->set_scrollx(0, (SEIBU_CRTC_SC0_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
m_sc0_tilemap->set_scrolly(0, (SEIBU_CRTC_SC0_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
m_sc2_tilemap->set_scrollx(0, (SEIBU_CRTC_SC2_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
m_sc2_tilemap->set_scrolly(0, (SEIBU_CRTC_SC2_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
m_sc1_tilemap->set_scrollx(0, (SEIBU_CRTC_SC1_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
m_sc1_tilemap->set_scrolly(0, (SEIBU_CRTC_SC1_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
(SEIBU_CRTC_SC3_PAGE_SEL ? m_sc3_tilemap_0 : m_sc3_tilemap_1)->set_scrollx(0, (SEIBU_CRTC_FIX_SX+64) & 0x1ff );
(SEIBU_CRTC_SC3_PAGE_SEL ? m_sc3_tilemap_0 : m_sc3_tilemap_1)->set_scrolly(0, (SEIBU_CRTC_FIX_SY+1) & 0x1ff );
if(SEIBU_CRTC_ENABLE_SC0) { m_sc0_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 2); }
if(SEIBU_CRTC_ENABLE_SC2) { m_sc2_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 1); }
if(SEIBU_CRTC_ENABLE_SC1) { m_sc1_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 0); }
if(SEIBU_CRTC_ENABLE_SC3) { (SEIBU_CRTC_SC3_PAGE_SEL ? m_sc3_tilemap_0 : m_sc3_tilemap_1)->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 3); }
return 0;
}
#define GOODEJAN_MHZ1 7159090
#define GOODEJAN_MHZ2 16000000
@ -108,13 +368,13 @@ WRITE16_MEMBER(goodejan_state::mahjong_panel_w)
static ADDRESS_MAP_START( goodejan_map, AS_PROGRAM, 16, goodejan_state )
AM_RANGE(0x00000, 0x0afff) AM_RAM
AM_RANGE(0x0c000, 0x0c7ff) AM_RAM_WRITE_LEGACY(seibucrtc_sc0vram_w) AM_SHARE("crtc_sc0vram")
AM_RANGE(0x0c800, 0x0cfff) AM_RAM_WRITE_LEGACY(seibucrtc_sc3vram_w) AM_SHARE("crtc_sc3vram")
AM_RANGE(0x0c000, 0x0c7ff) AM_RAM_WRITE(seibucrtc_sc0vram_w) AM_SHARE("sc0_vram")
AM_RANGE(0x0c800, 0x0cfff) AM_RAM_WRITE(seibucrtc_sc3vram_w) AM_SHARE("sc3_vram")
AM_RANGE(0x0d000, 0x0dfff) AM_RAM_WRITE(paletteram_xxxxBBBBGGGGRRRR_word_w) AM_SHARE("paletteram")
/*Guess: these two aren't used/initialized at all.*/
AM_RANGE(0x0e000, 0x0e7ff) AM_RAM_WRITE_LEGACY(seibucrtc_sc1vram_w) AM_SHARE("crtc_sc1vram")
AM_RANGE(0x0e800, 0x0efff) AM_RAM_WRITE_LEGACY(seibucrtc_sc2vram_w) AM_SHARE("crtc_sc2vram")
AM_RANGE(0x0f800, 0x0ffff) AM_RAM AM_SHARE("spriteram")
AM_RANGE(0x0e000, 0x0e7ff) AM_RAM_WRITE(seibucrtc_sc1vram_w) AM_SHARE("sc1_vram")
AM_RANGE(0x0e800, 0x0efff) AM_RAM_WRITE(seibucrtc_sc2vram_w) AM_SHARE("sc2_vram")
AM_RANGE(0x0f800, 0x0ffff) AM_RAM AM_SHARE("sprite_ram")
AM_RANGE(0xc0000, 0xfffff) AM_ROM
ADDRESS_MAP_END
@ -131,12 +391,12 @@ static ADDRESS_MAP_START( common_io_map, AS_IO, 16, goodejan_state )
ADDRESS_MAP_END
static ADDRESS_MAP_START( totmejan_io_map, AS_IO, 16, goodejan_state )
AM_RANGE(0x8000, 0x804f) AM_RAM_WRITE_LEGACY(seibucrtc_vregs_w) AM_SHARE("crtc_vregs")
AM_RANGE(0x8000, 0x804f) AM_RAM_WRITE(seibucrtc_vregs_w) AM_SHARE("crtc_vregs")
AM_IMPORT_FROM(common_io_map)
ADDRESS_MAP_END
static ADDRESS_MAP_START( goodejan_io_map, AS_IO, 16, goodejan_state )
AM_RANGE(0x8040, 0x807f) AM_RAM_WRITE_LEGACY(seibucrtc_vregs_w) AM_SHARE("crtc_vregs")
AM_RANGE(0x8040, 0x807f) AM_RAM_WRITE(seibucrtc_vregs_w) AM_SHARE("crtc_vregs")
AM_IMPORT_FROM(common_io_map)
ADDRESS_MAP_END
@ -356,13 +616,11 @@ static MACHINE_CONFIG_START( goodejan, goodejan_state )
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
MCFG_SCREEN_SIZE(32*8, 32*8)
MCFG_SCREEN_VISIBLE_AREA(0*8, 32*8-1, 2*8, 30*8-1) //TODO: dynamic resolution
MCFG_SCREEN_UPDATE_STATIC(seibu_crtc)
MCFG_SCREEN_UPDATE_DRIVER(goodejan_state, screen_update_goodejan)
MCFG_GFXDECODE(goodejan)
MCFG_PALETTE_LENGTH(0x1000)
MCFG_VIDEO_START(seibu_crtc)
/* sound hardware */
SEIBU_SOUND_SYSTEM_YM3812_INTERFACE(GOODEJAN_MHZ1/2,GOODEJAN_MHZ2/16)
MACHINE_CONFIG_END

View File

@ -55,7 +55,7 @@ RSSENGO2.72 chr.
#include "cpu/nec/nec.h"
#include "audio/seibu.h"
#include "sound/3812intf.h"
#include "includes/sei_crtc.h"
//#include "includes/sei_crtc.h"
#include "machine/nvram.h"
@ -64,19 +64,281 @@ class sengokmj_state : public driver_device
public:
sengokmj_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag),
m_sc0_vram(*this, "sc0_vram"),
m_sc1_vram(*this, "sc1_vram"),
m_sc2_vram(*this, "sc2_vram"),
m_sc3_vram(*this, "sc3_vram"),
m_seibucrtc_vregs(*this, "crtc_vregs"),
m_spriteram16(*this, "sprite_ram"),
m_maincpu(*this, "maincpu") { }
required_shared_ptr<UINT16> m_sc0_vram;
required_shared_ptr<UINT16> m_sc1_vram;
required_shared_ptr<UINT16> m_sc2_vram;
required_shared_ptr<UINT16> m_sc3_vram;
required_shared_ptr<UINT16> m_seibucrtc_vregs;
required_shared_ptr<UINT16> m_spriteram16;
required_device<cpu_device> m_maincpu;
tilemap_t *m_sc0_tilemap;
tilemap_t *m_sc1_tilemap;
tilemap_t *m_sc2_tilemap;
tilemap_t *m_sc3_tilemap_0;
tilemap_t *m_sc3_tilemap_1;
UINT16 m_sengokumj_mux_data;
UINT8 m_hopper_io;
UINT16 m_seibucrtc_sc0bank;
DECLARE_READ16_MEMBER(mahjong_panel_r);
DECLARE_WRITE16_MEMBER(mahjong_panel_w);
DECLARE_WRITE16_MEMBER(sengokmj_out_w);
DECLARE_READ16_MEMBER(sengokmj_system_r);
DECLARE_WRITE16_MEMBER(seibucrtc_sc0vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc1vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc2vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_sc3vram_w);
DECLARE_WRITE16_MEMBER(seibucrtc_vregs_w);
TILE_GET_INFO_MEMBER(seibucrtc_sc0_tile_info);
TILE_GET_INFO_MEMBER(seibucrtc_sc1_tile_info);
TILE_GET_INFO_MEMBER(seibucrtc_sc2_tile_info);
TILE_GET_INFO_MEMBER(seibucrtc_sc3_tile_info);
INTERRUPT_GEN_MEMBER(sengokmj_interrupt);
required_device<cpu_device> m_maincpu;
void seibucrtc_sc0bank_w(UINT16 data);
void draw_sprites(running_machine &machine, bitmap_ind16 &bitmap,const rectangle &cliprect,int pri);
virtual void video_start();
UINT32 screen_update_sengokmj(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
};
/*******************************
*
* Macros for the video registers
*
*******************************/
/*******************************
* 0x1a - Layer Dynamic Paging?
*******************************/
#define SEIBU_CRTC_DYN_PAGING (m_seibucrtc_vregs[0x001a/2])
#define SEIBU_CRTC_SC3_PAGE_SEL (SEIBU_CRTC_DYN_PAGING & 0x0002)
/*******************************
* 0x1c - Layer Enable
*******************************/
#define SEIBU_CRTC_LAYER_EN (m_seibucrtc_vregs[0x001c/2])
#define SEIBU_CRTC_ENABLE_SC0 (!(SEIBU_CRTC_LAYER_EN & 0x0001))
#define SEIBU_CRTC_ENABLE_SC2 (!(SEIBU_CRTC_LAYER_EN & 0x0002))
#define SEIBU_CRTC_ENABLE_SC1 (!(SEIBU_CRTC_LAYER_EN & 0x0004))
#define SEIBU_CRTC_ENABLE_SC3 (!(SEIBU_CRTC_LAYER_EN & 0x0008))
#define SEIBU_CRTC_ENABLE_SPR (!(SEIBU_CRTC_LAYER_EN & 0x0010))
/************************************
* 0x20 - Screen 0 (BG) scroll x
************************************/
#define SEIBU_CRTC_SC0_SX (m_seibucrtc_vregs[0x0020/2])
/************************************
* 0x22 - Screen 0 (BG) scroll y
************************************/
#define SEIBU_CRTC_SC0_SY (m_seibucrtc_vregs[0x0022/2])
/************************************
* 0x24 - Screen 1 (FG) scroll x
************************************/
#define SEIBU_CRTC_SC1_SX (m_seibucrtc_vregs[0x0028/2])
/************************************
* 0x26 - Screen 1 (FG) scroll y
************************************/
#define SEIBU_CRTC_SC1_SY (m_seibucrtc_vregs[0x002a/2])
/************************************
* 0x28 - Screen 2 (MD) scroll x
************************************/
#define SEIBU_CRTC_SC2_SX (m_seibucrtc_vregs[0x0024/2])
/************************************
* 0x2a - Screen 2 (MD) scroll y
************************************/
#define SEIBU_CRTC_SC2_SY (m_seibucrtc_vregs[0x0026/2])
/************************************
* 0x2c - Fix screen scroll x (global)
************************************/
#define SEIBU_CRTC_FIX_SX (m_seibucrtc_vregs[0x002c/2])
/************************************
* 0x2e - Fix screen scroll y (global)
************************************/
#define SEIBU_CRTC_FIX_SY (m_seibucrtc_vregs[0x002e/2])
/*******************************
*
* Write RAM accesses
*
*******************************/
WRITE16_MEMBER( sengokmj_state::seibucrtc_sc0vram_w )
{
COMBINE_DATA(&m_sc0_vram[offset]);
m_sc0_tilemap->mark_tile_dirty(offset);
}
WRITE16_MEMBER( sengokmj_state::seibucrtc_sc2vram_w )
{
COMBINE_DATA(&m_sc2_vram[offset]);
m_sc2_tilemap->mark_tile_dirty(offset);
}
WRITE16_MEMBER( sengokmj_state::seibucrtc_sc1vram_w )
{
COMBINE_DATA(&m_sc1_vram[offset]);
m_sc1_tilemap->mark_tile_dirty(offset);
}
WRITE16_MEMBER( sengokmj_state::seibucrtc_sc3vram_w )
{
COMBINE_DATA(&m_sc3_vram[offset]);
m_sc3_tilemap_0->mark_tile_dirty(offset);
m_sc3_tilemap_1->mark_tile_dirty(offset);
}
WRITE16_MEMBER( sengokmj_state::seibucrtc_vregs_w )
{
COMBINE_DATA(&m_seibucrtc_vregs[offset]);
}
/* Actually external from the CRTC */
void sengokmj_state::seibucrtc_sc0bank_w(UINT16 data)
{
m_seibucrtc_sc0bank = data & 1;
m_sc0_tilemap->mark_all_dirty();
}
/*******************************
*
* Tilemap info accesses
*
*******************************/
TILE_GET_INFO_MEMBER( sengokmj_state::seibucrtc_sc0_tile_info )
{
int tile = m_sc0_vram[tile_index] & 0xfff;
int color = (m_sc0_vram[tile_index] >> 12) & 0x0f;
tile+=(m_seibucrtc_sc0bank<<12);
SET_TILE_INFO_MEMBER(1, tile, color, 0);
}
TILE_GET_INFO_MEMBER( sengokmj_state::seibucrtc_sc2_tile_info )
{
int tile = m_sc2_vram[tile_index] & 0xfff;
int color = (m_sc2_vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO_MEMBER(2, tile, color, 0);
}
TILE_GET_INFO_MEMBER( sengokmj_state::seibucrtc_sc1_tile_info )
{
int tile = m_sc1_vram[tile_index] & 0xfff;
int color = (m_sc1_vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO_MEMBER(3, tile, color, 0);
}
TILE_GET_INFO_MEMBER( sengokmj_state::seibucrtc_sc3_tile_info )
{
int tile = m_sc3_vram[tile_index] & 0xfff;
int color = (m_sc3_vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO_MEMBER(4, tile, color, 0);
}
void sengokmj_state::draw_sprites(running_machine &machine, bitmap_ind16 &bitmap,const rectangle &cliprect,int pri)
{
int offs,fx,fy,x,y,color,sprite;
int dx,dy,ax,ay;
for (offs = 0x400-4;offs >= 0;offs -= 4)
{
if ((m_spriteram16[offs+0]&0x8000)!=0x8000) continue;
sprite = m_spriteram16[offs+1];
if ((sprite>>14)!=pri) continue;
sprite &= 0x1fff;
y = m_spriteram16[offs+3];
x = m_spriteram16[offs+2];
if (x&0x8000) x=0-(0x200-(x&0x1ff));
else x&=0x1ff;
if (y&0x8000) y=0-(0x200-(y&0x1ff));
else y&=0x1ff;
color = m_spriteram16[offs+0]&0x3f;
fx = m_spriteram16[offs+0]&0x4000;
fy = m_spriteram16[offs+0]&0x2000;
dy=((m_spriteram16[offs+0]&0x0380)>>7)+1;
dx=((m_spriteram16[offs+0]&0x1c00)>>10)+1;
for (ax=0; ax<dx; ax++)
for (ay=0; ay<dy; ay++) {
if (!fx)
drawgfx_transpen(bitmap,cliprect,machine.gfx[0],
sprite++,
color,fx,fy,x+ax*16,y+ay*16,15);
else
drawgfx_transpen(bitmap,cliprect,machine.gfx[0],
sprite++,
color,fx,fy,x+(dx-1-ax)*16,y+ay*16,15);
}
}
}
/***********************************
*
* VIDEO_START/VIDEO_UPDATE functions
*
***********************************/
void sengokmj_state::video_start()
{
m_sc0_tilemap = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(sengokmj_state::seibucrtc_sc0_tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32);
m_sc2_tilemap = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(sengokmj_state::seibucrtc_sc2_tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32);
m_sc1_tilemap = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(sengokmj_state::seibucrtc_sc1_tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32);
m_sc3_tilemap_0 = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(sengokmj_state::seibucrtc_sc3_tile_info),this),TILEMAP_SCAN_ROWS,8,8,32,32);
m_sc3_tilemap_1 = &machine().tilemap().create(tilemap_get_info_delegate(FUNC(sengokmj_state::seibucrtc_sc3_tile_info),this),TILEMAP_SCAN_ROWS,8,8,64,32);
m_sc2_tilemap->set_transparent_pen(15);
m_sc1_tilemap->set_transparent_pen(15);
m_sc3_tilemap_0->set_transparent_pen(15);
m_sc3_tilemap_1->set_transparent_pen(15);
m_seibucrtc_sc0bank = 0;
}
UINT32 sengokmj_state::screen_update_sengokmj(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
{
bitmap.fill(screen.machine().pens[0x7ff], cliprect); //black pen
m_sc0_tilemap->set_scrollx(0, (SEIBU_CRTC_SC0_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
m_sc0_tilemap->set_scrolly(0, (SEIBU_CRTC_SC0_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
m_sc2_tilemap->set_scrollx(0, (SEIBU_CRTC_SC2_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
m_sc2_tilemap->set_scrolly(0, (SEIBU_CRTC_SC2_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
m_sc1_tilemap->set_scrollx(0, (SEIBU_CRTC_SC1_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
m_sc1_tilemap->set_scrolly(0, (SEIBU_CRTC_SC1_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
(SEIBU_CRTC_SC3_PAGE_SEL ? m_sc3_tilemap_0 : m_sc3_tilemap_1)->set_scrollx(0, (SEIBU_CRTC_FIX_SX+64) & 0x1ff );
(SEIBU_CRTC_SC3_PAGE_SEL ? m_sc3_tilemap_0 : m_sc3_tilemap_1)->set_scrolly(0, (SEIBU_CRTC_FIX_SY+1) & 0x1ff );
if(SEIBU_CRTC_ENABLE_SC0) { m_sc0_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 2); }
if(SEIBU_CRTC_ENABLE_SC2) { m_sc2_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 1); }
if(SEIBU_CRTC_ENABLE_SC1) { m_sc1_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 0); }
if(SEIBU_CRTC_ENABLE_SC3) { (SEIBU_CRTC_SC3_PAGE_SEL ? m_sc3_tilemap_0 : m_sc3_tilemap_1)->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 3); }
return 0;
}
/* Multiplexer device for the mahjong panel */
READ16_MEMBER(sengokmj_state::mahjong_panel_r)
@ -123,19 +385,19 @@ READ16_MEMBER(sengokmj_state::sengokmj_system_r)
static ADDRESS_MAP_START( sengokmj_map, AS_PROGRAM, 16, sengokmj_state )
AM_RANGE(0x00000, 0x07fff) AM_RAM
AM_RANGE(0x08000, 0x09fff) AM_RAM AM_SHARE("nvram")
AM_RANGE(0x0c000, 0x0c7ff) AM_RAM_WRITE_LEGACY(seibucrtc_sc0vram_w) AM_SHARE("crtc_sc0vram")
AM_RANGE(0x0c800, 0x0cfff) AM_RAM_WRITE_LEGACY(seibucrtc_sc1vram_w) AM_SHARE("crtc_sc1vram")
AM_RANGE(0x0d000, 0x0d7ff) AM_RAM_WRITE_LEGACY(seibucrtc_sc2vram_w) AM_SHARE("crtc_sc2vram")
AM_RANGE(0x0d800, 0x0e7ff) AM_RAM_WRITE_LEGACY(seibucrtc_sc3vram_w) AM_SHARE("crtc_sc3vram")
AM_RANGE(0x0c000, 0x0c7ff) AM_RAM_WRITE(seibucrtc_sc0vram_w) AM_SHARE("sc0_vram")
AM_RANGE(0x0c800, 0x0cfff) AM_RAM_WRITE(seibucrtc_sc1vram_w) AM_SHARE("sc1_vram")
AM_RANGE(0x0d000, 0x0d7ff) AM_RAM_WRITE(seibucrtc_sc2vram_w) AM_SHARE("sc2_vram")
AM_RANGE(0x0d800, 0x0e7ff) AM_RAM_WRITE(seibucrtc_sc3vram_w) AM_SHARE("sc3_vram")
AM_RANGE(0x0e800, 0x0f7ff) AM_RAM_WRITE(paletteram_xBBBBBGGGGGRRRRR_word_w) AM_SHARE("paletteram")
AM_RANGE(0x0f800, 0x0ffff) AM_RAM AM_SHARE("spriteram")
AM_RANGE(0x0f800, 0x0ffff) AM_RAM AM_SHARE("sprite_ram")
AM_RANGE(0xc0000, 0xfffff) AM_ROM
ADDRESS_MAP_END
static ADDRESS_MAP_START( sengokmj_io_map, AS_IO, 16, sengokmj_state )
AM_RANGE(0x4000, 0x400f) AM_READWRITE_LEGACY(seibu_main_word_r, seibu_main_word_w)
/*Areas from 8000-804f are for the custom Seibu CRTC.*/
AM_RANGE(0x8000, 0x804f) AM_RAM_WRITE_LEGACY(seibucrtc_vregs_w) AM_SHARE("crtc_vregs")
AM_RANGE(0x8000, 0x804f) AM_RAM_WRITE(seibucrtc_vregs_w) AM_SHARE("crtc_vregs")
// AM_RANGE(0x8080, 0x8081) CRTC extra register?
// AM_RANGE(0x80c0, 0x80c1) CRTC extra register?
@ -315,13 +577,11 @@ static MACHINE_CONFIG_START( sengokmj, sengokmj_state )
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
MCFG_SCREEN_SIZE(64*8, 32*8)
MCFG_SCREEN_VISIBLE_AREA(0, 320-1, 16, 256-1) //TODO: dynamic resolution
MCFG_SCREEN_UPDATE_STATIC(seibu_crtc)
MCFG_SCREEN_UPDATE_DRIVER(sengokmj_state, screen_update_sengokmj)
MCFG_GFXDECODE(sengokmj)
MCFG_PALETTE_LENGTH(0x800)
MCFG_VIDEO_START(seibu_crtc)
/* sound hardware */
SEIBU_SOUND_SYSTEM_YM3812_INTERFACE(14318180/4,1320000)
MACHINE_CONFIG_END

View File

@ -26,7 +26,7 @@ const device_type XXX = &device_creator<xxx_device>;
//-------------------------------------------------
xxx_device::xxx_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock)
: device_t(mconfig, XXX, "xxx", tag, owner, clock)
: device_t(mconfig, XXX, "xxx_longname", tag, owner, clock, "xxx", __FILE__)
{
}

View File

@ -1602,7 +1602,7 @@ $(MAMEOBJ)/seibu.a: \
$(MACHINE)/seicop.o \
$(MACHINE)/spisprit.o \
$(AUDIO)/seibu.o \
$(VIDEO)/sei_crtc.o \
$(VIDEO)/seibu_crtc.o \
$(MAMEOBJ)/seta.a: \
$(DRIVERS)/aleck64.o $(MACHINE)/n64.o $(VIDEO)/n64.o $(VIDEO)/rdpblend.o $(VIDEO)/rdpspn16.o $(VIDEO)/rdptpipe.o \

View File

@ -1,341 +0,0 @@
/******************************************************************************************
Seibu Custom "CRT Controller" emulation
by Angelo Salese,based off the old D-Con video HW part by Bryan McPhail
The (likely) custom Seibu CRTC is used at least in the following games:
Raiden (probably the first game to use it)
*Sengoku Mahjong
*Good e Jong
*Tottemo de Jong
Blood Bros.
Sky Smasher
D-Con
SD Gundam Psycho Salamander no Kyoui
(all games in legionna.c)
(all games in raiden2.c)
(all games in seibuspi.c)
The name "Seibu CRTC" is actually an agglomerate of all the Seibu Customs that are on the
single boards, most if not all of them are shared video chips in the aforementioned games.
TODO:
- Needs a full device rewrite, presumably device split too (where CRTC and tilemap are on different chip emulation).
- Dynamic Resolution Change (xx10 register?)
- Dynamic Paging register probably incorrect,needs further investigation;
- Merge the aforementioned games and clean-up the code in these drivers;
- Merge the gfxdecode too?
- Fully understand remaining video registers;
- Are the xx80/xxc0 in some games (D-Con/Sengoku Mahjong) another bunch of registers?
- Investigate about the real name(s) of this Seibu "CRT Controller",and if it is really
custom.
===========================================================================================
List of default vregs (title screen):
*Sengoku Mahjong:
8000: 000F 0013 009F 00BF 00FA 000F 00FA 00FF
8010: 007D 0006 0000 0002 0000 0000 0000 0000
8020: 0000 0000 0004 0000 0000 0000 0040 01FF
8030: 003E 01FF 003F 01FF 0040 0001 0034 0035
8040: 0000 A8A8 0003 1C37 0001 0000 0000 0000
*Tottemo de Jong
8000: 000F 000F 009F 00BF 00FA 000F 00FA 00FF
8010: 0076 0006 0000 0002 0000 0002 0006 0000
8020: 0000 0000 0000 0000 0000 0000 01C0 01FF
8030: 003E 01FF 003F 01FF 00C0 01FF 0034 003F
8040: 0000 A8A8 0003 1830 0001 0000 0000 0000
*Good e Jong
8040: 000F 000F 009F 00BF 00FA 000F 00FA 00FF
8050: 0076 0006 0000 0002 0000 0002 0006 0000
8060: 0000 00FA 0000 0000 0000 0000 01C0 01FF
8070: 003E 01FF 003F 01FF 00C0 01FF 0034 003F
8080: 0000 0000 0000 0000 0000 0000 0000 0000
*SD Gundam Sangokushi Rainbow Tairiku Senki (320 x 224 normal, @ service mode)
100600: 000F 0013 00A7 00C7 00E0 000F 00E7 00F3
100610: 007E 01FE 0000 0002 0000 0000 0017 0000
100620: 0000 0000 0000 0000 0000 0000 01C8 01FF
100630: 01CA 01FF 01C9 01FF 01C8 01FF 0034 003F
100640: 0000 A8A8 001E 1C37 0008 0000 0000 FFFF
(320 x 224, flipped)
100600: 000F 0013 00A7 00C7 00E0 000F 00E7 00F3
100610: 007E 01FE 0000 0002 0000 0001 0017 0000
100620: 0001 0000 0000 0000 0000 0000 0177 0100
100630: 0175 0100 0176 0100 0177 0100 0034 003F
100640: 0000 A8A8 00E1 1C37 0018 0000 013F FFFF
(320 x 256, normal)
100600: 000F 0013 00A7 00C7 00E0 000F 00E1 00E9
100610: 0076 01FE 0000 0002 0000 0000 0017 0000
100620: 0002 0000 0000 0000 0000 0000 01C8 0207
100630: 01CA 0207 01C9 0207 01C8 0207 0034 003F
100640: 0000 A8A8 0016 1C37 0008 0000 0000 FFFF
(320 x 256, flipped)
100600: 000F 0013 00A7 00C7 00E0 000F 00E1 00E9
100610: 0076 01FE 0000 0002 0000 0001 0017 0000
100620: 0003 0000 0000 0000 0000 0000 0178 02F8
100630: 0175 02F8 0176 02F8 0177 02F8 0034 003F
100640: 0000 A8A8 00E9 1C37 0018 0000 013F FFFF
(320 x 240, normal)
100600: 000F 0013 00A7 00C7 00FA 000F 00FA 00FF
100610: 0076 0006 0000 0002 0000 0000 0017 0000
100620: 0004 0000 0000 0000 0000 0000 01D8 01FF
100630: 01DA 01FF 01D9 01FF 01D8 01FF 0034 003F
100640: 0000 A8A8 0004 1C37 0008 0000 0000 FFFF
(320 x 240, flipped)
100600: 000F 0013 00A7 00C7 00FA 000F 00FA 00FF
100610: 0076 0006 0000 0002 0000 0001 0017 0000
100620: 0005 0000 0000 0000 0000 0000 0187 0300
100630: 0185 0300 0186 0300 0185 0300 0034 003F
100640: 0000 A8A8 00FB 1C37 0018 0000 013F FFFF
*******************************************************************************************/
#include "emu.h"
#include "includes/sei_crtc.h"
static tilemap_t *sc0_tilemap,*sc2_tilemap,*sc1_tilemap,*sc3_tilemap_0,*sc3_tilemap_1;
static UINT16 *seibucrtc_sc0vram,*seibucrtc_sc1vram,*seibucrtc_sc2vram,*seibucrtc_sc3vram;
static UINT16 *seibucrtc_vregs;
UINT16 seibucrtc_sc0bank;
/*******************************
*
* Macros for the video registers
*
*******************************/
/*******************************
* 0x1a - Layer Dynamic Paging?
*******************************/
#define SEIBU_CRTC_DYN_PAGING (seibucrtc_vregs[0x001a/2])
#define SEIBU_CRTC_SC3_PAGE_SEL (SEIBU_CRTC_DYN_PAGING & 0x0002)
/*******************************
* 0x1c - Layer Enable
*******************************/
#define SEIBU_CRTC_LAYER_EN (seibucrtc_vregs[0x001c/2])
#define SEIBU_CRTC_ENABLE_SC0 (!(SEIBU_CRTC_LAYER_EN & 0x0001))
#define SEIBU_CRTC_ENABLE_SC2 (!(SEIBU_CRTC_LAYER_EN & 0x0002))
#define SEIBU_CRTC_ENABLE_SC1 (!(SEIBU_CRTC_LAYER_EN & 0x0004))
#define SEIBU_CRTC_ENABLE_SC3 (!(SEIBU_CRTC_LAYER_EN & 0x0008))
#define SEIBU_CRTC_ENABLE_SPR (!(SEIBU_CRTC_LAYER_EN & 0x0010))
/************************************
* 0x20 - Screen 0 (BG) scroll x
************************************/
#define SEIBU_CRTC_SC0_SX (seibucrtc_vregs[0x0020/2])
/************************************
* 0x22 - Screen 0 (BG) scroll y
************************************/
#define SEIBU_CRTC_SC0_SY (seibucrtc_vregs[0x0022/2])
/************************************
* 0x24 - Screen 1 (FG) scroll x
************************************/
#define SEIBU_CRTC_SC1_SX (seibucrtc_vregs[0x0028/2])
/************************************
* 0x26 - Screen 1 (FG) scroll y
************************************/
#define SEIBU_CRTC_SC1_SY (seibucrtc_vregs[0x002a/2])
/************************************
* 0x28 - Screen 2 (MD) scroll x
************************************/
#define SEIBU_CRTC_SC2_SX (seibucrtc_vregs[0x0024/2])
/************************************
* 0x2a - Screen 2 (MD) scroll y
************************************/
#define SEIBU_CRTC_SC2_SY (seibucrtc_vregs[0x0026/2])
/************************************
* 0x2c - Fix screen scroll x (global)
************************************/
#define SEIBU_CRTC_FIX_SX (seibucrtc_vregs[0x002c/2])
/************************************
* 0x2e - Fix screen scroll y (global)
************************************/
#define SEIBU_CRTC_FIX_SY (seibucrtc_vregs[0x002e/2])
/*******************************
*
* Write RAM accesses
*
*******************************/
WRITE16_HANDLER( seibucrtc_sc0vram_w )
{
COMBINE_DATA(&seibucrtc_sc0vram[offset]);
sc0_tilemap->mark_tile_dirty(offset);
}
WRITE16_HANDLER( seibucrtc_sc2vram_w )
{
COMBINE_DATA(&seibucrtc_sc2vram[offset]);
sc2_tilemap->mark_tile_dirty(offset);
}
WRITE16_HANDLER( seibucrtc_sc1vram_w )
{
COMBINE_DATA(&seibucrtc_sc1vram[offset]);
sc1_tilemap->mark_tile_dirty(offset);
}
WRITE16_HANDLER( seibucrtc_sc3vram_w )
{
COMBINE_DATA(&seibucrtc_sc3vram[offset]);
sc3_tilemap_0->mark_tile_dirty(offset);
sc3_tilemap_1->mark_tile_dirty(offset);
}
WRITE16_HANDLER( seibucrtc_vregs_w )
{
COMBINE_DATA(&seibucrtc_vregs[offset]);
}
/* Actually external from the CRTC */
void seibucrtc_sc0bank_w(UINT16 data)
{
seibucrtc_sc0bank = data & 1;
sc0_tilemap->mark_all_dirty();
}
/*******************************
*
* Tilemap info accesses
*
*******************************/
static TILE_GET_INFO( seibucrtc_sc0_tile_info )
{
int tile = seibucrtc_sc0vram[tile_index] & 0xfff;
int color = (seibucrtc_sc0vram[tile_index] >> 12) & 0x0f;
tile+=(seibucrtc_sc0bank<<12);
SET_TILE_INFO(1, tile, color, 0);
}
static TILE_GET_INFO( seibucrtc_sc2_tile_info )
{
int tile = seibucrtc_sc2vram[tile_index] & 0xfff;
int color = (seibucrtc_sc2vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO(2, tile, color, 0);
}
static TILE_GET_INFO( seibucrtc_sc1_tile_info )
{
int tile = seibucrtc_sc1vram[tile_index] & 0xfff;
int color = (seibucrtc_sc1vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO(3, tile, color, 0);
}
static TILE_GET_INFO( seibucrtc_sc3_tile_info )
{
int tile = seibucrtc_sc3vram[tile_index] & 0xfff;
int color = (seibucrtc_sc3vram[tile_index] >> 12) & 0x0f;
SET_TILE_INFO(4, tile, color, 0);
}
static void draw_sprites(running_machine &machine, bitmap_ind16 &bitmap,const rectangle &cliprect,int pri)
{
UINT16 *spriteram16 = reinterpret_cast<UINT16 *>(machine.root_device().memshare("spriteram")->ptr());
int offs,fx,fy,x,y,color,sprite;
int dx,dy,ax,ay;
for (offs = 0x400-4;offs >= 0;offs -= 4)
{
if ((spriteram16[offs+0]&0x8000)!=0x8000) continue;
sprite = spriteram16[offs+1];
if ((sprite>>14)!=pri) continue;
sprite &= 0x1fff;
y = spriteram16[offs+3];
x = spriteram16[offs+2];
if (x&0x8000) x=0-(0x200-(x&0x1ff));
else x&=0x1ff;
if (y&0x8000) y=0-(0x200-(y&0x1ff));
else y&=0x1ff;
color = spriteram16[offs+0]&0x3f;
fx = spriteram16[offs+0]&0x4000;
fy = spriteram16[offs+0]&0x2000;
dy=((spriteram16[offs+0]&0x0380)>>7)+1;
dx=((spriteram16[offs+0]&0x1c00)>>10)+1;
for (ax=0; ax<dx; ax++)
for (ay=0; ay<dy; ay++) {
if (!fx)
drawgfx_transpen(bitmap,cliprect,machine.gfx[0],
sprite++,
color,fx,fy,x+ax*16,y+ay*16,15);
else
drawgfx_transpen(bitmap,cliprect,machine.gfx[0],
sprite++,
color,fx,fy,x+(dx-1-ax)*16,y+ay*16,15);
}
}
}
/***********************************
*
* VIDEO_START/VIDEO_UPDATE functions
*
***********************************/
VIDEO_START( seibu_crtc )
{
seibucrtc_sc0vram = reinterpret_cast<UINT16 *>(machine.root_device().memshare("crtc_sc0vram")->ptr());
seibucrtc_sc1vram = reinterpret_cast<UINT16 *>(machine.root_device().memshare("crtc_sc1vram")->ptr());
seibucrtc_sc2vram = reinterpret_cast<UINT16 *>(machine.root_device().memshare("crtc_sc2vram")->ptr());
seibucrtc_sc3vram = reinterpret_cast<UINT16 *>(machine.root_device().memshare("crtc_sc3vram")->ptr());
seibucrtc_vregs = reinterpret_cast<UINT16 *>(machine.root_device().memshare("crtc_vregs")->ptr());
sc0_tilemap = tilemap_create(machine, seibucrtc_sc0_tile_info,TILEMAP_SCAN_ROWS,16,16,32,32);
sc2_tilemap = tilemap_create(machine, seibucrtc_sc2_tile_info,TILEMAP_SCAN_ROWS,16,16,32,32);
sc1_tilemap = tilemap_create(machine, seibucrtc_sc1_tile_info,TILEMAP_SCAN_ROWS,16,16,32,32);
sc3_tilemap_0 = tilemap_create(machine, seibucrtc_sc3_tile_info,TILEMAP_SCAN_ROWS, 8, 8,32,32);
sc3_tilemap_1 = tilemap_create(machine, seibucrtc_sc3_tile_info,TILEMAP_SCAN_ROWS, 8, 8,64,32);
sc2_tilemap->set_transparent_pen(15);
sc1_tilemap->set_transparent_pen(15);
sc3_tilemap_0->set_transparent_pen(15);
sc3_tilemap_1->set_transparent_pen(15);
seibucrtc_sc0bank = 0;
}
SCREEN_UPDATE_IND16( seibu_crtc )
{
bitmap.fill(screen.machine().pens[0x7ff], cliprect); //black pen
sc0_tilemap->set_scrollx(0, (SEIBU_CRTC_SC0_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
sc0_tilemap->set_scrolly(0, (SEIBU_CRTC_SC0_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
sc2_tilemap->set_scrollx(0, (SEIBU_CRTC_SC2_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
sc2_tilemap->set_scrolly(0, (SEIBU_CRTC_SC2_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
sc1_tilemap->set_scrollx(0, (SEIBU_CRTC_SC1_SX + SEIBU_CRTC_FIX_SX+64) & 0x1ff );
sc1_tilemap->set_scrolly(0, (SEIBU_CRTC_SC1_SY + SEIBU_CRTC_FIX_SY+1) & 0x1ff );
(SEIBU_CRTC_SC3_PAGE_SEL ? sc3_tilemap_0 : sc3_tilemap_1)->set_scrollx(0, (SEIBU_CRTC_FIX_SX+64) & 0x1ff );
(SEIBU_CRTC_SC3_PAGE_SEL ? sc3_tilemap_0 : sc3_tilemap_1)->set_scrolly(0, (SEIBU_CRTC_FIX_SY+1) & 0x1ff );
if(SEIBU_CRTC_ENABLE_SC0) { sc0_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 2); }
if(SEIBU_CRTC_ENABLE_SC2) { sc2_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 1); }
if(SEIBU_CRTC_ENABLE_SC1) { sc1_tilemap->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 0); }
if(SEIBU_CRTC_ENABLE_SC3) { (SEIBU_CRTC_SC3_PAGE_SEL ? sc3_tilemap_0 : sc3_tilemap_1)->draw(bitmap, cliprect, 0,0); }
if(SEIBU_CRTC_ENABLE_SPR) { draw_sprites(screen.machine(), bitmap,cliprect, 3); }
return 0;
}

202
src/mame/video/seibu_crtc.c Normal file
View File

@ -0,0 +1,202 @@
/***************************************************************************
Seibu Custom "CRT Controller" emulation
Template to replace "legacy" version.
written by Angelo Salese
preliminary memory map:
(screen 0 -> Background)
(screen 1 -> Foreground)
(screen 2 -> Midground)
(screen 3 -> Text layer)
[0x00]: Single cell H size +1?
[0x02]: Total number of visible cells +1?
[0x1a]: Layer Dynamic Paging?
[0x1c]: Layer Enable
---x ---- sprite enable
---- x--- tilemap screen 3 enable
---- -x-- tilemap screen 1 enable
---- --x- tilemap screen 2 enable
---- ---x tilemap screen 0 enable
[0x20]: Tilemap Screen 0 scroll X
[0x22]: Tilemap Screen 0 scroll Y
[0x24]: Tilemap Screen 2 scroll X
[0x26]: Tilemap Screen 2 scroll Y
[0x28]: Tilemap Screen 1 scroll X
[0x2a]: Tilemap Screen 1 scroll Y
[0x2c]: Tilemap Screen 0 base scroll X
[0x2e]: Tilemap Screen 0 base scroll Y
[0x30]: Tilemap Screen 2 base scroll X
[0x32]: Tilemap Screen 2 base scroll Y
[0x34]: Tilemap Screen 1 base scroll X
[0x36]: Tilemap Screen 1 base scroll Y
[0x38]: Tilemap Screen 3 base scroll X
[0x3a]: Tilemap Screen 3 base scroll Y
===========================================================================================
List of default vregs (title screen):
*Sengoku Mahjong:
8000: 000F 0013 009F 00BF 00FA 000F 00FA 00FF
8010: 007D 0006 0000 0002 0000 0000 0000 0000
8020: 0000 0000 0004 0000 0000 0000 0040 01FF
8030: 003E 01FF 003F 01FF 0040 0001 0034 0035
8040: 0000 A8A8 0003 1C37 0001 0000 0000 0000
*Tottemo de Jong
8000: 000F 000F 009F 00BF 00FA 000F 00FA 00FF
8010: 0076 0006 0000 0002 0000 0002 0006 0000
8020: 0000 0000 0000 0000 0000 0000 01C0 01FF
8030: 003E 01FF 003F 01FF 00C0 01FF 0034 003F
8040: 0000 A8A8 0003 1830 0001 0000 0000 0000
*Good e Jong
8040: 000F 000F 009F 00BF 00FA 000F 00FA 00FF
8050: 0076 0006 0000 0002 0000 0002 0006 0000
8060: 0000 00FA 0000 0000 0000 0000 01C0 01FF
8070: 003E 01FF 003F 01FF 00C0 01FF 0034 003F
8080: 0000 0000 0000 0000 0000 0000 0000 0000
*SD Gundam Sangokushi Rainbow Tairiku Senki (320 x 224 normal, @ service mode)
100600: 000F 0013 00A7 00C7 00E0 000F 00E7 00F3
100610: 007E 01FE 0000 0002 0000 0000 0017 0000
100620: 0000 0000 0000 0000 0000 0000 01C8 01FF
100630: 01CA 01FF 01C9 01FF 01C8 01FF 0034 003F
100640: 0000 A8A8 001E 1C37 0008 0000 0000 FFFF
(320 x 224, flipped)
100600: 000F 0013 00A7 00C7 00E0 000F 00E7 00F3
100610: 007E 01FE 0000 0002 0000 0001 0017 0000
100620: 0001 0000 0000 0000 0000 0000 0177 0100
100630: 0175 0100 0176 0100 0177 0100 0034 003F
100640: 0000 A8A8 00E1 1C37 0018 0000 013F FFFF
(320 x 256, normal)
100600: 000F 0013 00A7 00C7 00E0 000F 00E1 00E9
100610: 0076 01FE 0000 0002 0000 0000 0017 0000
100620: 0002 0000 0000 0000 0000 0000 01C8 0207
100630: 01CA 0207 01C9 0207 01C8 0207 0034 003F
100640: 0000 A8A8 0016 1C37 0008 0000 0000 FFFF
(320 x 256, flipped)
100600: 000F 0013 00A7 00C7 00E0 000F 00E1 00E9
100610: 0076 01FE 0000 0002 0000 0001 0017 0000
100620: 0003 0000 0000 0000 0000 0000 0178 02F8
100630: 0175 02F8 0176 02F8 0177 02F8 0034 003F
100640: 0000 A8A8 00E9 1C37 0018 0000 013F FFFF
(320 x 240, normal)
100600: 000F 0013 00A7 00C7 00FA 000F 00FA 00FF
100610: 0076 0006 0000 0002 0000 0000 0017 0000
100620: 0004 0000 0000 0000 0000 0000 01D8 01FF
100630: 01DA 01FF 01D9 01FF 01D8 01FF 0034 003F
100640: 0000 A8A8 0004 1C37 0008 0000 0000 FFFF
(320 x 240, flipped)
100600: 000F 0013 00A7 00C7 00FA 000F 00FA 00FF
100610: 0076 0006 0000 0002 0000 0001 0017 0000
100620: 0005 0000 0000 0000 0000 0000 0187 0300
100630: 0185 0300 0186 0300 0185 0300 0034 003F
100640: 0000 A8A8 00FB 1C37 0018 0000 013F FFFF
*Legionnaire (attract mode, that definitely runs with an horizontal res of 256)
100600: 000F 000F 00B0 00D7 00FA 000F 00FA 00FF
100610: 0076 0006 0000 0002 0000 0000 0000 0000
100620: 0000 0000 0000 0000 0000 0000 01D8 01FF
100630: 01DA 01FF 01D9 01FF 01D8 01FF 0034 003F
100640: 0000 A8A8 0004 1830 0009 0000 0000 FFFF
***************************************************************************/
#include "emu.h"
#include "video/seibu_crtc.h"
//**************************************************************************
// GLOBAL VARIABLES
//**************************************************************************
// device type definition
const device_type SEIBU_CRTC = &device_creator<seibu_crtc_device>;
//**************************************************************************
// LIVE DEVICE
//**************************************************************************
//-------------------------------------------------
// seibu_crtc_device - constructor
//-------------------------------------------------
seibu_crtc_device::seibu_crtc_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock)
: device_t(mconfig, SEIBU_CRTC, "Seibu CRT Controller", tag, owner, clock, "seibu_crtc", __FILE__)
{
}
//-------------------------------------------------
// device_validity_check - perform validity checks
// on this device
//-------------------------------------------------
void seibu_crtc_device::device_validity_check(validity_checker &valid) const
{
}
//-------------------------------------------------
// device_config_complete - perform any
// operations now that the configuration is
// complete
//-------------------------------------------------
void seibu_crtc_device::device_config_complete()
{
// inherit a copy of the static data
const seibu_crtc_interface *intf = reinterpret_cast<const seibu_crtc_interface *>(static_config());
if (intf != NULL)
*static_cast<seibu_crtc_interface *>(this) = *intf;
// or initialize to defaults if none provided
else
{
m_screen_tag = "";
}
}
//-------------------------------------------------
// device_start - device-specific startup
//-------------------------------------------------
void seibu_crtc_device::device_start()
{
m_screen = machine().device<screen_device>(m_screen_tag);
}
//-------------------------------------------------
// device_reset - device-specific reset
//-------------------------------------------------
void seibu_crtc_device::device_reset()
{
}
//**************************************************************************
// INLINE HELPERS
//**************************************************************************
//**************************************************************************
// READ/WRITE HANDLERS
//**************************************************************************
READ16_MEMBER( seibu_crtc_device::read )
{
return 0;
}
WRITE16_MEMBER( seibu_crtc_device::write )
{
// ...
}

View File

@ -0,0 +1,74 @@
/***************************************************************************
Template for skeleton device
***************************************************************************/
#pragma once
#ifndef __SEIBU_CRTCDEV_H__
#define __SEIBU_CRTCDEV_H__
struct seibu_crtc_interface
{
const char *m_screen_tag;
// TODO: layer enable, scrolling
};
//**************************************************************************
// INTERFACE CONFIGURATION MACROS
//**************************************************************************
#define MCFG_SEIBU_CRTC_ADD(_tag,_config,_freq) \
MCFG_DEVICE_ADD(_tag, SEIBU_CRTC, _freq) \
MCFG_DEVICE_CONFIG(_config)
#define SEIBU_CRTC_INTERFACE(name) \
const seibu_crtc_interface (name) =
//**************************************************************************
// TYPE DEFINITIONS
//**************************************************************************
// ======================> seibu_crtc_device
class seibu_crtc_device : public device_t,
public seibu_crtc_interface
{
public:
// construction/destruction
seibu_crtc_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
// I/O operations
DECLARE_WRITE16_MEMBER( write );
DECLARE_READ16_MEMBER( read );
protected:
// device-level overrides
virtual void device_validity_check(validity_checker &valid) const;
virtual void device_config_complete();
virtual void device_start();
virtual void device_reset();
screen_device *m_screen;
private:
const address_space_config m_space_config;
inline UINT16 read_word(offs_t address);
inline void write_word(offs_t address, UINT16 data);
};
// device type definition
extern const device_type SEIBU_CRTC;
//**************************************************************************
// GLOBAL VARIABLES
//**************************************************************************
#endif