Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2528555ybc; Mon, 18 Nov 2019 00:00:48 -0800 (PST) X-Google-Smtp-Source: APXvYqz3w6x+EAw02f7Biqa0TKqyfPTC49CiHyOq3MiyNloIr1Ewiync0x3OyfivyrboXSrKN5RH X-Received: by 2002:ac2:5089:: with SMTP id f9mr9943812lfm.89.1574064048625; Mon, 18 Nov 2019 00:00:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574064048; cv=none; d=google.com; s=arc-20160816; b=UJOg1vwXKuDVlKLwHmpiOeqVZ8DJBXycSKmGeTy9ye69pgsxZe5vCFiRUgalVadm5p eZrzKAX2p2HeZRpYrtNIthvKpUPmg3KvuPpRNwWKOlHT9ZX0lYOCDWDduIGBqPpN1Jou MHn0g4oHlAp/FPkzqUAbeCcNMur0OWOiOJS1BqFgf8jv1XaMBgrh2ZBimEn3jSKfAX5X YbmjLjTONRpkp3RQQCczk0XQZrfeczVdc8lRPnx1aCWx0M5ZjD+kjb5EhCbJ7KK/cZlF DQeVaqgNe1TqLiEkxcIj5X21sxHOrxlnC77IukygvZpKcJpcqlz54gEdvrrbKcD1eBlS frWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=lEhuBY2nXRRWlQnAtrwA+g8dLWlMM0JGf6Brg1zGw/o=; b=XnS5zli4RXeD4rhBz4v/LjXhOiJl3xmoqhAW6GUvNnIOQcv7ZDLqjlXi9bQpHd4/5e q5KG2LjP59/JxAZTLUfE5FhzLmFOlUf1vxeghmSYpid63ZeuedgCL+qypGIRyr2OAWNm Sm5Adq2GuysOjPZDUfvWLM/xCvmJsDfW3IfVedXNvzc9QtsOmNjCNY2iba/yqhnwNARR dF7B8Te4U2kktDEtACa/rMjv+oefWke8HwCnXl65LVNXHpGseBOmT8OhD9JdHh/kiCMn ooxvK5hqjM7ZAzH6QE+7KCgFVa9aGbNAC78nbiZkxGzViTzqbxMkUwm5O4WF5MP54+nK R4wA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i7si11647956edx.107.2019.11.18.00.00.25; Mon, 18 Nov 2019 00:00:48 -0800 (PST) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726607AbfKRH67 (ORCPT + 99 others); Mon, 18 Nov 2019 02:58:59 -0500 Received: from mga09.intel.com ([134.134.136.24]:49378 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726283AbfKRH67 (ORCPT ); Mon, 18 Nov 2019 02:58:59 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 17 Nov 2019 23:58:58 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.68,319,1569308400"; d="scan'208";a="356706254" Received: from linux.intel.com ([10.54.29.200]) by orsmga004.jf.intel.com with ESMTP; 17 Nov 2019 23:58:58 -0800 Received: from [10.226.38.242] (unknown [10.226.38.242]) by linux.intel.com (Postfix) with ESMTP id 095EC5804A0; Sun, 17 Nov 2019 23:58:54 -0800 (PST) Subject: Re: [PATCH v7 2/3] dwc: PCI: intel: PCIe RC controller driver To: Jingoo Han , "gustavo.pimentel@synopsys.com" , "lorenzo.pieralisi@arm.com" , "andrew.murray@arm.com" , "helgaas@kernel.org" , "robh@kernel.org" , "martin.blumenstingl@googlemail.com" , "linux-pci@vger.kernel.org" , "devicetree@vger.kernel.org" , "andriy.shevchenko@intel.com" Cc: "linux-kernel@vger.kernel.org" , "cheol.yong.kim@intel.com" , "chuanhua.lei@linux.intel.com" , "qi-ming.wu@intel.com" References: <99a29f5a4ce18df26bd300ac6728433ec025631b.1573784557.git.eswara.kota@linux.intel.com> From: Dilip Kota Message-ID: <50dabbc6-eae5-5ae5-95a0-f195c1ef7362@linux.intel.com> Date: Mon, 18 Nov 2019 15:58:53 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/16/2019 4:40 AM, Jingoo Han wrote: > On 11/14/19, 9:31 PM, Dilip Kota wrote: > >> Add support to PCIe RC controller on Intel Gateway SoCs. >> PCIe controller is based of Synopsys DesignWare PCIe core. >> >> Intel PCIe driver requires Upconfigure support, Fast Training >> Sequence and link speed configurations. So adding the respective >> helper functions in the PCIe DesignWare framework. >> It also programs hardware autonomous speed during speed >> configuration so defining it in pci_regs.h. >> >> Signed-off-by: Dilip Kota >> Reviewed-by: Andrew Murray >> Acked-by: Gustavo Pimentel >> --- > [.....] > >> drivers/pci/controller/dwc/Kconfig | 10 + >> drivers/pci/controller/dwc/Makefile | 1 + >> drivers/pci/controller/dwc/pcie-designware.c | 57 +++ >> drivers/pci/controller/dwc/pcie-designware.h | 12 + >> drivers/pci/controller/dwc/pcie-intel-gw.c | 542 +++++++++++++++++++++++++++ >> include/uapi/linux/pci_regs.h | 1 + >> 6 files changed, 623 insertions(+) >> create mode 100644 drivers/pci/controller/dwc/pcie-intel-gw.c >> >> diff --git a/drivers/pci/controller/dwc/Kconfig b/drivers/pci/controller/dwc/Kconfig >> index 0ba988b5b5bc..fb6d474477df 100644 >> --- a/drivers/pci/controller/dwc/Kconfig >> +++ b/drivers/pci/controller/dwc/Kconfig >> @@ -82,6 +82,16 @@ config PCIE_DW_PLAT_EP >> order to enable device-specific features PCI_DW_PLAT_EP must be >> selected. >> >> +config PCIE_INTEL_GW >> + bool "Intel Gateway PCIe host controller support" >> + depends on OF && (X86 || COMPILE_TEST) >> + select PCIE_DW_HOST >> + help >> + Say 'Y' here to enable PCIe Host controller support on Intel >> + Gateway SoCs. >> + The PCIe controller uses the DesignWare core plus Intel-specific >> + hardware wrappers. >> + > Please add this config alphabetical order! > So, this config should be after 'config PCI_IMX6'. > There is no reason to put this config at the first place. > >> config PCI_EXYNOS >> bool "Samsung Exynos PCIe controller" >> depends on SOC_EXYNOS5440 || COMPILE_TEST >> diff --git a/drivers/pci/controller/dwc/Makefile b/drivers/pci/controller/dwc/Makefile >> index b30336181d46..99db83cd2f35 100644 >> --- a/drivers/pci/controller/dwc/Makefile >> +++ b/drivers/pci/controller/dwc/Makefile >> @@ -3,6 +3,7 @@ obj-$(CONFIG_PCIE_DW) += pcie-designware.o >> obj-$(CONFIG_PCIE_DW_HOST) += pcie-designware-host.o >> obj-$(CONFIG_PCIE_DW_EP) += pcie-designware-ep.o >> obj-$(CONFIG_PCIE_DW_PLAT) += pcie-designware-plat.o >> +obj-$(CONFIG_PCIE_INTEL_GW) += pcie-intel-gw.o > Ditto. PCIE_INTEL_GW wouldnt come after PCI_IMX6, the complete Makefile and Kconfig are not in order,( PCI_* and PCIE_* are not in any order). So i just followed PCIE_DW and placed PCIE_INTEL_GW after PCIE_DW as I is after D (and i see PCI_* immediately after the PCIE_DW*, so i placed PCIE_INTEL_GW after PCIE_DW* and before PCI_*). Regards, Dilip > > Best regards, > Jingoo Han > >> obj-$(CONFIG_PCI_DRA7XX) += pci-dra7xx.o >> obj-$(CONFIG_PCI_EXYNOS) += pci-exynos.o >> obj-$(CONFIG_PCI_IMX6) += pci-imx6.o >> diff --git a/drivers/pci/controller/dwc/pcie-designware.c b/drivers/pci/controller/dwc/pcie-designware.c >> index 820488dfeaed..479e250695a0 100644 > [.....]