2021-02-27 22:08:58 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2021 Aidan MacDonald
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2021-04-07 21:11:01 +00:00
|
|
|
#include "spl-x1000.h"
|
2021-02-27 22:08:58 +00:00
|
|
|
#include "gpio-x1000.h"
|
2021-04-07 21:11:01 +00:00
|
|
|
#include "nand-x1000.h"
|
|
|
|
#include "system.h"
|
2021-02-27 22:08:58 +00:00
|
|
|
#include <string.h>
|
|
|
|
|
2021-04-07 21:11:01 +00:00
|
|
|
/* Boot select button state must remain stable for this duration
|
|
|
|
* before the choice will be accepted. Currently 100ms.
|
|
|
|
*/
|
|
|
|
#define BTN_STABLE_TIME (100 * (X1000_EXCLK_FREQ / 4000))
|
2021-02-27 22:08:58 +00:00
|
|
|
|
|
|
|
static const char normal_cmdline[] = "mem=64M@0x0\
|
|
|
|
no_console_suspend\
|
|
|
|
console=ttyS2,115200n8\
|
|
|
|
lpj=5009408\
|
|
|
|
ip=off\
|
|
|
|
init=/linuxrc\
|
|
|
|
ubi.mtd=3\
|
|
|
|
root=ubi0:rootfs\
|
|
|
|
ubi.mtd=4\
|
|
|
|
rootfstype=ubifs\
|
|
|
|
rw\
|
|
|
|
loglevel=8";
|
|
|
|
|
2021-04-07 21:11:01 +00:00
|
|
|
static const char recovery_cmdline[] = "mem=64M@0x0\
|
|
|
|
no_console_suspend\
|
|
|
|
console=ttyS2,115200n8\
|
|
|
|
lpj=5009408\
|
|
|
|
ip=off";
|
|
|
|
|
|
|
|
const struct spl_boot_option spl_boot_options[] = {
|
2021-02-27 22:08:58 +00:00
|
|
|
{
|
|
|
|
/* Rockbox: the first unused NAND page is 26 KiB in, and the
|
|
|
|
* remainder of the block is unused, giving us 102 KiB to use.
|
|
|
|
*/
|
|
|
|
.nand_addr = 0x6800,
|
|
|
|
.nand_size = 0x19800,
|
|
|
|
.load_addr = 0x80003ff8, /* first 8 bytes are bootloader ID */
|
|
|
|
.exec_addr = 0x80004000,
|
|
|
|
.cmdline = NULL,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
/* Original firmware */
|
|
|
|
.nand_addr = 0x20000,
|
|
|
|
.nand_size = 0x400000,
|
|
|
|
.load_addr = 0x80efffc0,
|
|
|
|
.exec_addr = 0x80f00000,
|
|
|
|
.cmdline = normal_cmdline,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
/* Recovery image */
|
|
|
|
.nand_addr = 0x420000,
|
|
|
|
.nand_size = 0x500000,
|
|
|
|
.load_addr = 0x80efffc0,
|
|
|
|
.exec_addr = 0x80f00000,
|
|
|
|
.cmdline = recovery_cmdline,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2021-04-07 21:11:01 +00:00
|
|
|
void spl_error(void)
|
2021-02-27 22:08:58 +00:00
|
|
|
{
|
|
|
|
const int pin = (1 << 24);
|
|
|
|
|
|
|
|
/* Turn on button light */
|
|
|
|
jz_clr(GPIO_INT(GPIO_C), pin);
|
|
|
|
jz_set(GPIO_MSK(GPIO_C), pin);
|
|
|
|
jz_clr(GPIO_PAT1(GPIO_C), pin);
|
|
|
|
jz_set(GPIO_PAT0(GPIO_C), pin);
|
|
|
|
|
|
|
|
while(1) {
|
|
|
|
/* Turn it off */
|
|
|
|
mdelay(100);
|
|
|
|
jz_set(GPIO_PAT0(GPIO_C), pin);
|
|
|
|
|
|
|
|
/* Turn it on */
|
|
|
|
mdelay(100);
|
|
|
|
jz_clr(GPIO_PAT0(GPIO_C), pin);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-07 21:11:01 +00:00
|
|
|
int spl_get_boot_option(void)
|
2021-02-27 22:08:58 +00:00
|
|
|
{
|
|
|
|
const uint32_t pinmask = (1 << 17) | (1 << 19);
|
|
|
|
|
|
|
|
uint32_t pin = 1, lastpin = 0;
|
|
|
|
uint32_t deadline = 0;
|
|
|
|
|
|
|
|
/* Configure the button GPIOs as inputs */
|
|
|
|
gpio_config(GPIO_A, pinmask, GPIO_INPUT);
|
|
|
|
|
|
|
|
/* Poll the pins for a short duration to detect a keypress */
|
|
|
|
do {
|
|
|
|
lastpin = pin;
|
|
|
|
pin = ~REG_GPIO_PIN(GPIO_A) & pinmask;
|
|
|
|
if(pin != lastpin) {
|
|
|
|
/* This will always be set on the first iteration */
|
|
|
|
deadline = __ost_read32() + BTN_STABLE_TIME;
|
|
|
|
}
|
|
|
|
} while(__ost_read32() < deadline);
|
|
|
|
|
|
|
|
/* Play button boots original firmware */
|
|
|
|
if(pin == (1 << 17))
|
2021-04-07 21:11:01 +00:00
|
|
|
return SPL_BOOTOPT_ORIG_FW;
|
2021-02-27 22:08:58 +00:00
|
|
|
|
|
|
|
/* Volume up boots recovery */
|
|
|
|
if(pin == (1 << 19))
|
2021-04-07 21:11:01 +00:00
|
|
|
return SPL_BOOTOPT_RECOVERY;
|
2021-02-27 22:08:58 +00:00
|
|
|
|
|
|
|
/* Default is to boot Rockbox */
|
2021-04-07 21:11:01 +00:00
|
|
|
return SPL_BOOTOPT_ROCKBOX;
|
2021-02-27 22:08:58 +00:00
|
|
|
}
|