1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-07-07 07:12:34 +00:00

WIP - C side verification of write validity

This commit is contained in:
matejcik 2024-01-25 13:03:31 +01:00
parent f459cac9bc
commit 9a718b92b9
2 changed files with 10 additions and 3 deletions

View File

@ -1,12 +1,17 @@
#include "translations.h"
#include <assert.h>
#include <stdbool.h>
#include <string.h>
#include "common.h"
#include "flash.h"
#include "model.h"
void translations_write(const uint8_t* data, uint32_t offset, uint32_t len) {
// TODO maybe return errors from here?
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;
}
ensure(flash_unlock_write(), "translations_write unlock");
for (int i = 0; i < len; i++) {
// TODO optimize by writing by (quad)words
@ -14,6 +19,7 @@ void translations_write(const uint8_t* data, uint32_t offset, uint32_t len) {
"translations_write write");
}
ensure(flash_lock_write(), "translations_write lock");
return true;
}
const uint8_t* translations_read(uint32_t* len, uint32_t offset) {

View File

@ -1,6 +1,7 @@
#include <stdbool.h>
#include <stdint.h>
void translations_write(const uint8_t* data, uint32_t offset, uint32_t len);
bool translations_write(const uint8_t* data, uint32_t offset, uint32_t len);
const uint8_t* translations_read(uint32_t* len, uint32_t offset);