【独家】我就要用MDK来开发树莓Pico,怎么地吧!


【说在前面的话】


按照树莓派基金会的说法:

Raspberry Pi Pico is a tiny, fast, and versatile board built using RP2040, a brand new microcontroller chip designed by Raspberry Pi in the UK.

https://www.raspberrypi.org/products/raspberry-pi-pico/


树莓派 Pico是一个小巧、“迅速”且多功能的开发板,基于独家定制的RP2040芯片打造,是在英国的树莓派团队设计的全新微控制器。

30RMB左右的价格来看,Pico作为一个开发板具有非常吸引人的特性:

  • 搭载了设计最大频率为133MHz的双核Cortex-M0+

    • 实际可以轻松超频到250MHz,甚至是400MHz

  • 256K + 8K 的SRAM

    • 由多个SRAM总线从机接口构成,从而保证了多总线主机访问时不易出现冲突的问题——双向八车道的高速,几乎不会堵车——吞吐量杠杠的

  • 大量充满奇思妙想的外设(这里就不做赘述)


在开发环境上,Pico身为单片机,却有着Linux般豪华的富贵病——这么说吧,你要是没玩过cmake、gcc、没用过命令行、没搞过OpenOCD,你都不好意思说你是Pico的C玩家。

在Pico官方论坛上,曾经有一个带节奏的帖子叫做《Pi Pico - the most user un-friendly MCU?(中文:树莓派Pico——对用户最不友好的MCU)?如果你可以看懂英文,建议去观摩下这个13页的热帖。其中你可以看到:


  • Pico-SDK团队开发者下场撕逼亲切的与各种暴躁老哥用户交流使用经验
  • Pico-SDK开发者谈Pico开发环境的设计思路,总结如下:
    • 不会玩cmake的请学习cmake,用不了你多少时间
    • Windows我们也支持啊,你装个Linux模拟环境……
    • 我们推荐所有用户都应该用树莓派4的Linux环境来开发Pico这个MCU
    • 别人都玩得好好的,你玩不好一定是你不熟悉cmake
    • makefile玩家、IAR玩家、MDK玩家请自寻出路(“on your own”)
    • 我们团队庙小,4美元的开发板你还要啥自行车?
    • ……

诸如此类,非常下饭。该贴的连接如下:

https://www.raspberrypi.org/forums/viewtopic.php?f=144&t=315750&start=75


然而,MCU的开发并不同于MPU的开发。我的观察中,树莓派这类能跑Linux的系统,基本上使用的是Linux生态,在这一生态下,很多工具比如cmake、命令行、GDB或者OpenOCD之类都是如空气和水一样自然的东西。然而,树莓派团队在处理Pico这类MCU时可能多少有点“屁股决定脑袋”了,仍然按照自己的习惯照搬了Linux的那套开发习惯到MCU环境中。


我经常说,抛开正态分布的中央主极大、用两端的个案来举反例,就是耍流氓。


对MCU开发环境来说,虽然也有不少人使用gcc、cmake之类的工具,但主体的大多数人还是以IDE等“一站式”开发工具为主体的。RP2040无论多么优秀,它本质上就是个装了两个Cortex-M0+的大号MCU,凭什么非要上Linux环境才能开发?

MDK虽然老旧、不支持多级工程管理、偶尔闪退、语法提示经常出错、被破解的爹妈都不认识……被人骂了那么多,但Cortex-M用MDK开发仍然是主流。但无奈,人家的孩子人家说了算,官方明确态度说暂时不支持Arm Compiler 6,也不支持用MDK这样的不带cmake支持的IDE,你也没办法啊


好在Pico-SDK是一个基于BSD 3-Clause协议的开源项目;RP2040的数据手册写的也很清晰。官方说不支持,我们就自己来呗?于是就有了这个MDK专属的Pico-Template开源项目。



实际上:

  • Pico-Template 是目前世界上第一个用MDK配合Arm Compiler 6开发Pico的模板;

  • 使用该模板你可以使用Pico-SDK来访问全部的外设



实际使用中 Pico-Template 具有以下特点:

  • 支持Arm Compiler 6

  • 可以使用RTE和Pack-Installer获得各类中间件软件包

  • 告别纯汇编编写的startup文件,使用纯C语言进行开发

  • 配置栈和堆的大小更为简单

  • 支持使用JLINK进行调试

  • 默认搭载了perf_counter服务

  • 一键切换不同的地址空间布局

    • 在外部Flash里执行代码

    • 在SRAM里执行代码(代码仍保存在外部Flash里)

    • 在SRAM里调试

  • 【裸机思维】对该开源项目提供持续的维护和更新


【Pico-Template的部署】


一个合格的工程模板,应该做到只要成功的下载到了本地,就能够立即使用——Pico-Template也是这样。因此,所谓的Pico-Template的部署,实际上有三种方式:它们主要围绕着如何处理Pico-Template所依赖的第三方仓库而有所区别。

第一种方式:使用git工具进行下载



1、新建一个目录,比如叫做 pico-mdk来保存模板,并进入该目录
mkdir pico-mdkcd pico-mdk

2、使用git工具clone模板到本地:
git clone https://github.com/GorgonMeducer/Pico_Template .


3、将Pico-Template所依赖的其它仓库以submodule的形式更新到本地:

git submodule update --remote --init


至此,我们已经成功的将Pico-Template同步到了本地一个叫做pico-mdk的目录下。


第二种方式:手工下载压缩包


1、打开Pico-Template在Github上的Release页面,下载最新版本的压缩包。


https://github.com/GorgonMeducer/Pico_Template/releases



完成下载后,解压缩到本地。


2、打开Pico-SDK在Github上的Release页面,下载最新的压缩包:

https://github.com/raspberrypi/pico-sdk/releases



完成下载后,解压缩到本地。打开解压后的目录,应该看到类似下图的内容:

全选上述目录列表中的内容后,将它们拷贝Pico-Templatepico-sdk目录


3、打开perf_counter在github上的Release页面,下载最新的压缩包:


https://github.com/GorgonMeducer/perf_counter/releases



完成下载后,解压缩到本地。打开解压后的目录,应该看到类似下图的内容:


全选上述目录列表中的内容后,将它们拷贝Pico-Template/project/mdk/perf_counter目录内:


至此,我们成功的完成了Pico-Template的合体工作。恭喜恭喜!


第三种方式:网盘见


如果你觉得上述方法都挺麻烦的,尤其是你无法稳定的访问Github,那么可以在订阅【裸机思维】公众号后发送关键字 "Pico"来获取网盘链接。下载成功后立即可以使用。

这一方法唯一的缺点是:我可能会忘记更新网盘上的压缩包。





【如何编译和下载】


当你获得了Pico-Template后,可以通过路径project/mdk找到工程文件:

双击后,就可以见到我们熟悉的界面:

单击编译,应该可以顺利的看到类似如下的结果:



可以看到,在工程目录下(project/mdk/) 生成了一个名为 template.uf2 的文件——这就是Pico专用的镜像文件:



此时,我们可以按住Pico上的白色按钮不放、将Pico的USB接口连接PC。当我们在文件管理器中发现一个新的叫做 PRI-RP2 的U盘时,说明Pico已经成功进入烧录准备状态。


template.uf2拖放到U盘中即可。

如果一切顺利,可以看到Pico上的LED以大约0.5Hz的频率进行呼吸。


【如何配置栈和堆的大小】


一个实用的工程模板,最绕不开的问题之一就是:如何设置栈和堆的大小。Pico-Template提供了极其简单的方法。步骤如下:

1、打开Options for Target窗口,进入Linker选项卡:

单击图中红圈内选中的“Edit”按钮。



这里宏STACK_0_SIZEHEAP_0_SIZE就是我们要配置的栈与堆的尺寸。请暂时无视其它宏的内容,也不要修改它们。


完成修改后,保存、重新编译即可。


【如何在SRAM中执行代码】


由于RP2040芯片并没有片内Flash,因此通常会像Pico那样使用外部Flash来保存程序。由于RP2040的XIP已经将外部Flash的内容映射到了Cortex-M0+的地址空间中(从0x10000000开始),因此可以直接在外部Flash上执行代码。众所周知,外部Flash是通过SPI或者QSPI来连接的,其速度肯定无法媲美芯片内部的Flash,因此即便 XIP有cache来提高速度,直接从0x1000-0000的地址上运行程序(或者是读取数据)显然存在性能上的瓶颈。
为了解决这一问题,在SRAM富余的情况下(RP2040带了264KB的SRAM)对一些小的应用来说,完全允许用户直接在SRAM中执行代码。为了提供这一功能,Pico-Template贴心的提供了对应的工程配置:我们可以在下拉列表中直接一键切换:


这一操作的本质实际上是更换了对应的scatter-script脚本。所有用到的链接脚本都保存在工程目录下:


有兴趣的小伙伴可以自行把玩。



【如何使用MDK进行调试】


在众多的商业调试工具中,Segger 的J-Link很迅捷的就添加了对RP2040的调试支持,具体细节可以通过下面的网址来了解:

https://wiki.segger.com/Raspberry_Pi_Pico


Pico-Template默认已经选择J-Link作为调试工具。需要注意的是,并非所有的J-Link都能支持RP2040的调试,按照官方的说法,只有v9版本的J-Link硬件才有对应的功能。如果你手头正好有符合要求的J-Link,恭喜你,获得了完整的MDK体验——基本告别了手动拖放uf2文件,调试全靠LED的生活。

【elf2uf2转换工具】


最后,值得特别说明的是,在Pico_Template的tool目录下有一个我亲手定制过的elf2uf2.exe——增加了自动计算0x1000-0000地址开始的252个字节的CRC32校验码,并将校验结果追加其后的功能——如果不这么做,生成的uf2将无法通过stage2-boot的校验。


工程模板会在每次编译完成后执行 axf2uf2.bat,将生成的elf/axf文件转换成Pico可以直接使用的uf2文件,方便用户进行U盘拖放操作。


【说在后面的话】


说句实话,我挺喜欢树莓派Pico的——即便我对官方的“Pico官方只支持用cmake开发不然自己想办法”的态度有些许不满,但仍然架不住它的小巧和魅力。
这个模板已经涵盖了除tinyUSB支持以外的几乎大部分功能,成功的将Pico以普通Cortex-M0+的身份拉回了国内大部分嵌入式工程师所熟悉的开发环境中。

最后的最后,我一定要把心里憋了很久的那句话吐出来:

就一个M0+而已,干嘛开发它我还要去用命令行、用Linux、学cmake?凭什么?


你们Linux玩家人均cmake、命令行、OpenOCD、GDB、gcc,所以就不管单片机玩家的死活了么?

跟我这儿玩啥凡尔赛?

老子就不想用cmake……你还不让我玩了?


就一个M0+而已,我就要用MDK来开发!怎么地吧!




原创不易,

如果你喜欢我的思维、觉得我的文章对你有所启发,

请务必 “点赞、收藏、转发” 三连,这对我很重要!谢谢!


欢迎订阅 裸机思维


你可以添加微信17775982065为好友,注明:公司+姓名,拉进RT-Thread官方微信交流群!


RTThread物联网操作系统 帮助您了解RT-Thread相关的资讯.
评论
  • 流量传感器是实现对燃气、废气、生活用水、污水、冷却液、石油等各种流体流量精准计量的关键手段。但随着工业自动化、数字化、智能化与低碳化进程的不断加速,采用传统机械式检测方式的流量传感器已不能满足当代流体计量行业对于测量精度、测量范围、使用寿命与维护成本等方面的精细需求。流量传感器的应用场景(部分)超声波流量传感器,是一种利用超声波技术测量流体流量的新型传感器,其主要通过发射超声波信号并接收反射回来的信号,根据超声波在流体中传播的时间、幅度或相位变化等参数,间接计算流体的流量,具有非侵入式测量、高精
    华普微HOPERF 2025-01-13 14:18 497浏览
  • 随着数字化的不断推进,LED显示屏行业对4K、8K等超高清画质的需求日益提升。与此同时,Mini及Micro LED技术的日益成熟,推动了间距小于1.2 Pitch的Mini、Micro LED显示屏的快速发展。这类显示屏不仅画质卓越,而且尺寸适中,通常在110至1000英寸之间,非常适合应用于电影院、监控中心、大型会议、以及电影拍摄等多种室内场景。鉴于室内LED显示屏与用户距离较近,因此对于噪音控制、体积小型化、冗余备份能力及电气安全性的要求尤为严格。为满足这一市场需求,开关电源技术推出了专为
    晶台光耦 2025-01-13 10:42 513浏览
  • 食物浪费已成为全球亟待解决的严峻挑战,并对环境和经济造成了重大影响。最新统计数据显示,全球高达三分之一的粮食在生产过程中损失或被无谓浪费,这不仅导致了资源消耗,还加剧了温室气体排放,并带来了巨大经济损失。全球领先的光学解决方案供应商艾迈斯欧司朗(SIX:AMS)近日宣布,艾迈斯欧司朗基于AS7341多光谱传感器开发的创新应用来解决食物浪费这一全球性难题。其多光谱传感解决方案为农业与食品行业带来深远变革,该技术通过精确判定最佳收获时机,提升质量控制水平,并在整个供应链中有效减少浪费。 在2024
    艾迈斯欧司朗 2025-01-14 18:45 69浏览
  • 新年伊始,又到了对去年做总结,对今年做展望的时刻 不知道你在2024年初立的Flag都实现了吗? 2025年对自己又有什么新的期待呢? 2024年注定是不平凡的一年, 一年里我测评了50余块开发板, 写出了很多科普文章, 从一个小小的工作室成长为科工公司。 展望2025年, 中国香河英茂科工, 会继续深耕于,具身机器人、飞行器、物联网等方面的研发, 我觉得,要向未来学习未来, 未来是什么? 是掌握在孩子们生活中的发现,和精历, 把最好的技术带给孩子,
    丙丁先生 2025-01-11 11:35 465浏览
  • 01. 什么是过程能力分析?过程能力研究利用生产过程中初始一批产品的数据,预测制造过程是否能够稳定地生产符合规格的产品。可以把它想象成一种预测。通过历史数据的分析,推断未来是否可以依赖该工艺持续生产高质量产品。客户可能会要求将过程能力研究作为生产件批准程序 (PPAP) 的一部分。这是为了确保制造过程能够持续稳定地生产合格的产品。02. 基本概念在定义制造过程时,目标是确保生产的零件符合上下规格限 (USL 和 LSL)。过程能力衡量制造过程能多大程度上稳定地生产符合规格的产品。核心概念很简单:
    优思学院 2025-01-12 15:43 533浏览
  • 根据Global Info Research(环洋市场咨询)项目团队最新调研,预计2030年全球无人机电池和电源产值达到2834百万美元,2024-2030年期间年复合增长率CAGR为10.1%。 无人机电池是为无人机提供动力并使其飞行的关键。无人机使用的电池类型因无人机的大小和型号而异。一些常见的无人机电池类型包括锂聚合物(LiPo)电池、锂离子电池和镍氢(NiMH)电池。锂聚合物电池是最常用的无人机电池类型,因为其能量密度高、设计轻巧。这些电池以输出功率大、飞行时间长而著称。不过,它们需要
    GIRtina 2025-01-13 10:49 201浏览
  • 随着通信技术的迅速发展,现代通信设备需要更高效、可靠且紧凑的解决方案来应对日益复杂的系统。中国自主研发和制造的国产接口芯片,正逐渐成为通信设备(从5G基站到工业通信模块)中的重要基石。这些芯片凭借卓越性能、成本效益及灵活性,满足了现代通信基础设施的多样化需求。 1. 接口芯片在通信设备中的关键作用接口芯片作为数据交互的桥梁,是通信设备中不可或缺的核心组件。它们在设备内的各种子系统之间实现无缝数据传输,支持高速数据交换、协议转换和信号调节等功能。无论是5G基站中的数据处理,还是物联网网关
    克里雅半导体科技 2025-01-10 16:20 449浏览
  • 随着全球向绿色能源转型的加速,对高效、可靠和环保元件的需求从未如此强烈。在这种背景下,国产固态继电器(SSR)在实现太阳能逆变器、风力涡轮机和储能系统等关键技术方面发挥着关键作用。本文探讨了绿色能源系统背景下中国固态继电器行业的前景,并强调了2025年的前景。 1.对绿色能源解决方案日益增长的需求绿色能源系统依靠先进的电源管理技术来最大限度地提高效率并最大限度地减少损失。固态继电器以其耐用性、快速开关速度和抗机械磨损而闻名,正日益成为传统机电继电器的首选。可再生能源(尤其是太阳能和风能
    克里雅半导体科技 2025-01-10 16:18 331浏览
  • PNT、GNSS、GPS均是卫星定位和导航相关领域中的常见缩写词,他们经常会被用到,且在很多情况下会被等同使用或替换使用。我们会把定位导航功能测试叫做PNT性能测试,也会叫做GNSS性能测试。我们会把定位导航终端叫做GNSS模块,也会叫做GPS模块。但是实际上他们之间是有一些重要的区别。伴随着技术发展与越发深入,我们有必要对这三个词汇做以清晰的区分。一、什么是GPS?GPS是Global Positioning System(全球定位系统)的缩写,它是美国建立的全球卫星定位导航系统,是GNSS概
    德思特测试测量 2025-01-13 15:42 500浏览
  •   在信号处理过程中,由于信号的时域截断会导致频谱扩展泄露现象。那么导致频谱泄露发生的根本原因是什么?又该采取什么样的改善方法。本文以ADC性能指标的测试场景为例,探讨了对ADC的输出结果进行非周期截断所带来的影响及问题总结。 两个点   为了更好的分析或处理信号,实际应用时需要从频域而非时域的角度观察原信号。但物理意义上只能直接获取信号的时域信息,为了得到信号的频域信息需要利用傅里叶变换这个工具计算出原信号的频谱函数。但对于计算机来说实现这种计算需要面对两个问题: 1.
    TIAN301 2025-01-14 14:15 113浏览
  • 数字隔离芯片是现代电气工程师在进行电路设计时所必须考虑的一种电子元件,主要用于保护低压控制电路中敏感电子设备的稳定运行与操作人员的人身安全。其不仅能隔离两个或多个高低压回路之间的电气联系,还能防止漏电流、共模噪声与浪涌等干扰信号的传播,有效增强电路间信号传输的抗干扰能力,同时提升电子系统的电磁兼容性与通信稳定性。容耦隔离芯片的典型应用原理图值得一提的是,在电子电路中引入隔离措施会带来传输延迟、功耗增加、成本增加与尺寸增加等问题,而数字隔离芯片的目标就是尽可能消除这些不利影响,同时满足安全法规的要
    华普微HOPERF 2025-01-15 09:48 85浏览
  • ARMv8-A是ARM公司为满足新需求而重新设计的一个架构,是近20年来ARM架构变动最大的一次。以下是对ARMv8-A的详细介绍: 1. 背景介绍    ARM公司最初并未涉足PC市场,其产品主要针对功耗敏感的移动设备。     随着技术的发展和市场需求的变化,ARM开始扩展到企业设备、服务器等领域,这要求其架构能够支持更大的内存和更复杂的计算任务。 2. 架构特点    ARMv8-A引入了Execution State(执行状
    丙丁先生 2025-01-12 10:30 474浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦