summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tests/.gitignore2
-rw-r--r--tests/Makefile.am2
-rw-r--r--tests/gen_tests.in6
-rw-r--r--tests/prlimit64-success--pidns-translation.c2
-rw-r--r--tests/prlimit64-success.c2
-rw-r--r--tests/prlimit64.c51
6 files changed, 49 insertions, 16 deletions
diff --git a/tests/.gitignore b/tests/.gitignore
index 485e1ff6e..9501a8d86 100644
--- a/tests/.gitignore
+++ b/tests/.gitignore
@@ -691,6 +691,8 @@ printstrn-umoven-peekdata
printstrn-umoven-undumpable
prlimit64
prlimit64--pidns-translation
+prlimit64-success
+prlimit64-success--pidns-translation
process_madvise
process_madvise-y
process_madvise-yy
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 7216b80ce..5eddf2278 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -283,6 +283,8 @@ check_PROGRAMS = $(PURE_EXECUTABLES) \
print_maxfd \
print_ppid_tracerpid \
prlimit64--pidns-translation \
+ prlimit64-success \
+ prlimit64-success--pidns-translation \
process_vm_readv--pidns-translation \
process_vm_writev--pidns-translation \
qual_fault \
diff --git a/tests/gen_tests.in b/tests/gen_tests.in
index 281720c09..cafb4a708 100644
--- a/tests/gen_tests.in
+++ b/tests/gen_tests.in
@@ -656,8 +656,10 @@ printstr -e trace=writev
printstrn-umoven -s4096 -e signal=none -e trace=add_key
printstrn-umoven-peekdata -e signal=none -e trace=add_key
printstrn-umoven-undumpable -e signal=none -e trace=add_key
-prlimit64 -a36 "QUIRK:START-OF-TEST-OUTPUT:prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
-prlimit64--pidns-translation test_pidns -a36 -e trace=prlimit64 "QUIRK:START-OF-TEST-OUTPUT:prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
+prlimit64 -a36 "QUIRK:START-OF-TEST-OUTPUT:prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
+prlimit64--pidns-translation test_pidns -a36 -e trace=prlimit64 "QUIRK:START-OF-TEST-OUTPUT:prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
+prlimit64-success -a36 -einject=prlimit64:retval=42:when=256+ -etrace=prlimit64 "QUIRK:START-OF-TEST-OUTPUT:prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
+prlimit64-success--pidns-translation check_scno_tampering; test_pidns -a36 -einject=prlimit64:retval=42:when=256+ -etrace=prlimit64 "QUIRK:START-OF-TEST-OUTPUT:prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
process_madvise
process_madvise-y --trace=process_madvise -y
process_madvise-yy --trace=process_madvise -yy
diff --git a/tests/prlimit64-success--pidns-translation.c b/tests/prlimit64-success--pidns-translation.c
new file mode 100644
index 000000000..eb53c582e
--- /dev/null
+++ b/tests/prlimit64-success--pidns-translation.c
@@ -0,0 +1,2 @@
+#define PIDNS_TRANSLATION
+#include "prlimit64-success.c"
diff --git a/tests/prlimit64-success.c b/tests/prlimit64-success.c
new file mode 100644
index 000000000..4f7599ffa
--- /dev/null
+++ b/tests/prlimit64-success.c
@@ -0,0 +1,2 @@
+#define RETVAL_INJECTED 1
+#include "prlimit64.c"
diff --git a/tests/prlimit64.c b/tests/prlimit64.c
index 41b0404a3..8febdaeea 100644
--- a/tests/prlimit64.c
+++ b/tests/prlimit64.c
@@ -14,6 +14,7 @@
#include <inttypes.h>
#include <stdio.h>
#include <stdint.h>
+#include <stdlib.h>
#include <sys/resource.h>
#include <unistd.h>
@@ -21,6 +22,17 @@
#include "xlat.h"
#include "xlat/resources.h"
+#ifndef RETVAL_INJECTED
+# define RETVAL_INJECTED 0
+#endif
+
+#if RETVAL_INJECTED
+# define INJ_STR " (INJECTED)"
+#else
+# define INJ_STR ""
+#endif
+#define INJECT_RETVAL 42
+
static const char *
sprint_rlim(uint64_t lim)
{
@@ -39,7 +51,7 @@ sprint_rlim(uint64_t lim)
}
int
-main(void)
+main(int argc, char *argv[])
{
PIDNS_TEST_INIT;
@@ -48,38 +60,49 @@ main(void)
const char *pid_str = pidns_pid2str(PT_TGID);
uint64_t *const rlimit = tail_alloc(sizeof(*rlimit) * 2);
const struct xlat_data *xlat;
+ long rc;
+ unsigned long num_skip = 256;
size_t i = 0;
- long rc = syscall(__NR_prlimit64, 0, 16, 0, 0);
- pidns_print_leader();
- printf("prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL) = %s\n",
- sprintrc(rc));
+ if (argc >= 2)
+ num_skip = strtoul(argv[1], NULL, 0);
+
+ for (i = 0; i < num_skip; i++) {
+ long rc = syscall(__NR_prlimit64, 0, 16, 0, 0);
+ pidns_print_leader();
+ printf("prlimit64(0, 0x10 /* RLIMIT_??? */, NULL, NULL)"
+ " = %s%s\n",
+ sprintrc(rc), rc == INJECT_RETVAL ? INJ_STR : "");
+ }
/* The shortest output */
rc = syscall(__NR_prlimit64, 0, RLIMIT_AS, 0, 0);
pidns_print_leader();
- printf("prlimit64(0, RLIMIT_AS, NULL, NULL) = %s\n", sprintrc(rc));
+ printf("prlimit64(0, RLIMIT_AS, NULL, NULL) = %s" INJ_STR "\n",
+ sprintrc(rc));
- for (xlat = resources->data; i < resources->size; ++xlat, ++i) {
+ for (i = 0, xlat = resources->data; i < resources->size; ++xlat, ++i) {
if (!xlat->str)
continue;
unsigned long res = 0xfacefeed00000000ULL | xlat->val;
rc = syscall(__NR_prlimit64, pid, res, 0, rlimit);
pidns_print_leader();
- if (rc)
- printf("prlimit64(%d%s, %s, NULL, %p) ="
- " %ld %s (%m)\n",
+ if (!RETVAL_INJECTED && (rc < 0)) {
+ printf("prlimit64(%d%s, %s, NULL, %p) = %s\n",
(unsigned) pid, pid_str,
xlat->str, rlimit,
- rc, errno2name());
- else
+ sprintrc(rc));
+ } else {
printf("prlimit64(%d%s, %s, NULL"
- ", {rlim_cur=%s, rlim_max=%s}) = 0\n",
+ ", {rlim_cur=%s, rlim_max=%s})"
+ " = %d" INJ_STR "\n",
(unsigned) pid, pid_str,
xlat->str,
sprint_rlim(rlimit[0]),
- sprint_rlim(rlimit[1]));
+ sprint_rlim(rlimit[1]),
+ RETVAL_INJECTED ? INJECT_RETVAL : 0);
+ }
}
pidns_print_leader();