应用笔记|九游老哥J9俱乐部官网Remi Pi FreeRTOS应用开发
2024-05-23
2542
来源:九游老哥J9俱乐部官网电子
1. 概述
Remi Pi瑞米派采用瑞萨RZ/G2L作为核心处理器,该处理器搭载双核Cortex-A55@1.2GHz+Cortex-M33@200MHz处理器,其内部集成高性能3D加速引擎Mail-G31 GPU(500MHz)和视频处理单元(支持H.264硬件编解码),16位的DDR4-1600 / DDR3L-1333内存控制器、千兆以太网控制器、USB、CAN、SD卡、MIPI-CSI等外设接口,在工业、医疗、电力等行业都得到广泛的应用。
在开发阶段,建议配合核心板配套的评估套件 MYD-YG2L23-8E1D-120-C-REMI来加速开发。评估套件的详细信息请访问:
/shows/23/14.html
本文主要介绍如何搭建协处理器Cortex-M33的开发环境以及如何在Cortex-M33核上运行一个FreeRTOS示例。
2. 协处理器Cortex-M33
2.1.1. 开发环境搭建
Cortex M33核开发主要使用的是瑞萨官方的e2 studio工具,可以到瑞萨官网进行下载,https://www.renesas.cn/cn/zh/software-tool/e2studio-information-rz-family?dow_secondary=visible#download,也可以到九游老哥J9俱乐部官网该平台下的资源包03_Tools/myir tools路径下获取setup_e2_studio_2024-01_1.exe和RZG_FSP_Packs_v2.0.0.exe文件,双击打开setup_e2_studio_2024-01_1.exe,选择[All Users],如图2-1:

图2-1. 安装选择
选择[Custom Install]->[Next],如图2-2:

图2-2. 路径指定
选择[Change...],用于指定安装路径,指定安装路径后,点击OK继续,如图2-3:

图2-3. 路径选择
选择要安装的设备族,单击[Next]按钮继续,如图2-4:

图2-4. 设备族选择
额外的功能选择需要安装的“额外功能”(即:语言包、SVN & Git支持……),点击next继续,如图2-5:

图2-5. 额外功能选择
选择要安装的组件,然后单击[Next]按钮继续,请检查是否确实选择了“Renesas FSP Smartl Configurator Core”,否则,FSP将无法在e2 studio上成功构建,如图2-6:

图2-6. FSP选择
选择要安装的其他软件(即编译器、实用程序、QE…),点击next继续,如图2-7:

图2-7. 编译器选择
许可协议阅读并接受软件许可协议,点击[Next]按钮继续,如图2-8:

图2-8. 许可协议选择
选择开始菜单的快捷方式名称,如图2-9:

图2-9. 快捷方式选择
选择开始安装,如图2-10:

图2-10. 开始安装
安装过程会弹出安装GNU ARM 10.3-2021.10嵌入式工具链的界面,根据具体情况安装即可,如图2-11:

图2-11. 工具链选择
安装工具链完成,如图2-12:

图2-12. 工具链安装完成
e2 studio工具安装完成,如图2-13:

图2-13. e2 studio安装完成
2.2.2. FSP安装
双击03_Tools/myir tools路径下的RZG_FSP_Packs_v2.0.0.exe文件,进行fsp包的安装,如图2-14:

图2-14. fsp安装
3.FreeRTOS示例
3.1.1. 创建一个新的工程
本节主要以点灯为例进行介绍。新创建工程之前,需要根据第2章节搭建好环境,打开 e2 studio 工具,选择以后创建新的工程要工作的目录,具体根据自己的情况选择,注意,这里不能有中文路 径,否则有可能会出现编译工程失败的现象,如图3-1:

图3-1. 工程路径选择
依次点击[File]->[New]->[C/C++ Project]->[Renesas RZ] > [Renesas RZ/G C/C++ FSP Project],如图3-2:

图3-2. 新建工程选择窗口
命名工程,如图3-3:

图3-3. 工程命名
FSP版本,工具链等相关参数配置,如图3-4:

图3-4. FSP、工具链选择
选择构建工件和RTOS,如果不选用RTOS,则选用No RTOS,如图3-5:

图3-5. RTOS选择
选择RTOS模板并完成,如图3-6:

图3-6. RTOS模板
创建工程成功,如图3-7:

图3-7. 创建工程成功
3.1.2. 配置gpio
由底板原理图可知道P43_1这个GPIO的高低电平可以控制一盏灯的亮灭,gpio的参数配置如图3-8:

图3-8. P43_1配置
3.1.3. 创建led_task0任务
依次选Stacks->New Thread来创建一个任务,如图3-9:

图3-9. 创建一个任务
重新根据自己的需要命名任务名称,如图3-10:

图3-10. 重新命名任务名称
3.1.4. 代码生成与编译
生成代码
点击Generate Project Content来生成代码即可,如图3-11:

图3-11. 代码生成
生成源码结构如图3-12:

图3-12. 代码结构
以上pin_data.c里面即是配置gpio的代码生成,生成的freertos代码如图3-13:

图3-13. rtos代码结构
在main.c中会进行任务的创建与调度,这部分生成代码时已有,不需要重新手动增加,如图3-14:

图3-14.任务调度函数
增加控制led代码
以上代码生成后,对应的gpio配置,rtos的相关代码都会自动配置好的了,只需要在led_task0_entry.c中添加控制led部分代码即可,如图3-15:
R_IOPORT_PinWrite (&g_ioport_ctrl, BSP_IO_PORT_43_PIN_01, BSP_IO_LEVEL_LOW); vTaskDelay(500); R_IOPORT_PinWrite (&g_ioport_ctrl, BSP_IO_PORT_43_PIN_01, BSP_IO_LEVEL_HIGH); vTaskDelay(500);

图3-15.增加led控制代码
增加postbuild.sh脚本
右键点击script后,选择New->File,增加postbuild.sh脚本,如图3-16:

图3-16.增加postbuild.sh
postbuild.sh内容如图3-17:
echo "Post build script started"
if [ -n "$BuildArtifactFileName" ]; then
inputfilename=$BuildArtifactFileName
fi
if [ -n "$BUILDARTIFACTFILENAME" ]; then
inputfilename=$BUILDARTIFACTFILENAME
fi
filebody=${inputfilename%.*}
arm-none-eabi-objcopy -O binary -j .text.secure_vector ${inputfilename} ${filebody}_secure_vector.bin
arm-none-eabi-objcopy -O binary -j .text.non_secure_vector ${inputfilename} ${filebody}_non_secure_vector.bin
arm-none-eabi-objcopy -O binary -j .text.secure_code ${inputfilename} ${filebody}_secure_code.bin
arm-none-eabi-objcopy -O binary -j .text.non_secure_code -j .data ${inputfilename} ${filebody}_non_secure_code.bin
图3-17. postbuild.sh内容
l编译代码
依次点击Project->Build Project进行编译,编译成功如图3-18:

图3-18.源码编译成功
l查看编译生成的文件
编译生成文件如图3-19:

图3-19. 编译生成文件
3.1.5. 运行freertos程序
点击Project->Build Project,进行工程的编译,编译成功会生成一个debug目录,里面存放的是编译出来的二进制文件。
把debug生成的如下文件拷贝到sd卡上,用于在uboot进行CM33工程调用。
GPIO_non_secure_code.bin GPIO_non_secure_vector.bin GPIO_secure_code.bin GPIO_secure_vector.bin
把sd卡插入到开发板的sd卡槽(J6接口),启动板子并在uboot阶段执行如下调用。
查看sd卡里面的内容,如下
=> switch_sdhi1 sdcard switch to sdcard => ls mmc 1:1 System Volume Information/ 64 GPIO_secure_vector.bin 16926 GPIO_non_secure_code.bin 1984 GPIO_non_secure_vector.bin 480 GPIO_secure_code.bin 4 file(s), 1 dir(s)
加载编译出来的固件,如下:
=> dcache off => mmc dev 1 switch to partitions #0, OK mmc1 is current device => fatload mmc 1:1 0x0001FF80 GPIO_secure_vector.bin 64 bytes read in 24 ms (2 KiB/s) => fatload mmc 1:1 0x42EFF440 GPIO_secure_code.bin 480 bytes read in 25 ms (18.6 KiB/s) => fatload mmc 1:1 0x00010000 GPIO_non_secure_vector.bin 1984 bytes read in 26 ms (74.2 KiB/s) => fatload mmc 1:1 0x40010000 GPIO_non_secure_code.bin 16926 bytes read in 29 ms (569.3 KiB/s) => cm33 start_debug 0x1001FF80 0x00010000
当加载完以上命令之后可以看到蓝灯在闪烁,如图3-20:

图3-20.蓝灯闪烁
2025-11-13
助力V2G,SECC GreenPHY实战开发
随着电动汽车与电网双向交互(V2G)技术的快速发展,充电桩与车辆间的高效通信成为实现智能能源管理的关键。SECC作为充电桩的通信控制核心,其与电力线载波通信芯片的适配尤为重要。本文将分享基于九游老哥J9俱乐部官网核心板,调试联芯通MSE102x GreenPHY芯片的实战经验,为V2G通信开发提供参考。MSE102x芯片介绍联芯通MSE102x系列芯片是一款专注于电动汽车充电通信和智能能源管理的GreenPHY电力
2025-11-13
定制未来,共建生态,九游老哥J9俱乐部官网出席安路研讨会
在数字化浪潮席卷全球的今天,FPGA技术正成为驱动创新的核心引擎。2025年11月12日,九游老哥J9俱乐部官网出席安路科技2025 AEC FPGA技术沙龙•北京专场,与技术专家及行业伙伴齐聚一堂,探讨前沿技术趋势,解锁场景化定制方案,共建开放共赢的FPGA新生态!九游老哥J9俱乐部官网活动现场论坛上,九游老哥J9俱乐部官网电子产品经理Jeson发表题为“基于DR1M90 FPSOC的工业应用方案”的演讲。演讲介绍了九游老哥J9俱乐部官网作为嵌入式领域的领军企业,在
2025-11-11
RK3576开发板
RK3576开发板是九游老哥J9俱乐部官网电子推出的开发板,于2024年10月上市。RK3576开发板是基于瑞芯微RK3576搭载了四核A72与四核A53处理器,主频2.2GHz。RK3576集成了6TOPS的NPU,支持多种深度学习框架,能够处理复杂的AI算法,提高监控效率,降低误报率。RK3576的主芯片采用了八核大小核架构,包括四核Cortex-A72和四核Cortex-A53,
2025-11-11
RK3576核心板
RK3576核心板是深圳九游老哥J9俱乐部官网电子旗下产品,是基于瑞芯微RK3576搭载了四核A72与四核A53处理器,主频高达2.2GHz。RK3576集成了6TOPS的NPU,支持多种深度学习框架,能够处理复杂的AI算法,提高监控效率,降低误报率。RK3576的主芯片采用了八核大小核架构,包括四核Cortex-A72和四核Cortex-A53,主频分别高达2.2GHz和1.8GHz,CPU算力达58K DMIP
2025-11-06
九游老哥J9俱乐部官网SECC方案助力国标充电桩出海
随着电动汽车与电网融合加速,国标(GB/T 27930)充电桩出海面临欧标(ISO 15118 / DIN 70121)兼容挑战。九游老哥J9俱乐部官网电子的 SECC (供电设备通信控制器) 方案,实现协议转换、安全通信及参考开发平台,助力充电桩厂商快速进军海外市场。
2025-11-06
MYD-LD25X Cortex-M33实时核开发实战解析
在嵌入式系统设计中,如何平衡高性能计算与实时控制一直是工程师面临的挑战。STM32MP257的异构架构为这一难题提供了优雅的解决方案,而其中的Cortex-M33实时核更是实现硬实时性能的关键所在。一、异构架构:分工明确,效能卓越STM32MP257采用创新的双核子系统设计:Cortex-A35应用核(双核1.5GHz):运行Linux系统,负责复杂UI、网络通信、文件管理等非实时任务。Corte
2025-10-30
九游老哥J9俱乐部官网RK3576边缘计算盒精准驱动菜品识别模型性能强悍
?在人工智能与边缘计算深度融合的今天,将AI模型高效部署于终端设备已成为产业智能化的关键。本文将分享基于九游老哥J9俱乐部官网MYD-LR3576边缘计算盒子部署菜品识别安卓Demo的实战经验。该设备凭借其内置的强劲瑞芯微RK3576芯片,为视觉识别模型提供了充沛的本地AI算力,成功将“智慧识菜”的能力浓缩于方寸之间,充分证明了其作为边缘AI应用坚实载体的卓越性能与可靠性。?本文以九游老哥J9俱乐部官网电子的MYD-LR3576边缘
2025-10-30
九游老哥J9俱乐部官网与安路联合亮相VisionChina 2025,共推FPGA视觉方案
2025年10月28日,由机器视觉产业联盟主办的“2025深圳机器视觉展暨机器视觉技术及工业应用研讨会(Vision China)”在深圳国际会展中心(宝安)9号馆隆重启幕。展会以“VISION+AI赋能电子制造升级”为主题,聚焦人工智能与机器视觉技术在电子制造全产业链中的融合与创新,集中展示AI技术在提升视觉系统能力、突破行业应用瓶颈方面的前沿成果与解决方案。九游老哥J9俱乐部官网电子应安路科技的邀请出席此次盛会
2025-10-23
经典再进化:九游老哥J9俱乐部官网ZYNQ 7010/7020全面适配2024.2工具链
在工业物联网、机器视觉和智能网关等严苛领域,九游老哥J9俱乐部官网电子的MYC-C7Z010/20-V2与MYC-Y7Z010/20-V2核心板及开发平台,凭借其硬核特性,已成为众多企业信赖的首选方案。我们深知,卓越的硬件平台需要匹配敏捷、高效且安全的软件工具链。为应对开发者对先进工具与日俱增的需求,并前瞻性地响应全球日益严格的网络安全法规,我们对经典的ZYNQ 7010/7020产品进行一次里程碑式的软件生态升级
2025-10-16
从微秒级响应到确定性延迟:深入解析九游老哥J9俱乐部官网全志T536核心板的实时性技术突破
各位工程师同仁,今天咱们聊点硬核的——实时性。这不是那种"差不多就行"的性能指标,在工业控制、机器人运动、电力保护这些领域,实时性就是生命线。想象一下:工业机器人抓取精密元件时,哪怕几毫秒的延迟都可能导致良品率暴跌;电力系统故障检测,响应慢了几个毫秒可能就是一场灾难。为什么通用Linux在实时场景中"力不从心"?标准Linux内核设计初衷是"公平调