summaryrefslogtreecommitdiff
path: root/firmware
diff options
context:
space:
mode:
authorCástor Muñoz <cmvidal@gmail.com>2017-04-16 00:36:11 +0200
committerCástor Muñoz <cmvidal@gmail.com>2017-04-16 00:37:45 +0200
commit3fffff90e2c7c4e6ae3ab9d93f2c82d7b4d59961 (patch)
tree546d80b3c8e7b3db2bbc2c7f404be13b18def131 /firmware
parentc577c63c93e96571c3c0c3b84a1bbf3d3ecd66c2 (diff)
ipod6g: some fixes for recording
- Fix broken recording from jack microphone. - Fix recording hardware detection on models that do not support the jack microphone. - Enable monitor mode when recording. Change-Id: Ib79a2746f2d75f74cf6667d33bc9ed6512bbc8a9
Diffstat (limited to 'firmware')
-rw-r--r--firmware/target/arm/s5l8702/gpio-s5l8702.c1
-rw-r--r--firmware/target/arm/s5l8702/ipod6g/audio-6g.c58
2 files changed, 51 insertions, 8 deletions
diff --git a/firmware/target/arm/s5l8702/gpio-s5l8702.c b/firmware/target/arm/s5l8702/gpio-s5l8702.c
index 60ac141a91..6ad84c3dbb 100644
--- a/firmware/target/arm/s5l8702/gpio-s5l8702.c
+++ b/firmware/target/arm/s5l8702/gpio-s5l8702.c
@@ -62,6 +62,7 @@ void INIT_ATTR gpio_init(void)
* 1 0 120/160slim dock line-in + jack mic
*/
GPIOCMD = 0xe0700;
+ udelay(10000);
rec_hw_ver = (PDAT(14) & (1 << 7)) ? 0 : 1;
GPIOCMD = 0xe070e; /* restore default configuration */
diff --git a/firmware/target/arm/s5l8702/ipod6g/audio-6g.c b/firmware/target/arm/s5l8702/ipod6g/audio-6g.c
index 6a3bab06d6..825249400f 100644
--- a/firmware/target/arm/s5l8702/ipod6g/audio-6g.c
+++ b/firmware/target/arm/s5l8702/ipod6g/audio-6g.c
@@ -23,10 +23,55 @@
#include "audio.h"
#include "sound.h"
#include "pmu-target.h"
+#include "i2c-s5l8702.h"
extern int rec_hw_ver;
+/* Mikey is the internal controller for jack microphone and/or
+ * remote accessories.
+ * TODO:
+ * - move to mikey-6g.c
+ * - detect jack accessory
+ * - support for remote buttons
+ */
+unsigned char mikey_read(int address)
+{
+ unsigned char val;
+ i2c_read(0, 0x72, address, 1, &val);
+ return val;
+}
+
+int mikey_write(int address, unsigned char val)
+{
+ return i2c_write(0, 0x72, address, 1, &val);
+}
+
+void mikey_reset(void)
+{
+ mikey_write(0, 5);
+ mikey_write(1, 0x80);
+}
+
#if INPUT_SRC_CAPS != 0
+#ifdef HAVE_RECORDING
+void audio_enable_mic(bool enable)
+{
+ if (rec_hw_ver == 0)
+ return;
+
+ if (enable)
+ {
+ mikey_write(0, 7); /* raise voltage to polarize microphone */
+ GPIOCMD = 0xe070f; /* enable preamp */
+ }
+ else
+ {
+ mikey_reset(); /* microphone line voltage = 0 */
+ GPIOCMD = 0xe070e; /* disable preamp */
+ }
+}
+#endif
+
void audio_set_output_source(int source)
{
if ((unsigned)source >= AUDIO_NUM_SOURCES)
@@ -53,8 +98,7 @@ void audio_input_mux(int source, unsigned flags)
/* Vcodec = 1800mV (900mV + value*100mV) */
pmu_ldo_set_voltage(3, 0x9);
- if (rec_hw_ver == 1)
- GPIOCMD = 0xe070e;
+ audio_enable_mic(false);
}
#endif
break;
@@ -63,13 +107,12 @@ void audio_input_mux(int source, unsigned flags)
case AUDIO_SRC_MIC: /* recording only */
if (source != last_source)
{
- if (rec_hw_ver == 1)
- GPIOCMD = 0xe070f;
+ audio_enable_mic(true);
/* Vcodec = 2400mV (900mV + value*100mV) */
pmu_ldo_set_voltage(3, 0xf);
- audiohw_set_monitor(false);
+ audiohw_set_monitor(true);
audiohw_enable_recording(true); /* source mic */
}
break;
@@ -79,13 +122,12 @@ void audio_input_mux(int source, unsigned flags)
case AUDIO_SRC_LINEIN: /* recording only */
if (source != last_source)
{
- if (rec_hw_ver == 1)
- GPIOCMD = 0xe070e;
+ audio_enable_mic(false);
/* Vcodec = 2400mV (900mV + value*100mV) */
pmu_ldo_set_voltage(3, 0xf);
- audiohw_set_monitor(false);
+ audiohw_set_monitor(true);
audiohw_enable_recording(false); /* source line */
}
break;