mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-11-22 23:48:12 +00:00
7b6f444751
[no changelog]
49 lines
1.4 KiB
C
49 lines
1.4 KiB
C
#include <trezor_model.h>
|
|
#include <trezor_rtl.h>
|
|
|
|
#include "flash.h"
|
|
#include "mpu.h"
|
|
#include "translations.h"
|
|
|
|
#ifdef KERNEL_MODE
|
|
|
|
bool translations_write(const uint8_t* data, uint32_t offset, uint32_t len) {
|
|
uint32_t size = translations_area_bytesize();
|
|
if (offset > size || size - offset < len) {
|
|
return false;
|
|
}
|
|
|
|
mpu_mode_t mpu_mode = mpu_reconfig(MPU_MODE_ASSETS);
|
|
|
|
ensure(flash_unlock_write(), "translations_write unlock");
|
|
// todo consider alignment
|
|
ensure(flash_area_write_data_padded(&ASSETS_AREA, offset, data, len, 0xFF,
|
|
FLASH_ALIGN(len)),
|
|
"translations_write write");
|
|
ensure(flash_lock_write(), "translations_write lock");
|
|
|
|
mpu_restore(mpu_mode);
|
|
|
|
return true;
|
|
}
|
|
|
|
const uint8_t* translations_read(uint32_t* len, uint32_t offset) {
|
|
// TODO: _Static_assert was not happy with ASSETS_AREA.num_subareas == 1
|
|
// error: expression in static assertion is not constant
|
|
assert(ASSETS_AREA.num_subareas == 1);
|
|
*len = flash_area_get_size(&ASSETS_AREA) - offset;
|
|
return flash_area_get_address(&ASSETS_AREA, offset, 0);
|
|
}
|
|
|
|
void translations_erase(void) {
|
|
mpu_mode_t mpu_mode = mpu_reconfig(MPU_MODE_ASSETS);
|
|
ensure(flash_area_erase(&ASSETS_AREA, NULL), "translations erase");
|
|
mpu_restore(mpu_mode);
|
|
}
|
|
|
|
uint32_t translations_area_bytesize(void) {
|
|
return flash_area_get_size(&ASSETS_AREA);
|
|
}
|
|
|
|
#endif // KERNEL_MODE
|