From: Fei Jie Date: Thu, 17 Mar 2016 09:30:45 +0000 (+0800) Subject: tests: add xetpriority.test X-Git-Tag: v4.12~509 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=032a9a4358b7cca57762eedf3614aec161e2649f;p=strace tests: add xetpriority.test * resource.c (SYS_FUNC(getpriority), SYS_FUNC(setpriority)): Print the second syscall argument using %d format. * tests/xetpriority.c: New file. * tests/xetpriority.test: New test. * tests/.gitignore: Add xetpriority. * tests/Makefile.am (check_PROGRAMS): Likewise. (TESTS): Add xetpriority.test. --- diff --git a/resource.c b/resource.c index c68f0456..9aacfbe4 100644 --- a/resource.c +++ b/resource.c @@ -184,7 +184,7 @@ SYS_FUNC(osf_getrusage) SYS_FUNC(getpriority) { printxval(priorities, tcp->u_arg[0], "PRIO_???"); - tprintf(", %lu", tcp->u_arg[1]); + tprintf(", %d", (int) tcp->u_arg[1]); return RVAL_DECODED; } @@ -192,7 +192,7 @@ SYS_FUNC(getpriority) SYS_FUNC(setpriority) { printxval(priorities, tcp->u_arg[0], "PRIO_???"); - tprintf(", %lu, %d", tcp->u_arg[1], (int) tcp->u_arg[2]); + tprintf(", %d, %d", (int) tcp->u_arg[1], (int) tcp->u_arg[2]); return RVAL_DECODED; } diff --git a/tests/.gitignore b/tests/.gitignore index 93ffa0b0..449af182 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -149,4 +149,5 @@ xattr xet_robust_list xetitimer xetpgid +xetpriority xettimeofday diff --git a/tests/Makefile.am b/tests/Makefile.am index 6590f95e..30053821 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -197,6 +197,7 @@ check_PROGRAMS = \ xet_robust_list \ xetitimer \ xetpgid \ + xetpriority \ xettimeofday \ # end of check_PROGRAMS @@ -365,6 +366,7 @@ TESTS = \ xet_robust_list.test \ xetitimer.test \ xetpgid.test \ + xetpriority.test \ xettimeofday.test \ \ count.test \ diff --git a/tests/xetpriority.c b/tests/xetpriority.c new file mode 100644 index 00000000..aefe5e95 --- /dev/null +++ b/tests/xetpriority.c @@ -0,0 +1,38 @@ +#include "tests.h" +#include + +#if defined __NR_getpriority && defined __NR_setpriority + +# include +# include +# include +# include +# include + +int +main(void) +{ + const int pid = getpid(); + int rc = syscall(__NR_getpriority, PRIO_PROCESS, + (unsigned long) 0xffffffff00000000 | pid); + printf("getpriority(PRIO_PROCESS, %d) = %d\n", + pid, rc); + + if ((syscall(__NR_setpriority, PRIO_PROCESS, + (unsigned long) 0xffffffff00000000 | pid, + (unsigned long) 0xffffffff00000000)) == 0) { + printf("setpriority(PRIO_PROCESS, %d, 0) = 0\n", pid); + } else { + printf("setpriority(PRIO_PROCESS, %d, 0) = -1 %s (%m)\n", + pid, errno == EPERM ? "EPERM" : "EACCES"); + } + + puts("+++ exited with 0 +++"); + return 0; +} + +#else + +SKIP_MAIN_UNDEFINED("__NR_getpriority && _NR_setpriority") + +#endif diff --git a/tests/xetpriority.test b/tests/xetpriority.test new file mode 100755 index 00000000..f9b0251c --- /dev/null +++ b/tests/xetpriority.test @@ -0,0 +1,11 @@ +#!/bin/sh + +# Check getpriority and setpriority syscalls decoding. + +. "${srcdir=.}/init.sh" + +run_prog > /dev/null +OUT="$LOG.out" +run_strace -egetpriority,setpriority -a29 $args > "$OUT" +match_diff "$LOG" "$OUT" +rm -f "$OUT"