not going to need you anymore (2)

This commit is contained in:
Naim2000 2025-01-07 21:11:59 -05:00
parent dda0293603
commit 62205f9ab5
2 changed files with 48 additions and 24 deletions

View File

@ -4,10 +4,11 @@
#include <limits.h> #include <limits.h>
#include <ogcsys.h> #include <ogcsys.h>
#include <ogc/es.h> #include <ogc/es.h>
#include <ogc/aes.h>
#include "title.h" #include "title.h"
#include "nand.h"
#include "sha1.h" #include "sha1.h"
#include "aes.h"
#include "utils.h" #include "utils.h"
#include "otp.h" #include "otp.h"
#include "malloc.h" #include "malloc.h"
@ -184,6 +185,35 @@ err:
return ret; return ret;
} }
s32 Title_GetTMDView(u64 tid, tmd_view** outbuf, u32* outlen)
{
s32 ret;
u32 view_sz = 0;
*outbuf = NULL;
*outlen = 0;
ret = ES_GetTMDViewSize(tid, &view_sz);
if (ret < 0)
return ret;
tmd_view* view = memalign32(view_sz);
if (!view)
return -1;
ret = ES_GetTMDView(tid, (u8*) view, view_sz);
if (ret < 0)
goto fail;
*outbuf = view;
*outlen = view_sz;
return 0;
fail:
free(view);
return ret;
}
s32 Title_GetVersion(u64 tid, u16 *outbuf) s32 Title_GetVersion(u64 tid, u16 *outbuf)
{ {
signed_blob *p_tmd = NULL; signed_blob *p_tmd = NULL;
@ -262,7 +292,7 @@ s32 Title_GetSize(u64 tid, u32 *outbuf)
*outbuf = size; *outbuf = size;
/* Free memory */ /* Free memory */
free(p_tmd); free(view);
return 0; return 0;
} }
@ -361,45 +391,37 @@ bool Title_SharedContentPresent(tmd_content* content, SharedContent shared[], u3
bool Title_GetcIOSInfo(int IOS, cIOSInfo* out) bool Title_GetcIOSInfo(int IOS, cIOSInfo* out)
{ {
u64 titleID = 0x0000000100000000ULL | IOS; u64 titleID = 0x0000000100000000ULL | IOS;
ATTRIBUTE_ALIGN(0x20) char path[ISFS_MAXPATH]; tmd_view* view = NULL;
u32 view_size = 0;
char path[ISFS_MAXPATH];
u32 size; u32 size;
cIOSInfo* buf = NULL; cIOSInfo* buf = NULL;
u32 view_size = 0; s32 ret = Title_GetTMDView(titleID, &view, &view_size);
if (ES_GetTMDViewSize(titleID, &view_size) < 0) if (ret < 0)
return false; return ret;
tmd_view* view = memalign32(view_size); u32 content0 = 0;
if (!view) for (int i = 0; i < view->num_contents; i++)
return false;
if (ES_GetTMDView(titleID, (u8*)view, view_size) < 0)
goto fail;
tmd_view_content* content0 = NULL;
for (tmd_view_content* con = view->contents; con < view->contents + view->num_contents; con++)
{ {
if (con->index == 0) if (view->contents[i].index == 0) {
content0 = con; content0 = view->contents[i].cid;
break;
}
} }
free(view);
if (!content0) sprintf(path, "/title/00000001/%08x/content/%08x.app", IOS, content0);
goto fail;
sprintf(path, "/title/00000001/%08x/content/%08x.app", IOS, content0->cid);
buf = (cIOSInfo*)NANDLoadFile(path, &size); buf = (cIOSInfo*)NANDLoadFile(path, &size);
if (!buf || size != 0x40 || buf->hdr_magic != CIOS_INFO_MAGIC || buf->hdr_version != CIOS_INFO_VERSION) if (!buf || size != 0x40 || buf->hdr_magic != CIOS_INFO_MAGIC || buf->hdr_version != CIOS_INFO_VERSION)
goto fail; goto fail;
*out = *buf; *out = *buf;
free(view);
free(buf); free(buf);
return true; return true;
fail: fail:
free(view);
free(buf); free(buf);
return false; return false;
} }

View File

@ -43,6 +43,7 @@ s32 Title_FakesignTik(signed_blob *);
s32 Title_FakesignTMD(signed_blob *); s32 Title_FakesignTMD(signed_blob *);
s32 Title_GetList(u64 **, u32 *); s32 Title_GetList(u64 **, u32 *);
s32 Title_GetTicketViews(u64, tikview **, u32 *); s32 Title_GetTicketViews(u64, tikview **, u32 *);
s32 Title_GetTMDView(u64, tmd_view **, u32 *);
s32 Title_GetTMD(u64, signed_blob **, u32 *); s32 Title_GetTMD(u64, signed_blob **, u32 *);
s32 Title_GetVersion(u64, u16 *); s32 Title_GetVersion(u64, u16 *);
s32 Title_GetSysVersion(u64, u64 *); s32 Title_GetSysVersion(u64, u64 *);
@ -51,6 +52,7 @@ s32 Title_GetIOSVersions(u8 **, u32 *);
s32 Title_GetSharedContents(SharedContent** out, u32* count); s32 Title_GetSharedContents(SharedContent** out, u32* count);
bool Title_SharedContentPresent(tmd_content* content, SharedContent shared[], u32 count); bool Title_SharedContentPresent(tmd_content* content, SharedContent shared[], u32 count);
bool Title_GetcIOSInfo(int IOS, cIOSInfo*); bool Title_GetcIOSInfo(int IOS, cIOSInfo*);
void Title_SetupCommonKeys(void); void Title_SetupCommonKeys(void);
#endif #endif