1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- /*
- * Copyright (c) 2019 Intel Corporation
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #include <kernel.h>
- #include <sys/mutex.h>
- #include <syscall_handler.h>
- #include <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>
|