[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <0b49b681-2289-412a-8969-d134ffcfb7fc@lunn.ch>
Date: Thu, 26 Sep 2024 21:30:32 +0200
From: Andrew Lunn <andrew@...n.ch>
To: Drew Fustini <dfustini@...storrent.com>
Cc: "David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>, Paolo Abeni <pabeni@...hat.com>,
Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>,
Alexandre Torgue <alexandre.torgue@...s.st.com>,
Giuseppe Cavallaro <peppe.cavallaro@...com>,
Jose Abreu <joabreu@...opsys.com>,
Jisheng Zhang <jszhang@...nel.org>,
Maxime Coquelin <mcoquelin.stm32@...il.com>,
Emil Renner Berthing <emil.renner.berthing@...onical.com>,
Drew Fustini <drew@...7.com>, Guo Ren <guoren@...nel.org>,
Fu Wei <wefu@...hat.com>, Conor Dooley <conor@...nel.org>,
Paul Walmsley <paul.walmsley@...ive.com>,
Palmer Dabbelt <palmer@...belt.com>,
Albert Ou <aou@...s.berkeley.edu>, netdev@...r.kernel.org,
devicetree@...r.kernel.org, linux-kernel@...r.kernel.org,
linux-stm32@...md-mailman.stormreply.com,
linux-arm-kernel@...ts.infradead.org,
linux-riscv@...ts.infradead.org
Subject: Re: [PATCH v2 3/3] riscv: dts: thead: Add TH1520 ethernet nodes
On Thu, Sep 26, 2024 at 12:13:06PM -0700, Drew Fustini wrote:
> On Thu, Sep 26, 2024 at 08:39:29PM +0200, Andrew Lunn wrote:
> > > +&mdio0 {
> > > + phy0: ethernet-phy@1 {
> > > + reg = <1>;
> > > + };
> > > +
> > > + phy1: ethernet-phy@2 {
> > > + reg = <2>;
> > > + };
> > > +};
> >
> > Two PHYs on one bus...
>
> Thanks for pointing this out. I will move phy1 to mdio1.
???
Are you saying the two PHYs are not on the same bus?
> > > + gmac1: ethernet@...7060000 {
> > > + compatible = "thead,th1520-gmac", "snps,dwmac-3.70a";
> > > + reg = <0xff 0xe7060000 0x0 0x2000>, <0xff 0xec004000 0x0 0x1000>;
> > > + reg-names = "dwmac", "apb";
> > > + interrupts = <67 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-names = "macirq";
> > > + clocks = <&clk CLK_GMAC_AXI>, <&clk CLK_GMAC_AXI>;
> > > + clock-names = "stmmaceth", "pclk";
> > > + snps,pbl = <32>;
> > > + snps,fixed-burst;
> > > + snps,multicast-filter-bins = <64>;
> > > + snps,perfect-filter-entries = <32>;
> > > + snps,axi-config = <&stmmac_axi_config>;
> > > + status = "disabled";
> > > +
> > > + mdio1: mdio {
> > > + compatible = "snps,dwmac-mdio";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + };
> > > + };
> > > +
> > > + gmac0: ethernet@...7070000 {
> > > + compatible = "thead,th1520-gmac", "snps,dwmac-3.70a";
> > > + reg = <0xff 0xe7070000 0x0 0x2000>, <0xff 0xec003000 0x0 0x1000>;
> > > + reg-names = "dwmac", "apb";
> > > + interrupts = <66 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-names = "macirq";
> > > + clocks = <&clk CLK_GMAC_AXI>, <&clk CLK_GMAC_AXI>;
> >
> > And the MACs are listed in opposite order. Does gmac1 probe first,
> > find the PHY does not exist, and return -EPROBE_DEFER. Then gmac0
> > probes successfully, and then sometime later gmac1 then reprobes?
> >
> > I know it is normal to list nodes in address order, but you might be
> > able to avoid the EPROBE_DEFER if you reverse the order.
>
> The probe order seems to always be the ethernet@...7060000 (gmac1) first
> and then ethernet@...7070000 (gmac0). I do not see any probe deferral
> in the boot log [1].
> [1] https://gist.github.com/pdp7/02a44b024bdb6be5fe61ac21303ab29a
So two PHYs are found, so they must be on the same bus.
It could well be that this MAC driver does not connect to the PHY
until the interface is opened. That is a good 30 seconds after the
driver probes in this log message. So there has been plenty of time
for the PHYs to be found.
What would be interesting is if you used NFS root. Then the interface
would be opened much faster, and you might see an EPROBE_DEFER. But
i'm just speculating. If it works for you, there is no need to do
more.
Andrew
Powered by blists - more mailing lists