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

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

3天内不再提示

【深度实战】MYD-LR3576 AMP非对称多核开发指南:从配置到实战

米尔电子 2025-12-05 08:07 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

一、什么是AMP?为什么重要?

AMP(Asymmetric Multi-Processing)非对称多处理架构,允许单个芯片的不同核心运行不同的操作系统或裸机程序。相比传统的SMP(对称多处理),AMP具有独特优势。

核心特性:

异构运算:不同核心运行最适合的操作系统,如Linux处理复杂应用,RT-Thread保障实时任务;

资源隔离:各核心拥有独立内存空间,避免资源冲突;

灵活通信:通过共享内存、RPMSG等方式实现高效核间通信;

商业价值:

成本优化:单芯片替代多芯片方案,减少PCB面积和元器件数量;

开发灵活:支持Linux、RT-Thread、裸机程序的自由组合;

系统可靠:故障隔离,关键任务永不掉线;

二、实战选型:MYD-LR3576的AMP硬件基础

米尔核心板MYD-LR3576 基于 RK3576 处理器,集成三大核心集群:AP 端配备 4 颗 ARM Cortex-A72 与 4 颗 ARM Cortex-A53 核心,MCU 端搭载 1 颗 ARM Cortex-M0 核心,通过 AMP 架构实现多系统异构运行,在成本优化与开发灵活性上展现突出优势。

6c75b324-d16e-11f0-8ce9-92fbcf53809c.png

MYD-LR3576开发板

三大核心集群

6c95bb06-d16e-11f0-8ce9-92fbcf53809c.png

系统支持:

6ca77378-d16e-11f0-8ce9-92fbcf53809c.png

已验证AMP方案:

AP+AP架构:Linux + RT-Thread/Bare-metal

AP+MCU架构:Linux + MCU RT-Thread/Bare-metal

三、实战操作:AMP 系统串口资源配置

实战目标:基于MYD-LR3576开发板,详细讲解Linux与RT-Thread侧的串口资源配置全流程,实现从理论到实践的完整落地。

3.1 Linux 侧串口资源的剥离与分配

在AMP 架构中,若需将 UART6 分配给 RT-Thread 从核使用,需先在 Linux 设备树中完成资源剥离,避免 Linux 内核对该外设的占用。

1.失能UART6: Linux 设备树通过节点状态配置控制外设的启用 / 禁用。对于UART6,需在其节点中添加“status = "disabled"”属性,明确告知 Linux 内核:该串口不再由 Linux 管理。

&uart6 { status ="disabled"; // 剥离Linux对UART6的控制权};

2.分配UART6 资源

剥离后的UART6 资源需通过 rockchip_amp 节点重新分配给从核,配置内容包括时钟资源、引脚功能与中断路由:

&rockchip_amp { clocks = <...>, <&cru SCLK_UART6>, <&cru PCLK_UART6>; pinctrl-0 = <&uart6m3_xfer>; amp-irqs = ;};

3.分配从核内存

为避免Linux 内核占用从核的运行内存,需在 reserved-memory 节点中划分专属内存区域。例如,为 RT-Thread 从核预留 8MB 内存:

amp_reserved: amp@41800000{ reg = <0x0 0x41800000 0x0 0x00800000>;//起始地址0x41800000,大小8MB no-map;//禁止Linux映射该区域,确保从核独占};

3.2 RT-Thread 侧 UART6 的初始化与启用

Linux 侧完成资源剥离后,需在 RT-Thread 中对 UART6 进行初始化,使其具备通信能力。RT-Thread 的配置流程主要包括引脚复用、中断路由与外设使能三步。

1.UART6 引脚复用配置

RK3576 的引脚支持多功能复用,UART6 的 TX/RX 引脚需配置为对应功能模式(如 Func13)。通过 RT-Thread 的硬件抽象层(HAL)接口,可直接完成引脚功能的配置:

#ifdefRT_USING_UART6 uart6_m3_iomux_config();#endifvoiduart6_m3_iomux_config(void){ HAL_PINCTRL_SetIOMUX(GPIO_BANK4, GPIO_PIN_C5, PIN_CONFIG_MUX_FUNC13); HAL_PINCTRL_SetIOMUX(GPIO_BANK4, GPIO_PIN_C4, PIN_CONFIG_MUX_FUNC13);}

2.UART6 中断路由配置

为确保UART6 的中断能被 CPU3(从核)响应,需通过 GIC 中断控制器的路由配置,将 UART6 的中断号与 CPU3 绑定。RT-Thread 提供了简洁的条件编译选项:

#ifdef RT_USING_UART6 GIC_AMP_IRQ_CFG_ROUTE(UART6_IRQn,0xd0, CPU_GET_AFFINITY(3,0));#endif

3.UART6 RTOS侧使能

通过在RT-Thread 的配置文件中启用对应选项,使能 UART6条件编译:

CONFIG_RT_CONSOLE_DEVICE_NAME="uart6"CONFIG_RT_USING_UART6=y

四、编译部署:AMP系统镜像构建

4.1 编译镜像

完成配置后,返回SDK 工程根目录,执行编译脚本:

cdMYD-LR3576./build.sh lunch1. rockchip_defconfig2. rockchip_rk3576_myd_lr3576_amp_defconfig3. rockchip_rk3576_myd_lr3576_defconfig4. rockchip_rk3576_myd_lr3576_mcu_defconfigWhich would you like? [1]: 2...../build.sh# 完整编译

编译成功后,生成的系统镜像文件路径为:

lsoutput/update/Image/update.imgupdate.img

4.2 烧录镜像至开发板

请使用瑞芯微官方烧录工具RKDevTool将镜像写入开发板。

五、功能验证

5.1 验证环境搭建

连接开发板Debug 口:串口参数设为 115200 波特率、8 数据位、1 停止位、无校验位;

连接开发板UART6 串口(具体位置如下图):参数设为1500000 波特率、8 数据位、1 停止位、无校验位。

6cba7c20-d16e-11f0-8ce9-92fbcf53809c.png

5.2 主核验证(Linux终端)

打开主核debug终端,输入lscpu命令查看CPU信息,若Cortex-A53核心数量显示为3(原4颗,1颗分配给RT-Thread),说明主核配置生效:

lscpu# 输出结果中Cortex-A53核心数为3

6ce1c46a-d16e-11f0-8ce9-92fbcf53809c.png

5.3 从核验证(RT-Thread终端)

打开UART6对应的串口终端(波特率默认1500000),若能看到RT-Thread的启动日志,说明从核系统已成功运行,UART6外设正常工作。

6cfa5a34-d16e-11f0-8ce9-92fbcf53809c.png

六、总结

本次串口资源配置实战,清晰地验证了外设从Linux侧剥离、再分配至RT-Thread侧的核心方法论。这仅是AMP灵活性的起点,基于相同的配置逻辑,开发者还可将GPIO、I2C、SPI等更多外设进行精细化分配。

这种灵活的异构计算模式,使其能够无缝适配多类对性能、实时性与功耗有综合要求的工业与嵌入式场景。其典型应用模式可归纳如下:

1.工业网关:Linux运行网络协议栈、数据库与Web服务,实现数据上云与远程管理;RT-Thread则实时采集PLC数据、精准控制执行器,保障工业现场毫秒级响应与确定性。

2.机器人控制器:Linux承载SLAM算法、视觉感知、路径规划与人机交互界面;RT-Thread专责多轴电机闭环控制、高频率传感器融合及硬实时安全连锁。

3.智能音视频设备:Linux处理高清音视频编解码、AI模型推理及云服务对接;独立Cortex-M0核心则实现低功耗待机、语音关键词唤醒与触控检测,显著优化系统功耗与响应速度。

AMP架构的价值,正是在于让开发者能够根据场景需求,在同一硬件平台上自由调配计算资源,实现性能、成本与功耗的最佳平衡。

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

    关注

    0

    文章

    102

    浏览量

    48646
  • 核心板
    +关注

    关注

    6

    文章

    1422

    浏览量

    32133
  • 米尔电子
    +关注

    关注

    2

    文章

    199

    浏览量

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    如何在RK3576开发板上运行TinyMaix :超轻量级推理框架--基于米尔MYD-LR3576开发

    本文将介绍基于米尔电子MYD-LR3576开发平台部署超轻量级推理框架方案:TinyMaix摘自优秀创作者-短笛君TinyMaix是面向单片机的超轻量级的神经网络推理库,即TinyML推理库,可以
    的头像 发表于 07-25 08:03 4416次阅读
    如何在RK<b class='flag-5'>3576</b><b class='flag-5'>开发</b>板上运行TinyMaix :超轻量级推理框架--基于米尔<b class='flag-5'>MYD-LR3576</b><b class='flag-5'>开发</b>板

    如何在 MA35 系列微处理器 (MPU) 上开发 AMP非对称多处理)应用程序?

    如何在 MA35 系列微处理器 (MPU) 上开发 AMP非对称多处理)应用程序,并通过建立多个端点的过程促进与其他内核的多通道数据传输。
    发表于 08-19 06:11

    LSI丰富非对称多核解决方案

    LSI丰富非对称多核解决方案  LSI 公司 宣布推出适用于无线应用的最新系列非对称多核芯片解决方案和软件。这些新一代处理器基于 LSI 前代业界领先的无线基础设施
    发表于 02-23 09:06 776次阅读

    LSI推出最新系列非对称多核芯片解决方案和软件

    LSI推出适用于无线应用的最新系列非对称多核芯片解决方案和软件。这些新一代处理器基于LSI前代业界领先的
    发表于 01-03 14:56 984次阅读

    传统多核解决方案与非对称多核解决方案的对比

    就当今通信处理器而言,市场中存在两种相互竞争的多核架构方案,一种是传统(即对称式)的多核解决方案,另一种是非对称多核解决方案。这两种方案都将通用多核
    发表于 05-09 09:35 956次阅读

    非对称多谐振荡器原理图

    非对称多谐振荡器原理图都是值得参考的设计。
    发表于 05-11 17:11 22次下载

    裸机AMP(非对称多进程处理模式)

    在上一篇博客中,我们已经将Zynq SoC启动并运行起来,在AMP非对称多进程处理)模式下使用了两个ARM Cortex-A9 MPCore处理器,然而因为上一篇博客已经相当长了,我没有详细的介绍软件方面的工程细节。
    发表于 02-11 10:18 3956次阅读
    裸机<b class='flag-5'>AMP</b>(<b class='flag-5'>非对称多</b>进程处理模式)

    C#上位机实战开发指南

    C#上位机实战开发指南
    发表于 11-22 19:25 0次下载

    arduino开发实战指南

    arduino开发实战指南
    发表于 02-22 14:56 0次下载

    提供非对称多核处理器提高性能可预测性

      下一代网络和应用程序不断增长的性能需求,加上用户对可靠性和服务质量的期望,需要专门构建的非对称多核架构以最低的功耗和成本实现线速、确定性的性能。
    的头像 发表于 06-14 16:16 1949次阅读
    提供<b class='flag-5'>非对称多核</b>处理器提高性能可预测性

    有奖丨米尔 瑞芯微RK3576开发板免费试用

    米尔与瑞芯微合作发布的新品基于瑞芯微RK3576应用处理器的MYD-LR3576开发板免费试用活动来啦~~米尔提供了7块价值849元的MYD-LR3576
    的头像 发表于 11-12 01:00 1575次阅读
    有奖丨米尔 瑞芯微RK<b class='flag-5'>3576</b><b class='flag-5'>开发</b>板免费试用

    追加名额丨米尔瑞芯微RK3576开发板有奖试用

    米尔与瑞芯微合作发布的新品基于瑞芯微RK3576应用处理器的MYD-LR3576开发板免费试用活动加码啦~~米尔追加了2块价值849元的MYD-LR3576
    的头像 发表于 11-22 01:00 1458次阅读
    追加名额丨米尔瑞芯微RK<b class='flag-5'>3576</b><b class='flag-5'>开发</b>板有奖试用

    “国产双系统”出炉!复旦微FMQL20SM非对称AMP:Linux + 裸机

    非对称AMP”双系统是什么 AMP(Asymmetric Multi-Processing),即非对称多处理架构。“非对称
    的头像 发表于 01-24 13:46 1787次阅读
    “国产双系统”出炉!复旦微FMQL20SM<b class='flag-5'>非对称</b><b class='flag-5'>AMP</b>:Linux + 裸机

    C#上位机实战开发指南

    电子发烧友网站提供《C#上位机实战开发指南.pdf》资料免费下载
    发表于 01-11 17:15 6次下载

    爆火的OpenClaw! 告别云端,米尔RK3576本地部署

    PART01概述基于最近爆火的OpenClaw项目,本文将在MYD-LR3576开发板上部署OpenClaw,并接入飞书机器人,实现本地自托管AI助手。1.1.硬件资源部署端:MYD-LR3576
    的头像 发表于 03-06 08:04 1133次阅读
    爆火的OpenClaw! 告别云端,米尔RK<b class='flag-5'>3576</b>本地部署