Commit 25745981 authored by Frederic Barrat's avatar Frederic Barrat Committed by Kamal Mostafa

cxl: Define process problem state area at attach time only

BugLink: http://bugs.launchpad.net/bugs/1588468

CXL kernel API was defining the process problem state area during
context initialization, making it possible to map the problem state
area before attaching the context. This won't work on a powerVM
guest. So force the logical behavior, like in userspace: attach first,
then map the problem state area.
Remove calls to cxl_assign_psn_space during init. The function is
already called on the attach paths.
Co-authored-by: default avatarChristophe Lombard <clombard@linux.vnet.ibm.com>
Signed-off-by: default avatarFrederic Barrat <fbarrat@linux.vnet.ibm.com>
Signed-off-by: default avatarChristophe Lombard <clombard@linux.vnet.ibm.com>
Reviewed-by: default avatarManoj Kumar <manoj@linux.vnet.ibm.com>
Acked-by: default avatarIan Munsie <imunsie@au1.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
(cherry picked from commit cca44c01)
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
Acked-by: default avatarStefan Bader <stefan.bader@canonical.com>
Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
parent c20742ae
...@@ -51,8 +51,6 @@ struct cxl_context *cxl_dev_context_init(struct pci_dev *dev) ...@@ -51,8 +51,6 @@ struct cxl_context *cxl_dev_context_init(struct pci_dev *dev)
if (rc) if (rc)
goto err_mapping; goto err_mapping;
cxl_assign_psn_space(ctx);
return ctx; return ctx;
err_mapping: err_mapping:
...@@ -207,7 +205,6 @@ EXPORT_SYMBOL_GPL(cxl_stop_context); ...@@ -207,7 +205,6 @@ EXPORT_SYMBOL_GPL(cxl_stop_context);
void cxl_set_master(struct cxl_context *ctx) void cxl_set_master(struct cxl_context *ctx)
{ {
ctx->master = true; ctx->master = true;
cxl_assign_psn_space(ctx);
} }
EXPORT_SYMBOL_GPL(cxl_set_master); EXPORT_SYMBOL_GPL(cxl_set_master);
...@@ -325,15 +322,11 @@ EXPORT_SYMBOL_GPL(cxl_start_work); ...@@ -325,15 +322,11 @@ EXPORT_SYMBOL_GPL(cxl_start_work);
void __iomem *cxl_psa_map(struct cxl_context *ctx) void __iomem *cxl_psa_map(struct cxl_context *ctx)
{ {
struct cxl_afu *afu = ctx->afu; if (ctx->status != STARTED)
int rc;
rc = cxl_afu_check_and_enable(afu);
if (rc)
return NULL; return NULL;
pr_devel("%s: psn_phys%llx size:%llx\n", pr_devel("%s: psn_phys%llx size:%llx\n",
__func__, afu->psn_phys, afu->adapter->ps_size); __func__, ctx->psn_phys, ctx->psn_size);
return ioremap(ctx->psn_phys, ctx->psn_size); return ioremap(ctx->psn_phys, ctx->psn_size);
} }
EXPORT_SYMBOL_GPL(cxl_psa_map); EXPORT_SYMBOL_GPL(cxl_psa_map);
......
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