mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-22 05:10:56 +00:00
refactor(core): remove hash_processor syscalls
[no changelog]
This commit is contained in:
parent
0312158aa1
commit
be59a09a4c
@ -7,7 +7,7 @@
|
|||||||
#ifdef IMAGE_HASH_SHA256
|
#ifdef IMAGE_HASH_SHA256
|
||||||
#include "sha2.h"
|
#include "sha2.h"
|
||||||
#define IMAGE_HASH_DIGEST_LENGTH SHA256_DIGEST_LENGTH
|
#define IMAGE_HASH_DIGEST_LENGTH SHA256_DIGEST_LENGTH
|
||||||
#ifdef USE_HASH_PROCESSOR
|
#if defined(USE_HASH_PROCESSOR) && defined(KERNEL_MODE)
|
||||||
#include "hash_processor.h"
|
#include "hash_processor.h"
|
||||||
#define IMAGE_HASH_CTX hash_sha256_context_t
|
#define IMAGE_HASH_CTX hash_sha256_context_t
|
||||||
#define IMAGE_HASH_INIT(ctx) hash_processor_sha256_init(ctx)
|
#define IMAGE_HASH_INIT(ctx) hash_processor_sha256_init(ctx)
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#ifdef KERNEL_MODE
|
||||||
|
|
||||||
#define HASH_SHA256_BUFFER_SIZE 4
|
#define HASH_SHA256_BUFFER_SIZE 4
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -34,4 +36,6 @@ void hash_processor_sha256_update(hash_sha256_context_t *ctx,
|
|||||||
// Finalize the hash calculation, retrieve the digest
|
// Finalize the hash calculation, retrieve the digest
|
||||||
void hash_processor_sha256_final(hash_sha256_context_t *ctx, uint8_t *output);
|
void hash_processor_sha256_final(hash_sha256_context_t *ctx, uint8_t *output);
|
||||||
|
|
||||||
|
#endif // KERNEL_MODE
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -29,7 +29,6 @@
|
|||||||
#include "entropy.h"
|
#include "entropy.h"
|
||||||
#include "fwutils.h"
|
#include "fwutils.h"
|
||||||
#include "haptic.h"
|
#include "haptic.h"
|
||||||
#include "hash_processor.h"
|
|
||||||
#include "irq.h"
|
#include "irq.h"
|
||||||
#include "mpu.h"
|
#include "mpu.h"
|
||||||
#include "optiga.h"
|
#include "optiga.h"
|
||||||
@ -130,33 +129,6 @@ __attribute((no_stack_protector)) void syscall_handler(uint32_t *args,
|
|||||||
reboot_and_upgrade(hash);
|
reboot_and_upgrade(hash);
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
#ifdef STM32U5
|
|
||||||
case SYSCALL_SHA256_INIT: {
|
|
||||||
hash_sha256_context_t *ctx = (hash_sha256_context_t *)args[0];
|
|
||||||
hash_processor_sha256_init(ctx);
|
|
||||||
} break;
|
|
||||||
|
|
||||||
case SYSCALL_SHA256_UPDATE: {
|
|
||||||
hash_sha256_context_t *ctx = (hash_sha256_context_t *)args[0];
|
|
||||||
const uint8_t *data = (const uint8_t *)args[1];
|
|
||||||
uint32_t len = args[2];
|
|
||||||
hash_processor_sha256_update(ctx, data, len);
|
|
||||||
} break;
|
|
||||||
|
|
||||||
case SYSCALL_SHA256_FINAL: {
|
|
||||||
hash_sha256_context_t *ctx = (hash_sha256_context_t *)args[0];
|
|
||||||
uint8_t *output = (uint8_t *)args[1];
|
|
||||||
hash_processor_sha256_final(ctx, output);
|
|
||||||
} break;
|
|
||||||
|
|
||||||
case SYSCALL_SHA256_CALC: {
|
|
||||||
const uint8_t *data = (const uint8_t *)args[0];
|
|
||||||
uint32_t len = args[1];
|
|
||||||
uint8_t *hash = (uint8_t *)args[2];
|
|
||||||
hash_processor_sha256_calc(data, len, hash);
|
|
||||||
} break;
|
|
||||||
#endif // STM32U5
|
|
||||||
|
|
||||||
case SYSCALL_DISPLAY_SET_BACKLIGHT: {
|
case SYSCALL_DISPLAY_SET_BACKLIGHT: {
|
||||||
int level = (int)args[0];
|
int level = (int)args[0];
|
||||||
args[0] = display_set_backlight(level);
|
args[0] = display_set_backlight(level);
|
||||||
|
@ -37,11 +37,6 @@ typedef enum {
|
|||||||
SYSCALL_REBOOT_TO_BOOTLOADER,
|
SYSCALL_REBOOT_TO_BOOTLOADER,
|
||||||
SYSCALL_REBOOT_AND_UPGRADE,
|
SYSCALL_REBOOT_AND_UPGRADE,
|
||||||
|
|
||||||
SYSCALL_SHA256_INIT,
|
|
||||||
SYSCALL_SHA256_UPDATE,
|
|
||||||
SYSCALL_SHA256_FINAL,
|
|
||||||
SYSCALL_SHA256_CALC,
|
|
||||||
|
|
||||||
SYSCALL_DISPLAY_SET_BACKLIGHT,
|
SYSCALL_DISPLAY_SET_BACKLIGHT,
|
||||||
SYSCALL_DISPLAY_GET_BACKLIGHT,
|
SYSCALL_DISPLAY_GET_BACKLIGHT,
|
||||||
SYSCALL_DISPLAY_SET_ORIENTATION,
|
SYSCALL_DISPLAY_SET_ORIENTATION,
|
||||||
|
@ -98,32 +98,6 @@ void reboot_device(void) {
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
// =============================================================================
|
|
||||||
// hash_processor.h
|
|
||||||
// =============================================================================
|
|
||||||
|
|
||||||
#include "hash_processor.h"
|
|
||||||
|
|
||||||
void hash_processor_sha256_init(hash_sha256_context_t *ctx) {
|
|
||||||
syscall_invoke1((uint32_t)ctx, SYSCALL_SHA256_INIT);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Feed the hash next chunk of data
|
|
||||||
void hash_processor_sha256_update(hash_sha256_context_t *ctx,
|
|
||||||
const uint8_t *data, uint32_t len) {
|
|
||||||
syscall_invoke3((uint32_t)ctx, (uint32_t)data, len, SYSCALL_SHA256_UPDATE);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Finalize the hash calculation, retrieve the digest
|
|
||||||
void hash_processor_sha256_final(hash_sha256_context_t *ctx, uint8_t *output) {
|
|
||||||
syscall_invoke2((uint32_t)ctx, (uint32_t)output, SYSCALL_SHA256_FINAL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void hash_processor_sha256_calc(const uint8_t *data, uint32_t len,
|
|
||||||
uint8_t *hash) {
|
|
||||||
syscall_invoke3((uint32_t)data, len, (uint32_t)hash, SYSCALL_SHA256_CALC);
|
|
||||||
}
|
|
||||||
|
|
||||||
// =============================================================================
|
// =============================================================================
|
||||||
// xdisplay.h
|
// xdisplay.h
|
||||||
// =============================================================================
|
// =============================================================================
|
||||||
|
Loading…
Reference in New Issue
Block a user