mirror of
https://github.com/DarkMatterCore/nxdumptool.git
synced 2024-11-08 11:51:48 +00:00
gamecard: remove attempt to fix HOS errors.
This commit is contained in:
parent
2c5ff529ec
commit
a1645e0c78
1 changed files with 6 additions and 18 deletions
|
@ -148,7 +148,7 @@ NX_INLINE void gamecardCloseHandle(void);
|
||||||
|
|
||||||
static bool gamecardOpenStorageArea(u8 area);
|
static bool gamecardOpenStorageArea(u8 area);
|
||||||
static bool gamecardReadStorageArea(void *out, u64 read_size, u64 offset);
|
static bool gamecardReadStorageArea(void *out, u64 read_size, u64 offset);
|
||||||
static void gamecardCloseStorageArea(bool switch_to_normal);
|
static void gamecardCloseStorageArea(void);
|
||||||
|
|
||||||
static bool gamecardGetStorageAreasSizes(void);
|
static bool gamecardGetStorageAreasSizes(void);
|
||||||
NX_INLINE u64 gamecardGetCapacityFromRomSizeValue(u8 rom_size);
|
NX_INLINE u64 gamecardGetCapacityFromRomSizeValue(u8 rom_size);
|
||||||
|
@ -838,8 +838,6 @@ end:
|
||||||
|
|
||||||
static void gamecardFreeInfo(bool clear_status)
|
static void gamecardFreeInfo(bool clear_status)
|
||||||
{
|
{
|
||||||
gamecardCloseStorageArea(true);
|
|
||||||
|
|
||||||
memset(&g_gameCardHeader, 0, sizeof(GameCardHeader));
|
memset(&g_gameCardHeader, 0, sizeof(GameCardHeader));
|
||||||
|
|
||||||
memset(&g_gameCardInfoArea, 0, sizeof(GameCardInfo));
|
memset(&g_gameCardInfoArea, 0, sizeof(GameCardInfo));
|
||||||
|
@ -866,6 +864,8 @@ static void gamecardFreeInfo(bool clear_status)
|
||||||
|
|
||||||
g_gameCardHfsCount = 0;
|
g_gameCardHfsCount = 0;
|
||||||
|
|
||||||
|
gamecardCloseStorageArea();
|
||||||
|
|
||||||
if (clear_status) g_gameCardStatus = GameCardStatus_NotInserted;
|
if (clear_status) g_gameCardStatus = GameCardStatus_NotInserted;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1047,7 +1047,7 @@ static bool gamecardOpenStorageArea(u8 area)
|
||||||
if (g_gameCardHandle.value && serviceIsActive(&(g_gameCardStorage.s)) && g_gameCardCurrentStorageArea == area) return true;
|
if (g_gameCardHandle.value && serviceIsActive(&(g_gameCardStorage.s)) && g_gameCardCurrentStorageArea == area) return true;
|
||||||
|
|
||||||
/* Close both gamecard handle and open storage area. */
|
/* Close both gamecard handle and open storage area. */
|
||||||
gamecardCloseStorageArea(false);
|
gamecardCloseStorageArea();
|
||||||
|
|
||||||
/* Retrieve both a new gamecard handle and a storage area handle. */
|
/* Retrieve both a new gamecard handle and a storage area handle. */
|
||||||
if (!gamecardGetHandleAndStorage(area - 1)) /* Zero-based index. */
|
if (!gamecardGetHandleAndStorage(area - 1)) /* Zero-based index. */
|
||||||
|
@ -1139,22 +1139,10 @@ end:
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gamecardCloseStorageArea(bool switch_to_normal)
|
static void gamecardCloseStorageArea(void)
|
||||||
{
|
{
|
||||||
if (g_gameCardCurrentStorageArea == GameCardStorageArea_None) return;
|
if (g_gameCardCurrentStorageArea == GameCardStorageArea_None) return;
|
||||||
|
|
||||||
/* Workaround: try to reset the Lotus driver by switching to the normal storage area before closing all gamecard comms. */
|
|
||||||
if (switch_to_normal && g_gameCardCurrentStorageArea == GameCardStorageArea_Secure)
|
|
||||||
{
|
|
||||||
LOG_MSG("Switching to normal area before shutting down.");
|
|
||||||
if (gamecardOpenStorageArea(GameCardStorageArea_Normal))
|
|
||||||
{
|
|
||||||
/* Perform a bogus read (just one page). */
|
|
||||||
u8 bogus[GAMECARD_PAGE_SIZE] = {0};
|
|
||||||
gamecardReadStorageArea(bogus, sizeof(bogus), 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (serviceIsActive(&(g_gameCardStorage.s)))
|
if (serviceIsActive(&(g_gameCardStorage.s)))
|
||||||
{
|
{
|
||||||
fsStorageClose(&g_gameCardStorage);
|
fsStorageClose(&g_gameCardStorage);
|
||||||
|
@ -1182,7 +1170,7 @@ static bool gamecardGetStorageAreasSizes(void)
|
||||||
|
|
||||||
rc = fsStorageGetSize(&g_gameCardStorage, (s64*)&area_size);
|
rc = fsStorageGetSize(&g_gameCardStorage, (s64*)&area_size);
|
||||||
|
|
||||||
gamecardCloseStorageArea(false);
|
gamecardCloseStorageArea();
|
||||||
|
|
||||||
if (R_FAILED(rc) || !area_size)
|
if (R_FAILED(rc) || !area_size)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue