google/poppy: Use rt5663 interrupt as GpioInt instead of PIRQ
The kernel driver for rt5663 expects to get an interrupt on both a rising and falling edge, and using a legacy interrupt doesn't provide that flexibility. Instead configure this pin as a GPIO and use the interrupt through the GPIO controller. This allows using GpioInt() with ActiveBoth setting and results in correct operation of the headset jack. This is a clone of Duncan's patch for eve at I6f181ec560fe9d34efc023ef6e78e33cb0b4c529 BUG=none BRANCH=none TEST=test on poppy that headset jack detect is read properly at boot, and that plugging in and removing both generate a single interrupt event in the driver. Change-Id: I4aaa4164cb277a98ab5d5f033632f5e16bfb779e Signed-off-by: Rizwan Qureshi <rizwan.qureshi@intel.com> Signed-off-by: Duncan Laurie <dlaurie@chromium.org> Reviewed-on: https://review.coreboot.org/18853 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
887e7936f8
commit
6a1503e9db
|
@ -234,7 +234,7 @@ chip soc/intel/skylake
|
||||||
register "hid" = ""10EC5663""
|
register "hid" = ""10EC5663""
|
||||||
register "name" = ""RT53""
|
register "name" = ""RT53""
|
||||||
register "desc" = ""Realtek RT5663""
|
register "desc" = ""Realtek RT5663""
|
||||||
register "irq" = "ACPI_IRQ_LEVEL_LOW(GPP_D9_IRQ)"
|
register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_D9)"
|
||||||
register "probed" = "1"
|
register "probed" = "1"
|
||||||
device i2c 13 on end
|
device i2c 13 on end
|
||||||
end
|
end
|
||||||
|
|
|
@ -129,8 +129,7 @@ static const struct pad_config gpio_table[] = {
|
||||||
NF1), /* ISH_SENSOR */
|
NF1), /* ISH_SENSOR */
|
||||||
/* ISH_I2C1_SDA */ PAD_CFG_NC(GPP_D7),
|
/* ISH_I2C1_SDA */ PAD_CFG_NC(GPP_D7),
|
||||||
/* ISH_I2C1_SCL */ PAD_CFG_NC(GPP_D8),
|
/* ISH_I2C1_SCL */ PAD_CFG_NC(GPP_D8),
|
||||||
/* ISH_SPI_CS# */ PAD_CFG_GPI_APIC(GPP_D9, NONE,
|
/* ISH_SPI_CS# */ PAD_CFG_GPI(GPP_D9, NONE, PLTRST), /* HP_IRQ_GPIO */
|
||||||
PLTRST), /* HP_IRQ_GPIO */
|
|
||||||
/* ISH_SPI_CLK */ PAD_CFG_GPO(GPP_D10, 1, DEEP), /* SPKR_RST_L */
|
/* ISH_SPI_CLK */ PAD_CFG_GPO(GPP_D10, 1, DEEP), /* SPKR_RST_L */
|
||||||
/* ISH_SPI_MISO */ PAD_CFG_GPI_APIC(GPP_D11, NONE,
|
/* ISH_SPI_MISO */ PAD_CFG_GPI_APIC(GPP_D11, NONE,
|
||||||
PLTRST), /* SPKR_INT_L */
|
PLTRST), /* SPKR_INT_L */
|
||||||
|
|
Loading…
Reference in New Issue