2014-03-17 17:59:06 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* 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.
|
2014-03-17 17:59:06 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:44:09 +02:00
|
|
|
* @ingroup core_arch
|
2014-03-17 17:59:06 +01:00
|
|
|
* @{
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-03-17 17:59:06 +01:00
|
|
|
* @file hwtimer_arch.h
|
|
|
|
* @brief The kernel's hardware timer abstraction interface
|
|
|
|
*
|
|
|
|
* @author Thomas Hillebrandt <hillebra@inf.fu-berlin.de>
|
|
|
|
* @author Heiko Will <hwill@inf.fu-berlin.de>
|
2014-07-09 21:08:13 +02:00
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
2014-03-17 17:59:06 +01:00
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef HWTIMER_ARCH_H_
|
|
|
|
#define HWTIMER_ARCH_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize architecture dependent kernel timer support
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-07-09 21:08:13 +02:00
|
|
|
* @param[in] handler callback that is called when timer offset is reached
|
|
|
|
* @param[in] fcpu the core CPU-frequency for tick interval calculation
|
2014-03-17 17:59:06 +01:00
|
|
|
*/
|
|
|
|
void hwtimer_arch_init(void (*handler)(int), uint32_t fcpu);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Enable interrupts of hardware timers
|
|
|
|
*/
|
|
|
|
void hwtimer_arch_enable_interrupt(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Disable interrupts of hardware timers
|
|
|
|
*/
|
|
|
|
void hwtimer_arch_disable_interrupt(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set a kernel timer to raise an interrupt after ::offset kernel timer
|
|
|
|
* ticks from now
|
|
|
|
*
|
|
|
|
* @param[in] offset number of ticks until the timer fires
|
|
|
|
* @param[in] timer the channel to set
|
|
|
|
*/
|
|
|
|
void hwtimer_arch_set(unsigned long offset, short timer);
|
|
|
|
|
2014-07-09 21:08:13 +02:00
|
|
|
/**
|
|
|
|
* @brief Set a kernel timer to raise an interrupt at specified system time.
|
|
|
|
*
|
|
|
|
* @param[in] value absolute timer tick value to set a timer channel to
|
|
|
|
* @param[in] timer the channel to set
|
|
|
|
*/
|
|
|
|
void hwtimer_arch_set_absolute(unsigned long value, short timer);
|
|
|
|
|
2014-03-17 17:59:06 +01:00
|
|
|
/**
|
|
|
|
* @brief Unset the kernel timer with the given timer ID
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-03-17 17:59:06 +01:00
|
|
|
* @param[in] timer the channel to unset
|
|
|
|
*/
|
|
|
|
void hwtimer_arch_unset(short timer);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the current tick count of the default hardware timer
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-03-17 17:59:06 +01:00
|
|
|
* @return the current value of the hwtimer
|
|
|
|
*/
|
|
|
|
unsigned long hwtimer_arch_now(void);
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* HWTIMER_ARCH_H_ */
|
|
|
|
/** @} */
|