[PATCH v7 0/8] PCI: imx6: refine codes and add compliance tests mode support

From: Richard Zhu
Date: Wed Feb 16 2022 - 02:21:13 EST


This series patches refine pci-imx6 driver and do the following changes.
- Encapsulate the clock enable into one standalone function
- Add the error propagation from host_init
- Balance the usage of the regulator and clocks when link never came up
- Add the compliance tests mode support

Main changes from v6 to v7:
- Keep the regulator usage counter balance in the #5 patch

Main changes from v5 to v6:
- Refer to the following discussion with Fabio, fix the dump by his patch.
https://patchwork.kernel.org/project/linux-pci/patch/1641368602-20401-6-git-send-email-hongxing.zhu@xxxxxxx/
Refine and rebase this patch-set after Fabio' dump fix patch is merged.
- Add one new #4 patch to disable i.MX6QDL REF clock too when disable clocks
- Split the regulator refine codes into one standalone patch #5 in this version.

Main changes from v4 to v5:
- Since i.MX8MM PCIe support had been merged. Based on Lorenzo's git repos,
resend the patch-set after rebase.

Main changes from v3 to v4:
- Regarding Mark's comments, delete the regulator_is_enabled() check.
- Squash #3 and #6 of v3 patch into #5 patch of v4 set.

Main changes from v2 to v3:
- Add "Reviewed-by: Lucas Stach <l.stach@xxxxxxxxxxxxxx>" tag into
first two patches.
- Add a Fixes tag into #3 patch.
- Split the #4 of v2 to two patches, one is clock disable codes move,
the other one is the acutal clock unbalance fix.
- Add a new host_exit() callback into dw_pcie_host_ops, then it could be
invoked to handle the unbalance issue in the error handling after
host_init() function when link is down.
- Add a new host_exit() callback for i.MX PCIe driver to handle this case
in the error handling after host_init.

Main changes from v1 to v2:
Regarding Lucas' comments.
- Move the placement of the new imx6_pcie_clk_enable() to avoid the
forward declarition.
- Seperate the second patch of v1 patch-set to three patches.
- Use the module_param to replace the kernel command line.
Regarding Bjorn's comments:
- Use the cover-letter for a multi-patch series.
- Correct the subject line, and refine the commit logs. For example,
remove the timestamp of the logs.

drivers/pci/controller/dwc/pci-imx6.c | 218 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++---------------------------------
drivers/pci/controller/dwc/pcie-designware-host.c | 5 ++-
drivers/pci/controller/dwc/pcie-designware.h | 1 +
3 files changed, 147 insertions(+), 77 deletions(-)

[PATCH v7 1/8] PCI: imx6: Encapsulate the clock enable into one
[PATCH v7 2/8] PCI: imx6: Add the error propagation from host_init
[PATCH v7 3/8] PCI: imx6: Move imx6_pcie_clk_disable() earlier
[PATCH v7 4/8] PCI: imx6: Disable iMX6QDL PCIe REF clock when disable
[PATCH v7 5/8] PCI: imx6: Refine the regulator usage
[PATCH v7 6/8] PCI: dwc: Add dw_pcie_host_ops.host_exit() callback
[PATCH v7 7/8] PCI: imx6: Disable enabled clocks and regulators after
[PATCH v7 8/8] PCI: imx6: Add the compliance tests mode support