diff options
author | Gregory Nutt <gnutt@nuttx.org> | 2015-01-02 10:11:57 -0600 |
---|---|---|
committer | Gregory Nutt <gnutt@nuttx.org> | 2015-01-02 10:11:57 -0600 |
commit | b70778f938db35acd13ef2c3603e5b4665d03fe6 (patch) | |
tree | d28175205696d05d3641699820a479e9af216f57 /nuttx/arch/arm/src/tiva | |
parent | 9aba6a413e3bec5ff4bcb19e98a3af22455f41fe (diff) | |
download | nuttx-b70778f938db35acd13ef2c3603e5b4665d03fe6.tar.gz nuttx-b70778f938db35acd13ef2c3603e5b4665d03fe6.tar.bz2 nuttx-b70778f938db35acd13ef2c3603e5b4665d03fe6.zip |
Tiva Ethernet: Update PHY initialization
Diffstat (limited to 'nuttx/arch/arm/src/tiva')
-rw-r--r-- | nuttx/arch/arm/src/tiva/chip/tm4c_ethernet.h | 2 | ||||
-rw-r--r-- | nuttx/arch/arm/src/tiva/tm4c_ethernet.c | 290 |
2 files changed, 101 insertions, 191 deletions
diff --git a/nuttx/arch/arm/src/tiva/chip/tm4c_ethernet.h b/nuttx/arch/arm/src/tiva/chip/tm4c_ethernet.h index 72bdbfe65..af9d43ffb 100644 --- a/nuttx/arch/arm/src/tiva/chip/tm4c_ethernet.h +++ b/nuttx/arch/arm/src/tiva/chip/tm4c_ethernet.h @@ -834,7 +834,7 @@ #define EMAC_PC_DIGRESTART (1 << 25) /* Bit 25: PHY Soft Restart */ #define EMAC_PC_PINTFS_SHIFT (28) /* Bits 28-30: Ethernet Interface Select */ #define EMAC_PC_PINTFS_MASK (7 << EMAC_PC_PINTFS_SHIFT) -# define EMAC_PC_PINTFS_IMII (0 << EMAC_PC_PINTFS_SHIFT) /* MII: Internal PHY or external PHY connected via MII */ +# define EMAC_PC_PINTFS_MII (0 << EMAC_PC_PINTFS_SHIFT) /* MII: Internal PHY or external PHY connected via MII */ # define EMAC_PC_PINTFS_RMII (4 << EMAC_PC_PINTFS_SHIFT) /* RMII: External PHY connected via RMII */ #define EMAC_PC_PHYEXT (1 << 31) /* Bit 31: PHY Select */ diff --git a/nuttx/arch/arm/src/tiva/tm4c_ethernet.c b/nuttx/arch/arm/src/tiva/tm4c_ethernet.c index 001f63604..e63272ac7 100644 --- a/nuttx/arch/arm/src/tiva/tm4c_ethernet.c +++ b/nuttx/arch/arm/src/tiva/tm4c_ethernet.c @@ -714,8 +714,9 @@ static int tiva_phyinit(FAR struct tiva_ethmac_s *priv); /* MAC/DMA Initialization */ -static inline void tiva_phy_reconfigure(FAR struct tiva_ethmac_s *priv); -static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv); +static void tiva_phy_hold(FAR struct tiva_ethmac_s *priv); +static void tiva_phy_configure(FAR struct tiva_ethmac_s *priv); +static inline void tiva_phy_initialize(FAR struct tiva_ethmac_s *priv); static void tiva_ethreset(FAR struct tiva_ethmac_s *priv); static int tiva_macconfig(FAR struct tiva_ethmac_s *priv); @@ -3181,10 +3182,10 @@ static int tiva_phyinit(FAR struct tiva_ethmac_s *priv) } /**************************************************************************** - * Function: tiva_phy_reconfigure + * Function: tiva_phy_hold * * Description: - * Configure to support the internal PHY + * Reset the PHY * * Parameters: * priv - A reference to the private driver state structure @@ -3196,20 +3197,24 @@ static int tiva_phyinit(FAR struct tiva_ethmac_s *priv) * ****************************************************************************/ -#ifdef CONFIG_TIVA_PHY_INTERNAL -static inline void tiva_phy_reconfigure(FAR struct tiva_ethmac_s *priv) +static inline void tiva_phy_hold(FAR struct tiva_ethmac_s *priv) { - /* No special actions need to taken after a reset if the internal PHY - * is used. + uint32_t regval; + + /* Hold the Ethernet PHY from transmitting energy on the line during + * configuration by setting the PHYHOLD bit in the EMACPC register. */ + + regval = tiva_getreg(TIVA_EMAC_PC); + regval |= EMAC_PC_PHYHOLD; + tiva_putreg(regval, TIVA_EMAC_PC); } -#endif /**************************************************************************** - * Function: tiva_phy_gpioconfig + * Function: tiva_phy_configure * * Description: - * Configure to support the internal PHY + * Configure to support an external PHY * * Parameters: * priv - A reference to the private driver state structure @@ -3221,87 +3226,77 @@ static inline void tiva_phy_reconfigure(FAR struct tiva_ethmac_s *priv) * ****************************************************************************/ -#ifdef CONFIG_TIVA_PHY_INTERNAL -static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv) +static void tiva_phy_configure(FAR struct tiva_ethmac_s *priv) { uint32_t regval; - /* Integrated PHY: - * - * "The Ethernet Controller Module and Integrated PHY receive two clock inputs: - * - A gated system clock acts as the clock source to the Control and Status - * registers (CSR) of the Ethernet MAC. The SYSCLK frequency for Run, Sleep - * and Deep Sleep mode is programmed in the System Control module. ... - * - The PHY receives the main oscillator (MOSC) which must be 25 MHz ± 50 ppm - * for proper operation. The MOSC source can be a single-ended source or a - * crystal." - * - * These are currently set up in tiva_clockconfig() before this function runs. - * - * MII/RMII Clocking: - * - * External PHY support is not yet implemented. - */ - - /* Enable the Ethernet PHY in its default configuration */ - /* Hold the Ethernet PHY from transmitting energy on the line during * configuration by setting the PHYHOLD bit in the EMACPC register. */ - regval = tiva_getreg(TIVA_EMAC_PC); - regval |= EMAC_PC_PHYHOLD; - tiva_putreg(regval, TIVA_EMAC_PC); + tiva_phy_hold(priv); - /* Enable the clock to the PHY module */ + /* Set up the PHY configuration */ - tiva_ephy_enableclk(); +#if defined(CONFIG_TIVA_PHY_RMII) + regval = EMAC_PC_PHYHOLD | EMAC_PC_PINTFS_RMII | EMAC_PC_PHYEXT; +#elif defined(CONFIG_TIVA_PHY_MII) + regval = EMAC_PC_PHYHOLD | EMAC_PC_PINTFS_MII | EMAC_PC_PHYEXT; +#else /* defined(CONFIG_TIVA_PHY_INTERNAL) */ + regval = EMAC_PC_PHYHOLD | EMAC_PC_MDIXEN | EMAC_PC_ANMODE_100FD | + EMAC_PC_ANEN | EMAC_PC_PINTFS_MII; +#endif + tiva_putreg(regval, TIVA_EMAC_PC); - /* What until the PREPHY register indicates that the PHY is ready before - * continuing. +#ifdef CONFIG_TIVA_PHY_INTERNAL + /* If we are using the internal PHY, reset it to ensure that new + * configuration is latched. */ - while (!tiva_ephy_periphrdy()) - { - } - - /* Enable power to the Ethernet PHY */ + regval = tiva_getreg(TIVA_SYSCON_SREPHY); + regval |= SYSCON_SREPHY_R0; + tiva_putreg(regval, TIVA_SYSCON_SREPHY); - tiva_ephy_enablepwr(); + regval &= ~SYSCON_SREPHY_R0; + tiva_putreg(regval, TIVA_SYSCON_SREPHY); - /* What until the PREPHY register indicates that the PHY registers are ready - * to be accessed. - */ + /* Wait for the reset to complete */ while (!tiva_ephy_periphrdy()) { } - /* The EMAC interface defaults to MII mode. */ + /* Delay a bit longer to ensure that the PHY reset has completed. */ - /* PHY interface pins: - * - * EN0TXOP - Fixed pin assignment - * EN0TXON - Fixed pin assignment - * EN0RXIP - Fixed pin assignment - * EN0RXIN - Fixed pin assignment - * RBIAS - Fixed pin assignment - * EN0LED0 - Configured GPIO output - * EN0LED1 - Configured GPIO output - * EN0LED2 - Configured GPIO output + up_udelay(250); +#endif + + /* If using an external RMII PHY, we must enable the external clock */ + + regval = tiva_getreg(TIVA_EMAC_CC); + +#if defined(CONFIG_TIVA_PHY_RMII) + /* Enable the external clock source input to the RMII interface signal + * EN0RREF_CLK by setting both the CLKEN bit in the Ethernet Clock + * Configuration (EMACCC) register. The external clock source must be + * 50 MHz with a frequency tolerance of 50 PPM. */ - tiva_configgpio(GPIO_EN0_LED0); - tiva_configgpio(GPIO_EN0_LED1); - tiva_configgpio(GPIO_EN0_LED2); -} + regval = tiva_getreg(TIVA_EMAC_CC); +#else + /* Disable the external clock */ + + regval &= ~EMAC_CC_CLKEN; #endif + tiva_putreg(regval, TIVA_EMAC_CC); +} + /**************************************************************************** - * Function: tiva_phy_reconfigure + * Function: tiva_phy_initialize * * Description: - * Configure to support an external PHY + * Perform one-time PHY initialization * * Parameters: * priv - A reference to the private driver state structure @@ -3313,18 +3308,13 @@ static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv) * ****************************************************************************/ -#ifndef CONFIG_TIVA_PHY_INTERNAL -static inline void tiva_phy_reconfigure(FAR struct tiva_ethmac_s *priv) +static inline void tiva_phy_initialize(FAR struct tiva_ethmac_s *priv) { - /* Enable the Ethernet PHY in a custom configuration */ - - /* 1. Hold the Ethernet PHY from transmitting energy on the line during - * configuration by setting the PHYHOLD bit in the EMACPC register. + /* Hold the Ethernet PHY from transmitting energy on the line during + * configuration by setting the PHYHOLD bit in the EMACPC register. */ - regval = tiva_getreg(TIVA_EMAC_PC); - regval |= EMAC_PC_PHYHOLD; - tiva_putreg(regval, TIVA_EMAC_PC) + tiva_phy_hold(priv); /* Enable the clock to the PHY module */ @@ -3350,80 +3340,49 @@ static inline void tiva_phy_reconfigure(FAR struct tiva_ethmac_s *priv) { } - /* Set up the custom PHY configuration. +#ifdef CONFIG_TIVA_PHY_INTERNAL + /* Integrated PHY: * - * NOTE: This custom PHY configuration will be lost after a reset. - */ - -#if defined(CONFIG_TIVA_PHY_MII) - /* Set up the external MII interface configuration */ -#warning Missing logic - -#elif defined(CONFIG_TIVA_PHY_RMII) - /* Set up the external RMII interface configuration */ -#warning Missing logic - - /* Enable the external clock source input to the RMII interface signal - * EN0RREF_CLK by setting both the ECEXT and CLKEN bit in the in the Ethernet - * Clock Configuration (EMACCC) register. The external clock source must be - * 50 MHz with a frequency tolerance of 50 PPM. - */ -#warning Missing logic - - /* Select the RMII interface by programming the PINTFS bit field to 0x4 in - * the Ethernet Peripheral Configuration (EMACPC) register. - */ -#warning Missing logic - - /* Reset the Ethernet MAC to latch the new RMII configuration by setting the - * SWR bit in the EMACDMABUSMOD register. This bit resets the Ethernet MAC - * registers in addition to configuring the RMII interface. + * "The Ethernet Controller Module and Integrated PHY receive two clock inputs: + * - A gated system clock acts as the clock source to the Control and Status + * registers (CSR) of the Ethernet MAC. The SYSCLK frequency for Run, Sleep + * and Deep Sleep mode is programmed in the System Control module. ... + * - The PHY receives the main oscillator (MOSC) which must be 25 MHz ± 50 ppm + * for proper operation. The MOSC source can be a single-ended source or a + * crystal." + * + * These are currently set up in tiva_clockconfig() before this function runs. + * + * MII/RMII Clocking: + * + * External PHY support is not yet implemented. */ -#warning Missing logic - /* Software must poll the SWR bit to determine when the new configuration has - * been registered. + /* PHY interface pins: * - * Note: After this configuration is active, if the Ethernet MAC is reset by - * setting the R0 bit in the Ethernet MAC Software Reset (SREMAC) register in - * the System Control Module, then the interface is set back to its default - * MII configuration. In this case, the steps listed above must be repeated to - * return to an RMII interface. + * EN0TXOP - Fixed pin assignment + * EN0TXON - Fixed pin assignment + * EN0RXIP - Fixed pin assignment + * EN0RXIN - Fixed pin assignment + * RBIAS - Fixed pin assignment + * EN0LED0 - Configured GPIO output + * EN0LED1 - Configured GPIO output + * EN0LED2 - Configured GPIO output */ -#warning Missing logic -#endif -} -#endif -/**************************************************************************** - * Function: tiva_phy_gpioconfig - * - * Description: - * Configure to support an external PHY - * - * Parameters: - * priv - A reference to the private driver state structure - * - * Returned Value: - * None. - * - * Assumptions: - * - ****************************************************************************/ + tiva_configgpio(GPIO_EN0_LED0); + tiva_configgpio(GPIO_EN0_LED1); + tiva_configgpio(GPIO_EN0_LED2); -#ifndef CONFIG_TIVA_PHY_INTERNAL -static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv) -{ -#if defined(CONFIG_TIVA_PHY_MII) || defined(CONFIG_TIVA_PHY_RMII) - /* Configure GPIO pins to support Ethernet */ +#else /* if defined(CONFIG_TIVA_PHY_MII) || defined(CONFIG_TIVA_PHY_RMII) */ + /* Configure GPIO pins to support MII or RMII */ /* MDC and MDIO are common to both modes */ tiva_configgpio(GPIO_EN0_MDC); tiva_configgpio(GPIO_EN0_MDIO); - /* Set up the MII interface */ - #if defined(CONFIG_TIVA_PHY_MII) + /* Set up the MII interface */ /* "Four clock inputs are driven into the Ethernet MAC when the MII * configuration is enabled. The clocks are described as follows: @@ -3470,9 +3429,8 @@ static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv) tiva_configgpio(GPIO_EN0_MII_TX_CLK); tiva_configgpio(GPIO_EN0_MII_TX_EN); - /* Set up the RMII interface. */ - #elif defined(CONFIG_TIVA_PHY_RMII) + /* Set up the RMII interface. */ /* "There are three clock sources that interface to the Ethernet MAC in * an RMII configuration: @@ -3496,35 +3454,6 @@ static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv) * for receive and transmit data." */ - /* Enable the external clock source input to the RMII interface signal - * EN0RREF_CLK by setting both the ECEXT and CLKEN bit in the in the Ethernet - * Clock Configuration (EMACCC) register. The external clock source must be - * 50 MHz with a frequency tolerance of 50 PPM. - */ -#warning Missing logic - - /* Select the RMII interface by programming the PINTFS bit field to 0x4 in - * the Ethernet Peripheral Configuration (EMACPC) register. - */ -#warning Missing logic - - /* Reset the Ethernet MAC to latch the new RMII configuration by setting the - * SWR bit in the EMACDMABUSMOD register. This bit resets the Ethernet MAC - * registers in addition to configuring the RMII interface. - */ -#warning Missing logic - - /* Software must poll the SWR bit to determine when the new configuration has - * been registered. - * - * Note: After this configuration is active, if the Ethernet MAC is reset by - * setting the R0 bit in the Ethernet MAC Software Reset (SREMAC) register in - * the System Control Module, then the interface is set back to its default - * MII configuration. In this case, the steps listed above must be repeated to - * return to an RMII interface. - */ -#warning Missing logic - /* RMII interface pins (7): * * RMII_TXD[1:0], RMII_TX_EN, RMII_RXD[1:0], RMII_CRS_DV, MDC, MDIO, @@ -3545,9 +3474,8 @@ static inline void tiva_phy_gpioconfig(FAR struct tiva_ethmac_s *priv) /* Enable pulse-per-second (PPS) output signal */ tiva_configgpio(GPIO_EN0_PPS); -#endif +#endif } -#endif /**************************************************************************** * Function: tiva_ethreset @@ -3578,18 +3506,9 @@ static void tiva_ethreset(FAR struct tiva_ethmac_s *priv) regval &= ~SYSCON_SREMAC_R0; tiva_putreg(regval, TIVA_SYSCON_SREMAC); - /* Reset the internal PHY - * - * NOTE: If a custom PHY configuration is used, then that configuration - * will be lost after the reset. - */ - - regval = tiva_getreg(TIVA_SYSCON_SREPHY); - regval |= SYSCON_SREPHY_R0; - tiva_putreg(regval, TIVA_SYSCON_SREPHY); + /* Configure the PHY */ - regval &= ~SYSCON_SREPHY_R0; - tiva_putreg(regval, TIVA_SYSCON_SREPHY); + tiva_phy_configure(priv); /* Perform a software reset by setting the SR bit in the DMABUSMOD register. * This Resets all MAC subsystem internal registers and logic. After this @@ -3605,16 +3524,7 @@ static void tiva_ethreset(FAR struct tiva_ethmac_s *priv) */ while ((tiva_getreg(TIVA_EMAC_DMABUSMOD) & EMAC_DMABUSMOD_SWR) != 0); - - /* If the RMII configuration is active when the Ethernet MAC is reset, - * then the interface is set back to its default MII configuration. In - * this case, the we must restore the RMII interface configuration. - * - * Also, if the PHY is used any custom configuration, then the PHY - * must be reconfigured after the reset. - */ - - tiva_phy_reconfigure(priv); + up_udelay(250); } /**************************************************************************** @@ -3970,7 +3880,7 @@ int tiva_ethinitialize(int intf) /* Configure GPIOs to support the internal/eternal PHY */ - tiva_phy_gpioconfig(priv); + tiva_phy_initialize(priv); /* Attach the IRQ to the driver */ |