利用jlink实现串口调试
2017-01-30 21:46
127 查看
方法是stm32官网的,我只是一个搬运工
可能很多朋友和我一样买的最小系统板子,很多外设没有,比如说usb转串口的芯片,只有jlink下载器,大过年的想买也买不到,在这里搬运一种方法。
首先是硬件部分,只需要把jlink仿真器插上就ok,就像平时做硬件调试一样,不需要别的东西
下一步是mdk里面关于硬件部分的设置,如图所示,只需要更改下图的部分就Ok,别的不用管。
![](https://img-blog.csdn.net/20170130214601990?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTGVzdHJhZGVf/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
![](https://img-blog.csdn.net/20170130214610256?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTGVzdHJhZGVf/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
![](https://img-blog.csdn.net/20170130214613147?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTGVzdHJhZGVf/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
接下来附上一段代码,将这段代码添加到文件中,最好是main函数或者是原本用于uart打印显示的函数部分。
#define ITM_Port8(n) (*((volatile unsigned char *)(0xE0000000+4*n)))
#define ITM_Port16(n) (*((volatile unsigned short*)(0xE0000000+4*n)))
#define ITM_Port32(n) (*((volatile unsigned long *)(0xE0000000+4*n)))
#define DEMCR (*((volatile unsigned long *)(0xE000EDFC)))
#define TRCENA 0x01000000
struct __FILE { int handle; /* Add whatever you need here */ };
FILE __stdout;
FILE __stdin;
int fputc(int ch, FILE *f)
{
if (DEMCR & TRCENA)
{
while (ITM_Port32(0) == 0);
ITM_Port8(0) = ch;
}
return(ch);
}
原理类似于uart里面printf的重定向,前者是定向到uart端口,在这里是定义到了sw端口的port0,最后效果如下,在view里面打开debug(printf) viewer即可以看到,这样我们就省去了uart的部分,如果uart仅用来调试的话完全可以采用这样简便的方法来实现。
可能很多朋友和我一样买的最小系统板子,很多外设没有,比如说usb转串口的芯片,只有jlink下载器,大过年的想买也买不到,在这里搬运一种方法。
首先是硬件部分,只需要把jlink仿真器插上就ok,就像平时做硬件调试一样,不需要别的东西
下一步是mdk里面关于硬件部分的设置,如图所示,只需要更改下图的部分就Ok,别的不用管。
接下来附上一段代码,将这段代码添加到文件中,最好是main函数或者是原本用于uart打印显示的函数部分。
#define ITM_Port8(n) (*((volatile unsigned char *)(0xE0000000+4*n)))
#define ITM_Port16(n) (*((volatile unsigned short*)(0xE0000000+4*n)))
#define ITM_Port32(n) (*((volatile unsigned long *)(0xE0000000+4*n)))
#define DEMCR (*((volatile unsigned long *)(0xE000EDFC)))
#define TRCENA 0x01000000
struct __FILE { int handle; /* Add whatever you need here */ };
FILE __stdout;
FILE __stdin;
int fputc(int ch, FILE *f)
{
if (DEMCR & TRCENA)
{
while (ITM_Port32(0) == 0);
ITM_Port8(0) = ch;
}
return(ch);
}
原理类似于uart里面printf的重定向,前者是定向到uart端口,在这里是定义到了sw端口的port0,最后效果如下,在view里面打开debug(printf) viewer即可以看到,这样我们就省去了uart的部分,如果uart仅用来调试的话完全可以采用这样简便的方法来实现。
相关文章推荐
- 通过JLINK实现串口显示调试
- 利用VC++实现串口收发短消息
- Windows下利用Javax.comm实现对串口的读写
- ARM2440 NBOOT的实现(1调试工具-串口实现)!
- minicom的使用和配置(实现串口调试)(同样适用于虚拟机设置)
- 利用Keil调试精确实现软件延时
- 《利用反射实现类的动态加载》调试出错的解决
- OK6410裸机调试(使用串口,不需要使用JLINK)
- 利用Java实现串口全双工通讯
- 利用Java实现串口全双工通讯-Java基础-Java-编程开发
- 利用MSComm控件实现字符发送与接收(串口)的工程设置问题
- symbian 利用蓝牙串口服务输出调试信息zz
- 利用Java实现串口全双工通讯
- 简析利用调试寄存器实现内核函数的HOOK
- JAVA高级:利用Java实现串口全双工通讯
- symbian 利用蓝牙串口服务输出调试信息
- 利用Java实现串口全双工通讯
- 简析利用调试寄存器实现内核函数的HOOK
- WinCE 中调试串口打印信息的实现介绍
- 串口调试程序的实现