x86/acpi_device: Add support for GPIO output polarity
Instead of hard-coding the polarity of the GPIO to active high/low, accept it as a parameter in devicetree. This polarity can then be used while calling into acpi_dp_add_gpio to determine the active low status correctly. BUG=chrome-os-partner:55988 BRANCH=None TEST=Verified that correct polarity is set for reset-gpio on reef. Change-Id: I4aba4bb8bd61799962deaaa11307c0c5be112919 Signed-off-by: Furquan Shaikh <furquan@chromium.org> Reviewed-on: https://review.coreboot.org/16877 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins)
This commit is contained in:
parent
35c01bc4e0
commit
028200f75f
5 changed files with 21 additions and 5 deletions
|
@ -110,6 +110,11 @@ enum acpi_gpio_io_restrict {
|
||||||
ACPI_GPIO_IO_RESTRICT_PRESERVE
|
ACPI_GPIO_IO_RESTRICT_PRESERVE
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum acpi_gpio_polarity {
|
||||||
|
ACPI_GPIO_ACTIVE_HIGH = 0,
|
||||||
|
ACPI_GPIO_ACTIVE_LOW = 1,
|
||||||
|
};
|
||||||
|
|
||||||
#define ACPI_GPIO_REVISION_ID 1
|
#define ACPI_GPIO_REVISION_ID 1
|
||||||
#define ACPI_GPIO_MAX_PINS 8
|
#define ACPI_GPIO_MAX_PINS 8
|
||||||
|
|
||||||
|
@ -129,13 +134,23 @@ struct acpi_gpio {
|
||||||
uint16_t output_drive_strength; /* 1/100 mA */
|
uint16_t output_drive_strength; /* 1/100 mA */
|
||||||
int io_shared;
|
int io_shared;
|
||||||
enum acpi_gpio_io_restrict io_restrict;
|
enum acpi_gpio_io_restrict io_restrict;
|
||||||
|
enum acpi_gpio_polarity polarity;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Basic output GPIO with default pull settings */
|
/* Basic output GPIO with default pull settings */
|
||||||
#define ACPI_GPIO_OUTPUT(gpio) { \
|
#define ACPI_GPIO_OUTPUT_ACTIVE_HIGH(gpio) { \
|
||||||
.type = ACPI_GPIO_TYPE_IO, \
|
.type = ACPI_GPIO_TYPE_IO, \
|
||||||
.pull = ACPI_GPIO_PULL_DEFAULT, \
|
.pull = ACPI_GPIO_PULL_DEFAULT, \
|
||||||
.io_restrict = ACPI_GPIO_IO_RESTRICT_OUTPUT, \
|
.io_restrict = ACPI_GPIO_IO_RESTRICT_OUTPUT, \
|
||||||
|
.polarity = ACPI_GPIO_ACTIVE_HIGH, \
|
||||||
|
.pin_count = 1, \
|
||||||
|
.pins = { (gpio) } }
|
||||||
|
|
||||||
|
#define ACPI_GPIO_OUTPUT_ACTIVE_LOW(gpio) { \
|
||||||
|
.type = ACPI_GPIO_TYPE_IO, \
|
||||||
|
.pull = ACPI_GPIO_PULL_DEFAULT, \
|
||||||
|
.io_restrict = ACPI_GPIO_IO_RESTRICT_OUTPUT, \
|
||||||
|
.polarity = ACPI_GPIO_ACTIVE_LOW, \
|
||||||
.pin_count = 1, \
|
.pin_count = 1, \
|
||||||
.pins = { (gpio) } }
|
.pins = { (gpio) } }
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,8 @@ static void max98357a_fill_ssdt(struct device *dev)
|
||||||
/* This points to the first pin in the first gpio entry in _CRS */
|
/* This points to the first pin in the first gpio entry in _CRS */
|
||||||
path = acpi_device_path(dev);
|
path = acpi_device_path(dev);
|
||||||
dp = acpi_dp_new_table("_DSD");
|
dp = acpi_dp_new_table("_DSD");
|
||||||
acpi_dp_add_gpio(dp, "sdmode-gpio", path, 0, 0, 0);
|
acpi_dp_add_gpio(dp, "sdmode-gpio", path, 0, 0,
|
||||||
|
config->sdmode_gpio.polarity);
|
||||||
acpi_dp_add_integer(dp, "sdmode-delay", config->sdmode_delay);
|
acpi_dp_add_integer(dp, "sdmode-delay", config->sdmode_delay);
|
||||||
acpi_dp_write(dp);
|
acpi_dp_write(dp);
|
||||||
|
|
||||||
|
|
|
@ -279,7 +279,7 @@ chip soc/intel/skylake
|
||||||
device pci 1f.2 on end # Power Management Controller
|
device pci 1f.2 on end # Power Management Controller
|
||||||
device pci 1f.3 on
|
device pci 1f.3 on
|
||||||
chip drivers/generic/max98357a
|
chip drivers/generic/max98357a
|
||||||
register "sdmode_gpio" = "ACPI_GPIO_OUTPUT(GPP_B2)"
|
register "sdmode_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_B2)"
|
||||||
device generic 0 on end
|
device generic 0 on end
|
||||||
end
|
end
|
||||||
end # Intel HDA
|
end # Intel HDA
|
||||||
|
|
|
@ -84,7 +84,7 @@ chip soc/intel/apollolake
|
||||||
device pci 0d.3 on end # - Shared SRAM
|
device pci 0d.3 on end # - Shared SRAM
|
||||||
device pci 0e.0 on # - Audio
|
device pci 0e.0 on # - Audio
|
||||||
chip drivers/generic/max98357a
|
chip drivers/generic/max98357a
|
||||||
register "sdmode_gpio" = "ACPI_GPIO_OUTPUT(GPIO_76)"
|
register "sdmode_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPIO_76)"
|
||||||
device generic 0 on end
|
device generic 0 on end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -303,7 +303,7 @@ chip soc/intel/skylake
|
||||||
device pci 1f.2 on end # Power Management Controller
|
device pci 1f.2 on end # Power Management Controller
|
||||||
device pci 1f.3 on
|
device pci 1f.3 on
|
||||||
chip drivers/generic/max98357a
|
chip drivers/generic/max98357a
|
||||||
register "sdmode_gpio" = "ACPI_GPIO_OUTPUT(GPP_E3)"
|
register "sdmode_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_E3)"
|
||||||
register "device_present_gpio" = "GPP_E3"
|
register "device_present_gpio" = "GPP_E3"
|
||||||
register "device_present_gpio_invert" = "1"
|
register "device_present_gpio_invert" = "1"
|
||||||
device generic 0 on end
|
device generic 0 on end
|
||||||
|
|
Loading…
Reference in a new issue