netdrv_eth_spi.lua 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. --[[
  2. @module netdrv_eth_spi
  3. @summary “通过SPI外挂CH390H芯片的以太网卡”驱动模块
  4. @version 1.0
  5. @date 2025.07.24
  6. @author 朱天华
  7. @usage
  8. 本文件为“通过SPI外挂CH390H芯片的以太网卡”驱动模块,核心业务逻辑为:
  9. 1、默认开启AirETH_1000配件板供电开关;
  10. 2、初始化spi0,初始化以太网卡,并且在以太网卡上开启DHCP(动态主机配置协议);
  11. 3、以太网卡的连接状态发生变化时,在日志中进行打印;
  12. Air780EXX核心板和AirETH_1000配件板的硬件接线方式为:
  13. 核心板通过TYPE-C USB口供电(TYPE-C USB口旁边的ON/OFF拨动开关拨到ON一端);
  14. 如果测试发现软件重启,并且日志中出现 poweron reason 0,表示供电不足,此时再通过直流稳压电源对核心板的5V管脚进行5V供电;
  15. | Air780EXX核心板 | AirETH_1000配件板 |
  16. | --------------- | ----------------- |
  17. | 3V3 | 3.3v |
  18. | gnd | gnd |
  19. | 86/SPI0CLK | SCK |
  20. | 83/SPI0CS | CSS |
  21. | 84/SPI0MISO | SDO |
  22. | 85/SPI0MOSI | SDI |
  23. | 107/GPIO21 | INT |
  24. 本文件没有对外接口,直接在其他功能模块中require "netdrv_eth_spi"就可以加载运行;
  25. ]]
  26. local function ip_ready_func(ip, adapter)
  27. if adapter == socket.LWIP_ETH then
  28. log.info("netdrv_eth_spi.ip_ready_func", "IP_READY", socket.localIP(socket.LWIP_ETH))
  29. end
  30. end
  31. local function ip_lose_func(adapter)
  32. if adapter == socket.LWIP_ETH then
  33. log.warn("netdrv_eth_spi.ip_lose_func", "IP_LOSE")
  34. end
  35. end
  36. -- 此处订阅"IP_READY"和"IP_LOSE"两种消息
  37. -- 在消息的处理函数中,仅仅打印了一些信息,便于实时观察“通过SPI外挂CH390H芯片的以太网卡”的连接状态
  38. -- 也可以根据自己的项目需求,在消息处理函数中增加自己的业务逻辑控制,例如可以在连网状态发生改变时更新网络图标
  39. sys.subscribe("IP_READY", ip_ready_func)
  40. sys.subscribe("IP_LOSE", ip_lose_func)
  41. -- 设置默认网卡为socket.LWIP_ETH
  42. socket.dft(socket.LWIP_ETH)
  43. -- 本demo测试使用的是Air780EXX核心板
  44. -- 核心板的VDD 3V3管脚对AirETH_1000配件板进行供电
  45. -- 3V3管脚是作为LDO 3.3V输出,供测试用的,仅在使用DCDC供电时有输出,默认打开,无需控制
  46. -- 这个task的核心业务逻辑是:初始化SPI,初始化以太网卡,并在以太网卡上开启动态主机配置协议
  47. local function netdrv_eth_spi_task_func()
  48. -- 初始化SPI1
  49. local result = spi.setup(
  50. 0,--spi_id
  51. nil,
  52. 0,--CPHA
  53. 0,--CPOL
  54. 8,--数据宽度
  55. 25600000--,--频率
  56. -- spi.MSB,--高低位顺序 可选,默认高位在前
  57. -- spi.master,--主模式 可选,默认主
  58. -- spi.full--全双工 可选,默认全双工
  59. )
  60. log.info("netdrv_eth_spi", "spi open result", result)
  61. --返回值为0,表示打开成功
  62. if result ~= 0 then
  63. log.error("netdrv_eth_spi", "spi open error",result)
  64. return
  65. end
  66. --初始化以太网卡
  67. --以太网联网成功(成功连接路由器,并且获取到了IP地址)后,内核固件会产生一个"IP_READY"消息
  68. --各个功能模块可以订阅"IP_READY"消息实时处理以太网联网成功的事件
  69. --也可以在任何时刻调用socket.adapter(socket.LWIP_ETH)来获取以太网是否连接成功
  70. --以太网断网后,内核固件会产生一个"IP_LOSE"消息
  71. --各个功能模块可以订阅"IP_LOSE"消息实时处理以太网断网的事件
  72. --也可以在任何时刻调用socket.adapter(socket.LWIP_ETH)来获取以太网是否连接成功
  73. -- socket.LWIP_ETH 指定网络适配器编号
  74. -- netdrv.CH390外挂CH390
  75. -- SPI ID 0, 片选 GPIO8
  76. netdrv.setup(socket.LWIP_ETH, netdrv.CH390, {spi=0, cs=8})
  77. -- 在以太网上开启动态主机配置协议
  78. netdrv.dhcp(socket.LWIP_ETH, true)
  79. end
  80. -- 创建并且启动一个task
  81. -- task的处理函数为netdrv_eth_spi_task_func
  82. sys.taskInit(netdrv_eth_spi_task_func)