[U-Boot] [PATCH 3/3] mx25pdk: Add FEC support

Stefano Babic sbabic at denx.de
Thu Oct 11 09:21:49 CEST 2012


Am 11/10/2012 05:58, schrieb Fabio Estevam:
> From: Fabio Estevam <fabio.estevam at freescale.com>
> 
> mx25pdk has a Ethernet port that is connected to its internal FEC controller.
> 
> In order to power up the Ethernet PHY (DP83640) it is necessary to communicate
> with the PMIC via I2C.
> 
> Make FEC ethernet functional.
> 
> Signed-off-by: Fabio Estevam <fabio.estevam at freescale.com>
> ---

Hi Fabio,


>  board/freescale/mx25pdk/mx25pdk.c |   64 +++++++++++++++++++++++++++++++++++++
>  include/configs/mx25pdk.h         |   15 +++++++++
>  2 files changed, 79 insertions(+)
> 
> diff --git a/board/freescale/mx25pdk/mx25pdk.c b/board/freescale/mx25pdk/mx25pdk.c
> index e850b3e..e1fa2be 100644
> --- a/board/freescale/mx25pdk/mx25pdk.c
> +++ b/board/freescale/mx25pdk/mx25pdk.c
> @@ -25,6 +25,13 @@
>  #include <asm/arch/sys_proto.h>
>  #include <mmc.h>
>  #include <fsl_esdhc.h>
> +#include <i2c.h>
> +
> +#define FEC_RESET_B		IMX_GPIO_NR(2, 3)
> +#define FEC_ENABLE_B		IMX_GPIO_NR(4, 8)
> +#define CARD_DETECT		IMX_GPIO_NR(2, 1)
> +#define PMIC_I2C_ADDR		0x54
> +#define REG_PHY_3V3		0x02
>  
>  #define CARD_DETECT		IMX_GPIO_NR(2, 1)
>  
> @@ -36,6 +43,47 @@ struct fsl_esdhc_cfg esdhc_cfg[1] = {
>  };
>  #endif
>  
> +static void mx25pdk_fec_init(void)
> +{
> +	struct iomuxc_mux_ctl *muxctl;
> +	struct iomuxc_pad_ctl *padctl;
> +	u32 gpio_mux_mode = MX25_PIN_MUX_MODE(5);
> +	u32 gpio_mux_mode0_sion = MX25_PIN_MUX_MODE(0) | MX25_PIN_MUX_SION;
> +
> +	/* FEC pin init is generic */
> +	mx25_fec_init_pins();
> +
> +	muxctl = (struct iomuxc_mux_ctl *)IMX_IOPADMUX_BASE;
> +	padctl = (struct iomuxc_pad_ctl *)IMX_IOPADCTL_BASE;
> +	/*
> +	 * Set up FEC_RESET_B and FEC_ENABLE_B
> +	 *
> +	 * FEC_RESET_B: gpio2_3 is ALT 5 mode of pin D12
> +	 * FEC_ENABLE_B: gpio4_8 is ALT 5 mode of pin A17
> +	 */
> +	writel(gpio_mux_mode, &muxctl->pad_d12);
> +	writel(gpio_mux_mode, &muxctl->pad_a17);
> +
> +	writel(0x0, &padctl->pad_d12);
> +	writel(0x0, &padctl->pad_a17);
> +
> +	/* Assert RESET and ENABLE low */
> +	gpio_direction_output(FEC_RESET_B, 0);
> +	gpio_direction_output(FEC_ENABLE_B, 0);
> +
> +	udelay(10);
> +
> +	/* Deassert RESET and ENABLE */
> +	gpio_set_value(FEC_RESET_B, 1);
> +	gpio_set_value(FEC_ENABLE_B, 1);
> +
> +	/* Setup I2C pins so that PMIC can turn on PHY supply */
> +	writel(gpio_mux_mode0_sion, &muxctl->pad_i2c1_clk);
> +	writel(gpio_mux_mode0_sion, &muxctl->pad_i2c1_dat);
> +	writel(0x1E8, &padctl->pad_i2c1_clk);
> +	writel(0x1E8, &padctl->pad_i2c1_dat);
> +}
> +
>  int dram_init(void)
>  {
>  	/* dram_init must store complete ramsize in gd->ram_size */
> @@ -59,6 +107,22 @@ int board_init(void)
>  	return 0;
>  }
>  
> +int board_late_init(void)
> +{
> +	/* Turn on PHY supply via I2C command to PMIC */
> +	u8 reg[4];
> +	reg[0] = 0x09;
> +
> +	mx25pdk_fec_init();
> +
> +	if (i2c_write(PMIC_I2C_ADDR, REG_PHY_3V3, 1, reg, 1)) {
> +		printf("I2C write to PMIC failed\n");
> +		return -EINVAL;
> +	}

I do not know which PMIC is on this board. Anyway, we have accessors for
the PMICs. Please add register layout to your pmic (if it is not one of
the already supported) and use pmic_ functions (as in MX35 / MX5) to
modify the registers.

Best regards,
Stefano

-- 
=====================================================================
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-53 Fax: +49-8142-66989-80 Email: sbabic at denx.de
=====================================================================


More information about the U-Boot mailing list