Align HAL & US tickers

pull/4809/head
Wolfgang Betz 2017-07-25 11:50:50 +02:00
parent 953b9250f1
commit 4fe8e8ca44
4 changed files with 15 additions and 31 deletions

View File

@ -161,15 +161,15 @@ HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
return HAL_OK;
}
/* NOTE: must be called with interrupts disabled! */
void HAL_SuspendTick(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_DISABLE_IT(&TimMasterHandle, TIM_IT_CC2);
}
/* NOTE: must be called with interrupts disabled! */
void HAL_ResumeTick(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_ENABLE_IT(&TimMasterHandle, TIM_IT_CC2);
}

View File

@ -131,15 +131,15 @@ HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
return HAL_OK;
}
/* NOTE: must be called with interrupts disabled! */
void HAL_SuspendTick(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_DISABLE_IT(&TimMasterHandle, TIM_IT_CC2);
}
/* NOTE: must be called with interrupts disabled! */
void HAL_ResumeTick(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_ENABLE_IT(&TimMasterHandle, TIM_IT_CC2);
}

View File

@ -26,22 +26,13 @@ TIM_HandleTypeDef TimMasterHandle;
volatile uint32_t SlaveCounter = 0;
volatile uint32_t oc_int_part = 0;
static int us_ticker_inited = 0;
void us_ticker_init(void)
{
if (us_ticker_inited) return;
us_ticker_inited = 1;
TimMasterHandle.Instance = TIM_MST;
HAL_InitTick(0); // The passed value is not used
/* NOTE: assuming that HAL tick has already been initialized! */
}
uint32_t us_ticker_read()
{
if (!us_ticker_inited) us_ticker_init();
uint16_t cntH_old, cntH, cntL;
do {
cntH_old = SlaveCounter;
@ -73,7 +64,7 @@ void us_ticker_set_interrupt(timestamp_t timestamp)
{
// NOTE: This function must be called with interrupts disabled to keep our
// timer interrupt setup atomic
TimMasterHandle.Instance = TIM_MST;
// Set new output compare value
__HAL_TIM_SET_COMPARE(&TimMasterHandle, TIM_CHANNEL_1, timestamp & 0xFFFF);
// Ensure the compare event starts clear
@ -178,19 +169,18 @@ void us_ticker_set_interrupt(timestamp_t timestamp)
void us_ticker_fire_interrupt(void)
{
TimMasterHandle.Instance = TIM_MST;
HAL_TIM_GenerateEvent(&TimMasterHandle, TIM_EVENTSOURCE_CC1);
}
/* NOTE: must be called with interrupts disabled! */
void us_ticker_disable_interrupt(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_DISABLE_IT(&TimMasterHandle, TIM_IT_CC1);
}
/* NOTE: must be called with interrupts disabled! */
void us_ticker_clear_interrupt(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_CLEAR_FLAG(&TimMasterHandle, TIM_FLAG_CC1);
}

View File

@ -23,27 +23,21 @@
TIM_HandleTypeDef TimMasterHandle;
static int us_ticker_inited = 0;
void us_ticker_init(void)
{
if (us_ticker_inited) return;
us_ticker_inited = 1;
TimMasterHandle.Instance = TIM_MST;
HAL_InitTick(0); // The passed value is not used
/* NOTE: assuming that HAL tick has already been initialized! */
}
uint32_t us_ticker_read()
{
if (!us_ticker_inited) us_ticker_init();
return TIM_MST->CNT;
}
void us_ticker_set_interrupt(timestamp_t timestamp)
{
TimMasterHandle.Instance = TIM_MST;
// NOTE: This function must be called with interrupts disabled to keep our
// timer interrupt setup atomic
// disable IT while we are handling the correct timestamp
__HAL_TIM_DISABLE_IT(&TimMasterHandle, TIM_IT_CC1);
// Set new output compare value
@ -57,16 +51,16 @@ void us_ticker_fire_interrupt(void)
LL_TIM_GenerateEvent_CC1(TimMasterHandle.Instance);
}
/* NOTE: must be called with interrupts disabled! */
void us_ticker_disable_interrupt(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_DISABLE_IT(&TimMasterHandle, TIM_IT_CC1);
}
/* NOTE: must be called with interrupts disabled! */
void us_ticker_clear_interrupt(void)
{
TimMasterHandle.Instance = TIM_MST;
__HAL_TIM_CLEAR_IT(&TimMasterHandle, TIM_IT_CC1);
__HAL_TIM_CLEAR_FLAG(&TimMasterHandle, TIM_FLAG_CC1);
}
#endif // !TIM_MST_16BIT