1:debug的串口被占用
2:從Keil 遷移到的LINUX下開發.
3:手上只有JLinkOB,(4線:CLK,SWIO,GND,RST)
4:設備只引出了4線(SWO 沒接出)
環境:
JLink版本: 執行 JLinkExe 命令會先顯示版本信息
SEGGER J-Link Commander V6.56a (Compiled Nov 25 2019 16:58:42)
DLL version V6.56a, compiled Nov 25 2019 16:58:26
Host: Ubuntu 16.04
A:找到JLINK 安裝時的exmaple 和 RTT相關的頭文件
路徑:/opt/SEGGER/JLink_V656a/Samples/SEGGER_RTT_V656a.tgz
解壓出來就好
B:使用,復制路徑下的RTT文件夾和Syscalls文件夾下的文件到工程目錄,makefile增加對應的源文件
C:編譯可能報錯: xxxxx87:5: error: conflicting types for '_write_r' xxxxx
原因,是arm-gcc版本造成的,修改報錯的地方的 _write_r(在 reent.h中161行) 的聲明即可
修改如下
1 //extern _ssize_t _write_r _PARAMS ((struct _reent *, int, const void *, size_t)); 2 extern int _write_r(struct _reent *r, int file, const void *ptr, int len);
再編譯即可.
D: 實現打印:
打印代碼如下:
//main.c #include <stdio.h> #include "SEGGER_RTT.h" void main(){ /*HAL init 之類的初始化*/ SEGGER_RTT_ConfigUpBuffer(0, NULL, NULL, 0, SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL); SEGGER_RTT_printf(0, "printf Test: %%c, 'S' : %c.\r\n", 'S'); while(1){ } }
E:運行:
1:先運行 JLinkExe -Device STM32FXXXX -Speed 4000 -If SWD
2:connect
3:r
4:另起窗口運行 JLinkRTTClient
5:回到JLink的窗口 運行 go
操作如下:
JLinkExe -Device STM32F446RE -Speed 4000 -If SWD SEGGER J-Link Commander V6.56a (Compiled Nov 25 2019 16:58:42) DLL version V6.56a, compiled Nov 25 2019 16:58:26 Connecting to J-Link via USB...O.K. Firmware: J-Link OB-STM32F072-CortexM compiled Mar 8 2020 11:15:54 Hardware version: V1.00 S/N: -1 License(s): GDB, RDI, FlashBP, FlashDL, JFlash, RDDI VTref=3.300V Type "connect" to establish a target connection, '?' for help J-Link>connect Device "STM32F446RE" selected. Connecting to target via SWD Found SW-DP with ID 0x2BA01477 Found SW-DP with ID 0x2BA01477 Scanning AP map to find all available APs AP[1]: Stopped AP scan as end of AP map has been reached AP[0]: AHB-AP (IDR: 0x24770011) Iterating through AP map to find AHB-AP to use AP[0]: Core found AP[0]: AHB-AP ROM base: 0xE00FF000 CPUID register: 0x410FC241. Implementer code: 0x41 (ARM) Found Cortex-M4 r0p1, Little endian. FPUnit: 6 code (BP) slots and 2 literal slots CoreSight components: ROMTbl[0] @ E00FF000 ROMTbl[0][0]: E000E000, CID: B105E00D, PID: 000BB00C SCS-M7 ROMTbl[0][1]: E0001000, CID: B105E00D, PID: 003BB002 DWT ROMTbl[0][2]: E0002000, CID: B105E00D, PID: 002BB003 FPB ROMTbl[0][3]: E0000000, CID: B105E00D, PID: 003BB001 ITM ROMTbl[0][4]: E0040000, CID: B105900D, PID: 000BB9A1 TPIU ROMTbl[0][5]: E0041000, CID: B105900D, PID: 000BB925 ETM Cortex-M4 identified. J-Link>r Reset delay: 0 ms Reset type NORMAL: Resets core & peripherals via SYSRESETREQ & VECTRESET bit. Reset: Halt core after reset via DEMCR.VC_CORERESET. Reset: Reset device via AIRCR.SYSRESETREQ. J-Link>go
JLinkRTTClient ###RTT Client: ************************************************************ ###RTT Client: * SEGGER Microcontroller GmbH * ###RTT Client: * Solutions for real time microcontroller applications * ###RTT Client: ************************************************************ ###RTT Client: * * ###RTT Client: * (c) 2012 - 2016 SEGGER Microcontroller GmbH * ###RTT Client: * * ###RTT Client: * www.segger.com Support: support@segger.com * ###RTT Client: * * ###RTT Client: ************************************************************ ###RTT Client: * * ###RTT Client: * SEGGER J-Link RTT Client Compiled Nov 25 2019 16:59:02 * ###RTT Client: * * ###RTT Client: ************************************************************ ###RTT Client: ----------------------------------------------- ###RTT Client: Connecting to J-Link RTT Server via localhost:19021 ... ###RTT Client: Connected. SEGGER J-Link V6.56a - Real time terminal output J-Link OB-STM32F072-CortexM compiled Mar 8 2020 11:15:54 V1.0, SN=-1 Process: JLinkExe printf Test: %c, 'S' : S.
剩下問題:
啟動JLinkRTT Logger 失敗問題