STM32驱动lan8720a DP83848相关说明

stm32 lan8720 dp83848
摘要由CSDN通过智能技术生成

对LAN8720和DP83848使用上的一些问题补充。
除了芯片焊接不良导致的问题以外,说一下芯片设置相关问题。

  1. 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
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值