#include "main.h" #include "lcd.h" #include "SST25VF016B.h" extern SPI_HandleTypeDef hspi1; void SST25VF016B_run_test(void) { DISPLAY_CLEAR; display_write_data_seq("SST25VF016B Flas"); HAL_StatusTypeDef op_result; size_t err_count = 0; uint8_t tx_buffer[8] = {0x90, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; uint8_t rx_buffer[9]; rx_buffer[8] = '\0'; HAL_GPIO_WritePin(GPIOD, GPIO_PIN_7, GPIO_PIN_SET); HAL_Delay(50); HAL_GPIO_WritePin(GPIOD, GPIO_PIN_7, GPIO_PIN_RESET); for (size_t t = 0; t < 5; t++) { op_result = HAL_SPI_TransmitReceive(&hspi1, tx_buffer, rx_buffer, 8, 2000); if (op_result) { err_count++; DISPLAY_CLEAR; display_write_data_seq("SST25VF016B Flas"); DISPLAY_SET_CURSOR(1, 0); display_write_data_byte('1' + t); display_write_data_seq("/5 "); switch (op_result) { case HAL_ERROR: display_write_data_seq("ERROR"); break; case HAL_BUSY: display_write_data_seq("BUSY"); break; case HAL_TIMEOUT: display_write_data_seq("TIMEOUT"); break; } HAL_Delay(2000); } else { break; } } HAL_GPIO_WritePin(GPIOD, GPIO_PIN_7, GPIO_PIN_SET); DISPLAY_CLEAR; display_write_data_seq("SST25VF016B Flas"); if (err_count) { DISPLAY_SET_CURSOR(1, 1); display_write_data_byte('0' + err_count % 10); display_write_data_seq(" Errors"); } else { DISPLAY_SET_CURSOR(1, 1); display_write_data_seq("OK"); DISPLAY_SET_CURSOR(1, 8); display_write_data_seq((char) rx_buffer); } }