mirror of
				https://github.com/tillitis/tillitis-key1.git
				synced 2025-10-26 12:26:07 -04:00 
			
		
		
		
	 2c1c05f180
			
		
	
	
		2c1c05f180
		
			
		
	
	
	
	
		
			
			- Add per app flash storage
  - Adds four data areas. An app can allocate an area. Once allocated
    the area is tied to the CDI of the app and can only be
    read/written/deallocated by the same app.
- Add two pre loaded app slots to flash
  - Load an app from the first slot at boot. The app digest must match a
    specific digest specified in firmware.
  - Optionally load an app from the second slot
- Add a resetinfo area in FW_RAM which is used to signal an app's intent
  of resetting the system and, optionally, pass data to firmware or the
  next app in a bootchain.
Co-authored-by: Jonas Thörnblad <jonas@tillitis.se>
Co-authored-by: Mikael Ågren <mikael@tillitis.se>
Co-authored-by: Daniel Jobson <jobson@tillitis.se>
		
	
			
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2022, 2023 - Tillitis AB
 | |
|  * SPDX-License-Identifier: GPL-2.0-only
 | |
| */
 | |
| 
 | |
| OUTPUT_ARCH("riscv")
 | |
| ENTRY(_start)
 | |
| 
 | |
| /* Define stack size */
 | |
| STACK_SIZE = 3000;
 | |
| 
 | |
| MEMORY
 | |
| {
 | |
| 	ROM       (rx)  : ORIGIN = 0x00000000, LENGTH = 0x2000  /* 8 KB */
 | |
| 	FWRAM     (rw)  : ORIGIN = 0xd0000000, LENGTH = 0xF00   /* 3840 B */
 | |
| 	RESETINFO (rw)  : ORIGIN = 0xd0000F00, LENGTH = 0x100   /* 256 B (part of FW_RAM area) */
 | |
| 	RAM       (rwx) : ORIGIN = 0x40000000, LENGTH = 0x20000 /* 128 KB */
 | |
| }
 | |
| 
 | |
| SECTIONS
 | |
| {
 | |
| 	.text.init :
 | |
| 	{
 | |
| 		*(.text.init)
 | |
| 	} >ROM
 | |
| 
 | |
| 	.htif :
 | |
| 	{
 | |
| 		. = ALIGN(0x00000000);
 | |
| 		*(.htif)
 | |
| 	} >ROM
 | |
| 
 | |
| 	.text :
 | |
| 	{
 | |
| 		. = ALIGN(4);
 | |
| 		_stext = .;
 | |
| 		*(.text)           /* .text sections (code) */
 | |
| 		*(.text*)          /* .text* sections (code) */
 | |
| 		*(.rodata)         /* .rodata sections (constants, strings, etc.) */
 | |
| 		*(.rodata*)        /* .rodata* sections (constants, strings, etc.) */
 | |
| 		*(.srodata)        /* .srodata sections (constants, strings, etc.) */
 | |
| 		*(.srodata*)       /* .srodata* sections (constants, strings, etc.) */
 | |
| 		. = ALIGN(4);
 | |
| 		_etext = .;
 | |
| 	} >ROM
 | |
| 
 | |
| 	.stack (NOLOAD) :
 | |
| 	{
 | |
| 		. = ALIGN(16);
 | |
| 		_sstack = .;
 | |
| 		. += STACK_SIZE;
 | |
| 		. = ALIGN(16);
 | |
| 		_estack = .;
 | |
| 	} >FWRAM
 | |
| 
 | |
| 	.data :
 | |
| 	{
 | |
| 		. = ALIGN(4);
 | |
| 		_sdata = .;
 | |
| 		*(.data)           /* .data sections */
 | |
| 		*(.data*)          /* .data* sections */
 | |
| 		*(.sdata)          /* .sdata sections */
 | |
| 		*(.sdata*)         /* .sdata* sections */
 | |
| 		. = ALIGN(4);
 | |
| 		_edata = .;
 | |
| 	} >FWRAM AT>ROM
 | |
| 	_sidata = LOADADDR(.data);
 | |
| 
 | |
| 	/* Uninitialized data section */
 | |
| 	.bss :
 | |
| 	{
 | |
| 		. = ALIGN(4);
 | |
| 		_sbss = .;
 | |
| 		*(.bss)
 | |
| 		*(.bss*)
 | |
| 		*(.sbss)
 | |
| 		*(.sbss*)
 | |
| 		*(COMMON)
 | |
| 		. = ALIGN(4);
 | |
| 		_ebss = .;
 | |
| 	} >FWRAM
 | |
| }
 | |
| 
 | |
| _sfwram = ORIGIN(FWRAM);
 | |
| _efwram = ORIGIN(FWRAM) + LENGTH(FWRAM);
 | |
| _sresetinfo = ORIGIN(RESETINFO);
 | |
| _eresetinfo = ORIGIN(RESETINFO) + LENGTH(RESETINFO);
 |