2023-06-13 15:56:24 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 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 cpu_msp430
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Cortex CMSIS style definition of MSP430 registers
|
|
|
|
*
|
|
|
|
* @todo This file is incomplete, not all registers are listed. Further
|
|
|
|
* There are probably some inconsistencies throughout the MSP430
|
|
|
|
* family which need to be addressed.
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MSP430_REGS_COMMON_H
|
|
|
|
#define MSP430_REGS_COMMON_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Shortcut to specify 8-bit wide registers
|
|
|
|
*/
|
|
|
|
#define REG8 volatile uint8_t
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Shortcut to specify 16-bit wide registers
|
|
|
|
*/
|
|
|
|
#define REG16 volatile uint16_t
|
|
|
|
|
|
|
|
/**
|
2023-06-14 16:18:15 +02:00
|
|
|
* @name Timer SSEL Values
|
|
|
|
*
|
|
|
|
* @details When using the macros in the vendor header files such as TASSEL_0
|
|
|
|
* the actually used clock is non-obvious. Hence, provide aliases
|
|
|
|
* with obvious names.
|
|
|
|
* @{
|
2023-06-13 15:56:24 +02:00
|
|
|
*/
|
2023-06-14 16:18:15 +02:00
|
|
|
#define TXSSEL_TXCLK TASSEL_0 /**< External TxCLK as clock source */
|
|
|
|
#define TXSSEL_ACLK TASSEL_1 /**< Auxiliary clock as clock source */
|
|
|
|
#define TXSSEL_SMCLK TASSEL_2 /**< Sub-system master clock as clock source */
|
|
|
|
#define TXSSEL_INCLK TASSEL_3 /**< External INCLK as clock source */
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Timer Input Divider Values
|
|
|
|
*
|
|
|
|
* @details The vendor header macros are again non-obvious in their naming, so
|
2023-12-06 20:33:41 +01:00
|
|
|
* provide better alias names.
|
2023-06-14 16:18:15 +02:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define TXID_DIV_1 ID_0 /**< Input Divider: Divide by 1 */
|
|
|
|
#define TXID_DIV_2 ID_1 /**< Input Divider: Divide by 2 */
|
|
|
|
#define TXID_DIV_4 ID_2 /**< Input Divider: Divide by 4 */
|
2023-12-06 20:33:41 +01:00
|
|
|
#define TXID_DIV_8 ID_3 /**< Input Divider: Divide by 8 */
|
|
|
|
#define TXID_DIV_Msk ID_3 /**< Mask to get the TXID field */
|
|
|
|
#define TXID_DIV_Pos 6U /**< Position of the TXID field */
|
|
|
|
#define TXID_DIV_MAX 3 /**< Maximum configuration value in the TXID field */
|
2023-06-14 16:18:15 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Timer Mode Control Values
|
|
|
|
*
|
|
|
|
* @details The vendor header macros are again non-obvious in their naming, so
|
|
|
|
* provide better alies names.
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define TXMC_STOP MC_0 /**< Stop Mode */
|
|
|
|
#define TXMC_UP MC_1 /**< Up to CCR0 Mode*/
|
|
|
|
#define TXMC_CONT MC_2 /**< Continuous Mode */
|
|
|
|
#define TXMC_UP_DOWN MC_3 /**< Up/Down Mode */
|
|
|
|
#define TXMC_MASK MC_3 /**< Bitmask to retrieve MC field */
|
|
|
|
/** @} */
|
2023-06-13 15:56:24 +02:00
|
|
|
|
|
|
|
/**
|
2023-06-14 16:18:15 +02:00
|
|
|
* @brief Common MSP GPIO Port Registers
|
2023-06-13 15:56:24 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
REG8 IN; /**< input data */
|
|
|
|
REG8 OD; /**< output data */
|
|
|
|
REG8 DIR; /**< pin direction */
|
2023-12-06 17:03:39 +01:00
|
|
|
} msp430_port_t;
|
2023-06-13 15:56:24 +02:00
|
|
|
|
2023-06-14 16:18:15 +02:00
|
|
|
/**
|
|
|
|
* @brief GPIO Port 3..6 (without interrupt functionality)
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2023-12-06 17:03:39 +01:00
|
|
|
msp430_port_t base; /**< common GPIO port registers */
|
2023-06-14 16:18:15 +02:00
|
|
|
REG8 SEL; /**< alternative function select */
|
2023-12-06 17:03:39 +01:00
|
|
|
} msp430_port_p3_p6_t;
|
2023-06-14 16:18:15 +02:00
|
|
|
|
2023-06-13 15:56:24 +02:00
|
|
|
/**
|
2023-12-06 20:33:41 +01:00
|
|
|
* @brief Timer peripheral registers
|
|
|
|
*
|
|
|
|
* @note The TIMER_A timer only has 3 CC channels instead of the 8 channels
|
|
|
|
* the TIMER_B has, the memory layout is the same nonetheless.
|
2023-06-13 15:56:24 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
REG16 CTL; /**< timer control */
|
|
|
|
REG16 CCTL[7]; /**< capture compare channel control */
|
|
|
|
REG16 R; /**< current counter value */
|
|
|
|
REG16 CCR[7]; /**< capture compare channel values */
|
2023-12-06 17:03:39 +01:00
|
|
|
} msp430_timer_t;
|
2023-06-13 15:56:24 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* MSP430_REGS_COMMON_H */
|
|
|
|
/** @} */
|