diff --git a/Kconfig.zephyr b/Kconfig.zephyr index ccd4adbd6a..42df354ba3 100644 --- a/Kconfig.zephyr +++ b/Kconfig.zephyr @@ -332,7 +332,7 @@ config BOOTLOADER_SRAM_SIZE int "SRAM reserved for bootloader" default 16 depends on !XIP || IS_BOOTLOADER - depends on ARM + depends on ARM || XTENSA help This option specifies the amount of SRAM (measure in kB) reserved for a bootloader image, when either: diff --git a/boards/xtensa/intel_s1000_crb/intel_s1000_crb_defconfig b/boards/xtensa/intel_s1000_crb/intel_s1000_crb_defconfig index 386fa11dd8..7fd5e2b2db 100644 --- a/boards/xtensa/intel_s1000_crb/intel_s1000_crb_defconfig +++ b/boards/xtensa/intel_s1000_crb/intel_s1000_crb_defconfig @@ -18,6 +18,8 @@ CONFIG_3RD_LEVEL_INTERRUPTS=y CONFIG_CAVS_ICTL=y CONFIG_DW_ICTL=y +CONFIG_BOOTLOADER_SRAM_SIZE=192 + CONFIG_USB=y CONFIG_USB_DEVICE_STACK=y CONFIG_USB_DEVICE_VID=0x8087 diff --git a/soc/xtensa/intel_s1000/memory.h b/soc/xtensa/intel_s1000/memory.h index c5538aab94..039974587d 100644 --- a/soc/xtensa/intel_s1000/memory.h +++ b/soc/xtensa/intel_s1000/memory.h @@ -6,30 +6,40 @@ #ifndef __INC_MEMORY_H #define __INC_MEMORY_H +#include + /* L2 HP SRAM */ #define L2_VECTOR_SIZE 0x1000 +#ifdef CONFIG_BOOTLOADER_MCUBOOT +#define SRAM_BASE (DT_L2_SRAM_BASE + CONFIG_BOOTLOADER_SRAM_SIZE * 1K) +#define SRAM_SIZE (DT_L2_SRAM_SIZE - CONFIG_BOOTLOADER_SRAM_SIZE * 1K) +#else +#define SRAM_BASE (DT_L2_SRAM_BASE) +#define SRAM_SIZE (DT_L2_SRAM_SIZE) +#endif + /* The reset vector address in SRAM and its size */ -#define XCHAL_RESET_VECTOR0_PADDR_SRAM DT_L2_SRAM_BASE +#define XCHAL_RESET_VECTOR0_PADDR_SRAM SRAM_BASE #define MEM_RESET_TEXT_SIZE 0x268 #define MEM_RESET_LIT_SIZE 0x8 /* This is the base address of all the vectors defined in SRAM */ -#define XCHAL_VECBASE_RESET_PADDR_SRAM (DT_L2_SRAM_BASE + 0x400) +#define XCHAL_VECBASE_RESET_PADDR_SRAM (SRAM_BASE + 0x400) #define MEM_VECBASE_LIT_SIZE 0x178 /* The addresses of the vectors in SRAM. * Only the memerror vector continues to point to its ROM address. */ -#define XCHAL_INTLEVEL2_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x580) -#define XCHAL_INTLEVEL3_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x5C0) -#define XCHAL_INTLEVEL4_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x600) -#define XCHAL_INTLEVEL5_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x640) -#define XCHAL_INTLEVEL6_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x680) -#define XCHAL_INTLEVEL7_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x6C0) -#define XCHAL_KERNEL_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x700) -#define XCHAL_USER_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x740) -#define XCHAL_DOUBLEEXC_VECTOR_PADDR_SRAM (DT_L2_SRAM_BASE + 0x7C0) +#define XCHAL_INTLEVEL2_VECTOR_PADDR_SRAM (SRAM_BASE + 0x580) +#define XCHAL_INTLEVEL3_VECTOR_PADDR_SRAM (SRAM_BASE + 0x5C0) +#define XCHAL_INTLEVEL4_VECTOR_PADDR_SRAM (SRAM_BASE + 0x600) +#define XCHAL_INTLEVEL5_VECTOR_PADDR_SRAM (SRAM_BASE + 0x640) +#define XCHAL_INTLEVEL6_VECTOR_PADDR_SRAM (SRAM_BASE + 0x680) +#define XCHAL_INTLEVEL7_VECTOR_PADDR_SRAM (SRAM_BASE + 0x6C0) +#define XCHAL_KERNEL_VECTOR_PADDR_SRAM (SRAM_BASE + 0x700) +#define XCHAL_USER_VECTOR_PADDR_SRAM (SRAM_BASE + 0x740) +#define XCHAL_DOUBLEEXC_VECTOR_PADDR_SRAM (SRAM_BASE + 0x7C0) /* Vector and literal sizes */ #define MEM_VECT_LIT_SIZE 0x8 @@ -46,8 +56,8 @@ /* text and data share the same L2 HP SRAM on Intel S1000. * So, they lie next to each other. */ -#define RAM_BASE (DT_L2_SRAM_BASE + L2_VECTOR_SIZE) -#define RAM_SIZE (DT_L2_SRAM_SIZE - L2_VECTOR_SIZE) +#define RAM_BASE (SRAM_BASE + L2_VECTOR_SIZE) +#define RAM_SIZE (SRAM_SIZE - L2_VECTOR_SIZE) /* Location for the intList section which is later used to construct the * Interrupt Descriptor Table (IDT). This is a bogus address as this