1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-11-14 03:30:02 +00:00
trezor-firmware/micropython/loader/main.c

77 lines
1.9 KiB
C
Raw Normal View History

2017-03-20 14:41:21 +00:00
#include STM32_HAL_H
#include <string.h>
#include "common.h"
2017-03-20 14:41:21 +00:00
#include "display.h"
#include "image.h"
2017-03-20 14:41:21 +00:00
2017-03-21 15:06:22 +00:00
#define LOADER_FGCOLOR 0xFFFF
#define LOADER_BGCOLOR 0x0000
#define LOADER_PRINT(X) do { display_print(X, -1); display_print_out(LOADER_FGCOLOR, LOADER_BGCOLOR); } while(0)
#define LOADER_PRINTLN(X) do { display_print(X "\n", -1); display_print_out(LOADER_FGCOLOR, LOADER_BGCOLOR); } while(0)
void pendsv_isr_handler(void) {
__fatal_error("pendsv");
2017-03-20 14:41:21 +00:00
}
void display_vendor(const uint8_t *vimg)
{
if (memcmp(vimg, "TOIf", 4) != 0) {
return;
}
uint16_t w = *(uint16_t *)(vimg + 4);
uint16_t h = *(uint16_t *)(vimg + 6);
uint32_t datalen = *(uint32_t *)(vimg + 8);
display_image(0, 0, w, h, vimg + 12, datalen);
}
void check_and_jump(void)
{
LOADER_PRINTLN("checking firmware");
2017-04-01 17:24:41 +00:00
vendor_header vhdr;
if (!vendor_parse_header((const uint8_t *)(FIRMWARE_START), &vhdr)) {
LOADER_PRINTLN("invalid vendor header");
return;
}
if (!vendor_check_signature((const uint8_t *)(FIRMWARE_START))) {
LOADER_PRINTLN("unsigned vendor header");
return;
}
// TODO: use keys from vendor header in image_check_signature
if (image_check_signature((const uint8_t *)(FIRMWARE_START + vhdr.hdrlen))) {
LOADER_PRINTLN("valid firmware image");
// TODO: remove debug wait
display_vendor(vhdr.vimg);
HAL_Delay(1000);
// end
LOADER_PRINTLN("JUMP!");
2017-04-01 17:24:41 +00:00
jump_to(FIRMWARE_START + vhdr.hdrlen + HEADER_SIZE);
} else {
LOADER_PRINTLN("invalid firmware image");
}
}
int main(void)
2017-03-20 14:41:21 +00:00
{
SCB->VTOR = LOADER_START + HEADER_SIZE;
periph_init();
2017-03-20 14:41:21 +00:00
display_init();
display_clear();
display_backlight(255);
LOADER_PRINTLN("TREZOR Loader");
LOADER_PRINTLN("=============");
LOADER_PRINTLN("starting loader");
check_and_jump();
2017-03-29 18:50:45 +00:00
__fatal_error("halt");
2017-03-20 14:41:21 +00:00
return 0;
}