很荣幸收到瑞萨的RA2E1超低功耗开发板,现在开始写第一篇相关的试用报告,看到别人已经用RA2E1的串口实现了printf打印功能,我就不重复了,下面我就使用Jlink自带的RTT来实现printf打印功能,这个打印比串口打印更快更高新,不占用程序资源,可以放在中断服务函数中打印log日子而不影响性能。
*附件:RTT_printf.zip
下面开始讲干货,进入主题
1。打开rasc.exe程序
data:image/s3,"s3://crabby-images/1de52/1de52c481acdaeae8ea02c176a3b8ad5aa7366b6" alt="image.png"
我给工程取名为RTT_printf
data:image/s3,"s3://crabby-images/5835a/5835af52d93c8327cb4081d49218d30e13154c00" alt="image.png"
点击next
data:image/s3,"s3://crabby-images/26c86/26c860d65c79296620781ba124232a632f8a7483" alt="image.png"
按照我上面的选项进行配置即可,48pin,点击next
data:image/s3,"s3://crabby-images/62bf0/62bf0e4d4acc214c6bec5aac2d58f90cfe8ef033" alt="image.png"
data:image/s3,"s3://crabby-images/ff25e/ff25e77134c0f13397ee53f186925fa3cd8961a9" alt="image.png"
点击finish,完成
data:image/s3,"s3://crabby-images/93c6c/93c6cdd4050cd98546f6f97436b48d0db88e7613" alt="image.png"
我们先关闭rasc.exe。在文件家里打开keil工程
data:image/s3,"s3://crabby-images/d0372/d03724f1abe139b9ac272d99c0466879d6a8094b" alt="image.png"
选择MCU型号
data:image/s3,"s3://crabby-images/07de7/07de7a2193b5730aec165e52a29669cf589f04c0" alt="image.png"
选择AC6编译器
data:image/s3,"s3://crabby-images/310f6/310f6264f20eba531a47eb1d326bcbd8aa379445" alt="image.png"
选择jlink 下载器
data:image/s3,"s3://crabby-images/d0c4c/d0c4c9e4a94db02e0b42b966b3444e3837dcf578" alt="image.png"
模式一定要选SW,不能选JTAG,否则无法识别
data:image/s3,"s3://crabby-images/43cc8/43cc880492c048c1a965c76f708b972abfe05895" alt="image.png"
最后的配置
data:image/s3,"s3://crabby-images/f62c5/f62c538483556d39d275ea132e6af8bb9b31dd4e" alt="image.png"
然后先把keil工程编译一遍
data:image/s3,"s3://crabby-images/8d247/8d2475a073f144c726b609f74ec24ec33a2cc015" alt="image.png"
没有错误
data:image/s3,"s3://crabby-images/5996d/5996d18401248f0df8fadacb28d5aeea96cb1b92" alt="image.png"
将Jlink的RTT文件夹复制到KEIL项目文件夹里面
data:image/s3,"s3://crabby-images/b2aee/b2aee6109b44adc8d8b53453a6327a568dcddf13" alt="image.png"
我的是经过封装了一下宏操作的
data:image/s3,"s3://crabby-images/51b01/51b0115e65f793a0f6014928114d69e165f520d7" alt="image.png"
在keil里面添加源文件c
data:image/s3,"s3://crabby-images/511ca/511ca32d5798af8b669a5649580ea44e1f3437a8" alt="image.png"
在添加头文件目录
data:image/s3,"s3://crabby-images/efad3/efad390ead7f93f134a286e996ce146484ea87e9" alt="image.png"
如下图
data:image/s3,"s3://crabby-images/5a046/5a046fb93f2a34d9905d64f424af58d595210541" alt="image.png"
最后一步在hal_entry.c包含RTT.h文件
data:image/s3,"s3://crabby-images/1b6d7/1b6d7596dd191b65dbf74fdfd79d2e96134942dd" alt="image.png"
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "SEGGER_RTT.h"
#define BIT_SHIFT_8 (8u)
#define SIZE_64 (64u)
#define LVL_ERR (1u) /* error conditions */
#define RESET_VALUE (0x00)
#define SEGGER_INDEX (0)
#define print(fn_, ...) SEGGER_RTT_printf(SEGGER_INDEX,(fn_), ## VA_ARGS );
#define printf(fn_, ...) SEGGER_RTT_printf(SEGGER_INDEX,(fn_), ## VA_ARGS );
#define LOG(format, args...) SEGGER_RTT_printf(SEGGER_INDEX, "[%s:%d] "format, FILE , LINE , ##args)
#define APP_ERR_PRINT(fn_, ...) if(LVL_ERR)
SEGGER_RTT_printf (SEGGER_INDEX, "[ERR] In Function: %s(), %s", FUNCTION ,(fn_),## VA_ARGS );
#define APP_ERR_TRAP(err) if(err) {
SEGGER_RTT_printf(SEGGER_INDEX, "\r\nReturned Error Code: 0x%x \r\n", err);
__asm("BKPT #0\n");} /* trap upon the error */
#define APP_READ(read_data) SEGGER_RTT_Read(SEGGER_INDEX, read_data, sizeof(read_data));
#define APP_CHECK_DATA SEGGER_RTT_HasKey()
#endif /* COMMON_UTILS_H_ */
data:image/s3,"s3://crabby-images/d5c67/d5c67b1bbc2f042701d4243cf0bea76eb3545bc9" alt="image.png"
打开data:image/s3,"s3://crabby-images/d5f40/d5f40b6b5dbf5217c9b58e3f157de8394199f402" alt="image.png"
这个是Jlink RTT的上位机
data:image/s3,"s3://crabby-images/96825/968254db3dae0fc03bbde98b98fbb1a4c1ce2cf6" alt="image.png"
下面的信息表示连接上了,但是内容是空的,是因为我还没有烧录程序。接下来,我们直接用jlink烧录到板子上。
看看我的程序
data:image/s3,"s3://crabby-images/0e1c4/0e1c4cf4d99a2b3cc0b9712c1ff2f4fcbb6467e5" alt="image.png"
如果正确,会打印出上面3条日志
data:image/s3,"s3://crabby-images/23b63/23b63545824287ae00c84b0cc296f3a67d558148" alt="image.png"
烧录完成
data:image/s3,"s3://crabby-images/0e418/0e4188c9e1499c391c3dd559361720c5216750fb" alt="image.png"
结果正确,至此已经完成了Jlink的printf打印功能。
这个比MCU的硬件串口耗时低,可以直接放入中断不影响性能。us级别,硬件串口轻则几百毫秒,重则计秒绝对不能放入中断,这是Jlink RTT的优势之处。
以下是我的代码压缩包,使用KEIL可以打开编译
*附件:RTT_printf.zip