diff mbox series

ARM: dts: stm32: Do not set eth1addr if KS8851 has EEPROM

Message ID 20201008131458.6547-1-marex@denx.de
State Accepted
Commit e07f76b25debf224a0283671f0b9ab0912a7ac0a
Delegated to: Patrick Delaunay
Headers show
Series ARM: dts: stm32: Do not set eth1addr if KS8851 has EEPROM | expand

Commit Message

Marek Vasut Oct. 8, 2020, 1:14 p.m. UTC
In case the KS8851 has external EEPROM attached to it, do not set
eth1addr at all. The network stack will read the MAC out of the
KS8851 and set eth1addr accordingly.

Signed-off-by: Marek Vasut <marex@denx.de>
Cc: Patrice Chotard <patrice.chotard@st.com>
Cc: Patrick Delaunay <patrick.delaunay@st.com>
---
 board/dhelectronics/dh_stm32mp1/board.c | 40 ++++++++++++++++++++++---
 1 file changed, 36 insertions(+), 4 deletions(-)

Comments

Patrice CHOTARD Oct. 9, 2020, 7:28 a.m. UTC | #1
Hi Marek

On 10/8/20 3:14 PM, Marek Vasut wrote:
> In case the KS8851 has external EEPROM attached to it, do not set
> eth1addr at all. The network stack will read the MAC out of the
> KS8851 and set eth1addr accordingly.
>
> Signed-off-by: Marek Vasut <marex@denx.de>
> Cc: Patrice Chotard <patrice.chotard@st.com>
> Cc: Patrick Delaunay <patrick.delaunay@st.com>
> ---
>  board/dhelectronics/dh_stm32mp1/board.c | 40 ++++++++++++++++++++++---
>  1 file changed, 36 insertions(+), 4 deletions(-)
>
> diff --git a/board/dhelectronics/dh_stm32mp1/board.c b/board/dhelectronics/dh_stm32mp1/board.c
> index c9abe3cc6d..f42d395098 100644
> --- a/board/dhelectronics/dh_stm32mp1/board.c
> +++ b/board/dhelectronics/dh_stm32mp1/board.c
> @@ -81,6 +81,11 @@
>   */
>  DECLARE_GLOBAL_DATA_PTR;
>  
> +#define KS_CCR		0x08
> +#define KS_CCR_EEPROM	BIT(9)
> +#define KS_BE0		BIT(12)
> +#define KS_BE1		BIT(13)
> +
>  int setup_mac_address(void)
>  {
>  	unsigned char enetaddr[6];
> @@ -97,12 +102,39 @@ int setup_mac_address(void)
>  	if (off < 0) {
>  		/* ethernet1 is not present in the system */
>  		skip_eth1 = true;
> -	} else {
> -		ret = eth_env_get_enetaddr("eth1addr", enetaddr);
> -		if (ret)	/* eth1addr is already set */
> -			skip_eth1 = true;
> +		goto out_set_ethaddr;
> +	}
> +
> +	ret = eth_env_get_enetaddr("eth1addr", enetaddr);
> +	if (ret) {
> +		/* eth1addr is already set */
> +		skip_eth1 = true;
> +		goto out_set_ethaddr;
> +	}
> +
> +	ret = fdt_node_check_compatible(gd->fdt_blob, off, "micrel,ks8851-mll");
> +	if (ret)
> +		goto out_set_ethaddr;
> +
> +	/*
> +	 * KS8851 with EEPROM may use custom MAC from EEPROM, read
> +	 * out the KS8851 CCR register to determine whether EEPROM
> +	 * is present. If EEPROM is present, it must contain valid
> +	 * MAC address.
> +	 */
> +	u32 reg, ccr;
> +	reg = fdt_get_base_address(gd->fdt_blob, off);
> +	if (!reg)
> +		goto out_set_ethaddr;
> +
> +	writew(KS_BE0 | KS_BE1 | KS_CCR, reg + 2);
> +	ccr = readw(reg);
> +	if (ccr & KS_CCR_EEPROM) {
> +		skip_eth1 = true;
> +		goto out_set_ethaddr;
>  	}
>  
> +out_set_ethaddr:
>  	if (skip_eth0 && skip_eth1)
>  		return 0;
>  

Reviewed-by: Patrice Chotard <patrice.chotard@st.com>

Thanks

Patrice
Patrick DELAUNAY Oct. 13, 2020, 5:03 p.m. UTC | #2
Hi Marek,

> From: Marek Vasut <marex@denx.de>
> Sent: jeudi 8 octobre 2020 15:15
> 
> In case the KS8851 has external EEPROM attached to it, do not set eth1addr at
> all. The network stack will read the MAC out of the
> KS8851 and set eth1addr accordingly.
> 
> Signed-off-by: Marek Vasut <marex@denx.de>
> Cc: Patrice Chotard <patrice.chotard@st.com>
> Cc: Patrick Delaunay <patrick.delaunay@st.com>
> ---
>  board/dhelectronics/dh_stm32mp1/board.c | 40 ++++++++++++++++++++++---
>  1 file changed, 36 insertions(+), 4 deletions(-)
> 

Reviewed-by: Patrick Delaunay <patrick.delaunay@st.com>

Thanks

Patrick
Patrick DELAUNAY Oct. 21, 2020, 9:25 a.m. UTC | #3
Hi Marek,

> From: Marek Vasut <marex@denx.de>
> Sent: jeudi 8 octobre 2020 15:15
> 
> In case the KS8851 has external EEPROM attached to it, do not set eth1addr at
> all. The network stack will read the MAC out of the
> KS8851 and set eth1addr accordingly.
> 
> Signed-off-by: Marek Vasut <marex@denx.de>
> Cc: Patrice Chotard <patrice.chotard@st.com>
> Cc: Patrick Delaunay <patrick.delaunay@st.com>
> ---
>  board/dhelectronics/dh_stm32mp1/board.c | 40 ++++++++++++++++++++++---
>  1 file changed, 36 insertions(+), 4 deletions(-)
> 

Applied to u-boot-stm/master, thanks!

Regards

Patrick
diff mbox series

Patch

diff --git a/board/dhelectronics/dh_stm32mp1/board.c b/board/dhelectronics/dh_stm32mp1/board.c
index c9abe3cc6d..f42d395098 100644
--- a/board/dhelectronics/dh_stm32mp1/board.c
+++ b/board/dhelectronics/dh_stm32mp1/board.c
@@ -81,6 +81,11 @@ 
  */
 DECLARE_GLOBAL_DATA_PTR;
 
+#define KS_CCR		0x08
+#define KS_CCR_EEPROM	BIT(9)
+#define KS_BE0		BIT(12)
+#define KS_BE1		BIT(13)
+
 int setup_mac_address(void)
 {
 	unsigned char enetaddr[6];
@@ -97,12 +102,39 @@  int setup_mac_address(void)
 	if (off < 0) {
 		/* ethernet1 is not present in the system */
 		skip_eth1 = true;
-	} else {
-		ret = eth_env_get_enetaddr("eth1addr", enetaddr);
-		if (ret)	/* eth1addr is already set */
-			skip_eth1 = true;
+		goto out_set_ethaddr;
+	}
+
+	ret = eth_env_get_enetaddr("eth1addr", enetaddr);
+	if (ret) {
+		/* eth1addr is already set */
+		skip_eth1 = true;
+		goto out_set_ethaddr;
+	}
+
+	ret = fdt_node_check_compatible(gd->fdt_blob, off, "micrel,ks8851-mll");
+	if (ret)
+		goto out_set_ethaddr;
+
+	/*
+	 * KS8851 with EEPROM may use custom MAC from EEPROM, read
+	 * out the KS8851 CCR register to determine whether EEPROM
+	 * is present. If EEPROM is present, it must contain valid
+	 * MAC address.
+	 */
+	u32 reg, ccr;
+	reg = fdt_get_base_address(gd->fdt_blob, off);
+	if (!reg)
+		goto out_set_ethaddr;
+
+	writew(KS_BE0 | KS_BE1 | KS_CCR, reg + 2);
+	ccr = readw(reg);
+	if (ccr & KS_CCR_EEPROM) {
+		skip_eth1 = true;
+		goto out_set_ethaddr;
 	}
 
+out_set_ethaddr:
 	if (skip_eth0 && skip_eth1)
 		return 0;