2014-04-17 19:36:12 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
2014-07-31 19:45:27 +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-04-17 19:36:12 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup cpu_sam3x8e
|
|
|
|
* @{
|
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2014-04-17 19:36:12 +02:00
|
|
|
* @brief Implementation of the kernels hwtimer interface
|
|
|
|
*
|
|
|
|
* The hardware timer implementation uses the Cortex build-in system timer as back-end.
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2014-07-09 21:08:13 +02:00
|
|
|
#include "arch/hwtimer_arch.h"
|
2014-04-17 19:36:12 +02:00
|
|
|
#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)
|
|
|
|
{
|
2014-06-22 15:08:08 +02:00
|
|
|
timer_set_absolute(HW_TIMER, timer, value);
|
2014-04-17 19:36:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
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));
|
|
|
|
}
|