支持RT-Thread最新版本的瑞萨RA2E1开发板终于要大展身手了
熟悉RT-Thread和瑞萨MCU的朋友都知道,当前RT-Thread仓库的主线代码是不支持RA2E1这个BSP的。刚好,最近我在联合瑞萨推广一个叫《致敬未来的攻城狮计划》,使用的就是RA2E1开发板,正好乘着这个机会把RA2E1这个BSP合入到主线去,想必一定非常有趣。
文章目录
借助一个有趣的计划,完成一个有趣的任务,这本身就是一件很有趣的事情。
帮助一群未来的攻城狮快速地成长,把一颗芯片平台让更多人的发现并用起来,让RT-Thread的生态越来越丰富,这些事情,我们正在做,也会一直做下去,希望有更多的人加入并参与我们的实践中来。
本文的主要任务,还是聚焦在如何将RA2E1并入到RT-Thread的主线仓库。
一个崭新的计划,寻找那群有志于向嵌入式发展的未来工程师!
活动计划初衷
《致敬未来的攻城狮计划》来源于架构师李肯的一个念想,我一直在寻找那群渴望学习并专注于提升自我的技术朋友,他们可能还是憧憬在象牙塔里的大学生,也可能是初出茅庐的小助理,还有可能是一群转行无门的技术小白,但是他们都有一颗热诚扎入嵌入式领域的心,我称他们为【未来的攻城狮】,而我正是希望成为他们的星光指路人。
本次计划的初衷与瑞萨MCU不谋而合,瑞萨非常支持这群《未来的攻城狮》,愿意为他们的持续学习提供必要的硬件支持。
正是在这样的背景下,《致敬未来的攻城狮计划》孕育而生,一群闪亮的新星即将登场,嵌入式的技术即将因你们而更加精彩!
想要了解更多关于这个计划的内容,可以关注我的 个人社区 https://bbs.csdn.net/topics/613916237 (复制链接到浏览器即可打开)
《致敬未来的攻城狮计划》,从3月中旬就开始宣传推广,经过一周的报名筛选,我们挑选了10名优秀的、有潜力的未来攻城狮,第一时间聚拢大家,聊一聊这次计划的主要目的和开展形式,很快得到了大家的一致认可和支持,计划得以快速启动。
作为本次计划的主赞助商,瑞萨也在收到审核通过的名单后,迅速把板子发过来,这不刚过去一周,很多小伙伴已经把板子玩上几天了,好不惬意。
昨天开始,我在社区发布本期计划的激励措施,号召大家再社区打卡学习,现在好多小伙伴已经开始火热打卡学习了,欢迎大家来围观。(复制下面的链接到浏览器即可打开)
【致敬未来的攻城狮计划】任务提交及奖惩措施的相关说明 https://bbs.csdn.net/topics/614070195
【致敬未来的攻城狮计划】学习打卡频道 https://bbs.csdn.net/forums/recan-iot?typeId=2717193


最早我们在为《致敬未来的攻城狮计划》选型开发板的时候,也有过考虑的,尽快要选择一款能快速用上RT-Thread的板子。
当得知RT-Thread主线代码其实已经支持了RA2L1的,而我们选型的RA2E1与RA2L1基本是完全兼容的,只是存储有些不一样。
自然我的第一感觉也是,那就用它吧。应该问题不大,毕竟还有RA2L1在那里兜底。
然而,不幸的是,当我们参与计划的小伙伴拿到板子后,根据我给他们的信息提示,去RT-Thread的主线仓库拉取RA2L1的代码时,到KEIL中一编译,竟然发现有 20几个编译错误。Word天呐,简直有点不敢相信,然后一看仓库代码的提交记录,最后一次提交大概是 2个月前,感觉代码也不旧啊?怎么会这样,有些纳闷!

果然,白嫖是不可能的,这辈子都不可能白嫖的,关键时候还是要靠自己的双手来解决问题(此处没有开车)!
遇到问题,首先我想到的可能是 RT-Thread-首页-RT-Thread问答社区 - RT-Thread,虽然现在的活跃度比较差一些,但整体来说,还是能够找到一些有用的东西,帮助自己解决一些问题。
抱着试一下的心态去搜索,果然论坛里面很多介绍RA2L1这块芯片(板子)的,也有一个搭建开发环境踩坑的笔记之类的,看起来还是比较多。

经过一番筛选,我找到了这一篇文章 : RT-Thread-【开发板评测】Renesas RA2L 点亮LCD (SPI)RT-Thread问答社区 - RT-Thread,里面的几点对我接上面遇到的编译问题就很有帮助。

根据他的提示,很快我明白了原理,原理是RT-Thread主仓库的代码并不是根据这套板子来配置的,而是其他的一些配置,所以,需要解决编译的问题,要修改以下几个配置:
以上几个步骤需要借助env工具,然后配置完了,重新使用 scons --target=mdk5 生成KEIL的工程。
经过上面的配置后,再编译新的工程,终于是 0 error 了。

本以为,探索之旅到此结束,没想到把编译出来的可执行文件通过烧录器下载到(RA2E1)板子上,居然跑不起来,连我们常见的灯也不闪了,简直傻眼了。我开始想起最早的时候选项时:RA2E1与RA2L1是兼容的!
该不会除了啥问题吧?排除掉是板子的问题以及接线的问题之后,我开始锁定,非常有可能就是两个板子不完全兼容导致的。
手上有调试器,自然先跑一把调试下看看。记得上一小节找到的那个帖子,有说他遇到的问题是直接开始,最后排查是串口的问题导致,注释掉某一行代码就解决了,我们也尝试用这个小方法,还是不行,结果是一样的,灯不闪烁,串口无输出。
使用单步一调试,跳出这样的出错,本想去搜搜看,可是压根没有这样关键字的资料。

虽然没有啥解决方法,但是从这张错误中,我们可以看到,一定是 MEMORY 出问题了。
这时候我想起最早的选项,两者代码上是兼容的,但是就是内存不太一样。
至此,我基本断定了就是 Memory Layout 导致的问题,但是具体要怎么修改才行呢。还是没有思路。
自己想了一天,加上工作也比较忙,一直拖着没有解决。
想着这个问题我不能托太久,不然学习的小伙伴,也没法往下基于这个板子学习RT-Thread了。
于是我想到一个方法,那我就厚着脸皮去问一下瑞萨原厂的开发工程师吧。
之前参加 RA4M2网关设计大赛的时候,有加到RA的工程师,我就虚心地去请教了一下:

大家都工作忙,也不可能真的手把手教你去解决,关键时候还得靠自己。
从这次简短的沟通,基本已经完全确认方向了,就是内存的配置问题。
有了思路,就好办了,问题应该很快就有方法了。
在这里,我不得不提一句,瑞萨的资料是真的多,多到什么程度呢?就是多到你不知道该看哪个?或者说,究竟哪个文档或资料才能找到你想要的东西。

既然上面大致都已经定位到内存的问题,那我首先要做的就是找出 RA2E1 和 RA2L1 在内存上的差别究竟在哪里?
这些信息从哪里可以得出,那自然是官方的datasheet 最权威了。
最后,我也是大致翻看,发现这份**《RA2E1硬件用户手册(中英).pdf》有讲到Memory划分的详细内容,既然RA2E1有,自然RA2L1也有类似的文档,所以我就从官方找到了《RA2L1硬件用户手册(中英).pdf》**。
分别找到他们的内存划分那一章节:




有了这些内存分布之后,基本就知道怎么改了。
熟悉KEIL编译环境的都知道,在KEIL里面,关于芯片的内存分布是在一种叫 分散文件 的东西里面配置,它的文件名后缀是 .scat
顺着工程目录找到对应的分散文件,看到里面开头有这么一段:
#! armclang -mcpu=cortex-m4 --target=arm-arm-none-eabi -E -x c -I.
#include "memory_regions.scat"
虽然不太懂它的语法,但是一猜就知道,这种就是文件包含,也就是说芯片的内存划分是单纯放在 memory_regions.scat 文件里面。
这里,其实我还做了一个小动作,就是我从其他小伙伴手上拿到一份,可以工作的示例工程(这个工程是使用瑞萨的配置工具,从0到1自己配置出来的),所以它里面的内存划分肯定是正确的。
两个分散文件一拎出来,我一对比,就发现问题所在了:

还有一个方法也可以确认下这个内存分布,就是分析两个工程的axf文件。
比如我用如下的指令,导出axf的头部信息,对比如下:
recan@ubuntu:~/11111$ readelf -a project3.axf | head -n 100 > 111.txt
recan@ubuntu:~/11111$ readelf -a rtthread2.axf | head -n 100 > 333.txt

结合上一小节看到的RA2E1的内存分布,一下子就明白了,RAM的起始地址必须配置成上图中的右边部分。
为了快速验证,我直接把小伙伴的分散文件替换成我本地的RA2E1工程(实则是RT-Thread仓库的RA2L1工程)。
一编译,同样的0错误可用,然后我就快速地发起功能验证。
看到这个小标题自然就知道,问题迎刃而解,达到了我们预期的效果:灯也照常闪了,串口也正常输出了,RT-Thread的标志性的启动LOG输出也来了,一切都回到熟悉的样子。

我也在我们致敬未来攻城狮的小群里,第一时间发布了喜讯,号召大家尽快把RT-Thread学起来。

对我的本次修改感兴趣的可以关注我的代码仓库,不出意外的话,应该拉下来就能编译、烧录、调试、运行。有心者,请记一下这个仓库地址:https://gitee.com/recan-li/ra4m2-rt-thread
经过这几天的计划开展和对RA2E1的摸索,有几点东西想总结一下:
下一步计划,主要分为三个部分吧:
熟悉我的朋友都知道,近期我在疯狂地开展赠书活动,也有不少的朋友从我这里获得了许多高质量的精美图书,累计有送出近60本图书,这个事情我坚持做下去,努力把幸运和福利送到每一个知心者手中。
之前呢,每次基本送的都是一些技术研发类的书籍,所以近期也有收到一些朋友反馈说能不能送一些非技术的书籍。这不,有了目标,里面给安排上。
本期送出的书籍是一个关于Excel高效应用的数据,详细的图书介绍可以参考的社区文章:【第19期社区福利赠书活动】新书上市 | 《Excel高效应用:HR数字化管理实战》,30个二维码观看视频讲解(文末赠书5本)-CSDN社区

我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这
如果我使用ruby版本2.5.1和Rails版本2.3.18会怎样?我有基于rails2.3.18和ruby1.9.2p320构建的rails应用程序,我只想升级ruby的版本,而不是rails,这可能吗?我必须面对哪些挑战? 最佳答案 GitHub维护apublicfork它有针对旧Rails版本的分支,有各种变化,它们一直在运行。有一段时间,他们在较新的Ruby版本上运行较旧的Rails版本,而不是最初支持的版本,因此您可能会发现一些关于需要向后移植的有用提示。不过,他们现在已经有几年没有使用2.3了,所以充其量只能让更
我安装了ruby版本管理器,并将RVM安装的ruby实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby。有没有办法让emacs像shell一样尊重ruby的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el
有人知道在发布新版本的Ruby和Rails时收到电子邮件的方法吗?他们有邮件列表,RubyonRails有一个推特,但我不想听到那些随之而来的喧嚣,我只想知道什么时候发布新版本,尤其是那些有安全修复的版本。 最佳答案 从therailsblog获取提要.http://weblog.rubyonrails.org/feed/atom.xml 关于ruby-on-rails-如何在发布新的Ruby或Rails版本时收到通知?,我们在StackOverflow上找到一个类似的问题:
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
如果我一直输入geminstallrails使用不同版本的Rails会怎样?例如,我可以输入:geminstallrails--verson3.2.10或geminstallrails这给了我版本3.2.12。问题每次安装都会覆盖之前的吗?它会删除所有旧文件并添加我正在安装的新版本吗?或者如果我运行它两次,它会保留一些文件吗?我正在使用Ubuntu。 最佳答案 它将安装两个独立的gem。实际的可执行文件rails将调用最新版本。你可以覆盖它__例如,rails_3.2.10_将执行Rails3.2.10。bundler顺便说一下,如
我的Rails站点使用了一个确实不是很好的gem。每次我需要做一些新的事情时,我最终不得不花费与向实际Rails项目添加代码一样多的时间来为gem添加功能。但我不介意,我将我的Gemfile设置为指向我的gem的GitHub分支(我尝试提交PR,但维护者似乎已经下台)。问题是我真的没有找到一种合理的方法来测试我添加到gem的新东西。在railsc中测试它会特别好,但我能想到的唯一方法是a)更改~/.rvm/gems/.../foo。rb,这看起来不对或者b)升级版本,推送到Github,然后运行bundleup,这除了耗时之外显然是一场灾难,因为我不确定我所做的promise是否正
为了在我的mac上为一个rails项目安装mysql,我遵循了安装Homebrew软件和删除mac端口的在线建议。这是问题开始的地方。rails项目不会构建,我得到这个:[rake--prereqs]rakeaborted!dlopen(/Users/Parker/.rvm/gems/ruby-1.9.3-p448/gems/nokogiri-1.6.0/lib/nokogiri/nokogiri.bundle,9):Librarynotloaded:/opt/local/lib/libiconv.2.dylibReferencedfrom:/Users/Parker/.rvm/gem
我喜欢RVM。我意识到它的主要用例是让不同的用户在不同版本的Ruby之间切换。但是假设我正在将Rails应用程序部署到服务器,并且我只想运行单个版本的Ruby。特别是,我想要1.9.2,用RVM安装它很容易,但没有它就很痛苦。有没有一种方法可以让我说“我希望这是所有用户的规范Ruby安装”(连同它的所有gem),而不必手动创建一堆符号链接(symboliclink)并在每次更新到更新时更改它们Ruby版本? 最佳答案 以root身份安装RVM并执行sudorvmuse1.9.2--default。任何采购/usr/local/rvm