hwtimer_test.c 2.6 KB
Newer Older
H
heyuanjie87 已提交
1 2 3 4 5 6 7 8 9 10
#include <rtthread.h>
#include <rtdevice.h>
#include <finsh.h>

#ifdef RT_USING_HWTIMER

#define TIMER   "timer0"

static rt_err_t timer_timeout_cb(rt_device_t dev, rt_size_t size)
{
Z
zylx 已提交
11
    rt_kprintf("enter hardware timer isr\n");
H
heyuanjie87 已提交
12 13 14 15

    return 0;
}

H
heyuanjie87 已提交
16
int hwtimer(void)
H
heyuanjie87 已提交
17 18 19 20 21 22
{
    rt_err_t err;
    rt_hwtimerval_t val;
    rt_device_t dev = RT_NULL;
    rt_tick_t tick;
    rt_hwtimer_mode_t mode;
H
heyuanjie87 已提交
23 24
    int freq = 10000;
    int t = 5;
H
heyuanjie87 已提交
25 26 27 28 29 30 31 32 33 34

    if ((dev = rt_device_find(TIMER)) == RT_NULL)
    {
        rt_kprintf("No Device: %s\n", TIMER);
        return -1;
    }

    if (rt_device_open(dev, RT_DEVICE_OFLAG_RDWR) != RT_EOK)
    {
        rt_kprintf("Open %s Fail\n", TIMER);
H
heyuanjie87 已提交
35
        return -1;
H
heyuanjie87 已提交
36 37
    }

mysterywolf's avatar
mysterywolf 已提交
38 39
    /* 时间测量 */
    /* 计数时钟设置(默认1Mhz或支持的最小计数频率) */
H
heyuanjie87 已提交
40 41 42 43 44 45 46
    err = rt_device_control(dev, HWTIMER_CTRL_FREQ_SET, &freq);
    if (err != RT_EOK)
    {
        rt_kprintf("Set Freq=%dhz Fail\n", freq);
        goto EXIT;
    }

mysterywolf's avatar
mysterywolf 已提交
47
    /* 周期模式 */
H
heyuanjie87 已提交
48 49 50 51 52
    mode = HWTIMER_MODE_PERIOD;
    err = rt_device_control(dev, HWTIMER_CTRL_MODE_SET, &mode);

    tick = rt_tick_get();
    rt_kprintf("Start Timer> Tick: %d\n", tick);
mysterywolf's avatar
mysterywolf 已提交
53
    /* 设置定时器超时值并启动定时器 */
H
heyuanjie87 已提交
54 55 56 57 58 59 60 61 62 63 64
    val.sec = t;
    val.usec = 0;
    rt_kprintf("SetTime: Sec %d, Usec %d\n", val.sec, val.usec);
    if (rt_device_write(dev, 0, &val, sizeof(val)) != sizeof(val))
    {
        rt_kprintf("SetTime Fail\n");
        goto EXIT;
    }
    rt_kprintf("Sleep %d sec\n", t);
    rt_thread_delay(t*RT_TICK_PER_SECOND);

mysterywolf's avatar
mysterywolf 已提交
65
    /* 停止定时器 */
H
heyuanjie87 已提交
66 67
    err = rt_device_control(dev, HWTIMER_CTRL_STOP, RT_NULL);
    rt_kprintf("Timer Stoped\n");
mysterywolf's avatar
mysterywolf 已提交
68
    /* 读取计数 */
H
heyuanjie87 已提交
69 70 71
    rt_device_read(dev, 0, &val, sizeof(val));
    rt_kprintf("Read: Sec = %d, Usec = %d\n", val.sec, val.usec);

mysterywolf's avatar
mysterywolf 已提交
72 73
    /* 定时执行回调函数 -- 单次模式 */
    /* 设置超时回调函数 */
Z
zylx 已提交
74 75
    rt_device_set_rx_indicate(dev, timer_timeout_cb);

mysterywolf's avatar
mysterywolf 已提交
76
    /* 单次模式 */
Z
zylx 已提交
77 78 79
    mode = HWTIMER_MODE_PERIOD;
    err = rt_device_control(dev, HWTIMER_CTRL_MODE_SET, &mode);

mysterywolf's avatar
mysterywolf 已提交
80
    /* 设置定时器超时值并启动定时器 */
Z
zylx 已提交
81 82 83 84 85 86 87 88 89
    val.sec = t;
    val.usec = 0;
    rt_kprintf("SetTime: Sec %d, Usec %d\n", val.sec, val.usec);
    if (rt_device_write(dev, 0, &val, sizeof(val)) != sizeof(val))
    {
        rt_kprintf("SetTime Fail\n");
        goto EXIT;
    }

mysterywolf's avatar
mysterywolf 已提交
90
    /* 等待回调函数执行 */
Z
zylx 已提交
91 92
    rt_thread_delay((t + 1)*RT_TICK_PER_SECOND);

H
heyuanjie87 已提交
93 94 95 96 97 98
EXIT:
    err = rt_device_close(dev);
    rt_kprintf("Close %s\n", TIMER);

    return err;
}
Z
zylx 已提交
99 100
#ifdef FINSH_USING_MSH
MSH_CMD_EXPORT(hwtimer, "Test hardware timer");
H
heyuanjie87 已提交
101
#endif
Z
zylx 已提交
102
#endif /* RT_USING_HWTIMER */