|
|
|
@ -2,6 +2,7 @@ |
|
|
|
|
// Created by MightyPork on 2018/01/02.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
#include <stm32f072xb.h> |
|
|
|
|
#include "platform.h" |
|
|
|
|
#include "comm/messages.h" |
|
|
|
|
#include "unit_base.h" |
|
|
|
@ -483,21 +484,11 @@ static error_t UUSART_init(Unit *unit) |
|
|
|
|
configure_gpio_alternate( mappings[5].port, mappings[5].pin, mappings[5].af); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (priv->periph_num == 1) { |
|
|
|
|
__HAL_RCC_USART1_CLK_ENABLE(); |
|
|
|
|
} else if (priv->periph_num == 2) { |
|
|
|
|
__HAL_RCC_USART2_CLK_ENABLE(); |
|
|
|
|
} else if (priv->periph_num == 3) { |
|
|
|
|
__HAL_RCC_USART3_CLK_ENABLE(); |
|
|
|
|
} else if (priv->periph_num == 4) { |
|
|
|
|
__HAL_RCC_USART4_CLK_ENABLE(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
LL_USART_Disable(priv->periph); |
|
|
|
|
{ |
|
|
|
|
LL_USART_DeInit(priv->periph); |
|
|
|
|
LL_USART_SetBaudRate(priv->periph, |
|
|
|
|
PLAT_AHB_MHZ/2,//FIXME this isn't great ...
|
|
|
|
|
PLAT_AHB_MHZ*1000000,//FIXME this isn't great ...
|
|
|
|
|
LL_USART_OVERSAMPLING_16, |
|
|
|
|
priv->baudrate); |
|
|
|
|
|
|
|
|
@ -579,18 +570,7 @@ static void UUSART_deInit(Unit *unit) |
|
|
|
|
// de-init the pins & peripheral only if inited correctly
|
|
|
|
|
if (unit->status == E_SUCCESS) { |
|
|
|
|
assert_param(priv->periph); |
|
|
|
|
|
|
|
|
|
LL_USART_DeInit(priv->periph); |
|
|
|
|
|
|
|
|
|
if (priv->periph_num == 1) { |
|
|
|
|
__HAL_RCC_USART1_CLK_DISABLE(); |
|
|
|
|
} else if (priv->periph_num == 2) { |
|
|
|
|
__HAL_RCC_USART2_CLK_DISABLE(); |
|
|
|
|
} else if (priv->periph_num == 3) { |
|
|
|
|
__HAL_RCC_USART3_CLK_DISABLE(); |
|
|
|
|
} else if (priv->periph_num == 4) { |
|
|
|
|
__HAL_RCC_USART4_CLK_DISABLE(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Release all resources
|
|
|
|
@ -603,6 +583,30 @@ static void UUSART_deInit(Unit *unit) |
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
static error_t usart_wait_until_flag(struct priv *priv, uint32_t flag, bool stop_state) |
|
|
|
|
{ |
|
|
|
|
uint32_t t_start = HAL_GetTick(); |
|
|
|
|
while (((priv->periph->ISR & flag) != 0) != stop_state) { |
|
|
|
|
if (HAL_GetTick() - t_start > 10) { |
|
|
|
|
dbg("ERR waiting for ISR flag 0x%p = %d", (void*)flag, (int)stop_state); |
|
|
|
|
return E_HW_TIMEOUT; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
return E_SUCCESS; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
static error_t sync_send(struct priv *priv, const uint8_t *buf, uint32_t len) |
|
|
|
|
{ |
|
|
|
|
while (len > 0) { |
|
|
|
|
TRY(usart_wait_until_flag(priv, USART_ISR_TXE, 1)); |
|
|
|
|
priv->periph->TDR = *buf++; |
|
|
|
|
len--; |
|
|
|
|
} |
|
|
|
|
TRY(usart_wait_until_flag(priv, USART_ISR_TC, 1)); |
|
|
|
|
return E_SUCCESS; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
enum PinCmd_ { |
|
|
|
|
CMD_WRITE = 0, |
|
|
|
|
}; |
|
|
|
@ -610,9 +614,22 @@ enum PinCmd_ { |
|
|
|
|
/** Handle a request message */ |
|
|
|
|
static error_t UUSART_handleRequest(Unit *unit, TF_ID frame_id, uint8_t command, PayloadParser *pp) |
|
|
|
|
{ |
|
|
|
|
struct priv *priv = unit->data; |
|
|
|
|
|
|
|
|
|
switch (command) { |
|
|
|
|
case CMD_WRITE: |
|
|
|
|
return E_NOT_IMPLEMENTED; |
|
|
|
|
dbg("Tx req. CR1 0x%p, CR2 0x%p, CR3 0x%p, BRR 0x%p", |
|
|
|
|
(void*)priv->periph->CR1, |
|
|
|
|
(void*)priv->periph->CR2, |
|
|
|
|
(void*)priv->periph->CR3, |
|
|
|
|
(void*)priv->periph->BRR); |
|
|
|
|
|
|
|
|
|
uint32_t len; |
|
|
|
|
const uint8_t *pld = pp_tail(pp, &len); |
|
|
|
|
|
|
|
|
|
TRY(sync_send(priv, pld, len)); |
|
|
|
|
return E_SUCCESS; |
|
|
|
|
//return E_NOT_IMPLEMENTED;
|
|
|
|
|
|
|
|
|
|
default: |
|
|
|
|
return E_UNKNOWN_COMMAND; |
|
|
|
|