/*
- * Copyright (c) 2015 Dmitry V. Levin <ldv@altlinux.org>
+ * Copyright (c) 2015-2016 Dmitry V. Levin <ldv@altlinux.org>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
*/
#include "tests.h"
-#include <stdio.h>
-#include <unistd.h>
-#include <sys/mman.h>
#include <sys/syscall.h>
#if defined __NR_get_robust_list && defined __NR_set_robust_list
+# include <stdio.h>
+# include <unistd.h>
+
int
main(void)
{
- const size_t page_len = sysconf(_SC_PAGESIZE);
const pid_t pid = getpid();
const long long_pid = (unsigned long) (0xdeadbeef00000000LL | pid);
-
- void *p = mmap(NULL, page_len * 4, PROT_READ | PROT_WRITE,
- MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
- if (p == MAP_FAILED ||
- mprotect(p + page_len, page_len, PROT_NONE) ||
- mprotect(p + page_len * 3, page_len, PROT_NONE))
- return 77;
-
- void **p_head = p + page_len - sizeof(void *);
- size_t *p_len = p + page_len * 3 - sizeof(size_t);
+ void **p_head = tail_alloc(sizeof(void *));
+ size_t *p_len = tail_alloc(sizeof(size_t));
if (syscall(__NR_get_robust_list, long_pid, p_head, p_len))
- return 77;
+ perror_msg_and_skip("get_robust_list");
printf("get_robust_list(%d, [%#lx], [%lu]) = 0\n",
(int) pid, (unsigned long) *p_head, (unsigned long) *p_len);
- if (syscall(__NR_set_robust_list, p, *p_len))
- return 77;
- printf("set_robust_list(%#lx, %lu) = 0\n",
- (unsigned long) p, (unsigned long) *p_len);
+ void *head = tail_alloc(*p_len);
+ if (syscall(__NR_set_robust_list, head, *p_len))
+ perror_msg_and_skip("set_robust_list");
+ printf("set_robust_list(%p, %lu) = 0\n",
+ head, (unsigned long) *p_len);
if (syscall(__NR_get_robust_list, long_pid, p_head, p_len))
- return 77;
+ perror_msg_and_skip("get_robust_list");
printf("get_robust_list(%d, [%#lx], [%lu]) = 0\n",
(int) pid, (unsigned long) *p_head, (unsigned long) *p_len);
#else
-int
-main(void)
-{
- return 77;
-}
+SKIP_MAIN_UNDEFINED("__NR_get_robust_list && __NR_set_robust_list")
#endif