From: Thomas Graf <tgraf@suug.ch>
To: "David S. Miller" <davem@davemloft.net>
Cc: netdev@oss.sgi.com
Subject: [PATCH] [IPV4]: Exclude "All deletion of equal addresses only differing by prefix length."
Date: Thu, 31 Mar 2005 14:47:47 +0200 [thread overview]
Message-ID: <20050331124747.GT3086@postel.suug.ch> (raw)
The address deletion fix is no longer needed since a better fix
has made it into iproute2. Better in terms of same hack but in
userspace so we don't confuse other netlink users.
Please do a
bk pull bk://kernel.bkbits.net/tgraf/net-2.6-trunk
This will update the following files:
include/linux/inetdevice.h | 20 --------------------
include/linux/rtnetlink.h | 13 -------------
net/ipv4/devinet.c | 6 ++----
3 files changed, 2 insertions(+), 37 deletions(-)
through these ChangeSets:
<tgraf@suug.ch> (05/03/31 1.2199)
Cset exclude: tgraf@suug.ch|ChangeSet|20050316221421|24742
# This is a BitKeeper generated diff -Nru style patch.
#
# ChangeSet
# 2005/03/31 14:34:31+02:00 tgraf@suug.ch
# Cset exclude: tgraf@suug.ch|ChangeSet|20050316221421|24742
#
# net/ipv4/devinet.c
# 2005/03/31 14:34:23+02:00 tgraf@suug.ch +0 -0
# Exclude
#
# include/linux/rtnetlink.h
# 2005/03/31 14:34:23+02:00 tgraf@suug.ch +0 -0
# Exclude
#
# include/linux/inetdevice.h
# 2005/03/31 14:34:23+02:00 tgraf@suug.ch +0 -0
# Exclude
#
diff -Nru a/include/linux/inetdevice.h b/include/linux/inetdevice.h
--- a/include/linux/inetdevice.h 2005-03-31 14:35:28 +02:00
+++ b/include/linux/inetdevice.h 2005-03-31 14:35:28 +02:00
@@ -7,7 +7,6 @@
#include <linux/netdevice.h>
#include <linux/rcupdate.h>
#include <linux/timer.h>
-#include <linux/rtnetlink.h>
struct ipv4_devconf
{
@@ -130,25 +129,6 @@
if (mask & (mask+1))
return 1;
return 0;
-}
-
-static inline int inet_ifa_match_local_prefixlen(struct ifaddrmsg *ifm,
- struct in_ifaddr *ifa)
-{
- int real_prefixlen = IFA_REAL_DEL_PREFIX(ifm->ifa_prefixlen);
-
- /*
- * Since the prefix length hasn't been taken into account in
- * previous kernel versions, parts of the userspace rely on the fact
- * that the deletion of an address without specifying a prefix works.
- * We cannot break this and thus a prefix length of 32 still represents
- * a wildcard if no exact match is requested.
- */
- if (real_prefixlen != 32 || ifm->ifa_prefixlen & IFA_PREFIX_EXACT_DEL)
- if (real_prefixlen != ifa->ifa_prefixlen)
- return 0;
-
- return 1;
}
#define for_primary_ifa(in_dev) { struct in_ifaddr *ifa; \
diff -Nru a/include/linux/rtnetlink.h b/include/linux/rtnetlink.h
--- a/include/linux/rtnetlink.h 2005-03-31 14:35:28 +02:00
+++ b/include/linux/rtnetlink.h 2005-03-31 14:35:28 +02:00
@@ -398,19 +398,6 @@
#define IFA_MAX (__IFA_MAX - 1)
-/*
- * Quirk for IPv4 address deletion to allow exact deletion of equal
- * addresses varying only in prefix length. A explicit exact comparison
- * of the prefix length will only be done if IFA_PREFIX_EXACT_DEL is
- * ORed to ifa_prefixlen.
- *
- * Note: This special treatment is only understood while deleting
- * addresses and will lead to unexpected behaviour if used
- * otherwise.
- */
-#define IFA_PREFIX_EXACT_DEL 0x40
-#define IFA_REAL_DEL_PREFIX(l) ((l) & 0x3f)
-
/* ifa_flags */
#define IFA_F_SECONDARY 0x01
diff -Nru a/net/ipv4/devinet.c b/net/ipv4/devinet.c
--- a/net/ipv4/devinet.c 2005-03-31 14:35:28 +02:00
+++ b/net/ipv4/devinet.c 2005-03-31 14:35:28 +02:00
@@ -389,7 +389,6 @@
struct in_device *in_dev;
struct ifaddrmsg *ifm = NLMSG_DATA(nlh);
struct in_ifaddr *ifa, **ifap;
- int real_prefixlen = IFA_REAL_DEL_PREFIX(ifm->ifa_prefixlen);
ASSERT_RTNL();
@@ -400,13 +399,12 @@
for (ifap = &in_dev->ifa_list; (ifa = *ifap) != NULL;
ifap = &ifa->ifa_next) {
if ((rta[IFA_LOCAL - 1] &&
- (!inet_ifa_match_local_prefixlen(ifm, ifa) ||
memcmp(RTA_DATA(rta[IFA_LOCAL - 1]),
- &ifa->ifa_local, 4))) ||
+ &ifa->ifa_local, 4)) ||
(rta[IFA_LABEL - 1] &&
rtattr_strcmp(rta[IFA_LABEL - 1], ifa->ifa_label)) ||
(rta[IFA_ADDRESS - 1] &&
- (real_prefixlen != ifa->ifa_prefixlen ||
+ (ifm->ifa_prefixlen != ifa->ifa_prefixlen ||
!inet_ifa_match(*(u32*)RTA_DATA(rta[IFA_ADDRESS - 1]),
ifa))))
continue;
next reply other threads:[~2005-03-31 12:47 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-03-31 12:47 Thomas Graf [this message]
2005-03-31 17:48 ` [PATCH] [IPV4]: Exclude "All deletion of equal addresses only differing by prefix length." Pekka Savola
2005-03-31 18:26 ` Thomas Graf
2005-03-31 18:36 ` David S. Miller
2005-03-31 18:56 ` David S. Miller
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20050331124747.GT3086@postel.suug.ch \
--to=tgraf@suug.ch \
--cc=davem@davemloft.net \
--cc=netdev@oss.sgi.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).