load latest firmware from official os (not tested)

This commit is contained in:
Robin Jones 2017-02-21 22:49:47 +00:00
parent 311d060a14
commit 9ccd46e07f

View File

@ -162,7 +162,7 @@ enum InputMap
enum InputMap input_mapping = file_manager; enum InputMap input_mapping = file_manager;
//holds the string of the character input screen result //holds the string of the character input screen result
int text_input_on = 0; //int text_input_on = 0;
//char input vars //char input vars
int x, y, position, set; int x, y, position, set;
@ -172,7 +172,7 @@ uint32_t chr_forecolor;
uint32_t chr_backcolor; uint32_t chr_backcolor;
//save type still set - save todo after reboot //save type still set - save todo after reboot
int save_reboot = 0; int save_after_reboot = 0;
//cart id from rom header //cart id from rom header
unsigned char cartID[4]; unsigned char cartID[4];
@ -841,6 +841,20 @@ static int configHandler(void *user, const char *section, const char *name, cons
return 1; return 1;
} }
void updateFirmware(char *filename)
{ //check that firmware exists on the disk? mainly because it has to be ripped from the official image and may not have been.
FatRecord rec_tmpf;
int ok = fatFindRecord(filename, &rec_tmpf, 0);
if (ok == 0)
{
int fpf = dfs_open(filename);
firmware = malloc(dfs_size(fpf));
dfs_read(firmware, 1, dfs_size(fpf), fpf);
dfs_close(fpf);
bi_load_firmware(firmware);
}
}
//everdrive init functions //everdrive init functions
void configure() void configure()
{ {
@ -854,7 +868,7 @@ void configure()
//REG_MAX_MSG //REG_MAX_MSG
evd_setCfgBit(ED_CFG_SDRAM_ON, 0); evd_setCfgBit(ED_CFG_SDRAM_ON, 0);
dma_read_s(buff, ROM_ADDR + 0x20, 16); dma_read_s(buff, ROM_ADDR + 0x20, 16);
asm_date = memRomRead32(0x38); asm_date = memRomRead32(0x38); //TODO: this should be displayed somewhere...
evd_setCfgBit(ED_CFG_SDRAM_ON, 1); evd_setCfgBit(ED_CFG_SDRAM_ON, 1);
firm = evd_readReg(REG_VER); //TODO: why not just use evd_getFirmVersion() firm = evd_readReg(REG_VER); //TODO: why not just use evd_getFirmVersion()
@ -876,13 +890,17 @@ void configure()
{ {
msg |= 1 << 14; msg |= 1 << 14;
evd_writeReg(REG_MAX_MSG, msg); evd_writeReg(REG_MAX_MSG, msg);
if (firm == 0x0214) if (firm == 0x0214) //need to take into account different default firmware versions for each ED64 version
{ {
int fpf = dfs_open("/firmware.bin"); updateFirmware("/firmware/firmware_v2.bin");
firmware = malloc(dfs_size(fpf)); }
dfs_read(firmware, 1, dfs_size(fpf), fpf); else if (firm == 0x0250)
dfs_close(fpf); {
bi_load_firmware(firmware); updateFirmware("/firmware/firmware_v2_5.bin");
}
else if (firm == 0x0300)
{
updateFirmware("/firmware/firmware_v3.bin");
} }
sleep(1); sleep(1);
@ -893,7 +911,7 @@ void configure()
evd_setCfgBit(ED_CFG_SDRAM_ON, 1); evd_setCfgBit(ED_CFG_SDRAM_ON, 1);
} }
if (sd_mode) if (sd_mode) //TODO: can this be moved before the firmware is loaded?
{ {
diskSetInterface(DISK_IFACE_SD); diskSetInterface(DISK_IFACE_SD);
} }
@ -1365,18 +1383,18 @@ void loadrom(display_context_t disp, u8 *buff, int fast)
else if (resp) else if (resp)
{ {
sprintf(tmp, "resp: %i", resp); sprintf(tmp, "Response: %i", resp);
printText(tmp, 3, -1, disp); printText(tmp, 3, -1, disp);
} }
TRACE(disp, "enalbe sd_mode"); TRACE(disp, "Checking SD mode");
resp = evd_isSDMode(); resp = evd_isSDMode();
TRACEF(disp, "sdmode: %i", resp); TRACEF(disp, "SD mode: %i", resp);
TRACEF(disp, "Size: %i", file.sec_available); TRACEF(disp, "Size: %i", file.sec_available);
TRACEF(disp, "f_sector: %i", file.sector); TRACEF(disp, "File sector: %i", file.sector);
TRACE(disp, "loading:"); TRACE(disp, "Loading:");
sleep(10); sleep(10);
@ -1451,7 +1469,7 @@ int backupSaveData(display_context_t disp)
FatRecord rec_tmpf; FatRecord rec_tmpf;
printText("Saving Last Played Game State...", 3, 4, disp); printText("Saving last game session...", 3, 4, disp);
if (fatFindRecord(config_file_path, &rec_tmpf, 0) == 0) if (fatFindRecord(config_file_path, &rec_tmpf, 0) == 0)
{ //TODO: why does fatFindRecord return 0 for true?! { //TODO: why does fatFindRecord return 0 for true?!
@ -1494,7 +1512,7 @@ int backupSaveData(display_context_t disp)
{ //we are V3 and have had a hard reboot { //we are V3 and have had a hard reboot
evd_writeReg(REG_SAV_CFG, 1); //so we need to tell the save register it still has data. evd_writeReg(REG_SAV_CFG, 1); //so we need to tell the save register it still has data.
} }
save_reboot = 1; save_after_reboot = 1;
} }
} }
else else
@ -1520,7 +1538,7 @@ int backupSaveData(display_context_t disp)
//} //}
//reset with save request //reset with save request
if (save_reboot) if (save_after_reboot)
{ {
printText("Copying RAM to SD card...", 3, -1, disp); printText("Copying RAM to SD card...", 3, -1, disp);
if (saveTypeToSd(disp, rom_filename, save_format)) if (saveTypeToSd(disp, rom_filename, save_format))
@ -1859,7 +1877,7 @@ void view_mpk(display_context_t disp)
break; break;
case ACCESSORY_RUMBLEPAK: case ACCESSORY_RUMBLEPAK:
printText("rumblepak inserted", 11, -1, disp); printText("RumblePak inserted", 11, -1, disp);
break; break;
default: default:
@ -4606,7 +4624,6 @@ int main(void)
sndInit(); sndInit();
} }
timer_init(); timer_init();
//background //background
@ -4651,7 +4668,6 @@ int main(void)
background = read_sprite("rom://sprites/background.sprite"); background = read_sprite("rom://sprites/background.sprite");
} }
//todo: if bgm is enabled, we should start it... //todo: if bgm is enabled, we should start it...
//sndPlayBGM("rom://bgm21.it"); //sndPlayBGM("rom://bgm21.it");