你的浏览器版本过低,可能导致网站不能正常访问!为了你能正常使用网站功能,请使用这些浏览器。
举报
聿怀嘿嘿 发表于 2015-1-11 10:36 谢谢!不过第二种方法具体要怎样实现呢?是设定好后不断查询?
木易-357428 发表于 2015-1-10 21:43 为什么没法实现?你不应该这么问问题。至少,你要告诉大家用的什么型号的片子,代码怎么写的,时钟频率是多 ...
聿怀嘿嘿 发表于 2015-1-10 21:52 嗯嗯、f072,时钟48m,定时10us没问题,但定时到1us时就出事了
zhous 发表于 2015-1-10 22:19 可以的,肯定是代码问题,好好查一下
lkl0305 发表于 2015-1-10 22:27 查代码吧
木易-357428 发表于 2015-1-10 21:57 出什么事了?实际超过了1us的延时?定时器不工作了?程序死了?
jinlinlong 发表于 2015-1-10 22:32 没试过,系统时钟不是很准确的
定时器延时有两种方法,第一种直接设置成1us中断1次,也就是说systick config函数的参数是XMHz/1000000。但是这样频繁的打断CPU不是很合适。
另外在说一个方法,将定时器的时间间隔设计成为1ms的中断。这样你可以编写一个ms的延时。假设你的CPU是72M,那么也就是说SYSTICK->VAL从72M/1000-1开始,数到0结束。然后你再把这72M/1000等分成1000份,那么每一份又是1us了。这样就能使用定时器产生1us的时间间隔了。
还是while
static __INLINE uint32_t SysTick_Config(uint32_t ticks)
{
if (ticks > SYSTICK_MAXCOUNT) return (1); /* Reload value impossible */
SysTick->LOAD = (ticks & SYSTICK_MAXCOUNT) - 1; /* set reload register */
NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) - 1); /* set Priority for Cortex-M0 System Interrupts */
SysTick->VAL = (0x00); /* Load the SysTick Counter Value */
SysTick->CTRL = (1 << SYSTICK_CLKSOURCE) | (1<<SYSTICK_ENABLE) | (1<<SYSTICK_TICKINT); /* Enable SysTick IRQ and SysTick Timer */
return (0); /* Function successful */
}你看看这个,SYSTICK_MAXCOUNT 是多少,超过的话就一直while(1)了。
嗯嗯、f072,时钟48m,定时10us没问题,但定时到1us时就出事了
出什么事了?实际超过了1us的延时?定时器不工作了?程序死了?
查过、我觉得定时1us是定时器就不正常了
很简单的代码、10us跟1us就差一个数量级、结果就不工作了
定时器不工作
定时器定时总比软件定时精确把、您说的是内部晶振产生的时钟频率不精确把?