From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mx0a-001b2d01.pphosted.com (mx0a-001b2d01.pphosted.com [148.163.156.1]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by lists.ozlabs.org (Postfix) with ESMTPS id 3rgmqf6NSdzDqlg for ; Fri, 1 Jul 2016 16:35:10 +1000 (AEST) Received: from pps.filterd (m0098394.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.11/8.16.0.11) with SMTP id u616XTe1116111 for ; Fri, 1 Jul 2016 02:35:09 -0400 Received: from e23smtp04.au.ibm.com (e23smtp04.au.ibm.com [202.81.31.146]) by mx0a-001b2d01.pphosted.com with ESMTP id 23wag0efme-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Fri, 01 Jul 2016 02:35:08 -0400 Received: from localhost by e23smtp04.au.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Fri, 1 Jul 2016 16:35:06 +1000 Received: from d23relay08.au.ibm.com (d23relay08.au.ibm.com [9.185.71.33]) by d23dlp02.au.ibm.com (Postfix) with ESMTP id 9EB0B2BB0054 for ; Fri, 1 Jul 2016 16:35:02 +1000 (EST) Received: from d23av06.au.ibm.com (d23av06.au.ibm.com [9.190.235.151]) by d23relay08.au.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id u616Z2md18940154 for ; Fri, 1 Jul 2016 16:35:02 +1000 Received: from d23av06.au.ibm.com (localhost [127.0.0.1]) by d23av06.au.ibm.com (8.14.4/8.14.4/NCO v10.0 AVout) with ESMTP id u616Z2Oc002401 for ; Fri, 1 Jul 2016 16:35:02 +1000 Subject: Re: [PATCH v3 3/7] PCI: Do not disable memory decoding in pci_reassigndev_resource_alignment() To: Gavin Shan References: <1467283993-3185-1-git-send-email-xyjxie@linux.vnet.ibm.com> <1467283993-3185-4-git-send-email-xyjxie@linux.vnet.ibm.com> <20160701005036.GA18999@gwshan> Cc: nikunj@linux.vnet.ibm.com, zhong@linux.vnet.ibm.com, linux-doc@vger.kernel.org, aik@ozlabs.ru, linux-pci@vger.kernel.org, corbet@lwn.net, linux-kernel@vger.kernel.org, warrier@linux.vnet.ibm.com, alex.williamson@redhat.com, paulus@samba.org, bhelgaas@google.com, linuxppc-dev@lists.ozlabs.org From: Yongji Xie Date: Fri, 1 Jul 2016 14:35:04 +0800 MIME-Version: 1.0 In-Reply-To: <20160701005036.GA18999@gwshan> Content-Type: text/plain; charset=utf-8; format=flowed Message-Id: List-Id: Linux on PowerPC Developers Mail List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Hi Gavin, On 2016/7/1 8:50, Gavin Shan wrote: > On Thu, Jun 30, 2016 at 06:53:09PM +0800, Yongji Xie wrote: >> We should not disable memory decoding when we reassign alignment >> in pci_reassigndev_resource_alignment(). It's meaningless and >> have some side effect. For example, some fixup functions such as >> quirk_e100_interrupt() read PCI_COMMAND_MEMORY to know whether >> the devices has been initialized by the firmware or not. If we >> disable memory decoding here, these functions will get a wrong >> information that the devices was not initialized by the firmware >> which may cause a wrong fixup. Besides, disabling memory decoding >> may also break some devices that need to have memory decoding >> always-on during probing. >> > It seems the changelog isn't correct enough if it's talking about > below check in code: > > if (!(command & PCI_COMMAND_MEMORY) || !pci_resource_start(dev, 0)) > return; Could you give me more details? It seems that we couldn't disable e100 interrupts which enabled by some firmware if we disabling memory decoding here. >> Signed-off-by: Yongji Xie >> --- >> drivers/pci/pci.c | 8 +------- >> 1 file changed, 1 insertion(+), 7 deletions(-) >> >> diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c >> index 6ae02de..6241cfc 100644 >> --- a/drivers/pci/pci.c >> +++ b/drivers/pci/pci.c >> @@ -4820,7 +4820,6 @@ void pci_reassigndev_resource_alignment(struct pci_dev *dev) >> int i; >> struct resource *r; >> resource_size_t align, size; >> - u16 command; >> >> /* We should never try to reassign VF's alignment */ >> if (dev->is_virtfn) >> @@ -4838,12 +4837,7 @@ void pci_reassigndev_resource_alignment(struct pci_dev *dev) >> return; >> } >> >> - dev_info(&dev->dev, >> - "Disabling memory decoding and releasing memory resources.\n"); >> - pci_read_config_word(dev, PCI_COMMAND, &command); >> - command &= ~PCI_COMMAND_MEMORY; >> - pci_write_config_word(dev, PCI_COMMAND, command); >> - >> + dev_info(&dev->dev, "Releasing memory resources.\n"); > Is there a problem you found with PCI_COMMAND removed? If so, could you > please share more details, thanks. Disabling memory decoding may break some devices which have flag mmio_always_on. Besides the mmio_always_on case, I also found this would break some P2P bridge such as PEX 8718 controller. Thanks, Yongji