aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorJan Engelhardt <jengelh@computergmbh.de>2008-01-15 02:32:37 -0500
committerDavid S. Miller <davem@davemloft.net>2008-01-28 18:02:18 -0500
commit9bb268ed7c5f0ec76a5bd6824450a104231152ba (patch)
tree83384863682a32413ed13423ce001a1a9b5f718a /net
parent11fa2aa362fa54b9eaa8adce9a89f9b467cc9214 (diff)
[NETFILTER]: xt_TOS: Change semantic of mask value
This patch changes the behavior of xt_TOS v1 so that the mask value the user supplies means "zero out these bits" rather than "keep these bits". This is more easy on the user, as (I would assume) people keep more bits than zeroing, so, an example: Action: Set bit 0x01. before (&): iptables -j TOS --set-tos 0x01/0xFE after (&~): iptables -j TOS --set-tos 0x01/0x01 This is not too "tragic" with xt_TOS, but where larger fields are used (e.g. proposed xt_MARK v2), `--set-xmar 0x01/0x01` vs. `--set-xmark 0x01/0xFFFFFFFE` really makes a difference. Other target(!) modules, such as xt_TPROXY also use &~ rather than &, so let's get to a common ground. (Since xt_TOS has not yet left the development tree en direction to mainline, the semantic can be changed as proposed without breaking iptables.) Signed-off-by: Jan Engelhardt <jengelh@computergmbh.de> Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r--net/netfilter/xt_DSCP.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/net/netfilter/xt_DSCP.c b/net/netfilter/xt_DSCP.c
index fd7500ecadfd..9951e7f85e32 100644
--- a/net/netfilter/xt_DSCP.c
+++ b/net/netfilter/xt_DSCP.c
@@ -128,7 +128,7 @@ tos_tg(struct sk_buff *skb, const struct net_device *in,
128 u_int8_t orig, nv; 128 u_int8_t orig, nv;
129 129
130 orig = ipv4_get_dsfield(iph); 130 orig = ipv4_get_dsfield(iph);
131 nv = (orig & info->tos_mask) ^ info->tos_value; 131 nv = (orig & ~info->tos_mask) ^ info->tos_value;
132 132
133 if (orig != nv) { 133 if (orig != nv) {
134 if (!skb_make_writable(skb, sizeof(struct iphdr))) 134 if (!skb_make_writable(skb, sizeof(struct iphdr)))