/* Copyright 2021 The ChromiumOS Authors * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef __CROS_EC_STM32_FLASH_REGS_H #define __CROS_EC_STM32_FLASH_REGS_H #include /** * Unlock the flash control register using the unlock sequence. * * If the flash control register has been disabled since the last reset when * this function is called, a bus fault will be generated. * * See "3.5.1 Unlocking the Flash control register" in RM0402. * See "4.9.2 FLASH key register for bank 1" in RM0433. */ void unlock_flash_control_register(void); /** * Unlock the flash option bytes register using the unlock sequence. * * If the flash option bytes register has been disabled since the last reset * when this function is called, a bus fault will be generated. * * See "3.6.2 Programming user option bytes" in RM0402. * See "4.9.3 FLASH option key register" in RM0433. */ void unlock_flash_option_bytes(void); /** * Lock the flash control register. * * If the flash control register has been disabled since the last reset when * this function is called, a bus fault will be generated. * * See "3.5.1 Unlocking the Flash control register" in RM0402. * See "4.9.4 Flash control register for bank 1" in RM0433. */ void lock_flash_control_register(void); /** * Lock the flash option bytes register. * * If the flash option bytes register has been disabled since the last reset * when this function is called, a bus fault will be generated. * * See "3.6.2 Programming user option bytes" in RM0402. * See "4.9.7 FLASH option control register" in RM0433. */ void lock_flash_option_bytes(void); /** * Disable the flash option bytes register. * * This function expects that bus faults have not already been ignored when * called. * * Once this function is called any attempt at accessing the flash option * bytes register will generate a bus fault until the next reset. * * See "3.6.2 Programming user option bytes" in RM0402. * See "4.9.7 FLASH option control register" in RM0433. */ void disable_flash_option_bytes(void); /** * Disable the flash control register. * * This function expects that bus faults have not already been ignored when * called. * * Once this function is called any attempt at accessing the flash control * register will generate a bus fault until the next reset. * * See "3.5.1 Unlocking the Flash control register" in RM0402. * See "4.9.4 Flash control register for bank 1" in RM0433. */ void disable_flash_control_register(void); /** * Check if the flash option bytes are locked. * * If the flash option bytes register has been disabled since the last reset * when this function is called, a bus fault will be generated. * See "3.6.2 Programming user option bytes" in RM0402. * See "4.9.7 FLASH option control register" in RM0433. * * @return true if option bytes are locked, false otherwise */ bool flash_option_bytes_locked(void); /** * Check if the flash control register is locked. * * If the flash control register has been disabled since the last reset * when this function is called, a bus fault will be generated. * * See "3.5.1 Unlocking the Flash control register" in RM0402. * See "4.9.4 Flash control register for bank 1" in RM0433. * * @return true if register is locked, false otherwise */ bool flash_control_register_locked(void); #endif /* __CROS_EC_STM32_FLASH_REGS_H */