mqtt 串口_合宙Luat 2G/4G系列模块Lua版本串口功能汇总

5ff479bc441f42de6a69b5b287f9a14c.png

1

硬件概述


本文将描述Air系列模块(2G和4G模块)Lua版本上通用串口、调试串口、调试串口、USB口的特性和使用方法,先看一张对比图:

7c2d1b367c8c569915333566d3d85424.png

若无特别说明,下文中描述的串口包括通用串口、调试串口、USB口三种,描述的串口通信的对端设备称作MCU。

2

应用层数据收发原理


注意:默认状态下,在合适的时间点(此时间点不可预知),系统会自动进入休眠状态;串口数据收发之前,必须通过pm.wake(...)接口使系统持续处于唤醒状态,才能保证收发功能正常;收发结束后,可以通过pm.sleep(...)接口允许系统自动休眠。

2.1   数据接收

在core中的应用层,有一个1460字节的缓冲区,串口驱动接收到的数据插入此缓冲区;脚本有轮询和中断两种方式,通过uart.read(...)接口读取缓冲区中的数据;

需要注意如下两点:

1)脚本读取的速度要大于数据插入的速度,否则会造成缓冲区溢出,数据出错;

2)MCU一次性发送给模块的数据,调用uart.read接口,并不一定能够一次性读取完整,必须使用“循环读取数据”+“数据拼接判断完整性”的方案来处理;例如MCU一次性发送1460字节的数据,模块使用轮询或者中断第一次读取数据时,缓冲器里面可能才接收到10字节的数据。

2.1.1  uart.read接口详解

uart.read(id, format)

--- 读取串口数据(此接口不会阻塞,立即返回)

-- @number id 串口ID

-- @string or number format 读取串口数据的格式,有如下几种

-- number类型的数字:表示读取指定长度字节的数据

--     如果缓冲区中没有数据,则返回空字符串,返回值为string类型

--     如果缓冲区中的数据长度小于等于要读取的数据长度,则返回缓冲区中的所有数据,返回值为string类型

--     如果缓冲区中的数据长度大于要读取的数据长度,则返回要读取的长度的数据,返回值为string类型

-- string类型的*l:  表示读取到换行符\n

--     如果缓冲区中没有数据,则返回空字符串,返回值为string类型

--     如果缓冲区中的数据没有\n,则返回缓冲区中的所有数据,返回值为string类型

--     如果缓冲区中的数据有\n,则返回到\n结束的所有数据(包括\n),返回值为string类型

-- string类型的*n:  表示读取整型数据

--     如果缓冲区中没有数据,则返回0,返回值为number类型

--     如果缓冲区中的第一个字节的数据不是+、-、数字,则返回0,返回值为number类型

--     如果缓冲区中的前几个字节满足整型数据格式[+-]%d+,则按照最长匹配返回数据,返回值为number类型

-- string类型的*s:  表示读取到空格字符

--     如果缓冲区中没有数据,则返回空字符串,返回值为string类型

--     如果缓冲区中的数据没有空格,则返回缓冲区中的所有数据,返回值为string类型

--     如果缓冲区中的数据有空格,则返回到空格结束的所有数据(不包括空格),返回值为string类型


2.1.2   轮询方式读取数据

轮询方式比较简单,脚本定时调用uart.read接口读取数据、拼接数据、检查数据完整性、处理数据即可。

详细代码参考uart的demo。

2.1.3   中断方式读取数据

中断方式处理逻辑如下:

1)脚本调用uart.on(id, "receive", intFnc)注册中断处理函数intFnc;

2)脚本接收到core中产生的数据中断消息后,执行intFnc;

3)脚本在intFnc中循环调用uart.read接口读取数据、拼接数据、检查数据完整性、处理数据,直至没有数据可读;

什么情况下,core中才会产生数据中断消息呢?

当缓冲区为空时,收到数据才会插入缓冲区,然后产生数据中断消息;如果缓冲区不为空,收到数据时仅仅插入缓冲区,并不会产生数据中断消息。所以第3步要把缓冲区中的数据读完,这样才能保证以后收到的数据,可以产生中断消息,脚本可以及时处理。

详细代码参考uart的demo。

2.2  数据发送

脚本使用uart.write接口发送数据,一次性最多支持发送1460字节的数据;

可以通过异步消息来通知脚本数据已经发送成功,参考uart的demo。

3

相关常见问题


3.1  api文档在哪里

http://wiki.openluat.com/doc/luatApi/#uart

代码详见uart的demo。

3.2  休眠、唤醒和功耗控制

默认状态下,在合适的时间点(此时间点不可预知),系统会自动进入休眠状态;串口数据收发之前,必须通过pm.wake(...)接口使系统持续处于唤醒状态,才能保证收发功能正常;收发结束后,可以通过pm.sleep(...)接口允许系统自动休眠。

如果项目不要求低功耗,为了编程方便,可以调用pm.wake使系统一直处于唤醒状态。

如果项目要求低功耗,除了动态控制休眠唤醒外,还要使用uart.close关闭串口,这样才能完全消除串口功能的功耗。

3.3  2G模块的调试串口可以用来做普通数据传输使用吗

可以用来做普通数据传输,但是不建议使用,原因有如下两点:

1)调试串口数据传输不稳定,很容易丢失数据;必须在应用层之上增加重试和容错机制。

2)调试串口主要用于烧写固件和输出日志,有一套专用协议,如果要用做普通数据传输,必须按照这套协议开发对端程序。

有需要的话,参考hostUart的demo。

3.4  4G模块的USB口可以和PC之间进行数据传输吗

USB在PC端映射出的ASR Modem Device AT口可以和PC进行数据传输。

代码详见usbdata的demo。

3.5  RS485通信的收发方向控制

可使用uart.set_rs485_oe接口配置此功能。请参考:

http://wiki.openluat.com/doc/luatApi/#uartset_rs485_oe

3.6   串口无法数据通信

检查一下串口电平是否匹配,软件上是否进入了休眠。

以上就是合宙Luat 2G/4G模块Lua版本的通用串口、调试串口、USB口的特性和使用方法,如有疑问或建议,请留言给我们吧~

c7b39d5bcd29b8f8f912906f251f0983.gif

6f9a53024c55c2b1b294a3264fcb0191.gif

更多福利,敬请期待

4a3d0477a1bdfa5505fe23286c71d46f.gif

Luat相关教程文章: Luat系列官方教程1:下载调试工具LuaTools的使用指南 Luat系列官方教程2:控制LED小灯

Luat系列官方教程3:Luat程序的基本时序

Luat系列官方教程4:学会使用并看懂Luatools的trace信息

Luat系列官方教程5: Socket代码详解 Luat系列官方教程6: MQTT代码详解

Luat系列官方教程7:串口收发

Luat小企业系列原创文章:

小企业怎么寻找生意的蓝海?

小企业2B新产品怎样定价?

小企业的2B业务怎么获客(一)?

合宙Luat将陆续推出小企业系列原创作品,敬请关注!

43cf4acc3a5f31791252723cf8344a0e.png

811676575298a28ee98663d5bda0a97e.png

 ▼ Luat热文推荐 ▼

>小企业怎么寻找生意的蓝海?

>NB-IoT,未来的物联网脊梁,还是扶不起的阿斗?

>2019年最值得工作和落户的几个城市,有你的家乡吗?

>为什么说『 物联网通信模块业务』没有前途?

>4G模块价格进入2位数时代,合宙Air720模块正式量产发货

>NB向左,GPRS向右,谁会率先突破百亿连接数?

>GPRS模块为什么会低至十几元?我所经历的物联网模块国产化过程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值