|
|
36cfb7 |
From 074062808c630f2efb55c7093d510b44a38e74e5 Mon Sep 17 00:00:00 2001
|
|
|
36cfb7 |
From: Phil Sutter <psutter@redhat.com>
|
|
|
36cfb7 |
Date: Thu, 14 Sep 2017 15:27:47 +0200
|
|
|
36cfb7 |
Subject: [PATCH] tc: m_xt: Prevent a segfault in libipt
|
|
|
36cfb7 |
|
|
|
36cfb7 |
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=1465599
|
|
|
36cfb7 |
Upstream Status: iproute2.git commit f6fc1055e41a8
|
|
|
36cfb7 |
|
|
|
36cfb7 |
commit f6fc1055e41a8a924313c336b39b9ffe0c86938b
|
|
|
36cfb7 |
Author: Phil Sutter <psutter@redhat.com>
|
|
|
36cfb7 |
Date: Tue May 23 15:40:57 2017 +0200
|
|
|
36cfb7 |
|
|
|
36cfb7 |
tc: m_xt: Prevent a segfault in libipt
|
|
|
36cfb7 |
|
|
|
36cfb7 |
This happens with NAT targets, such as SNAT, DNAT and MASQUERADE. These
|
|
|
36cfb7 |
are still not usable with this patch, but at least tc doesn't crash
|
|
|
36cfb7 |
anymore when one tries to use them.
|
|
|
36cfb7 |
|
|
|
36cfb7 |
Signed-off-by: Phil Sutter <phil@nwl.cc>
|
|
|
36cfb7 |
---
|
|
|
36cfb7 |
tc/m_xt.c | 5 ++++-
|
|
|
36cfb7 |
1 file changed, 4 insertions(+), 1 deletion(-)
|
|
|
36cfb7 |
|
|
|
36cfb7 |
diff --git a/tc/m_xt.c b/tc/m_xt.c
|
|
|
36cfb7 |
index e59df8e..ad52d23 100644
|
|
|
36cfb7 |
--- a/tc/m_xt.c
|
|
|
36cfb7 |
+++ b/tc/m_xt.c
|
|
|
36cfb7 |
@@ -146,6 +146,9 @@ static int parse_ipt(struct action_util *a, int *argc_p,
|
|
|
36cfb7 |
char ***argv_p, int tca_id, struct nlmsghdr *n)
|
|
|
36cfb7 |
{
|
|
|
36cfb7 |
struct xtables_target *m = NULL;
|
|
|
36cfb7 |
+#if XTABLES_VERSION_CODE >= 6
|
|
|
36cfb7 |
+ struct ipt_entry fw = {};
|
|
|
36cfb7 |
+#endif
|
|
|
36cfb7 |
struct rtattr *tail;
|
|
|
36cfb7 |
|
|
|
36cfb7 |
int c;
|
|
|
36cfb7 |
@@ -206,7 +209,7 @@ static int parse_ipt(struct action_util *a, int *argc_p,
|
|
|
36cfb7 |
default:
|
|
|
36cfb7 |
#if XTABLES_VERSION_CODE >= 6
|
|
|
36cfb7 |
if (m != NULL && m->x6_parse != NULL) {
|
|
|
36cfb7 |
- xtables_option_tpcall(c, argv, 0, m, NULL);
|
|
|
36cfb7 |
+ xtables_option_tpcall(c, argv, 0, m, &fw;;
|
|
|
36cfb7 |
#else
|
|
|
36cfb7 |
if (m != NULL && m->parse != NULL) {
|
|
|
36cfb7 |
m->parse(c - m->option_offset, argv, 0,
|
|
|
36cfb7 |
--
|
|
|
36cfb7 |
1.8.3.1
|
|
|
36cfb7 |
|