Commit 62a59302 authored by Alexander Shishkin's avatar Alexander Shishkin Committed by Greg Kroah-Hartman

intel_th: Communicate IRQ via resource

Currently, the IRQ is passed between the glue layers and the core as a
separate argument, while the MMIO resources are passed as resources.
This also limits the number of IRQs thus used to one, while the current
versions of Intel TH use a different MSI vector for each interrupt
triggering event, of which there are 7.

Change this to pass IRQ in the resources array.
Signed-off-by: default avatarAlexander Shishkin <alexander.shishkin@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent fc027f4c
...@@ -40,20 +40,18 @@ static int intel_th_acpi_probe(struct platform_device *pdev) ...@@ -40,20 +40,18 @@ static int intel_th_acpi_probe(struct platform_device *pdev)
struct resource resource[TH_MMIO_END]; struct resource resource[TH_MMIO_END];
const struct acpi_device_id *id; const struct acpi_device_id *id;
struct intel_th *th; struct intel_th *th;
int i, r, irq = -1; int i, r;
id = acpi_match_device(intel_th_acpi_ids, &pdev->dev); id = acpi_match_device(intel_th_acpi_ids, &pdev->dev);
if (!id) if (!id)
return -ENODEV; return -ENODEV;
for (i = 0, r = 0; i < pdev->num_resources && r < TH_MMIO_END; i++) for (i = 0, r = 0; i < pdev->num_resources && r < TH_MMIO_END; i++)
if (pdev->resource[i].flags & IORESOURCE_IRQ) if (pdev->resource[i].flags &
irq = pdev->resource[i].start; (IORESOURCE_IRQ | IORESOURCE_MEM))
else if (pdev->resource[i].flags & IORESOURCE_MEM)
resource[r++] = pdev->resource[i]; resource[r++] = pdev->resource[i];
th = intel_th_alloc(&pdev->dev, (void *)id->driver_data, resource, r, th = intel_th_alloc(&pdev->dev, (void *)id->driver_data, resource, r);
irq);
if (IS_ERR(th)) if (IS_ERR(th))
return PTR_ERR(th); return PTR_ERR(th);
......
...@@ -834,10 +834,10 @@ static const struct file_operations intel_th_output_fops = { ...@@ -834,10 +834,10 @@ static const struct file_operations intel_th_output_fops = {
*/ */
struct intel_th * struct intel_th *
intel_th_alloc(struct device *dev, struct intel_th_drvdata *drvdata, intel_th_alloc(struct device *dev, struct intel_th_drvdata *drvdata,
struct resource *devres, unsigned int ndevres, int irq) struct resource *devres, unsigned int ndevres)
{ {
int err, r, nr_mmios = 0;
struct intel_th *th; struct intel_th *th;
int err, r;
th = kzalloc(sizeof(*th), GFP_KERNEL); th = kzalloc(sizeof(*th), GFP_KERNEL);
if (!th) if (!th)
...@@ -855,13 +855,26 @@ intel_th_alloc(struct device *dev, struct intel_th_drvdata *drvdata, ...@@ -855,13 +855,26 @@ intel_th_alloc(struct device *dev, struct intel_th_drvdata *drvdata,
err = th->major; err = th->major;
goto err_ida; goto err_ida;
} }
th->irq = -1;
th->dev = dev; th->dev = dev;
th->drvdata = drvdata; th->drvdata = drvdata;
for (r = 0; r < ndevres; r++) for (r = 0; r < ndevres; r++)
th->resource[r] = devres[r]; switch (devres[r].flags & IORESOURCE_TYPE_BITS) {
th->num_resources = ndevres; case IORESOURCE_MEM:
th->irq = irq; th->resource[nr_mmios++] = devres[r];
break;
case IORESOURCE_IRQ:
if (th->irq == -1)
th->irq = devres[r].start;
break;
default:
dev_warn(dev, "Unknown resource type %lx\n",
devres[r].flags);
break;
}
th->num_resources = nr_mmios;
dev_set_drvdata(dev, th); dev_set_drvdata(dev, th);
......
...@@ -213,7 +213,7 @@ static inline struct intel_th *to_intel_th(struct intel_th_device *thdev) ...@@ -213,7 +213,7 @@ static inline struct intel_th *to_intel_th(struct intel_th_device *thdev)
struct intel_th * struct intel_th *
intel_th_alloc(struct device *dev, struct intel_th_drvdata *drvdata, intel_th_alloc(struct device *dev, struct intel_th_drvdata *drvdata,
struct resource *devres, unsigned int ndevres, int irq); struct resource *devres, unsigned int ndevres);
void intel_th_free(struct intel_th *th); void intel_th_free(struct intel_th *th);
int intel_th_driver_register(struct intel_th_driver *thdrv); int intel_th_driver_register(struct intel_th_driver *thdrv);
......
...@@ -72,7 +72,7 @@ static int intel_th_pci_probe(struct pci_dev *pdev, ...@@ -72,7 +72,7 @@ static int intel_th_pci_probe(struct pci_dev *pdev,
const struct pci_device_id *id) const struct pci_device_id *id)
{ {
struct intel_th_drvdata *drvdata = (void *)id->driver_data; struct intel_th_drvdata *drvdata = (void *)id->driver_data;
struct resource resource[TH_MMIO_END] = { struct resource resource[TH_MMIO_END + 1] = {
[TH_MMIO_CONFIG] = pdev->resource[TH_PCI_CONFIG_BAR], [TH_MMIO_CONFIG] = pdev->resource[TH_PCI_CONFIG_BAR],
[TH_MMIO_SW] = pdev->resource[TH_PCI_STH_SW_BAR], [TH_MMIO_SW] = pdev->resource[TH_PCI_STH_SW_BAR],
}; };
...@@ -92,7 +92,12 @@ static int intel_th_pci_probe(struct pci_dev *pdev, ...@@ -92,7 +92,12 @@ static int intel_th_pci_probe(struct pci_dev *pdev,
r++; r++;
} }
th = intel_th_alloc(&pdev->dev, drvdata, resource, r, pdev->irq); if (pdev->irq > 0) {
resource[r].flags = IORESOURCE_IRQ;
resource[r++].start = pdev->irq;
}
th = intel_th_alloc(&pdev->dev, drvdata, resource, r);
if (IS_ERR(th)) if (IS_ERR(th))
return PTR_ERR(th); return PTR_ERR(th);
......
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