1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
/*
* Check decoding of socketcall syscall.
*
* Copyright (c) 2016-2018 Dmitry V. Levin <ldv@strace.io>
* Copyright (c) 2016-2024 The strace developers.
* All rights reserved.
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#include "tests.h"
#include "scno.h"
#if defined __NR_socketcall && !defined __ARM_EABI__
# include <assert.h>
# include <stdio.h>
# include <unistd.h>
# include "xlat.h"
# include "xlat/socketcalls.h"
static const char *
xlookup_uint(const struct xlat *xlat, const unsigned int val)
{
for (size_t i = 0; i < xlat->size; i++)
if (xlat->data[i].val == val)
return xlat->data[i].str;
return NULL;
}
static const int sc_min = 1, sc_max = 20;
static void *efault;
static void
test_socketcall(const int i, const void *const addr)
{
const unsigned long call =
(unsigned long) 0xfacefeed00000000ULL | (unsigned int) i;
long rc = syscall(__NR_socketcall, call, addr);
if (i < sc_min || i > sc_max) {
printf("socketcall(%d, %p) = %s\n",
(int) call, addr, sprintrc(rc));
} else if (addr == efault) {
const char *const str = xlookup_uint(socketcalls, i);
assert(str);
printf("socketcall(%s, %p) = %s\n",
str, addr, sprintrc(rc));
}
}
int
main(void)
{
assert(0 == socketcalls->data[0].val);
assert((unsigned) sc_max == socketcalls->data[socketcalls->size - 1].val);
TAIL_ALLOC_OBJECT_CONST_ARR(const unsigned long, args, 6);
efault = tail_alloc(1) + 1;
for (int i = sc_min - 3; i <= sc_max + 3; ++i) {
test_socketcall(i, efault);
test_socketcall(i, args);
}
puts("+++ exited with 0 +++");
return 0;
}
#else
SKIP_MAIN_UNDEFINED("__NR_socketcall && !__ARM_EABI__")
#endif
|