📄 slapfght.c
字号:
/***************************************************************************
machine.c
Functions to emulate general aspects of the machine (RAM, ROM, interrupts,
I/O ports)
***************************************************************************/
#include "driver.h"
unsigned char *slapfight_dpram;
int slapfight_dpram_size;
int slapfight_status;
int getstar_sequence_index;
int getstar_sh_intenabled;
static int slapfight_status_state;
extern unsigned char *getstar_e803;
/* Perform basic machine initialisation */
void slapfight_init_machine(void)
{
/* MAIN CPU */
slapfight_status_state=0;
slapfight_status = 0xc7;
getstar_sequence_index = 0;
getstar_sh_intenabled = 0; /* disable sound cpu interrupts */
/* SOUND CPU */
cpu_halt(1,0);
}
/* Interrupt handlers cpu & sound */
void slapfight_dpram_w(int offset, int data)
{
slapfight_dpram[offset]=data;
return;
}
int slapfight_dpram_r(int offset)
{
return slapfight_dpram[offset];
}
/* Slapfight CPU input/output ports
These ports seem to control memory access
*/
/* Reset and hold sound CPU */
void slapfight_port_00_w(int offset, int data)
{
cpu_halt(1,0);
getstar_sh_intenabled = 0;
}
/* Release reset on sound CPU */
void slapfight_port_01_w(int offset, int data)
{
cpu_halt(1,1);
cpu_reset(1);
cpu_yield();
}
/* Disable and clear hardware interrupt */
void slapfight_port_06_w(int offset, int data)
{
interrupt_enable_w(0,0);
}
/* Enable hardware interrupt */
void slapfight_port_07_w(int offset, int data)
{
interrupt_enable_w(0,1);
}
void slapfight_port_08_w(int offset, int data)
{
unsigned char *RAM = Machine->memory_region[Machine->drv->cpu[0].memory_region];
cpu_setbank(1,&RAM[0x10000]);
}
void slapfight_port_09_w(int offset, int data)
{
unsigned char *RAM = Machine->memory_region[Machine->drv->cpu[0].memory_region];
cpu_setbank(1,&RAM[0x14000]);
}
/* Status register */
int slapfight_port_00_r(int offset)
{
int states[3]={ 0xc7, 0x55, 0x00 };
slapfight_status = states[slapfight_status_state];
slapfight_status_state++;
if (slapfight_status_state > 2) slapfight_status_state = 0;
return slapfight_status;
}
/*
Reads at e803 expect a sequence of values such that:
- first value is different from successive
- third value is (first+5)^0x56
I don't know what writes to this address do (connected to port 0 reads?).
*/
int getstar_e803_r(int offset)
{
unsigned char seq[] = { 0, 1, (0+5)^0x56 };
unsigned char val;
val = seq[getstar_sequence_index];
getstar_sequence_index = (getstar_sequence_index+1)%3;
return val;
}
/* Enable hardware interrupt of sound cpu */
void getstar_sh_intenable_w(int offset, int data)
{
getstar_sh_intenabled = 1;
}
/* Generate interrups only if they have been enabled */
int getstar_interrupt(void)
{
if (getstar_sh_intenabled)
return nmi_interrupt();
else
return ignore_interrupt();
}
void getstar_port_04_w(int offset, int data)
{
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -