diff options
Diffstat (limited to 'drivers/char/tpm/tpm-interface.c')
| -rw-r--r-- | drivers/char/tpm/tpm-interface.c | 16 | 
1 files changed, 14 insertions, 2 deletions
diff --git a/drivers/char/tpm/tpm-interface.c b/drivers/char/tpm/tpm-interface.c index 7e513b771832..586ca10b0d72 100644 --- a/drivers/char/tpm/tpm-interface.c +++ b/drivers/char/tpm/tpm-interface.c @@ -412,6 +412,8 @@ int tpm_pm_suspend(struct device *dev)  	}  suspended: +	chip->flags |= TPM_CHIP_FLAG_SUSPENDED; +  	if (rc)  		dev_err(dev, "Ignoring error %d while suspending\n", rc);  	return 0; @@ -429,6 +431,14 @@ int tpm_pm_resume(struct device *dev)  	if (chip == NULL)  		return -ENODEV; +	chip->flags &= ~TPM_CHIP_FLAG_SUSPENDED; + +	/* +	 * Guarantee that SUSPENDED is written last, so that hwrng does not +	 * activate before the chip has been fully resumed. +	 */ +	wmb(); +  	return 0;  }  EXPORT_SYMBOL_GPL(tpm_pm_resume); @@ -466,13 +476,15 @@ static int __init tpm_init(void)  {  	int rc; -	tpm_class = class_create(THIS_MODULE, "tpm"); +	tpm_class = class_create("tpm");  	if (IS_ERR(tpm_class)) {  		pr_err("couldn't create tpm class\n");  		return PTR_ERR(tpm_class);  	} -	tpmrm_class = class_create(THIS_MODULE, "tpmrm"); +	tpm_class->shutdown_pre = tpm_class_shutdown; + +	tpmrm_class = class_create("tpmrm");  	if (IS_ERR(tpmrm_class)) {  		pr_err("couldn't create tpmrm class\n");  		rc = PTR_ERR(tpmrm_class);  |