新闻  |   论坛  |   博客  |   在线研讨会
高性能!Air8101模块助力设备一键接入以太网~
13673998452 | 2025-04-08 14:10:11    阅读:29   发布文章

以太网(Ethernet)外设驱动涉及硬件与软件的深度交互,其核心在于通过特定接口连接主处理器与以太网控制器,实现数据的发送、接收以及数据链路层处理等功能,部分控制器还集成了TCP/IP协议栈以简化网络应用开发,从而支持多通道通信和高效的网络数据传输。

最新开发资料详见:
www.air8101.cn


一、主要硬件准备


 

1.1 主要硬件

Air8101开发板套件;

支持数据传输的USB数据线;

Win10及其以上PC电脑。

1.2 接线示意

配套以太网小板,可以直插到Air8101开发板上,对应端口如下图示:

wKgZO2frgOqAMKkuAARuESH3274988.pngwKgZPGfrgQWAcUvcAALzYUe-X2U681.png


需要注意的是:

因前期B10版本的开发板设计原因,测试以太网功能时,需要把SNeT的3.3V单独接到板子右侧SWD的3.3V。

实物连线如下图示:

wKgZO2frgViAaBaxAAsUNzXHxok896.png


二、最新源码及实操教程


Air8101应用示例持续更新中,当前以太网示例demo及实操教程,将教你使用LuatOS开发,实现Air8101通过以太网小板LAN8720连接网络。

最新源码及实操教程详见:

https://docs.openluat.com/air8101/luatos/app/driver/eth/

1)示例代码:

wKgZO2frgbiAfX2SAALms7RYCzo039.pngwKgZO2frgdGAXiZwAAFbiDTurfo704.png

2)运行示意:

wKgZO2frgpWAE_aSAAR5OaYtKjY745.pngwKgZPGfrgquAIMgYAAU1HfA_lPk015.png



三、核心脚本代码详解 

netdrv接口提供了一系列函数,用于实现相关网络配置与管理功能。


3.1 初始化指定netdrv设备

netdrv.setup(id, tp, opts)

1)参数:

id:int型(网络适配器编号,例如socket.LWIP_ETH);

tp:int型(实现方式,如果是设备自带的硬件,那就不需要传,外挂设备需要传,当前支持CH390H/D);

opts:int型(外挂方式,需要额外的参数,参考示例)。

2)返回值:

返回值类型:boolean;

说明:初始化成功与否。

3)例子:

wKgZO2frgyiAIVlRAAEG8PslOxM956.png


3.2 开启或关闭DHCP

netdrv.dhcp(id, enable)

1)参数:

id:int型(网络适配器编号,例如socket.LWIP_ETH);

enable:boolean型(开启或者关闭)。

2)返回值:

返回值类型:boolean;

说明:成功与否。

3)例子:

wKgZO2frg2KAcEgxAAA4G1E0VRE504.png


3.3 设置或获取设备MAC

netdrv.mac(id, new_mac, raw_string)。

1)参数:

id:int型(网络适配器编号,例如socket.LWIP_ETH);

new_mac:string型(新的MAC地址,可选,必须是6个字节);

raw_string:boolean型(是否返回6字节原始数据,默认是否,返回HEX字符串)。

2)返回值:

返回值类型:boolean;

说明:成功与否。

3)例子:

wKgZPGfrg5-AWQ3TAABt3akDnyA446.png


3.4 设置或读取ipv4地址

netdrv.ipv4(id, addr, mark, gw)

1)参数:

id:int型(网络适配器编号,例如socket.LWIP_ETH);

addr:string型(ipv4地址,如果是读取就不需要传);

mark:string型(掩码);

gw:string型(网关)。

2)返回值:

addr:string型(ipv4地址);

mark:string型(掩码);

gw:string型(网关)。

3)例子:

wKgZO2frg9aAVlHmAACLbzcbmN8864.png


3.5 开启或关闭NAPT

netdrv.napt(id)

1)参数:

id:int型(网关适配器的id)。

2)返回值:

返回值类型:bool;

说明:合法值就返回true,否则返回nil。

3)例子:

wKgZO2frhBaAfWKPAACFmjxDWbA429.png


3.6  获取netdrv的物理连接状态

netdrv.link(id)

1)参数:

id:int型(netdrv的id,例如socket.LWIP_ETH)。

2)返回值:

返回值类型:bool;

说明:已连接返回true,否则返回false;如果id对应的netdrv不存在,返回nil。

3)例子:

wKgZO2frhGqAMpP3AAB_rTLZ6uA564.png


3.7 获取netdrv的网络状态

netdrv.ready(id)

1)参数:

id:int型(netdrv的id,例如socket.LWIP_ETH);

2)返回值:

返回值类型:bool;

说明:已连接返回true,否则返回false;如果id对应的netdrv不存在,返回nil。

3)例子:

wKgZPGfrhJmAT_LYAACACIVo-PQ305.png

今天的内容就分享到这里了~


*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。

参与讨论
登录后参与讨论
推荐文章
最近访客