Changed keycus into a device and moved it into it's own file, only 3 parameters are saved instead of 64k. Changed I/O to 16 bits & uses memory maps instead of installing at runtime. Simplified digital player 3 inputs that are hooked up to dac inputs. [smf]

This commit is contained in:
smf- 2013-05-21 10:15:41 +00:00
parent 5fcb2d1e38
commit f14ac55805
5 changed files with 1026 additions and 697 deletions

2
.gitattributes vendored
View File

@ -5080,6 +5080,8 @@ src/mame/machine/nmk004.c svneol=native#text/plain
src/mame/machine/nmk004.h svneol=native#text/plain
src/mame/machine/nmk112.c svneol=native#text/plain
src/mame/machine/nmk112.h svneol=native#text/plain
src/mame/machine/ns11prot.c svneol=native#text/plain
src/mame/machine/ns11prot.h svneol=native#text/plain
src/mame/machine/nycaptor.c svneol=native#text/plain
src/mame/machine/opwolf.c svneol=native#text/plain
src/mame/machine/pacplus.c svneol=native#text/plain

File diff suppressed because it is too large Load Diff

486
src/mame/machine/ns11prot.c Normal file
View File

@ -0,0 +1,486 @@
/*
* Namco System 11 Protection
*
*/
#include "ns11prot.h"
ns11_keycus_device::ns11_keycus_device(const machine_config &mconfig, device_type type, const char *name, const char *tag, device_t *owner, UINT32 clock) :
device_t(mconfig, type, name, tag, owner, clock)
{
}
void ns11_keycus_device::device_start()
{
save_item( NAME( m_p1 ) );
save_item( NAME( m_p2 ) );
save_item( NAME( m_p3 ) );
}
void ns11_keycus_device::device_reset()
{
m_p1 = 0;
m_p2 = 0;
m_p3 = 0;
}
/* tekken 2 */
keycus_c406_device::keycus_c406_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C406, "KEYCUS C406", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c406_device::read)
{
if( offset == 0 && m_p1 == 0x1234 && m_p2 == 0x5678 && m_p3 == 0x000f )
{
return 0x3256;
}
logerror( "keycus_c406_device::read unexpected offset=%d m_p1=%04x m_p2=%04x m_p3=%04x\n", offset, m_p1, m_p2, m_p3 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c406_device::write)
{
switch( offset )
{
case 1:
m_p1 = data;
return;
case 2:
m_p2 = data;
return;
case 3:
m_p3 = data;
return;
}
logerror( "keycus_c406_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C406 = &device_creator<keycus_c406_device>;
/* soul edge */
keycus_c409_device::keycus_c409_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C409, "KEYCUS C409", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c409_device::read)
{
if( offset == 7 && m_p1 == 0x0006 && m_p2 == 0x0000 && m_p3 == 0x0013 )
{
return 0x000f;
}
logerror( "keycus_c409_device::read unexpected offset=%d m_p1=%04x m_p2=%04x m_p3=%04x\n", offset, m_p1, m_p2, m_p3 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c409_device::write)
{
switch( offset )
{
case 1:
m_p1 = data;
return;
case 3:
m_p2 = data;
return;
case 7:
m_p3 = data;
return;
}
logerror( "keycus_c409_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C409 = &device_creator<keycus_c409_device>;
/* dunk mania */
keycus_c410_device::keycus_c410_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C410, "KEYCUS C410", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c410_device::read)
{
if( m_p2 == 0 )
{
UINT16 value = m_p1;
if( value == 0xfffe )
{
value = 410;
}
switch(offset)
{
case 1:
return ( ( value / 1 ) % 10 );
case 2:
return ( ( value / 100 ) % 10 ) |
( ( ( value / 1000 ) % 10 ) << 8 );
case 3:
return ( ( value / 10000 ) % 10 ) |
( ( ( value / 10 ) % 10 ) << 8 );
}
}
logerror( "keycus_c410_device::read unexpected offset=%d m_p1=%04x m_p2=%04x\n", offset, m_p1, m_p2 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c410_device::write)
{
switch( offset )
{
case 0:
m_p1 = data;
return;
case 2:
m_p2 = data;
return;
}
logerror( "keycus_c410_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C410 = &device_creator<keycus_c410_device>;
/* prime goal ex */
keycus_c411_device::keycus_c411_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C411, "KEYCUS C411", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c411_device::read)
{
if( m_p2 == 0x0000 && ( ( ( m_p1 == 0x0000 || m_p1 == 0x100 ) && m_p3 == 0xff7f ) || ( m_p1 == 0x7256 ) ) )
{
UINT16 value = m_p3;
if( m_p1 != 0x7256 )
{
value = 411;
}
switch( offset )
{
case 0:
return ( ( ( value / 10 ) % 10 ) << 8 ) | ( ( value / 1 ) % 10 );
case 2:
return ( ( ( value / 1000 ) % 10 ) << 8 ) | ( ( value / 100 ) % 10 );
case 8:
return ( ( value / 10000 ) % 10 );
}
}
logerror( "keycus_c411_device::read unexpected offset=%d m_p1=%04x m_p2=%04x m_p3=%04x\n", offset, m_p1, m_p2, m_p3 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c411_device::write)
{
switch( offset )
{
case 2:
m_p1 = data;
return;
case 8:
m_p2 = data;
return;
case 10:
m_p3 = data;
return;
}
logerror( "keycus_c411_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C411 = &device_creator<keycus_c411_device>;
/* xevious 3d/g */
keycus_c430_device::keycus_c430_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C430, "KEYCUS C430", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c430_device::read)
{
if( m_p2 == 0x0000 && ( ( m_p1 == 0xbfff && m_p3 == 0x0000 ) || m_p3 == 0xe296 ) )
{
UINT16 value = m_p1;
if( m_p3 != 0xe296 )
{
value = 430;
}
switch( offset )
{
case 1:
return ( ( value / 10000 ) % 10 );
case 4:
return ( ( value / 100 ) % 10 ) |
( ( ( value / 1000 ) % 10 ) << 8 );
case 5:
return ( ( value / 1 ) % 10 ) |
( ( ( value / 10 ) % 10 ) << 8 );
}
}
logerror( "keycus_c430_device::read unexpected offset=%d m_p1=%04x m_p2=%04x\n", offset, m_p1, m_p2 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c430_device::write)
{
switch( offset )
{
case 0:
m_p1 = data;
return;
case 1:
m_p2 = data;
return;
case 4:
m_p3 = data;
return;
}
logerror( "keycus_c430_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C430 = &device_creator<keycus_c430_device>;
/* dancing eyes */
keycus_c431_device::keycus_c431_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C431, "KEYCUS C431", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c431_device::read)
{
if( m_p2 == 0x0000 && ( ( ( m_p1 == 0x0000 || m_p1 == 0xab50 ) && m_p3 == 0x7fff ) || m_p1 == 0x9e61 ) )
{
UINT16 value = m_p3;
if( m_p1 != 0x9e61 )
{
value = 431;
}
switch( offset )
{
case 0:
return ( ( value / 1 ) % 10 ) |
( ( ( value / 10 ) % 10 ) << 8 );
case 4:
return ( ( value / 100 ) % 10 ) |
( ( ( value / 1000 ) % 10 ) << 8 );
case 8:
return ( value / 10000 ) % 10;
}
}
logerror( "keycus_c431_device::read unexpected offset=%d m_p1=%04x m_p2=%04x m_p3=%04x\n", offset, m_p1, m_p2, m_p3 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c431_device::write)
{
switch( offset )
{
case 0:
m_p1 = data;
return;
case 4:
m_p2 = data;
return;
case 12:
m_p3 = data;
return;
}
logerror( "keycus_c431_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C431 = &device_creator<keycus_c431_device>;
/* pocket racer */
keycus_c432_device::keycus_c432_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C432, "KEYCUS C432", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c432_device::read)
{
if( m_p1 == 0x0000 && ( ( ( m_p3 == 0x0000 || m_p3 == 0x00dc ) && m_p2 == 0xefff ) || m_p3 == 0x2f15 ) )
{
UINT16 value = m_p2;
if( m_p3 != 0x00002f15 )
{
value = 432;
}
switch( offset )
{
case 2:
return ( ( value / 1 ) % 10 ) |
( ( ( value / 10 ) % 10 ) << 8 );
case 4:
return ( ( value / 100 ) % 10 ) |
( ( ( value / 1000 ) % 10 ) << 8 );
case 6:
return ( ( value / 10000 ) % 10 ) |
( ( ( value / 100000 ) % 10 ) << 8 );
}
}
logerror( "keycus_c432_device::read unexpected offset=%d m_p1=%04x m_p2=%04x m_p3=%04x\n", offset, m_p1, m_p2, m_p3 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c432_device::write)
{
switch( offset )
{
case 0:
m_p1 = data;
return;
case 2:
m_p2 = data;
return;
case 6:
m_p3 = data;
return;
}
logerror( "keycus_c432_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C432 = &device_creator<keycus_c432_device>;
/* star sweep */
keycus_c442_device::keycus_c442_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C442, "KEYCUS C442", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c442_device::read)
{
if( ( offset == 0 && m_p1 == 0x0020 && m_p2 == 0x0000 ) ||
( offset == 0 && m_p1 == 0x0020 && m_p2 == 0x0021 ) )
{
return 0x0000;
}
if( ( offset == 1 && m_p1 == 0x0020 && m_p2 == 0x0020 ) ||
( offset == 1 && m_p1 == 0x0020 && m_p2 == 0x3af2 ) )
{
return 0x0000;
}
if( ( offset == 1 && m_p1 == 0x0020 && m_p2 == 0x0021 ) )
{
return 0xc442;
}
logerror( "keycus_c442_device::read unexpected offset=%d m_p1=%04x m_p2=%04x\n", offset, m_p1, m_p2 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c442_device::write)
{
switch( offset )
{
case 0:
m_p1 = data;
return;
case 1:
m_p2 = data;
return;
}
logerror( "keycus_c442_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C442 = &device_creator<keycus_c442_device>;
/* kosodate quiz my angel 3 / point blank 2 */
keycus_c443_device::keycus_c443_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
ns11_keycus_device(mconfig, KEYCUS_C443, "KEYCUS C443", tag, owner, clock)
{
}
READ16_MEMBER(keycus_c443_device::read)
{
if( offset == 0 && m_p1 == 0x0020 && ( m_p2 == 0x0000 || m_p2 == 0xffff || m_p2 == 0xffe0 ) )
{
return 0x0020;
}
if( offset == 1 && m_p1 == 0x0020 && m_p2 == 0xffdf )
{
return 0x0000;
}
if( offset == 1 && m_p1 == 0x0020 && ( m_p2 == 0xffff || m_p2 == 0xffe0 ) )
{
return 0xc443;
}
logerror( "keycus_c443_device::read unexpected offset=%d m_p1=%04x m_p2=%04x\n", offset, m_p1, m_p2 );
return machine().rand();
}
WRITE16_MEMBER(keycus_c443_device::write)
{
switch( offset )
{
case 0:
m_p1 = data;
return;
case 1:
m_p2 = data;
return;
}
logerror( "keycus_c443_device::write unexpected offset=%d data=%04x\n", offset, data );
}
const device_type KEYCUS_C443 = &device_creator<keycus_c443_device>;

141
src/mame/machine/ns11prot.h Normal file
View File

@ -0,0 +1,141 @@
/*
* Namco System 11 Protection
*
*/
#include "emu.h"
class ns11_keycus_device : public device_t
{
protected:
ns11_keycus_device(const machine_config &mconfig, device_type type, const char *name, const char *tag, device_t *owner, UINT32 clock);
virtual void device_start();
virtual void device_reset();
protected:
UINT16 m_p1;
UINT16 m_p2;
UINT16 m_p3;
public:
virtual DECLARE_READ16_MEMBER( read ) = 0;
virtual DECLARE_WRITE16_MEMBER( write ) = 0;
};
/* tekken 2 */
class keycus_c406_device : public ns11_keycus_device
{
public:
keycus_c406_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C406;
/* soul edge */
class keycus_c409_device : public ns11_keycus_device
{
public:
keycus_c409_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C409;
/* dunk mania */
class keycus_c410_device : public ns11_keycus_device
{
public:
keycus_c410_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C410;
/* prime goal ex */
class keycus_c411_device : public ns11_keycus_device
{
public:
keycus_c411_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C411;
/* xevious 3d/g */
class keycus_c430_device : public ns11_keycus_device
{
public:
keycus_c430_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C430;
/* dancing eyes */
class keycus_c431_device : public ns11_keycus_device
{
public:
keycus_c431_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C431;
/* pocket racer */
class keycus_c432_device : public ns11_keycus_device
{
public:
keycus_c432_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C432;
/* star sweep */
class keycus_c442_device : public ns11_keycus_device
{
public:
keycus_c442_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C442;
/* kosodate quiz my angel 3 / point blank 2 */
class keycus_c443_device : public ns11_keycus_device
{
public:
keycus_c443_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock);
virtual DECLARE_READ16_MEMBER( read );
virtual DECLARE_WRITE16_MEMBER( write );
};
extern const device_type KEYCUS_C443;

View File

@ -1088,7 +1088,7 @@ $(MAMEOBJ)/namco.a: \
$(DRIVERS)/namcops2.o \
$(DRIVERS)/namcos1.o $(MACHINE)/namcos1.o $(VIDEO)/namcos1.o \
$(DRIVERS)/namcos10.o \
$(DRIVERS)/namcos11.o \
$(DRIVERS)/namcos11.o $(MACHINE)/ns11prot.o \
$(DRIVERS)/namcos12.o \
$(DRIVERS)/namcos2.o $(MACHINE)/namcos2.o $(VIDEO)/namcos2.o \
$(DRIVERS)/namcos21.o $(VIDEO)/namcos21.o \