Commit 676b7c5e authored by David Xu's avatar David Xu Committed by Hans de Goede

platform/x86: serial-multi-instantiate: Auto detect IRQ resource for CSC3551

The current code assumes that the CSC3551(multiple cs35l41) always have
its interrupt pin connected to GPIO thus the IRQ can be acquired with
acpi_dev_gpio_irq_get. However on some newer laptop models this is no
longer the case as they have the CSC3551's interrupt pin connected to
APIC. This causes smi_i2c_probe to fail on these machines.

To support these machines, a new macro IRQ_RESOURCE_AUTO was introduced
for cs35l41 smi_node, and smi_get_irq function was modified so it tries
to get GPIO irq resource first and if failed, tries to get
APIC irq resource for cs35l41.

This patch affects only the cs35l41's probing and brings no negative
influence on machines that indeed have the cs35l41's interrupt pin
connected to GPIO.
Signed-off-by: default avatarDavid Xu <xuwd1@hotmail.com>
Link: https://lore.kernel.org/r/SY4P282MB18350CD8288687B87FFD2243E037A@SY4P282MB1835.AUSP282.PROD.OUTLOOK.COMReviewed-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
parent f2ae7254
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#define IRQ_RESOURCE_NONE 0 #define IRQ_RESOURCE_NONE 0
#define IRQ_RESOURCE_GPIO 1 #define IRQ_RESOURCE_GPIO 1
#define IRQ_RESOURCE_APIC 2 #define IRQ_RESOURCE_APIC 2
#define IRQ_RESOURCE_AUTO 3
enum smi_bus_type { enum smi_bus_type {
SMI_I2C, SMI_I2C,
...@@ -52,6 +53,18 @@ static int smi_get_irq(struct platform_device *pdev, struct acpi_device *adev, ...@@ -52,6 +53,18 @@ static int smi_get_irq(struct platform_device *pdev, struct acpi_device *adev,
int ret; int ret;
switch (inst->flags & IRQ_RESOURCE_TYPE) { switch (inst->flags & IRQ_RESOURCE_TYPE) {
case IRQ_RESOURCE_AUTO:
ret = acpi_dev_gpio_irq_get(adev, inst->irq_idx);
if (ret > 0) {
dev_dbg(&pdev->dev, "Using gpio irq\n");
break;
}
ret = platform_get_irq(pdev, inst->irq_idx);
if (ret > 0) {
dev_dbg(&pdev->dev, "Using platform irq\n");
break;
}
break;
case IRQ_RESOURCE_GPIO: case IRQ_RESOURCE_GPIO:
ret = acpi_dev_gpio_irq_get(adev, inst->irq_idx); ret = acpi_dev_gpio_irq_get(adev, inst->irq_idx);
break; break;
...@@ -307,10 +320,10 @@ static const struct smi_node int3515_data = { ...@@ -307,10 +320,10 @@ static const struct smi_node int3515_data = {
static const struct smi_node cs35l41_hda = { static const struct smi_node cs35l41_hda = {
.instances = { .instances = {
{ "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, { "cs35l41-hda", IRQ_RESOURCE_AUTO, 0 },
{ "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, { "cs35l41-hda", IRQ_RESOURCE_AUTO, 0 },
{ "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, { "cs35l41-hda", IRQ_RESOURCE_AUTO, 0 },
{ "cs35l41-hda", IRQ_RESOURCE_GPIO, 0 }, { "cs35l41-hda", IRQ_RESOURCE_AUTO, 0 },
{} {}
}, },
.bus_type = SMI_AUTO_DETECT, .bus_type = SMI_AUTO_DETECT,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment