Compare commits

...

39 Commits
v1.0 ... master

Author SHA1 Message Date
random() 2593440911 Update README.md 2023-10-31 22:57:30 +00:00
random() 9b6b472cef Update README.md 2023-10-31 22:55:38 +00:00
random() 0862f38d6e Update README.md 2023-10-31 22:51:51 +00:00
SilicaAndPina 5e3d65d9e1 Add O Check 2020-03-08 01:45:10 +13:00
SilicaAndPina 6db7d0a124 Fix warning 2020-03-08 01:41:26 +13:00
SilicaAndPina f467a9e651 Add support for 3.73 and probably newer fw 2020-03-08 01:27:22 +13:00
SilicaAndPina 0d11b84536 README.md edited online with Bitbucket 2019-10-19 01:17:57 +00:00
SilicaAndPina 8095be6a76 README.md edited online with Bitbucket 2019-10-19 01:16:09 +00:00
SilicaAndPina aaa2b239f2 README.md edited online with Bitbucket 2019-08-31 02:33:12 +00:00
SilicaAndPina 7e45ff54b0 README.md edited online with Bitbucket 2019-08-31 02:32:27 +00:00
SilicaAndPina e33d49994f Add support for 3.71/3.72 2019-08-30 23:56:35 +00:00
SilicaAndPina 4d9ad8949c README.md edited online with Bitbucket 2019-02-03 12:00:28 +00:00
SilicaAndPina d5a62d6296 README.md edited online with Bitbucket 2019-02-03 12:00:10 +00:00
AtelierWindows\SilicaAndPina f0277c2a2b 1.4 2019-02-04 00:57:24 +13:00
SilicaAndPina 3c4ac97316 README.md edited online with Bitbucket 2019-01-15 10:13:07 +00:00
SilicaAndPina 751eed0310 README.md edited online with Bitbucket 2019-01-15 10:01:02 +00:00
SilicaAndPina ff9692a11b README.md edited online with Bitbucket 2019-01-15 09:55:14 +00:00
AtelierWindows\SilicaAndPina 69e1d217bc Update 2019-01-15 22:51:26 +13:00
AtelierWindows\SilicaAndPina 4c8c7c9633 Fix timestamp desync 2019-01-15 22:32:50 +13:00
AtelierWindows\SilicaAndPina e2eb32beee Add 3.70 Support (BEFORE THEFLOW) 2019-01-15 21:35:43 +13:00
SilicaAndPina fcae55b5ec README.md edited online with Bitbucket 2018-12-05 10:22:52 +00:00
AtelierWindows\SilicaAndPina b474291ec6 Fix v1.2 2018-12-05 23:21:32 +13:00
SilicaAndPina 8bfc5cb9be README.md edited online with Bitbucket 2018-12-05 09:16:54 +00:00
SilicaAndPina e5db37c682 README.md edited online with Bitbucket 2018-12-05 09:16:32 +00:00
AtelierWindows\SilicaAndPina 0ea9193199 v1.2 2018-12-05 22:13:07 +13:00
SilicaAndPina 824ff31c39 README.md edited online with Bitbucket 2018-12-02 04:02:23 +00:00
SilicaAndPina 9afba3b735 README.md edited online with Bitbucket 2018-12-02 04:01:41 +00:00
SilicaAndPina 51e261de4f README.md edited online with Bitbucket 2018-12-02 03:44:13 +00:00
AtelierWindows\SilicaAndPina cce8c4ab73 Merge branch 'master' of https://bitbucket.org/SilicaAndPina/trophaxse 2018-12-02 16:41:31 +13:00
AtelierWindows\SilicaAndPina 9ca4219d87 THE REVOULTION IS HERE! 2018-12-02 16:41:12 +13:00
SilicaAndPina 1e024c1e3b Removed commented out code 2018-11-30 12:59:35 +00:00
SilicaAndPina 8e274faf3d README.md edited online with Bitbucket 2018-11-30 12:54:57 +00:00
SilicaAndPina b0f1e69519 README.md edited online with Bitbucket 2018-11-30 12:29:23 +00:00
SilicaAndPina b171b0aa54 README.md edited online with Bitbucket 2018-11-30 03:31:18 +00:00
SilicaAndPina 33124304a4 README.md edited online with Bitbucket 2018-11-30 03:18:06 +00:00
SilicaAndPina 95b5dcb045 v1.0 release 2018-11-30 03:09:34 +00:00
AtelierWindows\SilicaAndPina c80070230b Add background and stuff 2018-11-30 16:03:15 +13:00
AtelierWindows\SilicaAndPina 1e8243b897 no message 2018-11-30 15:19:58 +13:00
AtelierWindows\SilicaAndPina 765618585f v1.0 2018-11-30 15:04:33 +13:00
15 changed files with 721 additions and 252 deletions

View File

@ -1,2 +1,22 @@
# TropHAX-SE
TropHAX Standalone Edition
# Will i get banned?
Probably not, no one has ever gotten banned on vita
even in the past when using other trophy hacks such as:
TropHAX.suprx TrophyPather or PSVTrophyIsGood
If you claim "me was banned" - ConsoleID or GTFO
give me ur CID and ill check if it really is until then-
assume such claims are bullsheet
# TropHAXSE
TropHAX Standalone Edition
A homebrew app that can unlock trophys for any game.
Unlike the original TropHAX.SUPRX however, this is compadible with 100% of games!
You simply need the game installed and the trophy files inside ur0:/trophy and you can unlock stuffs!
# Credits
Li - Lead developer, - working out how trophys work and stuff.
TheFlow (vitashell) - For trop_dat0: mounting code
Princess Of Sleeping - For helping me with trop_dat0: mounting
AnalogMan - for doing UI Stuffs
Zecoaxco - ksceRtcSetCurrentTick();

View File

@ -20,7 +20,7 @@ set(VITA_VERSION "01.00")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
set(VITA_MKSFOEX_FLAGS "${VITA_MKSFOEX_FLAGS} -d PARENTAL_LEVEL=1")
set(VITA_MKSFOEX_FLAGS "${VITA_MKSFOEX_FLAGS} -d PARENTAL_LEVEL=1 -s CATEGORY=gdb")
set(VITA_MAKE_FSELF_FLAGS "${VITA_MAKE_FSELF_FLAGS} -a 0x2808000000000000")
include_directories(
@ -61,8 +61,8 @@ vita_create_vpk(${PROJECT_NAME}.vpk ${VITA_TITLEID} eboot.bin
FILE kernel.skprx module/kernel.skprx
FILE user.suprx module/user.suprx
#FILE sce_sys/icon0.png sce_sys/icon0.png
#FILE sce_sys/livearea/contents/bg.png sce_sys/livearea/contents/bg.png
#FILE sce_sys/livearea/contents/startup.png sce_sys/livearea/contents/startup.png
#FILE sce_sys/livearea/contents/template.xml sce_sys/livearea/contents/template.xml
FILE sce_sys/icon0.png sce_sys/icon0.png
FILE sce_sys/livearea/contents/bg0.png sce_sys/livearea/contents/bg0.png
FILE sce_sys/livearea/contents/startup.png sce_sys/livearea/contents/startup.png
FILE sce_sys/livearea/contents/template.xml sce_sys/livearea/contents/template.xml
)

BIN
app/sce_sys/icon0.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 172 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 KiB

View File

@ -0,0 +1,23 @@
<?xml version="1.0" encoding="utf-8"?>
<livearea style="a1" format-ver="01.00" content-rev="1">
<livearea-background>
<image>bg0.png</image>
</livearea-background>
<gate>
<startup-image>startup.png</startup-image>
</gate>
<frame id="frame1">
</frame>
<frame id="frame2">
</frame>
<frame id="frame3">
</frame>
</livearea>

View File

@ -14,6 +14,7 @@
#include "debugScreen.h"
#include "np.h"
#include "rtc.h"
#define printf psvDebugScreenPrintf
#define F psvDebugScreenFont
@ -214,7 +215,6 @@ int pfsMount(const char *path) {
}
void sceNpTrophySetupDialogParamInit(SceNpTrophySetupDialogParam* param)
{
sceClibMemset( param, 0x0, sizeof(SceNpTrophySetupDialogParam) );
@ -227,6 +227,31 @@ void sceNpTrophySetupDialogParamInit(SceNpTrophySetupDialogParam* param)
int setSecureTick(unsigned long long int psTime)
{
printf("setSecureTick: %llx\n",psTime);
printf("Creating splits..\n");
char hexint[15];
memset(hexint,0,15);
sprintf(hexint,"%llx",psTime);
char ts1[7] = {hexint[0],hexint[1],hexint[2],hexint[3],hexint[4],hexint[5],0x00};
unsigned long long int split1 = (unsigned int)strtoul(ts1, NULL, 16);
printf("Split1: %llx\n",split1);
char ts2[10] = {hexint[6],hexint[7],hexint[8],hexint[9],hexint[10],hexint[11],hexint[12],hexint[13],hexint[14],0x00};
unsigned long long int split2 = (unsigned int)strtoul(ts2, NULL, 16);
printf("Split2: %llx\n",split2);
return SetTrophyTimes(split2,split1);
}
int main() {
gxm_init();
psvDebugScreenInit();
@ -378,7 +403,7 @@ start:
SceUChar8 commsign[160];
memset(commsign,0,160);
char path[1024];
char path[0x1128];
SceUID fd;
int len;
@ -428,33 +453,6 @@ start:
memset(location,0x0,0x1028);
char checkPath[0x1028];
memset(checkPath,0x00,0x1028);
sprintf(checkPath,"ux0:/patch/%s/sce_sys/trophy/%s/TROPHY.TRP",titleidOfGame,commid);
if(getFileSize(checkPath) >=0)
{
sprintf(location,"ux0:/patch");
goto Found;
}
memset(checkPath,0x00,0x1028);
sprintf(checkPath,"grw0:/patch/%s/sce_sys/trophy/%s/TROPHY.TRP",titleidOfGame,commid);
if(getFileSize(checkPath) >=0)
{
sprintf(location,"grw0:/patch");
goto Found;
}
memset(checkPath,0x00,0x1028);
sprintf(checkPath,"ur0:/patch/%s/sce_sys/trophy/%s/TROPHY.TRP",titleidOfGame,commid);
if(getFileSize(checkPath) >=0)
{
sprintf(location,"ur0:/patch");
goto Found;
}
memset(checkPath,0x00,0x1028);
sprintf(checkPath,"ux0:/app/%s/sce_sys/trophy/%s/TROPHY.TRP",titleidOfGame,commid);
@ -490,8 +488,12 @@ start:
goto Found;
}
printf("Cound not find %s\n",titleidOfGame);
while(1){};
printf("Cound not find %s (Possibly game not installed?)\n",titleidOfGame);
while(1){
sceCtrlPeekBufferPositive(0, &pad, 1)
if(pad.buttons == SCE_CTRL_CIRCLE)
goto start;
};
Found:
@ -499,17 +501,13 @@ Found:
sprintf(path,"%s/%s",location,titleidOfGame);
ret = sceAppMgrGameDataMount(path,0,0,g_currentMount);
ret = sceAppMgrGameDataMount(path,0,0,g_currentMount); //GameDataMount mounts WITH patches, so no need to check for them
if(ret < 0){
printf("sceAppMgrGameDataMount() failed. ret = 0x%x\n", ret);
while(1){};
}
memset(path,0,1024);
memset(path,0,0x1128);
sprintf(path,"%s/sce_sys/trophy/%s/TROPHY.TRP",g_currentMount,commid);
size = getFileSize(path);
if (size >=0)
@ -527,7 +525,7 @@ Found:
while(1){};
}
memset(path,0,1024);
memset(path,0,0x1128);
sprintf(path,"ux0:app/%s/sce_sys",titleid);
sceIoMkdir(path,0006);
sprintf(path,"ux0:app/%s/sce_sys/trophy",titleid);
@ -561,7 +559,7 @@ Found:
// remount app0
// CelesteBlue TAKE NOTES.
memset(path,0,1024);
memset(path,0,0x1128);
sprintf(path,"ux0:/app/%s",titleid);
ret = pfsMount(path);
if(ret < 0){
@ -727,7 +725,544 @@ TrophyMenu:
sceKernelDelayThread(150000);
}
if(pad.buttons == SCE_CTRL_CIRCLE)
if(pad.buttons == SCE_CTRL_CIRCLE)
{
psvDebugScreenClear();
ret = sceNpTrophyDestroyContext(trophyContext);
if(ret < 0){
printf("sceNpTrophyDestroyContext() failed. ret = 0x%x\n", ret);
while(1){};
}
ret = sceNpTrophyDestroyHandle(handle);
if(ret < 0){
printf("sceNpTrophyDestroyHandle() failed. ret = 0x%x\n", ret);
while(1){};
}
ret = sceNpTrophyTerm();
if(ret < 0){
printf("sceNpTrophyTerm() failed. ret = 0x%x\n", ret);
while(1){};
}
sceKernelStopUnloadModule(user_modid, 0, NULL, 0, NULL, NULL);
taiStopUnloadKernelModule(kernel_modid, 0, NULL, 0, NULL, NULL);
sceKernelDelayThread(150000);
goto start;
}
if (pad.buttons == SCE_CTRL_CROSS)
{
if(selection == 0)
{
//Show trophy selection menu
x = 1, y = 1, selection = 0, window = 0;
psvDebugScreenClear();
printf("Obtaining trophy count..");
SceNpTrophyGameDetails gameDetails = {0};
gameDetails.size = sizeof(SceNpTrophyGameDetails);
sceNpTrophyGetGameInfo(trophyContext,handle,&gameDetails,NULL);
size = gameDetails.numTrophies;
printf(" %i\n",size);
paths *trophy_list = malloc(sizeof(paths)*size);
SceNpTrophyDetails trophyDetails = {0};
trophyDetails.size = sizeof(SceNpTrophyDetails);
printf("Obtaining trophy names...");
for (int i=0; i < size; i++)
{
sceNpTrophyGetTrophyInfo(trophyContext,handle,i,&trophyDetails,NULL);
if(strcmp((char *)trophyDetails.name,"") !=0)
{
sprintf(trophy_list[i].path,"%.50s (%i)",trophyDetails.name,i);
}
else
{
sprintf(trophy_list[i].path,"Hidden Trophy (%i)",i);
}
}
printf("OK!\n");
sceKernelDelayThread(500000);
selectTrophyMenu:
psvDebugScreenClear();
while(1)
{
char buf[256];
strncpy(buf, "**** TropHax StandAlone Edition ****", sizeof(buf));
printf("\e[%i;%iH%s", 1, CENTERX(buf), buf);
strncpy(buf, "Choose a trophy:", sizeof(buf));
printf("\e[%i;%iH%s", 2, CENTERX(buf), buf);
y = 3;
int max = (size < WINDOW_HEIGHT) ? size : WINDOW_HEIGHT;
for (int i=0; i < max; i++) {
if (i+window == selection)
psvDebugScreenSetFgColor(0xFF0000);
printf("\e[%i;%iH%s", y, x, trophy_list[i+window].path);
y += 1;
psvDebugScreenSetFgColor(0xFFFFFF);
}
strncpy(buf, "U/D: Select Trophy X: Unlock O: Return", sizeof(buf));
printf("\e[%i;%iH%s", SCREEN_ROW, CENTERX(buf), buf);
memset(&pad, 0, sizeof(pad));
sceCtrlPeekBufferPositive(0, &pad, 1);
if (pad.buttons == SCE_CTRL_UP)
{
if (selection <= size - WINDOW_HEIGHT){
window -= 1;
}
if (window < 0){
window = 0;
}
selection -= 1;
if (selection < 0)
selection = 0;
sceKernelDelayThread(150000);
}
if (pad.buttons == SCE_CTRL_DOWN)
{
if (selection >= WINDOW_HEIGHT - 1){
window += 1;
}
if (window > size - WINDOW_HEIGHT){
window = (size - WINDOW_HEIGHT < 0) ? 0 : size - WINDOW_HEIGHT;
}
selection += 1;
if (selection + 1 > size - 1)
selection = size - 1;
sceKernelDelayThread(150000);
}
if (pad.buttons == SCE_CTRL_CROSS)
{
psvDebugScreenClear(); // Clear the screen!
sceKernelDelayThread(200000);
x = 1, y = 1;
int selection2 = 0;
int window2 = 0;
int size2 = 2;
paths *timeList = malloc(sizeof(paths)*size2);
//set options
strcpy(timeList[0].path, "Use Real SecureTick");
strcpy(timeList[1].path, "Use Fake SecureTick");
while(1)
{
char buf[256];
strncpy(buf, "**** TropHax StandAlone Edition ****", sizeof(buf));
printf("\e[%i;%iH%s", 1, CENTERX(buf), buf);
strncpy(buf, "Choose an Option:", sizeof(buf));
printf("\e[%i;%iH%s", 2, CENTERX(buf), buf);
y = 3;
int max = (size2 < WINDOW_HEIGHT) ? size2 : WINDOW_HEIGHT;
for (int i=0; i < max; i++) {
if (i+window2 == selection2)
psvDebugScreenSetFgColor(0xFF0000);
printf("\e[%i;%iH%s", y, x, timeList[i+window2].path);
y += 1;
psvDebugScreenSetFgColor(0xFFFFFF);
}
strncpy(buf, "U/D: Select Option X: Confirm", sizeof(buf));
printf("\e[%i;%iH%s", SCREEN_ROW, CENTERX(buf), buf);
memset(&pad, 0, sizeof(pad));
sceCtrlPeekBufferPositive(0, &pad, 1);
if (pad.buttons == SCE_CTRL_UP)
{
if (selection2 <= size2 - WINDOW_HEIGHT){
window2 -= 1;
}
if (window2 < 0){
window2 = 0;
}
selection2 -= 1;
if (selection2 < 0)
selection2 = 0;
sceKernelDelayThread(150000);
}
if (pad.buttons == SCE_CTRL_DOWN)
{
if (selection2 >= WINDOW_HEIGHT - 1){
window2 += 1;
}
if (window2 > size2 - WINDOW_HEIGHT){
window2 = (size2 - WINDOW_HEIGHT < 0) ? 0 : size2 - WINDOW_HEIGHT;
}
selection2 += 1;
if (selection2 + 1 > size2 - 1)
selection2 = size2 - 1;
sceKernelDelayThread(150000);
}
if (pad.buttons == SCE_CTRL_CROSS)
{
if(selection2 == 0)
{
psvDebugScreenClear();
printf("Unlocking trophy %i\n",selection);
SceNpTrophyId id = selection;
SceNpTrophyId platid;
ret = sceNpTrophyUnlockTrophy(trophyContext,handle,id,&platid);
if(ret < 0){
if(ret == 0x8055160f)
{
printf("Trophy %li is allready unlocked.\n",id);
}
else
{
printf("sceNpTrophyUnlockTrophy() failed. ret = 0x%x\n", ret);
}
}
else
{
printf("Successfully unlocked trophy %li\n",id);
SceNpTrophyDetails trophyDetails = {0};
trophyDetails.size = sizeof(SceNpTrophyDetails);
sceNpTrophyGetTrophyInfo(trophyContext,handle,id,&trophyDetails,NULL);
memset(trophy_list[id].path,0x00,sizeof(trophy_list[id].path));
sprintf(trophy_list[id].path,"%.50s (%li)",trophyDetails.name,id);
}
sceKernelDelayThread(500000);
goto selectTrophyMenu;
}
if(selection2 == 1)
{
psvDebugScreenClear();
sceKernelDelayThread(150000);
int selectedPartOfTime = 0;
SceDateTime dateTime;
memset(&dateTime,0x00,sizeof(SceDateTime));
SceRtcTick fakeTime = {0};
sceRtcGetCurrentTick(&fakeTime);
sceRtcConvertUtcToLocalTime(&fakeTime,&fakeTime);
sceRtcSetTick(&dateTime,&fakeTime);
while(1)
{
char buf[256];
strncpy(buf, "**** TropHax StandAlone Edition ****", sizeof(buf));
printf("\e[%i;%iH%s\n", 1, CENTERX(buf), buf);
printf("Set SecureTick: (DD/MM/YY H:M:S)\n");
if(selectedPartOfTime == 0)
{
psvDebugScreenSetFgColor(0xFF0000);
}
printf("%02d",dateTime.day);
psvDebugScreenSetFgColor(0xFFFFFF);
printf("/");
if(selectedPartOfTime == 1)
{
psvDebugScreenSetFgColor(0xFF0000);
}
printf("%02d",dateTime.month);
psvDebugScreenSetFgColor(0xFFFFFF);
printf("/");
if(selectedPartOfTime == 2)
{
psvDebugScreenSetFgColor(0xFF0000);
}
printf("%02d",dateTime.year);
psvDebugScreenSetFgColor(0xFFFFFF);
printf(" ");
if(selectedPartOfTime == 3)
{
psvDebugScreenSetFgColor(0xFF0000);
}
printf("%02d",dateTime.hour);
psvDebugScreenSetFgColor(0xFFFFFF);
printf(":");
if(selectedPartOfTime == 4)
{
psvDebugScreenSetFgColor(0xFF0000);
}
printf("%02d",dateTime.minute);
psvDebugScreenSetFgColor(0xFFFFFF);
printf(":");
if(selectedPartOfTime == 5)
{
psvDebugScreenSetFgColor(0xFF0000);
}
printf("%02d",dateTime.second);
psvDebugScreenSetFgColor(0xFFFFFF);
printf("\n\nResulting timestamp:\n");
printf("%llx",fakeTime.tick);
strncpy(buf, "U/D: Increment/Decrement L/R: Part of Date X: Confirm", sizeof(buf));
printf("\e[%i;%iH%s", SCREEN_ROW, CENTERX(buf), buf);
memset(&pad, 0, sizeof(pad));
sceCtrlPeekBufferPositive(0, &pad, 1);
if(pad.buttons == SCE_CTRL_RIGHT)
{
selectedPartOfTime ++;
if(selectedPartOfTime >= 5)
{
selectedPartOfTime = 5;
}
sceKernelDelayThread(150000);
}
if(pad.buttons == SCE_CTRL_LEFT)
{
selectedPartOfTime --;
if(selectedPartOfTime <= 0)
{
selectedPartOfTime = 0;
}
sceKernelDelayThread(150000);
}
if(pad.buttons == SCE_CTRL_UP)
{
if(selectedPartOfTime == 0)
{
dateTime.day ++;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.day --;
}
}
if(selectedPartOfTime == 1)
{
dateTime.month ++;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.month --;
}
}
if(selectedPartOfTime == 2)
{
dateTime.year ++;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.year --;
}
}
if(selectedPartOfTime == 3)
{
dateTime.hour ++;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.hour --;
}
}
if(selectedPartOfTime == 4)
{
dateTime.minute ++;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.minute --;
}
}
if(selectedPartOfTime == 5)
{
dateTime.second ++;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.second --;
}
}
sceKernelDelayThread(150000);
}
if(pad.buttons == SCE_CTRL_DOWN)
{
if(selectedPartOfTime == 0)
{
dateTime.day --;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.day ++;
}
}
if(selectedPartOfTime == 1)
{
dateTime.month --;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.month ++;
}
}
if(selectedPartOfTime == 2)
{
dateTime.year --;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.year ++;
}
}
if(selectedPartOfTime == 3)
{
dateTime.hour --;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.hour ++;
}
}
if(selectedPartOfTime == 4)
{
dateTime.minute --;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.minute ++;
}
}
if(selectedPartOfTime == 5)
{
dateTime.second --;
ret = sceRtcGetTick(&dateTime, &fakeTime);
if(ret < 0)
{
dateTime.second ++;
}
}
sceKernelDelayThread(150000);
}
if(pad.buttons == SCE_CTRL_CROSS)
{
psvDebugScreenClear();
printf("Unlocking trophy %i\n",selection);
SceNpTrophyId id = selection;
SceNpTrophyId platid;
FakeTimes(1);
sceRtcConvertLocalTimeToUtc(&fakeTime, &fakeTime);
setSecureTick(fakeTime.tick);
ret = sceNpTrophyUnlockTrophy(trophyContext,handle,id,&platid);
if(ret < 0){
if(ret == 0x8055160f)
{
printf("Trophy %li is allready unlocked.\n",id);
}
else
{
printf("sceNpTrophyUnlockTrophy() failed. ret = 0x%x\n", ret);
}
}
else
{
printf("Successfully unlocked trophy %li\n",id);
SceNpTrophyDetails trophyDetails = {0};
trophyDetails.size = sizeof(SceNpTrophyDetails);
sceNpTrophyGetTrophyInfo(trophyContext,handle,id,&trophyDetails,NULL);
memset(trophy_list[id].path,0x00,sizeof(trophy_list[id].path));
sprintf(trophy_list[id].path,"%.50s (%li)",trophyDetails.name,id);
}
FakeTimes(0);
sceKernelDelayThread(500000);
goto selectTrophyMenu;
}
;
}
}
}
}
}
if (pad.buttons == SCE_CTRL_CIRCLE)
{
sceKernelDelayThread(150000);
goto TrophyMenu;
}
if(window != oWindow)
{
psvDebugScreenClear();
oWindow = window;
}
}
}
else if(selection == 1)
{
psvDebugScreenClear(); //clear screen
SceNpTrophyId id = 0;
SceNpTrophyId platid;
while (1)
{
ret = sceNpTrophyUnlockTrophy(trophyContext,handle,id,&platid);
if(ret < 0){
if(ret == 0x8055160f)
{
printf("Trophy %li is allready unlocked.\n",id);
}
else if(ret == 0x8055160e)
{
printf("All trophys unlocked!\n");
sceKernelDelayThread(500000);
goto TrophyMenu;
}
else
{
printf("sceNpTrophyUnlockTrophy() failed. ret = 0x%x\n", ret);
}
}
else
{
printf("Successfully unlocked trophy %li\n",id);
}
id ++;
}
}
else if(selection == 2)
{
psvDebugScreenClear();
ret = sceNpTrophyDestroyContext(trophyContext);
@ -754,208 +1289,21 @@ TrophyMenu:
sceKernelDelayThread(150000);
goto start;
}
if (pad.buttons == SCE_CTRL_CROSS)
{
if(selection == 0)
{
//Show trophy selection menu
x = 1, y = 1, selection = 0, window = 0;
psvDebugScreenClear();
printf("Obtaining trophy count..");
SceNpTrophyGameDetails gameDetails = {0};
gameDetails.size = sizeof(SceNpTrophyGameDetails);
sceNpTrophyGetGameInfo(trophyContext,handle,&gameDetails,NULL);
size = gameDetails.numTrophies;
printf(" %i\n",size);
paths *trophy_list = malloc(sizeof(paths)*size);
SceNpTrophyDetails trophyDetails = {0};
trophyDetails.size = sizeof(SceNpTrophyDetails);
printf("Obtaining trophy names...");
for (int i=0; i < size; i++)
{
sceNpTrophyGetTrophyInfo(trophyContext,handle,i,&trophyDetails,NULL);
if(strcmp((char *)trophyDetails.name,"") !=0)
{
sprintf(trophy_list[i].path,"%.50s (%i)",trophyDetails.name,i);
}
else
{
sprintf(trophy_list[i].path,"Hidden Trophy (%i)",i);
}
}
printf("OK!\n");
sceKernelDelayThread(500000);
selectTrophyMenu:
psvDebugScreenClear();
while(1)
{
char buf[256];
strncpy(buf, "**** TropHax StandAlone Edition ****", sizeof(buf));
printf("\e[%i;%iH%s", 1, CENTERX(buf), buf);
strncpy(buf, "Choose a trophy:", sizeof(buf));
printf("\e[%i;%iH%s", 2, CENTERX(buf), buf);
y = 3;
int max = (size < WINDOW_HEIGHT) ? size : WINDOW_HEIGHT;
for (int i=0; i < max; i++) {
if (i+window == selection)
psvDebugScreenSetFgColor(0xFF0000);
printf("\e[%i;%iH%s", y, x, trophy_list[i+window].path);
y += 1;
psvDebugScreenSetFgColor(0xFFFFFF);
}
strncpy(buf, "U/D: Select Trophy X: Unlock O: Return", sizeof(buf));
printf("\e[%i;%iH%s", SCREEN_ROW, CENTERX(buf), buf);
memset(&pad, 0, sizeof(pad));
sceCtrlPeekBufferPositive(0, &pad, 1);
if (pad.buttons == SCE_CTRL_UP)
{
if (selection <= size - WINDOW_HEIGHT){
window -= 1;
}
if (window < 0){
window = 0;
}
selection -= 1;
if (selection < 0)
selection = 0;
sceKernelDelayThread(150000);
}
if (pad.buttons == SCE_CTRL_DOWN)
{
if (selection >= WINDOW_HEIGHT - 1){
window += 1;
}
if (window > size - WINDOW_HEIGHT){
window = (size - WINDOW_HEIGHT < 0) ? 0 : size - WINDOW_HEIGHT;
}
selection += 1;
if (selection + 1 > size - 1)
selection = size - 1;
sceKernelDelayThread(150000);
}
if (pad.buttons == SCE_CTRL_CROSS)
{
psvDebugScreenClear();
printf("Unlocking trophy %i\n",selection);
SceNpTrophyId id = selection;
SceNpTrophyId platid;
ret = sceNpTrophyUnlockTrophy(trophyContext,handle,id,&platid);
if(ret < 0){
if(ret == 0x8055160f)
{
printf("Trophy %li is allready unlocked.\n",id);
}
else
{
printf("sceNpTrophyUnlockTrophy() failed. ret = 0x%x\n", ret);
}
}
else
{
printf("Successfully unlocked trophy %li\n",id);
SceNpTrophyDetails trophyDetails = {0};
trophyDetails.size = sizeof(SceNpTrophyDetails);
sceNpTrophyGetTrophyInfo(trophyContext,handle,id,&trophyDetails,NULL);
memset(trophy_list[id].path,0x00,sizeof(trophy_list[id].path));
sprintf(trophy_list[id].path,"%.50s (%li)",trophyDetails.name,id);
}
sceKernelDelayThread(500000);
goto selectTrophyMenu;
}
if (pad.buttons == SCE_CTRL_CIRCLE)
{
sceKernelDelayThread(150000);
goto TrophyMenu;
}
if(window != oWindow)
{
psvDebugScreenClear();
oWindow = window;
}
}
}
else if(selection == 1)
{
psvDebugScreenClear(); //clear screen
SceNpTrophyId id = 0;
SceNpTrophyId platid;
while (1)
{
ret = sceNpTrophyUnlockTrophy(trophyContext,handle,id,&platid);
if(ret < 0){
if(ret == 0x8055160f)
{
printf("Trophy %li is allready unlocked.\n",id);
}
else if(ret == 0x8055160e)
{
printf("All trophys unlocked!\n");
sceKernelDelayThread(500000);
goto TrophyMenu;
}
else
{
printf("sceNpTrophyUnlockTrophy() failed. ret = 0x%x\n", ret);
}
}
else
{
printf("Successfully unlocked trophy %li\n",id);
}
id ++;
}
}
else if(selection == 2)
{
psvDebugScreenClear();
ret = sceNpTrophyDestroyContext(trophyContext);
if(ret < 0){
printf("sceNpTrophyDestroyContext() failed. ret = 0x%x\n", ret);
while(1){};
}
ret = sceNpTrophyDestroyHandle(handle);
if(ret < 0){
printf("sceNpTrophyDestroyHandle() failed. ret = 0x%x\n", ret);
while(1){};
}
ret = sceNpTrophyTerm();
if(ret < 0){
printf("sceNpTrophyTerm() failed. ret = 0x%x\n", ret);
while(1){};
}
sceKernelStopUnloadModule(user_modid, 0, NULL, 0, NULL, NULL);
taiStopUnloadKernelModule(kernel_modid, 0, NULL, 0, NULL, NULL);
sceKernelDelayThread(150000);
goto start;
}
}
}
}
if(window != oWindow)
{
psvDebugScreenClear();
oWindow = window;
}
if(window != oWindow)
{
psvDebugScreenClear();
oWindow = window;
}
}while (pad.buttons != SCE_CTRL_CIRCLE);

4
app/src/rtc.h Normal file
View File

@ -0,0 +1,4 @@
//Defines functions relating to changing timestamps
int SetTrophyTimes(unsigned int timestamp1,unsigned int timestamp2);
int FakeTimes(int value);

View File

@ -25,6 +25,8 @@ target_link_libraries(${PROJECT_NAME}
SceModulemgrForDriver_stub
SceThreadmgrForDriver_stub
SceProcessmgrForDriver_stub
SceRtcForDriver_stub
SceDebugForDriver_stub
#SceNpDrmForDriver_stub
taihenForKernel_stub
taihenModuleUtils_stub

View File

@ -10,4 +10,6 @@ SceAppMgrKernel2:
SceAppMgrKernel2Library:
syscall: true
functions:
- sceAppMgrKernelMountById
- sceAppMgrKernelMountById
- kSetTrophyTimes
- kFakeTimes

View File

@ -17,11 +17,7 @@
*/
#include <psp2kern/kernel/cpu.h>
#include <psp2kern/kernel/modulemgr.h>
#include <psp2kern/kernel/sysmem.h>
#include <psp2kern/kernel/threadmgr.h>
#include <psp2kern/io/fcntl.h>
#include <vitasdkkern.h>
#include <stdio.h>
#include <string.h>
@ -30,6 +26,8 @@
#include "appmgr_kernel.h"
#define printf ksceDebugPrintf
int module_get_export_func(SceUID pid, const char *modname, uint32_t libnid, uint32_t funcnid, uintptr_t *func);
int module_get_offset(SceUID pid, SceUID modid, int segidx, size_t offset, uintptr_t *addr);
@ -37,8 +35,50 @@ void *(* sceAppMgrFindProcessInfoByPid)(void *data, SceUID pid);
int (* sceAppMgrMountById)(SceUID pid, void *info, int id, const char *titleid, const char *path, const char *desired_mount_point, const void *klicensee, char *mount_point);
int (* _ksceKernelGetModuleInfo)(SceUID pid, SceUID modid, SceKernelModuleInfo *info);
int ksceRtcSetCurrentSecureTick(unsigned int* timestamp);
int ksceRtcGetCurrentSecureTick(unsigned int* timestamp);
static int hook = -1;
static tai_hook_ref_t ref_hook;
tai_module_info_t tai_info;
int fakeTime[2];
int spoofTime = 0;
int getTimePatched(unsigned int* timestamp)
{
int ret;
ret = TAI_CONTINUE(int, ref_hook,timestamp);
if(spoofTime)
{
printf("[TROPHAXSE] Faking timestamp to %x%x and Return 0",fakeTime[1],fakeTime[0]);
timestamp[0] = fakeTime[0];
timestamp[1] = fakeTime[1];
return 0;
}
return ret;
}
int kFakeTimes(int value)
{
spoofTime = value;
return 0;
}
int kSetTrophyTimes(unsigned int timestamp1, unsigned int timestamp2)
{
fakeTime[0] = timestamp1;
fakeTime[1] = timestamp2;
return 0;
}
int _sceAppMgrKernelMountById(SceAppMgrMountIdArgs *args) {
int res;
@ -105,8 +145,14 @@ int sceAppMgrKernelMountById(SceAppMgrMountIdArgs *args) {
void _start() __attribute__ ((weak, alias("module_start")));
int module_start(SceSize args, void *argp) {
printf("TrophaxSE Kernel Module loaded!\n");
hook = taiHookFunctionExportForKernel(KERNEL_PID,
&ref_hook,
"SceRtc",
0x0351D827, // SceRtcForDriver
0x401C0954, // ksceRtcGetCurrentSecureTick
getTimePatched);
printf("[TROPHAXSE] hook: %x\n",hook);
// Get tai module info
@ -132,16 +178,24 @@ int module_start(SceSize args, void *argp) {
break;
case 0x321E4852: // 3.69 retail
case 0x700DA0CD: // 3.70 retail
case 0xF7846B4E: // 3.71 retail
case 0xA8E80BA8: // 3.72 retail
case 0xB299D195: // 3.73 retail
default:
module_get_offset(KERNEL_PID, tai_info.modid, 0, 0x2DE9, (uintptr_t *)&sceAppMgrFindProcessInfoByPid);
module_get_offset(KERNEL_PID, tai_info.modid, 0, 0x19E95, (uintptr_t *)&sceAppMgrMountById);
break;
}
return SCE_KERNEL_START_SUCCESS;
}
int module_stop(SceSize args, void *argp) {
if (hook >= 0) taiHookReleaseForKernel(hook, ref_hook);
return SCE_KERNEL_STOP_SUCCESS;
}

View File

@ -22,6 +22,7 @@ target_link_libraries(${PROJECT_NAME}
SceLibKernel_stub
SceIofilemgr_stub
SceAppMgrKernel2_stub
SceLibc_stub
)
vita_create_self(user.suprx ${PROJECT_NAME} CONFIG exports.yml UNSAFE)

View File

@ -10,4 +10,6 @@ SceAppMgrUser:
SceAppMgrUserLibrary:
syscall: false
functions:
- sceAppMgrUserMountById
- sceAppMgrUserMountById
- SetTrophyTimes
- FakeTimes

View File

@ -1,3 +1,5 @@
#include <appmgr_kernel.h>
int sceAppMgrUserMountById(SceAppMgrMountIdArgs *args);
int kSetTrophyTimes(unsigned int timestamp1, unsigned int timestamp2);
int kFakeTimes(int value);

View File

@ -18,9 +18,20 @@
#include <psp2/kernel/modulemgr.h>
#include <vitasdk.h>
#include "appmgr_user.h"
int SetTrophyTimes(unsigned int timestamp1,unsigned int timestamp2)
{
return kSetTrophyTimes(timestamp1,timestamp2);
}
int FakeTimes(int value)
{
return kFakeTimes(value);
}
int sceAppMgrUserMountById(SceAppMgrMountIdArgs *args) {
return sceAppMgrKernelMountById(args);
}