aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/crypto
diff options
context:
space:
mode:
authorTom Lendacky <thomas.lendacky@amd.com>2014-01-06 14:34:29 -0500
committerHerbert Xu <herbert@gondor.apana.org.au>2014-01-14 22:33:40 -0500
commitdb34cf9122319d6fed59bd3ba26fa099a8ece432 (patch)
treed161399362984611892d5f42cbe7f186547b9944 /drivers/crypto
parent82d1585b9a9d5106ec6a630696f3e2e532fc3cba (diff)
crypto: ccp - CCP device enabled/disabled changes
The CCP cannot be hot-plugged so it will either be there or it won't. Do not allow the driver to stay loaded if the CCP does not successfully initialize. Provide stub routines in the ccp.h file that return -ENODEV if the CCP has not been configured in the build. Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'drivers/crypto')
-rw-r--r--drivers/crypto/ccp/ccp-dev.c15
-rw-r--r--drivers/crypto/ccp/ccp-pci.c3
2 files changed, 17 insertions, 1 deletions
diff --git a/drivers/crypto/ccp/ccp-dev.c b/drivers/crypto/ccp/ccp-dev.c
index b2038a7e91e1..c3bc21264600 100644
--- a/drivers/crypto/ccp/ccp-dev.c
+++ b/drivers/crypto/ccp/ccp-dev.c
@@ -552,6 +552,7 @@ static const struct x86_cpu_id ccp_support[] = {
552static int __init ccp_mod_init(void) 552static int __init ccp_mod_init(void)
553{ 553{
554 struct cpuinfo_x86 *cpuinfo = &boot_cpu_data; 554 struct cpuinfo_x86 *cpuinfo = &boot_cpu_data;
555 int ret;
555 556
556 if (!x86_match_cpu(ccp_support)) 557 if (!x86_match_cpu(ccp_support))
557 return -ENODEV; 558 return -ENODEV;
@@ -560,7 +561,19 @@ static int __init ccp_mod_init(void)
560 case 22: 561 case 22:
561 if ((cpuinfo->x86_model < 48) || (cpuinfo->x86_model > 63)) 562 if ((cpuinfo->x86_model < 48) || (cpuinfo->x86_model > 63))
562 return -ENODEV; 563 return -ENODEV;
563 return ccp_pci_init(); 564
565 ret = ccp_pci_init();
566 if (ret)
567 return ret;
568
569 /* Don't leave the driver loaded if init failed */
570 if (!ccp_get_device()) {
571 ccp_pci_exit();
572 return -ENODEV;
573 }
574
575 return 0;
576
564 break; 577 break;
565 } 578 }
566 579
diff --git a/drivers/crypto/ccp/ccp-pci.c b/drivers/crypto/ccp/ccp-pci.c
index f08c16d370cd..93319f9db753 100644
--- a/drivers/crypto/ccp/ccp-pci.c
+++ b/drivers/crypto/ccp/ccp-pci.c
@@ -267,6 +267,9 @@ static void ccp_pci_remove(struct pci_dev *pdev)
267 struct device *dev = &pdev->dev; 267 struct device *dev = &pdev->dev;
268 struct ccp_device *ccp = dev_get_drvdata(dev); 268 struct ccp_device *ccp = dev_get_drvdata(dev);
269 269
270 if (!ccp)
271 return;
272
270 ccp_destroy(ccp); 273 ccp_destroy(ccp);
271 274
272 pci_iounmap(pdev, ccp->io_map); 275 pci_iounmap(pdev, ccp->io_map);