mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
unity_utils: added helper function to disable cache and run user function
This commit is contained in:
parent
cdd50aff1a
commit
f24983a942
@ -317,7 +317,7 @@ esp_err_t mcpwm_capture_channel_register_event_callbacks(mcpwm_cap_channel_handl
|
|||||||
|
|
||||||
// lazy install interrupt service
|
// lazy install interrupt service
|
||||||
if (!cap_channel->intr) {
|
if (!cap_channel->intr) {
|
||||||
// we want the interrupt servie to be enabled after allocation successfully
|
// we want the interrupt service to be enabled after allocation successfully
|
||||||
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ ESP_INTR_FLAG_INTRDISABLED;
|
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ ESP_INTR_FLAG_INTRDISABLED;
|
||||||
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
||||||
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_CAPTURE(cap_chan_id),
|
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_CAPTURE(cap_chan_id),
|
||||||
|
@ -160,7 +160,7 @@ esp_err_t mcpwm_comparator_register_event_callbacks(mcpwm_cmpr_handle_t cmpr, co
|
|||||||
|
|
||||||
// lazy install interrupt service
|
// lazy install interrupt service
|
||||||
if (!cmpr->intr) {
|
if (!cmpr->intr) {
|
||||||
// we want the interrupt servie to be enabled after allocation successfully
|
// we want the interrupt service to be enabled after allocation successfully
|
||||||
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ ESP_INTR_FLAG_INTRDISABLED;
|
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ ESP_INTR_FLAG_INTRDISABLED;
|
||||||
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
||||||
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_CMP_EQUAL(oper_id, cmpr_id),
|
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_CMP_EQUAL(oper_id, cmpr_id),
|
||||||
|
@ -243,7 +243,7 @@ esp_err_t mcpwm_fault_register_event_callbacks(mcpwm_fault_handle_t fault, const
|
|||||||
|
|
||||||
// lazy install interrupt service
|
// lazy install interrupt service
|
||||||
if (!gpio_fault->intr) {
|
if (!gpio_fault->intr) {
|
||||||
// we want the interrupt servie to be enabled after allocation successfully
|
// we want the interrupt service to be enabled after allocation successfully
|
||||||
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ESP_INTR_FLAG_INTRDISABLED;
|
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ESP_INTR_FLAG_INTRDISABLED;
|
||||||
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
||||||
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_FAULT_MASK(fault_id),
|
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_FAULT_MASK(fault_id),
|
||||||
|
@ -233,7 +233,7 @@ esp_err_t mcpwm_operator_register_event_callbacks(mcpwm_oper_handle_t oper, cons
|
|||||||
|
|
||||||
// lazy install interrupt service
|
// lazy install interrupt service
|
||||||
if (!oper->intr) {
|
if (!oper->intr) {
|
||||||
// we want the interrupt servie to be enabled after allocation successfully
|
// we want the interrupt service to be enabled after allocation successfully
|
||||||
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ ESP_INTR_FLAG_INTRDISABLED;
|
int isr_flags = MCPWM_INTR_ALLOC_FLAG & ~ ESP_INTR_FLAG_INTRDISABLED;
|
||||||
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
ESP_RETURN_ON_ERROR(esp_intr_alloc_intrstatus(mcpwm_periph_signals.groups[group_id].irq_id, isr_flags,
|
||||||
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_OPER_MASK(oper_id),
|
(uint32_t)mcpwm_ll_intr_get_status_reg(hal->dev), MCPWM_LL_EVENT_OPER_MASK(oper_id),
|
||||||
|
@ -98,7 +98,7 @@ struct pcnt_unit_t {
|
|||||||
|
|
||||||
struct pcnt_chan_t {
|
struct pcnt_chan_t {
|
||||||
pcnt_unit_t *unit; // pointer to the PCNT unit where it derives from
|
pcnt_unit_t *unit; // pointer to the PCNT unit where it derives from
|
||||||
uint32_t channel_id; // channel ID, index from 0
|
int channel_id; // channel ID, index from 0
|
||||||
int edge_gpio_num;
|
int edge_gpio_num;
|
||||||
int level_gpio_num;
|
int level_gpio_num;
|
||||||
};
|
};
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
set(srcs "test_app_main.c"
|
set(srcs "test_app_main.c"
|
||||||
"test_gptimer.c"
|
"test_gptimer.c")
|
||||||
"test_gptimer_iram.c")
|
|
||||||
|
if(CONFIG_GPTIMER_ISR_IRAM_SAFE)
|
||||||
|
list(APPEND srcs "test_gptimer_iram.c")
|
||||||
|
endif()
|
||||||
|
|
||||||
# In order for the cases defined by `TEST_CASE` to be linked into the final elf,
|
# In order for the cases defined by `TEST_CASE` to be linked into the final elf,
|
||||||
# the component can be registered as WHOLE_ARCHIVE
|
# the component can be registered as WHOLE_ARCHIVE
|
||||||
|
@ -5,102 +5,58 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "sdkconfig.h"
|
#include <inttypes.h>
|
||||||
#include "freertos/FreeRTOS.h"
|
|
||||||
#include "freertos/task.h"
|
|
||||||
#include "freertos/semphr.h"
|
|
||||||
#include "unity.h"
|
#include "unity.h"
|
||||||
|
#include "unity_test_utils.h"
|
||||||
|
#include "esp_attr.h"
|
||||||
#include "driver/gptimer.h"
|
#include "driver/gptimer.h"
|
||||||
#include "spi_flash_mmap.h"
|
|
||||||
#include "esp_flash.h"
|
|
||||||
#include "soc/soc_caps.h"
|
|
||||||
|
|
||||||
#if CONFIG_GPTIMER_ISR_IRAM_SAFE
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
size_t buf_size;
|
|
||||||
uint8_t *buf;
|
|
||||||
size_t flash_addr;
|
|
||||||
size_t repeat_count;
|
|
||||||
SemaphoreHandle_t done_sem;
|
|
||||||
} read_task_arg_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
size_t delay_time_us;
|
|
||||||
size_t repeat_count;
|
|
||||||
} block_task_arg_t;
|
|
||||||
|
|
||||||
static bool IRAM_ATTR on_gptimer_alarm_cb(gptimer_handle_t timer, const gptimer_alarm_event_data_t *edata, void *user_ctx)
|
static bool IRAM_ATTR on_gptimer_alarm_cb(gptimer_handle_t timer, const gptimer_alarm_event_data_t *edata, void *user_ctx)
|
||||||
{
|
{
|
||||||
block_task_arg_t *arg = (block_task_arg_t *)user_ctx;
|
uint32_t *alarm_counts = (uint32_t *)user_ctx;
|
||||||
esp_rom_delay_us(arg->delay_time_us);
|
(*alarm_counts)++;
|
||||||
arg->repeat_count++;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void flash_read_task(void *varg)
|
static void IRAM_ATTR test_delay_post_cache_disable(void *args)
|
||||||
{
|
{
|
||||||
read_task_arg_t *arg = (read_task_arg_t *)varg;
|
esp_rom_delay_us(1000);
|
||||||
for (size_t i = 0; i < arg->repeat_count; i++) {
|
|
||||||
TEST_ESP_OK(esp_flash_read(NULL, arg->buf, arg->flash_addr, arg->buf_size));
|
|
||||||
}
|
|
||||||
xSemaphoreGive(arg->done_sem);
|
|
||||||
vTaskDelete(NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("gptimer_iram_interrupt_safe", "[gptimer]")
|
TEST_CASE("gptimer_interrupt_iram_safe", "[gptimer]")
|
||||||
{
|
{
|
||||||
gptimer_handle_t gptimer = NULL;
|
gptimer_handle_t gptimer = NULL;
|
||||||
const size_t size = 128;
|
|
||||||
uint8_t *buf = malloc(size);
|
|
||||||
TEST_ASSERT_NOT_NULL(buf);
|
|
||||||
SemaphoreHandle_t done_sem = xSemaphoreCreateBinary();
|
|
||||||
TEST_ASSERT_NOT_NULL(done_sem);
|
|
||||||
read_task_arg_t read_arg = {
|
|
||||||
.buf_size = size,
|
|
||||||
.buf = buf,
|
|
||||||
.flash_addr = 0,
|
|
||||||
.repeat_count = 1000,
|
|
||||||
.done_sem = done_sem,
|
|
||||||
};
|
|
||||||
|
|
||||||
block_task_arg_t block_arg = {
|
|
||||||
.repeat_count = 0,
|
|
||||||
.delay_time_us = 100,
|
|
||||||
};
|
|
||||||
|
|
||||||
gptimer_config_t timer_config = {
|
gptimer_config_t timer_config = {
|
||||||
.clk_src = GPTIMER_CLK_SRC_DEFAULT,
|
.clk_src = GPTIMER_CLK_SRC_DEFAULT,
|
||||||
.direction = GPTIMER_COUNT_UP,
|
.direction = GPTIMER_COUNT_UP,
|
||||||
.resolution_hz = 1 * 1000 * 1000,
|
.resolution_hz = 1 * 1000 * 1000, // 1MHz, 1 tick = 1us
|
||||||
};
|
};
|
||||||
TEST_ESP_OK(gptimer_new_timer(&timer_config, &gptimer));
|
TEST_ESP_OK(gptimer_new_timer(&timer_config, &gptimer));
|
||||||
gptimer_event_callbacks_t cbs = {
|
gptimer_event_callbacks_t cbs = {
|
||||||
.on_alarm = on_gptimer_alarm_cb,
|
.on_alarm = on_gptimer_alarm_cb,
|
||||||
};
|
};
|
||||||
|
uint32_t alarm_counts = 0;
|
||||||
|
TEST_ESP_OK(gptimer_register_event_callbacks(gptimer, &cbs, &alarm_counts));
|
||||||
gptimer_alarm_config_t alarm_config = {
|
gptimer_alarm_config_t alarm_config = {
|
||||||
.reload_count = 0,
|
.reload_count = 0,
|
||||||
.alarm_count = 120,
|
.alarm_count = 100, // 100us per alarm event
|
||||||
.flags.auto_reload_on_alarm = true,
|
.flags.auto_reload_on_alarm = true,
|
||||||
};
|
};
|
||||||
TEST_ESP_OK(gptimer_set_alarm_action(gptimer, &alarm_config));
|
TEST_ESP_OK(gptimer_set_alarm_action(gptimer, &alarm_config));
|
||||||
TEST_ESP_OK(gptimer_register_event_callbacks(gptimer, &cbs, &block_arg));
|
|
||||||
TEST_ESP_OK(gptimer_enable(gptimer));
|
TEST_ESP_OK(gptimer_enable(gptimer));
|
||||||
TEST_ESP_OK(gptimer_start(gptimer));
|
TEST_ESP_OK(gptimer_start(gptimer));
|
||||||
|
|
||||||
xTaskCreatePinnedToCore(flash_read_task, "read_flash", 2048, &read_arg, 3, NULL, portNUM_PROCESSORS - 1);
|
vTaskDelay(pdMS_TO_TICKS(10));
|
||||||
// wait for task done
|
|
||||||
xSemaphoreTake(done_sem, portMAX_DELAY);
|
printf("disable flash cache and check the alarm events are still in working\r\n");
|
||||||
printf("alarm callback runs %d times\r\n", block_arg.repeat_count);
|
for (int i = 0; i < 10; i++) {
|
||||||
TEST_ASSERT_GREATER_THAN(1000, block_arg.repeat_count);
|
unity_utils_run_cache_disable_stub(test_delay_post_cache_disable, NULL);
|
||||||
|
}
|
||||||
|
printf("alarm counts: %"PRIu32"\r\n", alarm_counts);
|
||||||
|
TEST_ASSERT_GREATER_THAN(150, alarm_counts);
|
||||||
|
|
||||||
// delete gptimer
|
// delete gptimer
|
||||||
TEST_ESP_OK(gptimer_stop(gptimer));
|
TEST_ESP_OK(gptimer_stop(gptimer));
|
||||||
TEST_ESP_OK(gptimer_disable(gptimer));
|
TEST_ESP_OK(gptimer_disable(gptimer));
|
||||||
TEST_ESP_OK(gptimer_del_timer(gptimer));
|
TEST_ESP_OK(gptimer_del_timer(gptimer));
|
||||||
vSemaphoreDelete(done_sem);
|
|
||||||
free(buf);
|
|
||||||
// leave time for IDLE task to recycle deleted task
|
|
||||||
vTaskDelay(2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // CONFIG_GPTIMER_ISR_IRAM_SAFE
|
|
||||||
|
@ -9,9 +9,9 @@
|
|||||||
#include "freertos/task.h"
|
#include "freertos/task.h"
|
||||||
#include "freertos/event_groups.h"
|
#include "freertos/event_groups.h"
|
||||||
#include "unity.h"
|
#include "unity.h"
|
||||||
|
#include "unity_test_utils.h"
|
||||||
#include "soc/soc_caps.h"
|
#include "soc/soc_caps.h"
|
||||||
#include "esp_private/esp_clk.h"
|
#include "esp_private/esp_clk.h"
|
||||||
#include "esp_private/spi_flash_os.h"
|
|
||||||
#include "driver/mcpwm_cap.h"
|
#include "driver/mcpwm_cap.h"
|
||||||
#include "driver/mcpwm_sync.h"
|
#include "driver/mcpwm_sync.h"
|
||||||
#include "driver/gpio.h"
|
#include "driver/gpio.h"
|
||||||
@ -28,15 +28,12 @@ static bool IRAM_ATTR test_capture_callback_iram_safe(mcpwm_cap_channel_handle_t
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void IRAM_ATTR test_mcpwm_capture_gpio_simulate(int gpio_sig)
|
static void IRAM_ATTR test_simulate_input_post_cache_disable(void *args)
|
||||||
{
|
{
|
||||||
// disable flash cache
|
int gpio_sig = (int)args;
|
||||||
spi_flash_guard_get()->start();
|
|
||||||
gpio_set_level(gpio_sig, 1);
|
gpio_set_level(gpio_sig, 1);
|
||||||
esp_rom_delay_us(1000);
|
esp_rom_delay_us(1000);
|
||||||
gpio_set_level(gpio_sig, 0);
|
gpio_set_level(gpio_sig, 0);
|
||||||
// enable flash cache
|
|
||||||
spi_flash_guard_get()->end();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("mcpwm_capture_iram_safe", "[mcpwm]")
|
TEST_CASE("mcpwm_capture_iram_safe", "[mcpwm]")
|
||||||
@ -77,7 +74,7 @@ TEST_CASE("mcpwm_capture_iram_safe", "[mcpwm]")
|
|||||||
TEST_ESP_OK(mcpwm_capture_timer_start(cap_timer));
|
TEST_ESP_OK(mcpwm_capture_timer_start(cap_timer));
|
||||||
|
|
||||||
printf("disable cache, simulate GPIO capture signal\r\n");
|
printf("disable cache, simulate GPIO capture signal\r\n");
|
||||||
test_mcpwm_capture_gpio_simulate(cap_gpio);
|
unity_utils_run_cache_disable_stub(test_simulate_input_post_cache_disable, (void *)cap_gpio);
|
||||||
|
|
||||||
printf("capture value: Pos=%"PRIu32", Neg=%"PRIu32"\r\n", cap_value[0], cap_value[1]);
|
printf("capture value: Pos=%"PRIu32", Neg=%"PRIu32"\r\n", cap_value[0], cap_value[1]);
|
||||||
// Capture timer is clocked from APB by default
|
// Capture timer is clocked from APB by default
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
set(srcs "test_app_main.c"
|
set(srcs "test_app_main.c"
|
||||||
"test_pulse_cnt_simulator.c"
|
"test_pulse_cnt_simulator.c"
|
||||||
"test_pulse_cnt.c"
|
"test_pulse_cnt.c")
|
||||||
"test_pulse_cnt_iram.c")
|
|
||||||
|
if(CONFIG_PCNT_ISR_IRAM_SAFE)
|
||||||
|
list(APPEND srcs "test_pulse_cnt_iram.c")
|
||||||
|
endif()
|
||||||
|
|
||||||
# In order for the cases defined by `TEST_CASE` to be linked into the final elf,
|
# In order for the cases defined by `TEST_CASE` to be linked into the final elf,
|
||||||
# the component can be registered as WHOLE_ARCHIVE
|
# the component can be registered as WHOLE_ARCHIVE
|
||||||
|
@ -10,16 +10,14 @@
|
|||||||
#include "freertos/task.h"
|
#include "freertos/task.h"
|
||||||
#include "freertos/semphr.h"
|
#include "freertos/semphr.h"
|
||||||
#include "unity.h"
|
#include "unity.h"
|
||||||
|
#include "unity_test_utils.h"
|
||||||
#include "driver/pulse_cnt.h"
|
#include "driver/pulse_cnt.h"
|
||||||
#include "driver/gpio.h"
|
#include "driver/gpio.h"
|
||||||
#include "spi_flash_mmap.h"
|
#include "spi_flash_mmap.h"
|
||||||
#include "esp_attr.h"
|
#include "esp_attr.h"
|
||||||
#include "soc/soc_caps.h"
|
#include "soc/soc_caps.h"
|
||||||
#include "esp_private/spi_flash_os.h"
|
|
||||||
#include "test_pulse_cnt_board.h"
|
#include "test_pulse_cnt_board.h"
|
||||||
|
|
||||||
#if CONFIG_PCNT_ISR_IRAM_SAFE
|
|
||||||
|
|
||||||
static bool IRAM_ATTR test_pcnt_iram_safe_callback(pcnt_unit_handle_t unit, const pcnt_watch_event_data_t *event_data, void *user_data)
|
static bool IRAM_ATTR test_pcnt_iram_safe_callback(pcnt_unit_handle_t unit, const pcnt_watch_event_data_t *event_data, void *user_data)
|
||||||
{
|
{
|
||||||
uint32_t *data = (uint32_t *)user_data;
|
uint32_t *data = (uint32_t *)user_data;
|
||||||
@ -29,13 +27,10 @@ static bool IRAM_ATTR test_pcnt_iram_safe_callback(pcnt_unit_handle_t unit, cons
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void IRAM_ATTR test_pcnt_iram_simulation(int gpio_sig)
|
static void IRAM_ATTR test_simulate_input_post_cache_disable(void *args)
|
||||||
{
|
{
|
||||||
// disable flash cache
|
int gpio_sig = (int)args;
|
||||||
spi_flash_guard_get()->start();
|
|
||||||
test_gpio_simulate_rising_edge(gpio_sig, 2);
|
test_gpio_simulate_rising_edge(gpio_sig, 2);
|
||||||
// enable flash cache
|
|
||||||
spi_flash_guard_get()->end();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("pcnt_iram_interrupt_safe", "[pcnt]")
|
TEST_CASE("pcnt_iram_interrupt_safe", "[pcnt]")
|
||||||
@ -83,8 +78,9 @@ TEST_CASE("pcnt_iram_interrupt_safe", "[pcnt]")
|
|||||||
|
|
||||||
printf("disable cache and check interrupt triggered\r\n");
|
printf("disable cache and check interrupt triggered\r\n");
|
||||||
TEST_ESP_OK(pcnt_unit_clear_count(unit));
|
TEST_ESP_OK(pcnt_unit_clear_count(unit));
|
||||||
// the function that will disable the flash must be placed in the IRAM
|
|
||||||
test_pcnt_iram_simulation(TEST_PCNT_GPIO_A);
|
// disable flash cache and run simulation
|
||||||
|
unity_utils_run_cache_disable_stub(test_simulate_input_post_cache_disable, (void *)TEST_PCNT_GPIO_A);
|
||||||
// check if the interrupt has fired up
|
// check if the interrupt has fired up
|
||||||
TEST_ASSERT_EQUAL(1, num_of_event_triggered);
|
TEST_ASSERT_EQUAL(1, num_of_event_triggered);
|
||||||
|
|
||||||
@ -101,5 +97,3 @@ TEST_CASE("pcnt_iram_interrupt_safe", "[pcnt]")
|
|||||||
TEST_ESP_OK(pcnt_del_channel(channelB));
|
TEST_ESP_OK(pcnt_del_channel(channelB));
|
||||||
TEST_ESP_OK(pcnt_del_unit(unit));
|
TEST_ESP_OK(pcnt_del_unit(unit));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // CONFIG_PCNT_ISR_IRAM_SAFE
|
|
||||||
|
@ -17,7 +17,7 @@ if(CONFIG_UNITY_ENABLE_IDF_TEST_RUNNER)
|
|||||||
list(APPEND srcs "unity_runner.c")
|
list(APPEND srcs "unity_runner.c")
|
||||||
# Note the following files are not compatible with the Linux target.
|
# Note the following files are not compatible with the Linux target.
|
||||||
# On Linux, these are masked because we also don't use the IDF test runner there
|
# On Linux, these are masked because we also don't use the IDF test runner there
|
||||||
list(APPEND srcs "unity_utils_freertos.c")
|
list(APPEND srcs "unity_utils_freertos.c" "unity_utils_cache.c")
|
||||||
list(APPEND requires "freertos")
|
list(APPEND requires "freertos")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -39,6 +39,10 @@ idf_component_register(SRCS "${srcs}"
|
|||||||
INCLUDE_DIRS ${includes}
|
INCLUDE_DIRS ${includes}
|
||||||
REQUIRES ${requires})
|
REQUIRES ${requires})
|
||||||
|
|
||||||
|
if(CONFIG_UNITY_ENABLE_IDF_TEST_RUNNER)
|
||||||
|
idf_component_optional_requires(PRIVATE spi_flash)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(NOT "${target}" STREQUAL "linux")
|
if(NOT "${target}" STREQUAL "linux")
|
||||||
target_compile_definitions(${COMPONENT_LIB} PUBLIC
|
target_compile_definitions(${COMPONENT_LIB} PUBLIC
|
||||||
-DUNITY_INCLUDE_CONFIG_H
|
-DUNITY_INCLUDE_CONFIG_H
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
#include "freertos/task.h"
|
#include "freertos/task.h"
|
||||||
#include "unity_test_utils_memory.h"
|
#include "unity_test_utils_memory.h"
|
||||||
|
#include "unity_test_utils_cache.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
25
components/unity/include/unity_test_utils_cache.h
Normal file
25
components/unity/include/unity_test_utils_cache.h
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Disable flash cache and run user stub function and then enable flash cache again
|
||||||
|
*
|
||||||
|
* @note You should make sure the passed-in function is in internal RAM.
|
||||||
|
*
|
||||||
|
* @param post_cache_disable User function to be invoked after cache is disabled.
|
||||||
|
* @param user_ctx User context to be passed to user function.
|
||||||
|
*/
|
||||||
|
void unity_utils_run_cache_disable_stub(void (*post_cache_disable)(void *), void *user_ctx);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
22
components/unity/unity_utils_cache.c
Normal file
22
components/unity/unity_utils_cache.c
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "unity.h"
|
||||||
|
#include "unity_test_utils_cache.h"
|
||||||
|
#include "esp_attr.h"
|
||||||
|
#include "esp_memory_utils.h"
|
||||||
|
#include "esp_private/spi_flash_os.h"
|
||||||
|
|
||||||
|
IRAM_ATTR void unity_utils_run_cache_disable_stub(void (*post_cache_disable)(void *), void *user_ctx)
|
||||||
|
{
|
||||||
|
// callback function must reside in IRAM
|
||||||
|
TEST_ASSERT_TRUE(esp_ptr_in_iram(post_cache_disable));
|
||||||
|
// disable flash cache
|
||||||
|
spi_flash_guard_get()->start();
|
||||||
|
post_cache_disable(user_ctx);
|
||||||
|
// enable flash cache
|
||||||
|
spi_flash_guard_get()->end();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user