diff options
author | Dana Conrad <dconrad@fastmail.com> | 2021-06-26 12:07:11 -0500 |
---|---|---|
committer | Aidan MacDonald <amachronic@protonmail.com> | 2021-07-18 12:14:35 +0000 |
commit | 3e7a09cb0dee0ee04b5c77f427bf89d990ec8d0b (patch) | |
tree | be1eb7e1d4166f60b245a0603e9f7dc11e1f5614 /firmware/target/mips/ingenic_x1000/erosqnative/spl-erosqnative.c | |
parent | 64a24591aec049682167b193700a07572fc04c4c (diff) | |
download | rockbox-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.c | 63 |
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 | |||
29 | const 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 | |||
39 | int spl_get_boot_option(void) | ||
40 | { | ||
41 | return BOOT_OPTION_ROCKBOX; | ||
42 | } | ||
43 | |||
44 | void 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 | } | ||