--[[ @module netdrv_eth_spi @summary “通过SPI外挂CH390H芯片的以太网卡”驱动模块 @version 1.0 @date 2025.07.24 @author 朱天华 @usage 本文件为“通过SPI外挂CH390H芯片的以太网卡”驱动模块,核心业务逻辑为: 1、打开CH390H芯片供电开关; 2、初始化spi1,初始化以太网卡,并且在以太网卡上开启DHCP(动态主机配置协议); 3、以太网卡的连接状态发生变化时,在日志中进行打印; 直接使用Air8000开发板硬件测试即可; 本文件没有对外接口,直接在其他功能模块中require "netdrv_eth_spi"就可以加载运行; ]] local function ip_ready_func(ip, adapter) if adapter == socket.LWIP_ETH then log.info("netdrv_eth_spi.ip_ready_func", "IP_READY", socket.localIP(socket.LWIP_ETH)) end end local function ip_lose_func(adapter) if adapter == socket.LWIP_ETH then log.warn("netdrv_eth_spi.ip_lose_func", "IP_LOSE") end end -- 此处订阅"IP_READY"和"IP_LOSE"两种消息 -- 在消息的处理函数中,仅仅打印了一些信息,便于实时观察“通过SPI外挂CH390H芯片的以太网卡”的连接状态 -- 也可以根据自己的项目需求,在消息处理函数中增加自己的业务逻辑控制,例如可以在连网状态发生改变时更新网络图标 sys.subscribe("IP_READY", ip_ready_func) sys.subscribe("IP_LOSE", ip_lose_func) -- 设置默认网卡为socket.LWIP_ETH socket.dft(socket.LWIP_ETH) -- 本demo测试使用的是Air8000开发板 -- GPIO140为CH390H以太网芯片的供电使能控制引脚 gpio.setup(140, 1, gpio.PULLUP) -- 这个task的核心业务逻辑是:初始化SPI,初始化以太网卡,并在以太网卡上开启动态主机配置协议 local function netdrv_eth_spi_task_func() -- 初始化SPI1 local result = spi.setup( 1,--spi_id nil, 0,--CPHA 0,--CPOL 8,--数据宽度 25600000--,--频率 -- spi.MSB,--高低位顺序 可选,默认高位在前 -- spi.master,--主模式 可选,默认主 -- spi.full--全双工 可选,默认全双工 ) log.info("netdrv_eth_spi", "spi open result", result) --返回值为0,表示打开成功 if result ~= 0 then log.error("netdrv_eth_spi", "spi open error",result) return end --初始化以太网卡 --以太网联网成功(成功连接路由器,并且获取到了IP地址)后,内核固件会产生一个"IP_READY"消息 --各个功能模块可以订阅"IP_READY"消息实时处理以太网联网成功的事件 --也可以在任何时刻调用socket.adapter(socket.LWIP_ETH)来获取以太网是否连接成功 --以太网断网后,内核固件会产生一个"IP_LOSE"消息 --各个功能模块可以订阅"IP_LOSE"消息实时处理以太网断网的事件 --也可以在任何时刻调用socket.adapter(socket.LWIP_ETH)来获取以太网是否连接成功 -- socket.LWIP_ETH 指定网络适配器编号 -- netdrv.CH390外挂CH390 -- SPI ID 1, 片选 GPIO12 netdrv.setup(socket.LWIP_ETH, netdrv.CH390, {spi=1, cs=12}) -- 在以太网上开启动态主机配置协议 netdrv.dhcp(socket.LWIP_ETH, true) end -- 创建并且启动一个task -- task的处理函数为netdrv_eth_spi_task_func sys.taskInit(netdrv_eth_spi_task_func)