From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: "Russell King (Oracle)" <linux@armlinux.org.uk>
Cc: netdev@vger.kernel.org, imx@lists.linux.dev,
Andrew Lunn <andrew+netdev@lunn.ch>,
Clark Wang <xiaoning.wang@nxp.com>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Fabio Estevam <festevam@denx.de>,
Fabio Estevam <festevam@gmail.com>,
Francesco Dolcini <francesco.dolcini@toradex.com>,
Frank Li <Frank.Li@nxp.com>, Heiko Schocher <hs@denx.de>,
Jakub Kicinski <kuba@kernel.org>, Joy Zou <joy.zou@nxp.com>,
Kieran Bingham <kieran.bingham@ideasonboard.com>,
Marco Felsch <m.felsch@pengutronix.de>,
Martyn Welch <martyn.welch@collabora.com>,
Mathieu Othacehe <othacehe@gnu.org>,
Paolo Abeni <pabeni@redhat.com>,
Pengutronix Kernel Team <kernel@pengutronix.de>,
Richard Hu <richard.hu@technexion.com>,
Sascha Hauer <s.hauer@pengutronix.de>,
Shawn Guo <shawnguo@kernel.org>,
Shenwei Wang <shenwei.wang@nxp.com>,
Stefan Klug <stefan.klug@ideasonboard.com>,
Stefano Radaelli <stefano.radaelli21@gmail.com>,
Wei Fang <wei.fang@nxp.com>,
Xiaoliang Yang <xiaoliang.yang_1@nxp.com>,
linux-arm-kernel@lists.infradead.org
Subject: Re: [PATCH v2] net: stmmac: imx: Disable EEE
Date: Tue, 10 Feb 2026 18:33:10 +0200 [thread overview]
Message-ID: <20260210163310.GO2405149@killaraus.ideasonboard.com> (raw)
In-Reply-To: <20260210143157.GM2405149@killaraus.ideasonboard.com>
On Tue, Feb 10, 2026 at 04:31:59PM +0200, Laurent Pinchart wrote:
> On Tue, Feb 10, 2026 at 12:26:12PM +0000, Russell King (Oracle) wrote:
> > On Mon, Feb 09, 2026 at 10:21:55PM +0200, Laurent Pinchart wrote:
> > > The i.MX8MP suffers from an interrupt storm related to the stmmac and
> > > EEE. A long and tedious analysis ([1]) concluded that the SoC wires the
> > > stmmac lpi_intr_o signal to an OR gate along with the main dwmac
> > > interrupts, which causes an interrupt storm for two reasons.
> > >
> > > First, there's a race condition due to the interrupt deassertion being
> > > synchronous to the RX clock domain:
> > >
> > > - When the PHY exits LPI mode, it restarts generating the RX clock
> > > (clk_rx_i input signal to the GMAC).
> > > - The MAC detects exit from LPI, and asserts lpi_intr_o. This triggers
> > > the ENET_EQOS interrupt.
> > > - Before the CPU has time to process the interrupt, the PHY enters LPI
> > > mode again, and stops generating the RX clock.
> > > - The CPU processes the interrupt and reads the GMAC4_LPI_CTRL_STATUS
> > > registers. This does not clear lpi_intr_o as there's no clk_rx_i.
> > >
> > > An attempt was made to fixing the issue by not stopping RX_CLK in Rx LPI
> > > state ([2]). This alleviates the symptoms but doesn't fix the issue.
> > > Since lpi_intr_o takes four RX_CLK cycles to clear, an interrupt storm
> > > can still occur during that window. In 1000T mode this is harder to
> > > notice, but slower receive clocks cause hundreds to thousands of
> > > spurious interrupts.
> > >
> > > Fix the issue by disabling EEE completely on i.MX8MP.
> > >
> > > [1] https://lore.kernel.org/all/20251026122905.29028-1-laurent.pinchart@ideasonboard.com/
> > > [2] https://lore.kernel.org/all/20251123053518.8478-1-laurent.pinchart@ideasonboard.com/
> > >
> > > Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> > > ---
> > > This patch depends on https://lore.kernel.org/all/E1vNUjC-0000000FhjR-0h6P@rmk-PC.armlinux.org.uk/
> >
> > ... and a few other patches as well. There is also a conflicting change
> > in net-next:
> >
> > commit dc6597fab3e3d291da9e0b4c6f7da01a5a863e80
> > Author: Stefan Eichenberger <stefan.eichenberger@toradex.com>
> > Date: Tue Jan 20 21:30:04 2026 +0100
> >
> > net: stmmac: dwmac-imx: keep preamble before sfd on i.MX8MP
> >
> > > base-commit: 05f7e89ab9731565d8a62e3b5d1ec206485eeb0b
> >
> > This is v6.19
> >
> > > prerequisite-patch-id: 9229185bf29c206923075a0450e763664af050bb
> > > prerequisite-patch-id: e17c3f8a7cb2b18fc0c3c6250773a9680bdabdba
> > > prerequisite-patch-id: a3c3f8b08fd66ee3ccce632aad3f4a3c21c92718
> >
> > I have no idea what these are. These don't exist in Linus', net, nor
> > net-next trees. I'm not sure what generates these, but they are useless
> > unless they also indicate the summary line for the commit in question,
> > so that one can have some clue what change they're referring to.
>
> The first two are mistakes, I had two unrelated DT changes at the base of my
> branch that I needed for testing, and I forgot to rebase before running
> git-format-patch. They can be ignored.
>
> The last one is your patch
> (https://lore.kernel.org/all/E1vNUjC-0000000FhjR-0h6P@rmk-PC.armlinux.org.uk/).
> Note that the value is the patch-id, not the commit ID.
>
> > While this is a fix, I think you previously suggested that this isn't
> > a regression, which suggests it should be merged in net-next (currently
> > closed due to the merge window) rather than net.
>
> I think I was first notified of the issue more than a year ago, so I
> would indeed not count it as a regression. net-next is fine with me.
>
> > Also, referring to another patch doesn't get it applied - netdev
> > workflow uses patchwork, and patches to be applied need to be there.
> > If patches depend on each other, they need to be submitted as a
> > series. So either I need to pick up your patch and send it along
> > with mine, or you need to pick up my patch and send it with yours.
> > We need to come to agreement on who is submitting it.
>
> I'm happy to submit a series with both, rebased on top of net-next to
> handle the conflict you pointed out. Is that fine with you ?
If you would like me to submit a series with both patches, should I
resolve the conflict with "net: stmmac: dwmac-imx: keep preamble before
sfd on i.MX8MP" by inserting the STMMAC_FLAG_EEE_DISABLE flag as BIT(10)
and change the value of subsequent flags as you did, or add it at the
end (BIT(15)) ?
I'm also happy if you take my patch and submit a series with both.
--
Regards,
Laurent Pinchart
next prev parent reply other threads:[~2026-02-10 16:33 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-09 20:21 [PATCH v2] net: stmmac: imx: Disable EEE Laurent Pinchart
2026-02-10 12:26 ` Russell King (Oracle)
2026-02-10 14:31 ` Laurent Pinchart
2026-02-10 16:33 ` Laurent Pinchart [this message]
2026-02-11 12:53 ` Russell King (Oracle)
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=20260210163310.GO2405149@killaraus.ideasonboard.com \
--to=laurent.pinchart@ideasonboard.com \
--cc=Frank.Li@nxp.com \
--cc=andrew+netdev@lunn.ch \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=festevam@denx.de \
--cc=festevam@gmail.com \
--cc=francesco.dolcini@toradex.com \
--cc=hs@denx.de \
--cc=imx@lists.linux.dev \
--cc=joy.zou@nxp.com \
--cc=kernel@pengutronix.de \
--cc=kieran.bingham@ideasonboard.com \
--cc=kuba@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux@armlinux.org.uk \
--cc=m.felsch@pengutronix.de \
--cc=martyn.welch@collabora.com \
--cc=netdev@vger.kernel.org \
--cc=othacehe@gnu.org \
--cc=pabeni@redhat.com \
--cc=richard.hu@technexion.com \
--cc=s.hauer@pengutronix.de \
--cc=shawnguo@kernel.org \
--cc=shenwei.wang@nxp.com \
--cc=stefan.klug@ideasonboard.com \
--cc=stefano.radaelli21@gmail.com \
--cc=wei.fang@nxp.com \
--cc=xiaoliang.yang_1@nxp.com \
--cc=xiaoning.wang@nxp.com \
/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