diff options
author | Koro Chen <koro.chen@mediatek.com> | 2015-07-31 17:11:04 +0800 |
---|---|---|
committer | Patrick Georgi <pgeorgi@google.com> | 2016-01-22 19:37:40 +0100 |
commit | 9733ba5bd0ca97efb08141f623f198b9c87e6d0f (patch) | |
tree | e7748e15bac395fd162f8a9a1d52aa93c856de3d /src/mainboard | |
parent | 64a6b9229a73a0577d7c738763d2d77d91bc0c49 (diff) |
google/oak: configure audio
BRANCH=none
BUG=none
TEST=build and verified pass on oak board
Change-Id: I01eb059a3525bbbc5d17335cf43bc01be4355142
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Original-Commit-Id: bc2bb9f5b461ec848df8aba07940b895401004f8
Original-Change-Id: I848468cec04a36659fbb4b898dff9368305d72ac
Original-Signed-off-by: Koro Chen <koro.chen@mediatek.com>
Original-Reviewed-on: https://chromium-review.googlesource.com/292683
Original-Commit-Ready: Yidi Lin <yidi.lin@mediatek.com>
Original-Tested-by: Yidi Lin <yidi.lin@mediatek.com>
Original-Reviewed-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/13092
Tested-by: build bot (Jenkins)
Reviewed-by: Martin Roth <martinroth@google.com>
Diffstat (limited to 'src/mainboard')
-rw-r--r-- | src/mainboard/google/oak/mainboard.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/src/mainboard/google/oak/mainboard.c b/src/mainboard/google/oak/mainboard.c index c219678ae8..8dde2ef186 100644 --- a/src/mainboard/google/oak/mainboard.c +++ b/src/mainboard/google/oak/mainboard.c @@ -17,10 +17,59 @@ #include <arch/io.h> #include <boardid.h> #include <boot/coreboot_tables.h> +#include <delay.h> #include <device/device.h> +#include <gpio.h> +#include <soc/mt6391.h> +#include <soc/mtcmos.h> +#include <soc/pinmux.h> +#include <soc/pll.h> + +static void configure_audio(void) +{ + mtcmos_audio_power_on(); + + /* regulator for codecs */ + switch (board_id()) { + case 0: + /* vgp1 set to 1.22V */ + mt6391_configure_ldo(LDO_VCAMD, LDO_1P22); + /* vgp4 set to 1.8V */ + mt6391_configure_ldo(LDO_VGP4, LDO_1P8); + break; + default: + /* board from Rev1 */ + /* vgp1 set to 1.8V */ + mt6391_configure_ldo(LDO_VCAMD, LDO_1P8); + /* delay 1ms for realtek's power sequence request */ + mdelay(1); + /* vcama set to 1.8V */ + mt6391_configure_ldo(LDO_VCAMA, LDO_1P8); + break; + } + + /* reset ALC5676 */ + gpio_output(PAD_LCM_RST, 1); + + /* SoC I2S */ + gpio_set_mode(PAD_I2S0_LRCK, PAD_I2S0_LRCK_FUNC_I2S1_WS); + gpio_set_mode(PAD_I2S0_BCK, PAD_I2S0_BCK_FUNC_I2S1_BCK); + gpio_set_mode(PAD_I2S0_MCK, PAD_I2S0_MCK_FUNC_I2S1_MCK); + gpio_set_mode(PAD_I2S0_DATA0, PAD_I2S0_DATA0_FUNC_I2S1_DO_1); + gpio_set_mode(PAD_I2S0_DATA1, PAD_I2S0_DATA1_FUNC_I2S2_DI_2); + + /* codec ext MCLK ON */ + mt6391_gpio_output(MT6391_KP_COL4, 1); + mt6391_gpio_output(MT6391_KP_COL5, 1); + + /* set I2S clock to 48KHz */ + mt_pll_set_aud_div(48 * KHz); +} + static void mainboard_init(device_t dev) { + configure_audio(); } static void mainboard_enable(device_t dev) |