]> granicus.if.org Git - strace/blob - tests/xet_robust_list.c
cf4f22347ab8c009bd8ac8879ee6354b19f64100
[strace] / tests / xet_robust_list.c
1 /*
2  * Copyright (c) 2015-2016 Dmitry V. Levin <ldv@altlinux.org>
3  * Copyright (c) 2015-2018 The strace developers.
4  * All rights reserved.
5  *
6  * SPDX-License-Identifier: GPL-2.0-or-later
7  */
8
9 #include "tests.h"
10 #include <asm/unistd.h>
11
12 #if defined __NR_get_robust_list && defined __NR_set_robust_list
13
14 # include <stdio.h>
15 # include <unistd.h>
16
17 static const char *
18 sprintaddr(void *addr)
19 {
20         static char buf[sizeof(addr) * 2 + sizeof("0x")];
21
22         if (!addr)
23                 return "NULL";
24         else
25                 snprintf(buf, sizeof(buf), "%p", addr);
26
27         return buf;
28 }
29
30 int
31 main(void)
32 {
33         const pid_t pid = getpid();
34         const long long_pid = (unsigned long) (0xdeadbeef00000000LL | pid);
35         TAIL_ALLOC_OBJECT_CONST_PTR(void *, p_head);
36         TAIL_ALLOC_OBJECT_CONST_PTR(size_t, p_len);
37
38         if (syscall(__NR_get_robust_list, long_pid, p_head, p_len))
39                 perror_msg_and_skip("get_robust_list");
40         printf("get_robust_list(%d, [%s], [%lu]) = 0\n",
41                (int) pid, sprintaddr(*p_head), (unsigned long) *p_len);
42
43         void *head = tail_alloc(*p_len);
44         if (syscall(__NR_set_robust_list, head, *p_len))
45                 perror_msg_and_skip("set_robust_list");
46         printf("set_robust_list(%p, %lu) = 0\n",
47                head, (unsigned long) *p_len);
48
49         if (syscall(__NR_get_robust_list, long_pid, p_head, p_len))
50                 perror_msg_and_skip("get_robust_list");
51         printf("get_robust_list(%d, [%s], [%lu]) = 0\n",
52                (int) pid, sprintaddr(*p_head), (unsigned long) *p_len);
53
54         puts("+++ exited with 0 +++");
55         return 0;
56 }
57
58 #else
59
60 SKIP_MAIN_UNDEFINED("__NR_get_robust_list && __NR_set_robust_list")
61
62 #endif