1 // SPDX-License-Identifier: GPL-2.0
3 * Google Veyron (and derivatives) fragment for the max98090 audio
4 * codec and analog headphone jack.
6 * Copyright 2016 Google, Inc
11 compatible = "rockchip,rockchip-audio-max98090";
12 pinctrl-names = "default";
13 pinctrl-0 = <&mic_det>, <&hp_det>;
14 rockchip,model = "VEYRON-I2S";
15 rockchip,i2s-controller = <&i2s>;
16 rockchip,audio-codec = <&max98090>;
17 rockchip,hp-det-gpios = <&gpio6 RK_PA5 GPIO_ACTIVE_HIGH>;
18 rockchip,mic-det-gpios = <&gpio6 RK_PB3 GPIO_ACTIVE_LOW>;
19 rockchip,headset-codec = <&headsetcodec>;
20 rockchip,hdmi-codec = <&hdmi>;
25 max98090: max98090@10 {
26 compatible = "maxim,max98090";
28 interrupt-parent = <&gpio6>;
29 interrupts = <RK_PA7 IRQ_TYPE_EDGE_FALLING>;
31 clocks = <&cru SCLK_I2S0_OUT>;
32 pinctrl-names = "default";
33 pinctrl-0 = <&int_codec>;
38 headsetcodec: ts3a227e@3b {
39 compatible = "ti,ts3a227e";
41 interrupt-parent = <&gpio0>;
42 interrupts = <RK_PA3 IRQ_TYPE_LEVEL_LOW>;
43 pinctrl-names = "default";
44 pinctrl-0 = <&ts3a227e_int_l>;
45 ti,micbias = <7>; /* MICBIAS = 2.8V */
54 audio-supply = <&vcc18_codec>;
58 vcc10-supply = <&vcc33_sys>;
61 vcc18_codec: LDO_REG6 {
62 regulator-name = "vcc18_codec";
65 regulator-min-microvolt = <1800000>;
66 regulator-max-microvolt = <1800000>;
68 regulator-off-in-suspend;
77 rockchip,pins = <6 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>;
81 * HACK: We're going to _pull down_ this _active low_ interrupt
82 * so that it never fires. We don't need this interrupt because
83 * we've got a ts3a227e chip but the driver requires it.
85 int_codec: int-codec {
86 rockchip,pins = <6 RK_PA7 RK_FUNC_GPIO &pcfg_pull_down>;
90 rockchip,pins = <6 RK_PB3 RK_FUNC_GPIO &pcfg_pull_up>;
95 ts3a227e_int_l: ts3a227e-int-l {
96 rockchip,pins = <0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>;