[XAM] XamShowSigninUI: Send signin and UI close notification with delay from separate thread
This is to prevent situation when game waits for notification, but receives it beforehand
This commit is contained in:
parent
629707b935
commit
d246e3bc70
|
@ -548,23 +548,30 @@ dword_result_t XamShowSigninUI_entry(dword_t users_needed, dword_t unk_mask) {
|
||||||
kernel_state()->UpdateUsedUserProfiles();
|
kernel_state()->UpdateUsedUserProfiles();
|
||||||
// Mask values vary. Probably matching user types? Local/remote?
|
// Mask values vary. Probably matching user types? Local/remote?
|
||||||
// Games seem to sit and loop until we trigger this notification:
|
// Games seem to sit and loop until we trigger this notification:
|
||||||
uint32_t user_mask = 0;
|
|
||||||
uint32_t active_users = 0;
|
|
||||||
|
|
||||||
for (uint32_t i = 0; i < 4; i++) {
|
auto run = [users_needed]() -> void {
|
||||||
if (kernel_state()->IsUserSignedIn(i)) {
|
uint32_t user_mask = 0;
|
||||||
user_mask |= (1 << i);
|
uint32_t active_users = 0;
|
||||||
active_users++;
|
|
||||||
if (active_users >= users_needed) break;
|
for (uint32_t i = 0; i < 4; i++) {
|
||||||
|
if (kernel_state()->IsUserSignedIn(i)) {
|
||||||
|
user_mask |= (1 << i);
|
||||||
|
active_users++;
|
||||||
|
if (active_users >= users_needed) break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// XN_SYS_SIGNINCHANGED (players)
|
std::this_thread::sleep_for(std::chrono::milliseconds(150));
|
||||||
kernel_state()->BroadcastNotification(kXNotificationIDSystemSignInChanged,
|
// XN_SYS_SIGNINCHANGED (players)
|
||||||
user_mask);
|
kernel_state()->BroadcastNotification(kXNotificationIDSystemSignInChanged,
|
||||||
|
user_mask);
|
||||||
|
// XN_SYS_UI (off)
|
||||||
|
kernel_state()->BroadcastNotification(kXNotificationIDSystemUI, 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
std::thread thread(run);
|
||||||
|
thread.detach();
|
||||||
|
|
||||||
// XN_SYS_UI (off)
|
|
||||||
kernel_state()->BroadcastNotification(kXNotificationIDSystemUI, 0);
|
|
||||||
return X_ERROR_SUCCESS;
|
return X_ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
DECLARE_XAM_EXPORT1(XamShowSigninUI, kUserProfiles, kStub);
|
DECLARE_XAM_EXPORT1(XamShowSigninUI, kUserProfiles, kStub);
|
||||||
|
|
Loading…
Reference in New Issue