【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口

可以直接用Jlink接口连接开发板,设置Debug选项为J-LINK/J-TRACE Cortex;再进入Settings对话框中选择SW模式(JTAG模式不行),并选择Trace使能并且必须使开发板的主频与其中的core相同(这里是72MHz);最后debug即可!好像只能用keil5,4的话会卡死。


Jlink/STLink自带一个SWO接口,使用这个接口配合keil可以输出一些简单的调试信息,在没有串口可以使用的时候,SWO也可很方便的打印一些信息,比如F303RE这个板子在我的电脑上一直没法安装虚拟串口的驱动,所以我可以用这个SWO输出调试信息。论坛送的STM32F303RE上自带的stlink正好有这个SWO口,而且也接到了MCU上,所以正好可以使用,好像有的ST的板子也带了这个接口,但是其中桥接电阻并没有贴到板子上,如果要使用的话,就要自己连接起来(比如STM32F429DISCO好像就没有接上)。


【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第1张图片 

对于stlink的驱动好像也有一些要求,我使用keil4带的有点旧的stlink驱动就会提示驱动不支持,后来使用keil5带的stlink驱动据可以了。

【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第2张图片 
如果硬件和软件都没有问题了,还需要设置下kei:
首先打开Micro LIB
【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第3张图片 
然后打开keil的Trace功能,具体设置如下:
【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第4张图片 
然后就是一些重定向printf的函数了,如果之前将printf重定向了串口,那么要修改并添加如下代码:
  1. #include "stdio.h"
  2. #define ITM_Port8(n)    (*((volatile unsigned char *)(0xE0000000+4*n)))
  3. #define ITM_Port16(n)   (*((volatile unsigned short*)(0xE0000000+4*n)))
  4. #define ITM_Port32(n)   (*((volatile unsigned long *)(0xE0000000+4*n)))

  5. #define DEMCR           (*((volatile unsigned long *)(0xE000EDFC)))
  6. #define TRCENA          0x01000000

  7. struct __FILE { int handle; /* Add whatever needed */ };
  8. FILE __stdout;
  9. FILE __stdin;

  10. int fputc(int ch, FILE *f) {
  11.   if (DEMCR & TRCENA) {
  12.     while (ITM_Port32(0) == 0);
  13.     ITM_Port8(0) = ch;
  14.   }
  15.   return(ch);
  16. }
复制代码

打开调试即可得到调试信息:
【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第5张图片 
输出调试信息
【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第6张图片 
测试代码:
  F303RE_SWO.rar (394.54 KB, 下载次数: 86) 

http://www.stmcu.org/module/forum/forum.php?mod=attachment&aid=MzQ1Mzg4fDdmZDdhOWYzfDE0NjgyOTcwMjF8MHw2MDIyMDU%3D
*******************************************一天过去了***************************************
上面说了输出的功能,其实如果需要的话,重定向下scanf()函数即可完成从Debug Viewer向程序输入参数的,这在调试某些需要动态调整参数的程序里面应该有帮助,比如按下某个按键,激活输入功能,重新配置下参数,然后继续运行程序。
调试的时候有个变量在一直检测是否有数据输入,如果有数据输入,那么输入的数据就传到这个变量,这个接口在内核的头文件有相关的定义,我们只需要定义这个变量即可。
将下面的main.c代码完整的替换掉上面的mian.c就可以使用了。
  1. #include "main.h"
  2. #include "string.h"
  3. //SWV test
  4. //2015-6-15
  5. //by creep
  6. #define ITM_Port8(n)    (*((volatile unsigned char *)(0xE0000000+4*n)))
  7. #define ITM_Port16(n)   (*((volatile unsigned short*)(0xE0000000+4*n)))
  8. #define ITM_Port32(n)   (*((volatile unsigned long *)(0xE0000000+4*n)))

  9. #define DEMCR           (*((volatile unsigned long *)(0xE000EDFC)))
  10. #define TRCENA          0x01000000

  11. struct __FILE { int handle; /* Add whatever needed */ };
  12. FILE __stdout;
  13. FILE __stdin;

  14. volatile int32_t ITM_RxBuffer=ITM_RXBUFFER_EMPTY;

  15. int fputc(int ch, FILE *f) {
  16.   if (DEMCR & TRCENA) {
  17.     while (ITM_Port32(0) == 0);
  18.     ITM_Port8(0) = ch;
  19.   }
  20.   return(ch);
  21. }
  22. int fgetc(FILE *f)
  23. {
  24.         while(ITM_CheckChar() == 0)
  25.         {                
  26.         }
  27.         return ITM_ReceiveChar();
  28. }

  29. u8 Write_buff[30] = "\n\r\n\rPlease enter your name:\n\r";
  30. u8 read_buff[50]= "";
  31. u8 name[100]="\n\rYour name is : ";
  32. int main(void)
  33. {
  34.         static u8 led_sta = ON;
  35.     LED_Init();
  36.     delay_init();
  37.                 delay_ms(1000);
  38.     while(1)
  39.     {
  40.                                 //将数据发送到Debug Viewer
  41.                                 printf((const char*)Write_buff);
  42.                                 memset(read_buff,0,50);
  43.                                 //等待输入
  44.                                 scanf("%s",read_buff);
  45.                                 //将姓名输出
  46.                                 printf((const char*)name);
  47.                                 printf((const char*)read_buff);
  48.                                 LED(led_sta);
  49.                                 led_sta = !led_sta;
  50.         delay_ms(1000);
  51.     }
  52. }


复制代码
直接在debug viewer窗口输入内容然后回车即可,输入的内容不会回显在窗口中,输入也支持中文。运行结果如下:


【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口_第7张图片 

你可能感兴趣的:(【STM32F303开发】+ 使用SWO输出调试信息到Debug Viewer窗口)