mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-05 13:01:12 +00:00
fix(core): align coreapp start to 8KB (u5 only)
[no changelog]
This commit is contained in:
parent
c300576d6c
commit
7bd3663930
@ -39,8 +39,6 @@
|
|||||||
#define IMAGE_CODE_ALIGN(addr) \
|
#define IMAGE_CODE_ALIGN(addr) \
|
||||||
((((uint32_t)(uintptr_t)addr) + (CODE_ALIGNMENT - 1)) & ~(CODE_ALIGNMENT - 1))
|
((((uint32_t)(uintptr_t)addr) + (CODE_ALIGNMENT - 1)) & ~(CODE_ALIGNMENT - 1))
|
||||||
|
|
||||||
#define COREAPP_ALIGNMENT 512
|
|
||||||
|
|
||||||
#define COREAPP_CODE_ALIGN(addr) \
|
#define COREAPP_CODE_ALIGN(addr) \
|
||||||
((((uint32_t)(uintptr_t)addr) + (COREAPP_ALIGNMENT - 1)) & \
|
((((uint32_t)(uintptr_t)addr) + (COREAPP_ALIGNMENT - 1)) & \
|
||||||
~(COREAPP_ALIGNMENT - 1))
|
~(COREAPP_ALIGNMENT - 1))
|
||||||
|
@ -50,3 +50,4 @@ KERNEL_FRAMEBUFFER_SIZE = 0x0;
|
|||||||
KERNEL_SRAM_SIZE = 0x400;
|
KERNEL_SRAM_SIZE = 0x400;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x200;
|
CODE_ALIGNMENT = 0x200;
|
||||||
|
COREAPP_ALIGNMENT = 0x200;
|
||||||
|
@ -87,12 +87,13 @@
|
|||||||
#define FIRMWARE_P2_SECTOR_END 23
|
#define FIRMWARE_P2_SECTOR_END 23
|
||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_STACK_SIZE 8 * 1024
|
#define KERNEL_STACK_SIZE (8 * 1024)
|
||||||
#define KERNEL_CCMRAM_SIZE 16 * 1024
|
#define KERNEL_CCMRAM_SIZE (16 * 1024)
|
||||||
#define KERNEL_FRAMEBUFFER_SIZE 0 * 1024
|
#define KERNEL_FRAMEBUFFER_SIZE (0 * 1024)
|
||||||
#define KERNEL_SRAM_SIZE 1 * 1024
|
#define KERNEL_SRAM_SIZE (1 * 1024)
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x200
|
#define CODE_ALIGNMENT 0x200
|
||||||
|
#define COREAPP_ALIGNMENT 0x200
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,3 +45,4 @@ KERNEL_SRAM2_SIZE = 0x2400;
|
|||||||
KERNEL_SRAM3_SIZE = 0xbb800;
|
KERNEL_SRAM3_SIZE = 0xbb800;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x400;
|
CODE_ALIGNMENT = 0x400;
|
||||||
|
COREAPP_ALIGNMENT = 0x2000;
|
||||||
|
@ -83,11 +83,12 @@
|
|||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_U_RAM_SIZE 512
|
#define KERNEL_U_RAM_SIZE 512
|
||||||
#define KERNEL_SRAM1_SIZE 16 * 1024
|
#define KERNEL_SRAM1_SIZE (16 * 1024)
|
||||||
#define KERNEL_SRAM2_SIZE 9 * 1024
|
#define KERNEL_SRAM2_SIZE (9 * 1024)
|
||||||
#define KERNEL_SRAM3_SIZE 750 * 1024
|
#define KERNEL_SRAM3_SIZE (750 * 1024)
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x400
|
#define CODE_ALIGNMENT 0x400
|
||||||
|
#define COREAPP_ALIGNMENT 0x2000
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -54,3 +54,4 @@ KERNEL_FRAMEBUFFER_SIZE = 0x2000;
|
|||||||
KERNEL_SRAM_SIZE = 0x400;
|
KERNEL_SRAM_SIZE = 0x400;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x200;
|
CODE_ALIGNMENT = 0x200;
|
||||||
|
COREAPP_ALIGNMENT = 0x200;
|
||||||
|
@ -92,12 +92,13 @@
|
|||||||
#define FIRMWARE_P2_SECTOR_END 23
|
#define FIRMWARE_P2_SECTOR_END 23
|
||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_STACK_SIZE 8 * 1024
|
#define KERNEL_STACK_SIZE (8 * 1024)
|
||||||
#define KERNEL_CCMRAM_SIZE 16 * 1024
|
#define KERNEL_CCMRAM_SIZE (16 * 1024)
|
||||||
#define KERNEL_FRAMEBUFFER_SIZE 8 * 1024
|
#define KERNEL_FRAMEBUFFER_SIZE (8 * 1024)
|
||||||
#define KERNEL_SRAM_SIZE 1 * 1024
|
#define KERNEL_SRAM_SIZE (1 * 1024)
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x200
|
#define CODE_ALIGNMENT 0x200
|
||||||
|
#define COREAPP_ALIGNMENT 0x200
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -50,3 +50,4 @@ KERNEL_FRAMEBUFFER_SIZE = 0x0;
|
|||||||
KERNEL_SRAM_SIZE = 0x400;
|
KERNEL_SRAM_SIZE = 0x400;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x200;
|
CODE_ALIGNMENT = 0x200;
|
||||||
|
COREAPP_ALIGNMENT = 0x200;
|
||||||
|
@ -87,12 +87,13 @@
|
|||||||
#define FIRMWARE_P2_SECTOR_END 23
|
#define FIRMWARE_P2_SECTOR_END 23
|
||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_STACK_SIZE 8 * 1024
|
#define KERNEL_STACK_SIZE (8 * 1024)
|
||||||
#define KERNEL_CCMRAM_SIZE 16 * 1024
|
#define KERNEL_CCMRAM_SIZE (16 * 1024)
|
||||||
#define KERNEL_FRAMEBUFFER_SIZE 0 * 1024
|
#define KERNEL_FRAMEBUFFER_SIZE (0 * 1024)
|
||||||
#define KERNEL_SRAM_SIZE 1 * 1024
|
#define KERNEL_SRAM_SIZE (1 * 1024)
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x200
|
#define CODE_ALIGNMENT 0x200
|
||||||
|
#define COREAPP_ALIGNMENT 0x200
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,3 +45,4 @@ KERNEL_SRAM2_SIZE = 0x2000;
|
|||||||
KERNEL_SRAM3_SIZE = 0x38400;
|
KERNEL_SRAM3_SIZE = 0x38400;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x200;
|
CODE_ALIGNMENT = 0x200;
|
||||||
|
COREAPP_ALIGNMENT = 0x2000;
|
||||||
|
@ -82,11 +82,12 @@
|
|||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_U_RAM_SIZE 512
|
#define KERNEL_U_RAM_SIZE 512
|
||||||
#define KERNEL_SRAM1_SIZE 16 * 1024
|
#define KERNEL_SRAM1_SIZE (16 * 1024)
|
||||||
#define KERNEL_SRAM2_SIZE 8 * 1024
|
#define KERNEL_SRAM2_SIZE (8 * 1024)
|
||||||
#define KERNEL_SRAM3_SIZE 0x38400
|
#define KERNEL_SRAM3_SIZE 0x38400
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x200
|
#define CODE_ALIGNMENT 0x200
|
||||||
|
#define COREAPP_ALIGNMENT 0x2000
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,3 +45,4 @@ KERNEL_SRAM2_SIZE = 0x2000;
|
|||||||
KERNEL_SRAM3_SIZE = 0x38400;
|
KERNEL_SRAM3_SIZE = 0x38400;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x200;
|
CODE_ALIGNMENT = 0x200;
|
||||||
|
COREAPP_ALIGNMENT = 0x2000;
|
||||||
|
@ -82,11 +82,12 @@
|
|||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_U_RAM_SIZE 512
|
#define KERNEL_U_RAM_SIZE 512
|
||||||
#define KERNEL_SRAM1_SIZE 16 * 1024
|
#define KERNEL_SRAM1_SIZE (16 * 1024)
|
||||||
#define KERNEL_SRAM2_SIZE 8 * 1024
|
#define KERNEL_SRAM2_SIZE (8 * 1024)
|
||||||
#define KERNEL_SRAM3_SIZE 0x38400
|
#define KERNEL_SRAM3_SIZE 0x38400
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x200
|
#define CODE_ALIGNMENT 0x200
|
||||||
|
#define COREAPP_ALIGNMENT 0x2000
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -50,3 +50,4 @@ KERNEL_FRAMEBUFFER_SIZE = 0x0;
|
|||||||
KERNEL_SRAM_SIZE = 0x400;
|
KERNEL_SRAM_SIZE = 0x400;
|
||||||
BOOTARGS_SIZE = 0x100;
|
BOOTARGS_SIZE = 0x100;
|
||||||
CODE_ALIGNMENT = 0x200;
|
CODE_ALIGNMENT = 0x200;
|
||||||
|
COREAPP_ALIGNMENT = 0x2000;
|
||||||
|
@ -89,11 +89,13 @@
|
|||||||
#define FIRMWARE_P2_SECTOR_END 23
|
#define FIRMWARE_P2_SECTOR_END 23
|
||||||
|
|
||||||
// RAM layout
|
// RAM layout
|
||||||
#define KERNEL_STACK_SIZE 8 * 1024
|
#define KERNEL_STACK_SIZE (8 * 1024)
|
||||||
#define KERNEL_CCMRAM_SIZE 16 * 1024
|
#define KERNEL_CCMRAM_SIZE (16 * 1024)
|
||||||
#define KERNEL_FRAMEBUFFER_SIZE 0 * 1024
|
#define KERNEL_FRAMEBUFFER_SIZE (0 * 1024)
|
||||||
#define KERNEL_SRAM_SIZE 1 * 1024
|
#define KERNEL_SRAM_SIZE (1 * 1024)
|
||||||
|
|
||||||
#define BOOTARGS_SIZE 0x100
|
#define BOOTARGS_SIZE 0x100
|
||||||
#define CODE_ALIGNMENT 0x200
|
#define CODE_ALIGNMENT 0x200
|
||||||
|
#define COREAPP_ALIGNMENT 0x2000
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -52,7 +52,7 @@ SECTIONS {
|
|||||||
|
|
||||||
.flash : ALIGN(512) {
|
.flash : ALIGN(512) {
|
||||||
KEEP(*(.kernel));
|
KEEP(*(.kernel));
|
||||||
. = ALIGN(512);
|
. = ALIGN(COREAPP_ALIGNMENT);
|
||||||
KEEP(*(.vector_table));
|
KEEP(*(.vector_table));
|
||||||
. = ALIGN(4);
|
. = ALIGN(4);
|
||||||
*(.text*);
|
*(.text*);
|
||||||
|
@ -47,7 +47,7 @@ SECTIONS {
|
|||||||
|
|
||||||
.flash : ALIGN(CODE_ALIGNMENT) {
|
.flash : ALIGN(CODE_ALIGNMENT) {
|
||||||
KEEP(*(.kernel));
|
KEEP(*(.kernel));
|
||||||
. = ALIGN(512);
|
. = ALIGN(COREAPP_ALIGNMENT);
|
||||||
KEEP(*(.vector_table));
|
KEEP(*(.vector_table));
|
||||||
. = ALIGN(4);
|
. = ALIGN(4);
|
||||||
*(.text*);
|
*(.text*);
|
||||||
|
@ -46,7 +46,7 @@ SECTIONS {
|
|||||||
|
|
||||||
.flash : ALIGN(CODE_ALIGNMENT) {
|
.flash : ALIGN(CODE_ALIGNMENT) {
|
||||||
KEEP(*(.kernel));
|
KEEP(*(.kernel));
|
||||||
. = ALIGN(512);
|
. = ALIGN(COREAPP_ALIGNMENT);
|
||||||
KEEP(*(.vector_table));
|
KEEP(*(.vector_table));
|
||||||
. = ALIGN(4);
|
. = ALIGN(4);
|
||||||
*(.text*);
|
*(.text*);
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "image.h"
|
||||||
#include "irq.h"
|
#include "irq.h"
|
||||||
#include "model.h"
|
#include "model.h"
|
||||||
#include "mpu.h"
|
#include "mpu.h"
|
||||||
@ -172,8 +173,9 @@ extern uint32_t _codelen;
|
|||||||
#define KERNEL_FLASH_START KERNEL_START
|
#define KERNEL_FLASH_START KERNEL_START
|
||||||
#define KERNEL_FLASH_SIZE (KERNEL_SIZE - KERNEL_U_FLASH_SIZE)
|
#define KERNEL_FLASH_SIZE (KERNEL_SIZE - KERNEL_U_FLASH_SIZE)
|
||||||
|
|
||||||
#define COREAPP_FLASH_START (KERNEL_FLASH_START + KERNEL_SIZE)
|
#define COREAPP_FLASH_START COREAPP_CODE_ALIGN(KERNEL_FLASH_START + KERNEL_SIZE)
|
||||||
#define COREAPP_FLASH_SIZE (FIRMWARE_MAXSIZE - KERNEL_SIZE)
|
#define COREAPP_FLASH_SIZE \
|
||||||
|
(FIRMWARE_MAXSIZE - (COREAPP_FLASH_START - KERNEL_FLASH_START))
|
||||||
|
|
||||||
#ifdef STM32U585xx
|
#ifdef STM32U585xx
|
||||||
#define COREAPP_RAM1_START SRAM1_BASE
|
#define COREAPP_RAM1_START SRAM1_BASE
|
||||||
|
Loading…
Reference in New Issue
Block a user