Implement option byte writing and set brown out level
This commit is contained in:
parent
decb484d06
commit
eb41e5e210
@ -49,6 +49,7 @@
|
|||||||
#include <reflow-controller/temp-profile/temp-profile-executer.h>
|
#include <reflow-controller/temp-profile/temp-profile-executer.h>
|
||||||
#include <reflow-controller/settings/spi-eeprom.h>
|
#include <reflow-controller/settings/spi-eeprom.h>
|
||||||
#include <reflow-controller/main-cycle-counter.h>
|
#include <reflow-controller/main-cycle-counter.h>
|
||||||
|
#include <stm-periph/option-bytes.h>
|
||||||
|
|
||||||
static void setup_nvic_priorities(void)
|
static void setup_nvic_priorities(void)
|
||||||
{
|
{
|
||||||
@ -211,6 +212,35 @@ static inline void handle_boot_status(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Read out the option bytes of the STM32 and program them to the desired values.
|
||||||
|
*
|
||||||
|
* - This function currently forces the brown out level to Level 3.
|
||||||
|
*/
|
||||||
|
static void check_and_program_opt_bytes(void)
|
||||||
|
{
|
||||||
|
struct option_bytes opts;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
/** - Read option bytes */
|
||||||
|
stm_option_bytes_read(&opts);
|
||||||
|
|
||||||
|
|
||||||
|
if (opts.brown_out_level != 0) {
|
||||||
|
/* Set the brown out level to level 3 => highest brown out limit. */
|
||||||
|
opts.brown_out_level = 0;
|
||||||
|
/** - Program the option bytes if brown out level was not set correctly */
|
||||||
|
err = stm_option_bytes_program(&opts);
|
||||||
|
|
||||||
|
/** - If programming failes, enter panic mode */
|
||||||
|
if (err)
|
||||||
|
panic_mode();
|
||||||
|
|
||||||
|
/** - If programming is successful, reset the system to apply new settings */
|
||||||
|
NVIC_SystemReset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Setup the system.
|
* @brief Setup the system.
|
||||||
*
|
*
|
||||||
@ -220,6 +250,9 @@ static inline void setup_system(void)
|
|||||||
{
|
{
|
||||||
float tmp;
|
float tmp;
|
||||||
|
|
||||||
|
/** - Read the option bytes and if necessary program them to the desired values */
|
||||||
|
check_and_program_opt_bytes();
|
||||||
|
|
||||||
/** - Setup the NVIC priorities of the core peripherals using interrupts */
|
/** - Setup the NVIC priorities of the core peripherals using interrupts */
|
||||||
setup_nvic_priorities();
|
setup_nvic_priorities();
|
||||||
|
|
||||||
|
@ -21,6 +21,16 @@
|
|||||||
#include <stm-periph/option-bytes.h>
|
#include <stm-periph/option-bytes.h>
|
||||||
#include <stm32/stm32f4xx.h>
|
#include <stm32/stm32f4xx.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief First key for unlocking hte option byte write access
|
||||||
|
*/
|
||||||
|
#define FLASH_OPTION_KEY1 (0x08192A3BUL)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Second key for unlocking hte option byte write access
|
||||||
|
*/
|
||||||
|
#define FLASH_OPTION_KEY2 (0x4C5D6E7FUL)
|
||||||
|
|
||||||
void stm_option_bytes_read(struct option_bytes *opts)
|
void stm_option_bytes_read(struct option_bytes *opts)
|
||||||
{
|
{
|
||||||
uint32_t opt_reg;
|
uint32_t opt_reg;
|
||||||
@ -39,10 +49,42 @@ void stm_option_bytes_read(struct option_bytes *opts)
|
|||||||
|
|
||||||
int stm_option_bytes_program(const struct option_bytes *opts)
|
int stm_option_bytes_program(const struct option_bytes *opts)
|
||||||
{
|
{
|
||||||
FLASH->OPTKEYR = 0x08192A3BUL;
|
uint32_t reg;
|
||||||
FLASH->OPTKEYR = 0x4C5D6E7FUL;
|
|
||||||
|
|
||||||
|
FLASH->OPTKEYR = FLASH_OPTION_KEY1;
|
||||||
|
FLASH->OPTKEYR = FLASH_OPTION_KEY2;
|
||||||
|
|
||||||
|
__DSB();
|
||||||
|
|
||||||
|
if (FLASH->OPTCR & FLASH_OPTCR_OPTLOCK) {
|
||||||
|
/* Unlocking failed */
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
reg = FLASH->OPTCR;
|
||||||
|
reg &= ~FLASH_OPTCR_BOR_LEV;
|
||||||
|
reg &= ~FLASH_OPTCR_nRST_STDBY;
|
||||||
|
reg &= ~FLASH_OPTCR_nRST_STOP;
|
||||||
|
reg &= ~FLASH_OPTCR_nWRP;
|
||||||
|
reg &= ~FLASH_OPTCR_RDP;
|
||||||
|
reg &= ~FLASH_OPTCR_WDG_SW;
|
||||||
|
|
||||||
|
reg |= (opts->brown_out_level << 2) & FLASH_OPTCR_BOR_LEV;
|
||||||
|
reg |= (opts->nrst_standby << 7) & FLASH_OPTCR_nRST_STDBY;
|
||||||
|
reg |= (opts->nrst_stop << 6) & FLASH_OPTCR_nRST_STOP;
|
||||||
|
reg |= (opts->nwrpi << 16) & FLASH_OPTCR_nWRP;
|
||||||
|
reg |= (opts->read_protection << 8) & FLASH_OPTCR_RDP;
|
||||||
|
reg |= (opts->wdg_sw << 5) & FLASH_OPTCR_WDG_SW;
|
||||||
|
|
||||||
|
while (FLASH->SR & FLASH_SR_BSY);
|
||||||
|
|
||||||
|
FLASH->OPTCR = reg;
|
||||||
|
FLASH->OPTCR |= FLASH_OPTCR_OPTSTRT;
|
||||||
|
__DSB();
|
||||||
|
while (FLASH->SR & FLASH_SR_BSY);
|
||||||
|
|
||||||
FLASH->OPTCR |= FLASH_OPTCR_OPTLOCK;
|
FLASH->OPTCR |= FLASH_OPTCR_OPTLOCK;
|
||||||
|
|
||||||
|
__DSB();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user