高精度定时器

static struct hrtimer timer;
ktime_t kt;
static unsigned int interval=1000; /* unit: 1ms */ 

static enum hrtimer_restart hrtimer_handler(struct hrtimer *timer)
{
    nuc977_pin_ctrl();
    
    hrtimer_forward(timer, timer->base->get_time(), kt);

    return HRTIMER_RESTART;
}

static void init_htimer( void ) 
{
    kt = ktime_set( interval/1000000, (interval%1000000)*1000 );  
    hrtimer_init(&timer, CLOCK_MONOTONIC, HRTIMER_MODE_REL);
    timer.function = hrtimer_handler;
	hrtimer_start(&timer, kt, HRTIMER_MODE_REL);
}

static void exit_htimer(void)
{
    int ret;

    ret = hrtimer_cancel(&timer);
    if (ret)
        printk("nuc977_scuart:exit_htimer() hTimer was still in use...\n");
    printk("nuc977_scuart: exit_htimer().\n");  
}

 

一个串口驱动使用到了高精度定时器,运行了几年,一直没有问题,最近在做停上电实验,驱动在动态加载之后导致内核崩溃...最终查找到问题是由于使用高精度内核定时器的流程问题

    kt = ktime_set( interval/1000000, (interval%1000000)*1000 );  
    hrtimer_init(&timer, CLOCK_MONOTONIC, HRTIMER_MODE_REL);

    //启动高精度定时器
    hrtimer_start(&timer, kt, HRTIMER_MODE_REL);

    //绑定高精度的回调函数
    timer.function = hrtimer_handler;

然而就是在启动高精度定时器和绑定高精度回调函数之前出现了内核资源调度的切换、抢占,导致内核崩溃!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值