On Wed, Sep 06, 2017 at 10:56:42AM +0000, Gabriele Paoloni wrote: > Hi Bjorn > > > -----Original Message----- > > From: Bjorn Helgaas [mailto:helgaas@xxxxxxxxxx] > > Sent: 02 September 2017 18:33 > > To: Gabriele Paoloni > > Cc: Linuxarm; liudongdong (C); linux-pci@xxxxxxxxxxxxxxx; linux- > > kernel@xxxxxxxxxxxxxxx > > Subject: Re: [PATCH v2] PCIe AER: report uncorrectable errors only to > > the functions that logged the errors > > > > On Fri, Sep 01, 2017 at 11:39:35AM +0000, Gabriele Paoloni wrote: > > > Hi Bjorn > > > > > > Many thanks for looking at this > > > > > > > -----Original Message----- > > > > From: Bjorn Helgaas [mailto:helgaas@xxxxxxxxxx] > > > > Sent: 01 September 2017 05:43 > > > > To: Gabriele Paoloni > > > > Cc: Linuxarm; liudongdong (C); linux-pci@xxxxxxxxxxxxxxx; linux- > > > > kernel@xxxxxxxxxxxxxxx > > > > Subject: Re: [PATCH v2] PCIe AER: report uncorrectable errors only > > to > > > > the functions that logged the errors > > > > > > > > On Thu, Aug 31, 2017 at 03:03:44PM -0500, Bjorn Helgaas wrote: > > > > > On Fri, Aug 18, 2017 at 12:02:21PM +0100, Gabriele Paoloni wrote: > > > > > > Currently if an uncorrectable error is reported by an EP the > > AER > > > > > > driver walks over all the devices connected to the upstream > > port > > > > > > bus and in turns call the report_error_detected() callback. > > > > > > If any of the devices connected to the bus does not implement > > > > > > dev->driver->err_handler->error_detected() do_recovery() will > > fail > > > > > > leaving all the bus hierarchy devices unrecovered. > > > > > > > > > > > > However for non fatal errors the PCIe link should not be > > considered > > > > > > compromised, therefore it makes sense to report the error only > > to > > > > > > all the functions that logged an error. > > > > > > > > > > Can you include a pointer to the relevant part of the spec here? > > > > > > Sure > > > According to section "6.2.2.2.2. Non-Fatal Errors" > > > << Non-fatal errors are uncorrectable errors which cause a particular > > > transaction to be unreliable but the Link is otherwise fully > > functional. > > > Isolating Non-fatal from Fatal errors provides Requester/Receiver > > logic > > > in a device or system management software the opportunity to recover > > > from the error without resetting the components on the Link and > > > disturbing other transactions in progress. Devices not associated > > with > > > the transaction in error are not impacted by the error.>> > > > > > > I will add it to the commit msg: > > > > > > > > > > > Also, I forgot to ask: can you outline the problem this fixes? I'm > > > > curious about why this hasn't been an issue in the past. My guess > > is > > > > there's something new about your configuration, and the config and > > the > > > > symptoms might help connect this fix to similar problems. > > > > > > I already replied about this in the previous patch... > > > << In Hi1620 we have some integrated controllers that appear as PCIe > > EPs > > > under the same bus. Some of these controllers (e.g. the SATA > > > controller) are missing the err_handler callbacks. > > > > > > If one device reports a non-fatal uncorrectable error with the > > current > > > AER core code the callbacks for all the devices under the same bus > > will > > > be called and, if any of the devices is missing the callback all the > > > devices in the subtree are left in error state without recovery... > > > This patch is needed to sort out a situation like this one.>> > > > > > > Should I add this to the commit msg? > > > > Thanks for the reminder. I thought I remembered some details but > > hadn't dug them out again. Yes, I was hoping for something we could > > include in the commit message. I'm still not sure what specifically > > is *new* about this situation. Maybe the particular mix of functions > > in a multi-function device? Maybe the fact that you're seeing more > > AER errors than before (or maybe just doing more testing?) > > Hi Bjorn as I said here we have some integrated controllers that appear > as PCIe EPs under the same bus. Usually PCIe is p2p (no more that 1 > device per bus), but in our SoC we have different devices under the same > bus (not MF devices): > > RC---bus0---|-SAS ctrl > | > |-SATA ctrl > | > |-XGE ctrl > > Since this is unusual this is maybe the reason why this has not been > seen yet elsewhere... > > > > > Since this is actually a bug fix, this might be a good opportunity to > > open a bugzilla for it. Then we have a place to attach the complete > > "lspci -vv" output, dmesg, etc., that are of interest but too much for > > the commit message. > > Sure we can do this and add the bugzilla link in the commit msg > > > > > > > > > This patch implements this new behaviour for non fatal errors. > > > > > > > > > > > > Signed-off-by: Gabriele Paoloni <gabriele.paoloni@xxxxxxxxxx> > > > > > > Signed-off-by: Dongdong Liu <liudongdong3@xxxxxxxxxx> > > > > > > --- > > > > > > Changes from v1: > > > > > > - now errors are reported only to the fucntions that logged > > the > > > > error > > > > > > instead of all the functions in the same device. > > > > > > - the patch subject has changed to match the new > > implementation > > > > > > --- > > > > > > drivers/pci/pcie/aer/aerdrv_core.c | 9 ++++++++- > > > > > > 1 file changed, 8 insertions(+), 1 deletion(-) > > > > > > > > > > > > diff --git a/drivers/pci/pcie/aer/aerdrv_core.c > > > > b/drivers/pci/pcie/aer/aerdrv_core.c > > > > > > index b1303b3..057465ad 100644 > > > > > > --- a/drivers/pci/pcie/aer/aerdrv_core.c > > > > > > +++ b/drivers/pci/pcie/aer/aerdrv_core.c > > > > > > @@ -390,7 +390,14 @@ static pci_ers_result_t > > > > broadcast_error_message(struct pci_dev *dev, > > > > > > * If the error is reported by an end point, we think > > this > > > > > > * error is related to the upstream link of the end > > point. > > > > > > */ > > > > > > - pci_walk_bus(dev->bus, cb, &result_data); > > > > > > + if (state == pci_channel_io_normal) > > > > > > + /* > > > > > > + * the error is non fatal so the bus is ok, > > just > > > > invoke > > > > > > + * the callback for the function that logged > > the > > > > error. > > > > > > + */ > > > > > > + cb(dev, &result_data); > > > > > > + else > > > > > > + pci_walk_bus(dev->bus, cb, &result_data); > > > > > > > > > > I think the concept of this change makes sense, but I don't like > > the > > > > > implicit connection of PCI_ERR_ROOT_UNCOR_RCV -> AER_NONFATAL -> > > > > > pci_channel_io_normal. That makes it harder than it should be to > > > > read > > > > > the code. > > > > > > > > > > What would you think of changing the signature of do_recovery() > > and > > > > > broadcast_error_message() so they take the struct aer_err_info > > > > pointer > > > > > instead of just the severity and pci_channel_state? Then we > > could > > > > > check directly for AER_NONFATAL here. > > > > > > I think the main issue of this approach is > > > aer_recover_work_func()->do_recovery() > > > If we modify the signature of do_recovery() we also need to modify > > > struct aer_recover_entry to embed aer_err_info sub struct (and anyway > > > so far there is no hook to aer_err_info in ghes.c...so it seems to > > > me like unfeasible...) > > > > > > I think we can either add a severity field to > > broadcast_error_message() > > > or move > > > > > > enum pci_channel_state state; > > > > > > if (severity == AER_FATAL) > > > state = pci_channel_io_frozen; > > > else > > > state = pci_channel_io_normal; > > > > > > inside broadcast_error_message() > > > > > > In both cases we make the code more readable but we add redundancy... > > > Thoughts? > > > > Hmmm, it's not as simple to solve as I hoped. > > > > The "native" Linux AER driver reads registers directly from the AER > > capability, produces logs, and does some recovery. > > > > From 100 miles away, APEI is basically a way for the platform (i.e., > > firmware or manageability software) to insert itself in the middle: > > *it* reads the AER registers, does whatever it wants to do (e.g., > > OS-independent logging), and then passes a copy of the AER capability > > (and the PCIe capability for good measure) on to the OS via APEI. > > > > The Linux APEI code then stuffs that AER info into the native Linux > > AER path where we do our own recovery. > > > > So we basically have two entry points to the Linux AER code: (1) the > > get_device_error_info() path that reads the AER registers directly, > > and (2) the APEI path that gets the AER register info from the > > firmware. > > > > In my mind, these paths ought to be far more unified than they are. > > The transition from APEI to the native Linux AER code throws away > > almost all the information we got from the platform: > > aer_recover_work_func() in the APEI path gets a copy of the AER > > capability, but all it passes to do_recovery() in the native AER code > > is "severity" -- a single int. > > > > I think we should revamp the native AER code so it collects the AER > > register info a little higher up, maybe in aer_isr_one_error() (it's > > kind of stupid that aer_process_err_devices() currently reads the AER > > registers *twice*). > > > > Then we could make the APEI code copy the information we care about > > from the CPER into a struct aer_err_info, then stuff it into > > aer_process_err_devices(). That would have the nice side-effect of > > using exactly the same logging code for both paths (currently the APEI > > path uses cper_print_aer(), while the native path uses > > aer_print_error()). > > > > This is a lot of work. > > I agree (on what to do and, unfortunately, on a lot of work :) ). > However given that this patch fixes a bug I would ask if we can first > accept this patch first and then proceed with the rework...what do > you think? Yes, I think we can do that. Can you repost this with a revised changelog that references the bugzilla? Bjorn