Compare commits
14 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 72a2083d76 | |||
| 3f6bbc0752 | |||
| d1fc24dae8 | |||
| ef104bce41 | |||
| 0015c7e8ac | |||
| 6dde73f39e | |||
| 97e8c3d965 | |||
| 586afc2f56 | |||
| f943887b39 | |||
| 335ea03b05 | |||
| b0523ada6c | |||
| 9a2307a8ee | |||
| e71fb13bfc | |||
| 5bcd3987a2 |
2
.github/workflows/build.yml
vendored
2
.github/workflows/build.yml
vendored
@@ -1,7 +1,7 @@
|
|||||||
name: Build
|
name: Build
|
||||||
|
|
||||||
on:
|
on:
|
||||||
#push:
|
push:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
|
|||||||
199
Makefile
199
Makefile
@@ -1,90 +1,109 @@
|
|||||||
rwildcard = $(foreach d, $(wildcard $1*), $(filter $(subst *, %, $2), $d) $(call rwildcard, $d/, $2))
|
rwildcard = $(foreach d, $(wildcard $1*), $(filter $(subst *, %, $2), $d) $(call rwildcard, $d/, $2))
|
||||||
|
|
||||||
ifeq ($(strip $(DEVKITARM)),)
|
ifeq ($(strip $(DEVKITARM)),)
|
||||||
$(error "Please set DEVKITARM in your environment. export DEVKITARM=<path to>devkitARM")
|
$(error "Please set DEVKITARM in your environment. export DEVKITARM=<path to>devkitARM")
|
||||||
endif
|
endif
|
||||||
|
|
||||||
include $(DEVKITARM)/base_rules
|
include $(DEVKITARM)/base_rules
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
IPL_LOAD_ADDR := 0x40008000
|
IPL_LOAD_ADDR := 0x40008000
|
||||||
VERSION := $(shell cat VERSION)
|
VERSION := $(shell cat VERSION)
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
TARGET := omninx-installer
|
TARGET := omninx-installer
|
||||||
OUTPUT_NAME := OmniNX-Installer.bin
|
OUTPUT_NAME := OmniNX-Installer.bin
|
||||||
BUILDDIR := build
|
BUILDDIR := build
|
||||||
OUTPUTDIR := output
|
OUTPUTDIR := output
|
||||||
SOURCEDIR := source
|
SOURCEDIR := source
|
||||||
BDKDIR := bdk
|
BDKDIR := bdk
|
||||||
BDKINC := -I./$(BDKDIR)
|
BDKINC := -I./$(BDKDIR)
|
||||||
VPATH = $(dir ./$(SOURCEDIR)/) $(dir $(wildcard ./$(SOURCEDIR)/*/)) $(dir $(wildcard ./$(SOURCEDIR)/*/*/))
|
VPATH = $(dir ./$(SOURCEDIR)/) $(dir $(wildcard ./$(SOURCEDIR)/*/)) $(dir $(wildcard ./$(SOURCEDIR)/*/*/))
|
||||||
VPATH += $(dir $(wildcard ./$(BDKDIR)/)) $(dir $(wildcard ./$(BDKDIR)/*/)) $(dir $(wildcard ./$(BDKDIR)/*/*/))
|
VPATH += $(dir $(wildcard ./$(BDKDIR)/)) $(dir $(wildcard ./$(BDKDIR)/*/)) $(dir $(wildcard ./$(BDKDIR)/*/*/))
|
||||||
|
|
||||||
# All source files
|
# All source files
|
||||||
OBJS = $(patsubst $(SOURCEDIR)/%.S, $(BUILDDIR)/$(TARGET)/%.o, \
|
OBJS = $(patsubst $(SOURCEDIR)/%.S, $(BUILDDIR)/$(TARGET)/%.o, \
|
||||||
$(patsubst $(SOURCEDIR)/%.c, $(BUILDDIR)/$(TARGET)/%.o, \
|
$(patsubst $(SOURCEDIR)/%.c, $(BUILDDIR)/$(TARGET)/%.o, \
|
||||||
$(call rwildcard, $(SOURCEDIR), *.S *.c)))
|
$(call rwildcard, $(SOURCEDIR), *.S *.c)))
|
||||||
OBJS += $(patsubst $(BDKDIR)/%.S, $(BUILDDIR)/$(TARGET)/%.o, \
|
OBJS += $(patsubst $(BDKDIR)/%.S, $(BUILDDIR)/$(TARGET)/%.o, \
|
||||||
$(patsubst $(BDKDIR)/%.c, $(BUILDDIR)/$(TARGET)/%.o, \
|
$(patsubst $(BDKDIR)/%.c, $(BUILDDIR)/$(TARGET)/%.o, \
|
||||||
$(call rwildcard, $(BDKDIR), *.S *.c)))
|
$(call rwildcard, $(BDKDIR), *.S *.c)))
|
||||||
|
|
||||||
GFX_INC := '"../$(SOURCEDIR)/gfx.h"'
|
GFX_INC := '"../$(SOURCEDIR)/gfx.h"'
|
||||||
FFCFG_INC := '"../$(SOURCEDIR)/libs/fatfs/ffconf.h"'
|
FFCFG_INC := '"../$(SOURCEDIR)/libs/fatfs/ffconf.h"'
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
CUSTOMDEFINES := -DIPL_LOAD_ADDR=$(IPL_LOAD_ADDR)
|
CUSTOMDEFINES := -DIPL_LOAD_ADDR=$(IPL_LOAD_ADDR)
|
||||||
CUSTOMDEFINES += -DGFX_INC=$(GFX_INC) -DFFCFG_INC=$(FFCFG_INC)
|
CUSTOMDEFINES += -DGFX_INC=$(GFX_INC) -DFFCFG_INC=$(FFCFG_INC)
|
||||||
CUSTOMDEFINES += -DVERSION='"$(VERSION)"'
|
CUSTOMDEFINES += -DVERSION='"$(VERSION)"'
|
||||||
|
|
||||||
ARCH := -march=armv4t -mtune=arm7tdmi -mthumb -mthumb-interwork
|
ARCH := -march=armv4t -mtune=arm7tdmi -mthumb -mthumb-interwork
|
||||||
CFLAGS = $(ARCH) -Os -nostdlib -ffunction-sections -fdata-sections -fomit-frame-pointer -fno-inline -std=gnu11 -Wall -Wno-missing-braces $(CUSTOMDEFINES)
|
CFLAGS = $(ARCH) -Os -nostdlib -ffunction-sections -fdata-sections -fomit-frame-pointer -fno-inline -std=gnu11 -Wall -Wno-missing-braces $(CUSTOMDEFINES)
|
||||||
LDFLAGS = $(ARCH) -nostartfiles -lgcc -Wl,--nmagic,--gc-sections -Xlinker --defsym=IPL_LOAD_ADDR=$(IPL_LOAD_ADDR)
|
LDFLAGS = $(ARCH) -nostartfiles -lgcc -Wl,--nmagic,--gc-sections -Xlinker --defsym=IPL_LOAD_ADDR=$(IPL_LOAD_ADDR)
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
.PHONY: all clean release
|
RAMTEST_BIN := $(OUTPUTDIR)/RAM-Test.bin
|
||||||
|
OBJS_RAMTEST := $(filter-out $(BUILDDIR)/$(TARGET)/main.o,$(OBJS)) \
|
||||||
all: $(OUTPUTDIR)/$(OUTPUT_NAME)
|
$(BUILDDIR)/$(TARGET)/ram_test_main.o
|
||||||
$(eval BIN_SIZE = $(shell wc -c < $(OUTPUTDIR)/$(OUTPUT_NAME)))
|
|
||||||
@echo "Payload size is $(BIN_SIZE) bytes"
|
.PHONY: all clean release ram-test
|
||||||
@echo "Max size is 126296 bytes."
|
|
||||||
|
all: $(OUTPUTDIR)/$(OUTPUT_NAME)
|
||||||
clean:
|
$(eval BIN_SIZE = $(shell wc -c < $(OUTPUTDIR)/$(OUTPUT_NAME)))
|
||||||
@rm -rf $(BUILDDIR)
|
@echo "Payload size is $(BIN_SIZE) bytes"
|
||||||
@rm -rf $(OUTPUTDIR)
|
@echo "Max size is 126296 bytes."
|
||||||
@rm -rf release
|
|
||||||
@rm -f $(TARGET)-*.zip
|
clean:
|
||||||
|
@rm -rf $(BUILDDIR)
|
||||||
$(OUTPUTDIR)/$(OUTPUT_NAME): $(BUILDDIR)/$(TARGET)/$(TARGET).elf
|
@rm -rf $(OUTPUTDIR)
|
||||||
@mkdir -p "$(@D)"
|
@rm -f $(RAMTEST_BIN)
|
||||||
$(OBJCOPY) -S -O binary $< $(OUTPUTDIR)/$(TARGET).bin
|
@rm -rf release
|
||||||
@mv $(OUTPUTDIR)/$(TARGET).bin $(OUTPUTDIR)/$(OUTPUT_NAME)
|
@rm -f $(TARGET)-*.zip
|
||||||
|
|
||||||
$(BUILDDIR)/$(TARGET)/$(TARGET).elf: $(OBJS)
|
$(OUTPUTDIR)/$(OUTPUT_NAME): $(BUILDDIR)/$(TARGET)/$(TARGET).elf
|
||||||
$(CC) $(LDFLAGS) -T $(SOURCEDIR)/link.ld $^ -o $@
|
@mkdir -p "$(@D)"
|
||||||
|
$(OBJCOPY) -S -O binary $< $(OUTPUTDIR)/$(TARGET).bin
|
||||||
$(BUILDDIR)/$(TARGET)/%.o: $(SOURCEDIR)/%.c
|
@mv $(OUTPUTDIR)/$(TARGET).bin $(OUTPUTDIR)/$(OUTPUT_NAME)
|
||||||
@mkdir -p "$(@D)"
|
|
||||||
$(CC) $(CFLAGS) $(BDKINC) -I$(SOURCEDIR) -c $< -o $@
|
$(BUILDDIR)/$(TARGET)/$(TARGET).elf: $(OBJS)
|
||||||
|
$(CC) $(LDFLAGS) -T $(SOURCEDIR)/link.ld $^ -o $@
|
||||||
$(BUILDDIR)/$(TARGET)/%.o: $(SOURCEDIR)/%.S
|
|
||||||
@mkdir -p "$(@D)"
|
$(BUILDDIR)/$(TARGET)/ram_test_main.o: tools/ram_test_main.c
|
||||||
$(CC) $(CFLAGS) -c $< -o $@
|
@mkdir -p "$(@D)"
|
||||||
|
$(CC) $(CFLAGS) $(BDKINC) -I$(SOURCEDIR) -c $< -o $@
|
||||||
$(BUILDDIR)/$(TARGET)/%.o: $(BDKDIR)/%.c
|
|
||||||
@mkdir -p "$(@D)"
|
$(BUILDDIR)/$(TARGET)/ram_test.elf: $(OBJS_RAMTEST)
|
||||||
$(CC) $(CFLAGS) $(BDKINC) -I$(SOURCEDIR) -c $< -o $@
|
$(CC) $(LDFLAGS) -T $(SOURCEDIR)/link.ld $^ -o $@
|
||||||
|
|
||||||
$(BUILDDIR)/$(TARGET)/%.o: $(BDKDIR)/%.S
|
$(RAMTEST_BIN): $(BUILDDIR)/$(TARGET)/ram_test.elf
|
||||||
@mkdir -p "$(@D)"
|
@mkdir -p "$(@D)"
|
||||||
$(CC) $(CFLAGS) -c $< -o $@
|
$(OBJCOPY) -S -O binary $< $@
|
||||||
|
@echo "RAM-Test payload: $(RAMTEST_BIN) ($$(wc -c < $@) bytes)"
|
||||||
release: $(OUTPUTDIR)/$(OUTPUT_NAME)
|
|
||||||
@mkdir -p release/bootloader/payloads
|
ram-test: $(RAMTEST_BIN)
|
||||||
@cp $(OUTPUTDIR)/$(OUTPUT_NAME) release/bootloader/payloads/$(OUTPUT_NAME)
|
|
||||||
@cd release && zip -r ../$(TARGET)-$(VERSION).zip bootloader
|
$(BUILDDIR)/$(TARGET)/%.o: $(SOURCEDIR)/%.c
|
||||||
@echo "Release package created: $(TARGET)-$(VERSION).zip"
|
@mkdir -p "$(@D)"
|
||||||
|
$(CC) $(CFLAGS) $(BDKINC) -I$(SOURCEDIR) -c $< -o $@
|
||||||
|
|
||||||
|
$(BUILDDIR)/$(TARGET)/%.o: $(SOURCEDIR)/%.S
|
||||||
|
@mkdir -p "$(@D)"
|
||||||
|
$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
$(BUILDDIR)/$(TARGET)/%.o: $(BDKDIR)/%.c
|
||||||
|
@mkdir -p "$(@D)"
|
||||||
|
$(CC) $(CFLAGS) $(BDKINC) -I$(SOURCEDIR) -c $< -o $@
|
||||||
|
|
||||||
|
$(BUILDDIR)/$(TARGET)/%.o: $(BDKDIR)/%.S
|
||||||
|
@mkdir -p "$(@D)"
|
||||||
|
$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
|
release: $(OUTPUTDIR)/$(OUTPUT_NAME)
|
||||||
|
@mkdir -p release/bootloader/payloads
|
||||||
|
@cp $(OUTPUTDIR)/$(OUTPUT_NAME) release/bootloader/payloads/$(OUTPUT_NAME)
|
||||||
|
@cd release && zip -r ../$(TARGET)-$(VERSION).zip bootloader
|
||||||
|
@echo "Release package created: $(TARGET)-$(VERSION).zip"
|
||||||
|
|||||||
@@ -6,97 +6,14 @@
|
|||||||
#include "fs.h"
|
#include "fs.h"
|
||||||
#include <libs/fatfs/ff.h>
|
#include <libs/fatfs/ff.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
|
||||||
#include <utils/sprintf.h>
|
#include <utils/sprintf.h>
|
||||||
|
|
||||||
#define BACKUP_PATH_MAX 270
|
|
||||||
|
|
||||||
// Check if file/directory exists
|
// Check if file/directory exists
|
||||||
static bool path_exists(const char *path) {
|
static bool path_exists(const char *path) {
|
||||||
FILINFO fno;
|
FILINFO fno;
|
||||||
return (f_stat(path, &fno) == FR_OK);
|
return (f_stat(path, &fno) == FR_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create all parent directories for a path (mkdir -p style)
|
|
||||||
static void ensure_parent_dirs(const char *full_path) {
|
|
||||||
char buf[BACKUP_PATH_MAX];
|
|
||||||
int n = (int)strlen(full_path);
|
|
||||||
if (n >= BACKUP_PATH_MAX) return;
|
|
||||||
memcpy(buf, full_path, n + 1);
|
|
||||||
|
|
||||||
for (int i = 4; i < n; i++) {
|
|
||||||
if (buf[i] == '/') {
|
|
||||||
buf[i] = '\0';
|
|
||||||
f_mkdir(buf);
|
|
||||||
buf[i] = '/';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Copy a single path (file or dir) to backup base, preserving SD structure
|
|
||||||
static int backup_single_path(const char *src_path, const char *backup_base) {
|
|
||||||
FILINFO fno;
|
|
||||||
if (f_stat(src_path, &fno) != FR_OK)
|
|
||||||
return FR_OK;
|
|
||||||
|
|
||||||
const char *relative = src_path;
|
|
||||||
if (strncmp(relative, "sd:/", 4) == 0)
|
|
||||||
relative += 4;
|
|
||||||
|
|
||||||
if (fno.fattrib & AM_DIR) {
|
|
||||||
const char *last_slash = strrchr(relative, '/');
|
|
||||||
char parent[BACKUP_PATH_MAX];
|
|
||||||
if (last_slash && last_slash > relative) {
|
|
||||||
s_printf(parent, "%s/%.*s", backup_base, (int)(last_slash - relative), relative);
|
|
||||||
/* Create full parent hierarchy (e.g. atmosphere, atmosphere/contents) */
|
|
||||||
ensure_parent_dirs(parent);
|
|
||||||
f_mkdir(parent); /* Ensure parent exists; FR_EXIST is fine */
|
|
||||||
return folder_copy(src_path, parent);
|
|
||||||
} else {
|
|
||||||
ensure_parent_dirs(backup_base);
|
|
||||||
return folder_copy(src_path, backup_base);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
char dst_path[BACKUP_PATH_MAX];
|
|
||||||
s_printf(dst_path, "%s/%s", backup_base, relative);
|
|
||||||
ensure_parent_dirs(dst_path);
|
|
||||||
return file_copy(src_path, dst_path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Backup all paths from varargs lists (same structure as delete_path_lists_grouped)
|
|
||||||
int backup_deletion_lists(const char *backup_base, ...) {
|
|
||||||
va_list ap;
|
|
||||||
const char **list;
|
|
||||||
int res = FR_OK;
|
|
||||||
|
|
||||||
/* FatFS f_mkdir only creates the last component; parent must exist first */
|
|
||||||
ensure_parent_dirs(BACKUP_BASE_PATH);
|
|
||||||
res = f_mkdir(BACKUP_BASE_PATH);
|
|
||||||
if (res != FR_OK && res != FR_EXIST)
|
|
||||||
return res;
|
|
||||||
|
|
||||||
ensure_parent_dirs(backup_base);
|
|
||||||
res = f_mkdir(backup_base);
|
|
||||||
if (res != FR_OK && res != FR_EXIST)
|
|
||||||
return res;
|
|
||||||
|
|
||||||
va_start(ap, backup_base);
|
|
||||||
while ((list = va_arg(ap, const char **)) != NULL) {
|
|
||||||
for (int i = 0; list[i] != NULL; i++) {
|
|
||||||
if (path_exists(list[i])) {
|
|
||||||
int copy_res = backup_single_path(list[i], backup_base);
|
|
||||||
if (copy_res != FR_OK && res == FR_OK)
|
|
||||||
res = copy_res; // Remember first error but keep going
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
va_end(ap);
|
|
||||||
|
|
||||||
/* Best-effort: return FR_OK so install continues even if some copies failed */
|
|
||||||
return FR_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Backup user data before clean install
|
// Backup user data before clean install
|
||||||
int backup_user_data(void) {
|
int backup_user_data(void) {
|
||||||
int res;
|
int res;
|
||||||
|
|||||||
@@ -7,8 +7,6 @@
|
|||||||
#include <utils/types.h>
|
#include <utils/types.h>
|
||||||
|
|
||||||
#define TEMP_BACKUP_PATH "sd:/temp_backup"
|
#define TEMP_BACKUP_PATH "sd:/temp_backup"
|
||||||
#define BACKUP_BASE_PATH "sd:/backup/OmniNX"
|
|
||||||
#define PRE_OMNINX_LABEL "pre-omninx"
|
|
||||||
|
|
||||||
// Backup user data (DBI, Tinfoil, prod.keys) before clean install
|
// Backup user data (DBI, Tinfoil, prod.keys) before clean install
|
||||||
int backup_user_data(void);
|
int backup_user_data(void);
|
||||||
@@ -18,6 +16,3 @@ int restore_user_data(void);
|
|||||||
|
|
||||||
// Clean up temporary backup directory
|
// Clean up temporary backup directory
|
||||||
int cleanup_backup(void);
|
int cleanup_backup(void);
|
||||||
|
|
||||||
// Backup paths from varargs lists to backup_base (pass path arrays, terminate with NULL)
|
|
||||||
int backup_deletion_lists(const char *backup_base, ...);
|
|
||||||
|
|||||||
@@ -1,295 +1,298 @@
|
|||||||
/*
|
/*
|
||||||
* OmniNX Installer - Deletion Lists for Clean Install Mode
|
* OmniNX Installer - Deletion Lists for Clean Install Mode
|
||||||
* Selective deletion when no OmniNX install was found.
|
* Selective deletion when no OmniNX install was found.
|
||||||
* Only listed paths are removed; does not wipe whole card or user configs.
|
* Only listed paths are removed; does not wipe whole card or user configs.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
// Atmosphere subdirectories to delete
|
// Atmosphere subdirectories to delete
|
||||||
static const char* clean_atmosphere_dirs_to_delete[] = {
|
static const char* clean_atmosphere_dirs_to_delete[] = {
|
||||||
"sd:/atmosphere/config",
|
"sd:/atmosphere/config",
|
||||||
"sd:/atmosphere/crash_reports",
|
"sd:/atmosphere/crash_reports",
|
||||||
"sd:/atmosphere/erpt_reports",
|
"sd:/atmosphere/erpt_reports",
|
||||||
"sd:/atmosphere/exefs_patches/CrunchPatch",
|
"sd:/atmosphere/exefs_patches/CrunchPatch",
|
||||||
"sd:/atmosphere/exefs_patches/Crunchyroll Patch 1.10.0",
|
"sd:/atmosphere/exefs_patches/Crunchyroll Patch 1.10.0",
|
||||||
"sd:/atmosphere/exefs_patches/bluetooth_patches",
|
"sd:/atmosphere/exefs_patches/bluetooth_patches",
|
||||||
"sd:/atmosphere/exefs_patches/bootlogo",
|
"sd:/atmosphere/exefs_patches/bootlogo",
|
||||||
"sd:/atmosphere/exefs_patches/btm_patches",
|
"sd:/atmosphere/exefs_patches/btm_patches",
|
||||||
"sd:/atmosphere/exefs_patches/es_patches",
|
"sd:/atmosphere/exefs_patches/es_patches",
|
||||||
"sd:/atmosphere/exefs_patches/hid_patches",
|
"sd:/atmosphere/exefs_patches/hid_patches",
|
||||||
"sd:/atmosphere/exefs_patches/logo1",
|
"sd:/atmosphere/exefs_patches/logo1",
|
||||||
"sd:/atmosphere/exefs_patches/nfim_ctest",
|
"sd:/atmosphere/exefs_patches/nfim_ctest",
|
||||||
"sd:/atmosphere/exefs_patches/nim_ctest",
|
"sd:/atmosphere/exefs_patches/nim_ctest",
|
||||||
"sd:/atmosphere/exefs_patches/nvnflinger_cmu",
|
"sd:/atmosphere/exefs_patches/nvnflinger_cmu",
|
||||||
"sd:/atmosphere/extrazz",
|
"sd:/atmosphere/extrazz",
|
||||||
"sd:/atmosphere/fatal_errors",
|
"sd:/atmosphere/fatal_errors",
|
||||||
"sd:/atmosphere/fatal_reports",
|
"sd:/atmosphere/fatal_reports",
|
||||||
"sd:/atmosphere/flags",
|
"sd:/atmosphere/flags",
|
||||||
"sd:/atmosphere/hbl_html",
|
"sd:/atmosphere/hbl_html",
|
||||||
"sd:/atmosphere/hosts",
|
"sd:/atmosphere/hosts",
|
||||||
"sd:/atmosphere/kips",
|
"sd:/atmosphere/kips",
|
||||||
"sd:/atmosphere/kip1",
|
"sd:/atmosphere/kip1",
|
||||||
"sd:/atmosphere/kip_patches",
|
"sd:/atmosphere/kip_patches",
|
||||||
"sd:/atmosphere/logs",
|
"sd:/atmosphere/logs",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Atmosphere contents directories (title IDs; only under atmosphere/contents/)
|
// Atmosphere contents directories (title IDs; only under atmosphere/contents/)
|
||||||
static const char* clean_atmosphere_contents_dirs_to_delete[] = {
|
static const char* clean_atmosphere_contents_dirs_to_delete[] = {
|
||||||
"sd:/atmosphere/contents/0000000000534C56",
|
"sd:/atmosphere/contents/0000000000534C56",
|
||||||
"sd:/atmosphere/contents/00FF0000B378D640",
|
"sd:/atmosphere/contents/00FF0000B378D640",
|
||||||
"sd:/atmosphere/contents/00FF0000636C6BFF",
|
"sd:/atmosphere/contents/00FF0000636C6BFF",
|
||||||
"sd:/atmosphere/contents/00FF0000A53BB665",
|
"sd:/atmosphere/contents/00FF0000A53BB665",
|
||||||
"sd:/atmosphere/contents/0100000000000008",
|
"sd:/atmosphere/contents/0100000000000008",
|
||||||
"sd:/atmosphere/contents/010000000000000D",
|
"sd:/atmosphere/contents/010000000000000D",
|
||||||
"sd:/atmosphere/contents/010000000000002B",
|
"sd:/atmosphere/contents/010000000000002B",
|
||||||
"sd:/atmosphere/contents/0100000000000032",
|
"sd:/atmosphere/contents/0100000000000032",
|
||||||
"sd:/atmosphere/contents/0100000000000034",
|
"sd:/atmosphere/contents/0100000000000034",
|
||||||
"sd:/atmosphere/contents/0100000000000036",
|
"sd:/atmosphere/contents/0100000000000036",
|
||||||
"sd:/atmosphere/contents/0100000000000037",
|
"sd:/atmosphere/contents/0100000000000037",
|
||||||
"sd:/atmosphere/contents/010000000000003C",
|
"sd:/atmosphere/contents/010000000000003C",
|
||||||
"sd:/atmosphere/contents/0100000000000042",
|
"sd:/atmosphere/contents/0100000000000042",
|
||||||
"sd:/atmosphere/contents/0100000000000895",
|
"sd:/atmosphere/contents/0100000000000895",
|
||||||
"sd:/atmosphere/contents/0100000000000F12",
|
"sd:/atmosphere/contents/0100000000000F12",
|
||||||
"sd:/atmosphere/contents/0100000000001000",
|
"sd:/atmosphere/contents/0100000000001000",
|
||||||
"sd:/atmosphere/contents/0100000000001007",
|
"sd:/atmosphere/contents/0100000000001007",
|
||||||
"sd:/atmosphere/contents/0100000000001013",
|
"sd:/atmosphere/contents/0100000000001013",
|
||||||
"sd:/atmosphere/contents/010000000000DA7A",
|
"sd:/atmosphere/contents/010000000000DA7A",
|
||||||
"sd:/atmosphere/contents/010000000000bd00",
|
"sd:/atmosphere/contents/010000000000bd00",
|
||||||
"sd:/atmosphere/contents/01006a800016e000",
|
"sd:/atmosphere/contents/01006a800016e000",
|
||||||
"sd:/atmosphere/contents/01009D901BC56000",
|
"sd:/atmosphere/contents/01009D901BC56000",
|
||||||
"sd:/atmosphere/contents/0100A3900C3E2000",
|
"sd:/atmosphere/contents/0100A3900C3E2000",
|
||||||
"sd:/atmosphere/contents/0100F43008C44000",
|
"sd:/atmosphere/contents/0100F43008C44000",
|
||||||
"sd:/atmosphere/contents/050000BADDAD0000",
|
"sd:/atmosphere/contents/050000BADDAD0000",
|
||||||
"sd:/atmosphere/contents/4200000000000000",
|
"sd:/atmosphere/contents/4200000000000000",
|
||||||
"sd:/atmosphere/contents/420000000000000B",
|
"sd:/atmosphere/contents/420000000000000B",
|
||||||
"sd:/atmosphere/contents/420000000000000E",
|
"sd:/atmosphere/contents/420000000000000E",
|
||||||
"sd:/atmosphere/contents/4200000000000010",
|
"sd:/atmosphere/contents/4200000000000010",
|
||||||
"sd:/atmosphere/contents/4200000000000FFF",
|
"sd:/atmosphere/contents/4200000000000FFF",
|
||||||
"sd:/atmosphere/contents/420000000007E51A",
|
"sd:/atmosphere/contents/420000000007E51A",
|
||||||
"sd:/atmosphere/contents/420000000007E51B",
|
"sd:/atmosphere/contents/420000000007E51B",
|
||||||
"sd:/atmosphere/contents/690000000000000D",
|
"sd:/atmosphere/contents/690000000000000D",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Atmosphere files to delete
|
// Atmosphere files to delete
|
||||||
static const char* clean_atmosphere_files_to_delete[] = {
|
static const char* clean_atmosphere_files_to_delete[] = {
|
||||||
"sd:/atmosphere/config/exosphere.ini",
|
"sd:/atmosphere/config/exosphere.ini",
|
||||||
"sd:/atmosphere/config/stratosphere.ini",
|
"sd:/atmosphere/config/stratosphere.ini",
|
||||||
"sd:/atmosphere/hbl.nsp",
|
"sd:/atmosphere/hbl.nsp",
|
||||||
"sd:/atmosphere/package3",
|
"sd:/atmosphere/package3",
|
||||||
"sd:/atmosphere/reboot_payload.bin",
|
"sd:/atmosphere/reboot_payload.bin",
|
||||||
"sd:/atmosphere/stratosphere.romfs",
|
"sd:/atmosphere/stratosphere.romfs",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Bootloader directories to delete
|
// Bootloader directories to delete
|
||||||
static const char* clean_bootloader_dirs_to_delete[] = {
|
static const char* clean_bootloader_dirs_to_delete[] = {
|
||||||
"sd:/bootloader/boot",
|
"sd:/bootloader/boot",
|
||||||
"sd:/bootloader/bootlogo",
|
"sd:/bootloader/bootlogo",
|
||||||
"sd:/bootloader/ini2",
|
"sd:/bootloader/ini2",
|
||||||
"sd:/bootloader/payloads",
|
"sd:/bootloader/payloads",
|
||||||
"sd:/bootloader/reboot",
|
"sd:/bootloader/reboot",
|
||||||
"sd:/bootloader/res",
|
"sd:/bootloader/res",
|
||||||
"sd:/bootloader/sys",
|
"sd:/bootloader/sys",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Bootloader files to delete
|
// Bootloader files to delete
|
||||||
static const char* clean_bootloader_files_to_delete[] = {
|
static const char* clean_bootloader_files_to_delete[] = {
|
||||||
"sd:/bootloader/ArgonNX.bin",
|
"sd:/bootloader/ArgonNX.bin",
|
||||||
"sd:/bootloader/bootlogo.bmp",
|
"sd:/bootloader/bootlogo.bmp",
|
||||||
"sd:/bootloader/hekate_ipl.ini",
|
"sd:/bootloader/hekate_ipl.ini",
|
||||||
"sd:/bootloader/nyx.ini",
|
"sd:/bootloader/nyx.ini",
|
||||||
"sd:/bootloader/patches.ini",
|
"sd:/bootloader/patches.ini",
|
||||||
"sd:/bootloader/update.bin",
|
"sd:/bootloader/update.bin",
|
||||||
"sd:/bootloader/ini/EmuMMC ohne Mods.ini",
|
"sd:/bootloader/ini/EmuMMC ohne Mods.ini",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Config directories to delete
|
// Config directories to delete
|
||||||
static const char* clean_config_dirs_to_delete[] = {
|
static const char* clean_config_dirs_to_delete[] = {
|
||||||
"sd:/config/aio-switch-updater",
|
"sd:/config/aio-switch-updater",
|
||||||
"sd:/config/blue_pack_updater",
|
"sd:/config/blue_pack_updater",
|
||||||
"sd:/config/kefir-updater",
|
"sd:/config/kefir-updater",
|
||||||
"sd:/config/nx-hbmenu",
|
"sd:/config/nx-hbmenu",
|
||||||
"sd:/config/quickntp",
|
"sd:/config/quickntp",
|
||||||
"sd:/config/sys-con",
|
"sd:/config/sys-con",
|
||||||
"sd:/config/sys-patch",
|
"sd:/config/sys-patch",
|
||||||
"sd:/config/uberhand",
|
"sd:/config/uberhand",
|
||||||
"sd:/config/ultrahand",
|
"sd:/config/ultrahand",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Switch directories to delete
|
// Switch directories to delete
|
||||||
static const char* clean_switch_dirs_to_delete[] = {
|
static const char* clean_switch_dirs_to_delete[] = {
|
||||||
"sd:/switch/.overlays",
|
"sd:/switch/.overlays",
|
||||||
"sd:/switch/.packages",
|
"sd:/switch/.packages",
|
||||||
"sd:/switch/90DNS_tester",
|
"sd:/switch/90DNS_tester",
|
||||||
"sd:/switch/aio-switch-updater",
|
"sd:/switch/aio-switch-updater",
|
||||||
"sd:/switch/amsPLUS-downloader",
|
"sd:/switch/amsPLUS-downloader",
|
||||||
"sd:/switch/appstore",
|
"sd:/switch/appstore",
|
||||||
"sd:/switch/AtmoXL-Titel-Installer",
|
"sd:/switch/AtmoXL-Titel-Installer",
|
||||||
"sd:/switch/breeze",
|
"sd:/switch/breeze",
|
||||||
"sd:/switch/checkpoint",
|
"sd:/switch/checkpoint",
|
||||||
"sd:/switch/cheats-updater",
|
"sd:/switch/cheats-updater",
|
||||||
"sd:/switch/chiaki",
|
"sd:/switch/chiaki",
|
||||||
"sd:/switch/ChoiDujourNX",
|
"sd:/switch/ChoiDujourNX",
|
||||||
"sd:/switch/crash_ams",
|
"sd:/switch/crash_ams",
|
||||||
"sd:/switch/Daybreak",
|
"sd:/switch/Daybreak",
|
||||||
"sd:/switch/DNS_mitm Tester",
|
"sd:/switch/DNS_mitm Tester",
|
||||||
"sd:/switch/EdiZon",
|
"sd:/switch/EdiZon",
|
||||||
"sd:/switch/Fizeau",
|
"sd:/switch/Fizeau",
|
||||||
"sd:/switch/FTPD",
|
"sd:/switch/FTPD",
|
||||||
"sd:/switch/fw-downloader",
|
"sd:/switch/fw-downloader",
|
||||||
"sd:/switch/gamecard_installer",
|
"sd:/switch/gamecard_installer",
|
||||||
"sd:/switch/Goldleaf",
|
"sd:/switch/Goldleaf",
|
||||||
"sd:/switch/haze",
|
"sd:/switch/haze",
|
||||||
"sd:/switch/JKSV",
|
"sd:/switch/JKSV",
|
||||||
"sd:/switch/kefir-updater",
|
"sd:/switch/kefir-updater",
|
||||||
"sd:/switch/ldnmitm_config",
|
"sd:/switch/ldnmitm_config",
|
||||||
"sd:/switch/Linkalho",
|
"sd:/switch/Linkalho",
|
||||||
"sd:/switch/Moonlight-Switch",
|
"sd:/switch/Moonlight-Switch",
|
||||||
"sd:/switch/Neumann",
|
"sd:/switch/Neumann",
|
||||||
"sd:/switch/NX-Activity-Log",
|
"sd:/switch/NX-Activity-Log",
|
||||||
"sd:/switch/NX-Save-Sync",
|
"sd:/switch/NX-Save-Sync",
|
||||||
"sd:/switch/NX-Shell",
|
"sd:/switch/NX-Shell",
|
||||||
"sd:/switch/NX-Update-Checker ",
|
"sd:/switch/NX-Update-Checker ",
|
||||||
"sd:/switch/NXGallery",
|
"sd:/switch/NXGallery",
|
||||||
"sd:/switch/NXRemoteLauncher",
|
"sd:/switch/NXRemoteLauncher",
|
||||||
"sd:/switch/NXThemesInstaller",
|
"sd:/switch/NXThemesInstaller",
|
||||||
"sd:/switch/nxdumptool",
|
"sd:/switch/nxdumptool",
|
||||||
"sd:/switch/nxmtp",
|
"sd:/switch/nxmtp",
|
||||||
"sd:/switch/Payload_launcher",
|
"sd:/switch/Payload_launcher",
|
||||||
"sd:/switch/Reboot",
|
"sd:/switch/Reboot",
|
||||||
"sd:/switch/reboot_to_argonNX",
|
"sd:/switch/reboot_to_argonNX",
|
||||||
"sd:/switch/reboot_to_hekate",
|
"sd:/switch/reboot_to_hekate",
|
||||||
"sd:/switch/Shutdown_System",
|
"sd:/switch/Shutdown_System",
|
||||||
"sd:/switch/SimpleModDownloader",
|
"sd:/switch/SimpleModDownloader",
|
||||||
"sd:/switch/SimpleModManager",
|
"sd:/switch/SimpleModManager",
|
||||||
"sd:/switch/sphaira",
|
"sd:/switch/sphaira",
|
||||||
"sd:/switch/studious-pancake",
|
"sd:/switch/studious-pancake",
|
||||||
"sd:/switch/Switch-Time",
|
"sd:/switch/Switch-Time",
|
||||||
"sd:/switch/SwitchIdent",
|
"sd:/switch/SwitchIdent",
|
||||||
"sd:/switch/Switch_themes_Installer",
|
"sd:/switch/Switch_themes_Installer",
|
||||||
"sd:/switch/Switchfin",
|
"sd:/switch/Switchfin",
|
||||||
"sd:/switch/Sys-Clk Manager",
|
"sd:/switch/Sys-Clk Manager",
|
||||||
"sd:/switch/Sys-Con",
|
"sd:/switch/Sys-Con",
|
||||||
"sd:/switch/sys-clk-manager",
|
"sd:/switch/sys-clk-manager",
|
||||||
"sd:/switch/themezer-nx",
|
"sd:/switch/themezer-nx",
|
||||||
"sd:/switch/themezernx",
|
"sd:/switch/themezernx",
|
||||||
"sd:/switch/tinwoo",
|
"sd:/switch/tinwoo",
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
// Switch files (NRO) to delete
|
// Switch files (NRO) to delete
|
||||||
static const char* clean_switch_files_to_delete[] = {
|
static const char* clean_switch_files_to_delete[] = {
|
||||||
"sd:/switch/90DNS_tester/90DNS_tester.nro",
|
"sd:/switch/90DNS_tester/90DNS_tester.nro",
|
||||||
"sd:/switch/breeze.nro",
|
"sd:/switch/breeze.nro",
|
||||||
"sd:/switch/cheats-updater.nro",
|
"sd:/switch/cheats-updater.nro",
|
||||||
"sd:/switch/chiaki.nro",
|
"sd:/switch/chiaki.nro",
|
||||||
"sd:/switch/ChoiDujourNX.nro",
|
"sd:/switch/ChoiDujourNX.nro",
|
||||||
"sd:/switch/daybreak.nro",
|
"sd:/switch/daybreak.nro",
|
||||||
"sd:/switch/DBI.nro",
|
"sd:/switch/DBI.nro",
|
||||||
"sd:/switch/DBI/DBI.nro",
|
"sd:/switch/DBI/DBI.nro",
|
||||||
"sd:/switch/DBI/DBI_810_DE.nro",
|
"sd:/switch/DBI/DBI_810_DE.nro",
|
||||||
"sd:/switch/DBI/DBI_810_EN.nro",
|
"sd:/switch/DBI/DBI_810_EN.nro",
|
||||||
"sd:/switch/DBI/DBI_845_DE.nro",
|
"sd:/switch/DBI/DBI_845_DE.nro",
|
||||||
"sd:/switch/DBI/DBI_845_EN.nro",
|
"sd:/switch/DBI/DBI_845_EN.nro",
|
||||||
"sd:/switch/DBI/DBI_849_DE.nro",
|
"sd:/switch/DBI/DBI_849_DE.nro",
|
||||||
"sd:/switch/DBI/DBI_849_EN.nro",
|
"sd:/switch/DBI/DBI_849_EN.nro",
|
||||||
"sd:/switch/DBI_810_DE/DBI_810.nro",
|
"sd:/switch/DBI/DBI_874_DE.nro",
|
||||||
"sd:/switch/DBI_810_DE/DBI_810_DE.nro",
|
"sd:/switch/DBI/DBI_874_EN.nro",
|
||||||
"sd:/switch/DBI_810_EN/DBI_810_EN.nro",
|
"sd:/switch/DBI_810_DE/DBI_810.nro",
|
||||||
"sd:/switch/DBI_RU/DBI_RU.nro",
|
"sd:/switch/DBI_810_DE/DBI_810_DE.nro",
|
||||||
"sd:/switch/DBI/DBI_EN.nro",
|
"sd:/switch/DBI_810_EN/DBI_810_EN.nro",
|
||||||
"sd:/switch/DBI_DE/DBI_DE.nro",
|
"sd:/switch/DBI_RU/DBI_RU.nro",
|
||||||
"sd:/switch/DNS_mitm Tester.nro",
|
"sd:/switch/DBI/DBI_EN.nro",
|
||||||
"sd:/switch/EdiZon.nro",
|
"sd:/switch/DBI_DE/DBI_DE.nro",
|
||||||
"sd:/switch/Fizeau.nro",
|
"sd:/switch/DNS_mitm Tester.nro",
|
||||||
"sd:/switch/Goldleaf.nro",
|
"sd:/switch/EdiZon.nro",
|
||||||
"sd:/switch/haze.nro",
|
"sd:/switch/Fizeau.nro",
|
||||||
"sd:/switch/JKSV.nro",
|
"sd:/switch/Goldleaf.nro",
|
||||||
"sd:/switch/ldnmitm_config.nro",
|
"sd:/switch/haze.nro",
|
||||||
"sd:/switch/linkalho.nro",
|
"sd:/switch/JKSV.nro",
|
||||||
"sd:/switch/Moonlight-Switch.nro",
|
"sd:/switch/ldnmitm_config.nro",
|
||||||
"sd:/switch/Neumann.nro",
|
"sd:/switch/linkalho.nro",
|
||||||
"sd:/switch/NX-Shell.nro",
|
"sd:/switch/Moonlight-Switch.nro",
|
||||||
"sd:/switch/NXGallery.nro",
|
"sd:/switch/Neumann.nro",
|
||||||
"sd:/switch/NXThemesInstaller.nro",
|
"sd:/switch/NX-Shell.nro",
|
||||||
"sd:/switch/nxdumptool.nro",
|
"sd:/switch/NXGallery.nro",
|
||||||
"sd:/switch/nxtc.bin",
|
"sd:/switch/NXThemesInstaller.nro",
|
||||||
"sd:/switch/reboot_to_payload.nro",
|
"sd:/switch/nxdumptool.nro",
|
||||||
"sd:/switch/SimpleModDownloader.nro",
|
"sd:/switch/nxtc.bin",
|
||||||
"sd:/switch/SimpleModManager.nro",
|
"sd:/switch/reboot_to_payload.nro",
|
||||||
"sd:/switch/sphaira.nro",
|
"sd:/switch/SimpleModDownloader.nro",
|
||||||
"sd:/switch/SwitchIdent.nro",
|
"sd:/switch/SimpleModManager.nro",
|
||||||
"sd:/switch/Switch_themes_Installer/NXThemesInstaller.nro",
|
"sd:/switch/sphaira.nro",
|
||||||
"sd:/switch/Switchfin.nro",
|
"sd:/switch/SwitchIdent.nro",
|
||||||
"sd:/switch/Sys-Clk Manager/sys-clk-manager.nro",
|
"sd:/switch/Switch_themes_Installer/NXThemesInstaller.nro",
|
||||||
"sd:/switch/Sys-Con.nro",
|
"sd:/switch/Switchfin.nro",
|
||||||
"sd:/switch/sys-clk-manager.nro",
|
"sd:/switch/Sys-Clk Manager/sys-clk-manager.nro",
|
||||||
"sd:/switch/tinfoil.nro",
|
"sd:/switch/Sys-Con.nro",
|
||||||
"sd:/switch/tinfoil/tinfoil.nro",
|
"sd:/switch/sys-clk-manager.nro",
|
||||||
"sd:/switch/tinwoo.nro",
|
"sd:/switch/tinfoil.nro",
|
||||||
"sd:/switch/tinwoo/tinwoo.nro",
|
"sd:/switch/tinfoil/tinfoil.nro",
|
||||||
NULL
|
"sd:/switch/tinwoo.nro",
|
||||||
};
|
"sd:/switch/tinwoo/tinwoo.nro",
|
||||||
|
NULL
|
||||||
// Root CFW files to delete
|
};
|
||||||
static const char* clean_root_files_to_delete[] = {
|
|
||||||
"sd:/boot.dat",
|
// Root CFW files to delete
|
||||||
"sd:/boot.ini",
|
static const char* clean_root_files_to_delete[] = {
|
||||||
"sd:/exosphere.bin",
|
"sd:/boot.dat",
|
||||||
"sd:/exosphere.ini",
|
"sd:/boot.ini",
|
||||||
"sd:/hbmenu.nro",
|
"sd:/exosphere.bin",
|
||||||
"sd:/install.bat",
|
"sd:/exosphere.ini",
|
||||||
"sd:/license",
|
"sd:/hbmenu.nro",
|
||||||
"sd:/loader.bin",
|
"sd:/install.bat",
|
||||||
"sd:/mc-mitm.log",
|
"sd:/license",
|
||||||
"sd:/payload.bin",
|
"sd:/loader.bin",
|
||||||
"sd:/update.bin",
|
"sd:/mc-mitm.log",
|
||||||
"sd:/version",
|
"sd:/payload.bin",
|
||||||
NULL
|
"sd:/update.bin",
|
||||||
};
|
"sd:/version",
|
||||||
|
NULL
|
||||||
// Miscellaneous directories to delete
|
};
|
||||||
static const char* clean_misc_dirs_to_delete[] = {
|
|
||||||
"sd:/argon",
|
// Miscellaneous directories to delete
|
||||||
"sd:/games",
|
static const char* clean_misc_dirs_to_delete[] = {
|
||||||
"sd:/NSPs (Tools)",
|
"sd:/argon",
|
||||||
"sd:/Patched Apps",
|
"sd:/games",
|
||||||
"sd:/SaltySD/flags",
|
"sd:/NSPs (Tools)",
|
||||||
"sd:/scripts",
|
"sd:/Patched Apps",
|
||||||
"sd:/switch/tinfoil/db",
|
"sd:/SaltySD/flags",
|
||||||
"sd:/tools",
|
"sd:/scripts",
|
||||||
"sd:/warmboot_mariko",
|
"sd:/switch/tinfoil/db",
|
||||||
NULL
|
"sd:/tools",
|
||||||
};
|
"sd:/warmboot_mariko",
|
||||||
|
NULL
|
||||||
// Miscellaneous files to delete
|
};
|
||||||
static const char* clean_misc_files_to_delete[] = {
|
|
||||||
"sd:/fusee-primary.bin",
|
// Miscellaneous files to delete
|
||||||
"sd:/fusee.bin",
|
static const char* clean_misc_files_to_delete[] = {
|
||||||
"sd:/SaltySD/exceptions.txt",
|
"sd:/fusee-primary.bin",
|
||||||
"sd:/SaltySD/saltysd_bootstrap.elf",
|
"sd:/fusee.bin",
|
||||||
"sd:/SaltySD/saltysd_bootstrap32_3k.elf",
|
"sd:/SaltySD/exceptions.txt",
|
||||||
"sd:/SaltySD/saltysd_bootstrap32_5k.elf",
|
"sd:/SaltySD/saltysd_bootstrap.elf",
|
||||||
"sd:/SaltySD/saltysd_core.elf",
|
"sd:/SaltySD/saltysd_bootstrap32_3k.elf",
|
||||||
"sd:/SaltySD/saltysd_core32.elf",
|
"sd:/SaltySD/saltysd_bootstrap32_5k.elf",
|
||||||
NULL
|
"sd:/SaltySD/saltysd_core.elf",
|
||||||
};
|
"sd:/SaltySD/saltysd_core32.elf",
|
||||||
|
NULL
|
||||||
// Old version marker files to delete (clean install only)
|
};
|
||||||
static const char* old_version_files_to_delete[] = {
|
|
||||||
"sd:/1.0.0l",
|
// Old version marker files to delete (clean install only)
|
||||||
"sd:/1.0.0s",
|
static const char* old_version_files_to_delete[] = {
|
||||||
"sd:/1.0.0oc",
|
"sd:/1.0.0l",
|
||||||
"sd:/1.4.0-pre",
|
"sd:/1.0.0s",
|
||||||
"sd:/1.4.0-pre-c",
|
"sd:/1.0.0oc",
|
||||||
"sd:/1.4.0-pre-d",
|
"sd:/1.4.0-pre",
|
||||||
"sd:/1.4.1",
|
"sd:/1.4.0-pre-c",
|
||||||
"sd:/1.5.0",
|
"sd:/1.4.0-pre-d",
|
||||||
NULL
|
"sd:/1.4.1",
|
||||||
};
|
"sd:/1.5.0",
|
||||||
|
"sd:/1.6.0",
|
||||||
|
NULL
|
||||||
|
};
|
||||||
|
|||||||
@@ -122,8 +122,8 @@ static const char* config_dirs_to_delete[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Switch directories to delete
|
// Switch directories to delete
|
||||||
// NOTE: .packages is intentionally excluded - UltraHand package cache, preserve during updates
|
|
||||||
static const char* switch_dirs_to_delete[] = {
|
static const char* switch_dirs_to_delete[] = {
|
||||||
|
"sd:/switch/.packages",
|
||||||
"sd:/switch/.overlays",
|
"sd:/switch/.overlays",
|
||||||
"sd:/switch/90DNS_tester",
|
"sd:/switch/90DNS_tester",
|
||||||
"sd:/switch/aio-switch-updater",
|
"sd:/switch/aio-switch-updater",
|
||||||
@@ -172,7 +172,6 @@ static const char* switch_dirs_to_delete[] = {
|
|||||||
"sd:/switch/Switch-Time",
|
"sd:/switch/Switch-Time",
|
||||||
"sd:/switch/SwitchIdent",
|
"sd:/switch/SwitchIdent",
|
||||||
"sd:/switch/Switch_themes_Installer",
|
"sd:/switch/Switch_themes_Installer",
|
||||||
"sd:/switch/Switchfin",
|
|
||||||
"sd:/switch/Sys-Clk Manager",
|
"sd:/switch/Sys-Clk Manager",
|
||||||
"sd:/switch/Sys-Con",
|
"sd:/switch/Sys-Con",
|
||||||
"sd:/switch/sys-clk-manager",
|
"sd:/switch/sys-clk-manager",
|
||||||
@@ -223,9 +222,9 @@ static const char* switch_files_to_delete[] = {
|
|||||||
"sd:/switch/SimpleModDownloader.nro",
|
"sd:/switch/SimpleModDownloader.nro",
|
||||||
"sd:/switch/SimpleModManager.nro",
|
"sd:/switch/SimpleModManager.nro",
|
||||||
"sd:/switch/sphaira.nro",
|
"sd:/switch/sphaira.nro",
|
||||||
|
"sd:/switch/swr-ini-tool/swr-ini-tool.nro",
|
||||||
"sd:/switch/SwitchIdent.nro",
|
"sd:/switch/SwitchIdent.nro",
|
||||||
"sd:/switch/Switch_themes_Installer/NXThemesInstaller.nro",
|
"sd:/switch/Switch_themes_Installer/NXThemesInstaller.nro",
|
||||||
"sd:/switch/Switchfin.nro",
|
|
||||||
"sd:/switch/Sys-Clk Manager/sys-clk-manager.nro",
|
"sd:/switch/Sys-Clk Manager/sys-clk-manager.nro",
|
||||||
"sd:/switch/Sys-Con.nro",
|
"sd:/switch/Sys-Con.nro",
|
||||||
"sd:/switch/sys-clk-manager.nro",
|
"sd:/switch/sys-clk-manager.nro",
|
||||||
|
|||||||
46
source/dram_fuse.c
Normal file
46
source/dram_fuse.c
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
* DRAM capacity from fuse (SKU), not physical probe.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "dram_fuse.h"
|
||||||
|
#include <soc/fuse.h>
|
||||||
|
#include <soc/hw_init.h>
|
||||||
|
#include <soc/t210.h>
|
||||||
|
|
||||||
|
static int mariko_dram_mib(u32 dram_id)
|
||||||
|
{
|
||||||
|
switch (dram_id) {
|
||||||
|
case 9:
|
||||||
|
case 13:
|
||||||
|
case 18:
|
||||||
|
case 21:
|
||||||
|
case 23:
|
||||||
|
case 28:
|
||||||
|
return 8192;
|
||||||
|
default:
|
||||||
|
if (dram_id >= 3 && dram_id <= 28)
|
||||||
|
return 4096;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int erista_dram_mib(u32 dram_id)
|
||||||
|
{
|
||||||
|
if (dram_id == 4)
|
||||||
|
return 6144;
|
||||||
|
if (dram_id <= 6)
|
||||||
|
return 4096;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int dram_capacity_mib_from_fuse(void)
|
||||||
|
{
|
||||||
|
u32 nid = fuse_read_dramid(false);
|
||||||
|
u32 chip = hw_get_chip_id();
|
||||||
|
|
||||||
|
if (chip == GP_HIDREV_MAJOR_T210)
|
||||||
|
return erista_dram_mib(nid);
|
||||||
|
if (chip == GP_HIDREV_MAJOR_T210B01)
|
||||||
|
return mariko_dram_mib(nid);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
6
source/dram_fuse.h
Normal file
6
source/dram_fuse.h
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <utils/types.h>
|
||||||
|
|
||||||
|
/* DRAM capacity in MiB from fuse DRAM ID + SoC (same table as RAM test payload). */
|
||||||
|
int dram_capacity_mib_from_fuse(void);
|
||||||
135
source/install.c
135
source/install.c
@@ -3,6 +3,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "install.h"
|
#include "install.h"
|
||||||
|
#include "dram_fuse.h"
|
||||||
#include "fs.h"
|
#include "fs.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "gfx.h"
|
#include "gfx.h"
|
||||||
@@ -113,6 +114,38 @@ void install_combine_path(char *result, size_t size, const char *base, const cha
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Copy every regular file at staging root to dst_root; subdirs and volume labels skipped. */
|
||||||
|
int install_copy_staging_root_files(const char *staging, const char *dst_root) {
|
||||||
|
DIR dir;
|
||||||
|
FILINFO fno;
|
||||||
|
char src_full[256];
|
||||||
|
char dst_full[256];
|
||||||
|
int res = f_opendir(&dir, staging);
|
||||||
|
if (res != FR_OK)
|
||||||
|
return res;
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
res = f_readdir(&dir, &fno);
|
||||||
|
if (res != FR_OK || fno.fname[0] == 0)
|
||||||
|
break;
|
||||||
|
if (fno.fname[0] == '.' && (fno.fname[1] == '\0' || (fno.fname[1] == '.' && fno.fname[2] == '\0')))
|
||||||
|
continue;
|
||||||
|
if (fno.fattrib & (AM_DIR | AM_VOL))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
install_combine_path(src_full, sizeof(src_full), staging, fno.fname);
|
||||||
|
install_combine_path(dst_full, sizeof(dst_full), dst_root, fno.fname);
|
||||||
|
res = file_copy(src_full, dst_full);
|
||||||
|
if (res != FR_OK) {
|
||||||
|
f_closedir(&dir);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
f_closedir(&dir);
|
||||||
|
return FR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
// Recursive folder copy with progress tracking
|
// Recursive folder copy with progress tracking
|
||||||
static int folder_copy_progress_recursive(const char *src, const char *dst, int *copied, int total, u32 start_x, u32 start_y, const char *display_name, int *last_percent) {
|
static int folder_copy_progress_recursive(const char *src, const char *dst, int *copied, int total, u32 start_x, u32 start_y, const char *display_name, int *last_percent) {
|
||||||
DIR dir;
|
DIR dir;
|
||||||
@@ -586,34 +619,58 @@ int delete_path_list(const char* paths[], const char* description) {
|
|||||||
return (failed == 0) ? FR_OK : FR_DISK_ERR;
|
return (failed == 0) ? FR_OK : FR_DISK_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define HEKATE_8GB_SRC "sd:/bootloader/hekate_8gb.bin"
|
||||||
|
#define PAYLOAD_BIN_DST "sd:/payload.bin"
|
||||||
|
#define UPDATE_BIN_DST "sd:/bootloader/update.bin"
|
||||||
|
|
||||||
|
static void unlink_ignore_err(const char *path)
|
||||||
|
{
|
||||||
|
FILINFO fno;
|
||||||
|
if (f_stat(path, &fno) != FR_OK)
|
||||||
|
return;
|
||||||
|
if (fno.fattrib & AM_RDO)
|
||||||
|
f_chmod(path, fno.fattrib & ~AM_RDO, AM_RDO);
|
||||||
|
f_unlink(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* After pack copy: if >4 GiB fuse RAM, install 8GB Hekate to payload.bin + bootloader/update.bin; always remove hekate_8gb.bin when done or if not used. */
|
||||||
|
static void install_hekate_8gb_post_copy(void)
|
||||||
|
{
|
||||||
|
if (!install_path_exists(HEKATE_8GB_SRC))
|
||||||
|
return;
|
||||||
|
|
||||||
|
int mib = dram_capacity_mib_from_fuse();
|
||||||
|
if (mib > 4096) {
|
||||||
|
install_set_color(COLOR_CYAN);
|
||||||
|
gfx_printf("\nMehr als 4 GB RAM erkannt (Fuse). Die 8-GB-Hekate-Variante wird verwendet.\n");
|
||||||
|
gfx_printf("Kopiere nach payload.bin und bootloader/update.bin...\n");
|
||||||
|
install_set_color(COLOR_WHITE);
|
||||||
|
|
||||||
|
int r1 = file_copy(HEKATE_8GB_SRC, PAYLOAD_BIN_DST);
|
||||||
|
int r2 = file_copy(HEKATE_8GB_SRC, UPDATE_BIN_DST);
|
||||||
|
if (r1 == FR_OK && r2 == FR_OK) {
|
||||||
|
install_set_color(COLOR_GREEN);
|
||||||
|
gfx_printf(" [OK] Hekate 8 GB installiert.\n");
|
||||||
|
install_set_color(COLOR_WHITE);
|
||||||
|
unlink_ignore_err(HEKATE_8GB_SRC);
|
||||||
|
} else {
|
||||||
|
install_set_color(COLOR_ORANGE);
|
||||||
|
gfx_printf(" [WARN] Kopie fehlgeschlagen (payload: %d, update: %d). hekate_8gb.bin bleibt.\n", r1, r2);
|
||||||
|
install_set_color(COLOR_WHITE);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
unlink_ignore_err(HEKATE_8GB_SRC);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Main installation function
|
// Main installation function
|
||||||
int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
if (mode == INSTALL_MODE_UPDATE) {
|
if (mode == INSTALL_MODE_UPDATE) {
|
||||||
// Update mode: backup, selective cleanup, then install
|
// Update mode: selective cleanup then install
|
||||||
omninx_status_t status = detect_omninx_installation();
|
|
||||||
const char *version = (status.version_file[0] != '\0') ? status.version_file : "unknown";
|
|
||||||
|
|
||||||
install_set_color(COLOR_YELLOW);
|
install_set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Schritt 1: Backup vor Update (%s)...\n", version);
|
gfx_printf("Schritt 1: Bereinigung...\n");
|
||||||
install_set_color(COLOR_WHITE);
|
|
||||||
res = backup_before_update(version);
|
|
||||||
/* Backup is best-effort; continue install even on failure */
|
|
||||||
if (res == FR_OK) {
|
|
||||||
install_set_color(COLOR_GREEN);
|
|
||||||
gfx_printf(" [OK] Sicherung nach sd:/backup/OmniNX/%s/\n", version);
|
|
||||||
install_set_color(COLOR_WHITE);
|
|
||||||
} else {
|
|
||||||
install_set_color(COLOR_ORANGE);
|
|
||||||
gfx_printf(" [WARN] Backup fehlgeschlagen, fahre trotzdem fort...\n");
|
|
||||||
install_set_color(COLOR_WHITE);
|
|
||||||
}
|
|
||||||
|
|
||||||
install_check_and_clear_screen_if_needed();
|
|
||||||
gfx_printf("\n");
|
|
||||||
install_set_color(COLOR_YELLOW);
|
|
||||||
gfx_printf("Schritt 2: Bereinigung...\n");
|
|
||||||
install_set_color(COLOR_WHITE);
|
install_set_color(COLOR_WHITE);
|
||||||
res = update_mode_cleanup(pack_variant);
|
res = update_mode_cleanup(pack_variant);
|
||||||
if (res != FR_OK) return res;
|
if (res != FR_OK) return res;
|
||||||
@@ -621,11 +678,13 @@ int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
|||||||
install_check_and_clear_screen_if_needed();
|
install_check_and_clear_screen_if_needed();
|
||||||
gfx_printf("\n");
|
gfx_printf("\n");
|
||||||
install_set_color(COLOR_YELLOW);
|
install_set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Schritt 3: Dateien kopieren...\n");
|
gfx_printf("Schritt 2: Dateien kopieren...\n");
|
||||||
install_set_color(COLOR_WHITE);
|
install_set_color(COLOR_WHITE);
|
||||||
res = update_mode_install(pack_variant);
|
res = update_mode_install(pack_variant);
|
||||||
if (res != FR_OK) return res;
|
if (res != FR_OK) return res;
|
||||||
|
|
||||||
|
install_hekate_8gb_post_copy();
|
||||||
|
|
||||||
install_check_and_clear_screen_if_needed();
|
install_check_and_clear_screen_if_needed();
|
||||||
// Remove staging directory (installed pack)
|
// Remove staging directory (installed pack)
|
||||||
res = cleanup_staging_directory(pack_variant);
|
res = cleanup_staging_directory(pack_variant);
|
||||||
@@ -634,7 +693,7 @@ int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
|||||||
res = cleanup_other_staging_directories(pack_variant);
|
res = cleanup_other_staging_directories(pack_variant);
|
||||||
return res;
|
return res;
|
||||||
} else {
|
} else {
|
||||||
// Clean mode: backup user data, backup pre-omninx, wipe, restore, install
|
// Clean mode: backup, wipe, restore, install
|
||||||
install_set_color(COLOR_YELLOW);
|
install_set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Schritt 1: Sichere Benutzerdaten...\n");
|
gfx_printf("Schritt 1: Sichere Benutzerdaten...\n");
|
||||||
install_set_color(COLOR_WHITE);
|
install_set_color(COLOR_WHITE);
|
||||||
@@ -644,23 +703,7 @@ int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
|||||||
install_check_and_clear_screen_if_needed();
|
install_check_and_clear_screen_if_needed();
|
||||||
gfx_printf("\n");
|
gfx_printf("\n");
|
||||||
install_set_color(COLOR_YELLOW);
|
install_set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Schritt 2: Backup alter CFW-Dateien (pre-omninx)...\n");
|
gfx_printf("Schritt 2: Bereinige alte Installation...\n");
|
||||||
install_set_color(COLOR_WHITE);
|
|
||||||
res = backup_before_clean();
|
|
||||||
if (res == FR_OK) {
|
|
||||||
install_set_color(COLOR_GREEN);
|
|
||||||
gfx_printf(" [OK] Sicherung nach sd:/backup/OmniNX/pre-omninx/\n");
|
|
||||||
install_set_color(COLOR_WHITE);
|
|
||||||
} else {
|
|
||||||
install_set_color(COLOR_ORANGE);
|
|
||||||
gfx_printf(" [WARN] Backup fehlgeschlagen, fahre trotzdem fort...\n");
|
|
||||||
install_set_color(COLOR_WHITE);
|
|
||||||
}
|
|
||||||
|
|
||||||
install_check_and_clear_screen_if_needed();
|
|
||||||
gfx_printf("\n");
|
|
||||||
install_set_color(COLOR_YELLOW);
|
|
||||||
gfx_printf("Schritt 3: Bereinige alte Installation...\n");
|
|
||||||
install_set_color(COLOR_WHITE);
|
install_set_color(COLOR_WHITE);
|
||||||
res = clean_mode_wipe();
|
res = clean_mode_wipe();
|
||||||
if (res != FR_OK) return res;
|
if (res != FR_OK) return res;
|
||||||
@@ -668,7 +711,7 @@ int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
|||||||
install_check_and_clear_screen_if_needed();
|
install_check_and_clear_screen_if_needed();
|
||||||
gfx_printf("\n");
|
gfx_printf("\n");
|
||||||
install_set_color(COLOR_YELLOW);
|
install_set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Schritt 4: Stelle Benutzerdaten wieder her...\n");
|
gfx_printf("Schritt 3: Stelle Benutzerdaten wieder her...\n");
|
||||||
install_set_color(COLOR_WHITE);
|
install_set_color(COLOR_WHITE);
|
||||||
res = clean_mode_restore();
|
res = clean_mode_restore();
|
||||||
if (res != FR_OK) return res;
|
if (res != FR_OK) return res;
|
||||||
@@ -676,11 +719,13 @@ int perform_installation(omninx_variant_t pack_variant, install_mode_t mode) {
|
|||||||
install_check_and_clear_screen_if_needed();
|
install_check_and_clear_screen_if_needed();
|
||||||
gfx_printf("\n");
|
gfx_printf("\n");
|
||||||
install_set_color(COLOR_YELLOW);
|
install_set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Schritt 5: Dateien kopieren...\n");
|
gfx_printf("Schritt 4: Dateien kopieren...\n");
|
||||||
install_set_color(COLOR_WHITE);
|
install_set_color(COLOR_WHITE);
|
||||||
res = clean_mode_install(pack_variant);
|
res = clean_mode_install(pack_variant);
|
||||||
if (res != FR_OK) return res;
|
if (res != FR_OK) return res;
|
||||||
|
|
||||||
|
install_hekate_8gb_post_copy();
|
||||||
|
|
||||||
install_check_and_clear_screen_if_needed();
|
install_check_and_clear_screen_if_needed();
|
||||||
// Remove staging directory (installed pack)
|
// Remove staging directory (installed pack)
|
||||||
res = cleanup_staging_directory(pack_variant);
|
res = cleanup_staging_directory(pack_variant);
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ typedef enum {
|
|||||||
int perform_installation(omninx_variant_t pack_variant, install_mode_t mode);
|
int perform_installation(omninx_variant_t pack_variant, install_mode_t mode);
|
||||||
|
|
||||||
// Update mode operations (install_update.c)
|
// Update mode operations (install_update.c)
|
||||||
int backup_before_update(const char *version);
|
|
||||||
int update_mode_cleanup(omninx_variant_t variant);
|
int update_mode_cleanup(omninx_variant_t variant);
|
||||||
int update_mode_install(omninx_variant_t variant);
|
int update_mode_install(omninx_variant_t variant);
|
||||||
int cleanup_staging_directory(omninx_variant_t pack_variant);
|
int cleanup_staging_directory(omninx_variant_t pack_variant);
|
||||||
@@ -25,7 +24,6 @@ int cleanup_staging_directory(omninx_variant_t pack_variant);
|
|||||||
int cleanup_other_staging_directories(omninx_variant_t installed_variant);
|
int cleanup_other_staging_directories(omninx_variant_t installed_variant);
|
||||||
|
|
||||||
// Clean install operations (install_clean.c)
|
// Clean install operations (install_clean.c)
|
||||||
int backup_before_clean(void);
|
|
||||||
int clean_mode_backup(void);
|
int clean_mode_backup(void);
|
||||||
int clean_mode_wipe(void);
|
int clean_mode_wipe(void);
|
||||||
int clean_mode_restore(void);
|
int clean_mode_restore(void);
|
||||||
@@ -37,6 +35,7 @@ void install_check_and_clear_screen_if_needed(void);
|
|||||||
bool install_path_exists(const char *path);
|
bool install_path_exists(const char *path);
|
||||||
int install_count_directory_items(const char *path);
|
int install_count_directory_items(const char *path);
|
||||||
void install_combine_path(char *result, size_t size, const char *base, const char *add);
|
void install_combine_path(char *result, size_t size, const char *base, const char *add);
|
||||||
|
int install_copy_staging_root_files(const char *staging, const char *dst_root);
|
||||||
int delete_path_list(const char* paths[], const char* description);
|
int delete_path_list(const char* paths[], const char* description);
|
||||||
int delete_path_lists_grouped(const char *folder_display_name, ...);
|
int delete_path_lists_grouped(const char *folder_display_name, ...);
|
||||||
int folder_delete_single_with_progress(const char *path, const char *display_name);
|
int folder_delete_single_with_progress(const char *path, const char *display_name);
|
||||||
|
|||||||
@@ -11,7 +11,6 @@
|
|||||||
#include "gfx.h"
|
#include "gfx.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include <libs/fatfs/ff.h>
|
#include <libs/fatfs/ff.h>
|
||||||
#include <utils/sprintf.h>
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#undef COLOR_CYAN
|
#undef COLOR_CYAN
|
||||||
@@ -32,26 +31,6 @@
|
|||||||
#define path_exists install_path_exists
|
#define path_exists install_path_exists
|
||||||
#define count_directory_items install_count_directory_items
|
#define count_directory_items install_count_directory_items
|
||||||
|
|
||||||
// Backup paths before clean install (sd:/backup/OmniNX/pre-omninx)
|
|
||||||
int backup_before_clean(void) {
|
|
||||||
char backup_base[270];
|
|
||||||
s_printf(backup_base, "%s/%s", BACKUP_BASE_PATH, PRE_OMNINX_LABEL);
|
|
||||||
return backup_deletion_lists(backup_base,
|
|
||||||
clean_atmosphere_dirs_to_delete,
|
|
||||||
clean_atmosphere_contents_dirs_to_delete,
|
|
||||||
clean_atmosphere_files_to_delete,
|
|
||||||
clean_bootloader_dirs_to_delete,
|
|
||||||
clean_bootloader_files_to_delete,
|
|
||||||
clean_config_dirs_to_delete,
|
|
||||||
clean_switch_dirs_to_delete,
|
|
||||||
clean_switch_files_to_delete,
|
|
||||||
clean_root_files_to_delete,
|
|
||||||
clean_misc_dirs_to_delete,
|
|
||||||
clean_misc_files_to_delete,
|
|
||||||
old_version_files_to_delete,
|
|
||||||
NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Clean mode: Backup user data
|
// Clean mode: Backup user data
|
||||||
int clean_mode_backup(void) {
|
int clean_mode_backup(void) {
|
||||||
set_color(COLOR_CYAN);
|
set_color(COLOR_CYAN);
|
||||||
|
|||||||
@@ -4,7 +4,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "install.h"
|
#include "install.h"
|
||||||
#include "backup.h"
|
|
||||||
#include "deletion_lists_update.h"
|
#include "deletion_lists_update.h"
|
||||||
#include "fs.h"
|
#include "fs.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
@@ -35,25 +34,6 @@
|
|||||||
#define path_exists install_path_exists
|
#define path_exists install_path_exists
|
||||||
#define count_directory_items install_count_directory_items
|
#define count_directory_items install_count_directory_items
|
||||||
|
|
||||||
// Backup paths before update (sd:/backup/OmniNX/{version})
|
|
||||||
int backup_before_update(const char *version) {
|
|
||||||
char backup_base[270];
|
|
||||||
s_printf(backup_base, "%s/%s", BACKUP_BASE_PATH, version);
|
|
||||||
return backup_deletion_lists(backup_base,
|
|
||||||
atmosphere_dirs_to_delete,
|
|
||||||
atmosphere_contents_dirs_to_delete,
|
|
||||||
atmosphere_files_to_delete,
|
|
||||||
bootloader_dirs_to_delete,
|
|
||||||
bootloader_files_to_delete,
|
|
||||||
config_dirs_to_delete,
|
|
||||||
switch_dirs_to_delete,
|
|
||||||
switch_files_to_delete,
|
|
||||||
root_files_to_delete,
|
|
||||||
misc_dirs_to_delete,
|
|
||||||
misc_files_to_delete,
|
|
||||||
NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update mode: Cleanup specific directories/files
|
// Update mode: Cleanup specific directories/files
|
||||||
int update_mode_cleanup(omninx_variant_t variant) {
|
int update_mode_cleanup(omninx_variant_t variant) {
|
||||||
(void)variant;
|
(void)variant;
|
||||||
@@ -98,7 +78,6 @@ int update_mode_install(omninx_variant_t variant) {
|
|||||||
int res;
|
int res;
|
||||||
const char* staging = get_staging_path(variant);
|
const char* staging = get_staging_path(variant);
|
||||||
char src_path[256];
|
char src_path[256];
|
||||||
char dst_path[256];
|
|
||||||
|
|
||||||
if (!staging) {
|
if (!staging) {
|
||||||
return FR_INVALID_PARAMETER;
|
return FR_INVALID_PARAMETER;
|
||||||
@@ -126,6 +105,10 @@ int update_mode_install(omninx_variant_t variant) {
|
|||||||
res = folder_copy_with_progress_v2(src_path, "sd:/", "switch/");
|
res = folder_copy_with_progress_v2(src_path, "sd:/", "switch/");
|
||||||
if (res != FR_OK && res != FR_NO_FILE) return res;
|
if (res != FR_OK && res != FR_NO_FILE) return res;
|
||||||
|
|
||||||
|
s_printf(src_path, "%s/themes", staging);
|
||||||
|
res = folder_copy_with_progress_v2(src_path, "sd:/", "themes/");
|
||||||
|
if (res != FR_OK && res != FR_NO_FILE) return res;
|
||||||
|
|
||||||
s_printf(src_path, "%s/warmboot_mariko", staging);
|
s_printf(src_path, "%s/warmboot_mariko", staging);
|
||||||
res = folder_copy_with_progress_v2(src_path, "sd:/", "warmboot_mariko/");
|
res = folder_copy_with_progress_v2(src_path, "sd:/", "warmboot_mariko/");
|
||||||
if (res != FR_OK && res != FR_NO_FILE) return res;
|
if (res != FR_OK && res != FR_NO_FILE) return res;
|
||||||
@@ -140,29 +123,9 @@ int update_mode_install(omninx_variant_t variant) {
|
|||||||
gfx_printf(" Kopiere Root-Dateien...\n");
|
gfx_printf(" Kopiere Root-Dateien...\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
|
|
||||||
s_printf(src_path, "%s/boot.dat", staging);
|
res = install_copy_staging_root_files(staging, "sd:/");
|
||||||
s_printf(dst_path, "sd:/boot.dat");
|
if (res != FR_OK)
|
||||||
if (path_exists(src_path)) file_copy(src_path, dst_path);
|
return res;
|
||||||
|
|
||||||
s_printf(src_path, "%s/boot.ini", staging);
|
|
||||||
s_printf(dst_path, "sd:/boot.ini");
|
|
||||||
if (path_exists(src_path)) file_copy(src_path, dst_path);
|
|
||||||
|
|
||||||
s_printf(src_path, "%s/exosphere.ini", staging);
|
|
||||||
s_printf(dst_path, "sd:/exosphere.ini");
|
|
||||||
if (path_exists(src_path)) file_copy(src_path, dst_path);
|
|
||||||
|
|
||||||
s_printf(src_path, "%s/hbmenu.nro", staging);
|
|
||||||
s_printf(dst_path, "sd:/hbmenu.nro");
|
|
||||||
if (path_exists(src_path)) file_copy(src_path, dst_path);
|
|
||||||
|
|
||||||
s_printf(src_path, "%s/loader.bin", staging);
|
|
||||||
s_printf(dst_path, "sd:/loader.bin");
|
|
||||||
if (path_exists(src_path)) file_copy(src_path, dst_path);
|
|
||||||
|
|
||||||
s_printf(src_path, "%s/payload.bin", staging);
|
|
||||||
s_printf(dst_path, "sd:/payload.bin");
|
|
||||||
if (path_exists(src_path)) file_copy(src_path, dst_path);
|
|
||||||
|
|
||||||
set_color(COLOR_GREEN);
|
set_color(COLOR_GREEN);
|
||||||
gfx_printf(" Kopie abgeschlossen!\n");
|
gfx_printf(" Kopie abgeschlossen!\n");
|
||||||
|
|||||||
176
source/main.c
176
source/main.c
@@ -35,6 +35,7 @@
|
|||||||
#include "fs.h"
|
#include "fs.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "install.h"
|
#include "install.h"
|
||||||
|
#include "screenshot.h"
|
||||||
|
|
||||||
// Configuration
|
// Configuration
|
||||||
#define PAYLOAD_PATH "sd:/bootloader/update.bin"
|
#define PAYLOAD_PATH "sd:/bootloader/update.bin"
|
||||||
@@ -115,6 +116,12 @@ static void print_header(void) {
|
|||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Console Vol+ and Vol- together (exit / cancel where documented) */
|
||||||
|
static inline bool cancel_combo_pressed(u8 btn)
|
||||||
|
{
|
||||||
|
return (btn & (BTN_VOL_UP | BTN_VOL_DOWN)) == (BTN_VOL_UP | BTN_VOL_DOWN);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void reloc_patcher(u32 payload_dst, u32 payload_src, u32 payload_size) {
|
void reloc_patcher(u32 payload_dst, u32 payload_src, u32 payload_size) {
|
||||||
memcpy((u8 *)payload_src, (u8 *)IPL_LOAD_ADDR, PATCHED_RELOC_SZ);
|
memcpy((u8 *)payload_src, (u8 *)IPL_LOAD_ADDR, PATCHED_RELOC_SZ);
|
||||||
@@ -243,11 +250,13 @@ void ipl_main(void) {
|
|||||||
set_color(COLOR_GREEN);
|
set_color(COLOR_GREEN);
|
||||||
gfx_printf("Druecke A-Taste (rechter Joy-Con) oder Power-Taste,\n");
|
gfx_printf("Druecke A-Taste (rechter Joy-Con) oder Power-Taste,\n");
|
||||||
gfx_printf("um Hekate zu starten...\n");
|
gfx_printf("um Hekate zu starten...\n");
|
||||||
|
gfx_printf("Oder Vol+ und Vol- (Konsole) gleichzeitig.\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
} else {
|
} else {
|
||||||
set_color(COLOR_GREEN);
|
set_color(COLOR_GREEN);
|
||||||
gfx_printf("Druecke A-Taste (rechter Joy-Con) oder Power-Taste,\n");
|
gfx_printf("Druecke A-Taste (rechter Joy-Con) oder Power-Taste,\n");
|
||||||
gfx_printf("um den Neustart zu starten...\n");
|
gfx_printf("um den Neustart zu starten...\n");
|
||||||
|
gfx_printf("Oder Vol+ und Vol- (Konsole) gleichzeitig.\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -264,13 +273,21 @@ void ipl_main(void) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check joycon A button
|
// Check joycon A button; Capture = screenshot
|
||||||
jc_gamepad_rpt_t *jc = joycon_poll();
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
if (jc && jc->a) {
|
if (jc) {
|
||||||
|
if (jc->cap)
|
||||||
|
take_screenshot();
|
||||||
|
if (jc->a) {
|
||||||
|
button_pressed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (cancel_combo_pressed(btn_state)) {
|
||||||
button_pressed = true;
|
button_pressed = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
msleep(50); // Small delay to avoid busy-waiting
|
msleep(50); // Small delay to avoid busy-waiting
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -324,12 +341,14 @@ void ipl_main(void) {
|
|||||||
gfx_printf("\n");
|
gfx_printf("\n");
|
||||||
set_color(COLOR_CYAN);
|
set_color(COLOR_CYAN);
|
||||||
gfx_printf("D-Pad / Vol+/-: Auswahl | A oder Power: Bestaetigen\n");
|
gfx_printf("D-Pad / Vol+/-: Auswahl | A oder Power: Bestaetigen\n");
|
||||||
|
gfx_printf("Vol+ und Vol- gleichzeitig: Abbrechen (Hekate)\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
|
|
||||||
// Edge detection: only move on press (not while held)
|
// Edge detection: only move on press (not while held)
|
||||||
bool prev_up = false, prev_down = false;
|
bool prev_up = false, prev_down = false;
|
||||||
|
bool menu_aborted = false;
|
||||||
|
|
||||||
while (!confirmed) {
|
while (!confirmed && !menu_aborted) {
|
||||||
// On selection change: redraw only the two affected lines (no full clear)
|
// On selection change: redraw only the two affected lines (no full clear)
|
||||||
if (selected != prev_selected) {
|
if (selected != prev_selected) {
|
||||||
gfx_con_setpos(menu_x, menu_variant_start_y + (u32)prev_selected * 16);
|
gfx_con_setpos(menu_x, menu_variant_start_y + (u32)prev_selected * 16);
|
||||||
@@ -345,6 +364,14 @@ void ipl_main(void) {
|
|||||||
jc_gamepad_rpt_t *jc = joycon_poll();
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
u8 btn = btn_read();
|
u8 btn = btn_read();
|
||||||
|
|
||||||
|
if (jc && jc->cap)
|
||||||
|
take_screenshot();
|
||||||
|
|
||||||
|
if (cancel_combo_pressed(btn)) {
|
||||||
|
menu_aborted = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
// D-pad or Vol+ / Vol- for selection (Vol+ = up, Vol- = down)
|
// D-pad or Vol+ / Vol- for selection (Vol+ = up, Vol- = down)
|
||||||
bool cur_up = false, cur_down = false;
|
bool cur_up = false, cur_down = false;
|
||||||
if (jc) {
|
if (jc) {
|
||||||
@@ -369,6 +396,20 @@ void ipl_main(void) {
|
|||||||
|
|
||||||
msleep(50);
|
msleep(50);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (menu_aborted) {
|
||||||
|
gfx_printf("\n");
|
||||||
|
set_color(COLOR_YELLOW);
|
||||||
|
gfx_printf("Abgebrochen. Starte Hekate...\n");
|
||||||
|
set_color(COLOR_WHITE);
|
||||||
|
msleep(500);
|
||||||
|
if (file_exists(PAYLOAD_PATH)) {
|
||||||
|
launch_payload(PAYLOAD_PATH);
|
||||||
|
} else {
|
||||||
|
power_set_state(POWER_OFF_REBOOT);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
pack_variant = variants_present[selected];
|
pack_variant = variants_present[selected];
|
||||||
gfx_clear_grey(0x1B);
|
gfx_clear_grey(0x1B);
|
||||||
@@ -395,14 +436,19 @@ void ipl_main(void) {
|
|||||||
gfx_printf("mit angeschlossenem Ladegeraet durchgefuehrt werden.\n\n");
|
gfx_printf("mit angeschlossenem Ladegeraet durchgefuehrt werden.\n\n");
|
||||||
set_color(COLOR_YELLOW);
|
set_color(COLOR_YELLOW);
|
||||||
gfx_printf("Stecke das Ladegeraet an und warte...\n");
|
gfx_printf("Stecke das Ladegeraet an und warte...\n");
|
||||||
gfx_printf("Oder druecke + und - zum Abbrechen.\n");
|
gfx_printf("Oder Vol+ und Vol- (Konsole) zum Abbrechen.\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
jc_init_hw();
|
jc_init_hw();
|
||||||
while (btn_read() & BTN_POWER) { msleep(50); }
|
while (btn_read() & BTN_POWER) { msleep(50); }
|
||||||
bool user_cancelled = false;
|
bool user_cancelled = false;
|
||||||
while (batt_pct < BATT_LOW_THRESHOLD && !bq24193_charger_connected() && !user_cancelled) {
|
while (batt_pct < BATT_LOW_THRESHOLD && !bq24193_charger_connected() && !user_cancelled) {
|
||||||
|
u8 pbtn = btn_read();
|
||||||
jc_gamepad_rpt_t *jc = joycon_poll();
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
if (jc && jc->plus && jc->minus) {
|
if (jc) {
|
||||||
|
if (jc->cap)
|
||||||
|
take_screenshot();
|
||||||
|
}
|
||||||
|
if (cancel_combo_pressed(pbtn)) {
|
||||||
user_cancelled = true;
|
user_cancelled = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -428,6 +474,84 @@ void ipl_main(void) {
|
|||||||
gfx_con_setpos(0, 0);
|
gfx_con_setpos(0, 0);
|
||||||
print_header();
|
print_header();
|
||||||
|
|
||||||
|
// UHS class check: recommend U2 / V30 / A2 for emuMMC (speed and reliability)
|
||||||
|
#define UHS_U2_MIN 2
|
||||||
|
#define UHS_V30_MIN 30
|
||||||
|
#define UHS_A2_MIN 2
|
||||||
|
bool uhs_ok = (sd_storage.ssr.uhs_grade >= UHS_U2_MIN &&
|
||||||
|
sd_storage.ssr.video_class >= UHS_V30_MIN &&
|
||||||
|
sd_storage.ssr.app_class >= UHS_A2_MIN);
|
||||||
|
if (!uhs_ok) {
|
||||||
|
jc_init_hw();
|
||||||
|
gfx_clear_grey(0x1B);
|
||||||
|
gfx_con_setpos(0, 0);
|
||||||
|
set_color(COLOR_RED);
|
||||||
|
gfx_printf("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n");
|
||||||
|
gfx_printf("!! WARNUNG - SD-KARTEN-KLASSE !!\n");
|
||||||
|
gfx_printf("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n\n");
|
||||||
|
set_color(COLOR_WHITE);
|
||||||
|
gfx_printf("Diese SD-Karte erfuellt NICHT die empfohlenen\n");
|
||||||
|
gfx_printf("Mindestanforderungen (U2 | V30 | A2).\n\n");
|
||||||
|
set_color(COLOR_YELLOW);
|
||||||
|
gfx_printf("Aktuelle Werte: UHS%d | V%d | A%d\n\n",
|
||||||
|
(u32)sd_storage.ssr.uhs_grade,
|
||||||
|
(u32)sd_storage.ssr.video_class,
|
||||||
|
(u32)sd_storage.ssr.app_class);
|
||||||
|
set_color(COLOR_WHITE);
|
||||||
|
gfx_printf("Moegliche Folgen bei schwachen Karten:\n");
|
||||||
|
gfx_printf(" - Langsamere emuMMC / Spiel-Ladezeiten\n");
|
||||||
|
gfx_printf(" - Hoheres Risiko von Korruption oder Abstuerzen\n");
|
||||||
|
gfx_printf(" - Instabilitaet beim Schreiben groesserer Daten\n\n");
|
||||||
|
set_color(COLOR_CYAN);
|
||||||
|
gfx_printf("Empfohlen: U2 | V30 | A2 oder besser.\n");
|
||||||
|
gfx_printf("Empfohlene Karten: Samsung EVO Plus, EVO Select und PRO Plus.\n\n");
|
||||||
|
set_color(COLOR_GREEN);
|
||||||
|
gfx_printf("Druecke A (oder Power), um trotzdem fortzufahren.\n");
|
||||||
|
set_color(COLOR_CYAN);
|
||||||
|
gfx_printf("Vol+ und Vol- (Konsole) gleichzeitig: Abbrechen -> Hekate.\n");
|
||||||
|
set_color(COLOR_WHITE);
|
||||||
|
while (btn_read() & BTN_POWER) { msleep(50); }
|
||||||
|
bool acknowledged = false;
|
||||||
|
bool uhs_aborted = false;
|
||||||
|
while (!acknowledged && !uhs_aborted) {
|
||||||
|
u8 btn_state = btn_read();
|
||||||
|
if (btn_state & BTN_POWER) acknowledged = true;
|
||||||
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
|
if (jc) {
|
||||||
|
if (jc->cap)
|
||||||
|
take_screenshot();
|
||||||
|
if (jc->a) acknowledged = true;
|
||||||
|
}
|
||||||
|
if (cancel_combo_pressed(btn_state)) {
|
||||||
|
uhs_aborted = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
msleep(50);
|
||||||
|
}
|
||||||
|
if (uhs_aborted) {
|
||||||
|
gfx_printf("\nAbgebrochen. Starte Hekate...\n");
|
||||||
|
msleep(500);
|
||||||
|
if (file_exists(PAYLOAD_PATH)) {
|
||||||
|
launch_payload(PAYLOAD_PATH);
|
||||||
|
} else {
|
||||||
|
power_set_state(POWER_OFF_REBOOT);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Wait for A and Power to be released so the same press doesn't start the install
|
||||||
|
while (btn_read() & BTN_POWER) { msleep(50); }
|
||||||
|
bool released = false;
|
||||||
|
while (!released) {
|
||||||
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
|
released = (!jc || !jc->a) && !(btn_read() & BTN_POWER);
|
||||||
|
if (!released) msleep(50);
|
||||||
|
}
|
||||||
|
msleep(300); // Short delay so the next screen is visible before accepting input
|
||||||
|
gfx_clear_grey(0x1B);
|
||||||
|
gfx_con_setpos(0, 0);
|
||||||
|
print_header();
|
||||||
|
}
|
||||||
|
|
||||||
// Show information
|
// Show information
|
||||||
set_color(COLOR_CYAN);
|
set_color(COLOR_CYAN);
|
||||||
gfx_printf("Installationsmodus: %s\n", mode == INSTALL_MODE_UPDATE ? "Update" : "Saubere Installation");
|
gfx_printf("Installationsmodus: %s\n", mode == INSTALL_MODE_UPDATE ? "Update" : "Saubere Installation");
|
||||||
@@ -453,7 +577,7 @@ void ipl_main(void) {
|
|||||||
gfx_printf("um die Installation zu starten...\n");
|
gfx_printf("um die Installation zu starten...\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
set_color(COLOR_CYAN);
|
set_color(COLOR_CYAN);
|
||||||
gfx_printf("Druecke + und - gleichzeitig zum Abbrechen (zurueck zu Hekate).\n");
|
gfx_printf("Vol+ und Vol- (Konsole) gleichzeitig: Abbrechen -> Hekate.\n");
|
||||||
set_color(COLOR_WHITE);
|
set_color(COLOR_WHITE);
|
||||||
|
|
||||||
// Wait for A/Power to start, or +/- to cancel
|
// Wait for A/Power to start, or +/- to cancel
|
||||||
@@ -473,18 +597,19 @@ void ipl_main(void) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check joycon buttons
|
// Check joycon buttons; Capture = screenshot
|
||||||
jc_gamepad_rpt_t *jc = joycon_poll();
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
if (jc) {
|
if (jc) {
|
||||||
|
if (jc->cap)
|
||||||
|
take_screenshot();
|
||||||
if (jc->a) {
|
if (jc->a) {
|
||||||
button_pressed = true;
|
button_pressed = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// + and - simultaneously = cancel, return to hekate
|
}
|
||||||
if (jc->plus && jc->minus) {
|
if (cancel_combo_pressed(btn_state)) {
|
||||||
cancelled = true;
|
cancelled = true;
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
msleep(50); // Small delay to avoid busy-waiting
|
msleep(50); // Small delay to avoid busy-waiting
|
||||||
@@ -521,7 +646,8 @@ void ipl_main(void) {
|
|||||||
|
|
||||||
// Wait 3 seconds before clearing screen to allow errors to be visible
|
// Wait 3 seconds before clearing screen to allow errors to be visible
|
||||||
msleep(3000);
|
msleep(3000);
|
||||||
|
// take_screenshot(); // Take a screenshot of the installation summary
|
||||||
|
|
||||||
// Clear screen for final summary to ensure it's visible
|
// Clear screen for final summary to ensure it's visible
|
||||||
gfx_clear_grey(0x1B);
|
gfx_clear_grey(0x1B);
|
||||||
gfx_con_setpos(0, 0);
|
gfx_con_setpos(0, 0);
|
||||||
@@ -573,11 +699,15 @@ void ipl_main(void) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check joycon A button
|
// Check joycon A button; Capture = screenshot
|
||||||
jc_gamepad_rpt_t *jc = joycon_poll();
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
if (jc && jc->a) {
|
if (jc) {
|
||||||
button_pressed = true;
|
if (jc->cap)
|
||||||
break;
|
take_screenshot();
|
||||||
|
if (jc->a) {
|
||||||
|
button_pressed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
msleep(50); // Small delay to avoid busy-waiting
|
msleep(50); // Small delay to avoid busy-waiting
|
||||||
@@ -615,9 +745,13 @@ void ipl_main(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
jc_gamepad_rpt_t *jc = joycon_poll();
|
jc_gamepad_rpt_t *jc = joycon_poll();
|
||||||
if (jc && jc->a) {
|
if (jc) {
|
||||||
button_pressed = true;
|
if (jc->cap)
|
||||||
break;
|
take_screenshot();
|
||||||
|
if (jc->a) {
|
||||||
|
button_pressed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
msleep(50);
|
msleep(50);
|
||||||
|
|||||||
461
source/nx_sd.c
461
source/nx_sd.c
@@ -1,228 +1,233 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
* Copyright (c) 2018-2019 CTCaer
|
* Copyright (c) 2018-2019 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
* version 2, as published by the Free Software Foundation.
|
* version 2, as published by the Free Software Foundation.
|
||||||
*
|
*
|
||||||
* This program is distributed in the hope it will be useful, but WITHOUT
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
* more details.
|
* more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <storage/nx_sd.h>
|
#include <storage/nx_sd.h>
|
||||||
#include <storage/sdmmc.h>
|
#include <storage/sdmmc.h>
|
||||||
#include <storage/sdmmc_driver.h>
|
#include <storage/sdmmc_driver.h>
|
||||||
#include <gfx_utils.h>
|
#include <gfx_utils.h>
|
||||||
#include <libs/fatfs/ff.h>
|
#include <libs/fatfs/ff.h>
|
||||||
#include <mem/heap.h>
|
#include <mem/heap.h>
|
||||||
|
|
||||||
bool sd_mounted = false;
|
bool sd_mounted = false;
|
||||||
static u16 sd_errors[3] = { 0 }; // Init and Read/Write errors.
|
static u16 sd_errors[3] = { 0 }; // Init and Read/Write errors.
|
||||||
static u32 sd_mode = SD_UHS_SDR82;
|
static u32 sd_mode = SD_UHS_SDR82;
|
||||||
|
|
||||||
sdmmc_t sd_sdmmc;
|
sdmmc_t sd_sdmmc;
|
||||||
sdmmc_storage_t sd_storage;
|
sdmmc_storage_t sd_storage;
|
||||||
FATFS sd_fs;
|
FATFS sd_fs;
|
||||||
|
|
||||||
void sd_error_count_increment(u8 type)
|
void sd_error_count_increment(u8 type)
|
||||||
{
|
{
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
case SD_ERROR_INIT_FAIL:
|
case SD_ERROR_INIT_FAIL:
|
||||||
sd_errors[0]++;
|
sd_errors[0]++;
|
||||||
break;
|
break;
|
||||||
case SD_ERROR_RW_FAIL:
|
case SD_ERROR_RW_FAIL:
|
||||||
sd_errors[1]++;
|
sd_errors[1]++;
|
||||||
break;
|
break;
|
||||||
case SD_ERROR_RW_RETRY:
|
case SD_ERROR_RW_RETRY:
|
||||||
sd_errors[2]++;
|
sd_errors[2]++;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
u16 *sd_get_error_count()
|
u16 *sd_get_error_count()
|
||||||
{
|
{
|
||||||
return sd_errors;
|
return sd_errors;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool sd_get_card_removed()
|
bool sd_get_card_removed()
|
||||||
{
|
{
|
||||||
if (!sdmmc_get_sd_inserted())
|
if (!sdmmc_get_sd_inserted())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 sd_get_mode()
|
u32 sd_get_mode()
|
||||||
{
|
{
|
||||||
return sd_mode;
|
return sd_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sd_init_retry(bool power_cycle)
|
int sd_init_retry(bool power_cycle)
|
||||||
{
|
{
|
||||||
u32 bus_width = SDMMC_BUS_WIDTH_4;
|
u32 bus_width = SDMMC_BUS_WIDTH_4;
|
||||||
u32 type = SDHCI_TIMING_UHS_SDR82;
|
u32 type = SDHCI_TIMING_UHS_SDR82;
|
||||||
|
|
||||||
// Power cycle SD card.
|
// Power cycle SD card.
|
||||||
if (power_cycle)
|
if (power_cycle)
|
||||||
{
|
{
|
||||||
sd_mode--;
|
sd_mode--;
|
||||||
sdmmc_storage_end(&sd_storage);
|
sdmmc_storage_end(&sd_storage);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get init parameters.
|
// Get init parameters.
|
||||||
switch (sd_mode)
|
switch (sd_mode)
|
||||||
{
|
{
|
||||||
case SD_INIT_FAIL: // Reset to max.
|
case SD_INIT_FAIL: // Reset to max.
|
||||||
return 0;
|
return 0;
|
||||||
case SD_1BIT_HS25:
|
case SD_1BIT_HS25:
|
||||||
bus_width = SDMMC_BUS_WIDTH_1;
|
bus_width = SDMMC_BUS_WIDTH_1;
|
||||||
type = SDHCI_TIMING_SD_HS25;
|
type = SDHCI_TIMING_SD_HS25;
|
||||||
break;
|
break;
|
||||||
case SD_4BIT_HS25:
|
case SD_4BIT_HS25:
|
||||||
type = SDHCI_TIMING_SD_HS25;
|
type = SDHCI_TIMING_SD_HS25;
|
||||||
break;
|
break;
|
||||||
case SD_UHS_SDR82:
|
case SD_UHS_SDR82:
|
||||||
type = SDHCI_TIMING_UHS_SDR82;
|
type = SDHCI_TIMING_UHS_SDR82;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
sd_mode = SD_UHS_SDR82;
|
sd_mode = SD_UHS_SDR82;
|
||||||
}
|
}
|
||||||
|
|
||||||
return sdmmc_storage_init_sd(&sd_storage, &sd_sdmmc, bus_width, type);
|
return sdmmc_storage_init_sd(&sd_storage, &sd_sdmmc, bus_width, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool sd_initialize(bool power_cycle)
|
bool sd_initialize(bool power_cycle)
|
||||||
{
|
{
|
||||||
if (power_cycle)
|
if (power_cycle)
|
||||||
sdmmc_storage_end(&sd_storage);
|
sdmmc_storage_end(&sd_storage);
|
||||||
|
|
||||||
int res = !sd_init_retry(false);
|
int res = !sd_init_retry(false);
|
||||||
|
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
if (!res)
|
if (!res)
|
||||||
return true;
|
return true;
|
||||||
else if (!sdmmc_get_sd_inserted()) // SD Card is not inserted.
|
else if (!sdmmc_get_sd_inserted()) // SD Card is not inserted.
|
||||||
{
|
{
|
||||||
sd_mode = SD_UHS_SDR82;
|
sd_mode = SD_UHS_SDR82;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sd_errors[SD_ERROR_INIT_FAIL]++;
|
sd_errors[SD_ERROR_INIT_FAIL]++;
|
||||||
|
|
||||||
if (sd_mode == SD_INIT_FAIL)
|
if (sd_mode == SD_INIT_FAIL)
|
||||||
break;
|
break;
|
||||||
else
|
else
|
||||||
res = !sd_init_retry(true);
|
res = !sd_init_retry(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sdmmc_storage_end(&sd_storage);
|
sdmmc_storage_end(&sd_storage);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool is_sd_inited = false;
|
bool is_sd_inited = false;
|
||||||
|
|
||||||
bool sd_mount()
|
bool sd_mount()
|
||||||
{
|
{
|
||||||
if (sd_mounted)
|
if (sd_mounted)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
int res = !sd_initialize(false);
|
int res = !sd_initialize(false);
|
||||||
is_sd_inited = !res;
|
is_sd_inited = !res;
|
||||||
|
|
||||||
if (res)
|
if (res)
|
||||||
{
|
{
|
||||||
gfx_con.mute = false;
|
gfx_con.mute = false;
|
||||||
EPRINTF("Failed to init SD card.");
|
EPRINTF("Failed to init SD card.");
|
||||||
if (!sdmmc_get_sd_inserted())
|
if (!sdmmc_get_sd_inserted())
|
||||||
EPRINTF("Make sure that it is inserted.");
|
EPRINTF("Make sure that it is inserted.");
|
||||||
else
|
else
|
||||||
EPRINTF("SD Card Reader is not properly seated!");
|
EPRINTF("SD Card Reader is not properly seated!");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
res = f_mount(&sd_fs, "", 1);
|
res = f_mount(&sd_fs, "", 1);
|
||||||
if (res == FR_OK)
|
if (res == FR_OK)
|
||||||
{
|
{
|
||||||
sd_mounted = true;
|
sd_mounted = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
gfx_con.mute = false;
|
gfx_con.mute = false;
|
||||||
EPRINTFARGS("Failed to mount SD card (FatFS Error %d).\nMake sure that a FAT partition exists..", res);
|
EPRINTFARGS("Failed to mount SD card (FatFS Error %d).\nMake sure that a FAT partition exists..", res);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _sd_deinit()
|
static void _sd_deinit()
|
||||||
{
|
{
|
||||||
if (sd_mode == SD_INIT_FAIL)
|
if (sd_mode == SD_INIT_FAIL)
|
||||||
sd_mode = SD_UHS_SDR82;
|
sd_mode = SD_UHS_SDR82;
|
||||||
|
|
||||||
if (sd_mounted)
|
if (sd_mounted)
|
||||||
{
|
{
|
||||||
f_mount(NULL, "", 1);
|
f_mount(NULL, "", 1);
|
||||||
sdmmc_storage_end(&sd_storage);
|
sdmmc_storage_end(&sd_storage);
|
||||||
sd_mounted = false;
|
sd_mounted = false;
|
||||||
is_sd_inited = false;
|
is_sd_inited = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void sd_unmount() { _sd_deinit(); }
|
void sd_unmount() { _sd_deinit(); }
|
||||||
void sd_end() { _sd_deinit(); }
|
void sd_end() { _sd_deinit(); }
|
||||||
|
|
||||||
void *sd_file_read(const char *path, u32 *fsize)
|
bool sd_get_card_mounted(void)
|
||||||
{
|
{
|
||||||
FIL fp;
|
return sd_mounted;
|
||||||
if (f_open(&fp, path, FA_READ) != FR_OK)
|
}
|
||||||
return NULL;
|
|
||||||
|
void *sd_file_read(const char *path, u32 *fsize)
|
||||||
u32 size = f_size(&fp);
|
{
|
||||||
if (fsize)
|
FIL fp;
|
||||||
*fsize = size;
|
if (f_open(&fp, path, FA_READ) != FR_OK)
|
||||||
|
return NULL;
|
||||||
char *buf = malloc(size + 1);
|
|
||||||
buf[size] = '\0';
|
u32 size = f_size(&fp);
|
||||||
|
if (fsize)
|
||||||
if (f_read(&fp, buf, size, NULL) != FR_OK)
|
*fsize = size;
|
||||||
{
|
|
||||||
free(buf);
|
char *buf = malloc(size + 1);
|
||||||
f_close(&fp);
|
buf[size] = '\0';
|
||||||
|
|
||||||
return NULL;
|
if (f_read(&fp, buf, size, NULL) != FR_OK)
|
||||||
}
|
{
|
||||||
|
free(buf);
|
||||||
f_close(&fp);
|
f_close(&fp);
|
||||||
|
|
||||||
return buf;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int sd_save_to_file(void *buf, u32 size, const char *filename)
|
f_close(&fp);
|
||||||
{
|
|
||||||
FIL fp;
|
return buf;
|
||||||
u32 res = 0;
|
}
|
||||||
res = f_open(&fp, filename, FA_CREATE_ALWAYS | FA_WRITE);
|
|
||||||
if (res)
|
int sd_save_to_file(void *buf, u32 size, const char *filename)
|
||||||
{
|
{
|
||||||
EPRINTFARGS("Error (%d) creating file\n%s.\n", res, filename);
|
FIL fp;
|
||||||
return res;
|
u32 res = 0;
|
||||||
}
|
res = f_open(&fp, filename, FA_CREATE_ALWAYS | FA_WRITE);
|
||||||
|
if (res)
|
||||||
f_write(&fp, buf, size, NULL);
|
{
|
||||||
f_close(&fp);
|
EPRINTFARGS("Error (%d) creating file\n%s.\n", res, filename);
|
||||||
|
return res;
|
||||||
return 0;
|
}
|
||||||
}
|
|
||||||
|
f_write(&fp, buf, size, NULL);
|
||||||
|
f_close(&fp);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|||||||
111
source/screenshot.c
Normal file
111
source/screenshot.c
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
/*
|
||||||
|
* Screenshot support for OmniNX Installer Payload
|
||||||
|
* Based on TegraExplorer (AllgemeinerProblemLoeser) TakeScreenshot implementation.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "screenshot.h"
|
||||||
|
#include "gfx.h"
|
||||||
|
#include "nx_sd.h"
|
||||||
|
#include <libs/fatfs/ff.h>
|
||||||
|
#include <mem/heap.h>
|
||||||
|
#include <display/di.h>
|
||||||
|
#include <utils/util.h>
|
||||||
|
#include <utils/sprintf.h>
|
||||||
|
#include <rtc/max77620-rtc.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* BMP file header (54 bytes), matching TegraExplorer tools.h */
|
||||||
|
typedef struct __attribute__((packed)) _bmp_hdr_t
|
||||||
|
{
|
||||||
|
u16 magic;
|
||||||
|
u32 size;
|
||||||
|
u32 rsvd;
|
||||||
|
u32 data_off;
|
||||||
|
u32 hdr_size;
|
||||||
|
u32 width;
|
||||||
|
u32 height;
|
||||||
|
u16 planes;
|
||||||
|
u16 pxl_bits;
|
||||||
|
u32 comp;
|
||||||
|
u32 img_size;
|
||||||
|
u32 res_h;
|
||||||
|
u32 res_v;
|
||||||
|
u64 rsvd2;
|
||||||
|
} bmp_hdr_t;
|
||||||
|
|
||||||
|
#define BMP_HEADER_SIZE 0x36
|
||||||
|
#define FB_SIZE 0x384000 /* 1280 * 720 * 4 */
|
||||||
|
#define SCREEN_W 1280
|
||||||
|
#define SCREEN_H 720
|
||||||
|
|
||||||
|
void take_screenshot(void)
|
||||||
|
{
|
||||||
|
static u32 last_timer = 0;
|
||||||
|
|
||||||
|
if (!sd_get_card_mounted())
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* 3-second cooldown (same as TegraExplorer) */
|
||||||
|
u32 now = get_tmr_s();
|
||||||
|
if (last_timer != 0 && now < last_timer + 3)
|
||||||
|
return;
|
||||||
|
last_timer = now;
|
||||||
|
|
||||||
|
const char basepath[] = "sd:/switch/screenshot";
|
||||||
|
char name[48];
|
||||||
|
char path[80];
|
||||||
|
rtc_time_t rtc;
|
||||||
|
|
||||||
|
max77620_rtc_get_time(&rtc);
|
||||||
|
s_printf(name, "omninx_installer_%04d%02d%02d_%02d%02d%02d.bmp",
|
||||||
|
(u32)rtc.year, (u32)rtc.month, (u32)rtc.day,
|
||||||
|
(u32)rtc.hour, (u32)rtc.min, (u32)rtc.sec);
|
||||||
|
s_printf(path, "%s/%s", basepath, name);
|
||||||
|
|
||||||
|
f_mkdir("sd:/switch");
|
||||||
|
f_mkdir(basepath);
|
||||||
|
|
||||||
|
const u32 file_size = BMP_HEADER_SIZE + FB_SIZE;
|
||||||
|
u8 *bitmap = (u8 *)malloc(file_size);
|
||||||
|
u32 *fb_copy = (u32 *)malloc(FB_SIZE);
|
||||||
|
if (!bitmap || !fb_copy) {
|
||||||
|
if (bitmap) free(bitmap);
|
||||||
|
if (fb_copy) free(fb_copy);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Copy framebuffer with same coordinate flip as TegraExplorer (BGR layout) */
|
||||||
|
u32 *fb_ptr = gfx_ctxt.fb;
|
||||||
|
for (int x = SCREEN_W - 1; x >= 0; x--) {
|
||||||
|
for (int y = SCREEN_H - 1; y >= 0; y--)
|
||||||
|
fb_copy[y * SCREEN_W + x] = *fb_ptr++;
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(bitmap + BMP_HEADER_SIZE, fb_copy, FB_SIZE);
|
||||||
|
|
||||||
|
bmp_hdr_t *bmp = (bmp_hdr_t *)bitmap;
|
||||||
|
bmp->magic = 0x4D42;
|
||||||
|
bmp->size = file_size;
|
||||||
|
bmp->rsvd = 0;
|
||||||
|
bmp->data_off = BMP_HEADER_SIZE;
|
||||||
|
bmp->hdr_size = 40;
|
||||||
|
bmp->width = SCREEN_W;
|
||||||
|
bmp->height = SCREEN_H;
|
||||||
|
bmp->planes = 1;
|
||||||
|
bmp->pxl_bits = 32;
|
||||||
|
bmp->comp = 0;
|
||||||
|
bmp->img_size = FB_SIZE;
|
||||||
|
bmp->res_h = 2834;
|
||||||
|
bmp->res_v = 2834;
|
||||||
|
bmp->rsvd2 = 0;
|
||||||
|
|
||||||
|
sd_save_to_file(bitmap, file_size, path);
|
||||||
|
|
||||||
|
free(bitmap);
|
||||||
|
free(fb_copy);
|
||||||
|
|
||||||
|
/* Brief backlight flash (same as TegraExplorer) */
|
||||||
|
display_backlight_brightness(255, 1000);
|
||||||
|
msleep(100);
|
||||||
|
display_backlight_brightness(100, 1000);
|
||||||
|
}
|
||||||
13
source/screenshot.h
Normal file
13
source/screenshot.h
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
/*
|
||||||
|
* Screenshot support for OmniNX Installer Payload
|
||||||
|
* Based on TegraExplorer (AllgemeinerProblemLoeser) TakeScreenshot implementation.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <utils/types.h>
|
||||||
|
|
||||||
|
/* Take a screenshot of the current framebuffer and save as BMP to SD.
|
||||||
|
* Triggered by Capture button (jc->cap). Uses 3-second cooldown.
|
||||||
|
* Saves to sd:/switch/screenshot/omninx_installer_YYYYMMDD_HHMMSS.bmp */
|
||||||
|
void take_screenshot(void);
|
||||||
70
tools/ram_test_main.c
Normal file
70
tools/ram_test_main.c
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
/*
|
||||||
|
* Minimal RAM info test payload (fuse DRAM ID + SK table -> MiB).
|
||||||
|
* Build: make ram-test -> output/RAM-Test.bin
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <display/di.h>
|
||||||
|
#include <mem/heap.h>
|
||||||
|
#include <mem/minerva.h>
|
||||||
|
#include <memory_map.h>
|
||||||
|
#include <soc/bpmp.h>
|
||||||
|
#include <soc/fuse.h>
|
||||||
|
#include <soc/hw_init.h>
|
||||||
|
#include <soc/t210.h>
|
||||||
|
#include <utils/util.h>
|
||||||
|
|
||||||
|
#include "dram_fuse.h"
|
||||||
|
#include "gfx.h"
|
||||||
|
|
||||||
|
#undef COLOR_CYAN
|
||||||
|
#undef COLOR_WHITE
|
||||||
|
#define COLOR_CYAN 0xFF00FFFF
|
||||||
|
#define COLOR_WHITE 0xFFFFFFFF
|
||||||
|
|
||||||
|
/* Required by BDK */
|
||||||
|
boot_cfg_t __attribute__((section("._boot_cfg"))) b_cfg;
|
||||||
|
volatile nyx_storage_t *nyx_str = (nyx_storage_t *)NYX_STORAGE_ADDR;
|
||||||
|
|
||||||
|
extern void pivot_stack(u32 stack_top);
|
||||||
|
|
||||||
|
void ipl_main(void)
|
||||||
|
{
|
||||||
|
hw_init();
|
||||||
|
pivot_stack(IPL_STACK_TOP);
|
||||||
|
heap_init(IPL_HEAP_START);
|
||||||
|
|
||||||
|
minerva_init();
|
||||||
|
minerva_change_freq(FREQ_800);
|
||||||
|
|
||||||
|
display_init();
|
||||||
|
u32 *fb = display_init_framebuffer_pitch();
|
||||||
|
gfx_init_ctxt(fb, 720, 1280, 720);
|
||||||
|
gfx_con_init();
|
||||||
|
display_backlight_pwm_init();
|
||||||
|
display_backlight_brightness(100, 1000);
|
||||||
|
|
||||||
|
bpmp_clk_rate_set(BPMP_CLK_DEFAULT_BOOST);
|
||||||
|
|
||||||
|
gfx_clear_grey(0x1B);
|
||||||
|
gfx_con_setpos(0, 0);
|
||||||
|
gfx_con_setcol(COLOR_CYAN, gfx_con.fillbg, gfx_con.bgcol);
|
||||||
|
gfx_printf("RAM test payload\n\n");
|
||||||
|
gfx_con_setcol(COLOR_WHITE, gfx_con.fillbg, gfx_con.bgcol);
|
||||||
|
|
||||||
|
u32 raw = fuse_read_dramid(true);
|
||||||
|
u32 nid = fuse_read_dramid(false);
|
||||||
|
u32 chip = hw_get_chip_id();
|
||||||
|
int mib = dram_capacity_mib_from_fuse();
|
||||||
|
|
||||||
|
gfx_printf("SoC: %s\n", chip == GP_HIDREV_MAJOR_T210B01 ? "Mariko (T210B01)" : "Erista (T210)");
|
||||||
|
gfx_printf("DRAM fuse: raw %d norm %d\n", raw, nid);
|
||||||
|
if (mib > 0)
|
||||||
|
gfx_printf("Table MiB: %d (fuse SKU, not probe)\n", mib);
|
||||||
|
else
|
||||||
|
gfx_printf("Table MiB: (unknown id for this SoC)\n");
|
||||||
|
|
||||||
|
gfx_printf("\nHang — power off or inject payload.\n");
|
||||||
|
|
||||||
|
while (1)
|
||||||
|
msleep(500);
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user