From: Weijie Gao <weijie.gao@mediatek.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 16/26] net: mt7628-eth: remove phy link up detection
Date: Thu, 29 Aug 2019 11:32:28 +0800 [thread overview]
Message-ID: <1567049548.2874.123.camel@mcddlt001> (raw)
In-Reply-To: <81fc8089-4b13-fbca-7c57-6027ca55f26d@denx.de>
On Wed, 2019-08-28 at 15:37 +0200, Stefan Roese wrote:
> On 28.08.19 08:38, Weijie Gao wrote:
> > The mt7628 has an embedded ethernet switch (5 phy ports + 1 cpu port).
> > Although in IOT mode only port0 is usable, the phy0 is still connected
> > to the switch, not the ethernet gmac directly.
> >
> > This patch removes these codes as we should not check only the status of
> > phy0 because phy0 may not be linked up in router mode which has all 5 phy
> > ports working.
>
> I understand. But for those embedded targets that use the mainline code
> right now, this setup is exactly the one that's used. With this patch applied
> this "feature" of link detection of the only ethernet port is removed.
>
> Can't we somehow change this code, that it supports both operations modes?
> So targets without switch functionality and targets with multiple ports
> (with switch functionality) can be supported? Perhaps via some DT property
> or at least a Kconfig option?
>
> BTW: Do you plan to add support for a target with switch functionality? That
> would be just great.
>
> Thanks,
> Stefan
>
> > Signed-off-by: Weijie Gao <weijie.gao@mediatek.com>
> > ---
> > drivers/net/mt7628-eth.c | 32 --------------------------------
> > 1 file changed, 32 deletions(-)
> >
> > diff --git a/drivers/net/mt7628-eth.c b/drivers/net/mt7628-eth.c
> > index 4675b0f003..eef25da8a8 100644
> > --- a/drivers/net/mt7628-eth.c
> > +++ b/drivers/net/mt7628-eth.c
> > @@ -120,9 +120,6 @@ struct fe_tx_dma {
> > #define CONFIG_DMA_STOP_TIMEOUT 100
> > #define CONFIG_TX_DMA_TIMEOUT 100
> >
> > -#define LINK_DELAY_TIME 500 /* 500 ms */
> > -#define LINK_TIMEOUT 10000 /* 10 seconds */
> > -
> > struct mt7628_eth_dev {
> > void __iomem *base; /* frame engine base address */
> > void __iomem *eth_sw_base; /* switch base address */
> > @@ -437,14 +434,6 @@ static int mt7628_eth_free_pkt(struct udevice *dev, uchar *packet, int length)
> > return 0;
> > }
> >
> > -static int phy_link_up(struct mt7628_eth_dev *priv)
> > -{
> > - u32 val;
> > -
> > - mii_mgr_read(priv, 0x00, MII_BMSR, &val);
> > - return !!(val & BMSR_LSTATUS);
> > -}
> > -
> > static int mt7628_eth_start(struct udevice *dev)
> > {
> > struct mt7628_eth_dev *priv = dev_get_priv(dev);
> > @@ -493,27 +482,6 @@ static int mt7628_eth_start(struct udevice *dev)
> > wmb();
> > eth_dma_start(priv);
> >
> > - /* Check if link is not up yet */
> > - if (!phy_link_up(priv)) {
> > - /* Wait for link to come up */
> > -
> > - printf("Waiting for link to come up .");
> > - for (i = 0; i < (LINK_TIMEOUT / LINK_DELAY_TIME); i++) {
> > - mdelay(LINK_DELAY_TIME);
> > - if (phy_link_up(priv)) {
> > - mdelay(100); /* Ensure all is ready */
> > - break;
> > - }
> > -
> > - printf(".");
> > - }
> > -
> > - if (phy_link_up(priv))
> > - printf(" done\n");
> > - else
> > - printf(" timeout! Trying anyways\n");
> > - }
> > -
> > /*
> > * The integrated switch seems to queue some received ethernet
> > * packets in some FIFO. Lets read the already queued packets
> >
>
> Viele Grüße,
> Stefan
>
I think adding a phy interface should do. I'll try to implement this.
next prev parent reply other threads:[~2019-08-29 3:32 UTC|newest]
Thread overview: 60+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-08-28 6:37 [U-Boot] [PATCH 00/26] Add and update drivers for MediaTek MT76x8 SoCs Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 01/26] serial: serial_mtk: enable FIFO and disable flow control Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 02/26] serial: serial_mtk: add non-DM version for SPL Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 03/26] dts: mtmips: move uart property clock-frequency into mt7628an.dtsi Weijie Gao
2019-08-28 7:13 ` Stefan Roese
2019-08-28 6:37 ` [U-Boot] [PATCH 04/26] dts: mtmips: enable high-speed UART support for mt7628 Weijie Gao
2019-08-28 7:14 ` Stefan Roese
2019-08-28 6:37 ` [U-Boot] [PATCH 05/26] spi: mt7621-spi: remove data cache and rewrite its xfer function Weijie Gao
2019-08-28 7:55 ` Stefan Roese
2019-08-28 6:37 ` [U-Boot] [PATCH 06/26] spi: mt7621-spi: restore default register value after each xfer Weijie Gao
2019-08-28 8:01 ` Stefan Roese
2019-08-28 6:37 ` [U-Boot] [PATCH 07/26] pinctrl: add support for MediaTek MT7628 Weijie Gao
2019-08-28 12:26 ` Stefan Roese
2019-08-28 12:37 ` Stefan Roese
2019-08-29 3:04 ` Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 08/26] dts: mtmips: add pinctrl node for mt7628 Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 09/26] dts: mtmips: add default pinctrl for uart nodes Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 10/26] reset: add reset controller driver for MediaTek MIPS platform Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 11/26] dts: mtmips: update reset controller node for mt7628 Weijie Gao
2019-08-28 13:18 ` Stefan Roese
2019-08-29 3:18 ` Weijie Gao
2019-12-30 9:19 ` Mauro Condarelli
2019-12-30 10:22 ` Daniel Schwierzeck
2019-12-30 11:09 ` Mauro Condarelli
2019-12-30 12:14 ` Mauro Condarelli
2020-01-02 12:30 ` Stefan Roese
2020-01-02 13:36 ` Mauro Condarelli
2019-08-28 6:37 ` [U-Boot] [PATCH 12/26] clk: add clock gating driver for MediaTek MIPS platform Weijie Gao
2019-08-28 13:24 ` Daniel Schwierzeck
2019-08-29 3:25 ` Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 13/26] dts: mtmips: add gate clock node for mt7628 Weijie Gao
2019-08-28 6:37 ` [U-Boot] [PATCH 14/26] phy: mt76x8-usb-phy: add slew rate calibration and remove non-mt7628 part Weijie Gao
2019-08-28 6:38 ` [U-Boot] [PATCH 15/26] net: mt7628-eth: remove hardcoded gpio settings and regmap-based phy reset Weijie Gao
2019-08-28 13:32 ` Stefan Roese
2019-08-28 6:38 ` [U-Boot] [PATCH 16/26] net: mt7628-eth: remove phy link up detection Weijie Gao
2019-08-28 13:37 ` Stefan Roese
2019-08-29 3:32 ` Weijie Gao [this message]
2019-08-28 6:38 ` [U-Boot] [PATCH 17/26] net: mt7628-eth: free rx descriptor on receiving failure Weijie Gao
2019-08-28 13:42 ` Stefan Roese
2019-08-28 6:38 ` [U-Boot] [PATCH 18/26] net: mt7628-eth: add support to isolate LAN/WAN ports Weijie Gao
2019-08-28 13:46 ` Stefan Roese
2019-08-29 4:27 ` Weijie Gao
2019-08-28 6:38 ` [U-Boot] [PATCH 19/26] dts: mtmips: enable eth port0 led function for all boards Weijie Gao
2019-08-28 13:47 ` Stefan Roese
2019-08-28 6:38 ` [U-Boot] [PATCH 20/26] mmc: mtk-sd: add support for MediaTek MT7620/MT7628 SoCs Weijie Gao
2019-08-28 13:50 ` Stefan Roese
2019-08-29 4:28 ` Weijie Gao
2019-08-28 6:38 ` [U-Boot] [PATCH 21/26] mmc: mtk-sd: add a dts property cd-active-high for builtin-cd mode Weijie Gao
2019-08-28 6:38 ` [U-Boot] [PATCH 22/26] dts: mtmips: add mmc related nodes for mt7628an.dtsi Weijie Gao
2019-08-28 6:38 ` [U-Boot] [PATCH 23/26] dts: mtmips: add default pinctrl for gardena-smart-gateway-mt7688 Weijie Gao
2019-08-28 13:52 ` Stefan Roese
2019-08-28 6:38 ` [U-Boot] [PATCH 24/26] dts: mtmips: add default pinctrl to eth nodes for all boards Weijie Gao
2019-08-28 13:55 ` Stefan Roese
2019-08-28 6:38 ` [U-Boot] [PATCH 25/26] configs: mtmips: change all boards to use mtk high-speed uart driver Weijie Gao
2019-08-28 13:57 ` Stefan Roese
2019-08-29 4:30 ` Weijie Gao
2019-08-28 6:38 ` [U-Boot] [PATCH 26/26] configs: mtmips: add necessary drivers for mtmips boards Weijie Gao
2019-08-28 13:35 ` Daniel Schwierzeck
2019-08-28 13:40 ` Stefan Roese
2019-08-29 3:34 ` Weijie Gao
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=1567049548.2874.123.camel@mcddlt001 \
--to=weijie.gao@mediatek.com \
--cc=u-boot@lists.denx.de \
/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