diff options
author | piso <piso@FreeBSD.org> | 2008-03-06 21:50:41 +0000 |
---|---|---|
committer | piso <piso@FreeBSD.org> | 2008-03-06 21:50:41 +0000 |
commit | 5f33f90d24e8c6aa3689da010e33cf37f17155f7 (patch) | |
tree | e1a9424168a96098f55aa0944676e9c680eb8076 /sys/netinet/libalias/alias_proxy.c | |
parent | ad2b8c2d06f61008d2506c5967e2710e156623bf (diff) | |
download | FreeBSD-src-5f33f90d24e8c6aa3689da010e33cf37f17155f7.zip FreeBSD-src-5f33f90d24e8c6aa3689da010e33cf37f17155f7.tar.gz |
MFP4:
restrict the utilization of direct pointers to the content of
ip packet. These modifications are functionally nop()s thus
can be merged with no side effects.
Diffstat (limited to 'sys/netinet/libalias/alias_proxy.c')
-rw-r--r-- | sys/netinet/libalias/alias_proxy.c | 21 |
1 files changed, 8 insertions, 13 deletions
diff --git a/sys/netinet/libalias/alias_proxy.c b/sys/netinet/libalias/alias_proxy.c index d7efb4b..4e11d4d 100644 --- a/sys/netinet/libalias/alias_proxy.c +++ b/sys/netinet/libalias/alias_proxy.c @@ -453,8 +453,10 @@ ProxyEncodeTcpStream(struct alias_link *lnk, int delta; SetAckModified(lnk); - delta = GetDeltaSeqOut(pip, lnk); - AddSeq(pip, lnk, delta + slen); + tc = (struct tcphdr *)ip_next(pip); + delta = GetDeltaSeqOut(tc->th_seq, lnk); + AddSeq(lnk, delta + slen, pip->ip_hl, pip->ip_len, tc->th_seq, + tc->th_off); } /* Update IP header packet length and checksum */ @@ -561,20 +563,13 @@ ProxyEncodeIpHeader(struct ip *pip, */ int -ProxyCheck(struct libalias *la, struct ip *pip, - struct in_addr *proxy_server_addr, - u_short * proxy_server_port) +ProxyCheck(struct libalias *la, struct in_addr *proxy_server_addr, + u_short * proxy_server_port, struct in_addr src_addr, + struct in_addr dst_addr, u_short dst_port, u_char ip_p) { - u_short dst_port; - struct in_addr src_addr; - struct in_addr dst_addr; struct proxy_entry *ptr; LIBALIAS_LOCK_ASSERT(la); - src_addr = pip->ip_src; - dst_addr = pip->ip_dst; - dst_port = ((struct tcphdr *)ip_next(pip)) - ->th_dport; ptr = la->proxyList; while (ptr != NULL) { @@ -582,7 +577,7 @@ ProxyCheck(struct libalias *la, struct ip *pip, proxy_port = ptr->proxy_port; if ((dst_port == proxy_port || proxy_port == 0) - && pip->ip_p == ptr->proto + && ip_p == ptr->proto && src_addr.s_addr != ptr->server_addr.s_addr) { struct in_addr src_addr_masked; struct in_addr dst_addr_masked; |