netdrv_eth_rmii.lua 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. --[[
  2. @module netdrv_eth_rmii
  3. @summary “通过MAC层的rmii接口外挂PHY芯片(LAN8720Ai)的以太网卡”驱动模块
  4. @version 1.0
  5. @date 2025.07.24
  6. @author 马梦阳
  7. @usage
  8. 本文件为“通过MAC层的rmii接口外挂PHY芯片(LAN8720Ai)的以太网卡”驱动模块 ,核心业务逻辑为:
  9. 1、打开PHY芯片供电开关;
  10. 2、初始化以太网卡,并且在以太网卡上开启DHCP(动态主机配置协议);
  11. 3、以太网卡的连接状态发生变化时,在日志中进行打印;
  12. Air8101核心板和AirPHY_1000配件板的硬件接线方式为:
  13. Air8101核心板通过TYPE-C USB口供电(核心板背面的功耗测试开关拨到OFF一端);
  14. 如果测试发现软件重启,并且日志中出现 poweron reason 0,表示供电不足,此时再通过直流稳压电源对核心板的VIN管脚进行5V供电;
  15. | Air8101核心板 | AirPHY_1000配件板 |
  16. | ------------ | ------------------ |
  17. | 59/3V3 | 3.3v |
  18. | gnd | gnd |
  19. | 5/D2 | RX1 |
  20. | 72/D1 | RX0 |
  21. | 71/D3 | CRS |
  22. | 4/D0 | MDIO |
  23. | 6/D4 | TX0 |
  24. | 74/PCK | MDC |
  25. | 70/D5 | TX1 |
  26. | 7/D6 | TXEN |
  27. | 不接 | NC |
  28. | 69/D7 | CLK |
  29. 本文件没有对外接口,直接在其他功能模块中require "netdrv_eth_rmii"就可以加载运行;
  30. ]]
  31. local function ip_ready_func(ip, adapter)
  32. if adapter == socket.LWIP_ETH then
  33. log.info("netdrv_eth_rmii.ip_ready_func", "IP_READY", socket.localIP(socket.LWIP_ETH))
  34. sys.publish("CREATE_OK")
  35. end
  36. end
  37. local function ip_lose_func(adapter)
  38. if adapter == socket.LWIP_ETH then
  39. log.warn("netdrv_eth_rmii.ip_lose_func", "IP_LOSE")
  40. end
  41. end
  42. -- 此处订阅"IP_READY"和"IP_LOSE"两种消息
  43. -- 在消息的处理函数中,仅仅打印了一些信息,便于实时观察“通过MAC层的rmii接口外挂PHY芯片(LAN8720Ai)的以太网卡”的连接状态
  44. -- 也可以根据自己的项目需求,在消息处理函数中增加自己的业务逻辑控制,例如可以在连网状态发生改变时更新网络图标
  45. sys.subscribe("IP_READY", ip_ready_func)
  46. sys.subscribe("IP_LOSE", ip_lose_func)
  47. -- 设置默认网卡为socket.LWIP_ETH
  48. socket.dft(socket.LWIP_ETH)
  49. -- 本demo测试使用的是核心板的VDD 3V3引脚对AirPHY_1000配件板进行供电
  50. -- VDD 3V3引脚是Air8101内部的LDO输出引脚,最大输出电流300mA
  51. -- GPIO13在Air8101内部使能控制这个LDO的输出
  52. -- 所以在此处GPIO13输出高电平打开这个LDO
  53. gpio.setup(13, 1, gpio.PULLUP)
  54. --初始化以太网卡
  55. --以太网联网成功(成功连接路由器,并且获取到了IP地址)后,内核固件会产生一个"IP_READY"消息
  56. --各个功能模块可以订阅"IP_READY"消息实时处理以太网联网成功的事件
  57. --也可以在任何时刻调用socket.adapter(socket.LWIP_ETH)来获取以太网是否连接成功
  58. --以太网断网后,内核固件会产生一个"IP_LOSE"消息
  59. --各个功能模块可以订阅"IP_LOSE"消息实时处理以太网断网的事件
  60. --也可以在任何时刻调用socket.adapter(socket.LWIP_ETH)来获取以太网是否连接成功
  61. netdrv.setup(socket.LWIP_ETH)
  62. --在以太网卡上开启动态主机配置协议
  63. netdrv.dhcp(socket.LWIP_ETH, true)