FreeRTOS内核v0.1-LOVT浅析.doc

  1. 1、本文档共39页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
FreeRTOS内核解析 FreeRTOS是一个小型的嵌入式实时系统内核,应用比较广泛,而且开源,商业免费。 在STM32F4系列上移植FreeRTOS Start System Peripheral Init OS Init TASK A OS Task Scheduler TASK B TASK C 图1 OS操作流程 在FreeRTOS内核中包含的文件: 1. croutine.c 协线程文件,和任务类似,在系统资源比较缺乏下使用。 list.c 列表结构描述,在内核整体控制上都使用了列表格式数据处理。一切 的数据结构基础。 queue.c 队列,任务和任务之间的通讯处理。 Timers.c 软定时,以任务形式存在。 Port.c 硬件与系统内核交互部分。SVC、PENDSC、中断等设置。汇编与C的结合 Heap.c 堆栈内存空间。内存空间申请,释放。在这里我们使用heap_4.c。 tasks.c 所有任务相关函数。 8. cmsisi_os.c 系统相关接口CMSISI_OS标准化,接口处理。 heap_4.c 实现原理:申请一块静态内存,按照堆的方式处理。包含内存申请,释放,自动合并相连的空闲内存。 应用API函数: void *pvPortMalloc(size_t xWantedSize); void vPortFree(void *pv); size_t xPortGetFreeHeapSize(void); 内部过程函数: static void prvHeapInit(void); static void prvInsertBlockIntoFreeList(xBlockLink *pxBlockToInsert) ; //申请内存空间块描述 可以看做一个节点 typedef struct A_BLOCK_LINK { struct A_BLOCK_LINK *pxNextFreeBlock; //指向下一块内存 size_t xBlockSize; //空闲块大小 }xBlockLink; //指向开始和结尾 xStart是静态内存 pxEnd 是个指针 xBlockLink xStart, *pxEnd = NULL 节点 数据空间 。。。 节点 数据空间 。。。 在系统蛇口中要考虑到字节对齐的问题。所以在申请一块内存时,要先进行内存字节格式对齐。也就是说1-7个字节格式化后也为8个字节。 #define portBYTE_ALIGNMENT 8 //8字节对齐 #define portBYTE_ALIGNMENT_MASK ( 0x0007 ) //对齐掩码 static const unsigned short heapSTRUCT_SIZE = ((sizeof(xBlockLink) + (portBYTE_ALIGNMENT - 1)) ~portBYTE_ALIGNMENT_MASK); //静态内存 作为整个内存空间 configTOTAL_HEAP_SIZE 宏定义设置 根据需求设置大小 static unsigned char ucHeap[configTOTAL_HEAP_SIZE]; #define heapADJUSTED_HEAP_SIZE (configTOTAL_HEAP_SIZE -

文档评论(0)

1112111 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档