[PATCH 2/2] net: smc911x: Determine bus width at runtime
Ramon Fried
rfried.dev at gmail.com
Tue Jun 29 13:18:24 CEST 2021
On Mon, Jun 28, 2021 at 4:31 PM Andre Przywara <andre.przywara at arm.com> wrote:
>
> The SMC911x Ethernet MACs can be integrated using a 16 or 32-bit bus.
> The driver needs to know about this choice, which is the reason for us
> having a Kconfig symbol for that.
>
> Now this bus width is already described using a devicetree property, and
> since the driver is DM compliant and is using the DT now, we should query
> this at runtime. We leave the Kconfig choice around, in case the DT is
> missing this property.
>
> Signed-off-by: Andre Przywara <andre.przywara at arm.com>
> ---
> drivers/net/smc911x.c | 33 ++++++++++++++++++++-------------
> 1 file changed, 20 insertions(+), 13 deletions(-)
>
> diff --git a/drivers/net/smc911x.c b/drivers/net/smc911x.c
> index d596d96f4b3..3afebee4402 100644
> --- a/drivers/net/smc911x.c
> +++ b/drivers/net/smc911x.c
> @@ -28,6 +28,7 @@ struct smc911x_priv {
> phys_addr_t iobase;
> const struct chip_id *chipid;
> unsigned char enetaddr[6];
> + bool use_32_bit_io;
> };
>
> static const struct chip_id chip_ids[] = {
> @@ -48,28 +49,24 @@ static const struct chip_id chip_ids[] = {
>
> #define DRIVERNAME "smc911x"
>
> -#if defined (CONFIG_SMC911X_32_BIT)
> static u32 smc911x_reg_read(struct smc911x_priv *priv, u32 offset)
> {
> - return readl(priv->iobase + offset);
> -}
> + if (priv->use_32_bit_io)
> + return readl(priv->iobase + offset);
>
> -static void smc911x_reg_write(struct smc911x_priv *priv, u32 offset, u32 val)
> -{
> - writel(val, priv->iobase + offset);
> -}
> -#else
> -static u32 smc911x_reg_read(struct smc911x_priv *priv, u32 offset)
> -{
> return (readw(priv->iobase + offset) & 0xffff) |
> (readw(priv->iobase + offset + 2) << 16);
> }
> +
> static void smc911x_reg_write(struct smc911x_priv *priv, u32 offset, u32 val)
> {
> - writew(val & 0xffff, priv->iobase + offset);
> - writew(val >> 16, priv->iobase + offset + 2);
> + if (priv->use_32_bit_io) {
> + writel(val, priv->iobase + offset);
> + } else {
> + writew(val & 0xffff, priv->iobase + offset);
> + writew(val >> 16, priv->iobase + offset + 2);
> + }
> }
> -#endif /* CONFIG_SMC911X_32_BIT */
>
> static u32 smc911x_get_mac_csr(struct smc911x_priv *priv, u8 reg)
> {
> @@ -493,6 +490,8 @@ int smc911x_initialize(u8 dev_num, int base_addr)
> priv->iobase = base_addr;
> priv->dev.iobase = base_addr;
>
> + priv->use_32_bit_io = CONFIG_IS_ENABLED(SMC911X_32_BIT);
> +
> /* Try to detect chip. Will fail if not present. */
> ret = smc911x_detect_chip(priv);
> if (ret) {
> @@ -603,10 +602,18 @@ static int smc911x_of_to_plat(struct udevice *dev)
> {
> struct smc911x_priv *priv = dev_get_priv(dev);
> struct eth_pdata *pdata = dev_get_plat(dev);
> + u32 io_width;
> + int ret;
>
> pdata->iobase = dev_read_addr(dev);
> priv->iobase = pdata->iobase;
>
> + ret = dev_read_u32(dev, "reg-io-width", &io_width);
> + if (!ret)
> + priv->use_32_bit_io = (io_width == 4);
> + else
> + priv->use_32_bit_io = CONFIG_IS_ENABLED(SMC911X_32_BIT);
> +
> return 0;
> }
>
> --
> 2.17.5
>
Reviewed-by: Ramon Fried <rfried.dev at gmail.com>
More information about the U-Boot
mailing list