update stm32f107 ethernet driver
git-svn-id: https://rt-thread.googlecode.com/svn/trunk@1804 bbd45198-f89e-11dd-88c7-29a3b14d5316
This commit is contained in:
parent
7eaac75bcb
commit
fbd0b064c4
|
@ -26,7 +26,6 @@
|
||||||
#define CHECKSUM_BY_HARDWARE
|
#define CHECKSUM_BY_HARDWARE
|
||||||
#define MII_MODE /* MII mode for STM3210C-EVAL Board (MB784) (check jumpers setting) */
|
#define MII_MODE /* MII mode for STM3210C-EVAL Board (MB784) (check jumpers setting) */
|
||||||
//#define RMII_MODE /* RMII mode for STM3210C-EVAL Board (MB784) (check jumpers setting) */
|
//#define RMII_MODE /* RMII mode for STM3210C-EVAL Board (MB784) (check jumpers setting) */
|
||||||
#define PHY_ADDRESS 0x01 /* Relative to STM3210C-EVAL Board */
|
|
||||||
|
|
||||||
|
|
||||||
/** @addtogroup STM32_ETH_Driver
|
/** @addtogroup STM32_ETH_Driver
|
||||||
|
@ -134,17 +133,17 @@ void ETH_DeInit(void)
|
||||||
* parameters in the ETH_InitStruct .
|
* parameters in the ETH_InitStruct .
|
||||||
* @param ETH_InitStruct: pointer to a ETH_InitTypeDef structure that contains
|
* @param ETH_InitStruct: pointer to a ETH_InitTypeDef structure that contains
|
||||||
* the configuration information for the specified ETHERNET peripheral.
|
* the configuration information for the specified ETHERNET peripheral.
|
||||||
* @param PHYAddress: external PHY address
|
|
||||||
* @retval ETH_ERROR: Ethernet initialization failed
|
* @retval ETH_ERROR: Ethernet initialization failed
|
||||||
* ETH_SUCCESS: Ethernet successfully initialized
|
* ETH_SUCCESS: Ethernet successfully initialized
|
||||||
*/
|
*/
|
||||||
uint32_t ETH_Init(ETH_InitTypeDef* ETH_InitStruct, uint16_t PHYAddress)
|
uint32_t ETH_Init(ETH_InitTypeDef* ETH_InitStruct)
|
||||||
{
|
{
|
||||||
uint32_t RegValue = 0, tmpreg = 0;
|
uint32_t tmpreg = 0;
|
||||||
__IO uint32_t i = 0;
|
__IO uint32_t i = 0;
|
||||||
RCC_ClocksTypeDef rcc_clocks;
|
RCC_ClocksTypeDef rcc_clocks;
|
||||||
uint32_t hclk = 60000000;
|
uint32_t hclk = 60000000;
|
||||||
__IO uint32_t timeout = 0;
|
__IO uint32_t timeout = 0;
|
||||||
|
|
||||||
/* Check the parameters */
|
/* Check the parameters */
|
||||||
/* MAC --------------------------*/
|
/* MAC --------------------------*/
|
||||||
assert_param(IS_ETH_AUTONEGOTIATION(ETH_InitStruct->ETH_AutoNegotiation));
|
assert_param(IS_ETH_AUTONEGOTIATION(ETH_InitStruct->ETH_AutoNegotiation));
|
||||||
|
@ -193,6 +192,7 @@ uint32_t ETH_Init(ETH_InitTypeDef* ETH_InitStruct, uint16_t PHYAddress)
|
||||||
assert_param(IS_ETH_TXDMA_BURST_LENGTH(ETH_InitStruct->ETH_TxDMABurstLength));
|
assert_param(IS_ETH_TXDMA_BURST_LENGTH(ETH_InitStruct->ETH_TxDMABurstLength));
|
||||||
assert_param(IS_ETH_DMA_DESC_SKIP_LENGTH(ETH_InitStruct->ETH_DescriptorSkipLength));
|
assert_param(IS_ETH_DMA_DESC_SKIP_LENGTH(ETH_InitStruct->ETH_DescriptorSkipLength));
|
||||||
assert_param(IS_ETH_DMA_ARBITRATION_ROUNDROBIN_RXTX(ETH_InitStruct->ETH_DMAArbitration));
|
assert_param(IS_ETH_DMA_ARBITRATION_ROUNDROBIN_RXTX(ETH_InitStruct->ETH_DMAArbitration));
|
||||||
|
|
||||||
/*-------------------------------- MAC Config ------------------------------*/
|
/*-------------------------------- MAC Config ------------------------------*/
|
||||||
/*---------------------- ETHERNET MACMIIAR Configuration -------------------*/
|
/*---------------------- ETHERNET MACMIIAR Configuration -------------------*/
|
||||||
/* Get the ETHERNET MACMIIAR value */
|
/* Get the ETHERNET MACMIIAR value */
|
||||||
|
@ -220,94 +220,7 @@ uint32_t ETH_Init(ETH_InitTypeDef* ETH_InitStruct, uint16_t PHYAddress)
|
||||||
}
|
}
|
||||||
/* Write to ETHERNET MAC MIIAR: Configure the ETHERNET CSR Clock Range */
|
/* Write to ETHERNET MAC MIIAR: Configure the ETHERNET CSR Clock Range */
|
||||||
ETH->MACMIIAR = (uint32_t)tmpreg;
|
ETH->MACMIIAR = (uint32_t)tmpreg;
|
||||||
/*-------------------- PHY initialization and configuration ----------------*/
|
|
||||||
/* Put the PHY in reset mode */
|
|
||||||
if(!(ETH_WritePHYRegister(PHYAddress, PHY_BCR, PHY_Reset)))
|
|
||||||
{
|
|
||||||
/* Return ERROR in case of write timeout */
|
|
||||||
return ETH_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Delay to assure PHY reset */
|
|
||||||
for(i = PHY_ResetDelay; i != 0; i--)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
if(ETH_InitStruct->ETH_AutoNegotiation != ETH_AutoNegotiation_Disable)
|
|
||||||
{
|
|
||||||
/* We wait for linked satus... */
|
|
||||||
do
|
|
||||||
{
|
|
||||||
timeout++;
|
|
||||||
} while (!(ETH_ReadPHYRegister(PHYAddress, PHY_BSR) & PHY_Linked_Status) && (timeout < PHY_READ_TO));
|
|
||||||
/* Return ERROR in case of timeout */
|
|
||||||
if(timeout == PHY_READ_TO)
|
|
||||||
{
|
|
||||||
return ETH_ERROR;
|
|
||||||
}
|
|
||||||
/* Reset Timeout counter */
|
|
||||||
timeout = 0;
|
|
||||||
|
|
||||||
/* Enable Auto-Negotiation */
|
|
||||||
if(!(ETH_WritePHYRegister(PHYAddress, PHY_BCR, PHY_AutoNegotiation)))
|
|
||||||
{
|
|
||||||
/* Return ERROR in case of write timeout */
|
|
||||||
return ETH_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Wait until the autonegotiation will be completed */
|
|
||||||
do
|
|
||||||
{
|
|
||||||
timeout++;
|
|
||||||
} while (!(ETH_ReadPHYRegister(PHYAddress, PHY_BSR) & PHY_AutoNego_Complete) && (timeout < (uint32_t)PHY_READ_TO));
|
|
||||||
/* Return ERROR in case of timeout */
|
|
||||||
if(timeout == PHY_READ_TO)
|
|
||||||
{
|
|
||||||
return ETH_ERROR;
|
|
||||||
}
|
|
||||||
/* Reset Timeout counter */
|
|
||||||
timeout = 0;
|
|
||||||
|
|
||||||
/* Read the result of the autonegotiation */
|
|
||||||
RegValue = ETH_ReadPHYRegister(PHYAddress, PHY_SR);
|
|
||||||
|
|
||||||
/* Configure the MAC with the Duplex Mode fixed by the autonegotiation process */
|
|
||||||
if((RegValue & PHY_Duplex_Status) != (uint32_t)RESET)
|
|
||||||
{
|
|
||||||
/* Set Ethernet duplex mode to FullDuplex following the autonegotiation */
|
|
||||||
ETH_InitStruct->ETH_Mode = ETH_Mode_FullDuplex;
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Set Ethernet duplex mode to HalfDuplex following the autonegotiation */
|
|
||||||
ETH_InitStruct->ETH_Mode = ETH_Mode_HalfDuplex;
|
|
||||||
}
|
|
||||||
/* Configure the MAC with the speed fixed by the autonegotiation process */
|
|
||||||
if(RegValue & PHY_Speed_Status)
|
|
||||||
{
|
|
||||||
/* Set Ethernet speed to 10M following the autonegotiation */
|
|
||||||
ETH_InitStruct->ETH_Speed = ETH_Speed_10M;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Set Ethernet speed to 100M following the autonegotiation */
|
|
||||||
ETH_InitStruct->ETH_Speed = ETH_Speed_100M;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if(!ETH_WritePHYRegister(PHYAddress, PHY_BCR, ((uint16_t)(ETH_InitStruct->ETH_Mode >> 3) |
|
|
||||||
(uint16_t)(ETH_InitStruct->ETH_Speed >> 1))))
|
|
||||||
{
|
|
||||||
/* Return ERROR in case of write timeout */
|
|
||||||
return ETH_ERROR;
|
|
||||||
}
|
|
||||||
/* Delay to assure PHY configuration */
|
|
||||||
for(i = PHY_ConfigDelay; i != 0; i--)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*------------------------ ETHERNET MACCR Configuration --------------------*/
|
/*------------------------ ETHERNET MACCR Configuration --------------------*/
|
||||||
/* Get the ETHERNET MACCR value */
|
/* Get the ETHERNET MACCR value */
|
||||||
tmpreg = ETH->MACCR;
|
tmpreg = ETH->MACCR;
|
||||||
|
@ -3139,77 +3052,6 @@ void ETH_IRQHandler(void)
|
||||||
rt_interrupt_leave();
|
rt_interrupt_leave();
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MICR 0x11
|
|
||||||
#define MISR 0x12
|
|
||||||
|
|
||||||
void EXTI9_5_IRQHandler(void)
|
|
||||||
{
|
|
||||||
volatile rt_uint16_t status;
|
|
||||||
|
|
||||||
/* enter interrupt */
|
|
||||||
rt_interrupt_enter();
|
|
||||||
|
|
||||||
status = ETH_ReadPHYRegister(PHY_ADDRESS, MISR);
|
|
||||||
if (status & (1 << 13))
|
|
||||||
{
|
|
||||||
/* change of link */
|
|
||||||
status = ETH_ReadPHYRegister(PHY_ADDRESS, PHY_SR);
|
|
||||||
if (status & 0x01) /* link established */
|
|
||||||
{
|
|
||||||
netif_set_link_up(stm32_eth_device.parent.netif);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
netif_set_link_down(stm32_eth_device.parent.netif);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Clear the Key Button EXTI line pending bit */
|
|
||||||
EXTI_ClearITPendingBit(EXTI_Line5);
|
|
||||||
|
|
||||||
/* leave interrupt */
|
|
||||||
rt_interrupt_leave();
|
|
||||||
}
|
|
||||||
|
|
||||||
void rt_eth_phy_init(void)
|
|
||||||
{
|
|
||||||
GPIO_InitTypeDef GPIO_InitStructure;
|
|
||||||
EXTI_InitTypeDef EXTI_InitStructure;
|
|
||||||
NVIC_InitTypeDef NVIC_InitStructure;
|
|
||||||
|
|
||||||
/* Configure PC5 as input for PHY interrupt */
|
|
||||||
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
|
|
||||||
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
|
|
||||||
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;
|
|
||||||
GPIO_Init(GPIOC, &GPIO_InitStructure);
|
|
||||||
|
|
||||||
/* Connect PHY Interrupt Line to GPIOC Pin 5 */
|
|
||||||
GPIO_EXTILineConfig(GPIO_PortSourceGPIOC, GPIO_PinSource5);
|
|
||||||
|
|
||||||
/* Configure PHY Interrupt Line to generate an interrupt on falling edge */
|
|
||||||
EXTI_InitStructure.EXTI_Line = EXTI_Line5;
|
|
||||||
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
|
|
||||||
EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
|
|
||||||
EXTI_InitStructure.EXTI_LineCmd = ENABLE;
|
|
||||||
EXTI_Init(&EXTI_InitStructure);
|
|
||||||
|
|
||||||
/* set PHY interrupt */
|
|
||||||
ETH_WritePHYRegister(PHY_ADDRESS, MICR, 0x0003);
|
|
||||||
ETH_WritePHYRegister(PHY_ADDRESS, MISR, 0x0060);
|
|
||||||
|
|
||||||
/* Clear PHY Interrupt Line pending bit */
|
|
||||||
EXTI_ClearITPendingBit(EXTI_Line5);
|
|
||||||
|
|
||||||
|
|
||||||
/* Enable the EXTI0 Interrupt */
|
|
||||||
NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQn;
|
|
||||||
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
|
|
||||||
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
|
|
||||||
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
|
|
||||||
NVIC_Init(&NVIC_InitStructure);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/* RT-Thread Device Interface */
|
/* RT-Thread Device Interface */
|
||||||
|
|
||||||
/* initialize the interface */
|
/* initialize the interface */
|
||||||
|
@ -3267,7 +3109,7 @@ static rt_err_t rt_stm32_eth_init(rt_device_t dev)
|
||||||
ETH_InitStructure.ETH_DMAArbitration = ETH_DMAArbitration_RoundRobin_RxTx_2_1;
|
ETH_InitStructure.ETH_DMAArbitration = ETH_DMAArbitration_RoundRobin_RxTx_2_1;
|
||||||
|
|
||||||
/* Configure ETHERNET */
|
/* Configure ETHERNET */
|
||||||
Value = ETH_Init(Ð_InitStructure, PHY_ADDRESS);
|
Value = ETH_Init(Ð_InitStructure);
|
||||||
|
|
||||||
/* Enable DMA Receive interrupt (need to enable in this case Normal interrupt) */
|
/* Enable DMA Receive interrupt (need to enable in this case Normal interrupt) */
|
||||||
ETH_DMAITConfig(ETH_DMA_IT_NIS | ETH_DMA_IT_R | ETH_DMA_IT_T, ENABLE);
|
ETH_DMAITConfig(ETH_DMA_IT_NIS | ETH_DMA_IT_R | ETH_DMA_IT_T, ENABLE);
|
||||||
|
@ -3674,21 +3516,3 @@ void rt_hw_stm32_eth_init()
|
||||||
eth_device_init(&(stm32_eth_device.parent), "e0");
|
eth_device_init(&(stm32_eth_device.parent), "e0");
|
||||||
}
|
}
|
||||||
|
|
||||||
#include <finsh.h>
|
|
||||||
void phy(void)
|
|
||||||
{
|
|
||||||
rt_uint16_t v;
|
|
||||||
|
|
||||||
v = ETH_ReadPHYRegister(PHY_ADDRESS, PHY_BCR);
|
|
||||||
rt_kprintf("PHY BCR: 0x%04x\n", v);
|
|
||||||
v = ETH_ReadPHYRegister(PHY_ADDRESS, PHY_BSR);
|
|
||||||
rt_kprintf("PHY BSR: 0x%04x\n", v);
|
|
||||||
v = ETH_ReadPHYRegister(PHY_ADDRESS, PHY_SR);
|
|
||||||
rt_kprintf("PHY SR: 0x%04x\n", v);
|
|
||||||
v = ETH_ReadPHYRegister(PHY_ADDRESS, 0x11);
|
|
||||||
rt_kprintf("PHY MICR: 0x%04x\n", v);
|
|
||||||
v = ETH_ReadPHYRegister(PHY_ADDRESS, 0x12);
|
|
||||||
rt_kprintf("PHY MISR: 0x%04x\n", v);
|
|
||||||
}
|
|
||||||
FINSH_FUNCTION_EXPORT(phy, read phy);
|
|
||||||
|
|
||||||
|
|
|
@ -1581,7 +1581,7 @@ typedef struct {
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
void ETH_DeInit(void);
|
void ETH_DeInit(void);
|
||||||
uint32_t ETH_Init(ETH_InitTypeDef* ETH_InitStruct, u16 PHYAddress);
|
uint32_t ETH_Init(ETH_InitTypeDef* ETH_InitStruct);
|
||||||
void ETH_StructInit(ETH_InitTypeDef* ETH_InitStruct);
|
void ETH_StructInit(ETH_InitTypeDef* ETH_InitStruct);
|
||||||
void ETH_SoftwareReset(void);
|
void ETH_SoftwareReset(void);
|
||||||
FlagStatus ETH_GetSoftwareResetStatus(void);
|
FlagStatus ETH_GetSoftwareResetStatus(void);
|
||||||
|
|
Loading…
Reference in New Issue