开启攻城狮的成长之旅!这是我参与的由 CSDN博客专家 架构师李肯(http://yyds.recan-li.cn)和 瑞萨MCU (瑞萨电子 (Renesas Electronics Corporation) ) 联合发起的「 致敬未来的攻城狮计划 」的第 7 天,点击查看活动计划详情 (https://bbs.csdn.net/topics/613916237)!
对于从事电子方面开发的技术工程师来说,跑马灯大概是最简单的例子,就类似于每种编程语言中程序员接触的第一个程序 Hello World 一样,所以这个例子就从跑马灯开始。让它定时地对 LED 进行更新(亮或灭)。
用自家的IDE会更容易上手一些。所以我选择了e2studio。
新建一个瑞萨RA的项目
如果没有RA,则需要在“帮助”菜单下安装设备。
有些FSP的board列表是没有RA2E1板子的。需要导入合适的板级支持包BSP。
BSP下载地址:CPK-RA2L1 - RA2L1 MCU 群组中国本地评估板 | Renesas
点击“帮助”,在二级菜单中选择“关于e2studio”,在新窗口中选择“安装细节”,按图中顺序打开目录。
然后将BSP压缩包内容解压到目录中,一级目录有重名文件夹“internal”,如果是第一次安装,win环境下不会报重复文件的提示,如果有,覆盖即可。
回到上一步中到“新建项目”,项目名称随便写一个,然后会到这个界面。
如果BSP安装成功,则在对应版本的FSP下,board菜单会有CPK-RA2E1开头的选项。
可以选择CPK-RA2E1开头的选项,也可以选择第一个选项“Any Device”。
以下三段是瑞萨产品手册的指示:
不要修改main.c,要修改hal_entry.c
获取所有自动生成的文件之后,接下来查看创建的内容。 IDE 左侧的“Project Explorer
”(项目资源管理器)列出了当前 包含的所有内容。ra_gen
文件夹保存通道号等配置集。src 目录包 含一个名为 hal_entry.c
的文件。这是稍后要编辑的文件。请注 意,尽管在 ra_gen 文件夹中有一个名为 main.c
的文件,但用户 代码必须转到 hal_entry.c
中。否则,如果您在 FSP 配置器中进 行修改并重新创建项目内容,在 main.c 中的更改会丢失,因为每次单击“Generate Project Content
”(生成项目内容)时,都将覆盖该文件。
该项目还包含几个名称中带有“ra
”或“fsp
”的目录,其中 包含 FSP
的源文件、包含文件和配置文件。通常的规则是,不得 修改这些文件夹(和子文件夹)的内容。其中包含由配置器生成 的文件,在此所做的任何更改都将在下次生成或刷新项目内容时 丢失。用户可编辑的源文件是直接位于 \src
文件夹或您添加的任 何其他文件夹为根目录中的文件。
在common_data.c中, 写有 I/O 端口驱动程序实例 g_ioport
const ioport_instance_t g_ioport = { .p_api = &g_ioport_on_ioport, .p_ctrl = &g_ioport_ctrl, .p_cfg = &g_bsp_pin_cfg, };
g_ioport_on_ioport
是一个结构体,用于声明端口可能执行的操作,将分配给 g_ioport
实例 的 API 指针。将鼠标悬停在该结构体上,可以轻松查看其中的内容,此结构体显示了其成员之一 (.pinWrite
) 是指向引脚写入函数的指针。
根据官方文档的指示,要点量led灯,需要这行代码:
g_ioport.p_api->pinwrite (&g_ioport_ctrl, pin, BSP_IO_LEVEL_LOW);
其中,g_ioport_ctrl是一个结构体。
/** IOPORT private control block. DO NOT MODIFY. Initialization occurs when R_IOPORT_Open() is called. */
/** IOPORT 私有控制块。不要修改。初始化发生在调用 R_IOPORT_Open() 时。 */
typedef struct st_ioport_instance_ctrl
{
uint32_t open;
void const * p_context;
} ioport_instance_ctrl_t;
pin显然不是官方提供的对象
接下来我们需要自行修改
BSP_IO_LEVEL_LOW是一个宏,表示低电平
按Ctrl+Shift+T
,可以搜索全局变量。
/** Levels that can be set and read for individual pins */
/** 可以为各个引脚设置和读取的电平 */
typedef enum e_bsp_io_level
{
BSP_IO_LEVEL_LOW = 0, ///< Low
BSP_IO_LEVEL_HIGH ///< High
} bsp_io_level_t;
对于BSP_IO_LEVEL_LOW
和BSP_IO_LEVEL_HIGH
,使用了枚举来进行存储,因此第四行中的BSP_IO_LEVEL_HIGH
不需要手动赋值,默认升序。
接下来我们可以查阅官方的原理图,获取灯泡对应的端口,下载链接:
官方:https://www.renesas.cn/cn/zh/document/sch/1596866?r=1596841
CSDN:https://download.csdn.net/download/m0_49303993/87624323
官方文档给的样例是使用FSP。
创建类型为 bsp_leds_t
的结构体(在 board_leds.h
中声明)并为其分配在 board_leds.c
中定义的全局 BSP 结构体 g_bsp_leds
即可解决问题。这两个文件均位于项目的 ra\board\ra2e1_cpk
文件夹内。因此,以下两行代码足以获取有关评估板上 LED 的信息:
extern bsp_leds_t g_bsp_leds;
bsp_leds_t Leds = g_bsp_leds;
现在,可以使用 LED 结构体来访问电路板上的所有 LED,并使用以下语句点亮红色 LED(将端口设置为 低电平将点亮 LED,将端口设置为高电平则将熄灭 LED):
此语句后需要有第二条语句,用于将其引脚设置为高电平以熄灭 用户 LED。 最后,需要提供一段延时以使 LED 以用户友好的方式切换。为此,可以再次调用 BSP API:
R_BSP_SoftwareDelay(1, BSP_DELAY_UNITS_SECONDS);
R_BSP_SoftwareDelay
函数的第一个参数是要延迟的单位数,而第二个参数是指定的基本单位,在 本例中为秒。其他选项包括毫秒和微秒。
最后,由于我们想无限期地运行程序,因此必须围绕代码创建一个 while(1) 循环。
根据官方文档的指示,我们要将代码输入到 hal_entry.c
文件中的函数签名之后,替换 /* TODO: add your own code here */
行。对于由项目配置器和 FSP 配置器插入的其他代码,请保持不变。单片机需要借助这些代码来正常运行。
但我默认生成的项目没有这一行。
可以将以下代码复制到hal_entry.c
的hal_entry()
函数体的第一行中。
extern bsp_leds_t g_bsp_leds;
bsp_leds_t Leds = g_bsp_leds;
while (1)
{
g_ioport.p_api->pinWrite (&g_ioport_ctrl, Leds.p_leds[BSP_LED_LED1], BSP_IO_LEVEL_LOW);
R_BSP_SoftwareDelay (1, BSP_DELAY_UNITS_SECONDS);
g_ioport.p_api->pinWrite (&g_ioport_ctrl, Leds.p_leds[BSP_LED_LED1], BSP_IO_LEVEL_HIGH);
R_BSP_SoftwareDelay (1, BSP_DELAY_UNITS_SECONDS);
}
复制到选中的位置中
插入开发板,依次点击“构建”、“调试”、“继续”、“继续”。
然后就看到开发板红灯交替闪烁