Received: by 10.213.65.68 with SMTP id h4csp82248imn; Mon, 12 Mar 2018 07:25:03 -0700 (PDT) X-Google-Smtp-Source: AG47ELvU1Kkp8ASLqge5hl2mcAmcn7nNRBns+Ne0OOs6dREo+i7acpX2jBVKL0YiAqPIVAWE+6g+ X-Received: by 2002:a17:902:b582:: with SMTP id a2-v6mr8543405pls.353.1520864703423; Mon, 12 Mar 2018 07:25:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520864703; cv=none; d=google.com; s=arc-20160816; b=eiANr/XDhkTOyeTvt+OwYjYdP/bLoFCgsHDFdW7xwauYQNWQHeeqTiinbFy9grdpcc 4nrpe0I85bjfKJMbSv+Q46exbX2UQ3stuiJu77UWcT69cCFDekcGUbb01OXFdZoRKl1I NHfGzUdomKoFAJJYd6nEKhEsbm+0T2DVC6WEdori+MV+FUaGU254svADWeHkJIKHPNDx 3BgKBDEGXaA7HhQWIqKHMnIDi2JT3Pd3Jd9FBydqM2QMhyEsRmtXsNDbtkYImItOdcZG iRKm6TspDgnNvwrC1tktdw/xc3nCpWTgHlaxgKYqu7vnIvWz5n4XxfshTQznB2/ac3is +R4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=uLWKxM9fdc1s78BbhkPVaVquZYATVBZ1bnxFF0Osy9Y=; b=O4QCc6Gd6LMf/IyA7Tpy3Mg/cbPt5u2eKlJOX/3H+q0IZuIxxIzmfG3ah1CPCu4r72 3CUuuCpQShwqL252XIlpgTFb/4ty/Y4wietPw+EmfZ40ZhDX1fSexC2CHJOizGrWe0/K 7GqJvbblmYoX5uLWL/ePc7K1lZLMgxKsdfgTRzXAvJepDOmjv0ryDIXilijER5S0MG8e CDnAabjjAqUSBlG7kO1tbLY7gEKLxchkDHyheCJAg+CBEciCl6b0NPA1mNZBInXT99Mj ZK5BK7PBhe9GM41oOXQPdi0Pa7eWqDv/pj+haYKI+2ZEUgcjtGfNP3isalnDOlH7EhkC ixRw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s126si1875024pgc.477.2018.03.12.07.24.48; Mon, 12 Mar 2018 07:25:03 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751473AbeCLOX7 (ORCPT + 99 others); Mon, 12 Mar 2018 10:23:59 -0400 Received: from mga09.intel.com ([134.134.136.24]:49356 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751255AbeCLOX5 (ORCPT ); Mon, 12 Mar 2018 10:23:57 -0400 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False Received: from orsmga002.jf.intel.com ([10.7.209.21]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 12 Mar 2018 07:23:57 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,461,1515484800"; d="scan'208";a="41253301" Received: from unknown (HELO localhost.localdomain) ([10.232.112.44]) by orsmga002.jf.intel.com with ESMTP; 12 Mar 2018 07:23:56 -0700 Date: Mon, 12 Mar 2018 08:25:51 -0600 From: Keith Busch To: Sinan Kaya Cc: Bjorn Helgaas , Oza Pawandeep , Bjorn Helgaas , Philippe Ombredanne , Thomas Gleixner , Greg Kroah-Hartman , Kate Stewart , linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Dongdong Liu , Wei Zhang , Timur Tabi Subject: Re: [PATCH v12 0/6] Address error and recovery for AER and DPC Message-ID: <20180312142551.GB18494@localhost.localdomain> References: <1519837457-3596-1-git-send-email-poza@codeaurora.org> <20180311220337.GA194000@bhelgaas-glaptop.roam.corp.google.com> <04ade52e-d1ea-fe67-bb26-246621d159e6@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <04ade52e-d1ea-fe67-bb26-246621d159e6@codeaurora.org> User-Agent: Mutt/1.9.1 (2017-09-22) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Mar 11, 2018 at 11:03:58PM -0400, Sinan Kaya wrote: > On 3/11/2018 6:03 PM, Bjorn Helgaas wrote: > > On Wed, Feb 28, 2018 at 10:34:11PM +0530, Oza Pawandeep wrote: > > > That difference has been there since the beginning of DPC, so it has > > nothing to do with *this* series EXCEPT for the fact that it really > > complicates the logic you're adding to reset_link() and > > broadcast_error_message(). > > > > We ought to be able to simplify that somehow because the only real > > difference between AER and DPC should be that DPC automatically > > disables the link and AER does it in software. > > I agree this should be possible. Code execution path should be almost > identical to fatal error case. > > Is there any reason why you went to stop driver path, Keith? The fact is the link is truly down during a DPC event. When the link is enabled again, you don't know at that point if the device(s) on the other side have changed. Calling a driver's error handler for the wrong device in an unknown state may have undefined results. Enumerating the slot from scratch should be safe, and will assign resources, tune bus settings, and bind to the matching driver. Per spec, DPC is the recommended way for handling surprise removal events and even recommends DPC capable slots *not* set 'Surprise' in Slot Capabilities so that removals are always handled by DPC. This service driver was developed with that use in mind.