完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
STM8S103F tiM1 CLK_PSC和CLK_CNT频率不匹配
以上来自于谷歌翻译 以下为原文 STM8S103F TIM1 CLK_PSC and CLK_CNT frequency not matching |
|
相关推荐
2个回答
|
|
嗨franco,
您说您的信号宽度为10毫秒,但是时钟配置为16MHz且预分频器为0,TIM1溢出为65553,因此在65535/16000000 = 4.09 ms内。也许您应该使用更大的预处理器或更大的输入捕获分频器值(TIM1_ICPSC_DIV2,...)。 我在FWLib / examples / TIM1 / TIM1_Input_Capture中找到了一个可以帮助你的例子。 (当我开始在STM8S中使用计时器时,这对我很有用) 告诉我现在好吗 带着敬意, 低功率 以上来自于谷歌翻译 以下为原文 Hi franco, You said that your signal is 10msec width but with your clock config 16MHz and prescaler = 0, the TIM1 overflows at 65553 so within 65535/16000000 = 4.09 ms. Perhaps you should use a greater precaler or greater value of input capture divider (TIM1_ICPSC_DIV2,...). I have found an example in FWLib/examples/TIM1/TIM1_Input_Capture that could help you. (It is was useful for me when I started using timers in STM8S) Tell me if it is OK now With regards, be low power |
|
|
|
我已经发现这也是我的问题,但是使用你的建议,我无法解决它。我试过调整HSIDIV和TIM1_ICPSC_DIV无济于事。不会使ICPSC_DIV更高可以捕获更快的信号,而不是更慢?或者我的思维倒退了吗?我这样说是因为TIM会更频繁地溢出,边缘之间的时间更长,即更慢的频率。
CLK_DeInit(); / *将Fcpu配置为DIV1 * / CLK_SYSCLKConfig(CLK_PRESCALER_CPUDIV1); / *将HSI预分频器配置为最佳值* / CLK_SYSCLKConfig(CLK_PRESCALER_HSIDIV1); / *在CLK_CCO引脚PE.0上输出Fcpu * / CLK_CCOConfig(CLK_OUTPUT_HSI); CLK_CCOCmd(ENABLE); / *根据CLK_InitStructure 24MHz * /启动时钟控制器 status = CLK_ClockSwitchConfig(CLK_SWITCHMODE_AUTO,CLK_SOURCE_HSE,DISABLE,DISABLE); while(CLK_GetFlagStatus(CLK_FLAG_HSERDY)== 0); TIM1_ICInit(TIM1_CHANNEL_1,TIM1_ICPOLARITY_RISING,TIM1_ICSELECTION_DIRECTTI,TIM1_ICPSC_DIV8,0x0); 以上来自于谷歌翻译 以下为原文 I have figured out that this too is my problem, but using your suggestions, I can't get it fixed. I've tried adjusting the HSIDIV and the TIM1_ICPSC_DIV to no avail. Wouldn't making the ICPSC_DIV higher make it possible to capture faster signals, not slower? Or is my mind working backwards? I say this because the TIM will overflow more often with longer times between edges, i.e. slower freqs. CLK_DeInit(); /* Configure the Fcpu to DIV1*/ CLK_SYSCLKConfig(CLK_PRESCALER_CPUDIV1); /* Configure the HSI prescaler to the optimal value */ CLK_SYSCLKConfig(CLK_PRESCALER_HSIDIV1); /* Output Fcpu on CLK_CCO pin PE.0*/ CLK_CCOConfig(CLK_OUTPUT_HSI); CLK_CCOCmd(ENABLE); /* Initilize the Clock controller according to CLK_InitStructure 24MHz */ status = CLK_ClockSwitchConfig(CLK_SWITCHMODE_AUTO, CLK_SOURCE_HSE, DISABLE, DISABLE); while (CLK_GetFlagStatus(CLK_FLAG_HSERDY) == 0); TIM1_ICInit( TIM1_CHANNEL_1, TIM1_ICPOLARITY_RISING, TIM1_ICSELECTION_DIRECTTI, TIM1_ICPSC_DIV8, 0x0); |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2715 浏览 1 评论
3235 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1807 浏览 1 评论
3643 浏览 6 评论
6031 浏览 21 评论
1332浏览 4评论
206浏览 3评论
195浏览 3评论
对H747I-DISCO写程序时将CN2的st-link复用为usart1,再次烧录时无法检测到stlink怎么解决?
348浏览 2评论
STM32G474RE芯片只是串口发个数据就发烫严重是怎么回事?
440浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-19 10:43 , Processed in 1.165680 second(s), Total 80, Slave 64 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号