Patch "PCI: qcom-ep: Move controller cleanups to qcom_pcie_perst_deassert()" has been added to the 6.11-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    PCI: qcom-ep: Move controller cleanups to qcom_pcie_perst_deassert()

to the 6.11-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     pci-qcom-ep-move-controller-cleanups-to-qcom_pcie_pe.patch
and it can be found in the queue-6.11 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit e876761a78dcd42a3e2b8743f7833684c7ed09f7
Author: Manivannan Sadhasivam <manivannan.sadhasivam@xxxxxxxxxx>
Date:   Sat Aug 17 11:09:03 2024 +0530

    PCI: qcom-ep: Move controller cleanups to qcom_pcie_perst_deassert()
    
    [ Upstream commit 7d7cf89b119af433354f865fc01017b9f8aa411a ]
    
    Currently, the endpoint cleanup function dw_pcie_ep_cleanup() and EPF
    deinit notify function pci_epc_deinit_notify() are called during the
    execution of qcom_pcie_perst_assert() i.e., when the host has asserted
    PERST#. But quickly after this step, refclk will also be disabled by the
    host.
    
    All of the Qcom endpoint SoCs supported as of now depend on the refclk from
    the host for keeping the controller operational. Due to this limitation,
    any access to the hardware registers in the absence of refclk will result
    in a whole endpoint crash. Unfortunately, most of the controller cleanups
    require accessing the hardware registers (like eDMA cleanup performed in
    dw_pcie_ep_cleanup(), powering down MHI EPF etc...). So these cleanup
    functions are currently causing the crash in the endpoint SoC once host
    asserts PERST#.
    
    One way to address this issue is by generating the refclk in the endpoint
    itself and not depending on the host. But that is not always possible as
    some of the endpoint designs do require the endpoint to consume refclk from
    the host (as I was told by the Qcom engineers).
    
    Thus, fix this crash by moving the controller cleanups to the start of
    the qcom_pcie_perst_deassert() function. qcom_pcie_perst_deassert() is
    called whenever the host has deasserted PERST# and it is guaranteed that
    the refclk would be active at this point. So at the start of this function
    (after enabling resources), the controller cleanup can be performed. Once
    finished, rest of the code execution for PERST# deassert can continue as
    usual.
    
    Fixes: 473b2cf9c4d1 ("PCI: endpoint: Introduce 'epc_deinit' event and notify the EPF drivers")
    Fixes: 570d7715eed8 ("PCI: dwc: ep: Introduce dw_pcie_ep_cleanup() API for drivers supporting PERST#")
    Link: https://lore.kernel.org/r/20240817-pci-qcom-ep-cleanup-v1-1-d6b958226559@xxxxxxxxxx
    Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@xxxxxxxxxx>
    Signed-off-by: Krzysztof Wilczyński <kwilczynski@xxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/drivers/pci/controller/dwc/pcie-qcom-ep.c b/drivers/pci/controller/dwc/pcie-qcom-ep.c
index c8bb7cd89678f..a7f65d50d4ebb 100644
--- a/drivers/pci/controller/dwc/pcie-qcom-ep.c
+++ b/drivers/pci/controller/dwc/pcie-qcom-ep.c
@@ -395,6 +395,10 @@ static int qcom_pcie_perst_deassert(struct dw_pcie *pci)
 		return ret;
 	}
 
+	/* Perform cleanup that requires refclk */
+	pci_epc_deinit_notify(pci->ep.epc);
+	dw_pcie_ep_cleanup(&pci->ep);
+
 	/* Assert WAKE# to RC to indicate device is ready */
 	gpiod_set_value_cansleep(pcie_ep->wake, 1);
 	usleep_range(WAKE_DELAY_US, WAKE_DELAY_US + 500);
@@ -534,8 +538,6 @@ static void qcom_pcie_perst_assert(struct dw_pcie *pci)
 {
 	struct qcom_pcie_ep *pcie_ep = to_pcie_ep(pci);
 
-	pci_epc_deinit_notify(pci->ep.epc);
-	dw_pcie_ep_cleanup(&pci->ep);
 	qcom_pcie_disable_resources(pcie_ep);
 	pcie_ep->link_status = QCOM_PCIE_EP_LINK_DISABLED;
 }




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux