Commit 67a3c196 authored by Jason Gunthorpe's avatar Jason Gunthorpe Committed by Tim Gardner

tpm_tis: Use devm_ioremap_resource

BugLink: http://bugs.launchpad.net/bugs/1398274

This does a request_resource under the covers which means tis holds a
lock on the memory range it is using so other drivers cannot grab it.
When doing probing it is important to ensure that other drivers are
not using the same range before tis starts touching it.

To do this flow the actual struct resource from the device right
through to devm_ioremap_resource. This ensures all the proper resource
meta-data is carried down.
Signed-off-by: default avatarJason Gunthorpe <jgunthorpe@obsidianresearch.com>
Tested-by: default avatarWilck, Martin <martin.wilck@ts.fujitsu.com>
Tested-by: default avatarJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
Reviewed-by: default avatarJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
Acked-by: default avatarPeter Huewe <peterhuewe@gmx.de>
(cherry picked from commit 51dd43df)
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent 0f2ec6b0
...@@ -66,8 +66,7 @@ enum tis_defaults { ...@@ -66,8 +66,7 @@ enum tis_defaults {
}; };
struct tpm_info { struct tpm_info {
unsigned long start; struct resource res;
unsigned long len;
/* irq > 0 means: use irq $irq; /* irq > 0 means: use irq $irq;
* irq = 0 means: autoprobe for an irq; * irq = 0 means: autoprobe for an irq;
* irq = -1 means: no irq support * irq = -1 means: no irq support
...@@ -76,8 +75,11 @@ struct tpm_info { ...@@ -76,8 +75,11 @@ struct tpm_info {
}; };
static struct tpm_info tis_default_info = { static struct tpm_info tis_default_info = {
.start = TIS_MEM_BASE, .res = {
.len = TIS_MEM_LEN, .start = TIS_MEM_BASE,
.end = TIS_MEM_BASE + TIS_MEM_LEN - 1,
.flags = IORESOURCE_MEM,
},
.irq = 0, .irq = 0,
}; };
...@@ -691,9 +693,9 @@ static int tpm_tis_init(struct device *dev, struct tpm_info *tpm_info, ...@@ -691,9 +693,9 @@ static int tpm_tis_init(struct device *dev, struct tpm_info *tpm_info,
chip->acpi_dev_handle = acpi_dev_handle; chip->acpi_dev_handle = acpi_dev_handle;
#endif #endif
chip->vendor.iobase = devm_ioremap(dev, tpm_info->start, tpm_info->len); chip->vendor.iobase = devm_ioremap_resource(dev, &tpm_info->res);
if (!chip->vendor.iobase) if (IS_ERR(chip->vendor.iobase))
return -EIO; return PTR_ERR(chip->vendor.iobase);
/* Maximum timeouts */ /* Maximum timeouts */
chip->vendor.timeout_a = TIS_TIMEOUT_A_MAX; chip->vendor.timeout_a = TIS_TIMEOUT_A_MAX;
...@@ -874,9 +876,12 @@ static int tpm_tis_pnp_init(struct pnp_dev *pnp_dev, ...@@ -874,9 +876,12 @@ static int tpm_tis_pnp_init(struct pnp_dev *pnp_dev,
{ {
struct tpm_info tpm_info = {}; struct tpm_info tpm_info = {};
acpi_handle acpi_dev_handle = NULL; acpi_handle acpi_dev_handle = NULL;
struct resource *res;
tpm_info.start = pnp_mem_start(pnp_dev, 0); res = pnp_get_resource(pnp_dev, IORESOURCE_MEM, 0);
tpm_info.len = pnp_mem_len(pnp_dev, 0); if (!res)
return -ENODEV;
tpm_info.res = *res;
if (pnp_irq_valid(pnp_dev, 0)) if (pnp_irq_valid(pnp_dev, 0))
tpm_info.irq = pnp_irq(pnp_dev, 0); tpm_info.irq = pnp_irq(pnp_dev, 0);
...@@ -939,12 +944,10 @@ static int tpm_check_resource(struct acpi_resource *ares, void *data) ...@@ -939,12 +944,10 @@ static int tpm_check_resource(struct acpi_resource *ares, void *data)
struct tpm_info *tpm_info = (struct tpm_info *) data; struct tpm_info *tpm_info = (struct tpm_info *) data;
struct resource res; struct resource res;
if (acpi_dev_resource_interrupt(ares, 0, &res)) { if (acpi_dev_resource_interrupt(ares, 0, &res))
tpm_info->irq = res.start; tpm_info->irq = res.start;
} else if (acpi_dev_resource_memory(ares, &res)) { else if (acpi_dev_resource_memory(ares, &res))
tpm_info->start = res.start; tpm_info->res = res;
tpm_info->len = resource_size(&res);
}
return 1; return 1;
} }
...@@ -977,7 +980,7 @@ static int tpm_tis_acpi_init(struct acpi_device *acpi_dev) ...@@ -977,7 +980,7 @@ static int tpm_tis_acpi_init(struct acpi_device *acpi_dev)
acpi_dev_free_resource_list(&resources); acpi_dev_free_resource_list(&resources);
if (tpm_info.start == 0 && tpm_info.len == 0) { if (resource_type(&tpm_info.res) != IORESOURCE_MEM) {
dev_err(&acpi_dev->dev, dev_err(&acpi_dev->dev,
FW_BUG "TPM2 ACPI table does not define a memory resource\n"); FW_BUG "TPM2 ACPI table does not define a memory resource\n");
return -EINVAL; return -EINVAL;
......
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