Small changes, added a macro for reading options

This commit is contained in:
Aurora 2016-04-06 14:51:07 +02:00
parent e882dd7aaf
commit 4180261f1f
8 changed files with 34 additions and 27 deletions

View File

@ -116,13 +116,13 @@ bytes_read: .word 0
fopen: .ascii "OPEN" fopen: .ascii "OPEN"
.pool .pool
firm_fname: .dcw "sdmc:/aurei/patched_firmware_sys.bin" firm_fname: .dcw "sdmc:/aurei/patched_firmware_sys.bin"
.word 0x0 .word 0
.pool .pool
twlfirm_fname: .dcw "sdmc:/aurei/patched_firmware_twl.bin" twlfirm_fname: .dcw "sdmc:/aurei/patched_firmware_twl.bin"
.word 0x0 .word 0
.pool .pool
agbfirm_fname: .dcw "sdmc:/aurei/patched_firmware_agb.bin" agbfirm_fname: .dcw "sdmc:/aurei/patched_firmware_agb.bin"
.word 0x0 .word 0
.align 4 .align 4
kernelcode_start: kernelcode_start:

View File

@ -3,7 +3,7 @@
void main(void) void main(void)
{ {
const u32 brightness[4] = {0x5F, 0x4C, 0x39, 0x26}; const u32 brightness[4] = {0x5F, 0x4C, 0x39, 0x26};
u32 brightnessLevel = *(vu32 *)0x24F04000; u32 brightnessLevel = *(vu32 *)0x24F03008;
vu32 *const arm11 = (u32 *)0x1FFFFFF8; vu32 *const arm11 = (u32 *)0x1FFFFFF8;
*(vu32 *)0x10141200 = 0x1007F; *(vu32 *)0x10141200 = 0x1007F;

View File

@ -6,3 +6,5 @@ _start:
CPSID aif CPSID aif
b main b main
.word 0

View File

@ -37,9 +37,9 @@ void configureCFW(const char *configPath, const char *patchedFirms[])
} options[optionsAmount]; } options[optionsAmount];
//Parse the existing configuration //Parse the existing configuration
options[0].enabled = (config >> 10) & 3; options[0].enabled = CONFIG(10, 3);
for(u32 i = optionsAmount; i; i--) for(u32 i = optionsAmount; i; i--)
options[i].enabled = (config >> (i - 1)) & 1; options[i].enabled = CONFIG((i - 1), 1);
//Pre-select the first configuration option //Pre-select the first configuration option
u32 selectedOption = 1, u32 selectedOption = 1,
@ -65,7 +65,7 @@ void configureCFW(const char *configPath, const char *patchedFirms[])
u32 pressed = 0; u32 pressed = 0;
do { do {
//An option changed, black out the 'x' for the previously selected option/brightness level //The status of the selected option changed, black out the previously visible 'x' if needed
if(optionChanged) if(optionChanged)
{ {
if(!selectedOption) if(!selectedOption)
@ -116,9 +116,13 @@ void configureCFW(const char *configPath, const char *patchedFirms[])
selectedOption = optionsAmount - 1; selectedOption = optionsAmount - 1;
break; break;
case BUTTON_A: case BUTTON_A:
optionChanged = 1 + options[0].enabled; optionChanged = 1;
if(selectedOption) options[selectedOption].enabled = !options[selectedOption].enabled; if(selectedOption) options[selectedOption].enabled = !options[selectedOption].enabled;
else options[0].enabled = options[0].enabled == 3 ? 0 : options[0].enabled + 1; else
{
optionChanged += options[0].enabled;
options[0].enabled = options[0].enabled == 3 ? 0 : options[0].enabled + 1;
}
break; break;
} }
@ -126,10 +130,10 @@ void configureCFW(const char *configPath, const char *patchedFirms[])
} }
//If the user has been using A9LH and the "Updated SysNAND" setting changed, delete the patched 9.0 FIRM //If the user has been using A9LH and the "Updated SysNAND" setting changed, delete the patched 9.0 FIRM
if(((config >> 16) & 1) && ((config & 1) != options[1].enabled)) fileDelete(patchedFirms[3]); if(CONFIG(16, 1) && (CONFIG(0, 1) != options[1].enabled)) fileDelete(patchedFirms[3]);
//If the "Show GBA boot screen in patched AGB_FIRM" setting changed, delete the patched AGB_FIRM //If the "Show GBA boot screen in patched AGB_FIRM" setting changed, delete the patched AGB_FIRM
if(((config >> 6) & 1) != options[7].enabled) fileDelete(patchedFirms[5]); if(CONFIG(6, 1) != options[7].enabled) fileDelete(patchedFirms[5]);
//Preserve the last-used boot options (last 12 bits) //Preserve the last-used boot options (last 12 bits)
config &= 0xFFF000; config &= 0xFFF000;

View File

@ -9,6 +9,7 @@
#include "types.h" #include "types.h"
#define CFG_BOOTENV (*(vu32 *)0x10010000) #define CFG_BOOTENV (*(vu32 *)0x10010000)
#define CONFIG(a, b) ((config >> a) & b)
u32 config; u32 config;

View File

@ -68,7 +68,7 @@ void setupCFW(void)
//Determine if A9LH is installed and the user has an updated sysNAND //Determine if A9LH is installed and the user has an updated sysNAND
u32 updatedSys; u32 updatedSys;
if(a9lhBoot || (config >> 2) & 1) if(a9lhBoot || CONFIG(2, 1))
{ {
if(pressed == SAFE_MODE) if(pressed == SAFE_MODE)
error("Using Safe Mode would brick you, or remove A9LH!"); error("Using Safe Mode would brick you, or remove A9LH!");
@ -76,7 +76,7 @@ void setupCFW(void)
a9lhSetup = 1; a9lhSetup = 1;
//Check setting for > 9.2 sysNAND //Check setting for > 9.2 sysNAND
updatedSys = config & 1; updatedSys = CONFIG(0, 1);
} }
else else
{ {
@ -93,7 +93,7 @@ void setupCFW(void)
//Always force a sysNAND boot when quitting AGB_FIRM //Always force a sysNAND boot when quitting AGB_FIRM
if(previousFirm == 7) if(previousFirm == 7)
{ {
mode = updatedSys ? 1 : (config >> 12) & 1; mode = updatedSys ? 1 : CONFIG(12, 1);
emuNAND = 0; emuNAND = 0;
needConfig = 0; needConfig = 0;
@ -102,10 +102,10 @@ void setupCFW(void)
} }
/* Else, force the last used boot options unless a payload button or A/L/R are pressed /* Else, force the last used boot options unless a payload button or A/L/R are pressed
or the no-forcing flag is set */ or the no-forcing flag is set */
else if(!(pressed & OVERRIDE_BUTTONS) && !((config >> 15) & 1)) else if(!(pressed & OVERRIDE_BUTTONS) && !CONFIG(15, 1))
{ {
mode = (config >> 12) & 1; mode = CONFIG(12, 1);
emuNAND = (config >> 13) & 3; emuNAND = CONFIG(13, 3);
needConfig = 0; needConfig = 0;
} }
} }
@ -124,11 +124,11 @@ void setupCFW(void)
configureCFW(configPath, patchedFirms); configureCFW(configPath, patchedFirms);
//If screens are inited or the corresponding option is set, load splash screen //If screens are inited or the corresponding option is set, load splash screen
if(PDN_GPU_CNT != 1 || ((config >> 7) & 1)) loadSplash(); if(PDN_GPU_CNT != 1 || CONFIG(7, 1)) loadSplash();
/* If L is pressed, or L or R are not pressed when it is the default FIRM, /* If L is pressed, or L or R are not pressed when it is the default FIRM,
boot 9.0 FIRM */ boot 9.0 FIRM */
mode = ((config >> 3) & 1) ? ((!(pressed & BUTTON_L1R1)) ? 0 : 1) : mode = CONFIG(3, 1) ? ((!(pressed & BUTTON_L1R1)) ? 0 : 1) :
((pressed & BUTTON_L1) ? 0 : 1); ((pressed & BUTTON_L1) ? 0 : 1);
/* If L or R aren't pressed on a 9.0/9.2 sysNAND, or the 9.0 FIRM is selected /* If L or R aren't pressed on a 9.0/9.2 sysNAND, or the 9.0 FIRM is selected
@ -137,7 +137,7 @@ void setupCFW(void)
{ {
/* If not 9.0 FIRM and the second emuNAND is set as default and B isn't pressed, or vice-versa, /* If not 9.0 FIRM and the second emuNAND is set as default and B isn't pressed, or vice-versa,
attempt to boot it */ attempt to boot it */
emuNAND = (mode && ((!(pressed & BUTTON_B)) == ((config >> 4) & 1))) ? 2 : 1; emuNAND = (mode && ((!(pressed & BUTTON_B)) == CONFIG(4, 1))) ? 2 : 1;
} }
else emuNAND = 0; else emuNAND = 0;
@ -147,7 +147,7 @@ void setupCFW(void)
deleteFirms(patchedFirms, sizeof(patchedFirms) / sizeof(char *)); deleteFirms(patchedFirms, sizeof(patchedFirms) / sizeof(char *));
} }
u32 usePatchedFirmSet = ((config >> 1) & 1); u32 usePatchedFirmSet = CONFIG(1, 1);
while(1) while(1)
{ {
@ -271,7 +271,7 @@ static inline void patchTwlAgb(u32 whichFirm)
/* Calculate the amount of patches to apply. Only count the boot screen patch for AGB_FIRM /* Calculate the amount of patches to apply. Only count the boot screen patch for AGB_FIRM
if the matching option was enabled (keep it as last) */ if the matching option was enabled (keep it as last) */
u32 numPatches = whichFirm ? (sizeof(agbPatches) / sizeof(patchData)) - !((config >> 6) & 1) : u32 numPatches = whichFirm ? (sizeof(agbPatches) / sizeof(patchData) - !CONFIG(6, 1)) :
(sizeof(twlPatches) / sizeof(patchData)); (sizeof(twlPatches) / sizeof(patchData));
const patchData *patches = whichFirm ? agbPatches : twlPatches; const patchData *patches = whichFirm ? agbPatches : twlPatches;

View File

@ -51,11 +51,11 @@ void initScreens(void)
{ {
if(PDN_GPU_CNT == 1) if(PDN_GPU_CNT == 1)
{ {
//Write brightness level for the stub to pick up
*(vu32 *)0x24F04000 = (config >> 10) & 3;
memcpy((void *)SCREENINIT_ADDRESS, screeninit, screeninit_size); memcpy((void *)SCREENINIT_ADDRESS, screeninit, screeninit_size);
//Write brightness level for the stub to pick up
*(vu32 *)(SCREENINIT_ADDRESS + 8) = CONFIG(10, 3);
*arm11 = SCREENINIT_ADDRESS; *arm11 = SCREENINIT_ADDRESS;
while(*arm11); while(*arm11);