summaryrefslogtreecommitdiff
path: root/patches
diff options
context:
space:
mode:
authorAlexey Neyman <stilor@att.net>2017-01-26 06:39:42 (GMT)
committerGitHub <noreply@github.com>2017-01-26 06:39:42 (GMT)
commit462c3c0d1ffc1c82a46379ffd63c945918d0c9bd (patch)
tree7970b1b2d3ac052a61323c99ac0387e7992961fc /patches
parente1132fc82936f9dfe79f1f28054e11cb405122bf (diff)
parent74741a0dc3175aa22421b9e2253cc4c15a921953 (diff)
Merge pull request #558 from stilor/uclibc-ng-more
Add patch for init_module/delete_module
Diffstat (limited to 'patches')
-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