0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

浅析RT-Thread针对不同架构芯片移植的方法

RTThread物联网操作系统 来源:嵌入式IoT 作者:嵌入式IoT 2021-03-18 17:41 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

在做rt-thread系统移植的这段时间里,积累一些快速移植的经验,不论是现有架构的不同型号的芯片,还是一个全新架构的移植,只需要按照一定的步骤进行,一般大的方向不会出错。剩下的事情就是解决为什么没有达到预期效果的问题。

移植的里程碑有如下的几个:1.芯片工作在正常的模式,可以正常的执行c代码逻辑 2.至少有一个串口驱动 3.上下文切换逻辑 4.定时器可以正常的使用 5.串口输入有正常的中断产生并能够读到数据 针对以上的顺序详细描述问题以及解决办法。

芯片的工作模式

不同架构的芯片一定会有对应的模式适合操作系统的运行,这是芯片设计时就考虑到的问题,所以移植也要遵循这种规则。另外也涉及到寄存器的访问权限问题。 比如armv7,其操作系统存在的模式为system模式,可以方便的切换到其他模式。还有比较典型的armv8架构的el1特权级别。当然把芯片模式切换到其他的模式,也可以,比如rt-thread整个系统运行在el3特权模式,在el3特权级别最高,但是并不是越高越好,往往el3会有更加合适的用法。其切换到逻辑一般在芯片启动后,执行的最初一段的汇编代码逻辑里面,一般芯片在上电后,都会进入最高特权权限的模式里,切换到操作系统特定的特权级别模式即可。

可以正常执行c代码

完成这一步也是汇编的代码的实现,这一步的通用关键操作是bss段清零,以及设置栈指针地址。 对于bss段清零的必要性是因为c语言的语法规则,以前的存储程序的存储器是很贵的,所以程序在生成的时候,把未初始化的全局变量和静态变量,这些存储空间不存入存储器空间,然后在程序加载的时候,将这段空间指向的区域清零。而函数中的非静态的变量则存储在栈中,地址不确定。

如果不进行bss的清零,可能导致的问题是全局变量和静态变量的值不确定,导致程序编程时遇到异常的现象。 清空bss段的步骤也很简单,就是将bss这一段内存空间设置为0即可。 而设置栈地址也就是sp的地址,仅仅是为了在操作系统线程还未启动调度时,最开始的栈空间。根据c语言的函数调用规则,c语言进行函数调用时,都需要压栈和出栈,这段栈空间是用户自行分配的。 所以需要注意点是rt-thread启动调度前也是有一个栈空间的,调度启动后该栈空间不被使用,每个线程栈空间才生效。

至少有一个串口驱动

要完成这个工作,需要注意的问题是事先已经完成了串口驱动的验证工作。也就是可以正常的接收和发送数据。完成rt-thread串口驱动对接,只需实现串口初始化,串口接收,串口发送,中断注册即可。 由于前期没有中断,实现串口发送功能就可以接着进行下面工作了。 正常情况下,可以看到串口可以输出rt-thread的logo了。

上下文切换逻辑

对于程序的上下文,可以理解为程序当前运行的现场。其现场里面主要包含的内容有,当前所有的寄存器状态,当前sp的值,有些处理器还有pc值等等。

对于第一个调度起来的线程,其上下文的内容是人工手动赋值的。因为并不能保证调度器执行的第一个线程是哪个具体的线程,所以每个线程都会存储一个人工填充的上下文。 需要注意的地方主要有三点,第一个线程调度启动后,会打开全局中断,具体是在上下文恢复时,由汇编代码实现。第二个是线程退出后,会启动下一次调度,线程回收工作由空闲线程完成。第三点一定要确保压栈的顺序和出栈的顺序一致性。

该功能实现正常的标志是可以正常进入main函数以及msh控制台。但不能输入控制,因为没有实现串口输入中断,如果已经实现串口中断,那可以msh输入。

定时器可以正常使用

定时器可以正常使用的前提中断可以正常的产生,然后周期性的产生定时器中断。 定时器是系统tick的关键,没有定时器,系统将无法在任务中通过delay释放CPU资源,但是可以通过主动切换任务的方式进行调度。 关于rt-thread的tick的时间片多少合适的问题,这里解释为,一般合适的10ms,对于主频很高的芯片可以是1ms。曾经在30mhz的主频的FPGA上验证系统,发现并不能正常运行起来。分析因为系统定时器中断产生的太频繁,主频太低,程序来不及处理完成又发生了中断。

串口可正常输入

该步骤可作为移植的成功的验证工作,这一步的工作并非技术难点,但是往往前面步骤没有成功,可能会导致这里出现不了想要的现象。 比如曾经协助一个客户完成移植工作时,发现串口中断打开后,只能输入一个字符串后无反应,后来才查到中断处理标志没有清空。 一般可以正常的输入输出,该系统移植就基本成功了。

移植的工作难点

对于上面的步骤中,最难的就是栈帧的规划,上下文切换和中断处理。 结合实际移植经验,往往容易出问题的地方就是入栈和出栈的顺序对不上,或者有些寄存器没有存到栈中。在这个工作的时候,要检查一下寄存器是32位还是64位,可能因为这个小细节,导致栈帧的偏移。 另外要注意的是,线程压栈的时候,一定要压线程退出后的回收函数,曾经也因为没有注意这个细节导致main函数退出后,系统运行异常。

中断里面复杂设计在于中断的嵌套,往往在中断里执行调度,并不会立马执行到切换线程的上下文,这样就破坏了现场,而是待到所有中断执行完成后,再切换上下文。这一点在cortex-m上很好理解,中断控制器在处理pendsv异常时,总是等待其他高优先级中断处理完成后,再去处理优先级最低的pendsv。而对于sparc这种设计,切换任务是通过trap异常实现的,trap异常高于中断,也就是切换线程优先级高于中断,这是系统设计里面不合理的,在软件设计时,往往通过设置中断嵌套标志位,等到所有中断执行完成后,再切换上下文,一定不能够在中断执行时,把上下文切换走。

移植经验分享

rt-thread的移植是有一些关键点的,找到这些关键点,可以非常顺利的规划清楚方向和目标,对于每个关键点进行技术攻克,这样是最快也是最高效的做事方式。 要想移植不同芯片架构,需要非常清楚这个芯片的架构,也需要非常熟悉rt-thread系统最关键点底层代码。一般熟悉rt-thread的底层代码并不是很难,从头读一遍aarch64的rt-thread最小系统实现两三天就能差不多理解,而芯片手册的阅读要结合实际的工作经验,弄清楚芯片特权模式、看懂寄存器,看懂汇编基本就可以了。当然有些处理器是需要实现mmu才能正常执行的,比如aarch64,必须实现mmu的功能,即使是1:1映射。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    462

    文章

    53534

    浏览量

    458981
  • PC
    PC
    +关注

    关注

    9

    文章

    2164

    浏览量

    158492
  • RT-Thread
    +关注

    关注

    32

    文章

    1540

    浏览量

    44269
  • main
    +关注

    关注

    0

    文章

    38

    浏览量

    6556

原文标题:RT-Thread针对不同架构芯片移植的方法

文章出处:【微信号:RTThread,微信公众号:RTThread物联网操作系统】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    移植最新版的rt-thread nano时程序进入到entry就报错,为什么?

    我在移植最新版的rt-thread nano时发现程序只要一进去entry函数就直接跳到一个死循环里,我使用的编译器是armgcc10.2版本。然而我移植旧版的rt-thread na
    发表于 10-09 07:17

    CubeMX移植RT-Thread 3.1.5文件重复怎么解决?

    CubeMX6.7.0内移植RT-Thread Nano3.1.5文件重复,主要是两个部分 1、 和 两个地方重复rtconfig.h 2、shell相关的文件也会重复 和 请问下各位有没有办法可以解决这个问题的?
    发表于 09-24 07:11

    Windows上使用ENV工具开发基于先楫MCU的RT-Thread应用

    前言Env是RT-Thread推出的开发辅助工具,针对基于RT-Thread操作系统的项目工程,提供编译构建环境、图形化系统配置及软件包管理功能。其内置的menuconfig提供了简单易用的配置剪裁
    的头像 发表于 08-29 12:22 945次阅读
    Windows上使用ENV工具开发基于先楫MCU的<b class='flag-5'>RT-Thread</b>应用

    在Ubuntu上开发基于先楫MCU的RT-Thread应用指南

    1、前言RT-ThreadEnv是RT-Thread推出的开发辅助工具,针对基于RT-Thread操作系统的项目工程,提供编译构建环境、图形化系统配置及软件包管理功能。其内置的menu
    的头像 发表于 08-29 12:22 1223次阅读
    在Ubuntu上开发基于先楫MCU的<b class='flag-5'>RT-Thread</b>应用指南

    【好书推荐】RT-Thread第20本相关书籍!《嵌入式实时操作系统RT-Thread原理与应用》| 技术集结

    01内容简介ContentSummary本书为读者提供了一个全面、系统的RT-Thread学习指南,旨在帮助初学者及有经验的开发者掌握RT-Thread实时操作系统和STM32嵌入式微控制器的核心
    的头像 发表于 08-24 10:05 685次阅读
    【好书推荐】<b class='flag-5'>RT-Thread</b>第20本相关书籍!《嵌入式实时操作系统<b class='flag-5'>RT-Thread</b>原理与应用》| 技术集结

    恩智浦MCU教程 基于MCUXpresso和FRDM-MCXA346的RT-Thread Nano移植

    本篇还是以移植RT-Thread Nano到MCUXpresso IDE为主,移植的代码可以在nxpic.org.cn论坛搜索到。
    的头像 发表于 08-21 09:49 6228次阅读
    恩智浦MCU教程 基于MCUXpresso和FRDM-MCXA346的<b class='flag-5'>RT-Thread</b> Nano<b class='flag-5'>移植</b>

    如何移植 RT-Thread Nano 并创建 2 个线程?

    基于 BSP 中的 GPIO_OutputInput 演示,展示了如何移植 RT-Thread Nano 并创建 2 个线程。
    发表于 08-19 07:45

    RT-Thread 遇上 Rust:安全内核 RusT-Thread 的诞生

    大家好,我们是中国科学技术大学操作系统原理与设计(H)课oooooS小组。这个项目是我们的课程大作业:参考RT-Thread架构,使用Rust搭建一个原生的嵌入式操作系统内核。初识Rust是因为xk
    的头像 发表于 08-02 11:03 3206次阅读
    <b class='flag-5'>RT-Thread</b> 遇上 Rust:安全内核 RusT-<b class='flag-5'>Thread</b> 的诞生

    RT-Thread Nano硬核移植指南:手把手实现VGLite图形驱动适配 | 技术集结

    VGLite是NXP提供的轻量级2D图形API,本文将手把手带你实现VGLite图形驱动适配RT-Thread。文章分为上、下两篇,将手把手教您移植。上篇对RT-ThreadNano内核与Finsh组件进行
    的头像 发表于 07-17 14:40 3040次阅读
    <b class='flag-5'>RT-Thread</b> Nano硬核<b class='flag-5'>移植</b>指南:手把手实现VGLite图形驱动适配 | 技术集结

    RT-Thread荣获2025优秀开源项目 | 新闻速递

    6月底,RT-Thread睿赛德受邀参与由上海开源信息技术协会主办的2025上海开源创新精英荟。上海市商委副主任张杰出席会议并致辞。RT-Thread嵌入式操作系统项目凭借其卓越的技术创新与开源生态
    的头像 发表于 07-04 09:04 2420次阅读
    <b class='flag-5'>RT-Thread</b>荣获2025优秀开源项目 | 新闻速递

    揭秘RT-Thread上的AUTOSAR CP系统

    本文探讨了RT-Thread与AUTOSARCP的融合,解决车载ECU开发中实时性、安全性与灵活性的平衡问题。通过分层安全内核(rt-safetyos/autoos)和工具链整合,兼容AUTOSAR
    的头像 发表于 06-23 20:22 2939次阅读
    揭秘<b class='flag-5'>RT-Thread</b>上的AUTOSAR CP系统

    RT-Thread审核团招募: 深度参与开源RTOS社区治理与演进

    全球开发者招募:RT-Thread审核团(ReviewTeam)正式开放申请!在开源的世界里,代码审查(CodeReview)是保证软件质量、促进技术交流的关键环节。RT-Thread作为全球领先
    的头像 发表于 05-21 18:02 1063次阅读
    <b class='flag-5'>RT-Thread</b>审核团招募: 深度参与开源RTOS社区治理与演进

    如何将RT-Thread移植到NXP MCUXPressoIDE上

    RT-Thread默认支持的IDE只有IAR 和 Keil, 那如何将RT-Thread移植到NXP MCUXPressoIDE上呢?本文内容比较简单但稍有琐碎,希望对有需要的小伙伴有所帮助。
    的头像 发表于 02-13 10:37 2431次阅读
    如何将<b class='flag-5'>RT-Thread</b><b class='flag-5'>移植</b>到NXP MCUXPressoIDE上

    全志科技亮相2024 RT-Thread开发者大会

    近日,操作系统厂商睿赛德科技在上海举办“2024 RT-Thread开发者大会”。全志科技作为芯片设计厂商受邀参展并进行了主题分享。会上,全志科技系统软件中心资深架构师进行了名为《拥抱生态,和而共赢
    的头像 发表于 12-31 16:47 1560次阅读

    RT-Thread应用开发寒假师资培训——西安站

    随着物联网和智能系统的快速发展,嵌入式成为当前最热门最有发展前途的IT应用领域之一。为进一步提升全国大学生在嵌入式芯片及系统设计领域的创新能力,特别是针对物联网应用开发中RT-Thread操作系统
    的头像 发表于 12-11 01:06 1020次阅读
    <b class='flag-5'>RT-Thread</b>应用开发寒假师资培训——西安站