0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RA2L1移植SEGGER RTT日志打印功能

冬至子 ? 來源:dreamcmi ? 作者:dreamcmi ? 2023-10-12 11:30 ? 次閱讀

0.前言

因?yàn)镽A2L1開發(fā)板板載了JLINK-OB,那么我們完全可以通過SWD調(diào)試口去打印日志,從而不去用物理串口,這樣不僅省了硬件串口資源占用,而且可以很快速的打印log,對系統(tǒng)整體運(yùn)行效率也得到了一定程度的提高。接下來就來移植一下SEGGER的RTT日志打印功能。

1.準(zhǔn)備

一個由RTT Studio新建好的BSP工程

SEGGER RTT源碼(在jlink上位機(jī)按照目錄里,例如C:Program FilesSEGGERJLinkSamplesRTT)

2.移植

首先把四個基礎(chǔ)文件加到工程目錄(推薦單獨(dú)建一個文件夾放源碼實(shí)現(xiàn)模塊化,這里僅做演示沒有新建)

SEGGER_RTT.c SEGGER_RTT.h SEGGER_RTT_printf.c SEGGER_RTT_Conf.h

然后新建一個注冊文件,這里命名為segger_rtt_register.c

刷新ide,正常來說應(yīng)該和下圖文件一樣

1.jpg

接下來修改文件

segger_rtt_register.c加入以下代碼

/*

  • Copyright (c) 2006-2021, RT-Thread Development Team
  • SPDX-License-Identifier: Apache-2.0
  • Change Logs:
  • Date Author Notes
  • 2023-02-24 dreamcmi the first version
    */
    #include "SEGGER_RTT.h"
    #include "rtthread.h"
    void rt_hw_console_output(const char *str)
    {
    SEGGER_RTT_Write(0, str, rt_strlen(str));
    }
    SEGGER_RTT.h

將開頭的include改為#include "SEGGER_RTT_Conf.h"

SEGGER_RTT_Conf.h

(此文件可以暫時不修改)

主要看以下兩個地方

#ifndef BUFFER_SIZE_UP
#define BUFFER_SIZE_UP (512) // Size of the buffer for terminal output of target, up to host (Default: 1k)
#endif
#ifndef BUFFER_SIZE_DOWN
#define BUFFER_SIZE_DOWN (16) // Size of the buffer for terminal input to target from host (Usually keyboard input) (Default: 16)
#endif

這里的大小根據(jù)log頻率和長度進(jìn)行修改,默認(rèn)是1024和16

drv_common.c

這個文件開頭加入#include "SEGGER_RTT.h"

在最下面rt_hw_board_init函數(shù)增加rtt初始化函數(shù),并注釋掉rt_hw_usart_init();(原因后面說)

RT_WEAK void rt_hw_board_init()
{
rt_hw_systick_init();
SEGGER_RTT_Init();
/* Heap initialization */
#if defined(RT_USING_HEAP)
rt_system_heap_init((void *)HEAP_BEGIN, (void )HEAP_END);
#endif
/
Pin driver initialization is open by default /
#ifdef RT_USING_PIN
rt_hw_pin_init();
#endif
/
USART driver initialization is open by default /
#ifdef RT_USING_SERIAL
// rt_hw_usart_init();
#endif
/
Set the shell console output device /
#if defined(RT_USING_CONSOLE) && defined(RT_USING_DEVICE)
rt_console_set_device(RT_CONSOLE_DEVICE_NAME);
#endif
/
Board underlying hardware initialization */
#ifdef RT_USING_COMPONENTS_INIT
rt_components_board_init();
#endif
}
rtconfig.h

這里面只需要改一個地方, 將原來的uart9改成空即可

#define RT_CONSOLE_DEVICE_NAME ""
hal_entry.c

這里只是編寫演示代碼??!

void hal_entry(void)
{
while (1)
{
rt_kprintf("hal_entry 1n");
rt_thread_mdelay(1000);
rt_kprintf("hal_entry 2n");
rt_thread_mdelay(1000);
}
}

修改完成后直接編譯下載,同時打開J-LINK RTT Viewer,通過下圖配置好直接點(diǎn)擊ok,軟件會自動連接。

1.jpg

正常來說會在黑框中打印LOG

1.jpg

3.答疑

上面的文件修改可能有一些人會問為什么不去注冊一個rt_device,因?yàn)槟菢訉賹?shí)麻煩了(其實(shí)是懶)。

我們在修改rtconfig.h里的RT_CONSOLE_DEVICE_NAME為空字符串時,已經(jīng)把打印的函數(shù)對接到了void rt_hw_console_output(const char *str), 所以我們只需要對接這一個函數(shù)就可以完成printf重定向,至于為什么改一個空字串就可以不用device,看一下rt_kprintf的實(shí)現(xiàn)原理大概你就懂了,就是把_console_device的值識別成了NULL。

4.總結(jié)

使用segger rtt打印速度快還不占用io,快去試試吧。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • UART接口
    +關(guān)注

    關(guān)注

    0

    文章

    124

    瀏覽量

    15199
  • J-Link
    +關(guān)注

    關(guān)注

    0

    文章

    83

    瀏覽量

    22056
  • SEGGER
    +關(guān)注

    關(guān)注

    0

    文章

    36

    瀏覽量

    14065
  • RTThread
    +關(guān)注

    關(guān)注

    7

    文章

    132

    瀏覽量

    40684
  • swd接口
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    2762
收藏 人收藏

    評論

    相關(guān)推薦

    移植一下SEGGERRTT日志打印功能

      0. 前言  因?yàn)?b class='flag-5'>RA2L1開發(fā)板板載了JLINK-OB,那么我們完全可以通過SWD調(diào)試口去打印日志,從而不去用物理串口,這樣不僅省了硬件串口資源占用,而且可以很快速的打印log,
    發(fā)表于 03-06 10:38

    RT-Thread與Renesas RA2L1實(shí)現(xiàn)1.8寸TFT屏幕顯示的步驟

    使用過,本次借著RTT和本次參與RT-Thread與Renesas RA2L1的學(xué)習(xí)大挑戰(zhàn)更深入的去學(xué)習(xí)RTT和Renesas?! ∮?jì)劃使用RA2L1實(shí)現(xiàn)
    發(fā)表于 04-03 16:45

    華大移植SEGGER_RTT 打印

    華大移植SEGGER_RTT 打印一、目的1.在單片機(jī)開發(fā)中,串口是我們最好的‘伙伴’,沒有什么BUG是串口打印無法解決的。如果有就debu
    發(fā)表于 11-23 18:07 ?14次下載
    華大<b class='flag-5'>移植</b><b class='flag-5'>SEGGER_RTT</b> <b class='flag-5'>打印</b>

    RA2L1硬件用戶手冊(中英)

    RA2L1硬件用戶手冊(中英)
    發(fā)表于 11-07 19:49 ?6次下載
    <b class='flag-5'>RA2L1</b>硬件用戶手冊(中英)

    RA2L1開發(fā)板資料

    RA2L1開發(fā)板資料
    發(fā)表于 11-07 19:50 ?18次下載
    <b class='flag-5'>RA2L1</b>開發(fā)板資料

    基于RA2L1的串口及J-Link的燒寫說明

    本節(jié)介紹使用串口工具對RA2L1進(jìn)行程序的燒寫。采用CPK-RA2L1開發(fā)板,硬件如下圖所示。
    的頭像 發(fā)表于 11-25 13:55 ?1573次閱讀

    RA2L1 組用戶手冊:硬件

    RA2L1 組用戶手冊:硬件
    發(fā)表于 01-09 19:06 ?5次下載
    <b class='flag-5'>RA2L1</b> 組用戶手冊:硬件

    RA2L1 組數(shù)據(jù)表

    RA2L1 組數(shù)據(jù)表
    發(fā)表于 01-09 19:06 ?0次下載
    <b class='flag-5'>RA2L1</b> 組數(shù)據(jù)表

    RA2L1 組電容式觸控評估系統(tǒng)快速入門指南

    RA2L1 組電容式觸控評估系統(tǒng)快速入門指南
    發(fā)表于 02-03 19:24 ?0次下載
    <b class='flag-5'>RA2L1</b> 組電容式觸控評估系統(tǒng)快速入門指南

    RA2L1 組用戶手冊:硬件

    RA2L1 組用戶手冊:硬件
    發(fā)表于 06-30 18:50 ?0次下載
    <b class='flag-5'>RA2L1</b> 組用戶手冊:硬件

    RA2L1 組數(shù)據(jù)表

    RA2L1 組數(shù)據(jù)表
    發(fā)表于 06-30 18:50 ?0次下載
    <b class='flag-5'>RA2L1</b> 組數(shù)據(jù)表

    RA2L1 組 Capacitive Touch Evaluation System 用戶手冊

    RA2L1 組 Capacitive Touch Evaluation System 用戶手冊
    發(fā)表于 07-04 20:38 ?0次下載
    <b class='flag-5'>RA2L1</b> 組 Capacitive Touch Evaluation System 用戶手冊

    RA2L1上手優(yōu)化BSP占用

    在上手RA2L1開發(fā)板的時候,使用RTT Studio給的BSP進(jìn)行開發(fā)時發(fā)現(xiàn)默認(rèn)占用太大了,所以今天就來說一下如何優(yōu)化掉不是很必要的部分(當(dāng)然芯片資源很大且不在乎的可以不做)。
    的頭像 發(fā)表于 10-12 11:18 ?516次閱讀
    <b class='flag-5'>RA2L1</b>上手優(yōu)化BSP占用

    基于RA2L1實(shí)現(xiàn)串口DTC數(shù)據(jù)接收

    基于RA2L1實(shí)現(xiàn)串口DTC數(shù)據(jù)接收
    的頭像 發(fā)表于 10-10 09:34 ?385次閱讀
    基于<b class='flag-5'>RA2L1</b>實(shí)現(xiàn)串口DTC數(shù)據(jù)接收

    瑞薩RA2L1系列CAN通信應(yīng)用

    瑞薩RA2L1系列CAN通信應(yīng)用
    的頭像 發(fā)表于 06-26 08:06 ?389次閱讀
    瑞薩<b class='flag-5'>RA2L1</b>系列CAN通信應(yīng)用