mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-15 20:59:08 +01:00
commit
f573d21092
Binary file not shown.
Binary file not shown.
Before Width: | Height: | Size: 3.2 MiB After Width: | Height: | Size: 3.2 MiB |
Binary file not shown.
Before Width: | Height: | Size: 3.3 MiB After Width: | Height: | Size: 3.3 MiB |
@ -65,8 +65,8 @@ void gamepad_reset(int port)
|
|||||||
gamepad[port].Timeout = 0;
|
gamepad[port].Timeout = 0;
|
||||||
gamepad[port].Latency = 0;
|
gamepad[port].Latency = 0;
|
||||||
|
|
||||||
/* reset 4-WayPlay latch */
|
/* reset 4-WayPlay latch (controller #0 used by default) */
|
||||||
latch = 0;
|
latch = 0x00;
|
||||||
|
|
||||||
/* reset Master Tap flip-flop */
|
/* reset Master Tap flip-flop */
|
||||||
flipflop[port>>2].Latch = 0;
|
flipflop[port>>2].Latch = 0;
|
||||||
@ -211,7 +211,7 @@ INLINE void gamepad_write(int port, unsigned char data, unsigned char mask)
|
|||||||
/* retrieve current timestamp */
|
/* retrieve current timestamp */
|
||||||
unsigned int cycles = ((system_hw & SYSTEM_PBC) == SYSTEM_MD) ? m68k.cycles : Z80.cycles;
|
unsigned int cycles = ((system_hw & SYSTEM_PBC) == SYSTEM_MD) ? m68k.cycles : Z80.cycles;
|
||||||
|
|
||||||
/* TH is pulled high when not configured as output by I/O controller output */
|
/* TH is pulled high when not configured as output by I/O controller */
|
||||||
data = 0x40;
|
data = 0x40;
|
||||||
|
|
||||||
/* TH 0->1 internal switching does not occur immediately (verified on MK-1650 model) */
|
/* TH 0->1 internal switching does not occur immediately (verified on MK-1650 model) */
|
||||||
@ -255,14 +255,14 @@ void gamepad_2_write(unsigned char data, unsigned char mask)
|
|||||||
|
|
||||||
unsigned char wayplay_1_read(void)
|
unsigned char wayplay_1_read(void)
|
||||||
{
|
{
|
||||||
/* check if TH on port B is HIGH */
|
/* check if latched TH input on port B is HIGH */
|
||||||
if (latch & 0x04)
|
if (latch & 0x04)
|
||||||
{
|
{
|
||||||
/* 4-WayPlay detection : xxxxx00 */
|
/* 4-WayPlay detection : xxxxx00 */
|
||||||
return 0x7C;
|
return 0x7C;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TR & TL on port B select controller # (0-3) */
|
/* latched TR & TL input state on port B select controller # (0-3) on port A */
|
||||||
return gamepad_read(latch);
|
return gamepad_read(latch);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -273,14 +273,21 @@ unsigned char wayplay_2_read(void)
|
|||||||
|
|
||||||
void wayplay_1_write(unsigned char data, unsigned char mask)
|
void wayplay_1_write(unsigned char data, unsigned char mask)
|
||||||
{
|
{
|
||||||
/* TR & TL on port B select controller # (0-3) */
|
/* latched TR & TL input state on port B select controller # (0-3) on port A */
|
||||||
gamepad_write(latch & 0x03, data, mask);
|
gamepad_write(latch & 0x03, data, mask);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wayplay_2_write(unsigned char data, unsigned char mask)
|
void wayplay_2_write(unsigned char data, unsigned char mask)
|
||||||
{
|
{
|
||||||
/* latch TH, TR & TL state on port B */
|
/* pins not configured as output by I/O controller are pulled HIGH */
|
||||||
latch = ((data & mask) >> 4) & 0x07;
|
data |= ~mask;
|
||||||
|
|
||||||
|
/* check if both UP & DOWN inputs are LOW */
|
||||||
|
if (!(data & 0x03))
|
||||||
|
{
|
||||||
|
/* latch TH, TR & TL input state */
|
||||||
|
latch = (data >> 4) & 0x07;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@ int load_archive(char *filename, unsigned char *buffer, int maxsize, char *exten
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* Open file */
|
/* Open file */
|
||||||
gzFile *gd = gzopen(filename, "rb");
|
gzFile gd = gzopen(filename, "rb");
|
||||||
if (!gd) return 0;
|
if (!gd) return 0;
|
||||||
|
|
||||||
/* Read file data */
|
/* Read file data */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user