📄 ipt_ecn.c
字号:
/* iptables module for the IPv4 and TCP ECN bits, Version 1.2 * * (C) 2002 by Harald Welte <laforge@gnumonks.org> * * This software is distributed under GNU GPL v2, 1991 * * ipt_ECN.c,v 1.4 2002/08/05 19:36:51 laforge Exp*/#include <linux/module.h>#include <linux/skbuff.h>#include <linux/ip.h>#include <net/checksum.h>#include <linux/netfilter_ipv4/ip_tables.h>#include <linux/netfilter_ipv4/ipt_ECN.h>MODULE_LICENSE("GPL");/* set ECT codepoint from IP header. * return 0 in case there was no ECT codepoint * return 1 in case ECT codepoint has been overwritten * return < 0 in case there was error */static int inlineset_ect_ip(struct sk_buff **pskb, struct iphdr *iph, const struct ipt_ECN_info *einfo){ if ((iph->tos & IPT_ECN_IP_MASK) != (einfo->ip_ect & IPT_ECN_IP_MASK)) { u_int16_t diffs[2]; /* raw socket (tcpdump) may have clone of incoming * skb: don't disturb it --RR */ if (skb_cloned(*pskb) && !(*pskb)->sk) { struct sk_buff *nskb = skb_copy(*pskb, GFP_ATOMIC); if (!nskb) return NF_DROP; kfree_skb(*pskb); *pskb = nskb; iph = (*pskb)->nh.iph; } diffs[0] = htons(iph->tos) ^ 0xFFFF; iph->tos = iph->tos & ~IPT_ECN_IP_MASK; iph->tos = iph->tos | (einfo->ip_ect & IPT_ECN_IP_MASK); diffs[1] = htons(iph->tos); iph->check = csum_fold(csum_partial((char *)diffs, sizeof(diffs), iph->check^0xFFFF)); (*pskb)->nfcache |= NFC_ALTERED; return 1; } return 0;}static int inlineset_ect_tcp(struct sk_buff **pskb, struct iphdr *iph, const struct ipt_ECN_info *einfo){ struct tcphdr *tcph = (void *) iph + iph->ihl * 4; u_int16_t *tcpflags = (u_int16_t *)tcph + 6; u_int16_t diffs[2]; /* raw socket (tcpdump) may have clone of incoming * skb: don't disturb it --RR */ if (skb_cloned(*pskb) && !(*pskb)->sk) { struct sk_buff *nskb = skb_copy(*pskb, GFP_ATOMIC); if (!nskb) return NF_DROP; kfree_skb(*pskb); *pskb = nskb; iph = (*pskb)->nh.iph; } diffs[0] = *tcpflags; if (einfo->operation & IPT_ECN_OP_SET_ECE && tcph->ece != einfo->proto.tcp.ece) { tcph->ece = einfo->proto.tcp.ece; } if (einfo->operation & IPT_ECN_OP_SET_CWR && tcph->cwr != einfo->proto.tcp.cwr) { tcph->cwr = einfo->proto.tcp.cwr; } if (diffs[0] != *tcpflags) { diffs[0] = diffs[0] ^ 0xFFFF; diffs[1] = *tcpflags; tcph->check = csum_fold(csum_partial((char *)diffs, sizeof(diffs), tcph->check^0xFFFF)); (*pskb)->nfcache |= NFC_ALTERED; return 1; } return 0;}static unsigned inttarget(struct sk_buff **pskb, unsigned int hooknum, const struct net_device *in,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -