Skip to content

Commit

Permalink
DInputSource: Limit the amount of reported buttons and POV hats to wh…
Browse files Browse the repository at this point in the history
…at the data format supports

Fixes a crash when the device reports more buttons than what
DIJOYSTATE2 can handle.
  • Loading branch information
CookiePLMonster committed Oct 22, 2023
1 parent 489fdc5 commit 77ba601
Showing 1 changed file with 2 additions and 8 deletions.
10 changes: 2 additions & 8 deletions pcsx2/Input/DInputSource.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -210,12 +210,6 @@ bool DInputSource::AddDevice(ControllerData& cd, const std::string& name)
return false;
}

if (caps.dwButtons == 0)
{
Console.Error("Ignoring device '%s' because it has no buttons (%u axes, %u POVs).", name.c_str(), caps.dwAxes, caps.dwPOVs);
return false;
}

static constexpr const u32 axis_offsets[] = {offsetof(DIJOYSTATE2, lX), offsetof(DIJOYSTATE2, lY), offsetof(DIJOYSTATE2, lZ),
offsetof(DIJOYSTATE2, lRz), offsetof(DIJOYSTATE2, lRx), offsetof(DIJOYSTATE2, lRy), offsetof(DIJOYSTATE2, rglSlider[0]),
offsetof(DIJOYSTATE2, rglSlider[1])};
Expand Down Expand Up @@ -246,8 +240,8 @@ bool DInputSource::AddDevice(ControllerData& cd, const std::string& name)
if (hr != DI_OK)
Console.Warning("GetDeviceState() for '%s' failed: %08X", name.c_str(), hr);

cd.num_buttons = caps.dwButtons;
cd.num_hats = caps.dwPOVs;
cd.num_buttons = std::min<u32>(caps.dwButtons, std::size(cd.last_state.rgbButtons));
cd.num_hats = std::min<u32>(caps.dwPOVs, std::size(cd.last_state.rgdwPOV));

Console.WriteLn(
"%s has %u buttons, %u axes, %u hats", name.c_str(), cd.num_buttons, static_cast<u32>(cd.axis_offsets.size()), cd.num_hats);
Expand Down

0 comments on commit 77ba601

Please sign in to comment.