From: Manikandan Karunakaran Pillai <mpillai@cadence.com>
To: Manivannan Sadhasivam <mani@kernel.org>,
"hans.zhang@cixtech.com" <hans.zhang@cixtech.com>
Cc: "bhelgaas@google.com" <bhelgaas@google.com>,
"lpieralisi@kernel.org" <lpieralisi@kernel.org>,
"kw@linux.com" <kw@linux.com>,
"robh@kernel.org" <robh@kernel.org>,
"kwilczynski@kernel.org" <kwilczynski@kernel.org>,
"krzk+dt@kernel.org" <krzk+dt@kernel.org>,
"conor+dt@kernel.org" <conor+dt@kernel.org>,
"fugang.duan@cixtech.com" <fugang.duan@cixtech.com>,
"guoyin.chen@cixtech.com" <guoyin.chen@cixtech.com>,
"peter.chen@cixtech.com" <peter.chen@cixtech.com>,
"cix-kernel-upstream@cixtech.com"
<cix-kernel-upstream@cixtech.com>,
"linux-pci@vger.kernel.org" <linux-pci@vger.kernel.org>,
"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: RE: [PATCH v8 00/15] Enhance the PCIe controller driver for next generation controllers
Date: Mon, 1 Sep 2025 04:28:50 +0000 [thread overview]
Message-ID: <CH2PPF4D26F8E1CF3FCE470256515A96BB8A207A@CH2PPF4D26F8E1C.namprd07.prod.outlook.com> (raw)
In-Reply-To: <epz5rpofsw7yxxz6pga2ja37zl2xwauqxk2j45q4slj35ja27x@nmbaeo2jbdrb>
>
>On Tue, Aug 19, 2025 at 07:52:24PM GMT, hans.zhang@cixtech.com wrote:
>> From: Hans Zhang <hans.zhang@cixtech.com>
>>
>> ---
>> Dear Maintainers,
>>
>> This series is Cadence's HPA PCIe IP and the Root Port driver of our
>> CIX sky1. Please help review. Thank you very much.
>
>IIUC, sky1 only supports RC mode of the Cadence HPA architecture and not EP.
>But
>you have added the library functions for EP mode also and it is currently
>unused. So you should drop those EP related code from this series and add
>whenever the corresponding platform driver is added. It also makes patch 8
>smaller.
>
>- Mani
Hi Mani,
Will remove the EP related code.
- Manikandan
>
>> ---
>>
>> Enhances the exiting Cadence PCIe controller drivers to support
>> HPA (High Performance Architecture) Cadence PCIe controllers.
>>
>> The patch set enhances the Cadence PCIe driver for HPA support.
>> The header files are separated out for legacy and high performance
>> register maps, register address and bit definitions. The driver
>> read register and write register functions for HPA take the
>> updated offset stored from the platform driver to access the registers.
>> As part of refactoring of the code, few new files are added to the
>> driver by splitting the existing files.
>> This helps SoC vendor who change the address map within PCIe controller
>> in their designs. Setting the menuconfig appropriately will allow
>> selection between RP and/or EP PCIe controller support. The support
>> will include Legacy and HPA for the selected configuration.
>>
>> The TI SoC continues to be supported with the changes incorporated.
>>
>> The changes address the review comments in the previous patches where
>> the need to move away from "ops" pointers used in current implementation
>> and separate out the Legacy and HPA driver implementation was stressed.
>>
>> The scripts/checkpatch.pl has been run on the patches with and without
>> --strict. With the --strict option, 4 checks are generated on 3 patch,
>> which can be ignored. There are no code fixes required for these checks.
>> All other checks generated by ./scripts/checkpatch.pl --strict can be
>> ignored.
>>
>> ---
>> Changes for v8
>> - Fixed the error issue of DT binding. (Rob and Krzysztof)
>> - Optimization of CIX SKY1 Root Port driver. (Bjorn and Krzysztof)
>> - Review comments fixed. (Bjorn and Krzysztof)
>> - All comments related fixes like single line comments, spaces
>> between HPA or LGA, periods in single line, changes proposed
>> in the description, etc are fixed. (Bjorn and Krzysztof)
>> - Patches have been split to separate out code moves from
>> update and fixes.
>> - "cdns_...send_irq.." renamed to "cdns_..raise_irq.."
>>
>> The test log on the Orion O6 board is as follows:
>> root@cix-localhost:~# lspci
>> 0000:c0:00.0 PCI bridge: Device 1f6c:0001
>> 0000:c1:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. Device
>8126 (rev 01)
>> 0001:90:00.0 PCI bridge: Device 1f6c:0001
>> 0001:91:00.0 Non-Volatile memory controller: Samsung Electronics Co
>Ltd NVMe SSD Controller PM9A1/PM9A3/980PRO
>> 0002:60:00.0 PCI bridge: Device 1f6c:0001
>> 0002:61:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. Device
>8126 (rev 01)
>> 0003:00:00.0 PCI bridge: Device 1f6c:0001
>> 0003:01:00.0 Network controller: Realtek Semiconductor Co., Ltd.
>RTL8852BE PCIe 802.11ax Wireless Network Controller
>> 0004:30:00.0 PCI bridge: Device 1f6c:0001
>> 0004:31:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd.
>RTL8125 2.5GbE Controller (rev 05)
>> root@cix-localhost:~#
>> root@cix-localhost:~# uname -a
>> Linux cix-localhost 6.17.0-rc2-00043-gb2782ead460c #185 SMP PREEMPT
>Tue Aug 19 19:35:34 CST 2025 aarch64 GNU/Linux
>> root@cix-localhost:~# cat /etc/issue
>> Debian GNU/Linux 12 \n \l
>>
>> Changes for v7
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>pci/cover/20250813042331.1258272-1-
>hans.zhang@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC
>6r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZmCSWnAU$
>>
>> - Rebase to v6.17-rc1.
>> - Fixed the error issue of cix,sky1-pcie-host.yaml make dt_binding_check.
>> - CIX SKY1 Root Port driver compilation error issue: Add header
>> file, Kconfig select PCI_ECAM.
>>
>> Changes for v6
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>pci/cover/20250808072929.4090694-1-
>hans.zhang@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC
>6r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZANqbM0Q$
>>
>> - The IP level DTS changes for HPA have been removed as the SoC
>> level DTS is added
>> - Virtual FPGA platform is also removed as the CiX SoC support is
>> added
>> - Fix the issue of dt bindings
>> - Modify the order of PCIe node attributes in sky1-orion-o6.dts
>> and delete unnecessary attributes.
>> - Continue to simplify the RC driver.
>> - The patch of the Cix Sky1 platform has been accepted and merged into
>the linux master branch.
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>arm-kernel/cover/20250721144500.302202-1-
>peter.chen@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC6
>r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZlJ6xTRU$
>>
>> Changes for v5
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>pci/cover/20250630041601.399921-1-
>hans.zhang@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC
>6r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9Z0zlH-dY$
>>
>> - Header and code files separated for library functions(common
>> functions used by both architectures) and Legacy and HPA.
>> - Few new files added as part of refactoring
>> - No checks for "is_hpa" as the functions have been separated
>> out
>> - Review comments from previous patches have been addressed
>> - Add region 0 for ECAM and region 1 for message.
>> - Add CIX sky1 PCIe drivers. Submissions based on the following v9
>patches:
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>arm-kernel/cover/20250609031627.1605851-1-
>peter.chen@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC6
>r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZKPjlX9o$
>>
>> Cix Sky1 base dts review link to show its review status:
>>
>https://urldefense.com/v3/__https://lore.kernel.org/all/20250609031627.1605
>851-9-
>peter.chen@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC6
>r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZZsu9lqE$
>>
>> The test log on the Orion O6 board is as follows:
>> root@cix-localhost:~# lspci
>> 0000:c0:00.0 PCI bridge: Device 1f6c:0001
>> 0000:c1:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. Device
>8126 (rev 01)
>> 0001:90:00.0 PCI bridge: Device 1f6c:0001
>> 0001:91:00.0 Non-Volatile memory controller: Samsung Electronics Co
>Ltd NVMe SSD Controller PM9A1/PM9A3/980PRO
>> 0002:60:00.0 PCI bridge: Device 1f6c:0001
>> 0002:61:00.0 Network controller: Realtek Semiconductor Co., Ltd.
>RTL8852BE PCIe 802.11ax Wireless Network Controller
>> 0003:00:00.0 PCI bridge: Device 1f6c:0001
>> 0003:01:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. Device
>8126 (rev 01)
>> 0004:30:00.0 PCI bridge: Device 1f6c:0001
>> 0004:31:00.0 Ethernet controller: Realtek Semiconductor Co., Ltd. Device
>8126 (rev 01)
>> root@cix-localhost:~# uname -a
>> Linux cix-localhost 6.16.0-rc1-00023-gbaa962a95a28 #138 SMP PREEMPT
>Fri Jun 27 16:43:41 CST 2025 aarch64 GNU/Linux
>> root@cix-localhost:~# cat /etc/issue
>> Debian GNU/Linux 12 \n \l
>>
>> Changes for v4
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>pci/cover/20250424010445.2260090-1-
>hans.zhang@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC
>6r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZvcO-Ra8$
>>
>> - Add header file bitfield.h to pcie-cadence.h
>> - Addressed the following review comments
>> Merged the TI patch as it
>> Removed initialization of struct variables to '0'
>>
>> Changes for v3
>> https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-
>pci/patch/20250411103656.2740517-1-
>hans.zhang@cixtech.com/__;!!EHscmS1ygiU1lA!Gmyi8ReNNRud3t7ZTRxvGPLC
>6r2Oxv0SpzO-OG8wuhb7zNTE-lwLU_xeq-o0tM1C3i9ZZ1pD1qg$
>>
>> - Patch version v3 added to the subject
>> - Use HPA tag for architecture descriptions
>> - Remove bug related changes to be submitted later as a separate
>> patch
>> - Two patches merged from the last series to ensure readability to
>> address the review comments
>> - Fix several description related issues, coding style issues and
>> some misleading comments
>> - Remove cpu_addr_fixup() functions
>> ---
>>
>> Hans Zhang (6):
>> dt-bindings: PCI: Add CIX Sky1 PCIe Root Complex bindings
>> PCI: Add Cix Technology Vendor and Device ID
>> PCI: sky1: Add PCIe host support for CIX Sky1
>> MAINTAINERS: add entry for CIX Sky1 PCIe driver
>> arm64: dts: cix: Add PCIe Root Complex on sky1
>> arm64: dts: cix: Enable PCIe on the Orion O6 board
>>
>> Manikandan K Pillai (9):
>> PCI: cadence: Add module support for platform controller driver
>> PCI: cadence: Split PCIe controller header file
>> PCI: cadence: Add register definitions for High Perf Architecture
>> (HPA)
>> PCI: cadence: Add helper functions for supporting High Perf
>> Architecture (HPA)
>> PCI: cadence: Move PCIe EP common functions to a separate file
>> PCI: cadence: Move PCIe RP common functions to a separate file
>> PCI: cadence: Move PCIe controller common functions as a separate file
>> PCI: cadence: Add support for High Perf Architecture (HPA) controller
>> PCI: cadence: Update PCIe platform to use register offsets passed
>>
>> .../bindings/pci/cix,sky1-pcie-host.yaml | 83 +++
>> MAINTAINERS | 7 +
>> arch/arm64/boot/dts/cix/sky1-orion-o6.dts | 20 +
>> arch/arm64/boot/dts/cix/sky1.dtsi | 126 ++++
>> drivers/pci/controller/cadence/Kconfig | 21 +-
>> drivers/pci/controller/cadence/Makefile | 11 +-
>> drivers/pci/controller/cadence/pci-sky1.c | 232 +++++++
>> .../controller/cadence/pcie-cadence-common.c | 141 +++++
>> .../cadence/pcie-cadence-ep-common.c | 251 ++++++++
>> .../cadence/pcie-cadence-ep-common.h | 36 ++
>> .../controller/cadence/pcie-cadence-ep-hpa.c | 528 ++++++++++++++++
>> .../pci/controller/cadence/pcie-cadence-ep.c | 233 +------
>> .../cadence/pcie-cadence-host-common.c | 179 ++++++
>> .../cadence/pcie-cadence-host-common.h | 24 +
>> .../cadence/pcie-cadence-host-hpa.c | 585 ++++++++++++++++++
>> .../controller/cadence/pcie-cadence-host.c | 156 +----
>> .../cadence/pcie-cadence-hpa-regs.h | 182 ++++++
>> .../pci/controller/cadence/pcie-cadence-hpa.c | 204 ++++++
>> .../cadence/pcie-cadence-lga-regs.h | 228 +++++++
>> .../controller/cadence/pcie-cadence-plat.c | 20 +-
>> drivers/pci/controller/cadence/pcie-cadence.c | 139 +----
>> drivers/pci/controller/cadence/pcie-cadence.h | 412 ++++++------
>> include/linux/pci_ids.h | 3 +
>> 23 files changed, 3056 insertions(+), 765 deletions(-)
>> create mode 100644 Documentation/devicetree/bindings/pci/cix,sky1-pcie-
>host.yaml
>> create mode 100644 drivers/pci/controller/cadence/pci-sky1.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-common.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-ep-
>common.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-ep-
>common.h
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-ep-hpa.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-host-
>common.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-host-
>common.h
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-host-hpa.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-hpa-regs.h
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-hpa.c
>> create mode 100644 drivers/pci/controller/cadence/pcie-cadence-lga-regs.h
>>
>>
>> base-commit: be48bcf004f9d0c9207ff21d0edb3b42f253829e
>> --
>> 2.49.0
>>
>
>--
>மணிவண்ணன் சதாசிவம்
prev parent reply other threads:[~2025-09-01 5:19 UTC|newest]
Thread overview: 39+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-08-19 11:52 [PATCH v8 00/15] Enhance the PCIe controller driver for next generation controllers hans.zhang
2025-08-19 11:52 ` [PATCH v8 01/15] PCI: cadence: Add module support for platform controller driver hans.zhang
2025-08-19 11:52 ` [PATCH v8 02/15] PCI: cadence: Split PCIe controller header file hans.zhang
2025-08-19 11:52 ` [PATCH v8 03/15] PCI: cadence: Add register definitions for High Perf Architecture (HPA) hans.zhang
2025-08-19 17:36 ` ALOK TIWARI
2025-08-20 8:14 ` Manikandan Karunakaran Pillai
2025-08-19 11:52 ` [PATCH v8 04/15] PCI: cadence: Add helper functions for supporting " hans.zhang
2025-08-19 11:52 ` [PATCH v8 05/15] PCI: cadence: Move PCIe EP common functions to a separate file hans.zhang
2025-08-19 17:46 ` ALOK TIWARI
2025-08-19 11:52 ` [PATCH v8 06/15] PCI: cadence: Move PCIe RP " hans.zhang
2025-08-30 10:36 ` Manivannan Sadhasivam
2025-09-01 4:30 ` Manikandan Karunakaran Pillai
2025-08-19 11:52 ` [PATCH v8 07/15] PCI: cadence: Move PCIe controller common functions as " hans.zhang
2025-08-30 11:21 ` Manivannan Sadhasivam
2025-09-01 4:30 ` Manikandan Karunakaran Pillai
2025-08-19 11:52 ` [PATCH v8 08/15] PCI: cadence: Add support for High Perf Architecture (HPA) controller hans.zhang
2025-08-26 12:08 ` kernel test robot
2025-08-30 13:18 ` Manivannan Sadhasivam
2025-09-01 4:34 ` Manikandan Karunakaran Pillai
2025-08-19 11:52 ` [PATCH v8 09/15] PCI: cadence: Update PCIe platform to use register offsets passed hans.zhang
2025-08-19 11:52 ` [PATCH v8 10/15] dt-bindings: PCI: Add CIX Sky1 PCIe Root Complex bindings hans.zhang
2025-08-20 7:23 ` Krzysztof Kozlowski
2025-08-19 11:52 ` [PATCH v8 11/15] PCI: Add Cix Technology Vendor and Device ID hans.zhang
2025-08-30 13:20 ` Manivannan Sadhasivam
2025-08-30 13:21 ` Manivannan Sadhasivam
2025-09-01 3:03 ` Hans Zhang
2025-08-19 11:52 ` [PATCH v8 12/15] PCI: sky1: Add PCIe host support for CIX Sky1 hans.zhang
2025-08-30 13:29 ` Manivannan Sadhasivam
2025-09-01 3:04 ` Hans Zhang
2025-08-19 11:52 ` [PATCH v8 13/15] MAINTAINERS: add entry for CIX Sky1 PCIe driver hans.zhang
2025-08-19 11:52 ` [PATCH v8 14/15] arm64: dts: cix: Add PCIe Root Complex on sky1 hans.zhang
2025-08-30 13:31 ` Manivannan Sadhasivam
2025-09-01 3:09 ` Hans Zhang
2025-08-19 11:52 ` [PATCH v8 15/15] arm64: dts: cix: Enable PCIe on the Orion O6 board hans.zhang
2025-08-30 13:33 ` Manivannan Sadhasivam
2025-09-01 3:14 ` Hans Zhang
2025-09-01 3:17 ` Hans Zhang
2025-08-30 13:38 ` [PATCH v8 00/15] Enhance the PCIe controller driver for next generation controllers Manivannan Sadhasivam
2025-09-01 4:28 ` Manikandan Karunakaran Pillai [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CH2PPF4D26F8E1CF3FCE470256515A96BB8A207A@CH2PPF4D26F8E1C.namprd07.prod.outlook.com \
--to=mpillai@cadence.com \
--cc=bhelgaas@google.com \
--cc=cix-kernel-upstream@cixtech.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=fugang.duan@cixtech.com \
--cc=guoyin.chen@cixtech.com \
--cc=hans.zhang@cixtech.com \
--cc=krzk+dt@kernel.org \
--cc=kw@linux.com \
--cc=kwilczynski@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=lpieralisi@kernel.org \
--cc=mani@kernel.org \
--cc=peter.chen@cixtech.com \
--cc=robh@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).