Skip to content

Commit

Permalink
AnalogController: Reset state on analog->digital switch
Browse files Browse the repository at this point in the history
But only when the game does not support analog mode.

Tomb Raider's game selector menu puts the controller into
configuration mode, and we're supposed to respond with a
0x00 header byte if the user switches the pad to digital
mode.

Problem is, the game itself doesn't understand this mode
switch nor configuration mode. So the status byte gets
stuck at 0x00 if the user toggles analog mode, and the
game thinks no pad is connected.

Work around this by resetting the whole state if the game
does not support analog mode.
  • Loading branch information
stenzek committed Nov 5, 2024
1 parent 57ca5dd commit 7b7dd2b
Showing 1 changed file with 18 additions and 1 deletion.
19 changes: 18 additions & 1 deletion src/core/analog_controller.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -331,8 +331,25 @@ void AnalogController::ProcessAnalogModeToggle()
SetAnalogMode(!m_analog_mode, true);
ResetRumbleConfig();

// Set status byte to 0 if we were previously in configuration mode, so that the game knows about the mode change.
if (m_dualshock_enabled)
m_status_byte = 0x00;
{
// However, the problem with doing this unconditionally is that games like Tomb Raider have the loader menu
// put the pad into configuration mode, but not analog mode. So if the user toggles analog mode, the status
// byte ends up stuck at 0x00. As a workaround, clear out config/dualshock mode when the game isn't flagged
// as supporting the dualshock.
if (!m_analog_mode && !CanStartInAnalogMode(ControllerType::AnalogController))
{
WARNING_LOG("Resetting pad on digital->analog switch.");
m_configuration_mode = false;
m_dualshock_enabled = false;
m_status_byte = 0x5A;
}
else
{
m_status_byte = 0x00;
}
}
}
}

Expand Down

0 comments on commit 7b7dd2b

Please sign in to comment.