Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | /*
* Copyright (c) 2016 Intel Corporation
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <zephyr/ztest.h>
#include <zephyr/irq_offload.h>
#include <zephyr/ztest_error_hook.h>
#define TIMEOUT K_MSEC(100)
#define STACK_SIZE (512 + CONFIG_TEST_EXTRA_STACK_SIZE)
#define STACK_LEN 2
static ZTEST_BMEM stack_data_t data[STACK_LEN];
extern struct k_stack stack;
K_THREAD_STACK_DEFINE(threadstack2, STACK_SIZE);
struct k_thread thread_data2;
static void stack_pop_fail(struct k_stack *rx_data_stack)
{
stack_data_t rx_data;
/**TESTPOINT: stack pop returns -EBUSY*/
zassert_equal(k_stack_pop(rx_data_stack, &rx_data, K_NO_WAIT), -EBUSY);
/**TESTPOINT: stack pop returns -EAGAIN*/
zassert_equal(k_stack_pop(rx_data_stack, &rx_data, TIMEOUT), -EAGAIN);
}
/**
* @addtogroup kernel_stack_tests
* @{
*/
/* Sub-thread entry */
void tStack_pop_entry(void *p1, void *p2, void *p3)
{
zassert_true(k_stack_pop(p1, p2, K_FOREVER), "stack pop failed\n");
}
/**
* @brief Verifies stack pop functionality
* @see k_stack_init(), k_stack_pop()
*/
ZTEST(stack_fail, test_stack_pop_fail)
{
k_stack_init(&stack, data, STACK_LEN);
stack_pop_fail(&stack);
}
/**
* @brief Verifies cleanup a stack that still be needed by another
* thread.
* @see k_stack_cleanup()
*/
ZTEST(stack_fail, test_stack_cleanup_error)
{
stack_data_t rx_data[STACK_LEN - 1];
k_stack_init(&stack, data, STACK_LEN);
/* Creat a new thread */
k_tid_t tid = k_thread_create(&thread_data2, threadstack2, STACK_SIZE,
tStack_pop_entry, &stack,
rx_data, NULL, K_PRIO_PREEMPT(0), 0,
K_NO_WAIT);
/* Delay for finishing some actions of the new thread */
k_sleep(K_MSEC(500));
/* Try to clean up the stack, that still be waited by the thread */
zassert_true(k_stack_cleanup(&stack) == -EAGAIN, "The stack is cleanuped successful");
/* clear the spawn thread to avoid side effect */
k_thread_abort(tid);
}
/**
* @brief Verifies push a data in the full stack.
* @see k_stack_push()
*/
ZTEST(stack_fail, test_stack_push_full)
{
stack_data_t tx_data[STACK_LEN] = {0};
stack_data_t data_tmp = 0;
k_stack_init(&stack, data, STACK_LEN);
for (int i = 0; i < STACK_LEN; i++) {
zassert_true(k_stack_push(&stack, tx_data[i]) == 0, "push data into stack failed");
}
/* Verify that push a data in the full stack, a negative value will be met */
zassert_true(k_stack_push(&stack, data_tmp) == -ENOMEM, "push data successful");
}
#ifdef CONFIG_USERSPACE
/**
* @brief Verifies stack pop from a user thread
* @see k_stack_init(), k_stack_pop()
*/
ZTEST_USER(stack_fail, test_stack_user_pop_fail)
{
struct k_stack *alloc_stack = k_object_alloc(K_OBJ_STACK);
zassert_not_null(alloc_stack, "couldn't allocate stack object");
zassert_false(k_stack_alloc_init(alloc_stack, STACK_LEN),
"stack init failed");
stack_pop_fail(alloc_stack);
}
/**
* @brief Verifies stack alloc and initialize a null pointer.
* @see k_stack_alloc_init()
*/
ZTEST_USER(stack_fail, test_stack_user_init_null)
{
ztest_set_fault_valid(true);
k_stack_alloc_init(NULL, STACK_LEN);
}
/**
* @brief Verify that alloc and initialize a stack with
* 0 memory.
* @see k_stack_alloc_init()
*/
ZTEST_USER(stack_fail, test_stack_user_init_invalid_value)
{
ztest_set_fault_valid(true);
struct k_stack *alloc_stack = k_object_alloc(K_OBJ_STACK);
zassert_not_null(alloc_stack, "couldn't allocate stack object");
k_stack_alloc_init(alloc_stack, 0);
}
/**
* @brief Verify that push some data into a NULL
* pointer.
* @see k_stack_push()
*/
ZTEST_USER(stack_fail, test_stack_user_push_null)
{
ztest_set_fault_valid(true);
k_stack_push(NULL, 0);
}
/**
* @brief Verifies pop data from a NULL pointer.
* @see k_stack_pop()
*/
ZTEST_USER(stack_fail, test_stack_user_pop_null)
{
ztest_set_fault_valid(true);
k_stack_pop(NULL, 0, K_NO_WAIT);
}
/**
* @brief Verifies cleanup a stack that its data still be waited by
* another thread.
* @see k_stack_pop()
*/
ZTEST_USER(stack_fail, test_stack_user_pop_permission)
{
ztest_set_fault_valid(true);
struct k_stack *alloc_stack = k_object_alloc(K_OBJ_STACK);
zassert_not_null(alloc_stack, "couldn't allocate stack object");
zassert_false(k_stack_alloc_init(alloc_stack, STACK_LEN),
"stack init failed");
/* Try to access and to write data at invalid address */
k_stack_pop(alloc_stack, (stack_data_t *)alloc_stack, K_NO_WAIT);
}
#endif
/**
* @}
*/
|