LuatOS-SOC接口文档(air780E)-- ioqueue - io序列操作

2023-10-20 08:44

本文主要是介绍LuatOS-SOC接口文档(air780E)-- ioqueue - io序列操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ioqueue.init(hwtimer_id,cmd_cnt,repeat_cnt)

初始化一个io操作队列

参数

传入值类型

解释

int

硬件定时器id,默认用0,根据实际MCU确定,air105为0~5,与pwm共用,同一个通道号不能同时为pwm和ioqueue

int

一个完整周期需要的命令,可以比实际的多

int

重复次数,默认是1,如果写0则表示无限次数循环

return

返回值

例子

ioqueue.init(0,10,5) --以timer0为时钟源初始化一个io操作队列,有10个有效命令,循环5次

ioqueue.setdelay(hwtimer_id,time_us,time_tick,continue)

对io操作队列增加延时命令

参数

传入值类型

解释

int

硬件定时器id

int

延时时间,0~65535us

int

延时微调时间,0~255tick,总的延时时间是time_us * 1us_tick + time_tick

boolean

是否连续是连续延时,默认否,如果是,定时器在时间到后不会停止而是重新计时,

返回值

例子


ioqueue.delay(hwtimer_id)

对io操作队列增加一次重复延时,在前面必须有setdelay且是连续延时

参数

传入值类型

解释

int

硬件定时器id

return

返回值

例子

ioqueue.setdelay(0,9,15,true) --延时9us+15个tick,在之后遇到delay命令时,会延时9us+15个tick
ioqueue.delay(0)

ioqueue.setgpio(hwtimer_id,pin,is_input,pull_mode,init_level)

对io操作队列增加设置gpio命令

参数

传入值类型

解释

int

硬件定时器id

int

pin

boolean

是否是输入

int

上下拉模式,只能是0,gpio.PULLUP,gpio.PULLDOWN

int

初始输出电平

return

返回值

例子

ioqueue.setgpio(0,pin.PB01,true,gpio.PULLUP,0) --PB01设置成上拉输入
ioqueue.setgpio(0,pin.PB01,false,0,1)--PB01设置成默认上下拉输出高电平

ioqueue.input(hwtimer_id,pin)

对io操作队列增加读取gpio命令

参数

传入值类型

解释

int

硬件定时器id

int

pin

return

返回值

例子

ioqueue.input(0,pin.PB01)

ioqueue.output(hwtimer_id,pin,level)

对io操作队列增加输出GPIO命令

参数

传入值类型

解释

int

硬件定时器id

int

pin

int

输出电平

return

返回值

例子

ioqueue.output(0,pin.PB01,0)

ioqueue.setcap(hwtimer_id,pin,pull_mode,irq_mode,max_tick)

对io操作队列增加设置捕获某个IO命令

参数

传入值类型

解释

int

硬件定时器id

int

pin

int

上下拉模式,只能是0,gpio.PULLUP,gpio.PULLDOWN

int

中断模式,只能是gpio.BOTH,gpio.RISING,gpio.FALLING

int

定时器最大计时时间 考虑到lua是int类型,最小0x10000, 最大值为0x7fffffff,默认为最大值

return

返回值

例子

ioqueue.setcap(0,pin.PB01,gpio.PULLUP,gpio.FALLING,48000000)

ioqueue.capture(hwtimer_id)

对io操作队列增加捕获一次IO状态命令

参数

传入值类型

解释

int

硬件定时器id

return

返回值

例子

ioqueue.capture(0)

ioqueue.capend(hwtimer_id,pin)

对io操作队列增加结束捕获某个IO命令

参数

传入值类型

解释

int

硬件定时器id

int

pin

return

返回值

例子

ioqueue.capend(0,pin.PB01)

ioqueue.get(hwtimer_id, input_buff, capture_buff)

  • 获取io操作队列中输入和捕获的数据

参数

传入值类型

解释

int

硬件定时器id

zbuff

存放IO输入数据的buff,按照1byte pin + 1byte level 形式存放数据

zbuff

存放IO捕获数据的buff,按照1byte pin + 1byte level + 4byte tick形式存放数据

返回值

返回值类型

解释

int

返回多少组IO输入数据

int

返回多少组IO捕获数据

例子

local input_cnt, capture_cnt = ioqueue.get(0, input_buff, capture_buff)

ioqueue.start(hwtimer_id)

启动io操作队列

参数

传入值类型

解释

int

硬件定时器id

return

返回值

例子

ioqueue.start(0)

ioqueue.stop(hwtimer_id)

停止io操作队列,可以通过start从头开始

参数

传入值类型

解释

int

硬件定时器id

返回值

返回值类型

解释

int

返回已经循环的次数,如果是0,表示一次循环都没有完成

int

返回单次循环中已经执行的cmd次数,如果是0,可能是一次循环刚刚结束

例子

ioqueue.stop(0)

ioqueue.release(hwtimer_id)

释放io操作队列的资源,下次使用必须重新init

参数

传入值类型

解释

int

硬件定时器id

return

返回值

例子

ioqueue.clear(0)

ioqueue.clear(hwtimer_id)

清空io操作队列

参数

传入值类型

解释

int

硬件定时器id

return

返回值

例子

ioqueue.clear(0)

ioqueue.done(hwtimer_id)

检测io操作队列是否已经执行完成

参数

传入值类型

解释

int

硬件定时器id

返回值

返回值类型

解释

boolean

队列是否执行完成,

例子

local result = ioqueue.done(0)

ioqueue.exti(pin,pull_mode,irq_mode,onoff)

启动/停止一个带系统tick返回的外部中断

参数

传入值类型

解释

int

pin

int

上下拉模式,只能是0,gpio.PULLUP,gpio.PULLDOWN

int

中断模式,只能是gpio.BOTH,gpio.RISING,gpio.FALLING

boolean

开关,默认是false关

return

返回值

例子

ioqueue.exti(pin.PB01, gpio.PULLUP, gpio.BOTH, true)
ioqueue.exti(pin.PB01)

这篇关于LuatOS-SOC接口文档(air780E)-- ioqueue - io序列操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/246007

相关文章

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

uva 10131 最长子序列

题意: 给大象的体重和智商,求体重按从大到小,智商从高到低的最长子序列,并输出路径。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vect

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

POJ1631最长单调递增子序列

最长单调递增子序列 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.math.BigInteger;import java.util.StringTokenizer;publ

Java 后端接口入参 - 联合前端VUE 使用AES完成入参出参加密解密

加密效果: 解密后的数据就是正常数据: 后端:使用的是spring-cloud框架,在gateway模块进行操作 <dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.0-jre</version></dependency> 编写一个AES加密

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

springboot体会BIO(阻塞式IO)

使用springboot体会阻塞式IO 大致的思路为: 创建一个socket服务端,监听socket通道,并打印出socket通道中的内容。 创建两个socket客户端,向socket服务端写入消息。 1.创建服务端 public class RedisServer {public static void main(String[] args) throws IOException {