summaryrefslogtreecommitdiff
path: root/firmware/target/mips/ingenic_x1000/erosqnative/audiohw-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/audiohw-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/audiohw-erosqnative.c')
-rw-r--r--firmware/target/mips/ingenic_x1000/erosqnative/audiohw-erosqnative.c90
1 files changed, 90 insertions, 0 deletions
diff --git a/firmware/target/mips/ingenic_x1000/erosqnative/audiohw-erosqnative.c b/firmware/target/mips/ingenic_x1000/erosqnative/audiohw-erosqnative.c
new file mode 100644
index 0000000000..7bb985650c
--- /dev/null
+++ b/firmware/target/mips/ingenic_x1000/erosqnative/audiohw-erosqnative.c
@@ -0,0 +1,90 @@
1/***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
9 *
10 * Copyright (C) 2021 Aidan MacDonald, Dana Conrad
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 "audiohw.h"
23#include "system.h"
24#include "pcm_sampr.h"
25#include "aic-x1000.h"
26#include "i2c-x1000.h"
27#include "gpio-x1000.h"
28#include "logf.h"
29
30/* Audio path appears to be:
31 * DAC --> HP Amp --> Stereo Switch --> HP OUT
32 * \--> LO OUT
33 *
34 * The real purpose of the Stereo Switch is not clear.
35 * It appears to switch sources between the HP amp and something,
36 * likely something unimplemented. */
37
38void audiohw_init(void)
39{
40 /* explicitly mute everything */
41 gpio_set_level(GPIO_MAX97220_SHDN, 0);
42 gpio_set_level(GPIO_ISL54405_MUTE, 1);
43 gpio_set_level(GPIO_PCM5102A_XMIT, 0);
44
45 aic_set_external_codec(true);
46 aic_set_i2s_mode(AIC_I2S_MASTER_MODE);
47 audiohw_set_frequency(HW_FREQ_48);
48
49 aic_enable_i2s_master_clock(true);
50 aic_enable_i2s_bit_clock(true);
51
52 mdelay(10);
53
54 /* power on DAC and HP Amp */
55 gpio_set_level(GPIO_PCM5102A_ANALOG_PWR, 1);
56 gpio_set_level(GPIO_MAX97220_POWER, 1);
57}
58
59void audiohw_postinit(void)
60{
61 /* unmute - attempt to make power-on pop-free */
62 gpio_set_level(GPIO_ISL54405_SEL, 0);
63 gpio_set_level(GPIO_MAX97220_SHDN, 1);
64 mdelay(10);
65 gpio_set_level(GPIO_PCM5102A_XMIT, 1);
66 mdelay(10);
67 gpio_set_level(GPIO_ISL54405_MUTE, 0);
68}
69
70/* TODO: get shutdown just right according to dac datasheet */
71void audiohw_close(void)
72{
73 /* mute - attempt to make power-off pop-free */
74 gpio_set_level(GPIO_ISL54405_MUTE, 1);
75 mdelay(10);
76 gpio_set_level(GPIO_PCM5102A_XMIT, 0);
77 mdelay(10);
78 gpio_set_level(GPIO_MAX97220_SHDN, 0);
79}
80
81void audiohw_set_frequency(int fsel)
82{
83 int sampr = hw_freq_sampr[fsel];
84 int mult = 256;
85
86 aic_enable_i2s_bit_clock(false);
87 aic_set_i2s_clock(X1000_CLK_SCLK_A, sampr, mult);
88 aic_enable_i2s_bit_clock(true);
89}
90