2022-02-21 00:03:22 +03:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2017-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
2021-07-27 16:22:24 +08:00
|
|
|
#include "inttypes.h"
|
2018-07-29 14:17:09 +03:00
|
|
|
#include "unity.h"
|
|
|
|
#include "esp_attr.h"
|
|
|
|
#include "esp_log.h"
|
2018-09-29 13:53:37 +08:00
|
|
|
#include "soc/soc.h"
|
2020-02-07 00:00:45 +00:00
|
|
|
#include "esp_system.h"
|
2021-07-27 16:22:24 +08:00
|
|
|
#if CONFIG_IDF_TARGET_ESP32
|
2022-05-11 10:32:56 +08:00
|
|
|
#include "esp_private/esp_psram_extram.h"
|
2021-07-27 16:22:24 +08:00
|
|
|
#endif
|
2022-05-20 18:16:47 +08:00
|
|
|
#include "test_utils.h"
|
2018-07-29 14:17:09 +03:00
|
|
|
|
|
|
|
extern int _rtc_noinit_start;
|
|
|
|
extern int _rtc_noinit_end;
|
|
|
|
extern int _rtc_data_start;
|
|
|
|
extern int _rtc_data_end;
|
|
|
|
extern int _noinit_start;
|
|
|
|
extern int _noinit_end;
|
2018-09-29 13:53:37 +08:00
|
|
|
extern int _rtc_force_fast_start;
|
|
|
|
extern int _rtc_force_fast_end;
|
|
|
|
extern int _rtc_force_slow_start;
|
|
|
|
extern int _rtc_force_slow_end;
|
2021-07-27 16:22:24 +08:00
|
|
|
extern int _ext_ram_noinit_start;
|
|
|
|
extern int _ext_ram_noinit_end;
|
|
|
|
extern int _ext_ram_bss_start;
|
|
|
|
extern int _ext_ram_bss_end;
|
2018-09-29 13:53:37 +08:00
|
|
|
|
2018-07-29 14:17:09 +03:00
|
|
|
|
2022-05-20 18:16:47 +08:00
|
|
|
#if !TEMPORARY_DISABLED_FOR_TARGETS(ESP32C2)
|
|
|
|
//IDF-5045
|
|
|
|
//Variables for test: Attributes place variables into correct sections
|
|
|
|
static __NOINIT_ATTR uint32_t s_noinit;
|
|
|
|
static RTC_NOINIT_ATTR uint32_t s_rtc_noinit;
|
|
|
|
static RTC_DATA_ATTR uint32_t s_rtc_data;
|
|
|
|
static RTC_RODATA_ATTR uint32_t s_rtc_rodata;
|
|
|
|
static RTC_FAST_ATTR uint32_t s_rtc_force_fast;
|
|
|
|
static RTC_SLOW_ATTR uint32_t s_rtc_force_slow;
|
|
|
|
#if CONFIG_SPIRAM_ALLOW_NOINIT_SEG_EXTERNAL_MEMORY
|
|
|
|
static EXT_RAM_NOINIT_ATTR uint32_t s_noinit_ext;
|
|
|
|
#endif
|
|
|
|
|
2018-07-29 14:17:09 +03:00
|
|
|
static bool data_in_segment(void *ptr, int *seg_start, int *seg_end)
|
|
|
|
{
|
|
|
|
return ((intptr_t)ptr < (intptr_t)seg_end) && \
|
|
|
|
((intptr_t)ptr >= (intptr_t)seg_start);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("Attributes place variables into correct sections", "[ld]")
|
|
|
|
{
|
|
|
|
TEST_ASSERT(data_in_segment(&s_noinit, &_noinit_start, &_noinit_end));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_noinit, &_rtc_noinit_start, &_rtc_noinit_end));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_data, &_rtc_data_start, &_rtc_data_end));
|
2018-09-29 13:53:37 +08:00
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_rodata, &_rtc_data_start, &_rtc_data_end));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_force_fast, &_rtc_force_fast_start, &_rtc_force_fast_end));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_force_slow, &_rtc_force_slow_start, &_rtc_force_slow_end));
|
|
|
|
|
2021-01-18 07:12:21 +08:00
|
|
|
#if CONFIG_ESP32_RTCDATA_IN_FAST_MEM || \
|
|
|
|
CONFIG_ESP32S2_RTCDATA_IN_FAST_MEM || \
|
2022-03-15 18:25:05 +08:00
|
|
|
CONFIG_ESP32S3_RTCDATA_IN_FAST_MEM
|
2018-09-29 13:53:37 +08:00
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_data, (int*) SOC_RTC_DRAM_LOW, (int*) SOC_RTC_DRAM_HIGH));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_rodata, (int*) SOC_RTC_DRAM_LOW, (int*) SOC_RTC_DRAM_HIGH));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_noinit, (int*) SOC_RTC_DRAM_LOW, (int*) SOC_RTC_DRAM_HIGH));
|
2021-01-18 07:12:21 +08:00
|
|
|
#else
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_data, (int*) SOC_RTC_DATA_LOW, (int*) SOC_RTC_DATA_HIGH));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_rodata, (int*) SOC_RTC_DATA_LOW, (int*) SOC_RTC_DATA_HIGH));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_noinit, (int*) SOC_RTC_DATA_LOW, (int*) SOC_RTC_DATA_HIGH));
|
2018-09-29 13:53:37 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_force_fast, (int*) SOC_RTC_DRAM_LOW, (int*) SOC_RTC_DRAM_HIGH));
|
|
|
|
TEST_ASSERT(data_in_segment(&s_rtc_force_slow, (int*) SOC_RTC_DATA_LOW, (int*) SOC_RTC_DATA_HIGH));
|
2021-07-27 16:22:24 +08:00
|
|
|
|
|
|
|
#if CONFIG_SPIRAM_ALLOW_NOINIT_SEG_EXTERNAL_MEMORY
|
|
|
|
TEST_ASSERT(data_in_segment(&s_noinit_ext, &_ext_ram_noinit_start, &_ext_ram_noinit_end));
|
|
|
|
#endif
|
2018-07-29 14:17:09 +03:00
|
|
|
}
|
2020-02-07 00:00:45 +00:00
|
|
|
|
2022-05-20 18:16:47 +08:00
|
|
|
#endif //!TEMPORARY_DISABLED_FOR_TARGETS(ESP32C2)
|
2020-02-07 00:00:45 +00:00
|
|
|
|
|
|
|
#if CONFIG_SPIRAM_ALLOW_NOINIT_SEG_EXTERNAL_MEMORY
|
|
|
|
|
|
|
|
#define TEST_BUFFER_SIZE (16*1024/4)
|
|
|
|
static EXT_RAM_NOINIT_ATTR uint32_t s_noinit_buffer[TEST_BUFFER_SIZE];
|
|
|
|
|
|
|
|
static void write_spiram_and_reset(void)
|
|
|
|
{
|
|
|
|
// Fill the noinit buffer
|
|
|
|
printf("Filling buffer\n");
|
|
|
|
for (uint32_t i = 0; i < TEST_BUFFER_SIZE; i++) {
|
|
|
|
s_noinit_buffer[i] = i ^ 0x55555555U;
|
|
|
|
}
|
|
|
|
printf("Flushing cache\n");
|
|
|
|
// Flush the cache out to SPIRAM before resetting.
|
2022-05-11 10:32:56 +08:00
|
|
|
esp_psram_extram_writeback_cache();
|
2020-02-07 00:00:45 +00:00
|
|
|
|
|
|
|
printf("Restarting\n");
|
|
|
|
// Reset to test that noinit memory is left intact.
|
|
|
|
esp_restart();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void check_spiram_contents(void)
|
|
|
|
{
|
|
|
|
// Confirm that the memory contents are still what we expect
|
|
|
|
uint32_t error_count = 0;
|
|
|
|
for (uint32_t i = 0; i < TEST_BUFFER_SIZE; i++) {
|
|
|
|
if (s_noinit_buffer[i] != (i ^ 0x55555555U)) {
|
|
|
|
error_count++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
printf("Found %" PRIu32 " memory errors\n", error_count);
|
|
|
|
TEST_ASSERT(error_count == 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE_MULTIPLE_STAGES("Spiram test noinit memory", "[spiram]", write_spiram_and_reset, check_spiram_contents);
|
|
|
|
|
|
|
|
#endif // CONFIG_SPIRAM_ALLOW_NOINIT_SEG_EXTERNAL_MEMORY
|
2021-07-27 16:22:24 +08:00
|
|
|
|
|
|
|
|
|
|
|
#if CONFIG_SPIRAM_ALLOW_BSS_SEG_EXTERNAL_MEMORY
|
2022-03-23 20:16:08 +08:00
|
|
|
#define TEST_BSS_NUM (256 * 1024)
|
2022-03-23 20:22:54 +08:00
|
|
|
static EXT_RAM_BSS_ATTR uint32_t s_bss_buffer[TEST_BSS_NUM];
|
2021-07-27 16:22:24 +08:00
|
|
|
|
|
|
|
TEST_CASE("Test variables placed in external .bss segment", "[ld]")
|
|
|
|
{
|
|
|
|
for (int i = 0; i < TEST_BSS_NUM; i++) {
|
|
|
|
TEST_ASSERT(data_in_segment(&s_bss_buffer[i], &_ext_ram_bss_start, &_ext_ram_bss_end));
|
|
|
|
TEST_ASSERT_EQUAL(0, s_bss_buffer[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif //#if CONFIG_SPIRAM_ALLOW_BSS_SEG_EXTERNAL_MEMORY
|