lsnes/bsnes-patches/v086/0005-Add-needed-support-for-detecting-true-polls-as-oppos.patch
2013-02-02 01:23:34 +02:00

69 lines
2.6 KiB
Diff

From 574754de0ed7da044d3c559bb2c8bbca895c1e97 Mon Sep 17 00:00:00 2001
From: Ilari Liusvaara <ilari.liusvaara@elisanet.fi>
Date: Mon, 24 Sep 2012 21:46:09 +0300
Subject: [PATCH] Add needed support for detecting true polls as opposed to
just autopolling
---
snes/cpu/cpu.hpp | 1 +
snes/cpu/mmio/mmio.cpp | 18 ++++++++++--------
2 files changed, 11 insertions(+), 8 deletions(-)
diff --git a/snes/cpu/cpu.hpp b/snes/cpu/cpu.hpp
index 5eb963e..f6466cc 100755
--- a/snes/cpu/cpu.hpp
+++ b/snes/cpu/cpu.hpp
@@ -25,6 +25,7 @@ struct CPU : public Processor, public CPUcore, public PPUcounter {
CPU();
~CPU();
+ bool controller_flag;
privileged:
#include "dma/dma.hpp"
#include "memory/memory.hpp"
diff --git a/snes/cpu/mmio/mmio.cpp b/snes/cpu/mmio/mmio.cpp
index 8b6aaa6..c5ee930 100755
--- a/snes/cpu/mmio/mmio.cpp
+++ b/snes/cpu/mmio/mmio.cpp
@@ -42,6 +42,7 @@ void CPU::mmio_w4016(uint8 data) {
//1-0 = Joypad serial data
uint8 CPU::mmio_r4016() {
uint8 r = regs.mdr & 0xfc;
+ controller_flag = true;
r |= input.port1->data();
return r;
}
@@ -52,6 +53,7 @@ uint8 CPU::mmio_r4016() {
//1-0 = Joypad serial data
uint8 CPU::mmio_r4017() {
uint8 r = (regs.mdr & 0xe0) | 0x1c;
+ controller_flag = true;
r |= input.port2->data();
return r;
}
@@ -204,14 +206,14 @@ uint8 CPU::mmio_r4217() {
return status.rdmpy >> 8;
}
-uint8 CPU::mmio_r4218() { return status.joy1 >> 0; } //JOY1L
-uint8 CPU::mmio_r4219() { return status.joy1 >> 8; } //JOY1H
-uint8 CPU::mmio_r421a() { return status.joy2 >> 0; } //JOY2L
-uint8 CPU::mmio_r421b() { return status.joy2 >> 8; } //JOY2H
-uint8 CPU::mmio_r421c() { return status.joy3 >> 0; } //JOY3L
-uint8 CPU::mmio_r421d() { return status.joy3 >> 8; } //JOY3H
-uint8 CPU::mmio_r421e() { return status.joy4 >> 0; } //JOY4L
-uint8 CPU::mmio_r421f() { return status.joy4 >> 8; } //JOY4H
+uint8 CPU::mmio_r4218() { controller_flag = true; return status.joy1 >> 0; } //JOY1L
+uint8 CPU::mmio_r4219() { controller_flag = true; return status.joy1 >> 8; } //JOY1H
+uint8 CPU::mmio_r421a() { controller_flag = true; return status.joy2 >> 0; } //JOY2L
+uint8 CPU::mmio_r421b() { controller_flag = true; return status.joy2 >> 8; } //JOY2H
+uint8 CPU::mmio_r421c() { controller_flag = true; return status.joy3 >> 0; } //JOY3L
+uint8 CPU::mmio_r421d() { controller_flag = true; return status.joy3 >> 8; } //JOY3H
+uint8 CPU::mmio_r421e() { controller_flag = true; return status.joy4 >> 0; } //JOY4L
+uint8 CPU::mmio_r421f() { controller_flag = true; return status.joy4 >> 8; } //JOY4H
//DMAPx
uint8 CPU::mmio_r43x0(uint8 i) {
--
1.7.10.4