2013-08-05 14:08:52 +00:00
|
|
|
/*
|
|
|
|
ChibiOS/RT - Copyright (C) 2006-2013 Giovanni Di Sirio
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file STM32/st_lld.h
|
|
|
|
* @brief ST Driver subsystem low level driver header.
|
2013-08-21 13:33:40 +00:00
|
|
|
* @details This header is designed to be include-able without having to
|
|
|
|
* include other files from the HAL.
|
2013-08-05 14:08:52 +00:00
|
|
|
*
|
|
|
|
* @addtogroup ST
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ST_LLD_H_
|
|
|
|
#define _ST_LLD_H_
|
|
|
|
|
2013-09-12 14:43:29 +00:00
|
|
|
#include "mcuconf.h"
|
2013-08-21 13:33:40 +00:00
|
|
|
#include "stm32_registry.h"
|
2013-08-19 14:26:38 +00:00
|
|
|
#include "stm32_tim.h"
|
|
|
|
|
2013-08-05 14:08:52 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver constants. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver pre-compile time settings. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2013-09-12 14:43:29 +00:00
|
|
|
/**
|
|
|
|
* @name Configuration options
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief SysTick timer IRQ priority.
|
|
|
|
*/
|
|
|
|
#if !defined(STM32_ST_IRQ_PRIORITY) || defined(__DOXYGEN__)
|
|
|
|
#define STM32_ST_IRQ_PRIORITY 8
|
|
|
|
#endif
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
/**
|
|
|
|
* @brief TIMx unit (by number) to be used for free running operations.
|
2013-09-12 13:57:51 +00:00
|
|
|
* @note You must select a 32 bits timer if a 32 bits @p systick_t type
|
|
|
|
* is required.
|
2013-09-12 13:33:12 +00:00
|
|
|
*/
|
|
|
|
#if !defined(STM32_ST_USE_TIMER) || defined(__DOXYGEN__)
|
|
|
|
#define STM32_ST_USE_TIMER 2
|
|
|
|
#endif
|
2013-09-12 14:43:29 +00:00
|
|
|
/** @} */
|
2013-09-12 13:33:12 +00:00
|
|
|
|
2013-08-05 14:08:52 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Derived constants and error checks. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
#if STM32_ST_USE_TIMER == 2
|
2013-09-12 13:57:51 +00:00
|
|
|
#if !STM32_HAS_TIM2
|
|
|
|
#error "TIM2 not present"
|
|
|
|
#endif
|
2013-09-12 13:33:12 +00:00
|
|
|
#define STM32_ST_TIM STM32_TIM2
|
|
|
|
|
2013-09-12 13:57:51 +00:00
|
|
|
#elif STM32_ST_USE_TIMER == 3
|
|
|
|
#if !STM32_HAS_TIM3
|
|
|
|
#error "TIM3 not present"
|
|
|
|
#endif
|
|
|
|
#define STM32_ST_TIM STM32_TIM3
|
2013-09-12 13:33:12 +00:00
|
|
|
|
2013-09-12 13:57:51 +00:00
|
|
|
#elif STM32_ST_USE_TIMER == 4
|
|
|
|
#if !STM32_HAS_TIM4
|
|
|
|
#error "TIM4 not present"
|
|
|
|
#endif
|
|
|
|
#define STM32_ST_TIM STM32_TIM4
|
2013-09-12 13:33:12 +00:00
|
|
|
|
2013-09-12 13:57:51 +00:00
|
|
|
#elif STM32_ST_USE_TIMER == 5
|
|
|
|
#if !STM32_HAS_TIM5
|
|
|
|
#error "TIM5 not present"
|
|
|
|
#endif
|
|
|
|
#define STM32_ST_TIM STM32_TIM5
|
2013-09-12 13:33:12 +00:00
|
|
|
|
2013-09-10 10:08:00 +00:00
|
|
|
#else
|
2013-09-12 13:33:12 +00:00
|
|
|
#error "STM32_ST_USE_TIMER specifies an unsupported timer"
|
2013-09-10 10:08:00 +00:00
|
|
|
#endif
|
|
|
|
|
2013-08-05 14:08:52 +00:00
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver data structures and types. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver macros. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* External declarations. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void st_lld_init(void);
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*===========================================================================*/
|
|
|
|
/* Driver inline functions. */
|
|
|
|
/*===========================================================================*/
|
|
|
|
|
2013-08-21 13:33:40 +00:00
|
|
|
/**
|
|
|
|
* @brief Returns the time counter value.
|
|
|
|
*
|
|
|
|
* @return The counter value.
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
static inline systime_t st_lld_get_counter(void) {
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
return (systime_t)STM32_ST_TIM->CNT;
|
2013-08-21 13:33:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Starts the alarm.
|
|
|
|
* @note Makes sure that no spurious alarms are triggered after
|
|
|
|
* this call.
|
|
|
|
*
|
|
|
|
* @param[in] time the time to be set for the first alarm
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
static inline void st_lld_start_alarm(systime_t time) {
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
STM32_ST_TIM->CCR[0] = (uint32_t)time;
|
|
|
|
STM32_ST_TIM->SR = 0;
|
|
|
|
STM32_ST_TIM->DIER = STM32_TIM_DIER_CC1IE;
|
2013-08-21 13:33:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Stops the alarm interrupt.
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
static inline void st_lld_stop_alarm(void) {
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
STM32_ST_TIM->DIER = 0;
|
2013-08-21 13:33:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets the alarm time.
|
|
|
|
*
|
|
|
|
* @param[in] time the time to be set for the next alarm
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
static inline void st_lld_set_alarm(systime_t time) {
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
STM32_ST_TIM->CCR[0] = (uint32_t)time;
|
2013-08-21 13:33:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the current alarm time.
|
|
|
|
*
|
|
|
|
* @return The currently set alarm time.
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
static inline systime_t st_lld_get_alarm(void) {
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
return (systime_t)STM32_ST_TIM->CCR[0];
|
2013-08-21 13:33:40 +00:00
|
|
|
}
|
2013-08-05 14:08:52 +00:00
|
|
|
|
2013-08-23 07:57:26 +00:00
|
|
|
/**
|
|
|
|
* @brief Determines if the alarm is active.
|
|
|
|
*
|
|
|
|
* @return The alarm status.
|
|
|
|
* @retval false if the alarm is not active.
|
|
|
|
* @retval true is the alarm is active
|
|
|
|
*
|
|
|
|
* @notapi
|
|
|
|
*/
|
|
|
|
static inline bool st_lld_is_alarm_active(void) {
|
|
|
|
|
2013-09-12 13:33:12 +00:00
|
|
|
return (bool)((STM32_ST_TIM->DIER & STM32_TIM_DIER_CC1IE) != 0);
|
2013-08-23 07:57:26 +00:00
|
|
|
}
|
|
|
|
|
2013-08-05 14:08:52 +00:00
|
|
|
#endif /* _ST_LLD_H_ */
|
|
|
|
|
|
|
|
/** @} */
|