30 #if !defined(__CONTEXT_H__) 33 #include "bootloader_common.h" 34 #include "bootloader/bl_peripheral.h" 35 #include "memory/memory.h" 36 #include "packet/command_packet.h" 37 #include "bootloader/bl_command.h" 38 #include "property/property.h" 40 #if !defined(BOOTLOADER_HOST) 41 #include "flash/fsl_flash.h" 42 #if BL_FEATURE_ENCRYPTION 43 #include "security/aes_security.h" 44 #endif // #if BL_FEATURE_ENCRYPTION 45 #endif // #if !defined(BOOTLOADER_HOST) 54 #if !defined(BOOTLOADER_HOST) 57 typedef struct FlashDriverInterface
70 uint32_t lengthInBytes,
74 uint32_t lengthInBytes,
75 const uint32_t *expectedData,
77 uint32_t *failedAddress,
78 uint32_t *failedData);
81 status_t (*flash_program_once)(
flash_config_t *config, uint32_t index, uint32_t *src, uint32_t lengthInBytes);
82 status_t (*flash_read_once)(
flash_config_t *config, uint32_t index, uint32_t *dst, uint32_t lengthInBytes);
86 uint32_t lengthInBytes,
91 uint32_t lengthInBytes,
96 status_t (*flash_program_section)(
flash_config_t *config, uint32_t start, uint32_t *src, uint32_t lengthInBytes);
100 typedef struct AesDriverInterface
103 void (*
aes_encrypt)(uint32_t *in, uint32_t *key, uint32_t *out);
104 void (*
aes_decrypt)(uint32_t *in, uint32_t *key, uint32_t *out);
107 #else // #if !defined(BOOTLOADER_HOST) 114 #endif // #if !defined(BOOTLOADER_HOST) 117 typedef struct _bootloaderContext
147 #endif // __CONTEXT_H__ const aes_driver_interface_t * aesInterface
Interface to the AES driver.
Definition: bl_context.h:127
flash_config_t flashState
Flash driver instance.
Definition: bl_context.h:133
void(* flash_callback_t)(void)
callback type used for pflash block
Definition: src/drivers/flash/fsl_flash.h:421
const command_interface_t * commandInterface
Interface to command processor operations.
Definition: bl_context.h:124
standard_version_t version
flash driver API version number.
Definition: bl_context.h:59
bootloader_context_t g_bootloaderContext
Bootloader global context data.
Definition: bl_context.c:40
flash_read_resource_option_t
Enumeration for the two possible options of flash read resource command.
Definition: src/drivers/flash/fsl_flash.h:273
const memory_interface_t * memoryInterface
Abstract interface to memory operations.
Definition: bl_context.h:121
Interface for the flash driver.
Definition: bl_context.h:57
Structure of a memory map entry.
Definition: memory.h:86
Structure of bootloader global context.
Definition: bl_context.h:117
void aes_init(uint32_t *key)
An initialization function for the decryption peripheral Warning: The key must be word aligned...
Definition: aes_security.c:79
Interface for AES 128 functions.
Definition: bl_context.h:100
const peripheral_descriptor_t * allPeripherals
Array of all peripherals.
Definition: bl_context.h:126
Interface to property operations.
Definition: property.h:321
flash_flexram_function_option_t
Enumeration for the two possilbe options of set flexram function command.
Definition: src/drivers/flash/fsl_flash.h:317
flash_property_tag_t
Enumeration for various flash properties.
Definition: src/drivers/flash/fsl_flash.h:231
Structure of version property.
Definition: bootloader_common.h:168
const peripheral_descriptor_t * activePeripheral
The currently active peripheral.
Definition: bl_context.h:132
const flash_driver_interface_t * flashDriverInterface
Flash driver interface.
Definition: bl_context.h:125
void aes_decrypt(uint32_t *in, uint32_t *key, uint32_t *out)
Decrypts a 16 byte block of data in and out may use the same address so decrypting in place is suppor...
Definition: aes_security.c:138
flash_security_state_t
Enumeration for the three possible flash security states.
Definition: src/drivers/flash/fsl_flash.h:201
flash_margin_value_t
Enumeration for supported flash margin levels.
Definition: src/drivers/flash/fsl_flash.h:190
Flash driver state information.
Definition: src/drivers/flash/fsl_flash.h:443
void aes_encrypt(uint32_t *in, uint32_t *key, uint32_t *out)
Encrypts a 16 byte block of data in and out may use the same address so encrypting in place is suppor...
Definition: aes_security.c:113
flash_execute_only_access_state_t
Enumeration for the three possible flash execute access levels.
Definition: src/drivers/flash/fsl_flash.h:221
const flash_driver_interface_t g_flashDriverInterface
Function table for flash driver.
Definition: bl_tree_root.c:46
Interface to memory operations.
Definition: memory.h:64
const property_interface_t * propertyInterface
Interface to property store.
Definition: bl_context.h:123
int32_t status_t
Type used for all status and error return values.
Definition: fsl_common.h:121
const memory_map_entry_t * memoryMap
Memory map used by abstract memory interface.
Definition: bl_context.h:122
Interface to command processor operations.
Definition: bl_command.h:95