对LAN8720和DP83848使用上的一些问题补充。
除了芯片焊接不良导致的问题以外,说一下芯片设置相关问题。
- DP83848和LAN8720虽然网络引脚和串行管理引脚都是兼容使用的,但是他们的这些引脚复用定义上有差别。这将导致STM32官方驱动,在配置上会有差异。
举例:比如配置这两款芯片的全双工/半双工以及100M/10M模式。
a.lan8720:手册有如下一段介绍
从上图中可以看出,mode0,mode1,mode2同时被复用为rxd0,rxd1及crs_dv
b. dp83848: 手册有如下介绍
RXD0,RXD1分别复用为PHYAD1和PHYAD2,而PHYAD1和PHYAD2有关系到DP83848的物理地址,描述如下:
这里的意思大概是由于PHYAD[0]引脚有弱内部上拉电阻和PHYAD[4:1]引脚有弱内部下拉电阻,PHY地址的默认设置是00001 (01h)。
参见下图,了解PHYAD连接到外部组件的示例。在本例中,PHYAD绑定的结果是地址00011 (03h)。
2. 如果要对这两款芯片做程序兼容,或者互相之间进行程序的修改转换,需要对stm32官方的驱动文件做相关的修改.
a.
u8 lan8720_Init(void)
{
u8 rval=0;
GPIO_InitTypeDef GPIO_InitStructure;
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA|RCC_AHB1Periph_GPIOC|RCC_AHB1Periph_GPIOD|RCC_AHB1Periph_GPIOG, ENABLE); //使能GPIO时钟 RMII接口
RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE); //使能SYSCFG时钟
SYSCFG_ETH_MediaInterfaceConfig(SYSCFG_ETH_MediaInterface_RMII); //MAC和PHY之间使用RMII接口
/*网络引脚设置 RMII接口
ETH_MDIO -------------------------> PA2
ETH_MDC --------------------------> PC1
ETH_RMII_REF_CLK------------------> PA1
ETH_RMII_CRS_DV ------------------> PA7
ETH_RMII_RXD0 --------------------> PC4
ETH_RMII_RXD1 --------------------> PC5
ETH_RMII_TX_EN -------------------> PG11
ETH_RMII_TXD0 --------------------> PG13
ETH_RMII_TXD1 --------------------> PG14
ETH_RES