OpenEdv-开源电子网

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

关于system_stm32f10x.c的疑问

[复制链接]

20

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
165
金钱
165
注册时间
2013-7-4
在线时间
5 小时
发表于 2013-7-9 17:30:21 | 显示全部楼层 |阅读模式
在3.5的库system_stm32f10x.c中有#define SYSCLK_FREQ_72MHz  72000000这句没有被隐去;
然后下面有函数void SystemInit (void)这个函数算是定义了一个默认的时钟设置;这个函数中最后有一个内部函数
SetSysClock();然后这个函数就进入了SetSysClockTo72();函数,这个函数又对时钟重新定义了一遍,
不知道我这样理解对不对(我在主函数中调用了SystemInit)
我想问:1、这两个时钟定义算不算重复,如果是的话,那我是不是编程时要隐去一个?
            2、在工程中加入的这个system_stm32f10x.c文件是不是全部编译并执行了?还是只用到了我在主函数中调用的SystemInit
非常感谢大家
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

230

主题

1950

帖子

10

精华

论坛元老

Rank: 8Rank: 8

积分
4562
金钱
4562
注册时间
2010-12-14
在线时间
32 小时
发表于 2013-7-9 18:52:36 | 显示全部楼层
回复【楼主位】litai11114:
---------------------------------
1.没有你说的重复定义问题。
  最开头:#define SYSCLK_FREQ_72MHz  
 然后SystemInit函数里面会调用  SetSysClock();函数,然后调用函数SetSysClockTo72()设置相应的寄存器,使系统时钟为72M。
2.很显然,关键部分在SetSysClock函数,根据宏定义来预编译的,不会全部编译。你定义了SYSCLK_FREQ_72MHz ,那么只会调用SetSysClockTo72();
static void SetSysClock(void)
{
#ifdef SYSCLK_FREQ_HSE
  SetSysClockToHSE();
#elif defined SYSCLK_FREQ_24MHz
  SetSysClockTo24();
#elif defined SYSCLK_FREQ_36MHz
  SetSysClockTo36();
#elif defined SYSCLK_FREQ_48MHz
  SetSysClockTo48();
#elif defined SYSCLK_FREQ_56MHz
  SetSysClockTo56();  
#elif defined SYSCLK_FREQ_72MHz
  SetSysClockTo72();
#endif
 
 /* If none of the define above is enabled, the HSI is used as System clock
    source (default after reset) */ 
}
我是开源电子网?网站管理员,对网站有任何问题,请与我联系!QQ:389063473Email:389063473@qq.com
回复 支持 反对

使用道具 举报

20

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
165
金钱
165
注册时间
2013-7-4
在线时间
5 小时
 楼主| 发表于 2013-7-9 19:06:01 | 显示全部楼层

谢谢

回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-18 02:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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