[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1E8E4DB773970CB5+5a52c9e1-01b8-4872-99b7-021099f04031@radxa.com>
Date: Tue, 21 Oct 2025 13:26:26 +0900
From: FUKAUMI Naoki <naoki@...xa.com>
To: Niklas Cassel <cassel@...nel.org>,
Lorenzo Pieralisi <lpieralisi@...nel.org>,
Krzysztof WilczyĆski <kw@...ux.com>,
Manivannan Sadhasivam <manivannan.sadhasivam@...aro.org>,
Rob Herring <robh@...nel.org>, Bjorn Helgaas <bhelgaas@...gle.com>,
Heiko Stuebner <heiko@...ech.de>
Cc: Damien Le Moal <dlemoal@...nel.org>, Anand Moon <linux.amoon@...il.com>,
linux-pci@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
linux-rockchip@...ts.infradead.org, linux-kernel@...r.kernel.org,
Dragan Simic <dsimic@...jaro.org>, linux-rockchip@...ts.infradead.org
Subject: Re: [PATCH] PCI: dw-rockchip: Skip waiting for link up
Hi Niklas, Bjorn,
I noticed an issue on the Rockchip RK3588S SoC using the ASMedia ASM2806
PCIe bridge where devices behind the bridge fail to probe since v6.14.
Specifically, this started happening after commit
647d69605c70368d54fc012fce8a43e8e5955b04.
dmesg logs from before and after this commit are available at:
https://gist.github.com/RadxaNaoki/fca2bfca2ee80fefee7b00c7967d2e3d
I have confirmed that reverting the following commits fixes the issue:
commit ec9fd499b9c6 ("PCI: dw-rockchip: Don't wait for link since we
can detect Link Up")
commit 0e0b45ab5d77 ("PCI: dw-rockchip: Enumerate endpoints based on
dll_link_up IRQ")
On v6.18-rc2, the cold boot behavior has changed somewhat, and I have
observed the following three behaviors so far:
- Probe succeeds
- Probe fails
- Kernel oops
There seems to be no pattern to these three behaviors. During a warm
boot, a successful probe does not seem to occur.
If commit ec9fd499b9c6 is reverted on v6.18-rc2, I have observed the
following two behaviors so far:
- Probe succeeds
- Kernel oops
"Probe fails" has not been observed so far.
The dmesg for the kernel oops is available at:
https://gist.github.com/RadxaNaoki/4b2dcd5e41b09004eda2fdeb80ae5e15
Can you please help me with this issue?
Best regards,
--
FUKAUMI Naoki
Radxa Computer (Shenzhen) Co., Ltd.
On 1/13/25 19:59, Niklas Cassel wrote:
> The Root Complex specific device tree binding for pcie-dw-rockchip has the
> 'sys' interrupt marked as required.
>
> The driver requests the 'sys' IRQ unconditionally, and errors out if not
> provided.
>
> Thus, we can unconditionally set use_linkup_irq before calling
> dw_pcie_host_init().
>
> This will skip the wait for link up (since the bus will be enumerated once
> the link up IRQ is triggered), which reduces the bootup time.
>
> Signed-off-by: Niklas Cassel <cassel@...nel.org>
> ---
> drivers/pci/controller/dwc/pcie-dw-rockchip.c | 1 +
> 1 file changed, 1 insertion(+)
>
>
> ---
> base-commit: 2adda4102931b152f35d054055497631ed97fe73
> change-id: 20250113-rockchip-no-wait-403ffbc42313
>
> Best regards,
>
> diff --git a/drivers/pci/controller/dwc/pcie-dw-rockchip.c b/drivers/pci/controller/dwc/pcie-dw-rockchip.c
> index 1170e1107508bd793b610949b0afe98516c177a4..62034affb95fbb965aad3cebc613a83e31c90aee 100644
> --- a/drivers/pci/controller/dwc/pcie-dw-rockchip.c
> +++ b/drivers/pci/controller/dwc/pcie-dw-rockchip.c
> @@ -435,6 +435,7 @@ static int rockchip_pcie_configure_rc(struct rockchip_pcie *rockchip)
>
> pp = &rockchip->pci.pp;
> pp->ops = &rockchip_pcie_host_ops;
> + pp->use_linkup_irq = true;
>
> return dw_pcie_host_init(pp);
> }
Powered by blists - more mailing lists