STM32CUBE双串口空闲中断+DMA透传代码,拿到下载直接能用,U1:PA9PA10,U2:PA2PA3
2019-12-21 20:19:54 3.6MB STM32CUBE
1
STM32F103VET6 串口DMA+空闲中断接收,接收到的数据用DMA串口实时发送回去。该版本存在一个bug,推荐下载另一个修复后的版本,或者参照我的博文自己进行修复。 修复版本下载链接:https://download.csdn.net/download/mickey35/13034788 bug描述博文地址:https://blog.csdn.net/mickey35/article/details/78521311
2019-12-21 20:19:17 5.17MB STM32 串口 DMA 空闲中断
1
这是用于NVIDIA GEFORCE显卡的关闭空闲时降频节能的工具.可以锁定频率 使2d分频失效 当然也可以恢复2D分频
2019-12-21 20:12:13 1.23MB nvidia power
1
时隙式ALOHA的吞吐量,空闲率,碰撞率的验证
2019-12-21 20:12:07 527B aloha
1
最近做的一个 c# 软件,对初学C#很有帮助,大家可以用一下,有什么问题或建议,可以发到我邮箱,305867438@qq.com
1
STM32CubeMX 串口 DMA+空闲中断实现不定长接收 利用hal库进行修改实现不定长的uart接收,应用于不定长帧的传输
2019-12-21 20:02:49 7.02MB STM32 CubeMX
1
这个可以集合了查询空闲教室信息,和收集教室人数,温度湿度为一体的功能。不过需要有服务器支持,有这方面开发需要的可以参看以一下代码
2019-12-21 19:54:23 3.69MB android,教室,查询,代码
1
对已分配盘块采用索引方式管理, 闲闭盘块采用成组连接管理, 实现分配, 回收和盘块一致性检查
1
具体要求如下:  建立相应的数据结构;  磁盘上建立一个文件,文件长度设为10MB,用该文件来模拟一个磁盘,磁盘的物理块大小为512字节。  建立进程的数据结构;  时间的流逝可以用下面几种方法模拟:(a)按键盘,每按一次可认为过一个时间单位;(b) 响应WM_TIMER;  将一批进程对磁盘的请求的情况存磁盘文件,以后可以读出并重放;  使用两种方式产生进程对磁盘的请求:(a) 自动产生 (b) 手工输入  显示每次磁盘的请求和空间释放后的相关数据结构的状态;  显示每次磁盘的请求和空间释放后状态;  支持的管理方法:空闲表法、空闲链表法、位示图法、UNIX成组链接法。 用的比较low的控制台 核心的东西时在实现一个os时其内部怎样管理空闲磁盘块 由于存储器的原理,我们无法准确的知道哪以部分装的这么,从外部看只是0和1 但因为我们建立了数据结构在一小块区域代表了整个磁盘来管理磁盘的空闲空间, 使用空闲空间只需要通过地址映射寻到相应地址即可, 另一方面注意os的实际的操作,验收时很多同学没有通过只因为只是模拟了空闲空间,而忽略了对磁盘实际的操作 此项目为在java写好的情况下被通知不允许用java,一天之内仓促拼凑,可提供大致思路,如有纰漏敬请指正
2019-12-21 19:32:18 66KB os
1
配送一个自己写的串口驱动程序 用DMA接收数据 接收完会产生一个空闲中断 由此可判断接收完一个包的数据 再配送一个我自己写的动态内存管理 跟ESP8266的驱动 在项目中测试460800的波特率 30kb一秒的数据接收 一包1024个字节 每包需要应答15字节的情况下 AT指令处理是使用多个缓冲级来处理模块发送过来的数据 分别有模块应答缓冲级 跟等待应答的缓冲级、被忽略的AT指令集的缓冲级(例如注册一个SEND OK\r\n则模块应答此条指令立刻清除缓冲级释放内存无需等待超时直接忽略)还有需要回调的缓冲级(则出现此指令调用回调函数)都是通过注册的方式来实现 如果出现一包跟指令被分到一个包内 AT处理函数一样可以搜索到AT指令 使用strstr函数来实现 函数的缓冲级都是指针不占用内存 使用动态内存管理的方式 有数据则创建内存放入数据作为一个缓冲级 如果模块应答的数据在规定的时间内没有响应则删除此缓冲级 函数前都有注释介绍 下面介绍一些常用的函数: at_init初始化一些变量已经串口 at_time_task使用定时器回调 1毫秒回调一次 用来计数超时的指令缓冲&等待超时的计数 at_clear_all 在模块开机的时候可能会有很多乱数据 可以在初始化完毕后使用此函数清除所有缓冲级 释放所有内存 at_processing处理AT的应答超时的指令(做删除释放内存的动作),还有处理等待的AT指令 此函数一定要不断循环处理 可以加入到定时器 目前我实验是在UCOS上的 所以直接创建个任务来执行此函数 当程序在等待某个AT指令的时候此函数会寻找接收的缓冲级是否有等待的AT指令 at_cmd_cb_hand回调处理函数 如果接收缓冲级出现某个已经注册的指令则回调注册时所填写的函数地址 at_send_cmd 发送一个AT指令 可以用跟printf一样使用 %d等等 at_send_data 发送数据的时候所使用 需要填写长度 at_cmd_ignore_register 注册一个被忽略的AT指令 带入参数 *s (例如填写一个"SEND OK" 则模块应答的此条指令直接被忽略 释放内存 被忽略之前会检查此缓冲级会不会带有别的AT指令需要回调的) at_cmd_ignore_cancel 取消被忽略的指令 则取消已经注册的被忽略的AT指令 at_cmd_cb_register AT指令的回调注册 例如参数填写"+IPD",函数名a 则出现+IPD的时候回调a函数 a函数有类型 在at.h文件里面有 at_cmd_cb_cancel注销回调你懂得 at_wait_cmd 等待一个AT指令集或者超时则立刻返回 等待途中会不断调用OS的延迟程序 让系统能有时间去执行其他任务 使用方法例如{ at_send_cmd("AT+UART=%u,%u,%u,%u,%u\r\n",baudrate,databit,stopbit,parity,flow_control); return (esp_error)at_wait_cmd("\r\nOK\r\n",2000,NULL); } at_error at_wait2_cmd(char *s,char *s2,u16 timeout,u8 *index) 此函数是等待两个AT指令集 如果出现一个则立刻返回 返回值h文件有介绍 AT_DONE则出现此条指令 index参数则提取应答的缓冲首地址 使用at_buf_get函数获取首地址 使用完后要调用at_free_buf来清除并释放这个缓冲级 at_buf_len_get查询此应答的缓冲级长度 如果在index填写NULL则不需要缓冲级首地址 直接清除释放缓冲级
1