|
@@ -1,82 +0,0 @@
|
|
|
-/* This is a module which is used for setting the TOS field of a packet. */
|
|
|
-
|
|
|
-/* (C) 1999-2001 Paul `Rusty' Russell
|
|
|
- * (C) 2002-2004 Netfilter Core Team <coreteam@netfilter.org>
|
|
|
- *
|
|
|
- * This program is free software; you can redistribute it and/or modify
|
|
|
- * it under the terms of the GNU General Public License version 2 as
|
|
|
- * published by the Free Software Foundation.
|
|
|
- */
|
|
|
-
|
|
|
-#include <linux/module.h>
|
|
|
-#include <linux/skbuff.h>
|
|
|
-#include <linux/ip.h>
|
|
|
-#include <net/checksum.h>
|
|
|
-
|
|
|
-#include <linux/netfilter/x_tables.h>
|
|
|
-#include <linux/netfilter_ipv4/ipt_TOS.h>
|
|
|
-
|
|
|
-MODULE_LICENSE("GPL");
|
|
|
-MODULE_AUTHOR("Netfilter Core Team <coreteam@netfilter.org>");
|
|
|
-MODULE_DESCRIPTION("iptables TOS mangling module");
|
|
|
-
|
|
|
-static unsigned int
|
|
|
-tos_tg(struct sk_buff *skb, const struct net_device *in,
|
|
|
- const struct net_device *out, unsigned int hooknum,
|
|
|
- const struct xt_target *target, const void *targinfo)
|
|
|
-{
|
|
|
- const struct ipt_tos_target_info *tosinfo = targinfo;
|
|
|
- struct iphdr *iph = ip_hdr(skb);
|
|
|
-
|
|
|
- if ((iph->tos & IPTOS_TOS_MASK) != tosinfo->tos) {
|
|
|
- __u8 oldtos;
|
|
|
- if (!skb_make_writable(skb, sizeof(struct iphdr)))
|
|
|
- return NF_DROP;
|
|
|
- iph = ip_hdr(skb);
|
|
|
- oldtos = iph->tos;
|
|
|
- iph->tos = (iph->tos & IPTOS_PREC_MASK) | tosinfo->tos;
|
|
|
- csum_replace2(&iph->check, htons(oldtos), htons(iph->tos));
|
|
|
- }
|
|
|
- return XT_CONTINUE;
|
|
|
-}
|
|
|
-
|
|
|
-static bool
|
|
|
-tos_tg_check(const char *tablename, const void *e_void,
|
|
|
- const struct xt_target *target, void *targinfo,
|
|
|
- unsigned int hook_mask)
|
|
|
-{
|
|
|
- const u_int8_t tos = ((struct ipt_tos_target_info *)targinfo)->tos;
|
|
|
-
|
|
|
- if (tos != IPTOS_LOWDELAY
|
|
|
- && tos != IPTOS_THROUGHPUT
|
|
|
- && tos != IPTOS_RELIABILITY
|
|
|
- && tos != IPTOS_MINCOST
|
|
|
- && tos != IPTOS_NORMALSVC) {
|
|
|
- printk(KERN_WARNING "TOS: bad tos value %#x\n", tos);
|
|
|
- return false;
|
|
|
- }
|
|
|
- return true;
|
|
|
-}
|
|
|
-
|
|
|
-static struct xt_target tos_tg_reg __read_mostly = {
|
|
|
- .name = "TOS",
|
|
|
- .family = AF_INET,
|
|
|
- .target = tos_tg,
|
|
|
- .targetsize = sizeof(struct ipt_tos_target_info),
|
|
|
- .table = "mangle",
|
|
|
- .checkentry = tos_tg_check,
|
|
|
- .me = THIS_MODULE,
|
|
|
-};
|
|
|
-
|
|
|
-static int __init tos_tg_init(void)
|
|
|
-{
|
|
|
- return xt_register_target(&tos_tg_reg);
|
|
|
-}
|
|
|
-
|
|
|
-static void __exit tos_tg_exit(void)
|
|
|
-{
|
|
|
- xt_unregister_target(&tos_tg_reg);
|
|
|
-}
|
|
|
-
|
|
|
-module_init(tos_tg_init);
|
|
|
-module_exit(tos_tg_exit);
|