Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp1303646imm; Tue, 3 Jul 2018 08:51:29 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfxAcXX/mLKfl9sRn954dU0tc0ZRaTRS++pcIiNI3pwQi+7B84ZoWptQ/+NuZCeQnk5B2/O X-Received: by 2002:a63:3509:: with SMTP id c9-v6mr18494304pga.237.1530633088999; Tue, 03 Jul 2018 08:51:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530633088; cv=none; d=google.com; s=arc-20160816; b=DDk4e4ZUzwazba4K4S9Ks4+GnJIrOynBmIIF1FozqnPs1cTfk9DMaQ9pufa2v474qj wTBRT9jmsBtPidOJtZf/K+vL/CxPnt0P+8MmOhokMeGFbIPoYyAWV9TY07wOtV44t+qt txe74R08HKKUC9i/aQh38QLZW/8K0vL8sSJZgn2vNvU+Aleyap4nPjhD+KKCT9hDl//M nU/w9Wp1LXvvOBRrxfTiEuiSMfVKo8zu/c1c35dNQLX0BZtT4m9FFCHh25qG3p6jUOmg NU0zRP6drF8m6Eq33JczKCdRnMMoAgXucIlkZl9fIsMMS9RksCx9Pvz9YvHQzggHdGVe yCbw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=BuqBtehi3mL6tlC34xChbyvla9nADnNhkowAY9OSsg4=; b=DK5gKwXeR7O39TAkw18NrGhoJ7Ew9OeHPSYF9j8oJaPH25nwY5AWDWHU+q4WmL3oPP aguPT0HihsC4lpHS8MpAAUf3BBVyd8Q0ic5WvBJN8ac4OKtFu5e6YRC2Zp6hkrDeNWw+ Hfzaj+nLBKwXUvb9Jtc/GzAFQzxkAKJGkT/y+4tN17pMxXxH7TL7J+oAzjCEdZziLjR1 SXsC7l86HFezjSsJEu5ThFYHadQ679sFrCYRlln9hKqZ0Hx4c7RxLtPfhMSguJXBkS8M Xr5x269imIz/95YHn57yZ3uluWZ5MySh8vN0fogerxExHUbNQOWcI8H0HmzidZE8Vfa8 IsHQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=Q+LIukTk; dkim=pass header.i=@codeaurora.org header.s=default header.b=hys9Bi+6; 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 d18-v6si1142165pgv.248.2018.07.03.08.51.14; Tue, 03 Jul 2018 08:51:28 -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; dkim=pass header.i=@codeaurora.org header.s=default header.b=Q+LIukTk; dkim=pass header.i=@codeaurora.org header.s=default header.b=hys9Bi+6; 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 S932965AbeGCPtw (ORCPT + 99 others); Tue, 3 Jul 2018 11:49:52 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:45478 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752905AbeGCPtu (ORCPT ); Tue, 3 Jul 2018 11:49:50 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 4D1AD601A8; Tue, 3 Jul 2018 15:49:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1530632990; bh=5Zy6B5pUlaqsWFf8tqUNa8Z981ARt3SA3eKTk1RWR6Y=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=Q+LIukTkMMAj8/Wb+WCqX/F82KDLzxxXUla6CWwfkG3QyjSPR9DAJnx1hMUWI7YUo 29mJ0Y4YFUeRQGNdYdtntDdBa+AXTBis2q7XbxmM7W5n9UIijl8ozI1K7udxTP0Dd0 TWPd0SScoH2MIbpX9kTgdRGfAGScFWbIUnbroURk= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.0.117] (cpe-174-109-247-98.nc.res.rr.com [174.109.247.98]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: okaya@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 7C1EA601A8; Tue, 3 Jul 2018 15:49:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1530632989; bh=5Zy6B5pUlaqsWFf8tqUNa8Z981ARt3SA3eKTk1RWR6Y=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=hys9Bi+6rd9DiQoQHj2rLnrodeJdCvlsS0DIHaKIRd/Y93jArUWHgxVaofApkB8y3 Eo8htqP5WTEx0u6hHVZjYCm3fYYP9I5isBCPFBn52HwaZ7HptfjT/JM+iybkiWYwqg dmVRwL7sBDROlINMSyy9ZbPmLQSwdQK2lfS6pLSU= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 7C1EA601A8 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=okaya@codeaurora.org Subject: Re: [PATCH V5 3/3] PCI: Mask and unmask hotplug interrupts during reset To: poza@codeaurora.org, Lukas Wunner Cc: linux-pci@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Bjorn Helgaas , Keith Busch , open list References: <1530571967-19099-1-git-send-email-okaya@codeaurora.org> <1530571967-19099-4-git-send-email-okaya@codeaurora.org> <20180703143434.GA4086@wunner.de> From: Sinan Kaya Message-ID: <867e1f69-8b77-ecb0-d4e3-ab0636a49a2e@codeaurora.org> Date: Tue, 3 Jul 2018 11:49:47 -0400 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 7/3/2018 11:12 AM, poza@codeaurora.org wrote: > if (!pci_probe_reset_slot(dev->slot)) > { >     pci_reset_slot(dev->slot) >     result = reset_link(udev, service); >> in this case aer_root_reset must not call pci_reset_bridge_secondary_bus() > } else >     result = reset_link(udev, service); >> in this case aer_root_reset must call pci_reset_bridge_secondary_bus() [since bridge is not hotplug capable) Here are two different flow for two different FATAL error sources dpc_irq link is down due to DPC pcie_do_fatal_recovery() pci_reset_slot() mask hotplug IRQ secondary bus reset unmask hotplug IRQ undefined behavior as link went down due to DPC dpc_reset_link() undefined behavior secondary bus reset happened while a DPC event is pending link may or may not be up at this moment recover the link via DPC way if HW can cope with this undefined behavior. aer_irq link is up pcie_do_fatal_recovery() pci_reset_slot() mask hotplug IRQ secondary bus reset unmask hotplug IRQ link goes up aer_reset_link() secondary bus reset hotplug link down interrupt again I tried to change pci_reset_slot() such that we do mask hotplug IRQ go to AER/DPC reset_link based on error source unmask hotplug IRQ -- Sinan Kaya Qualcomm Datacenter Technologies, Inc. as an affiliate of Qualcomm Technologies, Inc. Qualcomm Technologies, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project.