Zephyr API Documentation
2.7.0-rc2
A Scalable Open Source RTOS
|
Functions | |
static uintptr_t | arch_syscall_invoke0 (uintptr_t call_id) |
static uintptr_t | arch_syscall_invoke1 (uintptr_t arg1, uintptr_t call_id) |
static uintptr_t | arch_syscall_invoke2 (uintptr_t arg1, uintptr_t arg2, uintptr_t call_id) |
static uintptr_t | arch_syscall_invoke3 (uintptr_t arg1, uintptr_t arg2, uintptr_t arg3, uintptr_t call_id) |
static uintptr_t | arch_syscall_invoke4 (uintptr_t arg1, uintptr_t arg2, uintptr_t arg3, uintptr_t arg4, uintptr_t call_id) |
static uintptr_t | arch_syscall_invoke5 (uintptr_t arg1, uintptr_t arg2, uintptr_t arg3, uintptr_t arg4, uintptr_t arg5, uintptr_t call_id) |
static uintptr_t | arch_syscall_invoke6 (uintptr_t arg1, uintptr_t arg2, uintptr_t arg3, uintptr_t arg4, uintptr_t arg5, uintptr_t arg6, uintptr_t call_id) |
static bool | arch_is_user_context (void) |
int | arch_mem_domain_max_partitions_get (void) |
Get the maximum number of partitions for a memory domain. More... | |
int | arch_buffer_validate (void *addr, size_t size, int write) |
Check memory region permissions. More... | |
FUNC_NORETURN void | arch_user_mode_enter (k_thread_entry_t user_entry, void *p1, void *p2, void *p3) |
FUNC_NORETURN void | arch_syscall_oops (void *ssf) |
Induce a kernel oops that appears to come from a specific location. More... | |
size_t | arch_user_string_nlen (const char *s, size_t maxsize, int *err) |
Safely take the length of a potentially bad string. More... | |
static bool | arch_mem_coherent (void *ptr) |
Detect memory coherence type. More... | |
static void | arch_cohere_stacks (struct k_thread *old_thread, void *old_switch_handle, struct k_thread *new_thread) |
Ensure cache coherence prior to context switch. More... | |
int arch_buffer_validate | ( | void * | addr, |
size_t | size, | ||
int | write | ||
) |
#include <include/sys/arch_interface.h>
Check memory region permissions.
Given a memory region, return whether the current memory management hardware configuration would allow a user thread to read/write that region. Used by system calls to validate buffers coming in from userspace.
Notes: The function is guaranteed to never return validation success, if the entire buffer area is not user accessible.
The function is guaranteed to correctly validate the permissions of the supplied buffer, if the user access permissions of the entire buffer are enforced by a single, enabled memory management region.
In some architectures the validation will always return failure if the supplied memory buffer spans multiple enabled memory management regions (even if all such regions permit user access).
addr | start address of the buffer |
size | the size of the buffer |
write | If nonzero, additionally check if the area is writable. Otherwise, just check if the memory can be read. |
|
inlinestatic |
#include <include/sys/arch_interface.h>
Ensure cache coherence prior to context switch.
Required when ARCH_HAS_COHERENCE is true. On cache-incoherent multiprocessor architectures, thread stacks are cached by default for performance reasons. They must therefore be flushed appropriately on context switch. The rules are:
#include <include/sys/arch_interface.h>
Indicate whether we are currently running in user mode
#include <include/sys/arch_interface.h>
Detect memory coherence type.
Required when ARCH_HAS_COHERENCE is true. This function returns true if the byte pointed to lies within an architecture-defined "coherence region" (typically implemented with uncached memory) and can safely be used in multiprocessor code without explicit flush or invalidate operations.
int arch_mem_domain_max_partitions_get | ( | void | ) |
#include <include/sys/arch_interface.h>
Get the maximum number of partitions for a memory domain.
#include <include/sys/arch_interface.h>
Invoke a system call with 0 arguments.
No general-purpose register state other than return value may be preserved when transitioning from supervisor mode back down to user mode for security reasons.
It is required that all arguments be stored in registers when elevating privileges from user to supervisor mode.
Processing of the syscall takes place on a separate kernel stack. Interrupts should be enabled when invoking the system call marshallers from the dispatch table. Thread preemption may occur when handling system calls.
Call ids are untrusted and must be bounds-checked, as the value is used to index the system call dispatch table, containing function pointers to the specific system call code.
call_id | System call ID |
#include <include/sys/arch_interface.h>
Invoke a system call with 1 argument.
arg1 | First argument to the system call. |
call_id | System call ID, will be bounds-checked and used to reference kernel-side dispatch table |
|
inlinestatic |
#include <include/sys/arch_interface.h>
Invoke a system call with 2 arguments.
arg1 | First argument to the system call. |
arg2 | Second argument to the system call. |
call_id | System call ID, will be bounds-checked and used to reference kernel-side dispatch table |
|
inlinestatic |
#include <include/sys/arch_interface.h>
Invoke a system call with 3 arguments.
arg1 | First argument to the system call. |
arg2 | Second argument to the system call. |
arg3 | Third argument to the system call. |
call_id | System call ID, will be bounds-checked and used to reference kernel-side dispatch table |
|
inlinestatic |
#include <include/sys/arch_interface.h>
Invoke a system call with 4 arguments.
arg1 | First argument to the system call. |
arg2 | Second argument to the system call. |
arg3 | Third argument to the system call. |
arg4 | Fourth argument to the system call. |
call_id | System call ID, will be bounds-checked and used to reference kernel-side dispatch table |
|
inlinestatic |
#include <include/sys/arch_interface.h>
Invoke a system call with 5 arguments.
arg1 | First argument to the system call. |
arg2 | Second argument to the system call. |
arg3 | Third argument to the system call. |
arg4 | Fourth argument to the system call. |
arg5 | Fifth argument to the system call. |
call_id | System call ID, will be bounds-checked and used to reference kernel-side dispatch table |
|
inlinestatic |
#include <include/sys/arch_interface.h>
Invoke a system call with 6 arguments.
arg1 | First argument to the system call. |
arg2 | Second argument to the system call. |
arg3 | Third argument to the system call. |
arg4 | Fourth argument to the system call. |
arg5 | Fifth argument to the system call. |
arg6 | Sixth argument to the system call. |
call_id | System call ID, will be bounds-checked and used to reference kernel-side dispatch table |
#include <include/sys/arch_interface.h>
Induce a kernel oops that appears to come from a specific location.
Normally, k_oops() generates an exception that appears to come from the call site of the k_oops() itself.
However, when validating arguments to a system call, if there are problems we want the oops to appear to come from where the system call was invoked and not inside the validation function.
ssf | System call stack frame pointer. This gets passed as an argument to _k_syscall_handler_t functions and its contents are completely architecture specific. |
FUNC_NORETURN void arch_user_mode_enter | ( | k_thread_entry_t | user_entry, |
void * | p1, | ||
void * | p2, | ||
void * | p3 | ||
) |
#include <include/sys/arch_interface.h>
Perform a one-way transition from supervisor to kernel mode.
Implementations of this function must do the following:
user_entry | Entry point to start executing as a user thread |
p1 | 1st parameter to user thread |
p2 | 2nd parameter to user thread |
p3 | 3rd parameter to user thread |
size_t arch_user_string_nlen | ( | const char * | s, |
size_t | maxsize, | ||
int * | err | ||
) |
#include <include/sys/arch_interface.h>
Safely take the length of a potentially bad string.
This must not fault, instead the err parameter must have -1 written to it. This function otherwise should work exactly like libc strnlen(). On success *err should be set to 0.
s | String to measure |
maxsize | Max length of the string |
err | Error value to write |