|  | /* | 
|  | * Copyright (c) 2019 Intel Corporation | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  |  | 
|  | #include <zephyr/kernel.h> | 
|  | #include <zephyr/sys/mutex.h> | 
|  | #include <zephyr/syscall_handler.h> | 
|  | #include <zephyr/kernel_structs.h> | 
|  |  | 
|  | static struct k_mutex *get_k_mutex(struct sys_mutex *mutex) | 
|  | { | 
|  | struct z_object *obj; | 
|  |  | 
|  | obj = z_object_find(mutex); | 
|  | if (obj == NULL || obj->type != K_OBJ_SYS_MUTEX) { | 
|  | return NULL; | 
|  | } | 
|  |  | 
|  | return obj->data.mutex; | 
|  | } | 
|  |  | 
|  | static bool check_sys_mutex_addr(struct sys_mutex *addr) | 
|  | { | 
|  | /* sys_mutex memory is never touched, just used to lookup the | 
|  | * underlying k_mutex, but we don't want threads using mutexes | 
|  | * that are outside their memory domain | 
|  | */ | 
|  | return Z_SYSCALL_MEMORY_WRITE(addr, sizeof(struct sys_mutex)); | 
|  | } | 
|  |  | 
|  | int z_impl_z_sys_mutex_kernel_lock(struct sys_mutex *mutex, k_timeout_t timeout) | 
|  | { | 
|  | struct k_mutex *kernel_mutex = get_k_mutex(mutex); | 
|  |  | 
|  | if (kernel_mutex == NULL) { | 
|  | return -EINVAL; | 
|  | } | 
|  |  | 
|  | return k_mutex_lock(kernel_mutex, timeout); | 
|  | } | 
|  |  | 
|  | static inline int z_vrfy_z_sys_mutex_kernel_lock(struct sys_mutex *mutex, | 
|  | k_timeout_t timeout) | 
|  | { | 
|  | if (check_sys_mutex_addr(mutex)) { | 
|  | return -EACCES; | 
|  | } | 
|  |  | 
|  | return z_impl_z_sys_mutex_kernel_lock(mutex, timeout); | 
|  | } | 
|  | #include <syscalls/z_sys_mutex_kernel_lock_mrsh.c> | 
|  |  | 
|  | int z_impl_z_sys_mutex_kernel_unlock(struct sys_mutex *mutex) | 
|  | { | 
|  | struct k_mutex *kernel_mutex = get_k_mutex(mutex); | 
|  |  | 
|  | if (kernel_mutex == NULL || kernel_mutex->lock_count == 0) { | 
|  | return -EINVAL; | 
|  | } | 
|  |  | 
|  | return k_mutex_unlock(kernel_mutex); | 
|  | } | 
|  |  | 
|  | static inline int z_vrfy_z_sys_mutex_kernel_unlock(struct sys_mutex *mutex) | 
|  | { | 
|  | if (check_sys_mutex_addr(mutex)) { | 
|  | return -EACCES; | 
|  | } | 
|  |  | 
|  | return z_impl_z_sys_mutex_kernel_unlock(mutex); | 
|  | } | 
|  | #include <syscalls/z_sys_mutex_kernel_unlock_mrsh.c> |