当前位置: 首页 > news >正文

网站建设 010今日广州新闻头条

网站建设 010,今日广州新闻头条,电子专业毕设做网站,手机怎么做淘客网站文章目录 23 环形缓冲块 ringblock23.1 初始化23.2 PUT & GET 块23.3 块释放23.4 rt_rbb_blk_queue_get23.5 rt_rbb_blk_alloc https://github.com/wdfk-prog/RT-Thread-Study 23 环形缓冲块 ringblock 环形块状缓冲区简称为:rbb。与传统的环形缓冲区不同的是&…

文章目录

  • 23 环形缓冲块 ringblock
    • 23.1 初始化
    • 23.2 PUT & GET 块
    • 23.3 块释放
    • 23.4 rt_rbb_blk_queue_get
    • 23.5 rt_rbb_blk_alloc

https://github.com/wdfk-prog/RT-Thread-Study

23 环形缓冲块 ringblock

环形块状缓冲区简称为:rbb。与传统的环形缓冲区不同的是,rbb 是一个由很多不定长度的块组成的环形缓冲区,而传统的环形缓冲区是由很多个单字节的 char 组成。rbb 支持 零字节拷贝 。所以 rbb 非常适合用于生产者顺序 put 数据块,消费者顺序 get 数据块的场景,例如:DMA 传输,通信帧的接收与发送等等

ringblk: 是由 多个不同长度 的 block 组成的,ringbuff : 是由单字节的数据组成的。ringblk 每一个 block 有多少个字节可以由用户自己设定。

ringblk 支持零字节拷贝(不需要额外的 memcpy 操作)。所以 rbb 非常适合用于生产者顺序 put 数据块,消费者顺序 get 数据块的场景,例如:DMA 传输,通信帧的接收与发送等等。

23.1 初始化

  1. 初始化块链表和释放链表
  2. 对每一个块链表进行初始化,并插入到释放链表中

23.2 PUT & GET 块

  • put

block->status = RT_RBB_BLK_PUT;
  • get
  1. 判断块链表为空,则返回NULL
  2. 遍历链表,找到具有 RT_RBB_BLK_PUT状态的块,设置状态为 RT_RBB_BLK_GET,返回块指针

23.3 块释放

  1. 从块链表总移除块,并插入到释放链表中

23.4 rt_rbb_blk_queue_get


//遍历块链表for (; node; node = tmp, tmp = rt_slist_next(node)){ 如果下一个 block 为空if (!last_block){// // 获取 list 节点上的结构体的地址last_block = rt_slist_entry(node, struct rt_rbb_blk, list);if (last_block->status == RT_RBB_BLK_PUT){// 保存第一个 blockblk_queue->blocks = last_block;blk_queue->blk_num = 0;}else{// 没有找到可用的 blocklast_block = RT_NULL;continue;}}else{block = rt_slist_entry(node, struct rt_rbb_blk, list);/*1.当前块没有放置状态2.最后一个块和当前块是不连续的3.data_total_size将超出范围*/if (block->status != RT_RBB_BLK_PUT ||last_block->buf > block->buf ||data_total_size + block->size > queue_data_len){break;}/* backup last block */last_block = block;}/* remove current block */data_total_size += last_block->size;last_block->status = RT_RBB_BLK_GET;blk_queue->blk_num++;}

23.5 rt_rbb_blk_alloc


rt_rbb_blk_trt_rbb_blk_alloc(rt_rbb_trbb, rt_size_tblk_size){new_rbb = find_empty_blk_in_set(rbb); // 找到一个空闲块// 判断申请出来的块是不是在 最大范围之内if (rt_slist_len(&rbb->blk_list) < rbb->blk_max_num && new_rbb){if (rt_slist_len(&rbb->blk_list) > 0) // 检查是不是第一次申请blk{   // 获取头节点的结构体起始地址head = rt_slist_first_entry(&rbb->blk_list, struct rt_rbb_blk, list);// 获取尾节点的结构体起始地址tail = rt_slist_tail_entry(&rbb->blk_list, struct rt_rbb_blk, list);if (head->buf <= tail->buf) // 头节点数据缓冲区的地址小于尾节点的数据缓存区的地址{/***                      head                     tail* +--------------------------------------+-----------------+------------------+* |      empty2     | block1 |   block2  |      block3     |       empty1     |* +--------------------------------------+-----------------+------------------+*                            rbb->buf*/// 求出空 block 的大小empty1 = (rbb->buf + rbb->buf_size) - (tail->buf + tail->size);empty2 = head->buf - rbb->buf;// 判断新的 block 可以存放的区域if (empty1 >= blk_size){ // 给 block 结构体赋值rt_slist_append(&rbb->blk_list, &new_rbb->list);new_rbb->status = RT_RBB_BLK_INITED;new_rbb->buf = tail->buf + tail->size;new_rbb->size = blk_size;}elseif (empty2 >= blk_size){// 给 block 结构体赋值rt_slist_append(&rbb->blk_list, &new_rbb->list);new_rbb->status = RT_RBB_BLK_INITED;new_rbb->buf = rbb->buf;new_rbb->size = blk_size;}else{/* no space */new_rbb = NULL;}}else{/***        tail                                              head* +----------------+-------------------------------------+--------+-----------+* |     block3     |                empty1               | block1 |  block2   |* +----------------+-------------------------------------+--------+-----------+*                            rbb->buf*/// 获取空闲的空间empty1 = head->buf - (tail->buf + tail->size);// 判断剩余空间是否够本次的分配if (empty1 >= blk_size){// 给 block 结构体赋值rt_slist_append(&rbb->blk_list, &new_rbb->list);new_rbb->status = RT_RBB_BLK_INITED;new_rbb->buf = tail->buf + tail->size;new_rbb->size = blk_size;}else{   /* no space */new_rbb = NULL;}}}else{/* the list is empty */rt_slist_append(&rbb->blk_list, &new_rbb->list); // 把bew_rbb 链表插入到 rbbnew_rbb->status = RT_RBB_BLK_INITED; // 修改状态为 已经初始化new_rbb->buf = rbb->buf; // 设置缓冲区new_rbb->size = blk_size;// 设置块大小}}else{new_rbb = NULL;}return new_rbb;}
http://www.hyszgw.com/news/20012.html

相关文章:

  • 保定网站建设推广公司怎么样网站怎么优化
  • 怎样做同城配送网站百度官方网平台
  • 网页游戏网址有哪些百家港 seo服务
  • 设计制作小车二教学视频搜索引擎优化指的是
  • 济宁网站建设有限公司站长之家排名查询
  • 请人做游戏的网站推广哪个网站好
  • 上海互联网公司有哪些优化网站排名如何
  • wordpress 重装教程长清区seo网络优化软件
  • 个人合法网站怎么做湘潭网站seo磐石网络
  • 网站建设 电子商务 品牌首选IDC百度识别图片找图
  • 怎么把自己的网站做自适应网站怎么在百度上推广
  • 搭建网站的网站苏州搜索引擎排名优化商家
  • 网站域名费一年交多少谷歌paypal官网登录入口
  • 带孩子做网站每日新闻
  • 郑州公司企业网站建设深圳网站开发公司
  • 电商网站是怎么建设的郑州网络营销学校
  • 一家专门做瓷砖特卖的网站百度sem认证
  • gta5可用手机网站大全西安网站建设公司排名
  • 上海市建设合同信息表网站企业管理培训课程
  • 网页设计师常用网站百度网站首页提交入口
  • 网站建设北京贵百度搜索引擎盘搜搜
  • 程序员做交友网站青岛 google seo
  • 浅析电商网站建设趋势百度ocpc怎么优化
  • 重庆公司网站设计制作百度知道一下
  • 域名怎么和网站绑定dw网站制作
  • 网站建设需要学代码吗百度客服号码
  • 完备的常州网站推广上海短视频培训机构
  • 做图片的网站成都seo优化排名推广
  • 网站退出率天津优化公司
  • 做网站需要哪些技能百度官网登录入口手机版