From c440ecdf36495008541e7ea39bd2000f82cec7a7 Mon Sep 17 00:00:00 2001 From: Exzap <13877693+Exzap@users.noreply.github.com> Date: Tue, 17 Oct 2023 06:16:29 +0200 Subject: [PATCH] FPD: Fix a crash due to incorrect instantiation --- src/Cafe/IOSU/legacy/iosu_fpd.cpp | 18 +++++++++--------- src/Cemu/nex/nexTypes.h | 4 +++- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/src/Cafe/IOSU/legacy/iosu_fpd.cpp b/src/Cafe/IOSU/legacy/iosu_fpd.cpp index 75bf0463a..bcd580efc 100644 --- a/src/Cafe/IOSU/legacy/iosu_fpd.cpp +++ b/src/Cafe/IOSU/legacy/iosu_fpd.cpp @@ -173,7 +173,7 @@ namespace iosu return t; } - void NexPresenceToGameMode(nexPresenceV2* presence, GameMode* gameMode) + void NexPresenceToGameMode(const nexPresenceV2* presence, GameMode* gameMode) { memset(gameMode, 0, sizeof(GameMode)); gameMode->joinFlagMask = presence->joinFlagMask; @@ -185,9 +185,9 @@ namespace iosu memcpy(gameMode->appSpecificData, presence->appSpecificData, 0x14); } - void GameModeToNexPresence(GameMode* gameMode, nexPresenceV2* presence) + void GameModeToNexPresence(const GameMode* gameMode, nexPresenceV2* presence) { - memset(presence, 0, sizeof(nexPresenceV2)); + *presence = {}; presence->joinFlagMask = gameMode->joinFlagMask; presence->joinAvailability = (uint8)(uint32)gameMode->matchmakeType; presence->gameId = gameMode->joinGameId; @@ -197,7 +197,7 @@ namespace iosu memcpy(presence->appSpecificData, gameMode->appSpecificData, 0x14); } - void NexFriendToFPDFriendData(FriendData* friendData, nexFriend* frd) + void NexFriendToFPDFriendData(const nexFriend* frd, FriendData* friendData) { memset(friendData, 0, sizeof(FriendData)); // setup friend data @@ -232,7 +232,7 @@ namespace iosu convertFPDTimestampToDate(frd->lastOnlineTimestamp, &friendData->friendExtraData.lastOnline); } - void NexFriendRequestToFPDFriendData(FriendData* friendData, nexFriendRequest* frdReq, bool isIncoming) + void NexFriendRequestToFPDFriendData(const nexFriendRequest* frdReq, bool isIncoming, FriendData* friendData) { memset(friendData, 0, sizeof(FriendData)); // setup friend data @@ -282,7 +282,7 @@ namespace iosu convertFPDTimestampToDate(frdReq->message.expireTimestamp, &friendData->requestExtraData.uknData1); } - void NexFriendRequestToFPDFriendRequest(FriendRequest* friendRequest, nexFriendRequest* frdReq, bool isIncoming) + void NexFriendRequestToFPDFriendRequest(const nexFriendRequest* frdReq, bool isIncoming, FriendRequest* friendRequest) { memset(friendRequest, 0, sizeof(FriendRequest)); @@ -1007,7 +1007,7 @@ namespace iosu cemuLog_log(LogType::Force, "GetFriendRequestListEx: Failed to get friend request"); return FPResult_RequestFailed; } - NexFriendRequestToFPDFriendRequest(friendRequests + i, &frdReq, incoming); + NexFriendRequestToFPDFriendRequest(&frdReq, incoming, friendRequests + i); } return FPResult_Ok; } @@ -1063,13 +1063,13 @@ namespace iosu nexFriendRequest frdReq; if (g_fpd.nexFriendSession->getFriendByPID(frd, pid)) { - NexFriendToFPDFriendData(friendData, &frd); + NexFriendToFPDFriendData(&frd, friendData); continue; } bool incoming = false; if (g_fpd.nexFriendSession->getFriendRequestByPID(frdReq, &incoming, pid)) { - NexFriendRequestToFPDFriendData(friendData, &frdReq, incoming); + NexFriendRequestToFPDFriendData(&frdReq, incoming, friendData); continue; } cemuLog_logDebug(LogType::Force, "GetFriendListEx: Failed to find friend or request with pid {}", pid); diff --git a/src/Cemu/nex/nexTypes.h b/src/Cemu/nex/nexTypes.h index 49edd3d34..f43a83f2f 100644 --- a/src/Cemu/nex/nexTypes.h +++ b/src/Cemu/nex/nexTypes.h @@ -16,7 +16,9 @@ class nexMetaType class nexType { -public: + public: + virtual ~nexType(){}; + virtual const char* getMetaName() { cemu_assert_unimplemented();