All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] netfilter : nfmark routing in OUTPUT, mangle, NFQUEUE
@ 2008-07-10  5:45 Laurent Licour
  2008-07-15 10:26 ` Patrick McHardy
  0 siblings, 1 reply; 3+ messages in thread
From: Laurent Licour @ 2008-07-10  5:45 UTC (permalink / raw)
  To: netfilter-devel


This patch let nfmark to be evaluated for routing decision for OUTPUT 
packet, in mangle
table, when process paquet in NFQUEUE
Until now, only change (in NFQUEUE process) on fields src_addr, 
dest_addr and tos
could make netfilter to reevalute the routing.
Similar code could also be applied to ipv6 code...


--- linux-2.6.18.i386.ori/net/ipv4/netfilter.c  2006-09-20 
05:42:06.000000000 +0200
+++ linux-2.6.18.i386/net/ipv4/netfilter.c      2008-07-07 
02:04:34.000000000 +0200
@@ -131,6 +131,9 @@
       u_int32_t daddr;
       u_int32_t saddr;
       u_int8_t tos;
+#ifdef CONFIG_IP_ROUTE_FWMARK
+       __u32 nfmark;
+#endif
};

static void nf_ip_saveroute(const struct sk_buff *skb, struct nf_info 
*info)
@@ -143,6 +146,9 @@
               rt_info->tos = iph->tos;
               rt_info->daddr = iph->daddr;
               rt_info->saddr = iph->saddr;
+#ifdef CONFIG_IP_ROUTE_FWMARK
+               rt_info->nfmark = skb->nfmark;
+#endif
       }
}

@@ -154,6 +160,9 @@
               struct iphdr *iph = (*pskb)->nh.iph;

               if (!(iph->tos == rt_info->tos
+#ifdef CONFIG_IP_ROUTE_FWMARK
+                     && (*pskb)->nfmark == rt_info->nfmark
+#endif
                     && iph->daddr == rt_info->daddr
                     && iph->saddr == rt_info->saddr))
                       return ip_route_me_harder(pskb);



^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2008-07-17  8:08 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-07-10  5:45 [PATCH] netfilter : nfmark routing in OUTPUT, mangle, NFQUEUE Laurent Licour
2008-07-15 10:26 ` Patrick McHardy
2008-07-17  8:00   ` Laurent Licour

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.