diff --git a/sys/Makefile b/sys/Makefile index 4d2bc7642c33a8bdd2e7ea82644744f83ad527a3..515cc1314803c5eaebd080ce6c8417e0f437bc25 100644 --- a/sys/Makefile +++ b/sys/Makefile @@ -137,6 +137,9 @@ endif ifneq (,$(filter ng_udp,$(USEMODULE))) DIRS += net/transport_layer/ng_udp endif +ifneq (,$(filter hwtimer_compat,$(USEMODULE))) + DIRS += compat/hwtimer +endif DIRS += $(dir $(wildcard $(addsuffix /Makefile, ${USEMODULE}))) diff --git a/sys/compat/Makefile b/sys/compat/Makefile new file mode 100644 index 0000000000000000000000000000000000000000..48422e909a47d7cd428d10fa73825060ccc8d8c2 --- /dev/null +++ b/sys/compat/Makefile @@ -0,0 +1 @@ +include $(RIOTBASE)/Makefile.base diff --git a/sys/compat/hwtimer/Makefile b/sys/compat/hwtimer/Makefile new file mode 100644 index 0000000000000000000000000000000000000000..316bf04d4792f2c4bc26528a5baa2adb4b162eef --- /dev/null +++ b/sys/compat/hwtimer/Makefile @@ -0,0 +1,3 @@ +MODULE = hwtimer_compat + +include $(RIOTBASE)/Makefile.base diff --git a/sys/compat/hwtimer/hwtimer_arch.c b/sys/compat/hwtimer/hwtimer_arch.c new file mode 100644 index 0000000000000000000000000000000000000000..0325e33026381c5da27052f5e2cb907166ed537a --- /dev/null +++ b/sys/compat/hwtimer/hwtimer_arch.c @@ -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)); +}