aboutsummaryrefslogtreecommitdiffstats
path: root/tap-iousers.c
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>2009-12-11 02:19:41 +0000
committerGuy Harris <guy@alum.mit.edu>2009-12-11 02:19:41 +0000
commitc6a5eacc1b57ef336d478d5e77ab61fdd401545d (patch)
tree40fd0b97ea3318d9bd4dd95306408d5f159555d0 /tap-iousers.c
parent0209b3014d594de5c9f2225a6a3aec764c5ee4a1 (diff)
As long as we have an IPv6 tap, we might as well add a "conv,ipv6"
statistic to TShark. svn path=/trunk/; revision=31232
Diffstat (limited to 'tap-iousers.c')
-rw-r--r--tap-iousers.c65
1 files changed, 65 insertions, 0 deletions
diff --git a/tap-iousers.c b/tap-iousers.c
index d25417e23a..1cfe1c1385 100644
--- a/tap-iousers.c
+++ b/tap-iousers.c
@@ -41,6 +41,7 @@
#include <epan/stat_cmd_args.h>
#include "register.h"
#include <epan/dissectors/packet-ip.h>
+#include <epan/dissectors/packet-ipv6.h>
#include <epan/dissectors/packet-ipx.h>
#include <epan/dissectors/packet-tcp.h>
#include <epan/dissectors/packet-udp.h>
@@ -298,6 +299,61 @@ iousers_ip_packet(void *arg, packet_info *pinfo, epan_dissect_t *edt _U_, const
}
static int
+iousers_ipv6_packet(void *arg, packet_info *pinfo, epan_dissect_t *edt _U_, const void *vip)
+{
+ io_users_t *iu=arg;
+ const struct ip6_hdr *ip6h=vip;
+ address src, dst;
+ const address *addr1, *addr2;
+ io_users_item_t *iui;
+
+ /* Addresses aren't implemented as 'address' type in struct ip6_hdr */
+ src.type = dst.type = AT_IPv6;
+ src.len = dst.len = sizeof(struct e_in6_addr);
+ src.data = &ip6h->ip6_src;
+ dst.data = &ip6h->ip6_dst;
+
+ if(CMP_ADDRESS(&src, &dst)>0){
+ addr1=&src;
+ addr2=&dst;
+ } else {
+ addr2=&src;
+ addr1=&dst;
+ }
+
+ for(iui=iu->items;iui;iui=iui->next){
+ if((!CMP_ADDRESS(&iui->addr1, addr1))
+ &&(!CMP_ADDRESS(&iui->addr2, addr2)) ){
+ break;
+ }
+ }
+
+ if(!iui){
+ iui=g_malloc(sizeof(io_users_item_t));
+ iui->next=iu->items;
+ iu->items=iui;
+ COPY_ADDRESS(&iui->addr1, addr1);
+ iui->name1=g_strdup(ep_address_to_str(addr1));
+ COPY_ADDRESS(&iui->addr2, addr2);
+ iui->name2=g_strdup(ep_address_to_str(addr2));
+ iui->frames1=0;
+ iui->frames2=0;
+ iui->bytes1=0;
+ iui->bytes2=0;
+ }
+
+ if(!CMP_ADDRESS(&dst, &iui->addr1)){
+ iui->frames1++;
+ iui->bytes1+=pinfo->fd->pkt_len;
+ } else {
+ iui->frames2++;
+ iui->bytes2+=pinfo->fd->pkt_len;
+ }
+
+ return 1;
+}
+
+static int
iousers_ipx_packet(void *arg, packet_info *pinfo, epan_dissect_t *edt _U_, const void *vipx)
{
io_users_t *iu=arg;
@@ -661,6 +717,15 @@ iousers_init(const char *optarg, void* userdata _U_)
tap_type="ip";
tap_type_name="IPv4";
packet_func=iousers_ip_packet;
+ } else if(!strncmp(optarg,"conv,ipv6",7)){
+ if(optarg[7]==','){
+ filter=optarg+10;
+ } else {
+ filter=NULL;
+ }
+ tap_type="ipv6";
+ tap_type_name="IPv6";
+ packet_func=iousers_ipv6_packet;
} else if(!strncmp(optarg,"conv,sctp",9)) {
if(optarg[9]==','){
filter=optarg+10;