summaryrefslogtreecommitdiff
path: root/firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c
diff options
context:
space:
mode:
authorDana Conrad <dconrad@fastmail.com>2021-06-26 12:07:11 -0500
committerAidan MacDonald <amachronic@protonmail.com>2021-07-18 12:14:35 +0000
commit3e7a09cb0dee0ee04b5c77f427bf89d990ec8d0b (patch)
treebe1eb7e1d4166f60b245a0603e9f7dc11e1f5614 /firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c
parent64a24591aec049682167b193700a07572fc04c4c (diff)
downloadrockbox-3e7a09cb0dee0ee04b5c77f427bf89d990ec8d0b.tar.gz
rockbox-3e7a09cb0dee0ee04b5c77f427bf89d990ec8d0b.zip
New Port: Eros Q Native
What works: - LCD: 16-bit RGB565 - all buttons, including scrollwheel - SD Card - Battery level and charging/not charging status - USB - audio - sample rate switching - HP / LO detect, with "safe" fixed LO volume - LO volume will only be put to user-defined max volume if headphones are not present. - rtc - Plugins build, tried a couple and they seem OK - Bootloader, installable to nand via usbboot What doesn't work: - Dual Boot - power on/off has intermittent, low volume audio click (sometimes it's completely silent, sometimes there's a click) - Audio uses 16-bit volume scaling, so clicking/popping is pretty bad at lower volumes - need 32 bit volume scaling, 24 bit I2S data - USB HID keys not yet defined - no jztool support Unknowns: - Stereo Switch pins: Direction select, AC_DC (probably not even hooked up) - What is the actual purpose of the Stereo Swtich? - How does the bluetooth module connect? "Someday" stuff: - get LCD working at higher bit depth - Bluetooth Change-Id: I70dda8fc092c6e3f4352f2245e4164193f803c33
Diffstat (limited to 'firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c')
-rw-r--r--firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c63
1 files changed, 63 insertions, 0 deletions
diff --git a/firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c b/firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c
new file mode 100644
index 0000000000..9d7a1d118a
--- /dev/null
+++ b/firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c
@@ -0,0 +1,63 @@
1/***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
9 *
10 * Copyright (C) 2021 Aidan MacDonald
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
16 *
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
19 *
20 ****************************************************************************/
21
22#include "system.h"
23#include "clk-x1000.h"
24#include "spl-x1000.h"
25#include "gpio-x1000.h"
26
27/* TODO: get dual-boot working */
28
29const struct spl_boot_option spl_boot_options[] = {
30 [BOOT_OPTION_ROCKBOX] = {
31 .storage_addr = 0x6800,
32 .storage_size = 102 * 1024,
33 .load_addr = X1000_DRAM_BASE,
34 .exec_addr = X1000_DRAM_BASE,
35 .flags = BOOTFLAG_UCLPACK,
36 },
37};
38
39int spl_get_boot_option(void)
40{
41 return BOOT_OPTION_ROCKBOX;
42}
43
44void spl_error(void)
45{
46 const uint32_t pin = (1 << 25);
47
48 /* Turn on backlight */
49 jz_clr(GPIO_INT(GPIO_C), pin);
50 jz_set(GPIO_MSK(GPIO_C), pin);
51 jz_clr(GPIO_PAT1(GPIO_C), pin);
52 jz_set(GPIO_PAT0(GPIO_C), pin);
53
54 while(1) {
55 /* Turn it off */
56 mdelay(100);
57 jz_set(GPIO_PAT0(GPIO_C), pin);
58
59 /* Turn it on */
60 mdelay(100);
61 jz_clr(GPIO_PAT0(GPIO_C), pin);
62 }
63}