当前位置:网站首页>Virtual serial port function of j-link V9 using skills
Virtual serial port function of j-link V9 using skills
2022-04-23 01:47:00 【Traceless rain】
Use ITM Mechanism implementation debugging contex-M series , Realization printf And scanf.
1. ITM brief introduction
ITM Mechanism is a debugging mechanism , It is a new generation of debugging mode ,
ITM yes ARM Cortex-M A new debugging function in the series of kernel chips , It can be easily realized through the debugger printf Debugging function . come from STM32 Introduction of Chinese Reference Manual :
ITM ( Instruction tracking micro unit instrumentation trace macrocell):ITM It is an application driven tracking source , It supports printf Class to track the operating system (OS) And application events , And release the determined system information .ITM Publish tracking information as a package , It consists of the following parts :
- Software tracking : Software can be written directly ITM Fire registers to publish package information .
- Hardware tracking :ITM Will be released by DWT Generated packets .
- Time stamp : The timestamp is posted to the corresponding package .ITM Contains a 21 Bit counter to generate timestamp .Cortex-M3 Clock or serial line observer (Serial Wire Viewer) The bit clock rate of provides a clock for the counter . from ITM The sent packet is output to TPIU(Trace Port Interface Unit),TPIU Add some extra packages ( Reference resources TPIU), Then output the complete package sequence to the debugger . The user is setting or using ITM Before , The exception debugging and monitoring control register must be enabled first (Debug Exception and Monitor Control Register) Of TRCEN position .
stay pc Written on C Everyone who speaks knows ,printf You can output... To the console ,scanf Input can be obtained from the console , there printf/scanf Are standard library functions , Using these functions of the operating system , We can easily debug the program . On embedded devices ( Such as stm32 On the single chip microcomputer platform ) development tool ( Such as MDK/IAR) Standard library functions are also provided , And nature provides that printf/scanf function , So can these functions be used ? The problem is coming. ,printf Where to output ? And in most cases , No keyboard , How to use scanf What about input ?
We all know , Embedded devices generally use emulators , If common Jlink/ulink, You can burn , Single step , Lower breakpoint , Check the variable , wait . The simulator will PC Machine and MCU connector to . Smart designers are considering whether they can use simulators , So that the single chip microcomputer can use PC The screen of the machine and PC Keyboard implementation of the machine printf Output and scanf Press the key to get .
in other words , As follows hello,world Program
#include <stdio.h>
int main()
{
// Hardware initialization
//....
printf("hello, world");
for(;;);
}
After burning this program into the single chip microcomputer , The simulator is connected with a single-chip microcomputer and PC, After starting online debugging , Then this program will "Hello, world" Output to PC On board , In developing tools (MDK/IAR etc. ) Show... In a window of .
This is equivalent to , MCU with the help of PC The display of the machine / The input device implements its own output / Input . This method is undoubtedly convenient for program developers to debug .
This mechanism can be implemented in many ways , The more famous is semihosting( Semi host mechanism ) and ITM Mechanism .
ITM yes ARM Launch semihosting After the launch of a new generation of debugging mechanism . Now let's try debugging in this way .
2. stm32 Use ITM debugging
2.1 Hardware connection
ITM The mechanism requires the use of SWD Mode interface
1> General four wire SWD The way (VCC SDCLK,SDIO,GND) You can't . Multiple connections are required SWO Line ,
2> The standard 20 The needle JTAG The interface is OK , Only need MDK Set and use SWD Interface can .
2.2 Add redirect file
Save the following file as retarget.c file , And add to the project . Here is a brief description of this document , You know, our program is MCU Running on , Why? printf It can be output to MDK In the window ? This is because In the standard library printf Actually call fputc Achieve output , So we need to write a fputc function , This function will use ITM( Be similar to USART) Register provided , Realize the sending of data , The emulator will receive this data , Concurrent to PC machine .
-
#include <stdio.h>
-
#include <stdint.h>
-
#include "stm32f4xx.h"
-
#pragma import(__use_no_semihosting_swi)
-
struct __FILE { int handle; /* Add whatever you need here */ };
-
FILE __stdout;
-
FILE __stdin;
-
int fputc(int ch, FILE *f)
-
{
-
return ITM_SendChar(ch);
-
}
-
volatile int32_t ITM_RxBuffer;
-
int fgetc(FILE *f)
-
{
-
while (ITM_CheckChar() != 1) __NOP();
-
return (ITM_ReceiveChar());
-
}
-
int ferror(FILE *f)
-
{
-
/* Your implementation of ferror */
-
return EOF;
-
}
-
void _ttywrch(int c)
-
{
-
fputc(c, 0);
-
}
-
int __backspace()
-
{
-
return 0;
-
}
-
void _sys_exit(int return_code)
-
{
-
label:
-
goto label; /* endless loop */
-
}
Here to retarget.c The document makes a few notes .
1). The above code is actually in X:\Keil\ARM\Startup\Retarget.c Modified from ,scanf There are two dependent functions ,fgetc and __backspace Both need to be implemented , If there is a lack of __backespace function , be scanf Hu can't from Debug Viewer Dialog Window to get input .
2). function ITM_SendChar,ITM_CheckChar,ITM_ReceiveChar In the library file CMSIS\Include\core_cm3.h in .
2.3 Another way to add redirected files
µVision User's Guide: Debug (printf) Viewer
2.4 To configure J-Link Initialization profile for
Place the following files under your project , And take any name , Here I call it STM32DBG.ini
-
/******************************************************************************/
-
/* STM32DBG.ini: STM32 Debugger Initialization File */
-
/******************************************************************************/
-
// <<< Use Configuration Wizard in Context Menu >>> //
-
/******************************************************************************/
-
/* This file is part of the uVision/ARM development tools. */
-
/* Copyright (c) 2005-2007 Keil Software. All rights reserved. */
-
/* This software may only be used under the terms of a valid, current, */
-
/* end user licence from KEIL for a compatible version of KEIL software */
-
/* development tools. Nothing else gives you the right to use this software. */
-
/******************************************************************************/
-
FUNC void DebugSetup (void) {
-
// <h> Debug MCU Configuration
-
// <o1.0> DBG_SLEEP <i> Debug Sleep Mode
-
// <o1.1> DBG_STOP <i> Debug Stop Mode
-
// <o1.2> DBG_STANDBY <i> Debug Standby Mode
-
// <o1.5> TRACE_IOEN <i> Trace I/O Enable
-
// <o1.6..7> TRACE_MODE <i> Trace Mode
-
// <0=> Asynchronous
-
// <1=> Synchronous: TRACEDATA Size 1
-
// <2=> Synchronous: TRACEDATA Size 2
-
// <3=> Synchronous: TRACEDATA Size 4
-
// <o1.8> DBG_IWDG_STOP <i> Independant Watchdog Stopped when Core is halted
-
// <o1.9> DBG_WWDG_STOP <i> Window Watchdog Stopped when Core is halted
-
// <o1.10> DBG_TIM1_STOP <i> Timer 1 Stopped when Core is halted
-
// <o1.11> DBG_TIM2_STOP <i> Timer 2 Stopped when Core is halted
-
// <o1.12> DBG_TIM3_STOP <i> Timer 3 Stopped when Core is halted
-
// <o1.13> DBG_TIM4_STOP <i> Timer 4 Stopped when Core is halted
-
// <o1.14> DBG_CAN_STOP <i> CAN Stopped when Core is halted
-
// </h>
-
_WDWORD(0xE0042004, 0x00000027); // DBGMCU_CR
-
_WDWORD(0xE000ED08, 0x20000000); // Setup Vector Table Offset Register
-
}
-
DebugSetup(); // Debugger Setup
Here is a brief explanation of this file ,
_WDWORD(0xE0042004, 0x00000027); // DBGMCU_CR
This sentence means you want to 0xE0042004 Write... At the address 0x000000027, This register is the meaning of each bit representation, which is explained in detail in the comments . 0x27 It indicates that the
BIT0 DBG_SLEEP
BIT1 DBG_STOP
BIT2 DBG_STANDBY
BIT5 TRACE_IOEN
Be careful , To use ITM Mechanism , It has to be opened BIT0.
open MDK engineering , Modify according to the following figure .
![]() |
2.5MDK Chinese vs J-Link Configuration of
![]() |
Note two points in the figure below
1). there CoreClock yes 120M, Because it uses stm32F207VG This chip , And the clock is configured as 120M, So fill in 120M, If you use stm32F10x, The clock is configured as 72M, Then you need to fill in 72M. That is, it needs to be consistent with the actual situation .
2). Finally, be sure to 0 Place a tick , And other bit Remove the tick from the position , It's best to keep consistent with this figure , except CoreClock Outside .
![]() |
2.6 Burn program , And start debugging . You can see , The author inserted a sentence in the program source code printf Statement output , Then follow the diagram below , You can see the output of the program .
![]() |
3. Compile operation
compile , burn , function , open Debug (printf) viewer, You can see the input , See below
![]() |
4. Virtual serial port function configuration
J-link The virtual serial port function of is turned off by default , Can be in J-link Commander Open down .
If it is V9 above , Input vcom enable. If the following prompt appears , Indicating successful configuration , Direct will Jlink Power on again .
If the following prompt appears :The connected probe does not support VCOM functionality, Re-enter the following command :
power on
power off
vcom enable
If you don't succeed, power on again and try a few more times ,J-link Commander Also reopen .
If there is no prompt error, everything is normal , take J-link Power on again , You can see that the driver will reload , There is an additional serial port device in the device manager , Indicates that the setting is successful . The serial port can be directly used as USB Use of serial port equipment , No effect J-link Debugging program .
If you need to turn off this function , Input vcom disable that will do .
版权声明
本文为[Traceless rain]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204230143119411.html
边栏推荐
- K zeros after leetcode factorial function
- 【动手学深度学习V2】循环神经网络-1.序列模型
- W801 / w800 / w806 unique ID / CPUID / flashid
- Garlic customer: equilateral triangle (DFS)
- VSCODE + PHP Debug + 名字空间指引
- Detonate the bomb (DFS)
- 2022 crane driver (limited to bridge crane) examination question bank and online simulation examination
- Do447 manage user and team access
- Realize the function of progress bar through layerdrawable
- Question bank and online simulation examination for safety management personnel of hazardous chemical business units in 2022
猜你喜欢
Unrelated interprocess communication -- creation and use of named pipes
《维C中国》乡村助农暖人心第三站嘉宝果农场
批处理多个文件合成一个HEX
Longest common subsequence (record path version)
42. Use k3det in mmrotate for rotating target detection, MNN deployment and ncnn deployment
postman里面使用 xdebug 断点调试
How to change the size of SVG pictures without width in openlayer
Error in face detection and signature of Tencent cloud interface
2022 melting welding and thermal cutting operation certificate examination question simulation examination platform operation
客户端项目管理经常面临的挑战
随机推荐
力扣(LeetCode)112. 路径总和(2022.04.22)
Custom numeric input control
C语言中如何“指名道姓”的进行初始化
Longest common subsequence (record path version)
ESP32蓝牙Bluetooth Controller API介绍
使用单元测试框架编写单元测试的好处?
[experience tutorial] Alipay balance automatically transferred to the balance of treasure how to set off, cancel Alipay balance automatically transferred to balance treasure?
RuntimeError: The size of tensor a (4) must match the size of tensor b (3) at non-singleton dimensio
Glide set fillet image (support custom fillet position)
Dimension C China helping farmers in rural areas warms people's hearts the third stop is jiabaoguo farm
Redis实现分布式锁
什么时候应该编写单元测试?什么是TDD?
Question bank and online simulation examination for safety management personnel of hazardous chemical business units in 2022
Chapter 6 uses Matplotlib to draw thermodynamic diagram
postman里面使用 xdebug 断点调试
JSP基础知识总结
Itextsharp infrastructure
Planning garlic guest (outing) (DFS and BFS solution of dyeing block problem)
Learning methods and career development guide (2022 Edition)
RuntimeError: The size of tensor a (4) must match the size of tensor b (3) at non-singleton dimensio