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

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

3天内不再提示

RT-Thread新开发工具支持:e2studio手把手适配教程 | 技术集结

RT-Thread官方账号 2026-04-02 18:06 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

Titan-RA8P1的芯片是Renensas的RA8P1系列芯片,瑞萨官方使用的IDE是e2studio。本文介绍如何在e2studio中创建工程并结合RT-Thread的源码,在e2studio实现RT-Thread工程的管理和调试。

目录


硬件外设


创建e2studio工程和配置基本外设


添加BSP模板并修改

1 硬件外设


使用RT-Thread实现控制Titan-RA8P1上的三色LED,并输出log都串口中断显示,查看开发板的原理图,串口和LED的控制引脚如图所示。

94731438-2e7b-11f1-ab55-92fbcf53809c.png947da57e-2e7b-11f1-ab55-92fbcf53809c.png

板载外部晶振用于提供系统时钟源。

948a28d0-2e7b-11f1-ab55-92fbcf53809c.png

2 创建e2studio工程和配置基本外设


根据Titan-RA8P1开发板的芯片的型号,创建基于芯片型号的工程,编译器选择GCC。

9495f354-2e7b-11f1-ab55-92fbcf53809c.png

选择工程使用的RTOS类型为No RTOS

94a2f630-2e7b-11f1-ab55-92fbcf53809c.png

FSP Configurator中的Stacks菜单中添加串口模块

94adc7c2-2e7b-11f1-ab55-92fbcf53809c.png

设置串口uart8模块的参数,指定其名称为g_uart8,中断回调函数名为usr_uart8_callback

94be2112-2e7b-11f1-ab55-92fbcf53809c.png94ca6468-2e7b-11f1-ab55-92fbcf53809c.png

保存配置只并生成代码。

3 添加BSP模板并修改


3.1 复制文件

复制bsp\renesas\libraries\bsp-template文件夹中的内容,到e2studio工程文件夹中。RTThread中使用KConfig工具对代码进行配置,生成rt_config.h头文件用于配置不同的软件组件。

94d47e30-2e7b-11f1-ab55-92fbcf53809c.png

复制bsp\renesas\中的libraries\HAL_Drivers中的文件夹到工程中。

3.2 修改Kconfig文件

由于存放Kconfig文件夹结构发生变化,需要修改复制到e2studio工程中的顶层目录中的Kconfig文件中的RTT_DIR变量,指定存放RT-Thread代码的位置。参考官方提供的Titan-RA8P1的工程配置,在其中添加芯片相关的项目,修改后的内容如下。

mainmenu"RT-Thread Configuration"BSP_DIR := .RTT_DIR := ../../rt-thread# you can change the RTT_ROOT default "../.." to your rtthread_root,# example : default "F:/git_repositories/rt-thread"PKGS_DIR := packagesENV_DIR := /source"$(RTT_DIR)/Kconfig"osource"$PKGS_DIR/Kconfig"rsource"libraries/Kconfig"source"$(BSP_DIR)/board/Kconfig"

修改board\Kconifg中的内容,在On-chip Peripheral Drivers菜单中添加片上的串口驱动,用于支持RT-Thread串口终端功能。同时根据libraries\Kconfig文件的存放位置修改文件中的rsource语句参数。主要的添加内容如下。

menu"Hardware Drivers Config" config SOC_R7KA8P1KF bool select SOC_SERIES_R7KA8P1 select SOC_SERIES_R7KA8P1_CORE0 select RT_USING_COMPONENTS_INIT select RT_USING_USER_MAIN defaulty menu"Onboard Peripheral Drivers" endmenu menu"On-chip Peripheral Drivers" rsource"../libraries/HAL_Drivers/drivers/Kconfig" menuconfig BSP_USING_UART bool"Enable UART" defaulty select RT_USING_SERIAL select RT_USING_SERIAL_V2 ifBSP_USING_UART menuconfig BSP_USING_UART8 bool"Enable UART8" defaultn ifBSP_USING_UART8 config BSP_UART8_RX_BUFSIZE int"Set UART8 RX buffer size" range6465535 depends on RT_USING_SERIAL_V2 default256 config BSP_UART8_TX_BUFSIZE int"Set UART8 TX buffer size" range065535 depends on RT_USING_SERIAL_V2 default0 endif endif endmenu menu"Board extended module Drivers" endmenuendmenu

完成添加后,在e2studio工程中使用RT-Thread提供的env工具,在其中运行menuconfig指令,验证Kconfig文件修改是否成功,报错的话根据提示修改即可。进入menuconfig界面,修改RT-Thread Kernel中的shell使用的uart名称。

94e28714-2e7b-11f1-ab55-92fbcf53809c.png

uart组件驱动使用Serial_V2

94f0fbbe-2e7b-11f1-ab55-92fbcf53809c.png

使能添加的uart8驱动

94feeb0c-2e7b-11f1-ab55-92fbcf53809c.png

保存并退出。

3.3 修改源码

修改board\board.h中的内存大小以及起始位置如下。

#defineRA_SRAM_SIZE 256/* The SRAM size of the chip needs to be modified */#defineRA_SRAM_END (0x22000000 + RA_SRAM_SIZE * 1024)

修改board\port\gpio_cfg.h文件中的内容如下,添加外部中端的引脚信息。

/** Copyright (c) 2006-2025, RT-Thread Development Team** SPDX-License-Identifier: Apache-2.0** Change Logs:* Date Author Notes* 2025-04-07 kurisaW first version*//* Number of IRQ channels on the device */#defineRA_IRQ_MAX 32/* PIN to IRQx table */#definePIN2IRQX_TABLE(pin) \{ \ switch (pin) \ { \ case BSP_IO_PORT_01_PIN_05: \ case BSP_IO_PORT_04_PIN_00: \ case BSP_IO_PORT_08_PIN_06: \ case BSP_IO_PORT_09_PIN_02: \ case BSP_IO_PORT_11_PIN_06: \ case BSP_IO_PORT_12_PIN_14: \ return 0; \ case BSP_IO_PORT_01_PIN_01: \ case BSP_IO_PORT_01_PIN_04: \ case BSP_IO_PORT_05_PIN_08: \ case BSP_IO_PORT_09_PIN_03: \ case BSP_IO_PORT_11_PIN_07: \ case BSP_IO_PORT_12_PIN_13: \ return 1; \ case BSP_IO_PORT_01_PIN_00: \ case BSP_IO_PORT_02_PIN_13: \ case BSP_IO_PORT_05_PIN_09: \ case BSP_IO_PORT_07_PIN_12: \ case BSP_IO_PORT_09_PIN_04: \ case BSP_IO_PORT_12_PIN_12: \ return 2; \ case BSP_IO_PORT_02_PIN_08: \ case BSP_IO_PORT_02_PIN_12: \ case BSP_IO_PORT_05_PIN_10: \ case BSP_IO_PORT_07_PIN_11: \ case BSP_IO_PORT_09_PIN_13: \ case BSP_IO_PORT_12_PIN_11: \ return 3; \ case BSP_IO_PORT_02_PIN_01: \ case BSP_IO_PORT_03_PIN_00: \ case BSP_IO_PORT_04_PIN_11: \ case BSP_IO_PORT_10_PIN_10: \ case BSP_IO_PORT_12_PIN_10: \ return 4; \ case BSP_IO_PORT_03_PIN_02: \ case BSP_IO_PORT_04_PIN_10: \ case BSP_IO_PORT_09_PIN_12: \ case BSP_IO_PORT_10_PIN_09: \ case BSP_IO_PORT_12_PIN_09: \ return 5; \ case BSP_IO_PORT_03_PIN_01: \ case BSP_IO_PORT_04_PIN_09: \ case BSP_IO_PORT_05_PIN_03: \ case BSP_IO_PORT_09_PIN_11: \ case BSP_IO_PORT_10_PIN_08: \ return 6; \ case BSP_IO_PORT_04_PIN_08: \ case BSP_IO_PORT_05_PIN_04: \ case BSP_IO_PORT_06_PIN_15: \ case BSP_IO_PORT_07_PIN_06: \ case BSP_IO_PORT_09_PIN_10: \ return 7; \ case BSP_IO_PORT_03_PIN_05: \ case BSP_IO_PORT_04_PIN_15: \ case BSP_IO_PORT_05_PIN_05: \ case BSP_IO_PORT_07_PIN_07: \ case BSP_IO_PORT_09_PIN_05: \ case BSP_IO_PORT_09_PIN_15: \ return 8; \ case BSP_IO_PORT_03_PIN_04: \ case BSP_IO_PORT_04_PIN_14: \ case BSP_IO_PORT_05_PIN_06: \ case BSP_IO_PORT_09_PIN_06: \ case BSP_IO_PORT_09_PIN_14: \ case BSP_IO_PORT_11_PIN_04: \ return 9; \ case BSP_IO_PORT_05_PIN_07: \ case BSP_IO_PORT_07_PIN_09: \ case BSP_IO_PORT_09_PIN_07: \ case BSP_IO_PORT_10_PIN_11: \ case BSP_IO_PORT_11_PIN_00: \ return 10; \ case BSP_IO_PORT_07_PIN_08: \ case BSP_IO_PORT_08_PIN_00: \ case BSP_IO_PORT_08_PIN_07: \ case BSP_IO_PORT_09_PIN_08: \ case BSP_IO_PORT_10_PIN_12: \ case BSP_IO_PORT_11_PIN_02: \ return 11; \ case BSP_IO_PORT_05_PIN_15: \ case BSP_IO_PORT_07_PIN_15: \ case BSP_IO_PORT_08_PIN_01: \ case BSP_IO_PORT_10_PIN_13: \ case BSP_IO_PORT_11_PIN_01: \ return 12; \ case BSP_IO_PORT_00_PIN_15: \ case BSP_IO_PORT_05_PIN_14: \ case BSP_IO_PORT_07_PIN_14: \ case BSP_IO_PORT_10_PIN_14: \ case BSP_IO_PORT_11_PIN_03: \ return 13; \ case BSP_IO_PORT_00_PIN_10: \ case BSP_IO_PORT_00_PIN_13: \ case BSP_IO_PORT_05_PIN_12: \ case BSP_IO_PORT_07_PIN_13: \ case BSP_IO_PORT_08_PIN_04: \ case BSP_IO_PORT_10_PIN_15: \ return 14; \ case BSP_IO_PORT_00_PIN_12: \ case BSP_IO_PORT_05_PIN_11: \ case BSP_IO_PORT_08_PIN_08: \ case BSP_IO_PORT_08_PIN_13: \ case BSP_IO_PORT_08_PIN_15: \ case BSP_IO_PORT_11_PIN_05: \ return 15; \ case BSP_IO_PORT_00_PIN_11: \ case BSP_IO_PORT_01_PIN_03: \ case BSP_IO_PORT_01_PIN_06: \ case BSP_IO_PORT_06_PIN_10: \ case BSP_IO_PORT_08_PIN_14: \ case BSP_IO_PORT_10_PIN_07: \ return 16; \ case BSP_IO_PORT_01_PIN_02: \ case BSP_IO_PORT_06_PIN_11: \ case BSP_IO_PORT_07_PIN_10: \ case BSP_IO_PORT_10_PIN_06: \ case BSP_IO_PORT_13_PIN_07: \ return 17; \ case BSP_IO_PORT_04_PIN_13: \ case BSP_IO_PORT_06_PIN_12: \ case BSP_IO_PORT_08_PIN_02: \ case BSP_IO_PORT_10_PIN_05: \ case BSP_IO_PORT_13_PIN_06: \ return 18; \ case BSP_IO_PORT_01_PIN_11: \ case BSP_IO_PORT_06_PIN_13: \ case BSP_IO_PORT_07_PIN_05: \ case BSP_IO_PORT_08_PIN_03: \ case BSP_IO_PORT_10_PIN_04: \ case BSP_IO_PORT_13_PIN_05: \ return 19; \ case BSP_IO_PORT_01_PIN_10: \ case BSP_IO_PORT_02_PIN_15: \ case BSP_IO_PORT_06_PIN_14: \ case BSP_IO_PORT_08_PIN_09: \ case BSP_IO_PORT_10_PIN_03: \ case BSP_IO_PORT_13_PIN_04: \ return 20; \ case BSP_IO_PORT_02_PIN_14: \ case BSP_IO_PORT_08_PIN_10: \ case BSP_IO_PORT_10_PIN_01: \ case BSP_IO_PORT_12_PIN_07: \ case BSP_IO_PORT_13_PIN_02: \ case BSP_IO_PORT_13_PIN_03: \ return 21; \ case BSP_IO_PORT_04_PIN_07: \ case BSP_IO_PORT_06_PIN_08: \ case BSP_IO_PORT_08_PIN_11: \ case BSP_IO_PORT_10_PIN_00: \ case BSP_IO_PORT_12_PIN_06: \ case BSP_IO_PORT_13_PIN_01: \ return 22; \ case BSP_IO_PORT_01_PIN_09: \ case BSP_IO_PORT_02_PIN_11: \ case BSP_IO_PORT_06_PIN_07: \ case BSP_IO_PORT_08_PIN_12: \ case BSP_IO_PORT_12_PIN_05: \ case BSP_IO_PORT_13_PIN_00: \ return 23; \ case BSP_IO_PORT_01_PIN_08: \ case BSP_IO_PORT_02_PIN_10: \ case BSP_IO_PORT_05_PIN_00: \ case BSP_IO_PORT_06_PIN_06: \ case BSP_IO_PORT_12_PIN_04: \ return 24; \ case BSP_IO_PORT_02_PIN_07: \ case BSP_IO_PORT_02_PIN_09: \ case BSP_IO_PORT_05_PIN_01: \ case BSP_IO_PORT_06_PIN_05: \ case BSP_IO_PORT_12_PIN_03: \ return 25; \ case BSP_IO_PORT_05_PIN_02: \ case BSP_IO_PORT_06_PIN_04: \ case BSP_IO_PORT_07_PIN_04: \ case BSP_IO_PORT_12_PIN_02: \ return 26; \ case BSP_IO_PORT_00_PIN_14: \ case BSP_IO_PORT_01_PIN_12: \ case BSP_IO_PORT_06_PIN_03: \ case BSP_IO_PORT_12_PIN_01: \ return 27; \ case BSP_IO_PORT_00_PIN_07: \ case BSP_IO_PORT_01_PIN_13: \ case BSP_IO_PORT_06_PIN_02: \ case BSP_IO_PORT_12_PIN_00: \ return 28; \ case BSP_IO_PORT_00_PIN_03: \ case BSP_IO_PORT_06_PIN_01: \ case BSP_IO_PORT_06_PIN_09: \ case BSP_IO_PORT_12_PIN_08: \ return 29; \ case BSP_IO_PORT_04_PIN_05: \ case BSP_IO_PORT_06_PIN_00: \ case BSP_IO_PORT_08_PIN_05: \ case BSP_IO_PORT_12_PIN_15: \ return 30; \ case BSP_IO_PORT_01_PIN_07: \ case BSP_IO_PORT_04_PIN_06: \ case BSP_IO_PORT_05_PIN_13: \ case BSP_IO_PORT_10_PIN_02: \ return 31; \ default : \ return -1; \ } \}

修改ra\fsp\src\bsp\cmsis\Device\RENESAS\Source\startup.c中的Reset_Handler函数如下

voidReset_Handler(void){ /* Initialize system using BSP. */ SystemInit(); /* Call user application. */#ifdefined(__GNUC__) externintentry(void); entry();#elifdefined(__ICCARM__) externvoid__low_level_init(void); __low_level_init();#else /* Jump to main. */ main();#endif while(1) { /* Infinite Loop. */ }}

3.4 链接RT-Thread源码

RT-Thread源代码使用Scons工具用于管理代码编译,不过使用e2studio进行管理后,需要开发者自行将RT-Thread工程需要使用到的代码添加e2studio的工程代码管理中。使用新增文件夹的链接功能,添加RT-Thread源码仓库中的相关文件夹。使用到的文件夹如下:

components

include

libcpu

src

其中src文件夹与e2studio工程中的src文件夹重名,在链接该文件夹时,设置不同的名称即可,具体页面操作如下。

95107868-2e7b-11f1-ab55-92fbcf53809c.png

在工程属性的Path and Symbolsinclude菜单中添加RT-Thread源码的路径。Assembly选项卡中添加如下。

951f3fd8-2e7b-11f1-ab55-92fbcf53809c.png

GNU C选项卡中添加以下路径。

952fce34-2e7b-11f1-ab55-92fbcf53809c.png

RT-Thread源码适配很多场景,其中有很多代码是不使用的,通过Paths and SymbolsSource location中添加源码的管理。在其中添加上述提到的源码文件夹路径。

95448d1a-2e7b-11f1-ab55-92fbcf53809c.png

其中libcpu中的排除文件如图。

955067e8-2e7b-11f1-ab55-92fbcf53809c.png

components目录中的finshlibc中文件排除情况如下

955f5168-2e7b-11f1-ab55-92fbcf53809c.png

components/drivers中的文件包含情况如下

956a25ac-2e7b-11f1-ab55-92fbcf53809c.png

3.4.1 参考RT-Thread示例工程确定源文件

RT-Thread中有大量的文件,如何确定需要排除哪些文件,可以通过参考官方提供的RT-Thread Studio中的示例工程,参考其中的配置信息

9574de02-2e7b-11f1-ab55-92fbcf53809c.png

3.4.2 利用scons生成CMake文件确定需要使用的源文件

也可以通过修改Scons编译需要用到的文件,利用scons --target=cmake指令,生成CMakeLists.txt文件,获取构建的文本信息。从官方的示例程序中复制其中的SConstructSConscript中的内容,根据RT-Thread源码的存放位置,修改SConstruct中的RTT_ROOT路径信息。

ifos.path.exists('rt-thread'): RTT_ROOT = os.path.normpath(os.getcwd() +'/rt-thread')else: RTT_ROOT = os.path.normpath(os.getcwd() +'../../../rt-thread')print(os.path.normpath(os.getcwd() +'../../../rt_thread'))

运行scons --target=cmake指令后,通过查看输出的CMakeLists.txt,其中给出不同模块中需要添加工程中文件信息,据此,可以修改e2studio中的源码exclude项目。

SET(RT_CPU_SOURCES ../../rt-thread/libcpu/arm/common/atomic_arm.c ../../rt-thread/libcpu/arm/common/div0.c ../../rt-thread/libcpu/arm/common/showmem.c ../../rt-thread/libcpu/arm/cortex-m85/context_gcc.S ../../rt-thread/libcpu/arm/cortex-m85/cpuport.c)SET(RT_DEVICEDRIVERS_SOURCES ../../rt-thread/components/drivers/core/device.c ../../rt-thread/components/drivers/ipc/completion_comm.c ../../rt-thread/components/drivers/ipc/completion_up.c ../../rt-thread/components/drivers/ipc/condvar.c ../../rt-thread/components/drivers/ipc/dataqueue.c ../../rt-thread/components/drivers/ipc/pipe.c ../../rt-thread/components/drivers/ipc/ringblk_buf.c ../../rt-thread/components/drivers/ipc/ringbuffer.c ../../rt-thread/components/drivers/ipc/waitqueue.c ../../rt-thread/components/drivers/ipc/workqueue.c ../../rt-thread/components/drivers/pin/dev_pin.c ../../rt-thread/components/drivers/serial/dev_serial_v2.c)SET(RT_DRIVERS_SOURCES libraries/HAL_Drivers/drivers/drv_gpio.c libraries/HAL_Drivers/drivers/drv_usart_v2.c libraries/HAL_Drivers/drv_common.c)SET(RT_FINSH_SOURCES ../../rt-thread/components/finsh/shell.c ../../rt-thread/components/finsh/msh.c ../../rt-thread/components/finsh/msh_parse.c ../../rt-thread/components/finsh/cmd.c)SET(RT_KERNEL_SOURCES ../../rt-thread/src/clock.c ../../rt-thread/src/components.c ../../rt-thread/src/cpu_up.c ../../rt-thread/src/defunct.c ../../rt-thread/src/idle.c ../../rt-thread/src/ipc.c ../../rt-thread/src/irq.c ../../rt-thread/src/kservice.c ../../rt-thread/src/mem.c ../../rt-thread/src/mempool.c ../../rt-thread/src/object.c ../../rt-thread/src/scheduler_comm.c ../../rt-thread/src/scheduler_up.c ../../rt-thread/src/thread.c ../../rt-thread/src/timer.c)SET(RT_LIBC_SOURCES ../../rt-thread/components/libc/compilers/common/cctype.c ../../rt-thread/components/libc/compilers/common/cstdlib.c ../../rt-thread/components/libc/compilers/common/cstring.c ../../rt-thread/components/libc/compilers/common/ctime.c ../../rt-thread/components/libc/compilers/common/cunistd.c ../../rt-thread/components/libc/compilers/common/cwchar.c ../../rt-thread/components/libc/compilers/newlib/syscalls.c ../../rt-thread/src/klibc/kerrno.c ../../rt-thread/src/klibc/kstdio.c ../../rt-thread/src/klibc/kstring.c ../../rt-thread/src/klibc/rt_vsnprintf_tiny.c ../../rt-thread/src/klibc/rt_vsscanf.c)

e2studio工程的src文件夹中的hal_warmstart.c中的代码和RTThread提供的适配代码冲突,在源码控制中将其排除出构建即可。

3.5 修改编译器选项和链接脚本以及添加示例源码

在工程的属性的Settings菜单中修改编译器的选项如下,解决编译时汇编指令支持的问题。

98790006-2e7b-11f1-ab55-92fbcf53809c.png

修改编译器的优化参数,解决RT-Thread串口输出乱码的问题。

98840028-2e7b-11f1-ab55-92fbcf53809c.png

e2studio工程中script文件夹中的fsp.ld链接文件中引用两个生成的链接脚本,为Debug文件夹中的fsp_gen.ldmemory_gen.ld文件,复制其中的内容到fsp.ld文件中。

文件中定位到MCU Vector Table位置,添加以下内容

/* MCU vector table */ __flash_vectors988bb5c0-2e7b-11f1-ab55-92fbcf53809c.svgBase = .; _VECTORS = .;        KEEP(*(.fixed_vectors))        KEEP(*(.application_vectors))        __flash_vectors$$Limit = .;        /* section information for finsh shell */        . = ALIGN(4);        __fsymtab_start = .;        KEEP(*(FSymTab))        __fsymtab_end = .;        . = ALIGN(4);        __vsymtab_start = .;        KEEP(*(VSymTab))        __vsymtab_end = .;        /* section information for initial. */        . = ALIGN(4);        __rt_init_start = .;        KEEP(*(SORT(.rti_fn*)))        __rt_init_end = .;        . = ALIGN(4);        KEEP(*(FalPartTable))    }> FLASH

另外定位到SDRAM区域具体可以参考工程中代码查看,添加以下内容

.ram.flat_nsc : { __sau_ddsc_RAM_NSC = .; }> RAM /* This symbol represents the end of user allocated RAM. The RAM after this symbol can be used at run time for things such as ThreadX memory pool allocations. */ __RAM_segment_used_end__ = ALIGN(__sau_ddsc_RAM_NSC ,4);

hal_entry中添加以下代码,实现控制EK-RA8P1上LED灯并输出log的功能。

#include#include"hal_data.h"#include#include#defineDBG_TAG "led"#defineDBG_LVL DBG_LOG#include/* 配置 LED 灯引脚 */#defineLED_PIN_R BSP_IO_PORT_00_PIN_12#defineLED_PIN_B BSP_IO_PORT_00_PIN_13#defineLED_PIN_G BSP_IO_PORT_06_PIN_13/* 定义 LED 亮灭电平 */#defineLED_ON (0)#defineLED_OFF (1)/* 定义 8 组 LED 闪灯表,其顺序为 R B G */staticconstrt_uint8_t_blink_tab[][3] ={ {LED_OFF, LED_OFF, LED_OFF}, {LED_ON, LED_OFF, LED_OFF}, {LED_OFF, LED_ON, LED_OFF}, {LED_OFF, LED_OFF, LED_ON}, {LED_ON, LED_OFF, LED_ON}, {LED_ON, LED_ON, LED_OFF}, {LED_OFF, LED_ON, LED_ON}, {LED_ON, LED_ON, LED_ON},};voidhal_entry(void){ rt_kprintf("\nHello RT-Thread!\n"); rt_kprintf("==================================================\n"); rt_kprintf("This example project is an RGB flicker routine!\n"); rt_kprintf("==================================================\n"); unsignedintcount =0; unsignedintgroup_num =sizeof(_blink_tab)/sizeof(_blink_tab[0]); unsignedintgroup_current; /* 设置 RGB 灯引脚为输出模式 */ rt_pin_mode(LED_PIN_R, PIN_MODE_OUTPUT); rt_pin_mode(LED_PIN_G, PIN_MODE_OUTPUT); rt_pin_mode(LED_PIN_B, PIN_MODE_OUTPUT); rt_pin_write(LED_PIN_R, LED_OFF); rt_pin_write(LED_PIN_G, LED_OFF); rt_pin_write(LED_PIN_B, LED_OFF); do { /* 获得组编号 */ group_current = count % group_num; /* 控制 RGB 灯 */ rt_pin_write(LED_PIN_R, _blink_tab[group_current][0]); rt_pin_write(LED_PIN_B, _blink_tab[group_current][1]); rt_pin_write(LED_PIN_G, _blink_tab[group_current][2]); /* 输出 LOG 信息 */ LOG_D("group: %d | red led [%-3.3s] | | blue led [%-3.3s] | | green led [%-3.3s]", group_current, _blink_tab[group_current][0] == LED_ON ?"ON":"OFF", _blink_tab[group_current][1] == LED_ON ?"ON":"OFF", _blink_tab[group_current][2] == LED_ON ?"ON":"OFF"); count++; /* 延时一段时间 */ rt_thread_mdelay(500); }while(count >0);}

【Titan-RA8P1】e2studio中使用pyocd调试(https://club.rt-thread.org/ask/article/ee532d8d659ae45b.html)

保存并编译工程,烧录到开发板运行,使用串口工具可以看到如下的log输出。

98970f1a-2e7b-11f1-ab55-92fbcf53809c.png

示例工程如下,需要配合RT-Thread仓库源码使用。

Titan_RA8P1_rtthread.zip

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

    关注

    463

    文章

    54304

    浏览量

    468405
  • 硬件
    +关注

    关注

    12

    文章

    3613

    浏览量

    69132
  • RT-Thread
    +关注

    关注

    32

    文章

    1632

    浏览量

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

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    从安装到使用,RT-Thread Nano最全教程看完不信你还不会使用

    RT-Thread Nano发布以来,小编收到不少开发者询问RT-Thread Nano的配套教程实例,幸得RT-Thread开发者燕十三
    的头像 发表于 09-26 06:39 7.2w次阅读
    从安装到使用,<b class='flag-5'>RT-Thread</b> Nano最全教程看完不信你还不会使用

    手把手教你基于RT-Thread Studio使用STM32单片机的PWM外设

    目前我使用的是STM32L475系列单片机,是ali当时在PDD 50块钱卖的一个开发板,其他STM32单片机参考即可,这里会手把手教大家基于RTT Studio 来使用PWM。
    的头像 发表于 09-28 15:12 7489次阅读
    <b class='flag-5'>手把手</b>教你基于<b class='flag-5'>RT-Thread</b> <b class='flag-5'>Studio</b>使用STM32单片机的PWM外设

    RT-Thread Nano硬核移植指南:手把手实现VGLite图形驱动适配 | 技术集结

    VGLite是NXP提供的轻量级2D图形API,本文将手把手带你实现VGLite图形驱动适配RT-Thread。文章分为上、下两篇,将手把手
    的头像 发表于 07-17 14:40 3567次阅读
    <b class='flag-5'>RT-Thread</b> Nano硬核移植指南:<b class='flag-5'>手把手</b>实现VGLite图形驱动<b class='flag-5'>适配</b> | <b class='flag-5'>技术</b><b class='flag-5'>集结</b>

    手把手教你实战RT-Thread Nano,不信都这样了你还不会

    手把手教你实战RT-Thread Nano,不信都这样了你还不会
    发表于 11-23 10:30

    手把手教你制作RT-Thread Studio开发支持

    CH32V103R-EVT的BSP提交已经合并了,开始制作对应的RT-Thread Studio开发支持包直接导入BSP工程发现import支持
    发表于 04-08 09:59

    带你玩转RT-Thread开发教程汇总(共13篇)

    本教程带你手把手带你学会玩转RT-Thread,从RT-Thread的内核到外设、传感器、组件包,应用开发,让对于刚刚接触使用RTT的你不再胆怯,开心玩耍
    发表于 05-11 14:10

    如何使用RT-Thread Studio创建支持HPM6750开发板的RT-Thread项目

    StudioRT-Thread Studio安装程序下载页面RT-Thread Studio安装程序下载完成后,运行安装程序,一路下一步即可完成R
    发表于 06-08 11:22

    请问是RT-Thread Studio工具支持Windows11系统吗?

    环境和步骤说明:1、公司新配置的电脑默认安装的是windows11系统2、要进行rt-thread支持的一款芯片的开发工作3、官网下载最新的RT-T
    发表于 12-14 17:15

    RT-Thread Studio 主要亮点功能

    RT-Thread Studio V1.1.0 快速上手体验 RT-Thread Studio 主要包括工程创建和管理,代码编辑,SDK管理器,RT
    的头像 发表于 06-19 11:45 7132次阅读

    RT-Thread Studio配置u8g2点亮OLED SSD1306

    RT-Thread的大佬竟然把它适配RT-Thread平台上了,而且通过RT-Thread Studio添加软件包再稍微操作一下就可以轻松
    的头像 发表于 08-03 15:47 8527次阅读
    <b class='flag-5'>RT-Thread</b> <b class='flag-5'>Studio</b>配置u8g<b class='flag-5'>2</b>点亮OLED SSD1306

    RT-Thread Studio驱动SD卡

    RT-Thread Studio驱动SD卡前言一、创建基本工程1、创建Bootloader2、创建项目工程二、配置RT-Thread Settings三、代码分析1.引入库
    发表于 12-27 19:13 20次下载
    <b class='flag-5'>RT-Thread</b> <b class='flag-5'>Studio</b>驱动SD卡

    RT-Thread已经全面支持极海APM32F1系列MCU

    近日,RT-Thread 和其高级会员合作伙伴极海半导体宣布:正式完成APM32F4系列MCU的RT-Thread 物联网操作系统适配RT-Thread
    发表于 08-30 09:45 1760次阅读

    基于RT-Thread Studio学习

    前期准备:从官网下载 RT-Thread Studio,弄个账号登陆,开启rt-thread学习之旅。
    的头像 发表于 05-15 11:00 6578次阅读
    基于<b class='flag-5'>RT-Thread</b> <b class='flag-5'>Studio</b>学习

    手把手教你在RT-THREAD bsp上运行pikascript脚本点亮小灯

    /lt6210925/article/details/130694587 最近有一些结构上的调整,这篇文章大概介绍一下如何使用。以及开发过程中需要注意的问题。 这篇文章几乎适配所有的RT-THREAD
    的头像 发表于 05-25 07:45 2167次阅读
    <b class='flag-5'>手把手</b>教你在<b class='flag-5'>RT-THREAD</b> bsp上运行pikascript脚本点亮小灯

    试用RT-Thread Studio(VSCode)

    想尝试RT-Thread studio (VSCode),先下载安装VSCode,再搜索RT-Thread
    的头像 发表于 10-12 10:58 2193次阅读
    试用<b class='flag-5'>RT-Thread</b> <b class='flag-5'>Studio</b>(VSCode)