Commit ad01a984 authored by Tom Lendacky's avatar Tom Lendacky Committed by Herbert Xu

crypto: ccp - Support register differences between PSP devices

In preparation for adding a new PSP device ID that uses different register
offsets, add support to the PSP version data for register offset values.
And then update the code to use these new register offset values.
Signed-off-by: default avatarTom Lendacky <thomas.lendacky@amd.com>
Acked-by: default avatarGary R Hook <gary.hook@amd.com>
Reviewed-by: default avatarBrijesh Singh <brijesh.singh@amd.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 03af9124
...@@ -62,14 +62,14 @@ static irqreturn_t psp_irq_handler(int irq, void *data) ...@@ -62,14 +62,14 @@ static irqreturn_t psp_irq_handler(int irq, void *data)
int reg; int reg;
/* Read the interrupt status: */ /* Read the interrupt status: */
status = ioread32(psp->io_regs + PSP_P2CMSG_INTSTS); status = ioread32(psp->io_regs + psp->vdata->intsts_reg);
/* Check if it is command completion: */ /* Check if it is command completion: */
if (!(status & PSP_CMD_COMPLETE)) if (!(status & PSP_CMD_COMPLETE))
goto done; goto done;
/* Check if it is SEV command completion: */ /* Check if it is SEV command completion: */
reg = ioread32(psp->io_regs + PSP_CMDRESP); reg = ioread32(psp->io_regs + psp->vdata->cmdresp_reg);
if (reg & PSP_CMDRESP_RESP) { if (reg & PSP_CMDRESP_RESP) {
psp->sev_int_rcvd = 1; psp->sev_int_rcvd = 1;
wake_up(&psp->sev_int_queue); wake_up(&psp->sev_int_queue);
...@@ -77,7 +77,7 @@ static irqreturn_t psp_irq_handler(int irq, void *data) ...@@ -77,7 +77,7 @@ static irqreturn_t psp_irq_handler(int irq, void *data)
done: done:
/* Clear the interrupt status by writing the same value we read. */ /* Clear the interrupt status by writing the same value we read. */
iowrite32(status, psp->io_regs + PSP_P2CMSG_INTSTS); iowrite32(status, psp->io_regs + psp->vdata->intsts_reg);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
...@@ -85,7 +85,7 @@ static irqreturn_t psp_irq_handler(int irq, void *data) ...@@ -85,7 +85,7 @@ static irqreturn_t psp_irq_handler(int irq, void *data)
static void sev_wait_cmd_ioc(struct psp_device *psp, unsigned int *reg) static void sev_wait_cmd_ioc(struct psp_device *psp, unsigned int *reg)
{ {
wait_event(psp->sev_int_queue, psp->sev_int_rcvd); wait_event(psp->sev_int_queue, psp->sev_int_rcvd);
*reg = ioread32(psp->io_regs + PSP_CMDRESP); *reg = ioread32(psp->io_regs + psp->vdata->cmdresp_reg);
} }
static int sev_cmd_buffer_len(int cmd) static int sev_cmd_buffer_len(int cmd)
...@@ -143,15 +143,15 @@ static int __sev_do_cmd_locked(int cmd, void *data, int *psp_ret) ...@@ -143,15 +143,15 @@ static int __sev_do_cmd_locked(int cmd, void *data, int *psp_ret)
print_hex_dump_debug("(in): ", DUMP_PREFIX_OFFSET, 16, 2, data, print_hex_dump_debug("(in): ", DUMP_PREFIX_OFFSET, 16, 2, data,
sev_cmd_buffer_len(cmd), false); sev_cmd_buffer_len(cmd), false);
iowrite32(phys_lsb, psp->io_regs + PSP_CMDBUFF_ADDR_LO); iowrite32(phys_lsb, psp->io_regs + psp->vdata->cmdbuff_addr_lo_reg);
iowrite32(phys_msb, psp->io_regs + PSP_CMDBUFF_ADDR_HI); iowrite32(phys_msb, psp->io_regs + psp->vdata->cmdbuff_addr_hi_reg);
psp->sev_int_rcvd = 0; psp->sev_int_rcvd = 0;
reg = cmd; reg = cmd;
reg <<= PSP_CMDRESP_CMD_SHIFT; reg <<= PSP_CMDRESP_CMD_SHIFT;
reg |= PSP_CMDRESP_IOC; reg |= PSP_CMDRESP_IOC;
iowrite32(reg, psp->io_regs + PSP_CMDRESP); iowrite32(reg, psp->io_regs + psp->vdata->cmdresp_reg);
/* wait for command completion */ /* wait for command completion */
sev_wait_cmd_ioc(psp, &reg); sev_wait_cmd_ioc(psp, &reg);
...@@ -789,7 +789,7 @@ static int sev_misc_init(struct psp_device *psp) ...@@ -789,7 +789,7 @@ static int sev_misc_init(struct psp_device *psp)
static int sev_init(struct psp_device *psp) static int sev_init(struct psp_device *psp)
{ {
/* Check if device supports SEV feature */ /* Check if device supports SEV feature */
if (!(ioread32(psp->io_regs + PSP_FEATURE_REG) & 1)) { if (!(ioread32(psp->io_regs + psp->vdata->feature_reg) & 1)) {
dev_dbg(psp->dev, "device does not support SEV\n"); dev_dbg(psp->dev, "device does not support SEV\n");
return 1; return 1;
} }
...@@ -817,11 +817,11 @@ int psp_dev_init(struct sp_device *sp) ...@@ -817,11 +817,11 @@ int psp_dev_init(struct sp_device *sp)
goto e_err; goto e_err;
} }
psp->io_regs = sp->io_map + psp->vdata->offset; psp->io_regs = sp->io_map;
/* Disable and clear interrupts until ready */ /* Disable and clear interrupts until ready */
iowrite32(0, psp->io_regs + PSP_P2CMSG_INTEN); iowrite32(0, psp->io_regs + psp->vdata->inten_reg);
iowrite32(-1, psp->io_regs + PSP_P2CMSG_INTSTS); iowrite32(-1, psp->io_regs + psp->vdata->intsts_reg);
/* Request an irq */ /* Request an irq */
ret = sp_request_psp_irq(psp->sp, psp_irq_handler, psp->name, psp); ret = sp_request_psp_irq(psp->sp, psp_irq_handler, psp->name, psp);
...@@ -838,7 +838,7 @@ int psp_dev_init(struct sp_device *sp) ...@@ -838,7 +838,7 @@ int psp_dev_init(struct sp_device *sp)
sp->set_psp_master_device(sp); sp->set_psp_master_device(sp);
/* Enable interrupt */ /* Enable interrupt */
iowrite32(-1, psp->io_regs + PSP_P2CMSG_INTEN); iowrite32(-1, psp->io_regs + psp->vdata->inten_reg);
dev_notice(dev, "psp enabled\n"); dev_notice(dev, "psp enabled\n");
......
...@@ -30,17 +30,8 @@ ...@@ -30,17 +30,8 @@
#include "sp-dev.h" #include "sp-dev.h"
#define PSP_C2PMSG(_num) ((_num) << 2)
#define PSP_CMDRESP PSP_C2PMSG(32)
#define PSP_CMDBUFF_ADDR_LO PSP_C2PMSG(56)
#define PSP_CMDBUFF_ADDR_HI PSP_C2PMSG(57)
#define PSP_FEATURE_REG PSP_C2PMSG(63)
#define PSP_CMD_COMPLETE BIT(1) #define PSP_CMD_COMPLETE BIT(1)
#define PSP_P2CMSG_INTEN 0x0110
#define PSP_P2CMSG_INTSTS 0x0114
#define PSP_CMDRESP_CMD_SHIFT 16 #define PSP_CMDRESP_CMD_SHIFT 16
#define PSP_CMDRESP_IOC BIT(0) #define PSP_CMDRESP_IOC BIT(0)
#define PSP_CMDRESP_RESP BIT(31) #define PSP_CMDRESP_RESP BIT(31)
......
...@@ -44,7 +44,12 @@ struct ccp_vdata { ...@@ -44,7 +44,12 @@ struct ccp_vdata {
}; };
struct psp_vdata { struct psp_vdata {
const unsigned int offset; const unsigned int cmdresp_reg;
const unsigned int cmdbuff_addr_lo_reg;
const unsigned int cmdbuff_addr_hi_reg;
const unsigned int feature_reg;
const unsigned int inten_reg;
const unsigned int intsts_reg;
}; };
/* Structure to hold SP device data */ /* Structure to hold SP device data */
......
...@@ -270,7 +270,12 @@ static int sp_pci_resume(struct pci_dev *pdev) ...@@ -270,7 +270,12 @@ static int sp_pci_resume(struct pci_dev *pdev)
#ifdef CONFIG_CRYPTO_DEV_SP_PSP #ifdef CONFIG_CRYPTO_DEV_SP_PSP
static const struct psp_vdata psp_entry = { static const struct psp_vdata psp_entry = {
.offset = 0x10500, .cmdresp_reg = 0x10580,
.cmdbuff_addr_lo_reg = 0x105e0,
.cmdbuff_addr_hi_reg = 0x105e4,
.feature_reg = 0x105fc,
.inten_reg = 0x10610,
.intsts_reg = 0x10614,
}; };
#endif #endif
......
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