2017-03-20 14:41:21 +00:00
|
|
|
#include STM32_HAL_H
|
|
|
|
|
2017-03-21 00:41:49 +00:00
|
|
|
#include "common.h"
|
2017-03-20 14:41:21 +00:00
|
|
|
#include "display.h"
|
2017-04-01 10:57:14 +00:00
|
|
|
#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)
|
|
|
|
|
2017-03-21 14:56:50 +00:00
|
|
|
void pendsv_isr_handler(void) {
|
|
|
|
__fatal_error("pendsv");
|
2017-03-20 14:41:21 +00:00
|
|
|
}
|
|
|
|
|
2017-04-01 00:32:05 +00:00
|
|
|
void check_and_jump(void)
|
|
|
|
{
|
|
|
|
LOADER_PRINTLN("checking firmware");
|
2017-04-01 13:45:50 +00:00
|
|
|
// TODO: check vendor header and its signature
|
|
|
|
uint32_t vhdrlen = *((const uint32_t *) (FIRMWARE_START + 4));
|
|
|
|
if (image_check_signature((const uint8_t *) (FIRMWARE_START + vhdrlen))) {
|
2017-04-01 10:57:14 +00:00
|
|
|
LOADER_PRINTLN("valid firmware image");
|
|
|
|
// TODO: remove debug wait
|
|
|
|
LOADER_PRINTLN("waiting 1 second");
|
|
|
|
HAL_Delay(1000);
|
|
|
|
// end
|
|
|
|
LOADER_PRINTLN("JUMP!");
|
2017-04-01 13:45:50 +00:00
|
|
|
jump_to(FIRMWARE_START + vhdrlen + HEADER_SIZE);
|
2017-04-01 00:32:05 +00:00
|
|
|
} else {
|
2017-04-01 10:57:14 +00:00
|
|
|
LOADER_PRINTLN("invalid firmware image");
|
2017-04-01 00:32:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-23 15:22:58 +00:00
|
|
|
int main(void)
|
2017-03-20 14:41:21 +00:00
|
|
|
{
|
2017-03-31 22:22:24 +00:00
|
|
|
SCB->VTOR = LOADER_START + HEADER_SIZE;
|
2017-03-23 15:22:58 +00:00
|
|
|
periph_init();
|
2017-03-20 14:41:21 +00:00
|
|
|
|
|
|
|
display_init();
|
|
|
|
display_clear();
|
|
|
|
display_backlight(255);
|
|
|
|
|
2017-04-01 00:32:05 +00:00
|
|
|
LOADER_PRINTLN("TREZOR Loader");
|
|
|
|
LOADER_PRINTLN("=============");
|
|
|
|
LOADER_PRINTLN("starting loader");
|
|
|
|
|
|
|
|
check_and_jump();
|
2017-03-29 18:50:45 +00:00
|
|
|
|
2017-04-01 00:32:05 +00:00
|
|
|
__fatal_error("halt");
|
2017-03-20 14:41:21 +00:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|