/******************************************************************************
-Author: Samuel Jero
+Utility to convert a LTP flow to a TCP flow for LTP analysis via tcptrace.
+Utility Functions for Encapsulation
-Date: 12/2010
+Copyright (C) 2013 Samuel Jero <sj323707@ohio.edu>
-Description: Utility Functions for Encapsulation
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+Author: Samuel Jero <sj323707@ohio.edu>
+Date: 06/2013
+
+Notes:
+ 1)Only handles one LTP "connection". There isn't a good way to separate
+ different LTP "connections" from new sessions of the same "connection".
+ Use Tcpdump filters to separate connections. Libpcap filtering could also
+ be added in ltp2tcp.
+ 2)Uses some special types from Linux (u_char, u_int32_t)
******************************************************************************/
#include "ltp2tcp.h"
+#include "checksums.h"
/* encapsulation manipulation after conversion */
int eip4_post(struct eip4_en_p *eip, int tlen, u_char* data){
struct iphdr *iph;
+ struct tcphdr *tcph;
/* Move data pointer to start of IPv4 header*/
data+=sizeof(struct ether_header);
/*Adjust IPv4 header to account for packet's total length*/
iph=(struct iphdr*)data;
- iph->tot_len=htons(sizeof(struct iphdr)+tlen);
+ iph->tot_len=htons(iph->ihl*4+tlen);
+
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum(data,iph->ihl*4);
+
+ /*Compute TCP Checksum*/
+ data+=iph->ihl*4;
+ tcph=(struct tcphdr*)data;
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum(data, tlen, (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
return 0;
}
iph->check=htonl(0);
iph->tot_len=htons(sizeof(struct iphdr)+sizeof(struct tcphdr)+4);
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum((u_char*)iph,iph->ihl*4);
+
/*Build TCP header*/
ptr+=sizeof(struct ether_header)+ sizeof(struct iphdr);
tcph=(struct tcphdr*)ptr;
ptr++;
*ptr=2;
+ /*Compute TCP Checksum*/
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum((u_char*)tcph,tcph->doff*4,
+ (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
+
/*Save To Packet Capture*/
pcap_dump((u_char*)state.out,&nh, data);
iph->daddr=temp;
iph->tot_len=htons(sizeof(struct iphdr)+sizeof(struct tcphdr)+4);
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum((u_char*)iph,iph->ihl*4);
+
/*Build TCP header*/
ptr+=sizeof(struct ether_header)+ sizeof(struct iphdr);
tcph=(struct tcphdr*)ptr;
ptr++;
*ptr=2;
+ /*Compute TCP Checksum*/
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum((u_char*)tcph,tcph->doff*4 ,
+ (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
+
/*Save To Packet Capture*/
pcap_dump((u_char*)state.out,&nh, data);
iph->check=htonl(0);
iph->tot_len=htons(sizeof(struct iphdr)+sizeof(struct tcphdr));
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum((u_char*)iph,iph->ihl*4);
+
/*Build TCP header*/
ptr+=sizeof(struct ether_header)+ sizeof(struct iphdr);
tcph=(struct tcphdr*)ptr;
tcph->ack_seq=htonl(state.ack_num);
tcph->window=htons(WIN_FACTOR);
+ /*Compute TCP Checksum*/
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum((u_char*)tcph,tcph->doff*4,
+ (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
+
/*Save To Packet Capture*/
pcap_dump((u_char*)state.out,&nh, data);
return 0;
iph->check=htonl(0);
iph->tot_len=htons(sizeof(struct iphdr)+sizeof(struct tcphdr));
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum((u_char*)iph,iph->ihl*4);
+
/*Build TCP header*/
ptr+=sizeof(struct ether_header)+ sizeof(struct iphdr);
tcph=(struct tcphdr*)ptr;
/*Update Sequence Number to include the fin packet in the sequence number space*/
state.seq_num++;
+ /*Compute TCP Checksum*/
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum((u_char*)tcph,tcph->doff*4,
+ (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
+
/* Save To Packet Capture*/
pcap_dump((u_char*)state.out,&nh, data);
iph->daddr=temp;
iph->tot_len=htons(sizeof(struct iphdr)+sizeof(struct tcphdr));
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum((u_char*)iph,iph->ihl*4);
+
/*Build TCP header*/
ptr+=sizeof(struct ether_header)+ sizeof(struct iphdr);
tcph=(struct tcphdr*)ptr;
tcph->ack_seq=htonl(state.seq_num);
tcph->window=htons(WIN_FACTOR);
+ /*Compute TCP Checksum*/
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum((u_char*)tcph,sizeof(struct tcphdr),
+ (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
+
/*Save To Packet Capture*/
pcap_dump((u_char*)state.out,&nh, data);
iph->check=htonl(0);
iph->tot_len=htons(sizeof(struct iphdr)+sizeof(struct tcphdr));
+ /*Compute IPv4 Checksum*/
+ iph->check=0;
+ iph->check=ipv4_chksum((u_char*)iph,iph->ihl*4);
+
/*Build TCP header*/
ptr+=sizeof(struct ether_header)+ sizeof(struct iphdr);
tcph=(struct tcphdr*)ptr;
tcph->ack_seq=htonl(state.ack_num);
tcph->window=htons(WIN_FACTOR);
+ /*Compute TCP Checksum*/
+ tcph->check=0;
+ tcph->check=ipv4_pseudohdr_chksum((u_char*)tcph,tcph->doff*4,
+ (u_char*)&iph->daddr, (u_char*)&iph->saddr, iph->protocol);
+
/*Save To Packet Capture*/
pcap_dump((u_char*)state.out,&nh, data);
return 0;