diff options
-rw-r--r-- | common/system.c | 20 | ||||
-rw-r--r-- | include/system.h | 5 |
2 files changed, 23 insertions, 2 deletions
diff --git a/common/system.c b/common/system.c index 7c3117a292..c1236f083c 100644 --- a/common/system.c +++ b/common/system.c @@ -107,6 +107,10 @@ static uintptr_t get_program_memory_addr(enum system_image_copy_t copy) return CONFIG_PROGRAM_MEMORY_BASE + CONFIG_RO_MEM_OFF; case SYSTEM_IMAGE_RW: return CONFIG_PROGRAM_MEMORY_BASE + CONFIG_RW_MEM_OFF; +#ifdef CONFIG_RW_B + case SYSTEM_IMAGE_RW_B: + return CONFIG_PROGRAM_MEMORY_BASE + CONFIG_RW_B_MEM_OFF; +#endif default: return 0xffffffff; } @@ -126,6 +130,10 @@ static uint32_t get_size(enum system_image_copy_t copy) return CONFIG_RO_SIZE; case SYSTEM_IMAGE_RW: return CONFIG_RW_SIZE; +#ifdef CONFIG_RW_B + case SYSTEM_IMAGE_RW_B: + return CONFIG_RW_SIZE; +#endif default: return 0; } @@ -335,6 +343,12 @@ test_mockable enum system_image_copy_t system_get_image_copy(void) my_addr < (CONFIG_RW_MEM_OFF + CONFIG_RW_SIZE)) return SYSTEM_IMAGE_RW; +#ifdef CONFIG_RW_B + if (my_addr >= CONFIG_RW_B_MEM_OFF && + my_addr < (CONFIG_RW_B_MEM_OFF + CONFIG_RW_SIZE)) + return SYSTEM_IMAGE_RW_B; +#endif + return SYSTEM_IMAGE_UNKNOWN; #endif } @@ -424,7 +438,11 @@ const char *system_get_image_copy_string(void) const char *system_image_copy_t_to_string(enum system_image_copy_t copy) { - static const char * const image_names[] = {"unknown", "RO", "RW"}; + static const char * const image_names[] = {"unknown", "RO", "RW", +#ifdef CONFIG_RW_B + "RW_B", +#endif + }; return image_names[copy < ARRAY_SIZE(image_names) ? copy : 0]; } diff --git a/include/system.h b/include/system.h index 220e0790e7..0d2eebdf1e 100644 --- a/include/system.h +++ b/include/system.h @@ -37,7 +37,10 @@ void chip_save_reset_flags(int flags); enum system_image_copy_t { SYSTEM_IMAGE_UNKNOWN = 0, SYSTEM_IMAGE_RO, - SYSTEM_IMAGE_RW + SYSTEM_IMAGE_RW, +#ifdef CONFIG_RW_B + SYSTEM_IMAGE_RW_B, +#endif }; /** |