Commit 03f008c5 authored by Hook, Gary's avatar Hook, Gary Committed by Herbert Xu

crypto: ccp - Verify access to device registers before initializing

Check early whether device registers can be accessed. Some BIOSes have
a broken security policy that prevents access to the device registers,
and return values from ioread() can be misinterpreted. If a read of
a feature register returns a -1, we may not be able to access
any device register, so report the problem and suggestion, and return.

For the PSP, the feature register is checked. For the CCP, the queue
register is checked.
Signed-off-by: default avatarGary R Hook <gary.hook@amd.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 0d3c6781
...@@ -789,6 +789,18 @@ static int ccp5_init(struct ccp_device *ccp) ...@@ -789,6 +789,18 @@ static int ccp5_init(struct ccp_device *ccp)
/* Find available queues */ /* Find available queues */
qmr = ioread32(ccp->io_regs + Q_MASK_REG); qmr = ioread32(ccp->io_regs + Q_MASK_REG);
/*
* Check for a access to the registers. If this read returns
* 0xffffffff, it's likely that the system is running a broken
* BIOS which disallows access to the device. Stop here and fail
* the initialization (but not the load, as the PSP could get
* properly initialized).
*/
if (qmr == 0xffffffff) {
dev_notice(dev, "ccp: unable to access the device: you might be running a broken BIOS.\n");
return 1;
}
for (i = 0; (i < MAX_HW_QUEUES) && (ccp->cmd_q_count < ccp->max_q_count); i++) { for (i = 0; (i < MAX_HW_QUEUES) && (ccp->cmd_q_count < ccp->max_q_count); i++) {
if (!(qmr & (1 << i))) if (!(qmr & (1 << i)))
continue; continue;
......
...@@ -929,8 +929,22 @@ static int sev_misc_init(struct psp_device *psp) ...@@ -929,8 +929,22 @@ static int sev_misc_init(struct psp_device *psp)
static int psp_check_sev_support(struct psp_device *psp) static int psp_check_sev_support(struct psp_device *psp)
{ {
/* Check if device supports SEV feature */ unsigned int val = ioread32(psp->io_regs + psp->vdata->feature_reg);
if (!(ioread32(psp->io_regs + psp->vdata->feature_reg) & 1)) {
/*
* Check for a access to the registers. If this read returns
* 0xffffffff, it's likely that the system is running a broken
* BIOS which disallows access to the device. Stop here and
* fail the PSP initialization (but not the load, as the CCP
* could get properly initialized).
*/
if (val == 0xffffffff) {
dev_notice(psp->dev, "psp: unable to access the device: you might be running a broken BIOS.\n");
return -ENODEV;
}
if (!(val & 1)) {
/* Device does not support the SEV feature */
dev_dbg(psp->dev, "psp does not support SEV\n"); dev_dbg(psp->dev, "psp does not support SEV\n");
return -ENODEV; return -ENODEV;
} }
......
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