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

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

3天内不再提示

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

RTThread物联网操作系统 来源:未知 2022-12-09 22:20 次阅读

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

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

芯片的工作模式

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png

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

可以正常执行c代码

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png

完成这一步也是汇编的代码的实现,这一步的通用关键操作是bss段清零,以及设置栈指针地址。 对于bss段清零的必要性是因为c语言的语法规则,以前的存储程序的存储器是很贵的,所以程序在生成的时候,把未初始化的全局变量和静态变量,这些存储空间不存入存储器空间,然后在程序加载的时候,将这段空间指向的区域清零。而函数中的非静态的变量则存储在栈中,地址不确定。 如果不进行bss的清零,可能导致的问题是全局变量和静态变量的值不确定,导致程序编程时遇到异常的现象。 清空bss段的步骤也很简单,就是将bss这一段内存空间设置为0即可。而设置栈地址也就是sp的地址,仅仅是为了在操作系统线程还未启动调度时,最开始的栈空间。根据c语言的函数调用规则,c语言进行函数调用时,都需要压栈和出栈,这段栈空间是用户自行分配的。 所以需要注意点是rt-thread启动调度前也是有一个栈空间的,调度启动后该栈空间不被使用,每个线程栈空间才生效。

至少有一个串口驱动

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png

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

上下文切换逻辑

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png  对于程序的上下文,可以理解为程序当前运行的现场。其现场里面主要包含的内容有,当前所有的寄存器状态,当前sp的值,有些处理器还有pc值等等。 对于第一个调度起来的线程,其上下文的内容是人工手动赋值的。因为并不能保证调度器执行的第一个线程是哪个具体的线程,所以每个线程都会存储一个人工填充的上下文。 需要注意的地方主要有三点,第一个线程调度启动后,会打开全局中断,具体是在上下文恢复时,由汇编代码实现。第二个是线程退出后,会启动下一次调度,线程回收工作由空闲线程完成。第三点一定要确保压栈的顺序和出栈的顺序一致性。 该功能实现正常的标志是可以正常进入main函数以及msh控制台。但不能输入控制,因为没有实现串口输入中断,如果已经实现串口中断,那可以msh输入。

定时器可以正常使用

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png

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

串口可正常输入

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png

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

移植的工作难点

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png  对于上面的步骤中,最难的就是栈帧的规划,上下文切换和中断处理。结合实际移植经验,往往容易出问题的地方就是入栈和出栈的顺序对不上,或者有些寄存器没有存到栈中。在这个工作的时候,要检查一下寄存器是32位还是64位,可能因为这个小细节,导致栈帧的偏移。 另外要注意的是,线程压栈的时候,一定要压线程退出后的回收函数,曾经也因为没有注意这个细节导致main函数退出后,系统运行异常。 中断里面复杂设计在于中断的嵌套,往往在中断里执行调度,并不会立马执行到切换线程的上下文,这样就破坏了现场,而是待到所有中断执行完成后,再切换上下文。这一点在cortex-m上很好理解,中断控制器在处理pendsv异常时,总是等待其他高优先级中断处理完成后,再去处理优先级最低的pendsv。而对于sparc这种设计,切换任务是通过trap异常实现的,trap异常高于中断,也就是切换线程优先级高于中断,这是系统设计里面不合理的,在软件设计时,往往通过设置中断嵌套标志位,等到所有中断执行完成后,再切换上下文,一定不能够在中断执行时,把上下文切换走。

移植经验分享

aaf0faa0-77cb-11ed-8abf-dac502259ad0.pngab0a388a-77cb-11ed-8abf-dac502259ad0.png

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

RT-Thread开发者大会

我们将联合重量级合作伙伴,围绕AIoT的发展、产业技术趋势,聚焦控制、连接、行业应用开发,通过主题演讲、技术分享、应用演示等环节,助力开发者探索万物智能的世界,期待与大家一起相聚线上直播间!

现在扫码报名 我们将在报名者中抽取“幸运参会者100名” 赠送RT-Thread新款开发板(即将揭秘)

abf4b7a2-77cb-11ed-8abf-dac502259ad0.png

本次将在大会当天在直播间宣布中奖名单

更多奖品即将来袭...


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

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


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

    关注

    31

    文章

    1273

    浏览量

    39924

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

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

收藏 人收藏

    评论

    相关推荐

    RT-Thread上CAN实践

    开箱测试RT-Thread官方已完成了对英飞凌XMC7200EVK的移植,通过shell可以看到做好了uart3的console。本文将介绍如何进行RT-ThreadCan移植。接下来
    的头像 发表于 11-13 01:03 959次阅读
    <b class='flag-5'>RT-Thread</b>上CAN实践

    开源共生 商业共赢 | RT-Thread 2024开发者大会报名启动!

    亲爱的RT-Thread开发者我们很高兴地宣布,一年一度的RDC(RT-ThreadDeveloperConference,RT-Thread开发者大会)正式启动报名!2024RT-Threa
    的头像 发表于 10-29 08:06 234次阅读
    开源共生 商业共赢 | <b class='flag-5'>RT-Thread</b> 2024开发者大会报名启动!

    Nordic-RT-Thread5.1.0移植笔记

    Nordic-RT-Thread5.1.0移植笔记
    的头像 发表于 10-16 08:09 317次阅读
    Nordic-<b class='flag-5'>RT-Thread</b>5.1.0<b class='flag-5'>移植</b>笔记

    如何在RT-thread studio的裸机例程上移植freertos?

    如何在RT-thread studio的裸机例程上移植freertos
    发表于 09-13 06:32

    2024 RT-Thread全球巡回 线下培训火热来袭!

    亲爱的RT-Thread社区成员们:我们非常高兴地宣布,2024年RT-Thread全球开发者线下培训即将拉开帷幕!24年全球巡回培训将覆盖超10座城市及国家,为开发者提供一个深入学习RT-Thread嵌入式开发的绝佳机会。
    的头像 发表于 08-07 08:35 919次阅读
    2024 <b class='flag-5'>RT-Thread</b>全球巡回 线下培训火热来袭!

    【好书推荐】RT-Thread设备驱动开发指南

    近年来国内芯片产业和物联网产业的快速崛起,行业发展迫切需要更多人才,尤其需要掌握嵌入式操作系统等底层技术的人才。随着RT-Thread被更广泛地应用于行业中,开发者对嵌入式驱动开发的需求越来越
    的头像 发表于 08-01 08:35 516次阅读
    【好书推荐】<b class='flag-5'>RT-Thread</b>设备驱动开发指南

    RT-Thread 新里程碑达成——GitHub Star 破万!

    RT-Thread实时操作系统开源项目在GitHub上的star数量突破一万!截止发文,RT-Thread作为实时操作系统在业界Star数量排名第一!仓库地址:https://github.com
    的头像 发表于 07-04 08:35 399次阅读
    <b class='flag-5'>RT-Thread</b> 新里程碑达成——GitHub Star 破万!

    6月6日杭州站RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    6月6日下午我们将在杭州举办RT-Thread混合部署线下workshop,在瑞芯微RK3568平台上实现同时运行RT-Thread和linux,本次workshop邀请到RT-Thread资深
    的头像 发表于 05-28 08:35 410次阅读
    6月6日杭州站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    RT-Thread混合部署Workshop北京站来啦!

    4月25日,下午我们将在北京举办RT-Thread混合部署线下workshop,在瑞芯微RK3568平台上实现同时运行RT-Thread和linux,本次workshop邀请到RT-Thread资深
    的头像 发表于 04-19 08:34 417次阅读
    <b class='flag-5'>RT-Thread</b>混合部署Workshop北京站来啦!

    4月25日北京站RT-Thread线下workshop,探索RT-Thread混合部署新模式

    4月25日,下午我们将在北京举办RT-Thread混合部署线下workshop,在瑞芯微RK3568平台上实现同时运行RT-Thread和linux,本次workshop邀请到RT-Thread资深
    的头像 发表于 04-16 08:35 394次阅读
    4月25日北京站<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式

    4月10日深圳场RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    4月10日我们将在深圳福田举办RT-Thread混合部署线下workshop,在瑞芯微RK3568平台上实现同时运行RT-Thread和linux,本次workshop邀请到RT-Thread资深嵌入式软件工程师农晓明老师为您讲
    的头像 发表于 03-27 11:36 777次阅读
    4月10日深圳场<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    4月10日深圳场RT-Thread线下workshop,探索RT-Thread混合部署新模式!

    4月10日我们将在深圳福田举办RT-Thread混合部署线下workshop,在瑞芯微RK3568平台上实现同时运行RT-Thread和linux,本次workshop邀请到RT-Thread资深
    的头像 发表于 03-27 08:34 490次阅读
    4月10日深圳场<b class='flag-5'>RT-Thread</b>线下workshop,探索<b class='flag-5'>RT-Thread</b>混合部署新模式!

    恩智浦半导体正式加入RT-Thread全球合作伙伴计划!

    前不久,恩智浦半导体正式加入RT-Thread全球合作伙伴计划,成为RT-Thread高级会员合作伙伴。同时,RT-Thread现已成为恩智浦注册合作伙伴(RT-Thread| 简介合
    的头像 发表于 03-14 10:40 571次阅读
    恩智浦半导体正式加入<b class='flag-5'>RT-Thread</b>全球合作伙伴计划!

    RT-Thread设备驱动开发指南基础篇—以先楫bsp的hwtimer设备为例

    RT-Thread设备驱动开发指南》书籍是RT-thread官方出品撰写,系统讲解RT-thread IO设备驱动开发方法,从三方面进行讲解。
    的头像 发表于 02-20 16:01 1616次阅读
    <b class='flag-5'>RT-Thread</b>设备驱动开发指南基础篇—以先楫bsp的hwtimer设备为例

    BL808 RT-Thread Wi-Fi驱动适配

    BL808 WiFi 属于 SOC 单芯片型无线 MCU,片上集成 WiFi 功能,移植 RT-Thread 过程中,需要使用 RT-Thread wlan 框架。
    的头像 发表于 12-04 11:38 824次阅读