Message ID | 1497368465-13104-1-git-send-email-clombard@linux.vnet.ibm.com (mailing list archive) |
---|---|
State | Accepted |
Commit | 797625deaedd9a0621376817db2813244b3246e3 |
Headers | show |
Christophe Lombard <clombard@linux.vnet.ibm.com> writes: > A previous set of patches "cxl: Add support for Coherent Accelerator > Interface Architecture 2.0" has introduced a new support for the CAPI > cards. Which commit is that? cheers > These patches have been tested on Simulation environment and > quite a bit of them have been tested on real hardware. > > This patch brings new fixes after a series of tests carried out on > new equipment: > * Add POWER9 definition. > * Re-enable any masked interrupts when the AFU is not activated after > resetting the AFU. > * Remove the api cxl_is_psl8/9 which is no longer useful. > * Do not dump CAPI1 registers. > * Rewrite cxl_is_page_fault() function. > * Do not register slb callack on P9. > > Changelog[v3] > - Rebase to latest upstream. > - Update the patch's header. > - Add new test in cxl_is_page_fault(). > > Changelog[v2] > - Rebase to latest upstream. > - Update cxl_is_page_fault() to handle the checkout response status. > - Add comments. > > Signed-off-by: Christophe Lombard <clombard@linux.vnet.ibm.com> > --- > drivers/misc/cxl/context.c | 6 +++--- > drivers/misc/cxl/cxl.h | 18 +++++------------- > drivers/misc/cxl/fault.c | 23 +++++++++++++++-------- > drivers/misc/cxl/main.c | 17 +++++++++++++---- > drivers/misc/cxl/native.c | 29 +++++++++++++++++------------ > drivers/misc/cxl/pci.c | 11 ++++------- > 6 files changed, 57 insertions(+), 47 deletions(-) > > diff --git a/drivers/misc/cxl/context.c b/drivers/misc/cxl/context.c > index 4472ce1..8c32040 100644 > --- a/drivers/misc/cxl/context.c > +++ b/drivers/misc/cxl/context.c > @@ -45,7 +45,7 @@ int cxl_context_init(struct cxl_context *ctx, struct cxl_afu *afu, bool master) > mutex_init(&ctx->mapping_lock); > ctx->mapping = NULL; > > - if (cxl_is_psl8(afu)) { > + if (cxl_is_power8()) { > spin_lock_init(&ctx->sste_lock); > > /* > @@ -189,7 +189,7 @@ int cxl_context_iomap(struct cxl_context *ctx, struct vm_area_struct *vma) > if (start + len > ctx->afu->adapter->ps_size) > return -EINVAL; > > - if (cxl_is_psl9(ctx->afu)) { > + if (cxl_is_power9()) { > /* > * Make sure there is a valid problem state > * area space for this AFU. > @@ -324,7 +324,7 @@ static void reclaim_ctx(struct rcu_head *rcu) > { > struct cxl_context *ctx = container_of(rcu, struct cxl_context, rcu); > > - if (cxl_is_psl8(ctx->afu)) > + if (cxl_is_power8()) > free_page((u64)ctx->sstp); > if (ctx->ff_page) > __free_page(ctx->ff_page); > diff --git a/drivers/misc/cxl/cxl.h b/drivers/misc/cxl/cxl.h > index c8568ea..a03f8e7 100644 > --- a/drivers/misc/cxl/cxl.h > +++ b/drivers/misc/cxl/cxl.h > @@ -357,6 +357,7 @@ static const cxl_p2n_reg_t CXL_PSL_WED_An = {0x0A0}; > #define CXL_PSL9_DSISR_An_PF_RGP 0x0000000000000090ULL /* PTE not found (Radix Guest (parent)) 0b10010000 */ > #define CXL_PSL9_DSISR_An_PF_HRH 0x0000000000000094ULL /* PTE not found (HPT/Radix Host) 0b10010100 */ > #define CXL_PSL9_DSISR_An_PF_STEG 0x000000000000009CULL /* PTE not found (STEG VA) 0b10011100 */ > +#define CXL_PSL9_DSISR_An_URTCH 0x00000000000000B4ULL /* Unsupported Radix Tree Configuration 0b10110100 */ > > /****** CXL_PSL_TFC_An ******************************************************/ > #define CXL_PSL_TFC_An_A (1ull << (63-28)) /* Acknowledge non-translation fault */ > @@ -844,24 +845,15 @@ static inline bool cxl_is_power8(void) > > static inline bool cxl_is_power9(void) > { > - /* intermediate solution */ > - if (!cxl_is_power8() && > - (cpu_has_feature(CPU_FTRS_POWER9) || > - cpu_has_feature(CPU_FTR_POWER9_DD1))) > + if (pvr_version_is(PVR_POWER9)) > return true; > return false; > } > > -static inline bool cxl_is_psl8(struct cxl_afu *afu) > +static inline bool cxl_is_power9_dd1(void) > { > - if (afu->adapter->caia_major == 1) > - return true; > - return false; > -} > - > -static inline bool cxl_is_psl9(struct cxl_afu *afu) > -{ > - if (afu->adapter->caia_major == 2) > + if ((pvr_version_is(PVR_POWER9)) && > + cpu_has_feature(CPU_FTR_POWER9_DD1)) > return true; > return false; > } > diff --git a/drivers/misc/cxl/fault.c b/drivers/misc/cxl/fault.c > index 5344448..c79e39b 100644 > --- a/drivers/misc/cxl/fault.c > +++ b/drivers/misc/cxl/fault.c > @@ -187,7 +187,7 @@ static struct mm_struct *get_mem_context(struct cxl_context *ctx) > > static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) > { > - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DS)) > + if ((cxl_is_power8() && (dsisr & CXL_PSL_DSISR_An_DS))) > return true; > > return false; > @@ -195,16 +195,23 @@ static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) > > static bool cxl_is_page_fault(struct cxl_context *ctx, u64 dsisr) > { > - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DM)) > - return true; > + u64 crs; /* Translation Checkout Response Status */ > > - if ((cxl_is_psl9(ctx->afu)) && > - ((dsisr & CXL_PSL9_DSISR_An_CO_MASK) & > - (CXL_PSL9_DSISR_An_PF_SLR | CXL_PSL9_DSISR_An_PF_RGC | > - CXL_PSL9_DSISR_An_PF_RGP | CXL_PSL9_DSISR_An_PF_HRH | > - CXL_PSL9_DSISR_An_PF_STEG))) > + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_An_DM)) > return true; > > + if (cxl_is_power9()) { > + crs = (dsisr & CXL_PSL9_DSISR_An_CO_MASK); > + if ((crs == CXL_PSL9_DSISR_An_PF_SLR) || > + (crs == CXL_PSL9_DSISR_An_PF_RGC) || > + (crs == CXL_PSL9_DSISR_An_PF_RGP) || > + (crs == CXL_PSL9_DSISR_An_PF_HRH) || > + (crs == CXL_PSL9_DSISR_An_PF_STEG) || > + (crs == CXL_PSL9_DSISR_An_URTCH)) { > + return true; > + } > + } > + > return false; > } > > diff --git a/drivers/misc/cxl/main.c b/drivers/misc/cxl/main.c > index 1703655..c1ba0d4 100644 > --- a/drivers/misc/cxl/main.c > +++ b/drivers/misc/cxl/main.c > @@ -329,8 +329,15 @@ static int __init init_cxl(void) > > cxl_debugfs_init(); > > - if ((rc = register_cxl_calls(&cxl_calls))) > - goto err; > + /* > + * we don't register the callback on P9. slb callack is only > + * used for the PSL8 MMU and CX4. > + */ > + if (cxl_is_power8()) { > + rc = register_cxl_calls(&cxl_calls); > + if (rc) > + goto err; > + } > > if (cpu_has_feature(CPU_FTR_HVMODE)) { > cxl_ops = &cxl_native_ops; > @@ -347,7 +354,8 @@ static int __init init_cxl(void) > > return 0; > err1: > - unregister_cxl_calls(&cxl_calls); > + if (cxl_is_power8()) > + unregister_cxl_calls(&cxl_calls); > err: > cxl_debugfs_exit(); > cxl_file_exit(); > @@ -366,7 +374,8 @@ static void exit_cxl(void) > > cxl_debugfs_exit(); > cxl_file_exit(); > - unregister_cxl_calls(&cxl_calls); > + if (cxl_is_power8()) > + unregister_cxl_calls(&cxl_calls); > idr_destroy(&cxl_adapter_idr); > } > > diff --git a/drivers/misc/cxl/native.c b/drivers/misc/cxl/native.c > index 8d6ea97..2b2f889 100644 > --- a/drivers/misc/cxl/native.c > +++ b/drivers/misc/cxl/native.c > @@ -105,11 +105,16 @@ static int native_afu_reset(struct cxl_afu *afu) > CXL_AFU_Cntl_An_RS_MASK | CXL_AFU_Cntl_An_ES_MASK, > false); > > - /* Re-enable any masked interrupts */ > - serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); > - serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; > - cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); > - > + /* > + * Re-enable any masked interrupts when the AFU is not > + * activated to avoid side effects after attaching a process > + * in dedicated mode. > + */ > + if (afu->current_mode == 0) { > + serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); > + serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; > + cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); > + } > > return rc; > } > @@ -139,9 +144,9 @@ int cxl_psl_purge(struct cxl_afu *afu) > > pr_devel("PSL purge request\n"); > > - if (cxl_is_psl8(afu)) > + if (cxl_is_power8()) > trans_fault = CXL_PSL_DSISR_TRANS; > - if (cxl_is_psl9(afu)) > + if (cxl_is_power9()) > trans_fault = CXL_PSL9_DSISR_An_TF; > > if (!cxl_ops->link_ok(afu->adapter, afu)) { > @@ -603,7 +608,7 @@ static u64 calculate_sr(struct cxl_context *ctx) > if (!test_tsk_thread_flag(current, TIF_32BIT)) > sr |= CXL_PSL_SR_An_SF; > } > - if (cxl_is_psl9(ctx->afu)) { > + if (cxl_is_power9()) { > if (radix_enabled()) > sr |= CXL_PSL_SR_An_XLAT_ror; > else > @@ -1117,10 +1122,10 @@ static irqreturn_t native_handle_psl_slice_error(struct cxl_context *ctx, > > static bool cxl_is_translation_fault(struct cxl_afu *afu, u64 dsisr) > { > - if ((cxl_is_psl8(afu)) && (dsisr & CXL_PSL_DSISR_TRANS)) > + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_TRANS)) > return true; > > - if ((cxl_is_psl9(afu)) && (dsisr & CXL_PSL9_DSISR_An_TF)) > + if ((cxl_is_power9()) && (dsisr & CXL_PSL9_DSISR_An_TF)) > return true; > > return false; > @@ -1194,10 +1199,10 @@ static void native_irq_wait(struct cxl_context *ctx) > if (ph != ctx->pe) > return; > dsisr = cxl_p2n_read(ctx->afu, CXL_PSL_DSISR_An); > - if (cxl_is_psl8(ctx->afu) && > + if (cxl_is_power8() && > ((dsisr & CXL_PSL_DSISR_PENDING) == 0)) > return; > - if (cxl_is_psl9(ctx->afu) && > + if (cxl_is_power9() && > ((dsisr & CXL_PSL9_DSISR_PENDING) == 0)) > return; > /* > diff --git a/drivers/misc/cxl/pci.c b/drivers/misc/cxl/pci.c > index 6dc1ee5..1eb9859 100644 > --- a/drivers/misc/cxl/pci.c > +++ b/drivers/misc/cxl/pci.c > @@ -436,7 +436,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci > /* nMMU_ID Defaults to: b’000001001’*/ > xsl_dsnctl |= ((u64)0x09 << (63-28)); > > - if (cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)) { > + if (!(cxl_is_power9_dd1())) { > /* > * Used to identify CAPI packets which should be sorted into > * the Non-Blocking queues by the PHB. This field should match > @@ -491,7 +491,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci > cxl_p1_write(adapter, CXL_PSL9_APCDEDTYPE, 0x40000003FFFF0000ULL); > > /* Disable vc dd1 fix */ > - if ((cxl_is_power9() && cpu_has_feature(CPU_FTR_POWER9_DD1))) > + if (cxl_is_power9_dd1()) > cxl_p1_write(adapter, CXL_PSL9_GP_CT, 0x0400000000000001ULL); > > return 0; > @@ -1439,8 +1439,7 @@ int cxl_pci_reset(struct cxl *adapter) > * The adapter is about to be reset, so ignore errors. > * Not supported on P9 DD1 > */ > - if ((cxl_is_power8()) || > - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) > + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) > cxl_data_cache_flush(adapter); > > /* pcie_warm_reset requests a fundamental pci reset which includes a > @@ -1750,7 +1749,6 @@ static const struct cxl_service_layer_ops psl9_ops = { > .debugfs_add_adapter_regs = cxl_debugfs_add_adapter_regs_psl9, > .debugfs_add_afu_regs = cxl_debugfs_add_afu_regs_psl9, > .psl_irq_dump_registers = cxl_native_irq_dump_regs_psl9, > - .err_irq_dump_registers = cxl_native_err_irq_dump_regs, > .debugfs_stop_trace = cxl_stop_trace_psl9, > .write_timebase_ctrl = write_timebase_ctrl_psl9, > .timebase_read = timebase_read_psl9, > @@ -1889,8 +1887,7 @@ static void cxl_pci_remove_adapter(struct cxl *adapter) > * Flush adapter datacache as its about to be removed. > * Not supported on P9 DD1. > */ > - if ((cxl_is_power8()) || > - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) > + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) > cxl_data_cache_flush(adapter); > > cxl_deconfigure_adapter(adapter); > -- > 2.7.4
Le 14/06/2017 à 07:01, Michael Ellerman a écrit : > Christophe Lombard <clombard@linux.vnet.ibm.com> writes: > >> A previous set of patches "cxl: Add support for Coherent Accelerator >> Interface Architecture 2.0" has introduced a new support for the CAPI >> cards. > Which commit is that? > > cheers Here are the commit ids of the patchset: cxl: Add support for Coherent Accelerator Interface Architecture 2.0 patch1: aba81433b50350fde68bf80fe9f75d671e15b5ae patch2: 66ef20c7834b7df18168b12a57ef01c6ae0d1a81 patch3: 6dd2d23403396d8e6d153a6c9db56e1a1012bad8 patch4: bdd2e7150644fee4de7167a3e08294ef32eeda11 patch5: 64663f372c72cedeba1b1dc86df9cc159ae5a93d patch6: abd1d99bb3da42d6c7341c14986f5b8f4dcc6bd5 patch7: f24be42aab37c6d07c05126673138e06223a6399 Thanks >> These patches have been tested on Simulation environment and >> quite a bit of them have been tested on real hardware. >> >> This patch brings new fixes after a series of tests carried out on >> new equipment: >> * Add POWER9 definition. >> * Re-enable any masked interrupts when the AFU is not activated after >> resetting the AFU. >> * Remove the api cxl_is_psl8/9 which is no longer useful. >> * Do not dump CAPI1 registers. >> * Rewrite cxl_is_page_fault() function. >> * Do not register slb callack on P9. >> >> Changelog[v3] >> - Rebase to latest upstream. >> - Update the patch's header. >> - Add new test in cxl_is_page_fault(). >> >> Changelog[v2] >> - Rebase to latest upstream. >> - Update cxl_is_page_fault() to handle the checkout response status. >> - Add comments. >> >> Signed-off-by: Christophe Lombard <clombard@linux.vnet.ibm.com> >> --- >> drivers/misc/cxl/context.c | 6 +++--- >> drivers/misc/cxl/cxl.h | 18 +++++------------- >> drivers/misc/cxl/fault.c | 23 +++++++++++++++-------- >> drivers/misc/cxl/main.c | 17 +++++++++++++---- >> drivers/misc/cxl/native.c | 29 +++++++++++++++++------------ >> drivers/misc/cxl/pci.c | 11 ++++------- >> 6 files changed, 57 insertions(+), 47 deletions(-) >> >> diff --git a/drivers/misc/cxl/context.c b/drivers/misc/cxl/context.c >> index 4472ce1..8c32040 100644 >> --- a/drivers/misc/cxl/context.c >> +++ b/drivers/misc/cxl/context.c >> @@ -45,7 +45,7 @@ int cxl_context_init(struct cxl_context *ctx, struct cxl_afu *afu, bool master) >> mutex_init(&ctx->mapping_lock); >> ctx->mapping = NULL; >> >> - if (cxl_is_psl8(afu)) { >> + if (cxl_is_power8()) { >> spin_lock_init(&ctx->sste_lock); >> >> /* >> @@ -189,7 +189,7 @@ int cxl_context_iomap(struct cxl_context *ctx, struct vm_area_struct *vma) >> if (start + len > ctx->afu->adapter->ps_size) >> return -EINVAL; >> >> - if (cxl_is_psl9(ctx->afu)) { >> + if (cxl_is_power9()) { >> /* >> * Make sure there is a valid problem state >> * area space for this AFU. >> @@ -324,7 +324,7 @@ static void reclaim_ctx(struct rcu_head *rcu) >> { >> struct cxl_context *ctx = container_of(rcu, struct cxl_context, rcu); >> >> - if (cxl_is_psl8(ctx->afu)) >> + if (cxl_is_power8()) >> free_page((u64)ctx->sstp); >> if (ctx->ff_page) >> __free_page(ctx->ff_page); >> diff --git a/drivers/misc/cxl/cxl.h b/drivers/misc/cxl/cxl.h >> index c8568ea..a03f8e7 100644 >> --- a/drivers/misc/cxl/cxl.h >> +++ b/drivers/misc/cxl/cxl.h >> @@ -357,6 +357,7 @@ static const cxl_p2n_reg_t CXL_PSL_WED_An = {0x0A0}; >> #define CXL_PSL9_DSISR_An_PF_RGP 0x0000000000000090ULL /* PTE not found (Radix Guest (parent)) 0b10010000 */ >> #define CXL_PSL9_DSISR_An_PF_HRH 0x0000000000000094ULL /* PTE not found (HPT/Radix Host) 0b10010100 */ >> #define CXL_PSL9_DSISR_An_PF_STEG 0x000000000000009CULL /* PTE not found (STEG VA) 0b10011100 */ >> +#define CXL_PSL9_DSISR_An_URTCH 0x00000000000000B4ULL /* Unsupported Radix Tree Configuration 0b10110100 */ >> >> /****** CXL_PSL_TFC_An ******************************************************/ >> #define CXL_PSL_TFC_An_A (1ull << (63-28)) /* Acknowledge non-translation fault */ >> @@ -844,24 +845,15 @@ static inline bool cxl_is_power8(void) >> >> static inline bool cxl_is_power9(void) >> { >> - /* intermediate solution */ >> - if (!cxl_is_power8() && >> - (cpu_has_feature(CPU_FTRS_POWER9) || >> - cpu_has_feature(CPU_FTR_POWER9_DD1))) >> + if (pvr_version_is(PVR_POWER9)) >> return true; >> return false; >> } >> >> -static inline bool cxl_is_psl8(struct cxl_afu *afu) >> +static inline bool cxl_is_power9_dd1(void) >> { >> - if (afu->adapter->caia_major == 1) >> - return true; >> - return false; >> -} >> - >> -static inline bool cxl_is_psl9(struct cxl_afu *afu) >> -{ >> - if (afu->adapter->caia_major == 2) >> + if ((pvr_version_is(PVR_POWER9)) && >> + cpu_has_feature(CPU_FTR_POWER9_DD1)) >> return true; >> return false; >> } >> diff --git a/drivers/misc/cxl/fault.c b/drivers/misc/cxl/fault.c >> index 5344448..c79e39b 100644 >> --- a/drivers/misc/cxl/fault.c >> +++ b/drivers/misc/cxl/fault.c >> @@ -187,7 +187,7 @@ static struct mm_struct *get_mem_context(struct cxl_context *ctx) >> >> static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) >> { >> - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DS)) >> + if ((cxl_is_power8() && (dsisr & CXL_PSL_DSISR_An_DS))) >> return true; >> >> return false; >> @@ -195,16 +195,23 @@ static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) >> >> static bool cxl_is_page_fault(struct cxl_context *ctx, u64 dsisr) >> { >> - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DM)) >> - return true; >> + u64 crs; /* Translation Checkout Response Status */ >> >> - if ((cxl_is_psl9(ctx->afu)) && >> - ((dsisr & CXL_PSL9_DSISR_An_CO_MASK) & >> - (CXL_PSL9_DSISR_An_PF_SLR | CXL_PSL9_DSISR_An_PF_RGC | >> - CXL_PSL9_DSISR_An_PF_RGP | CXL_PSL9_DSISR_An_PF_HRH | >> - CXL_PSL9_DSISR_An_PF_STEG))) >> + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_An_DM)) >> return true; >> >> + if (cxl_is_power9()) { >> + crs = (dsisr & CXL_PSL9_DSISR_An_CO_MASK); >> + if ((crs == CXL_PSL9_DSISR_An_PF_SLR) || >> + (crs == CXL_PSL9_DSISR_An_PF_RGC) || >> + (crs == CXL_PSL9_DSISR_An_PF_RGP) || >> + (crs == CXL_PSL9_DSISR_An_PF_HRH) || >> + (crs == CXL_PSL9_DSISR_An_PF_STEG) || >> + (crs == CXL_PSL9_DSISR_An_URTCH)) { >> + return true; >> + } >> + } >> + >> return false; >> } >> >> diff --git a/drivers/misc/cxl/main.c b/drivers/misc/cxl/main.c >> index 1703655..c1ba0d4 100644 >> --- a/drivers/misc/cxl/main.c >> +++ b/drivers/misc/cxl/main.c >> @@ -329,8 +329,15 @@ static int __init init_cxl(void) >> >> cxl_debugfs_init(); >> >> - if ((rc = register_cxl_calls(&cxl_calls))) >> - goto err; >> + /* >> + * we don't register the callback on P9. slb callack is only >> + * used for the PSL8 MMU and CX4. >> + */ >> + if (cxl_is_power8()) { >> + rc = register_cxl_calls(&cxl_calls); >> + if (rc) >> + goto err; >> + } >> >> if (cpu_has_feature(CPU_FTR_HVMODE)) { >> cxl_ops = &cxl_native_ops; >> @@ -347,7 +354,8 @@ static int __init init_cxl(void) >> >> return 0; >> err1: >> - unregister_cxl_calls(&cxl_calls); >> + if (cxl_is_power8()) >> + unregister_cxl_calls(&cxl_calls); >> err: >> cxl_debugfs_exit(); >> cxl_file_exit(); >> @@ -366,7 +374,8 @@ static void exit_cxl(void) >> >> cxl_debugfs_exit(); >> cxl_file_exit(); >> - unregister_cxl_calls(&cxl_calls); >> + if (cxl_is_power8()) >> + unregister_cxl_calls(&cxl_calls); >> idr_destroy(&cxl_adapter_idr); >> } >> >> diff --git a/drivers/misc/cxl/native.c b/drivers/misc/cxl/native.c >> index 8d6ea97..2b2f889 100644 >> --- a/drivers/misc/cxl/native.c >> +++ b/drivers/misc/cxl/native.c >> @@ -105,11 +105,16 @@ static int native_afu_reset(struct cxl_afu *afu) >> CXL_AFU_Cntl_An_RS_MASK | CXL_AFU_Cntl_An_ES_MASK, >> false); >> >> - /* Re-enable any masked interrupts */ >> - serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); >> - serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; >> - cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); >> - >> + /* >> + * Re-enable any masked interrupts when the AFU is not >> + * activated to avoid side effects after attaching a process >> + * in dedicated mode. >> + */ >> + if (afu->current_mode == 0) { >> + serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); >> + serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; >> + cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); >> + } >> >> return rc; >> } >> @@ -139,9 +144,9 @@ int cxl_psl_purge(struct cxl_afu *afu) >> >> pr_devel("PSL purge request\n"); >> >> - if (cxl_is_psl8(afu)) >> + if (cxl_is_power8()) >> trans_fault = CXL_PSL_DSISR_TRANS; >> - if (cxl_is_psl9(afu)) >> + if (cxl_is_power9()) >> trans_fault = CXL_PSL9_DSISR_An_TF; >> >> if (!cxl_ops->link_ok(afu->adapter, afu)) { >> @@ -603,7 +608,7 @@ static u64 calculate_sr(struct cxl_context *ctx) >> if (!test_tsk_thread_flag(current, TIF_32BIT)) >> sr |= CXL_PSL_SR_An_SF; >> } >> - if (cxl_is_psl9(ctx->afu)) { >> + if (cxl_is_power9()) { >> if (radix_enabled()) >> sr |= CXL_PSL_SR_An_XLAT_ror; >> else >> @@ -1117,10 +1122,10 @@ static irqreturn_t native_handle_psl_slice_error(struct cxl_context *ctx, >> >> static bool cxl_is_translation_fault(struct cxl_afu *afu, u64 dsisr) >> { >> - if ((cxl_is_psl8(afu)) && (dsisr & CXL_PSL_DSISR_TRANS)) >> + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_TRANS)) >> return true; >> >> - if ((cxl_is_psl9(afu)) && (dsisr & CXL_PSL9_DSISR_An_TF)) >> + if ((cxl_is_power9()) && (dsisr & CXL_PSL9_DSISR_An_TF)) >> return true; >> >> return false; >> @@ -1194,10 +1199,10 @@ static void native_irq_wait(struct cxl_context *ctx) >> if (ph != ctx->pe) >> return; >> dsisr = cxl_p2n_read(ctx->afu, CXL_PSL_DSISR_An); >> - if (cxl_is_psl8(ctx->afu) && >> + if (cxl_is_power8() && >> ((dsisr & CXL_PSL_DSISR_PENDING) == 0)) >> return; >> - if (cxl_is_psl9(ctx->afu) && >> + if (cxl_is_power9() && >> ((dsisr & CXL_PSL9_DSISR_PENDING) == 0)) >> return; >> /* >> diff --git a/drivers/misc/cxl/pci.c b/drivers/misc/cxl/pci.c >> index 6dc1ee5..1eb9859 100644 >> --- a/drivers/misc/cxl/pci.c >> +++ b/drivers/misc/cxl/pci.c >> @@ -436,7 +436,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci >> /* nMMU_ID Defaults to: b’000001001’*/ >> xsl_dsnctl |= ((u64)0x09 << (63-28)); >> >> - if (cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)) { >> + if (!(cxl_is_power9_dd1())) { >> /* >> * Used to identify CAPI packets which should be sorted into >> * the Non-Blocking queues by the PHB. This field should match >> @@ -491,7 +491,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci >> cxl_p1_write(adapter, CXL_PSL9_APCDEDTYPE, 0x40000003FFFF0000ULL); >> >> /* Disable vc dd1 fix */ >> - if ((cxl_is_power9() && cpu_has_feature(CPU_FTR_POWER9_DD1))) >> + if (cxl_is_power9_dd1()) >> cxl_p1_write(adapter, CXL_PSL9_GP_CT, 0x0400000000000001ULL); >> >> return 0; >> @@ -1439,8 +1439,7 @@ int cxl_pci_reset(struct cxl *adapter) >> * The adapter is about to be reset, so ignore errors. >> * Not supported on P9 DD1 >> */ >> - if ((cxl_is_power8()) || >> - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) >> + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) >> cxl_data_cache_flush(adapter); >> >> /* pcie_warm_reset requests a fundamental pci reset which includes a >> @@ -1750,7 +1749,6 @@ static const struct cxl_service_layer_ops psl9_ops = { >> .debugfs_add_adapter_regs = cxl_debugfs_add_adapter_regs_psl9, >> .debugfs_add_afu_regs = cxl_debugfs_add_afu_regs_psl9, >> .psl_irq_dump_registers = cxl_native_irq_dump_regs_psl9, >> - .err_irq_dump_registers = cxl_native_err_irq_dump_regs, >> .debugfs_stop_trace = cxl_stop_trace_psl9, >> .write_timebase_ctrl = write_timebase_ctrl_psl9, >> .timebase_read = timebase_read_psl9, >> @@ -1889,8 +1887,7 @@ static void cxl_pci_remove_adapter(struct cxl *adapter) >> * Flush adapter datacache as its about to be removed. >> * Not supported on P9 DD1. >> */ >> - if ((cxl_is_power8()) || >> - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) >> + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) >> cxl_data_cache_flush(adapter); >> >> cxl_deconfigure_adapter(adapter); >> -- >> 2.7.4
Le 13/06/2017 à 17:41, Christophe Lombard a écrit : > A previous set of patches "cxl: Add support for Coherent Accelerator > Interface Architecture 2.0" has introduced a new support for the CAPI > cards. These patches have been tested on Simulation environment and > quite a bit of them have been tested on real hardware. > > This patch brings new fixes after a series of tests carried out on > new equipment: > * Add POWER9 definition. > * Re-enable any masked interrupts when the AFU is not activated after > resetting the AFU. > * Remove the api cxl_is_psl8/9 which is no longer useful. > * Do not dump CAPI1 registers. > * Rewrite cxl_is_page_fault() function. > * Do not register slb callack on P9. > > Changelog[v3] > - Rebase to latest upstream. > - Update the patch's header. > - Add new test in cxl_is_page_fault(). > > Changelog[v2] > - Rebase to latest upstream. > - Update cxl_is_page_fault() to handle the checkout response status. > - Add comments. > > Signed-off-by: Christophe Lombard <clombard@linux.vnet.ibm.com> > --- Looks good to me, thanks! Acked-by: Frederic Barrat <fbarrat@linux.vnet.ibm.com> > drivers/misc/cxl/context.c | 6 +++--- > drivers/misc/cxl/cxl.h | 18 +++++------------- > drivers/misc/cxl/fault.c | 23 +++++++++++++++-------- > drivers/misc/cxl/main.c | 17 +++++++++++++---- > drivers/misc/cxl/native.c | 29 +++++++++++++++++------------ > drivers/misc/cxl/pci.c | 11 ++++------- > 6 files changed, 57 insertions(+), 47 deletions(-) > > diff --git a/drivers/misc/cxl/context.c b/drivers/misc/cxl/context.c > index 4472ce1..8c32040 100644 > --- a/drivers/misc/cxl/context.c > +++ b/drivers/misc/cxl/context.c > @@ -45,7 +45,7 @@ int cxl_context_init(struct cxl_context *ctx, struct cxl_afu *afu, bool master) > mutex_init(&ctx->mapping_lock); > ctx->mapping = NULL; > > - if (cxl_is_psl8(afu)) { > + if (cxl_is_power8()) { > spin_lock_init(&ctx->sste_lock); > > /* > @@ -189,7 +189,7 @@ int cxl_context_iomap(struct cxl_context *ctx, struct vm_area_struct *vma) > if (start + len > ctx->afu->adapter->ps_size) > return -EINVAL; > > - if (cxl_is_psl9(ctx->afu)) { > + if (cxl_is_power9()) { > /* > * Make sure there is a valid problem state > * area space for this AFU. > @@ -324,7 +324,7 @@ static void reclaim_ctx(struct rcu_head *rcu) > { > struct cxl_context *ctx = container_of(rcu, struct cxl_context, rcu); > > - if (cxl_is_psl8(ctx->afu)) > + if (cxl_is_power8()) > free_page((u64)ctx->sstp); > if (ctx->ff_page) > __free_page(ctx->ff_page); > diff --git a/drivers/misc/cxl/cxl.h b/drivers/misc/cxl/cxl.h > index c8568ea..a03f8e7 100644 > --- a/drivers/misc/cxl/cxl.h > +++ b/drivers/misc/cxl/cxl.h > @@ -357,6 +357,7 @@ static const cxl_p2n_reg_t CXL_PSL_WED_An = {0x0A0}; > #define CXL_PSL9_DSISR_An_PF_RGP 0x0000000000000090ULL /* PTE not found (Radix Guest (parent)) 0b10010000 */ > #define CXL_PSL9_DSISR_An_PF_HRH 0x0000000000000094ULL /* PTE not found (HPT/Radix Host) 0b10010100 */ > #define CXL_PSL9_DSISR_An_PF_STEG 0x000000000000009CULL /* PTE not found (STEG VA) 0b10011100 */ > +#define CXL_PSL9_DSISR_An_URTCH 0x00000000000000B4ULL /* Unsupported Radix Tree Configuration 0b10110100 */ > > /****** CXL_PSL_TFC_An ******************************************************/ > #define CXL_PSL_TFC_An_A (1ull << (63-28)) /* Acknowledge non-translation fault */ > @@ -844,24 +845,15 @@ static inline bool cxl_is_power8(void) > > static inline bool cxl_is_power9(void) > { > - /* intermediate solution */ > - if (!cxl_is_power8() && > - (cpu_has_feature(CPU_FTRS_POWER9) || > - cpu_has_feature(CPU_FTR_POWER9_DD1))) > + if (pvr_version_is(PVR_POWER9)) > return true; > return false; > } > > -static inline bool cxl_is_psl8(struct cxl_afu *afu) > +static inline bool cxl_is_power9_dd1(void) > { > - if (afu->adapter->caia_major == 1) > - return true; > - return false; > -} > - > -static inline bool cxl_is_psl9(struct cxl_afu *afu) > -{ > - if (afu->adapter->caia_major == 2) > + if ((pvr_version_is(PVR_POWER9)) && > + cpu_has_feature(CPU_FTR_POWER9_DD1)) > return true; > return false; > } > diff --git a/drivers/misc/cxl/fault.c b/drivers/misc/cxl/fault.c > index 5344448..c79e39b 100644 > --- a/drivers/misc/cxl/fault.c > +++ b/drivers/misc/cxl/fault.c > @@ -187,7 +187,7 @@ static struct mm_struct *get_mem_context(struct cxl_context *ctx) > > static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) > { > - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DS)) > + if ((cxl_is_power8() && (dsisr & CXL_PSL_DSISR_An_DS))) > return true; > > return false; > @@ -195,16 +195,23 @@ static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) > > static bool cxl_is_page_fault(struct cxl_context *ctx, u64 dsisr) > { > - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DM)) > - return true; > + u64 crs; /* Translation Checkout Response Status */ > > - if ((cxl_is_psl9(ctx->afu)) && > - ((dsisr & CXL_PSL9_DSISR_An_CO_MASK) & > - (CXL_PSL9_DSISR_An_PF_SLR | CXL_PSL9_DSISR_An_PF_RGC | > - CXL_PSL9_DSISR_An_PF_RGP | CXL_PSL9_DSISR_An_PF_HRH | > - CXL_PSL9_DSISR_An_PF_STEG))) > + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_An_DM)) > return true; > > + if (cxl_is_power9()) { > + crs = (dsisr & CXL_PSL9_DSISR_An_CO_MASK); > + if ((crs == CXL_PSL9_DSISR_An_PF_SLR) || > + (crs == CXL_PSL9_DSISR_An_PF_RGC) || > + (crs == CXL_PSL9_DSISR_An_PF_RGP) || > + (crs == CXL_PSL9_DSISR_An_PF_HRH) || > + (crs == CXL_PSL9_DSISR_An_PF_STEG) || > + (crs == CXL_PSL9_DSISR_An_URTCH)) { > + return true; > + } > + } > + > return false; > } > > diff --git a/drivers/misc/cxl/main.c b/drivers/misc/cxl/main.c > index 1703655..c1ba0d4 100644 > --- a/drivers/misc/cxl/main.c > +++ b/drivers/misc/cxl/main.c > @@ -329,8 +329,15 @@ static int __init init_cxl(void) > > cxl_debugfs_init(); > > - if ((rc = register_cxl_calls(&cxl_calls))) > - goto err; > + /* > + * we don't register the callback on P9. slb callack is only > + * used for the PSL8 MMU and CX4. > + */ > + if (cxl_is_power8()) { > + rc = register_cxl_calls(&cxl_calls); > + if (rc) > + goto err; > + } > > if (cpu_has_feature(CPU_FTR_HVMODE)) { > cxl_ops = &cxl_native_ops; > @@ -347,7 +354,8 @@ static int __init init_cxl(void) > > return 0; > err1: > - unregister_cxl_calls(&cxl_calls); > + if (cxl_is_power8()) > + unregister_cxl_calls(&cxl_calls); > err: > cxl_debugfs_exit(); > cxl_file_exit(); > @@ -366,7 +374,8 @@ static void exit_cxl(void) > > cxl_debugfs_exit(); > cxl_file_exit(); > - unregister_cxl_calls(&cxl_calls); > + if (cxl_is_power8()) > + unregister_cxl_calls(&cxl_calls); > idr_destroy(&cxl_adapter_idr); > } > > diff --git a/drivers/misc/cxl/native.c b/drivers/misc/cxl/native.c > index 8d6ea97..2b2f889 100644 > --- a/drivers/misc/cxl/native.c > +++ b/drivers/misc/cxl/native.c > @@ -105,11 +105,16 @@ static int native_afu_reset(struct cxl_afu *afu) > CXL_AFU_Cntl_An_RS_MASK | CXL_AFU_Cntl_An_ES_MASK, > false); > > - /* Re-enable any masked interrupts */ > - serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); > - serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; > - cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); > - > + /* > + * Re-enable any masked interrupts when the AFU is not > + * activated to avoid side effects after attaching a process > + * in dedicated mode. > + */ > + if (afu->current_mode == 0) { > + serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); > + serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; > + cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); > + } > > return rc; > } > @@ -139,9 +144,9 @@ int cxl_psl_purge(struct cxl_afu *afu) > > pr_devel("PSL purge request\n"); > > - if (cxl_is_psl8(afu)) > + if (cxl_is_power8()) > trans_fault = CXL_PSL_DSISR_TRANS; > - if (cxl_is_psl9(afu)) > + if (cxl_is_power9()) > trans_fault = CXL_PSL9_DSISR_An_TF; > > if (!cxl_ops->link_ok(afu->adapter, afu)) { > @@ -603,7 +608,7 @@ static u64 calculate_sr(struct cxl_context *ctx) > if (!test_tsk_thread_flag(current, TIF_32BIT)) > sr |= CXL_PSL_SR_An_SF; > } > - if (cxl_is_psl9(ctx->afu)) { > + if (cxl_is_power9()) { > if (radix_enabled()) > sr |= CXL_PSL_SR_An_XLAT_ror; > else > @@ -1117,10 +1122,10 @@ static irqreturn_t native_handle_psl_slice_error(struct cxl_context *ctx, > > static bool cxl_is_translation_fault(struct cxl_afu *afu, u64 dsisr) > { > - if ((cxl_is_psl8(afu)) && (dsisr & CXL_PSL_DSISR_TRANS)) > + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_TRANS)) > return true; > > - if ((cxl_is_psl9(afu)) && (dsisr & CXL_PSL9_DSISR_An_TF)) > + if ((cxl_is_power9()) && (dsisr & CXL_PSL9_DSISR_An_TF)) > return true; > > return false; > @@ -1194,10 +1199,10 @@ static void native_irq_wait(struct cxl_context *ctx) > if (ph != ctx->pe) > return; > dsisr = cxl_p2n_read(ctx->afu, CXL_PSL_DSISR_An); > - if (cxl_is_psl8(ctx->afu) && > + if (cxl_is_power8() && > ((dsisr & CXL_PSL_DSISR_PENDING) == 0)) > return; > - if (cxl_is_psl9(ctx->afu) && > + if (cxl_is_power9() && > ((dsisr & CXL_PSL9_DSISR_PENDING) == 0)) > return; > /* > diff --git a/drivers/misc/cxl/pci.c b/drivers/misc/cxl/pci.c > index 6dc1ee5..1eb9859 100644 > --- a/drivers/misc/cxl/pci.c > +++ b/drivers/misc/cxl/pci.c > @@ -436,7 +436,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci > /* nMMU_ID Defaults to: b’000001001’*/ > xsl_dsnctl |= ((u64)0x09 << (63-28)); > > - if (cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)) { > + if (!(cxl_is_power9_dd1())) { > /* > * Used to identify CAPI packets which should be sorted into > * the Non-Blocking queues by the PHB. This field should match > @@ -491,7 +491,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci > cxl_p1_write(adapter, CXL_PSL9_APCDEDTYPE, 0x40000003FFFF0000ULL); > > /* Disable vc dd1 fix */ > - if ((cxl_is_power9() && cpu_has_feature(CPU_FTR_POWER9_DD1))) > + if (cxl_is_power9_dd1()) > cxl_p1_write(adapter, CXL_PSL9_GP_CT, 0x0400000000000001ULL); > > return 0; > @@ -1439,8 +1439,7 @@ int cxl_pci_reset(struct cxl *adapter) > * The adapter is about to be reset, so ignore errors. > * Not supported on P9 DD1 > */ > - if ((cxl_is_power8()) || > - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) > + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) > cxl_data_cache_flush(adapter); > > /* pcie_warm_reset requests a fundamental pci reset which includes a > @@ -1750,7 +1749,6 @@ static const struct cxl_service_layer_ops psl9_ops = { > .debugfs_add_adapter_regs = cxl_debugfs_add_adapter_regs_psl9, > .debugfs_add_afu_regs = cxl_debugfs_add_afu_regs_psl9, > .psl_irq_dump_registers = cxl_native_irq_dump_regs_psl9, > - .err_irq_dump_registers = cxl_native_err_irq_dump_regs, > .debugfs_stop_trace = cxl_stop_trace_psl9, > .write_timebase_ctrl = write_timebase_ctrl_psl9, > .timebase_read = timebase_read_psl9, > @@ -1889,8 +1887,7 @@ static void cxl_pci_remove_adapter(struct cxl *adapter) > * Flush adapter datacache as its about to be removed. > * Not supported on P9 DD1. > */ > - if ((cxl_is_power8()) || > - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) > + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) > cxl_data_cache_flush(adapter); > > cxl_deconfigure_adapter(adapter); >
On Tue, 2017-06-13 at 15:41:05 UTC, Christophe Lombard wrote: > A previous set of patches "cxl: Add support for Coherent Accelerator > Interface Architecture 2.0" has introduced a new support for the CAPI > cards. These patches have been tested on Simulation environment and > quite a bit of them have been tested on real hardware. > > This patch brings new fixes after a series of tests carried out on > new equipment: > * Add POWER9 definition. > * Re-enable any masked interrupts when the AFU is not activated after > resetting the AFU. > * Remove the api cxl_is_psl8/9 which is no longer useful. > * Do not dump CAPI1 registers. > * Rewrite cxl_is_page_fault() function. > * Do not register slb callack on P9. > > Signed-off-by: Christophe Lombard <clombard@linux.vnet.ibm.com> > Acked-by: Frederic Barrat <fbarrat@linux.vnet.ibm.com> Applied to powerpc fixes, thanks. https://git.kernel.org/powerpc/c/797625deaedd9a0621376817db2813 cheers
diff --git a/drivers/misc/cxl/context.c b/drivers/misc/cxl/context.c index 4472ce1..8c32040 100644 --- a/drivers/misc/cxl/context.c +++ b/drivers/misc/cxl/context.c @@ -45,7 +45,7 @@ int cxl_context_init(struct cxl_context *ctx, struct cxl_afu *afu, bool master) mutex_init(&ctx->mapping_lock); ctx->mapping = NULL; - if (cxl_is_psl8(afu)) { + if (cxl_is_power8()) { spin_lock_init(&ctx->sste_lock); /* @@ -189,7 +189,7 @@ int cxl_context_iomap(struct cxl_context *ctx, struct vm_area_struct *vma) if (start + len > ctx->afu->adapter->ps_size) return -EINVAL; - if (cxl_is_psl9(ctx->afu)) { + if (cxl_is_power9()) { /* * Make sure there is a valid problem state * area space for this AFU. @@ -324,7 +324,7 @@ static void reclaim_ctx(struct rcu_head *rcu) { struct cxl_context *ctx = container_of(rcu, struct cxl_context, rcu); - if (cxl_is_psl8(ctx->afu)) + if (cxl_is_power8()) free_page((u64)ctx->sstp); if (ctx->ff_page) __free_page(ctx->ff_page); diff --git a/drivers/misc/cxl/cxl.h b/drivers/misc/cxl/cxl.h index c8568ea..a03f8e7 100644 --- a/drivers/misc/cxl/cxl.h +++ b/drivers/misc/cxl/cxl.h @@ -357,6 +357,7 @@ static const cxl_p2n_reg_t CXL_PSL_WED_An = {0x0A0}; #define CXL_PSL9_DSISR_An_PF_RGP 0x0000000000000090ULL /* PTE not found (Radix Guest (parent)) 0b10010000 */ #define CXL_PSL9_DSISR_An_PF_HRH 0x0000000000000094ULL /* PTE not found (HPT/Radix Host) 0b10010100 */ #define CXL_PSL9_DSISR_An_PF_STEG 0x000000000000009CULL /* PTE not found (STEG VA) 0b10011100 */ +#define CXL_PSL9_DSISR_An_URTCH 0x00000000000000B4ULL /* Unsupported Radix Tree Configuration 0b10110100 */ /****** CXL_PSL_TFC_An ******************************************************/ #define CXL_PSL_TFC_An_A (1ull << (63-28)) /* Acknowledge non-translation fault */ @@ -844,24 +845,15 @@ static inline bool cxl_is_power8(void) static inline bool cxl_is_power9(void) { - /* intermediate solution */ - if (!cxl_is_power8() && - (cpu_has_feature(CPU_FTRS_POWER9) || - cpu_has_feature(CPU_FTR_POWER9_DD1))) + if (pvr_version_is(PVR_POWER9)) return true; return false; } -static inline bool cxl_is_psl8(struct cxl_afu *afu) +static inline bool cxl_is_power9_dd1(void) { - if (afu->adapter->caia_major == 1) - return true; - return false; -} - -static inline bool cxl_is_psl9(struct cxl_afu *afu) -{ - if (afu->adapter->caia_major == 2) + if ((pvr_version_is(PVR_POWER9)) && + cpu_has_feature(CPU_FTR_POWER9_DD1)) return true; return false; } diff --git a/drivers/misc/cxl/fault.c b/drivers/misc/cxl/fault.c index 5344448..c79e39b 100644 --- a/drivers/misc/cxl/fault.c +++ b/drivers/misc/cxl/fault.c @@ -187,7 +187,7 @@ static struct mm_struct *get_mem_context(struct cxl_context *ctx) static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) { - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DS)) + if ((cxl_is_power8() && (dsisr & CXL_PSL_DSISR_An_DS))) return true; return false; @@ -195,16 +195,23 @@ static bool cxl_is_segment_miss(struct cxl_context *ctx, u64 dsisr) static bool cxl_is_page_fault(struct cxl_context *ctx, u64 dsisr) { - if ((cxl_is_psl8(ctx->afu)) && (dsisr & CXL_PSL_DSISR_An_DM)) - return true; + u64 crs; /* Translation Checkout Response Status */ - if ((cxl_is_psl9(ctx->afu)) && - ((dsisr & CXL_PSL9_DSISR_An_CO_MASK) & - (CXL_PSL9_DSISR_An_PF_SLR | CXL_PSL9_DSISR_An_PF_RGC | - CXL_PSL9_DSISR_An_PF_RGP | CXL_PSL9_DSISR_An_PF_HRH | - CXL_PSL9_DSISR_An_PF_STEG))) + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_An_DM)) return true; + if (cxl_is_power9()) { + crs = (dsisr & CXL_PSL9_DSISR_An_CO_MASK); + if ((crs == CXL_PSL9_DSISR_An_PF_SLR) || + (crs == CXL_PSL9_DSISR_An_PF_RGC) || + (crs == CXL_PSL9_DSISR_An_PF_RGP) || + (crs == CXL_PSL9_DSISR_An_PF_HRH) || + (crs == CXL_PSL9_DSISR_An_PF_STEG) || + (crs == CXL_PSL9_DSISR_An_URTCH)) { + return true; + } + } + return false; } diff --git a/drivers/misc/cxl/main.c b/drivers/misc/cxl/main.c index 1703655..c1ba0d4 100644 --- a/drivers/misc/cxl/main.c +++ b/drivers/misc/cxl/main.c @@ -329,8 +329,15 @@ static int __init init_cxl(void) cxl_debugfs_init(); - if ((rc = register_cxl_calls(&cxl_calls))) - goto err; + /* + * we don't register the callback on P9. slb callack is only + * used for the PSL8 MMU and CX4. + */ + if (cxl_is_power8()) { + rc = register_cxl_calls(&cxl_calls); + if (rc) + goto err; + } if (cpu_has_feature(CPU_FTR_HVMODE)) { cxl_ops = &cxl_native_ops; @@ -347,7 +354,8 @@ static int __init init_cxl(void) return 0; err1: - unregister_cxl_calls(&cxl_calls); + if (cxl_is_power8()) + unregister_cxl_calls(&cxl_calls); err: cxl_debugfs_exit(); cxl_file_exit(); @@ -366,7 +374,8 @@ static void exit_cxl(void) cxl_debugfs_exit(); cxl_file_exit(); - unregister_cxl_calls(&cxl_calls); + if (cxl_is_power8()) + unregister_cxl_calls(&cxl_calls); idr_destroy(&cxl_adapter_idr); } diff --git a/drivers/misc/cxl/native.c b/drivers/misc/cxl/native.c index 8d6ea97..2b2f889 100644 --- a/drivers/misc/cxl/native.c +++ b/drivers/misc/cxl/native.c @@ -105,11 +105,16 @@ static int native_afu_reset(struct cxl_afu *afu) CXL_AFU_Cntl_An_RS_MASK | CXL_AFU_Cntl_An_ES_MASK, false); - /* Re-enable any masked interrupts */ - serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); - serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; - cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); - + /* + * Re-enable any masked interrupts when the AFU is not + * activated to avoid side effects after attaching a process + * in dedicated mode. + */ + if (afu->current_mode == 0) { + serr = cxl_p1n_read(afu, CXL_PSL_SERR_An); + serr &= ~CXL_PSL_SERR_An_IRQ_MASKS; + cxl_p1n_write(afu, CXL_PSL_SERR_An, serr); + } return rc; } @@ -139,9 +144,9 @@ int cxl_psl_purge(struct cxl_afu *afu) pr_devel("PSL purge request\n"); - if (cxl_is_psl8(afu)) + if (cxl_is_power8()) trans_fault = CXL_PSL_DSISR_TRANS; - if (cxl_is_psl9(afu)) + if (cxl_is_power9()) trans_fault = CXL_PSL9_DSISR_An_TF; if (!cxl_ops->link_ok(afu->adapter, afu)) { @@ -603,7 +608,7 @@ static u64 calculate_sr(struct cxl_context *ctx) if (!test_tsk_thread_flag(current, TIF_32BIT)) sr |= CXL_PSL_SR_An_SF; } - if (cxl_is_psl9(ctx->afu)) { + if (cxl_is_power9()) { if (radix_enabled()) sr |= CXL_PSL_SR_An_XLAT_ror; else @@ -1117,10 +1122,10 @@ static irqreturn_t native_handle_psl_slice_error(struct cxl_context *ctx, static bool cxl_is_translation_fault(struct cxl_afu *afu, u64 dsisr) { - if ((cxl_is_psl8(afu)) && (dsisr & CXL_PSL_DSISR_TRANS)) + if ((cxl_is_power8()) && (dsisr & CXL_PSL_DSISR_TRANS)) return true; - if ((cxl_is_psl9(afu)) && (dsisr & CXL_PSL9_DSISR_An_TF)) + if ((cxl_is_power9()) && (dsisr & CXL_PSL9_DSISR_An_TF)) return true; return false; @@ -1194,10 +1199,10 @@ static void native_irq_wait(struct cxl_context *ctx) if (ph != ctx->pe) return; dsisr = cxl_p2n_read(ctx->afu, CXL_PSL_DSISR_An); - if (cxl_is_psl8(ctx->afu) && + if (cxl_is_power8() && ((dsisr & CXL_PSL_DSISR_PENDING) == 0)) return; - if (cxl_is_psl9(ctx->afu) && + if (cxl_is_power9() && ((dsisr & CXL_PSL9_DSISR_PENDING) == 0)) return; /* diff --git a/drivers/misc/cxl/pci.c b/drivers/misc/cxl/pci.c index 6dc1ee5..1eb9859 100644 --- a/drivers/misc/cxl/pci.c +++ b/drivers/misc/cxl/pci.c @@ -436,7 +436,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci /* nMMU_ID Defaults to: b’000001001’*/ xsl_dsnctl |= ((u64)0x09 << (63-28)); - if (cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)) { + if (!(cxl_is_power9_dd1())) { /* * Used to identify CAPI packets which should be sorted into * the Non-Blocking queues by the PHB. This field should match @@ -491,7 +491,7 @@ static int init_implementation_adapter_regs_psl9(struct cxl *adapter, struct pci cxl_p1_write(adapter, CXL_PSL9_APCDEDTYPE, 0x40000003FFFF0000ULL); /* Disable vc dd1 fix */ - if ((cxl_is_power9() && cpu_has_feature(CPU_FTR_POWER9_DD1))) + if (cxl_is_power9_dd1()) cxl_p1_write(adapter, CXL_PSL9_GP_CT, 0x0400000000000001ULL); return 0; @@ -1439,8 +1439,7 @@ int cxl_pci_reset(struct cxl *adapter) * The adapter is about to be reset, so ignore errors. * Not supported on P9 DD1 */ - if ((cxl_is_power8()) || - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) cxl_data_cache_flush(adapter); /* pcie_warm_reset requests a fundamental pci reset which includes a @@ -1750,7 +1749,6 @@ static const struct cxl_service_layer_ops psl9_ops = { .debugfs_add_adapter_regs = cxl_debugfs_add_adapter_regs_psl9, .debugfs_add_afu_regs = cxl_debugfs_add_afu_regs_psl9, .psl_irq_dump_registers = cxl_native_irq_dump_regs_psl9, - .err_irq_dump_registers = cxl_native_err_irq_dump_regs, .debugfs_stop_trace = cxl_stop_trace_psl9, .write_timebase_ctrl = write_timebase_ctrl_psl9, .timebase_read = timebase_read_psl9, @@ -1889,8 +1887,7 @@ static void cxl_pci_remove_adapter(struct cxl *adapter) * Flush adapter datacache as its about to be removed. * Not supported on P9 DD1. */ - if ((cxl_is_power8()) || - ((cxl_is_power9() && !cpu_has_feature(CPU_FTR_POWER9_DD1)))) + if ((cxl_is_power8()) || (!(cxl_is_power9_dd1()))) cxl_data_cache_flush(adapter); cxl_deconfigure_adapter(adapter);
A previous set of patches "cxl: Add support for Coherent Accelerator Interface Architecture 2.0" has introduced a new support for the CAPI cards. These patches have been tested on Simulation environment and quite a bit of them have been tested on real hardware. This patch brings new fixes after a series of tests carried out on new equipment: * Add POWER9 definition. * Re-enable any masked interrupts when the AFU is not activated after resetting the AFU. * Remove the api cxl_is_psl8/9 which is no longer useful. * Do not dump CAPI1 registers. * Rewrite cxl_is_page_fault() function. * Do not register slb callack on P9. Changelog[v3] - Rebase to latest upstream. - Update the patch's header. - Add new test in cxl_is_page_fault(). Changelog[v2] - Rebase to latest upstream. - Update cxl_is_page_fault() to handle the checkout response status. - Add comments. Signed-off-by: Christophe Lombard <clombard@linux.vnet.ibm.com> --- drivers/misc/cxl/context.c | 6 +++--- drivers/misc/cxl/cxl.h | 18 +++++------------- drivers/misc/cxl/fault.c | 23 +++++++++++++++-------- drivers/misc/cxl/main.c | 17 +++++++++++++---- drivers/misc/cxl/native.c | 29 +++++++++++++++++------------ drivers/misc/cxl/pci.c | 11 ++++------- 6 files changed, 57 insertions(+), 47 deletions(-)