On Thu, Jun 21, 2018 at 02:46:10PM +0530, poza@xxxxxxxxxxxxxx wrote: > On 2018-06-21 03:08, Keith Busch wrote: > > @@ -185,6 +187,10 @@ static void dpc_work(struct work_struct *work) > > /* show RP PIO error detail information */ > > if (dpc->rp_extensions && reason == 3 && ext_reason == 0) > > dpc_process_rp_pio_error(dpc); > > + else if (reason == 0 && aer_get_device_error_info(pdev, &info)) { > > + aer_print_error(pdev, &info); > > + pci_cleanup_aer_uncorrect_error_status(pdev); > > 6.2.10 for Downstream Port Containment: > > When DPC is triggered due to receipt of an uncorrectable error Message, > the Requester ID from the Message is recorded in the DPC Error > Source ID register and that Message is discarded and not forwarded > Upstream. When DPC is triggered by an unmasked uncorrectable error, > that error will not be signaled with an uncorrectable error Message, > even if otherwise enabled. > > Inst the message is discarded and not forwarded to upstream. > which means that we should not find AER status set in RP or Switch. > in other words, at time either we will find DPC or AER triggered but not > both at the same time. > then when DPC is triggered why do we need to > pci_cleanup_aer_uncorrect_error_status(pdev); ? According to the sequence diagram in 6.2.5, an uncorrectable error has the cooresponding bits set in the Device Status and AER Uncorrectable Error Status registers before DPC specifics are considered. DPC just suppresses the ERR_[NON]FATAL messages, but the detecting ports AER status, if implemented, should reflect what occured.