1 /*
2 * Copyright (c) 2019 Intel Corporation.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #include <zephyr/internal/syscall_handler.h>
8 #include <zephyr/logging/log.h>
9
10 LOG_MODULE_REGISTER(app_syscall);
11
12 /* Implementation of magic_syscall() which is a system call just for this
13 * application, not part of the kernel codebase.
14 *
15 * It's trivial, update the supplied cookie value by 1, only if it is less than
16 * 42. This is just for demonstration purposes to show how syscalls can be
17 * defined in application code.
18 */
z_impl_magic_syscall(unsigned int * cookie)19 int z_impl_magic_syscall(unsigned int *cookie)
20 {
21 LOG_DBG("magic syscall: got a cookie %u", *cookie);
22
23 if (*cookie > 42) {
24 LOG_ERR("bad cookie :(");
25 return -EINVAL;
26 }
27
28 *cookie = *cookie + 1;
29
30 return 0;
31 }
32
z_vrfy_magic_syscall(unsigned int * cookie)33 static int z_vrfy_magic_syscall(unsigned int *cookie)
34 {
35 unsigned int cookie_copy;
36 int ret;
37
38 /* Confirm that this user-supplied pointer is valid memory that
39 * can be accessed. If it's OK, copy into cookie_copy.
40 */
41 if (k_usermode_from_copy(&cookie_copy, cookie, sizeof(*cookie)) != 0) {
42 return -EPERM;
43 }
44
45 /* We pass to the implementation the *copy*, to prevent TOCTOU attacks
46 */
47 ret = z_impl_magic_syscall(&cookie_copy);
48
49 if (ret == 0 &&
50 k_usermode_to_copy(cookie, &cookie_copy, sizeof(*cookie)) != 0) {
51 return -EPERM;
52 }
53
54 return ret;
55 }
56
57 #include <zephyr/syscalls/magic_syscall_mrsh.c>
58