kernel: stack: Check possible overflow
Check possible overflow in k_stack data struct. An overflow can happens resulting in a much smaller amount of memory allocation. Signed-off-by: Flavio Ceolin <flavio.ceolin@intel.com>
This commit is contained in:
parent
37e3449a39
commit
11b85ee510
|
@ -8,6 +8,7 @@
|
||||||
* @brief fixed-size stack object
|
* @brief fixed-size stack object
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <zephyr/sys/math_extras.h>
|
||||||
#include <zephyr/kernel.h>
|
#include <zephyr/kernel.h>
|
||||||
#include <zephyr/kernel_structs.h>
|
#include <zephyr/kernel_structs.h>
|
||||||
|
|
||||||
|
@ -64,8 +65,12 @@ int32_t z_impl_k_stack_alloc_init(struct k_stack *stack, uint32_t num_entries)
|
||||||
static inline int32_t z_vrfy_k_stack_alloc_init(struct k_stack *stack,
|
static inline int32_t z_vrfy_k_stack_alloc_init(struct k_stack *stack,
|
||||||
uint32_t num_entries)
|
uint32_t num_entries)
|
||||||
{
|
{
|
||||||
|
size_t total_size;
|
||||||
|
|
||||||
K_OOPS(K_SYSCALL_OBJ_NEVER_INIT(stack, K_OBJ_STACK));
|
K_OOPS(K_SYSCALL_OBJ_NEVER_INIT(stack, K_OBJ_STACK));
|
||||||
K_OOPS(K_SYSCALL_VERIFY(num_entries > 0));
|
K_OOPS(K_SYSCALL_VERIFY(num_entries > 0));
|
||||||
|
K_OOPS(K_SYSCALL_VERIFY(!size_mul_overflow(num_entries, sizeof(stack_data_t),
|
||||||
|
&total_size)));
|
||||||
return z_impl_k_stack_alloc_init(stack, num_entries);
|
return z_impl_k_stack_alloc_init(stack, num_entries);
|
||||||
}
|
}
|
||||||
#include <syscalls/k_stack_alloc_init_mrsh.c>
|
#include <syscalls/k_stack_alloc_init_mrsh.c>
|
||||||
|
|
Loading…
Reference in a new issue