环形队列数据的循环读写.pdfVIP

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
环形队列数据的循环读写

在内存中建立一个环形队列的数据结构,此数据结构遵循先进先出的原则,它是用于对交通 灯驱动程序的上半部和下半部之间缓冲数据,其中ring_buf_read()函数用于对环形队列进 行读取数据。(本算法来自蒋静《操作系统原理。技术与编程》一书P392 页) #define R_SIGNATURE 0x860510 typedef struct{ long signature; int *head; int *tail; int *end; int *begin; int buffer[64]; }ring_buf; //定义一个环形队列数据结构 #include unistd.h #include linux/kernel.h #include ring.h int tag=0; int * psudo_head=NULL; void ring_buf_init(ring_buf *round) { round-signature=R_SIGNATURE; round-head=round-buffer; round-tail=round-buffer; round-begin=round-buffer; round-end=round-buffer[sizeof(round-buffer)-1]; } /** read the user_defined value from the ring_buffer, ** if no value available 0 is returned, on error -1 is ** returned, on success 1 is returned **/ int ring_buf_read(ring_buf *round,int *val) { int* tmp=round-tail;//每次调用该函数时都会将round-tail 指针的值赋给tmp,因为 round-tail 始终指向环形队列中未读数据的地址,这是下面round-tail=tmp 语句来实现的 if(round-signature !=R_SIGNATURE){ printk(ring_buf_read:signature fake/n); return(-1); } if((tmpround-begin)||(tmpround-end)){ printk(ring_buf_read:tail bad/n); return(-1); } if(tmp==round-head){ return(0); } *val=*tmp++;//将*tmp 指向的值赋给val,实现数据的读出操作 if(tmpround-end) tmp=round-begin; round-tail=tmp;//保证round-tail 始终指向环形队列中未读数据的地址,从而实现循 环读取 if(tag){ round-head=psudo_head; tag=0; } return(1); } int ring_buf_write(ring_buf *round,int val) { int* tmp=round-head; if(round-signature !=R_SIGNATURE){ printk(ring_buf_write:signature fake/n); return(-1); } if((tmpround-begin)||(tmpround-end)){ printk(ring_buf_write:head bad/n); return(-1); } if(tag) return 0; (*tmp)=val; tmp++; if(t

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档