Skip to content

Commit

Permalink
Merge pull request #5706 from unknownbrackets/win-input
Browse files Browse the repository at this point in the history
Poll controllers on a separate thread on Windows
  • Loading branch information
hrydgard committed Mar 24, 2014
2 parents a29b011 + b641ced commit 108ebca
Show file tree
Hide file tree
Showing 5 changed files with 112 additions and 20 deletions.
17 changes: 4 additions & 13 deletions Core/Core.cpp
Expand Up @@ -129,22 +129,13 @@ void UpdateScreenScale(int width, int height) {
}

static inline void UpdateRunLoop() {
NativeUpdate(input_state);

{
{
#ifdef _WIN32
lock_guard guard(input_state.lock);
input_state.pad_buttons = 0;
input_state.pad_lstick_x = 0;
input_state.pad_lstick_y = 0;
input_state.pad_rstick_x = 0;
input_state.pad_rstick_y = 0;
host->PollControllers(input_state);
UpdateInputState(&input_state);
#endif
}
NativeUpdate(input_state);
lock_guard guard(input_state.lock);
EndInputState(&input_state);
}

if (globalUIState != UISTATE_EXIT) {
NativeRender();
}
Expand Down
87 changes: 83 additions & 4 deletions Windows/InputDevice.cpp
@@ -1,7 +1,86 @@
#include "InputDevice.h"
#include "XinputDevice.h"
#include "DinputDevice.h"
#include "KeyboardDevice.h"
// Copyright (c) 2014- PPSSPP Project.

// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, version 2.0 or later versions.

// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License 2.0 for more details.

// A copy of the GPL 2.0 should have been included with the program.
// If not, see http://www.gnu.org/licenses/

// Official git repository and contact information can be found at
// https://github.com/hrydgard/ppsspp and http://www.ppsspp.org/.

#include <list>
#include <memory>
#include "base/mutex.h"
#include "input/input_state.h"
#include "thread/thread.h"
#include "thread/threadutil.h"
#include "Core/Host.h"
#include "Windows/InputDevice.h"
#include "Windows/XinputDevice.h"
#include "Windows/DinputDevice.h"
#include "Windows/KeyboardDevice.h"
#include "Windows/WindowsHost.h"

static volatile bool inputThreadStatus = false;
static volatile bool inputThreadEnabled = false;
static std::thread *inputThread = NULL;
static recursive_mutex inputMutex;
static condition_variable inputEndCond;

extern InputState input_state;

inline static void ExecuteInputPoll() {
lock_guard guard(input_state.lock);
input_state.pad_buttons = 0;
input_state.pad_lstick_x = 0;
input_state.pad_lstick_y = 0;
input_state.pad_rstick_x = 0;
input_state.pad_rstick_y = 0;
if (host) {
host->PollControllers(input_state);
}
UpdateInputState(&input_state);
}

static void RunInputThread() {
setCurrentThreadName("InputThread");

// NOTE: The keyboard and mouse buttons are handled via raw input, not here.
// This is mainly for controllers which need to be polled, instead of generating events.

while (inputThreadEnabled) {
ExecuteInputPoll();

// Update 250 times per second.
Sleep(4);
}

lock_guard guard(inputMutex);
inputThreadStatus = false;
inputEndCond.notify_one();
}

void InputDevice::BeginPolling() {
lock_guard guard(inputMutex);
inputThreadEnabled = true;
inputThread = new std::thread(&RunInputThread);
inputThread->detach();
}

void InputDevice::StopPolling() {
inputThreadEnabled = false;

lock_guard guard(inputMutex);
if (inputThreadStatus) {
inputEndCond.wait(inputMutex);
}
delete inputThread;
inputThread = NULL;
}
25 changes: 22 additions & 3 deletions Windows/InputDevice.h
@@ -1,16 +1,35 @@
// Copyright (c) 2014- PPSSPP Project.

// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, version 2.0 or later versions.

// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License 2.0 for more details.

// A copy of the GPL 2.0 should have been included with the program.
// If not, see http://www.gnu.org/licenses/

// Official git repository and contact information can be found at
// https://github.com/hrydgard/ppsspp and http://www.ppsspp.org/.

#pragma once

#include <list>
#include <memory>

#include "../Common/CommonTypes.h"
#include "Common/CommonTypes.h"

struct InputState;

class InputDevice
{
class InputDevice {
public:
enum { UPDATESTATE_SKIP_PAD = 0x1234};
virtual int UpdateState(InputState &input_state) = 0;
virtual bool IsPad() = 0;

static void BeginPolling();
static void StopPolling();
};
1 change: 1 addition & 0 deletions Windows/WndMainWindow.cpp
Expand Up @@ -1563,6 +1563,7 @@ namespace MainWindow

case WM_CLOSE:
EmuThread_Stop();
InputDevice::StopPolling();
WindowsRawInput::Shutdown();

return DefWindowProc(hWnd,message,wParam,lParam);
Expand Down
2 changes: 2 additions & 0 deletions Windows/main.cpp
Expand Up @@ -383,6 +383,7 @@ int WINAPI WinMain(HINSTANCE _hInstance, HINSTANCE hPrevInstance, LPSTR szCmdLin

// Emu thread is always running!
EmuThread_Start();
InputDevice::BeginPolling();

HACCEL hAccelTable = LoadAccelerators(_hInstance, (LPCTSTR)IDR_ACCELS);
HACCEL hDebugAccelTable = LoadAccelerators(_hInstance, (LPCTSTR)IDR_DEBUGACCELS);
Expand Down Expand Up @@ -433,6 +434,7 @@ int WINAPI WinMain(HINSTANCE _hInstance, HINSTANCE hPrevInstance, LPSTR szCmdLin

VFSShutdown();

InputDevice::StopPolling();
EmuThread_Stop();

MainWindow::DestroyDebugWindows();
Expand Down

0 comments on commit 108ebca

Please sign in to comment.