LIFOs
LIFO是一个内核对象,它实现了传统的最后先入,先出(LIFO)队列,允许线程和isr添加和删除任何大小的数据项。
概念
可以定义任意数量的lifo(仅受可用RAM的限制)。每个LIFO都由其内存地址引用。
LIFO具有以下关键属性:
已添加但尚未删除的数据项的队列。该队列被实现为一个简单的链表。
LIFO必须经过初始化后才能使用。这将将其队列设置为空。
LIFO数据项必须在单词边界上对齐,因为内核保留项目的第一个单词,用作指向队列中下一个数据项的指针。因此,一个包含N个字节的应用程序数据的数据项需要N个+4(或N个+8)字节的内存。如果使用k_lifo_alloc_put()添加了数据项,则没有对齐或保留空间要求,而是临时从调用线程的资源池中分配额外的内存。
数据项可以通过线程或ISR添加到LIFO中。如果存在等待线程,则将该项目直接提供给等待线程;否则,该项目将添加到LIFO的队列中。可以排队的项目的数量没有限制。
数据项可以通过线程从LIFO中删除。如果LIFO的队列为空,则线程可以选择等待要给出的数据项。任意数量的线程都可以同时等待一个空的LIFO。当添加一个数据项时,它将被授予等待时间最长的最高优先级线程。
注意:
内核确实允许ISR从LIFO中删除一个项,但是如果LIFO为空,ISR就不能尝试等待。
实现
定义LIFO
LIFO是使用
本文介绍了Zephyr内核中的LIFO(Last In, First Out)服务,这是一种用于数据传递的内核对象。LIFO允许线程和中断服务请求(ISR)添加和删除数据项。文章详细阐述了LIFO的概念、实现方法,包括如何定义、读取和使用LIFO,以及其在数据对齐和内存管理上的要求。建议使用LIFO进行异步传输任意大小的数据项。"
108178091,10012309,迁移到无服务器:用EventBridge处理遗留应用,"['服务器迁移', '无服务器架构', '事件驱动', '微服务', 'API Gateway']
订阅专栏 解锁全文
248

被折叠的 条评论
为什么被折叠?



