Merge branch 'integration-changes'
This commit is contained in:
@ -41,6 +41,7 @@
|
||||
/* Private define ------------------------------------------------------------*/
|
||||
/* USER CODE BEGIN PD */
|
||||
#define TIM_BASE_FREQ 96000000UL
|
||||
#define WSS_HISTORY_SIZE 10
|
||||
/* USER CODE END PD */
|
||||
|
||||
/* Private macro -------------------------------------------------------------*/
|
||||
@ -69,6 +70,9 @@ TIM_HandleTypeDef* PWM_TIM_MAP[3] = {&htim1, &htim4, &htim3};
|
||||
static uint8_t pwm_ch_active[8];
|
||||
|
||||
static uint16_t wss_flanks[2];
|
||||
static uint16_t wss_flanks_avg[2];
|
||||
static uint8_t wss_flanks_history[2][WSS_HISTORY_SIZE];
|
||||
static uint8_t wss_flanks_history_idx[2]; // index of the oldest entry (next to be overwritten)
|
||||
/* USER CODE END PV */
|
||||
|
||||
/* Private function prototypes -----------------------------------------------*/
|
||||
@ -86,10 +90,16 @@ void send_latest_can() {
|
||||
tx_counter++;
|
||||
|
||||
for (int di = 0; di < NUM_DIO_PINS; di++) {
|
||||
dio_values[di] = HAL_GPIO_ReadPin(
|
||||
uint8_t value = HAL_GPIO_ReadPin(
|
||||
DIO_PIN_MAP[di].port,
|
||||
DIO_PIN_MAP[di].pin
|
||||
);
|
||||
|
||||
if (DIO_LATCHING[di]) {
|
||||
dio_values[di] |= value;
|
||||
} else {
|
||||
dio_values[di] = value;
|
||||
}
|
||||
}
|
||||
|
||||
for (int pi = 0; pi < NUM_TX_PKT; pi++) {
|
||||
@ -112,6 +122,7 @@ void send_latest_can() {
|
||||
switch (signal->type) {
|
||||
case DIN:
|
||||
value = dio_values[signal->channel];
|
||||
dio_values[signal->channel] = 0; // will be overwritten with real value at start of 1kHz loop
|
||||
break;
|
||||
|
||||
case AIN:
|
||||
@ -119,8 +130,21 @@ void send_latest_can() {
|
||||
break;
|
||||
|
||||
case FIN:
|
||||
value = wss_flanks[signal->channel];
|
||||
uint8_t oldest_hist_idx = wss_flanks_history_idx[signal->channel];
|
||||
// subtract oldest entry from avg
|
||||
wss_flanks_avg[signal->channel] -= wss_flanks_history[signal->channel][oldest_hist_idx];
|
||||
// overwrite oldest history entry with new value and reset counter
|
||||
wss_flanks_history[signal->channel][oldest_hist_idx] = wss_flanks[signal->channel];
|
||||
wss_flanks[signal->channel] = 0;
|
||||
// add new counter to avg
|
||||
wss_flanks_avg[signal->channel] += wss_flanks_history[signal->channel][oldest_hist_idx];
|
||||
// increase / wrap around index
|
||||
wss_flanks_history_idx[signal->channel]++;
|
||||
if(wss_flanks_history_idx[signal->channel] >= WSS_HISTORY_SIZE) {
|
||||
wss_flanks_history_idx[signal->channel] = 0;
|
||||
}
|
||||
// value = wss_flanks_avg[signal->channel] * (1000 / pktinfo->period / WSS_HISTORY_SIZE);
|
||||
value = wss_flanks_avg[signal->channel];
|
||||
break;
|
||||
|
||||
default:
|
||||
@ -132,9 +156,11 @@ void send_latest_can() {
|
||||
|
||||
}
|
||||
|
||||
if (HAL_FDCAN_AddMessageToTxFifoQ(hMainCAN, &txHeader, (uint8_t*) &txData) != HAL_OK)
|
||||
Error_Handler();
|
||||
|
||||
if (HAL_FDCAN_AddMessageToTxFifoQ(hMainCAN, &txHeader, (uint8_t*) &txData) != HAL_OK) {
|
||||
if(HAL_FDCAN_GetError(hMainCAN) != HAL_FDCAN_ERROR_FIFO_FULL) {
|
||||
Error_Handler_Led(1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (tx_counter >= 256) {
|
||||
@ -207,10 +233,10 @@ int main(void)
|
||||
hPeriCAN = &hfdcan2;
|
||||
|
||||
if (HAL_ADCEx_Calibration_Start(&hadc1, ADC_CALIB_OFFSET, ADC_SINGLE_ENDED) != HAL_OK)
|
||||
Error_Handler();
|
||||
Error_Handler_Led(2);
|
||||
|
||||
if (HAL_ADC_Start_DMA(&hadc1, (uint32_t*)adc_values, NUM_ADC_PINS) != HAL_OK)
|
||||
Error_Handler();
|
||||
Error_Handler_Led(2);
|
||||
|
||||
HAL_TIM_Base_Start_IT(&htim6);
|
||||
|
||||
@ -227,11 +253,11 @@ int main(void)
|
||||
txHeader.DataLength = 8;
|
||||
|
||||
if (HAL_FDCAN_ActivateNotification(hMainCAN, FDCAN_IT_RX_FIFO0_NEW_MESSAGE, 0) != HAL_OK)
|
||||
Error_Handler();
|
||||
Error_Handler_Led(3);
|
||||
|
||||
if (HAL_FDCAN_ConfigGlobalFilter(hMainCAN, FDCAN_REJECT, FDCAN_REJECT,
|
||||
FDCAN_REJECT_REMOTE, FDCAN_REJECT_REMOTE) != HAL_OK)
|
||||
Error_Handler();
|
||||
Error_Handler_Led(3);
|
||||
|
||||
FDCAN_FilterTypeDef filter;
|
||||
filter.IdType = FDCAN_STANDARD_ID;
|
||||
@ -242,10 +268,10 @@ int main(void)
|
||||
filter.FilterID2 = CAN_PWM_FILTER_MASK;
|
||||
|
||||
if (HAL_FDCAN_ConfigFilter(hMainCAN, &filter) != HAL_OK)
|
||||
Error_Handler();
|
||||
Error_Handler_Led(5);
|
||||
|
||||
if (HAL_FDCAN_Start(hMainCAN) != HAL_OK)
|
||||
Error_Handler();
|
||||
Error_Handler_Led(5);
|
||||
|
||||
// Init all channels as stopped
|
||||
memset(pwm_ch_active, 0, 8);
|
||||
@ -256,6 +282,10 @@ int main(void)
|
||||
|
||||
tx_counter = 0;
|
||||
|
||||
memset(wss_flanks, 0, sizeof(wss_flanks));
|
||||
memset(wss_flanks_avg, 0, sizeof(wss_flanks));
|
||||
memset(wss_flanks_history, 0, sizeof(wss_flanks_history));
|
||||
memset(wss_flanks_history_idx, 0, sizeof(wss_flanks_history_idx));
|
||||
/* USER CODE END 2 */
|
||||
|
||||
/* Infinite loop */
|
||||
@ -317,7 +347,7 @@ void SystemClock_Config(void)
|
||||
RCC_OscInitStruct.PLL.PLLFRACN = 0;
|
||||
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
|
||||
{
|
||||
Error_Handler();
|
||||
Error_Handler_Led(4);
|
||||
}
|
||||
|
||||
/** Initializes the CPU, AHB and APB buses clocks
|
||||
@ -335,7 +365,7 @@ void SystemClock_Config(void)
|
||||
|
||||
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
|
||||
{
|
||||
Error_Handler();
|
||||
Error_Handler_Led(4);
|
||||
}
|
||||
}
|
||||
|
||||
@ -476,6 +506,49 @@ void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin)
|
||||
HAL_ResumeTick();
|
||||
}
|
||||
|
||||
void Error_Handler_Led(uint8_t err) {
|
||||
HAL_GPIO_WritePin(STATUS_R_GPIO_Port, STATUS_R_Pin, GPIO_PIN_RESET);
|
||||
HAL_GPIO_WritePin(STATUS_G_GPIO_Port, STATUS_G_Pin, GPIO_PIN_RESET);
|
||||
HAL_GPIO_WritePin(STATUS_B_GPIO_Port, STATUS_B_Pin, GPIO_PIN_RESET);
|
||||
switch (err)
|
||||
{
|
||||
case 0: // red: general error
|
||||
HAL_GPIO_WritePin(STATUS_R_GPIO_Port, STATUS_R_Pin, GPIO_PIN_SET);
|
||||
break;
|
||||
|
||||
case 1: // red blue: in 1 kHz loop
|
||||
HAL_GPIO_WritePin(STATUS_R_GPIO_Port, STATUS_R_Pin, GPIO_PIN_SET);
|
||||
HAL_GPIO_WritePin(STATUS_B_GPIO_Port, STATUS_B_Pin, GPIO_PIN_SET);
|
||||
break;
|
||||
|
||||
case 2: // blue: ADC calibration or DMA start
|
||||
HAL_GPIO_WritePin(STATUS_B_GPIO_Port, STATUS_B_Pin, GPIO_PIN_SET);
|
||||
break;
|
||||
|
||||
case 3: // green blue: CAN notify and config gloabl filter
|
||||
HAL_GPIO_WritePin(STATUS_B_GPIO_Port, STATUS_B_Pin, GPIO_PIN_SET);
|
||||
HAL_GPIO_WritePin(STATUS_G_GPIO_Port, STATUS_G_Pin, GPIO_PIN_SET);
|
||||
break;
|
||||
|
||||
case 4: //red green: clock
|
||||
HAL_GPIO_WritePin(STATUS_R_GPIO_Port, STATUS_R_Pin, GPIO_PIN_SET);
|
||||
HAL_GPIO_WritePin(STATUS_G_GPIO_Port, STATUS_G_Pin, GPIO_PIN_SET);
|
||||
break;
|
||||
|
||||
case 5: // red green blue: CAN config filter and start
|
||||
HAL_GPIO_WritePin(STATUS_R_GPIO_Port, STATUS_R_Pin, GPIO_PIN_SET);
|
||||
HAL_GPIO_WritePin(STATUS_B_GPIO_Port, STATUS_B_Pin, GPIO_PIN_SET);
|
||||
HAL_GPIO_WritePin(STATUS_G_GPIO_Port, STATUS_G_Pin, GPIO_PIN_SET);
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
__disable_irq();
|
||||
while (1);
|
||||
}
|
||||
|
||||
/* USER CODE END 4 */
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user