netdrv_eth_spi.lua 4.2 KB

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