[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Minios-devel] [UNIKRAFT/NEWLIB PATCH] Provide `syscall()` symbol



Hi Simon, looks good, thanks.

-- Felipe

Reviewed-by: Felipe Huici <felipe.huici@xxxxxxxxx>

On 07.02.20, 14:27, "Minios-devel on behalf of Simon Kuenzer" 
<minios-devel-bounces@xxxxxxxxxxxxxxxxxxxx on behalf of 
simon.kuenzer@xxxxxxxxx> wrote:

    Provides the `syscall()` function symbol (some language runtimes  link
    to the symbol directly). The function is calling `uk_syscall()` when
    lib/syscall_shim is enabled. Otherwise, `syscall()` returns always
    `-1` and sets `errno` to `ENOSYS`.
    
    Signed-off-by: Simon Kuenzer <simon.kuenzer@xxxxxxxxx>
    ---
     Config.uk             |  1 +
     Makefile.uk           |  1 +
     include/sys/syscall.h | 47 +++++++++++++++++++++++++---
     syscall.c             | 72 +++++++++++++++++++++++++++++++++++++++++++
     4 files changed, 117 insertions(+), 4 deletions(-)
     create mode 100644 syscall.c
    
    diff --git a/Config.uk b/Config.uk
    index ab127f0..8cb1058 100644
    --- a/Config.uk
    +++ b/Config.uk
    @@ -13,6 +13,7 @@ menuconfig LIBNEWLIBC
        select LIBVFSCORE
        select LIBPOSIX_PROCESS
        select LIBPOSIX_USER
    +   imply LIBSYSCALL_SHIM
     
     if LIBNEWLIBC
        config LIBNEWLIBC_WANT_IO_C99_FORMATS
    diff --git a/Makefile.uk b/Makefile.uk
    index 390e4f4..66c3b88 100644
    --- a/Makefile.uk
    +++ b/Makefile.uk
    @@ -135,6 +135,7 @@ LIBNEWLIBGLUE_SRCS-y += $(LIBNEWLIBC_BASE)/dev.c
     LIBNEWLIBGLUE_SRCS-y += $(LIBNEWLIBC_BASE)/signal.c
     LIBNEWLIBGLUE_SRCS-y += $(LIBNEWLIBC_BASE)/link.c
     LIBNEWLIBGLUE_SRCS-y += $(LIBNEWLIBC_BASE)/mntent.c
    +LIBNEWLIBGLUE_SRCS-y += $(LIBNEWLIBC_BASE)/syscall.c
     LIBNEWLIBGLUE_SRCS-y += $(LIBNEWLIBC_BASE)/musl-imported/src/misc/syslog.c
     LIBNEWLIBGLUE_SRCS-y += 
$(LIBNEWLIBC_BASE)/musl-imported/src/termios/tcsetattr.c
     LIBNEWLIBGLUE_SRCS-y += 
$(LIBNEWLIBC_BASE)/musl-imported/src/termios/tcgetattr.c
    diff --git a/include/sys/syscall.h b/include/sys/syscall.h
    index 55ae098..18edd7e 100644
    --- a/include/sys/syscall.h
    +++ b/include/sys/syscall.h
    @@ -1,6 +1,45 @@
    +/* SPDX-License-Identifier: BSD-3-Clause */
    +/*
    + * Authors: Simon Kuenzer <simon.kuenzer@xxxxxxxxx>
    + *
    + * Copyright (c) 2020, NEC Europe Ltd., NEC Corporation. All rights 
reserved.
    + *
    + * Redistribution and use in source and binary forms, with or without
    + * modification, are permitted provided that the following conditions
    + * are met:
    + *
    + * 1. Redistributions of source code must retain the above copyright
    + *    notice, this list of conditions and the following disclaimer.
    + * 2. Redistributions in binary form must reproduce the above copyright
    + *    notice, this list of conditions and the following disclaimer in the
    + *    documentation and/or other materials provided with the distribution.
    + * 3. Neither the name of the copyright holder nor the names of its
    + *    contributors may be used to endorse or promote products derived from
    + *    this software without specific prior written permission.
    + *
    + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 
IS"
    + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
THE
    + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
PURPOSE
    + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS 
BE
    + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
    + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
    + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
    + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
    + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
    + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 
THE
    + * POSSIBILITY OF SUCH DAMAGE.
    + *
    + */
    +#ifndef __SYS_SYSCALL_H__
    +#define __SYS_SYSCALL_H__
    +
     #include <uk/config.h>
    +
    +long syscall(long num, ...);
    +
     #if CONFIG_LIBSYSCALL_SHIM
    -#include <uk/syscall.h>
    -#else
    -#error "Provide alternative syscall.h header"
    -#endif
    +/* Provide __NR_syscallname variants */
    +#include <uk/bits/syscall_nrs2.h>
    +#endif /* CONFIG_LIBSYSCALL_SHIM */
    +
    +#endif /* __SYS_SYSCALL_H__ */
    diff --git a/syscall.c b/syscall.c
    new file mode 100644
    index 0000000..931cd64
    --- /dev/null
    +++ b/syscall.c
    @@ -0,0 +1,72 @@
    +/* SPDX-License-Identifier: BSD-3-Clause */
    +/*
    + * Authors: Simon Kuenzer <simon.kuenzer@xxxxxxxxx>
    + *
    + * Copyright (c) 2020, NEC Europe Ltd., NEC Corporation. All rights 
reserved.
    + *
    + * Redistribution and use in source and binary forms, with or without
    + * modification, are permitted provided that the following conditions
    + * are met:
    + *
    + * 1. Redistributions of source code must retain the above copyright
    + *    notice, this list of conditions and the following disclaimer.
    + * 2. Redistributions in binary form must reproduce the above copyright
    + *    notice, this list of conditions and the following disclaimer in the
    + *    documentation and/or other materials provided with the distribution.
    + * 3. Neither the name of the copyright holder nor the names of its
    + *    contributors may be used to endorse or promote products derived from
    + *    this software without specific prior written permission.
    + *
    + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 
IS"
    + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
THE
    + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
PURPOSE
    + * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS 
BE
    + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
    + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
    + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
    + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
    + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
    + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 
THE
    + * POSSIBILITY OF SUCH DAMAGE.
    + *
    + */
    +
    +#include <uk/config.h>
    +#if CONFIG_LIBSYSCALL_SHIM
    +#include <stdarg.h>
    +#include <uk/syscall.h>
    +
    +long syscall(long num, ...)
    +{
    +   va_list va;
    +   long arg[6];
    +
    +   va_start(va, num);
    +   arg[0] = va_arg(va, long);
    +   arg[1] = va_arg(va, long);
    +   arg[2] = va_arg(va, long);
    +   arg[3] = va_arg(va, long);
    +   arg[4] = va_arg(va, long);
    +   arg[5] = va_arg(va, long);
    +   va_end(va);
    +
    +   return uk_syscall(num,
    +                     arg[0],
    +                     arg[1],
    +                     arg[2],
    +                     arg[3],
    +                     arg[4],
    +                     arg[5]);
    +}
    +
    +#else
    +#include <errno.h>
    +#include <uk/print.h>
    +#include <uk/essentials.h>
    +
    +long syscall(long num __maybe_unused, ...)
    +{
    +   uk_pr_err("No such system call %lu\n", num);
    +   return -ENOSYS;
    +}
    +#endif /* CONFIG_LIBSYSCALL_SHIM */
    -- 
    2.20.1
    
    
    _______________________________________________
    Minios-devel mailing list
    Minios-devel@xxxxxxxxxxxxxxxxxxxx
    https://lists.xenproject.org/mailman/listinfo/minios-devel

_______________________________________________
Minios-devel mailing list
Minios-devel@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/mailman/listinfo/minios-devel

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.