]> git.ipfire.org Git - thirdparty/xtables-addons.git/commitdiff
xt_ACCOUNT: update prototype of nf_sockopt_ops::set callback
authorJeremy Sowden <jeremy@azazel.net>
Mon, 31 Aug 2020 12:59:47 +0000 (14:59 +0200)
committerJan Engelhardt <jengelh@inai.de>
Mon, 31 Aug 2020 13:04:43 +0000 (15:04 +0200)
In 5.9, the `void __user` parameter has been replaced by a `sockptr`.
Update `ipt_acc_set_ctl` appropriately.

Signed-off-by: Jeremy Sowden <jeremy@azazel.net>
extensions/ACCOUNT/xt_ACCOUNT.c

index 019f5bda007e68891bede8cab55e7125a2e4a8df..18e0b8a0a1b7242642cef466c649533a1ed5f8b2 100644 (file)
@@ -28,6 +28,9 @@
 #include <linux/kernel.h>
 #include <linux/mm.h>
 #include <linux/string.h>
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 9, 0)
+#include <linux/sockptr.h>
+#endif
 #include <linux/spinlock.h>
 #include <asm/uaccess.h>
 #include <net/netns/generic.h>
@@ -879,7 +882,12 @@ static int ipt_acc_handle_get_data(struct ipt_acc_net *ian,
 }
 
 static int ipt_acc_set_ctl(struct sock *sk, int cmd,
-                       void *user, unsigned int len)
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 9, 0)
+                          void *user,
+#else
+                          sockptr_t arg,
+#endif
+                          unsigned int len)
 {
        struct net *net = sock_net(sk);
        struct ipt_acc_net *ian = net_generic(net, ipt_acc_net_id);
@@ -898,7 +906,12 @@ static int ipt_acc_set_ctl(struct sock *sk, int cmd,
                        break;
                }
 
-               if (copy_from_user(&handle, user, len)) {
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 9, 0)
+               if (copy_from_user(&handle, user, len))
+#else
+               if (copy_from_sockptr(&handle, arg, len))
+#endif
+               {
                        printk("ACCOUNT: ipt_acc_set_ctl: copy_from_user failed for "
                                "IPT_SO_SET_HANDLE_FREE\n");
                        break;