2014-08-27 18:47:31 +02:00
|
|
|
/*
|
2014-04-28 14:28:34 +02:00
|
|
|
* Copyright (C) 2014 Freie Universitaet Berlin (FUB) and INRIA. All rights reserved.
|
2014-08-27 18:47:31 +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.
|
|
|
|
*/
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-04-28 14:28:34 +02:00
|
|
|
/**
|
|
|
|
* @ingroup cpu
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* @brief msp430 hardware timer driver definitions
|
|
|
|
*
|
|
|
|
* @author Freie Universitaet Berlin, Computer Systems and Telematics group
|
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
|
|
|
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
#ifndef __HWTIMER_CPU_H
|
|
|
|
#define __HWTIMER_CPU_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2013-12-09 11:12:39 +01:00
|
|
|
#include "cpu.h"
|
|
|
|
|
2014-10-13 10:53:20 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-04-28 14:28:34 +02:00
|
|
|
#if defined (__MSP430_HAS_TA2__)
|
|
|
|
#define TIMER_A_MAXCOMP 2
|
|
|
|
#elif defined (__MSP430_HAS_TA3__)
|
|
|
|
#define TIMER_A_MAXCOMP 3
|
|
|
|
#elif defined (__MSP430_HAS_T0A5__)
|
|
|
|
#define TIMER_A_MAXCOMP 5
|
|
|
|
#else
|
|
|
|
#define TIMER_A_MAXCOMP 0
|
2010-09-22 15:10:42 +02:00
|
|
|
#endif
|
2010-12-08 12:16:49 +01:00
|
|
|
|
2014-04-28 14:55:38 +02:00
|
|
|
#if defined (__MSP430_HAS_TB3__)
|
|
|
|
#define TIMER_B_MAXCOMP 3
|
|
|
|
#elif defined (__MSP430_HAS_TB7__)
|
|
|
|
#define TIMER_B_MAXCOMP 7
|
|
|
|
#else
|
|
|
|
#define TIMER_B_MAXCOMP 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define HWTIMER_MAXTIMERS (TIMER_A_MAXCOMP + TIMER_B_MAXCOMP)
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-03-21 17:31:55 +01:00
|
|
|
#ifndef HWTIMER_MAXTIMERS
|
|
|
|
#warning "HWTIMER_MAXTIMERS UNSET!"
|
2014-04-28 14:28:34 +02:00
|
|
|
#define HWTIMER_MAXTIMERS 0
|
2010-09-22 15:10:42 +02:00
|
|
|
#endif
|
|
|
|
|
2014-04-28 14:28:34 +02:00
|
|
|
typedef struct {
|
|
|
|
enum {
|
|
|
|
TIMER_A,
|
|
|
|
TIMER_B,
|
|
|
|
} base_timer;
|
|
|
|
uint8_t ccr_num;
|
|
|
|
} msp430_timer_t;
|
|
|
|
|
2013-08-19 19:00:09 +02:00
|
|
|
#define HWTIMER_SPEED (F_RC_OSCILLATOR)
|
2014-08-27 10:25:46 +02:00
|
|
|
#define HWTIMER_MAXTICKS (0x0000FFFF)
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-10-13 10:53:20 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
#endif // __HWTIMER_CPU_H
|