summaryrefslogtreecommitdiff
path: root/patches/uClibc-ng
diff options
context:
space:
mode:
authorAlexey Neyman <stilor@att.net>2017-01-24 02:02:06 (GMT)
committerAlexey Neyman <stilor@att.net>2017-01-24 22:58:11 (GMT)
commit74741a0dc3175aa22421b9e2253cc4c15a921953 (patch)
tree9ba4cad1267bc95f0e3407ab968a183bcb0211ee /patches/uClibc-ng
parentb5d0e396d9ad0c886ab487bd26776bda92e5f40c (diff)
Add patch for init_module/delete_module
Signed-off-by: Alexey Neyman <stilor@att.net>
Diffstat (limited to 'patches/uClibc-ng')
-rw-r--r--patches/uClibc-ng/1.0.21/120-module.patch50
1 files changed, 50 insertions, 0 deletions
diff --git a/patches/uClibc-ng/1.0.21/120-module.patch b/patches/uClibc-ng/1.0.21/120-module.patch
new file mode 100644
index 0000000..2e8a989
--- /dev/null
+++ b/patches/uClibc-ng/1.0.21/120-module.patch
@@ -0,0 +1,50 @@
+commit 03884934b32c79da545ef38a42835a6c257b125d
+Author: Waldemar Brodkorb <wbx@uclibc-ng.org>
+Date: Tue Dec 27 09:24:24 2016 +0100
+
+ add init_module/delete_module syscall wrappers
+
+ Add the wrappers unconditionally, because kmod package
+ still uses them.
+
+diff --git a/libc/sysdeps/linux/common/Makefile.in b/libc/sysdeps/linux/common/Makefile.in
+index 595074c..faed6fd 100644
+--- a/libc/sysdeps/linux/common/Makefile.in
++++ b/libc/sysdeps/linux/common/Makefile.in
+@@ -31,6 +31,7 @@ CSRC-$(UCLIBC_LINUX_SPECIFIC) += \
+ ioperm.c \
+ iopl.c \
+ modify_ldt.c \
++ module.c \
+ personality.c \
+ pipe2.c \
+ ppoll.c \
+diff --git a/libc/sysdeps/linux/common/module.c b/libc/sysdeps/linux/common/module.c
+new file mode 100644
+index 0000000..146a43e
+--- /dev/null
++++ b/libc/sysdeps/linux/common/module.c
+@@ -0,0 +1,23 @@
++/*
++ * init_module()/delete_module() for uClibc
++ *
++ * Copyright (C) 2000-2006 Erik Andersen <andersen@uclibc.org>
++ *
++ * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball.
++ */
++
++#include <sys/syscall.h>
++
++#ifdef __NR_init_module
++int init_module(void *first, void *second, void *third, void *fourth, void *fifth);
++/* This may have 5 arguments (for old 2.0 kernels) or 2 arguments
++ * (for 2.2 and 2.4 kernels). Use the greatest common denominator,
++ * and let the kernel cope with whatever it gets. It's good at that. */
++_syscall5(int, init_module, void *, first, void *, second, void *, third,
++ void *, fourth, void *, fifth)
++#endif
++
++#ifdef __NR_delete_module
++int delete_module(const char *name, unsigned int flags);
++_syscall2(int, delete_module, const char *, name, unsigned int, flags)
++#endif