> > static void ct3d_reg_write(void *opaque, hwaddr offset, uint64_t value, > > unsigned size) > > { > > @@ -341,6 +402,83 @@ static void ct3d_reg_write(void *opaque, hwaddr > > offset, uint64_t value, > > should_commit = FIELD_EX32(value, CXL_HDM_DECODER0_CTRL, COMMIT); > > which_hdm = 0; > > break; > > + case A_CXL_RAS_UNC_ERR_STATUS: > > + { > > + uint32_t capctrl = ldl_le_p(cache_mem + R_CXL_RAS_ERR_CAP_CTRL); > > + uint32_t fe = FIELD_EX32(capctrl, CXL_RAS_ERR_CAP_CTRL, > > FIRST_ERROR_POINTER); > > + CXLError *cxl_err; > > + uint32_t unc_err; > > + > > + /* > > + * If single bit written that corresponds to the first error > > + * pointer being cleared, update the status and header log. > > + */ > > + if (!QTAILQ_EMPTY(&ct3d->error_list)) { > > + if ((1 << fe) ^ value) { > > + CXLError *cxl_next; > > + /* > > + * Software is using wrong flow for multiple header > > recording > > + * Following behaviour in PCIe r6.0 and assuming multiple > > + * header support. Imdef choice to clear all matching > > records > > What does "Imdef" mean?
Good spot. Should have been Impdef, but there is no reason not to spell it out as "Implementation defined". What I'm trying to indicate here is that the PCIe r6.0 base specification lets hardware do one of several different things. I picked one of those options. In PCIe it's a little less critical than in CXL as there is an explicit opt in so you can expect software to do the right thing. Unfortunately not so for CXL where we have to assume the capability being there means the hardware will do it. I guess there was no need for backwards compatibility for CXL. Jonathan > > DJ