mirror of
https://github.com/suchmememanyskill/TegraExplorer.git
synced 2025-01-14 04:26:01 +00:00
Reduce file size + cleanup + add coreboot.rom file booting
This commit is contained in:
parent
bd99e2a138
commit
317e4b2038
3 changed files with 47 additions and 40 deletions
|
@ -347,7 +347,7 @@ void dump_sysnand()
|
||||||
{
|
{
|
||||||
h_cfg.emummc_force_disable = true;
|
h_cfg.emummc_force_disable = true;
|
||||||
b_cfg.extra_cfg &= ~EXTRA_CFG_DUMP_EMUMMC;
|
b_cfg.extra_cfg &= ~EXTRA_CFG_DUMP_EMUMMC;
|
||||||
dump_keys();
|
//dump_keys();
|
||||||
}
|
}
|
||||||
|
|
||||||
void dump_emunand()
|
void dump_emunand()
|
||||||
|
@ -356,7 +356,7 @@ void dump_emunand()
|
||||||
return;
|
return;
|
||||||
emu_cfg.enabled = 1;
|
emu_cfg.enabled = 1;
|
||||||
b_cfg.extra_cfg |= EXTRA_CFG_DUMP_EMUMMC;
|
b_cfg.extra_cfg |= EXTRA_CFG_DUMP_EMUMMC;
|
||||||
dump_keys();
|
//dump_keys();
|
||||||
}
|
}
|
||||||
|
|
||||||
ment_t ment_top[] = {
|
ment_t ment_top[] = {
|
||||||
|
|
|
@ -47,7 +47,7 @@ void viewbytes(char *path){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
msleep(200);
|
while (btn_read() & BTN_POWER);
|
||||||
|
|
||||||
while (1){
|
while (1){
|
||||||
f_lseek(&in, offset * 16);
|
f_lseek(&in, offset * 16);
|
||||||
|
@ -143,9 +143,9 @@ int filemenu(menu_entry file){
|
||||||
(attribs.fattrib & AM_ARC) ? 'A' : '-');
|
(attribs.fattrib & AM_ARC) ? 'A' : '-');
|
||||||
}
|
}
|
||||||
|
|
||||||
SETBIT(fs_menu_file[7].property, ISHIDE, !(strstr(file.name, ".bin") != NULL && file.property & ISKB));
|
SETBIT(fs_menu_file[7].property, ISHIDE, !(strstr(file.name, ".bin") != NULL && file.property & ISKB) && strstr(file.name, ".rom") == NULL);
|
||||||
SETBIT(fs_menu_file[8].property, ISHIDE, !(strstr(file.name, ".te") != NULL));
|
SETBIT(fs_menu_file[8].property, ISHIDE, strstr(file.name, ".te") == NULL);
|
||||||
SETBIT(fs_menu_file[10].property, ISHIDE, !(strstr(file.name, ".bis") != NULL));
|
SETBIT(fs_menu_file[10].property, ISHIDE, strstr(file.name, ".bis") == NULL);
|
||||||
|
|
||||||
temp = menu_make(fs_menu_file, 11, "-- File Menu --");
|
temp = menu_make(fs_menu_file, 11, "-- File Menu --");
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
#include <string.h>
|
||||||
#include "tools.h"
|
#include "tools.h"
|
||||||
#include "../gfx/gfxutils.h"
|
#include "../gfx/gfxutils.h"
|
||||||
#include "../../libs/fatfs/ff.h"
|
#include "../../libs/fatfs/ff.h"
|
||||||
|
@ -13,6 +14,9 @@
|
||||||
#include "../emmc/emmc.h"
|
#include "../emmc/emmc.h"
|
||||||
#include "../common/common.h"
|
#include "../common/common.h"
|
||||||
#include "../fs/fsactions.h"
|
#include "../fs/fsactions.h"
|
||||||
|
#include "../fs/fsutils.h"
|
||||||
|
#include "../../mem/heap.h"
|
||||||
|
#include "../utils/utils.h"
|
||||||
|
|
||||||
extern bool sd_mount();
|
extern bool sd_mount();
|
||||||
extern void sd_unmount();
|
extern void sd_unmount();
|
||||||
|
@ -96,10 +100,8 @@ int dumpfirmware(int mmc){
|
||||||
FILINFO fno;
|
FILINFO fno;
|
||||||
bool fail = false;
|
bool fail = false;
|
||||||
int ret, amount = 0;
|
int ret, amount = 0;
|
||||||
char path[100] = "emmc:/Contents/registered";
|
char sysbase[] = "emmc:/Contents/registered";
|
||||||
char sdfolderpath[100] = "";
|
char *syspathtemp, *syspath, *sdpath, *sdbase;
|
||||||
char syspath[100] = "";
|
|
||||||
char sdpath[100] = "";
|
|
||||||
pkg1_info pkg1 = returnpkg1info();
|
pkg1_info pkg1 = returnpkg1info();
|
||||||
u32 timer = get_tmr_s();
|
u32 timer = get_tmr_s();
|
||||||
|
|
||||||
|
@ -109,26 +111,33 @@ int dumpfirmware(int mmc){
|
||||||
|
|
||||||
gfx_printf("PKG1 version: %d\n", pkg1.ver);
|
gfx_printf("PKG1 version: %d\n", pkg1.ver);
|
||||||
|
|
||||||
ret = f_mkdir("sd:/tegraexplorer");
|
gfx_printf("Creating folders...\n");
|
||||||
gfx_printf("Creating sd:/tegraexplorer %d\n", ret);
|
f_mkdir("sd:/tegraexplorer");
|
||||||
|
f_mkdir("sd:/tegraexplorer/Firmware");
|
||||||
|
|
||||||
ret = f_mkdir("sd:/tegraexplorer/Firmware");
|
sdbase = calloc(32 + strlen(pkg1.id), sizeof(char));
|
||||||
gfx_printf("Creating sd:/tegraexplorer/Firmware %d\n", ret);
|
sprintf(sdbase, "sd:/tegraexplorer/Firmware/%d (%s)", pkg1.ver, pkg1.id);
|
||||||
|
gfx_printf("Out: %s\n", sdbase);
|
||||||
|
f_mkdir(sdbase);
|
||||||
|
|
||||||
sprintf(sdfolderpath, "sd:/tegraexplorer/Firmware/%d (%s)", pkg1.ver, pkg1.id);
|
if ((ret = f_opendir(&dir, sysbase)))
|
||||||
ret = f_mkdir(sdfolderpath);
|
fail = true;
|
||||||
gfx_printf("Creating %s %d\n", sdfolderpath, ret);
|
|
||||||
|
|
||||||
ret = f_opendir(&dir, path);
|
gfx_printf("Starting dump...\n");
|
||||||
gfx_printf("Result opening system:/ %d\n\n%k", ret, COLOR_GREEN);
|
SWAPCOLOR(COLOR_GREEN);
|
||||||
|
|
||||||
|
printerrors = 0;
|
||||||
|
|
||||||
while(!f_readdir(&dir, &fno) && fno.fname[0] && !fail){
|
while(!f_readdir(&dir, &fno) && fno.fname[0] && !fail){
|
||||||
sprintf(sdpath, "%s/%s", sdfolderpath, fno.fname);
|
utils_copystring(fsutil_getnextloc(sdbase, fno.fname), &sdpath);
|
||||||
|
utils_copystring(fsutil_getnextloc(sysbase, fno.fname), &syspathtemp);
|
||||||
if (fno.fattrib & AM_DIR)
|
|
||||||
sprintf(syspath, "%s/%s/00", path, fno.fname);
|
if (fno.fattrib & AM_DIR){
|
||||||
|
utils_copystring(fsutil_getnextloc(syspathtemp, "00"), &syspath);
|
||||||
|
free(syspathtemp);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
sprintf(syspath, "%s/%s", path, fno.fname);
|
syspath = syspathtemp;
|
||||||
|
|
||||||
ret = fsact_copy(syspath, sdpath, 0);
|
ret = fsact_copy(syspath, sdpath, 0);
|
||||||
|
|
||||||
|
@ -136,42 +145,40 @@ int dumpfirmware(int mmc){
|
||||||
|
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
fail = true;
|
fail = true;
|
||||||
|
|
||||||
|
free(sdpath);
|
||||||
|
free(syspath);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
printerrors = 1;
|
||||||
|
|
||||||
if (fail)
|
if (fail)
|
||||||
gfx_printf("%k\n\nDump failed! Aborting (%d)", COLOR_RED, ret);
|
gfx_printf("%k\n\nDump failed! Aborting (%d)", COLOR_RED, ret);
|
||||||
|
|
||||||
gfx_printf("%k\n\nPress any button to continue...\nTime taken: %ds", COLOR_WHITE, get_tmr_s() - timer);
|
gfx_printf("%k\n\nPress any button to continue...\nTime taken: %ds", COLOR_WHITE, get_tmr_s() - timer);
|
||||||
|
free(sdbase);
|
||||||
btn_wait();
|
btn_wait();
|
||||||
|
|
||||||
return fail;
|
return fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
void dumpusersaves(int mmc){
|
void dumpusersaves(int mmc){
|
||||||
int res;
|
|
||||||
|
|
||||||
connect_mmc(mmc);
|
connect_mmc(mmc);
|
||||||
mount_mmc("USER", 2);
|
mount_mmc("USER", 2);
|
||||||
gfx_clearscreen();
|
gfx_clearscreen();
|
||||||
|
|
||||||
res = f_mkdir("sd:/tegraexplorer");
|
gfx_printf("Creating folders...\n");
|
||||||
gfx_printf("Creating sd:/tegraexplorer, res: %d\nCopying:\n", res);
|
f_mkdir("sd:/tegraexplorer");
|
||||||
|
|
||||||
|
gfx_printf("Starting dump...\n");
|
||||||
|
|
||||||
SWAPCOLOR(COLOR_GREEN);
|
SWAPCOLOR(COLOR_GREEN);
|
||||||
|
|
||||||
res = fsact_copy_recursive("emmc:/save", "sd:/tegraexplorer");
|
if(fsact_copy_recursive("emmc:/save", "sd:/tegraexplorer"))
|
||||||
|
return;
|
||||||
SWAPCOLOR(COLOR_ORANGE);
|
|
||||||
gfx_printf("\rResult copy_recursive() %d\n\n", res);
|
|
||||||
|
|
||||||
if (res){
|
|
||||||
SWAPCOLOR(COLOR_RED);
|
|
||||||
gfx_printf("Dump failed!\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
gfx_printf("Saves are located in SD:/tegraexplorer/save\n");
|
|
||||||
|
|
||||||
|
RESETCOLOR;
|
||||||
|
gfx_printf("\n\nSaves are located in SD:/tegraexplorer/save\n");
|
||||||
gfx_printf("Press any key to continue");
|
gfx_printf("Press any key to continue");
|
||||||
btn_wait();
|
btn_wait();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue