tpm/tpm_crb: open code the crb_init into acpi_add
authorWinkler, Tomas <tomas.winkler@intel.com>
Mon, 12 Sep 2016 13:04:20 +0000 (16:04 +0300)
committerJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
Fri, 16 Sep 2016 12:47:52 +0000 (15:47 +0300)
This is preparation step for implementing tpm crb
runtime pm. We need to have tpm chip allocated
and populated before we access the runtime handlers.

Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Tested-by: Jarkko Sakkinen <jarkko.sakkinn@linux.intel.com>
drivers/char/tpm/tpm_crb.c

index 2d1669c..d385e63 100644 (file)
@@ -265,21 +265,6 @@ static const struct tpm_class_ops tpm_crb = {
        .req_complete_val = CRB_DRV_STS_COMPLETE,
 };
 
-static int crb_init(struct acpi_device *device, struct crb_priv *priv)
-{
-       struct tpm_chip *chip;
-
-       chip = tpmm_chip_alloc(&device->dev, &tpm_crb);
-       if (IS_ERR(chip))
-               return PTR_ERR(chip);
-
-       dev_set_drvdata(&chip->dev, priv);
-       chip->acpi_dev_handle = device->handle;
-       chip->flags = TPM_CHIP_FLAG_TPM2;
-
-       return tpm_chip_register(chip);
-}
-
 static int crb_check_resource(struct acpi_resource *ares, void *data)
 {
        struct resource *io_res = data;
@@ -401,6 +386,7 @@ static int crb_acpi_add(struct acpi_device *device)
 {
        struct acpi_table_tpm2 *buf;
        struct crb_priv *priv;
+       struct tpm_chip *chip;
        struct device *dev = &device->dev;
        acpi_status status;
        u32 sm;
@@ -438,11 +424,19 @@ static int crb_acpi_add(struct acpi_device *device)
        if (rc)
                return rc;
 
+       chip = tpmm_chip_alloc(dev, &tpm_crb);
+       if (IS_ERR(chip))
+               return PTR_ERR(chip);
+
+       dev_set_drvdata(&chip->dev, priv);
+       chip->acpi_dev_handle = device->handle;
+       chip->flags = TPM_CHIP_FLAG_TPM2;
+
        rc  = crb_cmd_ready(dev, priv);
        if (rc)
                return rc;
 
-       rc = crb_init(device, priv);
+       rc = tpm_chip_register(chip);
        if (rc)
                crb_go_idle(dev, priv);