OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4251|回复: 9

MDK printf不显示

[复制链接]

6

主题

21

帖子

0

精华

新手入门

积分
16
金钱
16
注册时间
2016-7-18
在线时间
11 小时
发表于 2016-7-31 19:07:50 | 显示全部楼层 |阅读模式
20金钱
本帖最后由 frc1 于 2016-8-1 11:39 编辑

下面是程序代码,大家能帮我看看哪里出问题了么
#include "stm32f10x.h"
#include <stdio.h>
#include "stm32f10x_GPIO.h"
#include "stm32f10x_RCC.h"
#include "stm32f10x_tim.h"


#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 is needed */ };
FILE __stdout;
FILE __stdin;
int fputc(int ch, FILE *f)
{
  if (DEMCR & TRCENA)
  {
    while (ITM_Port32(0) == 0);
    ITM_Port8(0) = ch;
  }
  return(ch);
}

unsigned int CountOfToggle=0;

void LED0_Config(void);
void LED0_On(void);
void LED0_Off(void);
void TIM2_Delay500MS(void);

int main(void)
{
  LED0_Config();
  while (1)
  {
    LED0_On();
        TIM2_Delay500MS();
    LED0_Off();
        TIM2_Delay500MS();
    CountOfToggle++;
    printf("The Count of Toggle is %d\n",CountOfToggle);
  }
}

void LED0_Config(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
  /* Enable GPIO_LED0 clock */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
  /* GPIO_LED0 Pin(PA8) Configuration */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
}

void LED0_On(void)
{
  GPIO_ResetBits(GPIOA, GPIO_Pin_8);
}

void LED0_Off(void)
{
  GPIO_SetBits(GPIOA, GPIO_Pin_8);
}

void TIM2_Delay500MS()
{
TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
  /* Enable TIM2 clock */
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
  /*  TIM2 Time Base Configuration:
      TIM2CLK / (( TIM_Prescaler + 1 ) * ( TIM_Period + 1 )) = TIM2 Frequency         
          TIM2CLK = 72MHz, TIM2 Frequency = 2Hz,
          TIM_Prescaler = 36000-1, (TIM2 Counter Clock = 2kHz), TIM_Period = 1000-1        */
  TIM_TimeBaseStructure.TIM_Prescaler = 36000-1;  
  TIM_TimeBaseStructure.TIM_Period = 1000-1;           
  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
  TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
  /* Clear TIM2 update pending flag */
  TIM_ClearFlag(TIM2, TIM_FLAG_Update);
  /* Enable TIM2 counter */
  TIM_Cmd(TIM2,ENABLE);
  while (TIM_GetFlagStatus(TIM2, TIM_FLAG_Update) == RESET);
}


1.png






最佳答案

查看完整内容[请看2#楼]

直接下我们例程测试
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-7-31 19:07:51 | 显示全部楼层
frc1 发表于 2016-8-3 12:18
我已经连了这个,还是不行

直接下我们例程测试
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-8-1 00:28:14 | 显示全部楼层
你这代码,怎么感觉怪怪的。
参考我们例程来吧。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

6

主题

21

帖子

0

精华

新手入门

积分
16
金钱
16
注册时间
2016-7-18
在线时间
11 小时
 楼主| 发表于 2016-8-1 16:34:15 | 显示全部楼层
改成下面这些还是显示不了
#pragma import(__use_no_semihosting)  
_sys_exit(int x)  
{  
x = x;  
}  
struct __FILE  
{  
int handle;  
/* Whatever you require here. If the only file you are using is */  
/* standard output using printf() for debugging, no file handling */  
/* is required. */  
};  
/* FILE is typedef’ d in stdio.h. */  
FILE __stdout;   
回复

使用道具 举报

22

主题

213

帖子

0

精华

高级会员

Rank: 4

积分
682
金钱
682
注册时间
2015-2-13
在线时间
74 小时
发表于 2016-8-2 14:44:52 | 显示全部楼层
本帖最后由 huishun1314 于 2016-8-2 14:46 编辑

你这是 jlink 调试时的 printf 打印,不是串口。

参考官方文档:
http://www.keil.com/support/man/ ... race_itm_viewer.htm

硬件连接
ITM机制要求使用SWD方式接口,并需要连接SWO线,一般的四线SWD方式(VCC SDCLK,SDIO,GND)是不行的。必须将SWO(即JTAG模式下的TDO)管脚引出,必须在MDK里设置使用SWD接口。



回复

使用道具 举报

6

主题

21

帖子

0

精华

新手入门

积分
16
金钱
16
注册时间
2016-7-18
在线时间
11 小时
 楼主| 发表于 2016-8-2 15:49:30 | 显示全部楼层
本帖最后由 frc1 于 2016-8-2 20:03 编辑
huishun1314 发表于 2016-8-2 14:44
你这是 jlink 调试时的 printf 打印,不是串口。

参考官方文档:

请问串口不是这个么 2.png
1.jpg
回复

使用道具 举报

2

主题

18

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
254
金钱
254
注册时间
2016-5-13
在线时间
45 小时
发表于 2016-8-2 20:59:11 | 显示全部楼层
没有串口配置
回复

使用道具 举报

22

主题

213

帖子

0

精华

高级会员

Rank: 4

积分
682
金钱
682
注册时间
2015-2-13
在线时间
74 小时
发表于 2016-8-3 11:40:37 | 显示全部楼层
frc1 发表于 2016-8-2 15:49
请问串口不是这个么

是的。
回复

使用道具 举报

6

主题

21

帖子

0

精华

新手入门

积分
16
金钱
16
注册时间
2016-7-18
在线时间
11 小时
 楼主| 发表于 2016-8-3 12:18:01 | 显示全部楼层

我已经连了这个,还是不行
回复

使用道具 举报

6

主题

21

帖子

0

精华

新手入门

积分
16
金钱
16
注册时间
2016-7-18
在线时间
11 小时
 楼主| 发表于 2016-8-7 00:08:32 | 显示全部楼层
正点原子 发表于 2016-8-3 21:06
直接下我们例程测试

例程是可以的,谢谢原子哥
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-9 05:14

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表