[RTNETLINK] Fix RTM_MAX to represent the maximum valid message type
authorThomas Graf <tgraf@suug.ch>
Tue, 3 May 2005 21:27:35 +0000 (14:27 -0700)
committerDavid S. Miller <davem@davemloft.net>
Tue, 3 May 2005 21:27:35 +0000 (14:27 -0700)
RTM_MAX is currently set to the maximum reserverd message type plus one
thus being the cause of two bugs for new types being assigned a) given the
new family registers only the NEW command in its reserved block the array
size for per family entries is calculated one entry short and b) given the
new family registers all commands RTM_MAX would point to the first entry
of the block following this one and the rtnetlink receive path would accept
a message type for a nonexisting family.

This patch changes RTM_MAX to point to the maximum valid message type
by aligning it to the start of the next block and subtracting one.

Signed-off-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/linux/rtnetlink.h

index 32e52769a00b6ee74b94af0605dc79640a024e80..d607219af6ac96f2e92d1aac883bd53c5b7116c6 100644 (file)
@@ -89,8 +89,8 @@ enum {
        RTM_GETANYCAST  = 62,
 #define RTM_GETANYCAST RTM_GETANYCAST
 
-       RTM_MAX,
-#define RTM_MAX                RTM_MAX
+       __RTM_MAX,
+#define RTM_MAX                (((__RTM_MAX + 3) & ~3) - 1)
 };
 
 /*