
4 changed files with 82 additions and 0 deletions
@ -0,0 +1,3 @@
|
||||
MODULE = hwtimer_compat
|
||||
|
||||
include $(RIOTBASE)/Makefile.base |
@ -0,0 +1,75 @@
|
||||
/*
|
||||
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de> |
||||
* 2014 Freie Universität Berlin |
||||
* |
||||
* |
||||
* This file is subject to the terms and conditions of the GNU Lesser |
||||
* General Public License v2.1. See the file LICENSE in the top level |
||||
* directory for more details. |
||||
*/ |
||||
|
||||
/**
|
||||
* @ingroup sys_compat |
||||
* @{ |
||||
* |
||||
* @file hwtimer_arch.c |
||||
* @brief Implementation of the kernels hwtimer interface over periph timers |
||||
* |
||||
* This hwtimer implementation wraps one periph timer |
||||
* |
||||
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de> |
||||
* @author Kaspar Schleiser <kaspar@schleiser.de> |
||||
* |
||||
* @} |
||||
*/ |
||||
|
||||
#include "arch/hwtimer_arch.h" |
||||
#include "board.h" |
||||
#include "periph/timer.h" |
||||
#include "thread.h" |
||||
|
||||
|
||||
void irq_handler(int channel); |
||||
void (*timeout_handler)(int); |
||||
|
||||
|
||||
void hwtimer_arch_init(void (*handler)(int), uint32_t fcpu) |
||||
{ |
||||
timeout_handler = handler; |
||||
timer_init(HW_TIMER, 1, &irq_handler); |
||||
} |
||||
|
||||
void hwtimer_arch_enable_interrupt(void) |
||||
{ |
||||
timer_irq_enable(HW_TIMER); |
||||
} |
||||
|
||||
void hwtimer_arch_disable_interrupt(void) |
||||
{ |
||||
timer_irq_disable(HW_TIMER); |
||||
} |
||||
|
||||
void hwtimer_arch_set(unsigned long offset, short timer) |
||||
{ |
||||
timer_set(HW_TIMER, timer, offset); |
||||
} |
||||
|
||||
void hwtimer_arch_set_absolute(unsigned long value, short timer) |
||||
{ |
||||
timer_set_absolute(HW_TIMER, timer, value); |
||||
} |
||||
|
||||
void hwtimer_arch_unset(short timer) |
||||
{ |
||||
timer_clear(HW_TIMER, timer); |
||||
} |
||||
|
||||
unsigned long hwtimer_arch_now(void) |
||||
{ |
||||
return timer_read(HW_TIMER); |
||||
} |
||||
|
||||
void irq_handler(int channel) |
||||
{ |
||||
timeout_handler((short)(channel)); |
||||
} |
Loading…
Reference in new issue