snes9x2005/source/seta011.c

103 lines
2.3 KiB
C
Raw Normal View History

#include "../copyright"
2014-10-29 23:23:30 +00:00
2011-03-06 02:39:25 +00:00
#include "seta.h"
#include "memmap.h"
ST011_Regs ST011;
uint8_t board[9][9]; /* shougi playboard */
2011-03-06 02:39:25 +00:00
2014-11-03 14:26:54 +00:00
uint8_t S9xGetST011(uint32_t Address)
2011-03-06 02:39:25 +00:00
{
2014-11-03 14:26:54 +00:00
uint8_t t;
uint16_t address = (uint16_t) Address & 0xFFFF;
2014-10-29 23:23:30 +00:00
if (address == 0x01) /* status check */
2014-10-29 23:23:30 +00:00
t = 0xFF;
else /* read directly from s-ram */
2014-10-29 23:23:30 +00:00
t = Memory.SRAM[address];
return t;
2011-03-06 02:39:25 +00:00
}
2014-11-03 14:26:54 +00:00
void S9xSetST011(uint32_t Address, uint8_t Byte)
2011-03-06 02:39:25 +00:00
{
2014-11-03 14:26:54 +00:00
uint16_t address = (uint16_t) Address & 0xFFFF;
2014-10-29 23:23:30 +00:00
static bool reset = false;
if (!reset) /* bootup values */
2014-10-29 23:23:30 +00:00
{
ST011.waiting4command = true;
reset = true;
}
Memory.SRAM[address] = Byte;
if (address == 0x00) /* op commands/data goes through this address */
2014-10-29 23:23:30 +00:00
{
if (ST011.waiting4command) /* check for new commands */
2014-10-29 23:23:30 +00:00
{
ST011.waiting4command = false;
ST011.command = Byte;
ST011.in_index = 0;
ST011.out_index = 0;
switch (ST011.command)
{
case 0x01:
ST011.in_count = 12 * 10 + 8;
break;
case 0x02:
ST011.in_count = 4;
break;
case 0x04:
case 0x05:
case 0x06:
case 0x07:
case 0x0E:
ST011.in_count = 0;
break;
default:
ST011.waiting4command = true;
break;
}
}
else
{
ST011.parameters [ST011.in_index] = Byte;
ST011.in_index++;
}
}
if (ST011.in_count == ST011.in_index) /* Actually execute the command */
2014-10-29 23:23:30 +00:00
{
ST011.waiting4command = true;
ST011.out_index = 0;
switch (ST011.command)
{
case 0x01: /* unknown: download playboard */
2014-10-29 23:23:30 +00:00
{
/* 9x9 board data: top to bottom, left to right */
/* Values represent piece types and ownership */
int32_t lcv;
2014-10-29 23:23:30 +00:00
for (lcv = 0; lcv < 9; lcv++)
memcpy(board[lcv], ST011.parameters + lcv * 10, 9 * 1);
break;
2014-10-29 23:23:30 +00:00
}
case 0x04: /* unknown */
2014-10-29 23:23:30 +00:00
case 0x05:
{
/* outputs */
2014-10-29 23:23:30 +00:00
Memory.SRAM[0x12C] = 0x00;
Memory.SRAM[0x12E] = 0x00;
break;
2014-10-29 23:23:30 +00:00
}
case 0x0E: /* unknown */
2014-10-29 23:23:30 +00:00
{
/* outputs */
2014-10-29 23:23:30 +00:00
Memory.SRAM[0x12C] = 0x00;
Memory.SRAM[0x12D] = 0x00;
break;
2014-10-29 23:23:30 +00:00
}
}
}
2011-03-06 02:39:25 +00:00
}