Little fixes

This commit is contained in:
Aurora 2016-11-16 14:52:50 +01:00
parent 6b8474b7b9
commit 2a563eddd0
2 changed files with 14 additions and 34 deletions

View File

@ -10,7 +10,7 @@
.arm .arm
; fsOpenFileDirectly function will be redirected here. ; fsOpenFileDirectly function will be redirected here.
; If the requested archive is not ROMFS, we'll return ; If the requested archive is not ROMFS, we'll return
; to the original fucntion. ; to the original function.
openFileDirectlyHook: openFileDirectlyHook:
cmp r3, #3 cmp r3, #3
beq openRomfs beq openRomfs

View File

@ -263,25 +263,25 @@ static u32 findFunctionCommand(u8* code, u32 size, u32 command)
{ {
u32 func = 0; u32 func = 0;
for(u32 i = 0; i < size && !func; i += 4) for(u32 i = 0; !func && i <= size - 4; i += 4)
if(*(u32 *)(code + i) == command) func = i; if(*(u32 *)(code + i) == command) func = i;
return !func ? 0 : findNearestStmfd(code, func); return findNearestStmfd(code, func);
} }
static inline u32 findThrowFatalError(u8* code, u32 size) static inline u32 findThrowFatalError(u8* code, u32 size)
{ {
u32 connectToPort = 0; u32 connectToPort = 0;
for(u32 i = 0; i < size && !connectToPort; i += 4) for(u32 i = 4; !connectToPort && i <= size - 4; i += 4)
if(*(u32 *)(code + i) == 0xEF00002D) connectToPort = i - 4; if(*(u32 *)(code + i) == 0xEF00002D) connectToPort = i - 4;
if(!connectToPort) return 0; if(!connectToPort) return 0;
u32 func = 0; u32 func = 0;
for(u32 i = 0; i < size && !func; i += 4) for(u32 i = 0; !func && i <= size - 4; i += 4)
{ {
if(*(u32 *)(code + i) != MAKE_BRANCH_LINK(i, connectToPort)) continue; if(*(u32 *)(code + i) != MAKE_BRANCH_LINK(i, connectToPort)) continue;
func = findNearestStmfd(code, i); func = findNearestStmfd(code, i);
@ -333,23 +333,15 @@ static inline bool loadTitleLocaleConfig(u64 progId, u8 *regionId, u8 *languageI
if(R_FAILED(openLumaFile(&file, path))) return true; if(R_FAILED(openLumaFile(&file, path))) return true;
bool ret; bool ret = false;
u64 fileSize; u64 fileSize;
if(R_FAILED(IFile_GetSize(&file, &fileSize)) || fileSize < 6 || fileSize > 8) if(R_FAILED(IFile_GetSize(&file, &fileSize)) || fileSize < 6 || fileSize > 8) goto exit;
{
ret = false;
goto exit;
}
char buf[8]; char buf[8];
u64 total; u64 total;
if(R_FAILED(IFile_Read(&file, &total, buf, fileSize))) if(R_FAILED(IFile_Read(&file, &total, buf, fileSize))) ret = false;
{
ret = false;
goto exit;
}
u32 i, u32 i,
j; j;
@ -396,33 +388,21 @@ static bool patchRomfsRedirection(u64 progId, u8* code, u32 size)
if(R_FAILED(openLumaFile(&file, path))) return true; if(R_FAILED(openLumaFile(&file, path))) return true;
bool ret; bool ret = false;
u64 romfsSize; u64 romfsSize;
if(R_FAILED(IFile_GetSize(&file, &romfsSize))) if(R_FAILED(IFile_GetSize(&file, &romfsSize))) goto exit;
{
ret = false;
goto exit;
}
u64 total; u64 total;
u32 header; u32 magic;
if(R_FAILED(IFile_Read(&file, &total, &header, 4)) || total != 4 || header != 0x43465649) if(R_FAILED(IFile_Read(&file, &total, &magic, 4)) || total != 4 || magic != 0x43465649) ret = false;
{
ret = false;
goto exit;
}
u32 fsOpenFileDirectly = findFunctionCommand(code, size, 0x08030204), u32 fsOpenFileDirectly = findFunctionCommand(code, size, 0x08030204),
fsOpenLinkFile = findFunctionCommand(code, size, 0x80C0000), fsOpenLinkFile = findFunctionCommand(code, size, 0x80C0000),
throwFatalError = findThrowFatalError(code, size); throwFatalError = findThrowFatalError(code, size);
if(!fsOpenFileDirectly || !throwFatalError) if(!fsOpenFileDirectly || !throwFatalError) goto exit;
{
ret = false;
goto exit;
}
//Setup the payload //Setup the payload
memcpy(code + throwFatalError, romfsredir_bin, romfsredir_bin_size); memcpy(code + throwFatalError, romfsredir_bin, romfsredir_bin_size);