Updated code
This commit is contained in:
parent
a2befb9dd0
commit
528760f924
2 changed files with 70 additions and 66 deletions
|
@ -28,7 +28,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* @(#)$Id: tcpdump.c,v 1.1 2006/06/17 22:41:18 adamdunkels Exp $
|
* @(#)$Id: tcpdump.c,v 1.2 2006/10/09 11:53:56 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "contiki-net.h"
|
#include "contiki-net.h"
|
||||||
|
@ -39,14 +39,14 @@
|
||||||
struct ip_hdr {
|
struct ip_hdr {
|
||||||
/* IP header. */
|
/* IP header. */
|
||||||
u8_t vhl,
|
u8_t vhl,
|
||||||
tos,
|
tos,
|
||||||
len[2],
|
len[2],
|
||||||
ipid[2],
|
ipid[2],
|
||||||
ipoffset[2],
|
ipoffset[2],
|
||||||
ttl,
|
ttl,
|
||||||
proto;
|
proto;
|
||||||
u16_t ipchksum;
|
u16_t ipchksum;
|
||||||
u8_t srcipaddr[4],
|
u8_t srcipaddr[4],
|
||||||
destipaddr[4];
|
destipaddr[4];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -61,48 +61,48 @@
|
||||||
struct tcpip_hdr {
|
struct tcpip_hdr {
|
||||||
/* IP header. */
|
/* IP header. */
|
||||||
u8_t vhl,
|
u8_t vhl,
|
||||||
tos,
|
tos,
|
||||||
len[2],
|
len[2],
|
||||||
ipid[2],
|
ipid[2],
|
||||||
ipoffset[2],
|
ipoffset[2],
|
||||||
ttl,
|
ttl,
|
||||||
proto;
|
proto;
|
||||||
u16_t ipchksum;
|
u16_t ipchksum;
|
||||||
u8_t srcipaddr[4],
|
u8_t srcipaddr[4],
|
||||||
destipaddr[4];
|
destipaddr[4];
|
||||||
/* TCP header. */
|
/* TCP header. */
|
||||||
u16_t srcport,
|
u16_t srcport,
|
||||||
destport;
|
destport;
|
||||||
u8_t seqno[4],
|
u8_t seqno[4],
|
||||||
ackno[4],
|
ackno[4],
|
||||||
tcpoffset,
|
tcpoffset,
|
||||||
flags,
|
flags,
|
||||||
wnd[2];
|
wnd[2];
|
||||||
u16_t tcpchksum;
|
u16_t tcpchksum;
|
||||||
u8_t urgp[2];
|
u8_t urgp[2];
|
||||||
u8_t optdata[4];
|
u8_t optdata[4];
|
||||||
};
|
};
|
||||||
|
|
||||||
#define ICMP_ECHO_REPLY 0
|
#define ICMP_ECHO_REPLY 0
|
||||||
#define ICMP_ECHO 8
|
#define ICMP_ECHO 8
|
||||||
|
|
||||||
struct icmpip_hdr {
|
struct icmpip_hdr {
|
||||||
/* IP header. */
|
/* IP header. */
|
||||||
u8_t vhl,
|
u8_t vhl,
|
||||||
tos,
|
tos,
|
||||||
len[2],
|
len[2],
|
||||||
ipid[2],
|
ipid[2],
|
||||||
ipoffset[2],
|
ipoffset[2],
|
||||||
ttl,
|
ttl,
|
||||||
proto;
|
proto;
|
||||||
u16_t ipchksum;
|
u16_t ipchksum;
|
||||||
u8_t srcipaddr[4],
|
u8_t srcipaddr[4],
|
||||||
destipaddr[4];
|
destipaddr[4];
|
||||||
/* The ICMP and IP headers. */
|
/* The ICMP and IP headers. */
|
||||||
/* ICMP (echo) header. */
|
/* ICMP (echo) header. */
|
||||||
u8_t type, icode;
|
u8_t type, icode;
|
||||||
u16_t icmpchksum;
|
u16_t icmpchksum;
|
||||||
u16_t id, seqno;
|
u16_t id, seqno;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -110,14 +110,14 @@ struct icmpip_hdr {
|
||||||
struct udpip_hdr {
|
struct udpip_hdr {
|
||||||
/* IP header. */
|
/* IP header. */
|
||||||
u8_t vhl,
|
u8_t vhl,
|
||||||
tos,
|
tos,
|
||||||
len[2],
|
len[2],
|
||||||
ipid[2],
|
ipid[2],
|
||||||
ipoffset[2],
|
ipoffset[2],
|
||||||
ttl,
|
ttl,
|
||||||
proto;
|
proto;
|
||||||
u16_t ipchksum;
|
u16_t ipchksum;
|
||||||
u8_t srcipaddr[4],
|
u8_t srcipaddr[4],
|
||||||
destipaddr[4];
|
destipaddr[4];
|
||||||
|
|
||||||
/* UDP header. */
|
/* UDP header. */
|
||||||
|
@ -127,11 +127,11 @@ struct udpip_hdr {
|
||||||
u16_t udpchksum;
|
u16_t udpchksum;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define ETHBUF ((struct eth_hdr *)&uip_buf[0])
|
#define ETHBUF ((struct eth_hdr *)&packet[0])
|
||||||
#define IPBUF ((struct ip_hdr *)&uip_buf[UIP_LLH_LEN])
|
#define IPBUF ((struct ip_hdr *)&packet[0])
|
||||||
#define UDPBUF ((struct udpip_hdr *)&uip_buf[UIP_LLH_LEN])
|
#define UDPBUF ((struct udpip_hdr *)&packet[0])
|
||||||
#define ICMPBUF ((struct icmpip_hdr *)&uip_buf[UIP_LLH_LEN])
|
#define ICMPBUF ((struct icmpip_hdr *)&packet[0])
|
||||||
#define TCPBUF ((struct tcpip_hdr *)&uip_buf[UIP_LLH_LEN])
|
#define TCPBUF ((struct tcpip_hdr *)&packet[0])
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
@ -157,7 +157,7 @@ tcpflags(unsigned char flags, char *flagsstr)
|
||||||
*flagsstr = 0;
|
*flagsstr = 0;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static char * CC_FASTCALL
|
static char * CC_FASTCALL
|
||||||
n(u16_t num, char *ptr)
|
n(u16_t num, char *ptr)
|
||||||
{
|
{
|
||||||
u16_t d;
|
u16_t d;
|
||||||
|
@ -165,7 +165,7 @@ n(u16_t num, char *ptr)
|
||||||
|
|
||||||
if(num == 0) {
|
if(num == 0) {
|
||||||
*ptr = '0';
|
*ptr = '0';
|
||||||
return ptr + 1;
|
return ptr + 1;
|
||||||
} else {
|
} else {
|
||||||
f = 0;
|
f = 0;
|
||||||
for(d = 10000; d >= 1; d /= 10) {
|
for(d = 10000; d >= 1; d /= 10) {
|
||||||
|
@ -180,7 +180,7 @@ n(u16_t num, char *ptr)
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static char * CC_FASTCALL
|
static char * CC_FASTCALL
|
||||||
d(char *ptr)
|
d(char *ptr)
|
||||||
{
|
{
|
||||||
*ptr = '.';
|
*ptr = '.';
|
||||||
|
@ -195,20 +195,21 @@ s(char *str, char *ptr)
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
int
|
int
|
||||||
tcpdump_print(char *buf, u16_t buflen)
|
tcpdump_format(u8_t *packet, u16_t packetlen,
|
||||||
|
char *buf, u16_t buflen)
|
||||||
{
|
{
|
||||||
char flags[8];
|
char flags[8];
|
||||||
if(IPBUF->proto == UIP_PROTO_ICMP) {
|
if(IPBUF->proto == UIP_PROTO_ICMP) {
|
||||||
if(ICMPBUF->type == ICMP_ECHO) {
|
if(ICMPBUF->type == ICMP_ECHO) {
|
||||||
return s(" ping",
|
return s(" ping",
|
||||||
n(IPBUF->destipaddr[3], d(
|
n(IPBUF->destipaddr[3], d(
|
||||||
n(IPBUF->destipaddr[2], d(
|
n(IPBUF->destipaddr[2], d(
|
||||||
n(IPBUF->destipaddr[1], d(
|
n(IPBUF->destipaddr[1], d(
|
||||||
n(IPBUF->destipaddr[0],
|
n(IPBUF->destipaddr[0],
|
||||||
s(" ",
|
s(" ",
|
||||||
n(IPBUF->srcipaddr[3], d(
|
n(IPBUF->srcipaddr[3], d(
|
||||||
n(IPBUF->srcipaddr[2], d(
|
n(IPBUF->srcipaddr[2], d(
|
||||||
n(IPBUF->srcipaddr[1], d(
|
n(IPBUF->srcipaddr[1], d(
|
||||||
n(IPBUF->srcipaddr[0],
|
n(IPBUF->srcipaddr[0],
|
||||||
buf)))))))))))))))) - buf;
|
buf)))))))))))))))) - buf;
|
||||||
|
|
||||||
|
@ -220,13 +221,13 @@ tcpdump_print(char *buf, u16_t buflen)
|
||||||
} else if(ICMPBUF->type == ICMP_ECHO_REPLY) {
|
} else if(ICMPBUF->type == ICMP_ECHO_REPLY) {
|
||||||
return s(" pong",
|
return s(" pong",
|
||||||
n(IPBUF->destipaddr[3], d(
|
n(IPBUF->destipaddr[3], d(
|
||||||
n(IPBUF->destipaddr[2], d(
|
n(IPBUF->destipaddr[2], d(
|
||||||
n(IPBUF->destipaddr[1], d(
|
n(IPBUF->destipaddr[1], d(
|
||||||
n(IPBUF->destipaddr[0],
|
n(IPBUF->destipaddr[0],
|
||||||
s(" ",
|
s(" ",
|
||||||
n(IPBUF->srcipaddr[3], d(
|
n(IPBUF->srcipaddr[3], d(
|
||||||
n(IPBUF->srcipaddr[2], d(
|
n(IPBUF->srcipaddr[2], d(
|
||||||
n(IPBUF->srcipaddr[1], d(
|
n(IPBUF->srcipaddr[1], d(
|
||||||
n(IPBUF->srcipaddr[0],
|
n(IPBUF->srcipaddr[0],
|
||||||
buf)))))))))))))))) - buf;
|
buf)))))))))))))))) - buf;
|
||||||
/* return sprintf(buf, "%d.%d.%d.%d %d.%d.%d.%d pong",
|
/* return sprintf(buf, "%d.%d.%d.%d %d.%d.%d.%d pong",
|
||||||
|
@ -237,16 +238,16 @@ tcpdump_print(char *buf, u16_t buflen)
|
||||||
}
|
}
|
||||||
} else if(IPBUF->proto == UIP_PROTO_UDP) {
|
} else if(IPBUF->proto == UIP_PROTO_UDP) {
|
||||||
return s(" UDP",
|
return s(" UDP",
|
||||||
n(htons(UDPBUF->destport), d(
|
n(htons(UDPBUF->destport), d(
|
||||||
n(IPBUF->destipaddr[3], d(
|
n(IPBUF->destipaddr[3], d(
|
||||||
n(IPBUF->destipaddr[2], d(
|
n(IPBUF->destipaddr[2], d(
|
||||||
n(IPBUF->destipaddr[1], d(
|
n(IPBUF->destipaddr[1], d(
|
||||||
n(IPBUF->destipaddr[0],
|
n(IPBUF->destipaddr[0],
|
||||||
s(" ",
|
s(" ",
|
||||||
n(htons(UDPBUF->srcport), d(
|
n(htons(UDPBUF->srcport), d(
|
||||||
n(IPBUF->srcipaddr[3], d(
|
n(IPBUF->srcipaddr[3], d(
|
||||||
n(IPBUF->srcipaddr[2], d(
|
n(IPBUF->srcipaddr[2], d(
|
||||||
n(IPBUF->srcipaddr[1], d(
|
n(IPBUF->srcipaddr[1], d(
|
||||||
n(IPBUF->srcipaddr[0],
|
n(IPBUF->srcipaddr[0],
|
||||||
buf)))))))))))))))))))) - buf;
|
buf)))))))))))))))))))) - buf;
|
||||||
/* return sprintf(buf, "%d.%d.%d.%d.%d %d.%d.%d.%d.%d UDP",
|
/* return sprintf(buf, "%d.%d.%d.%d.%d %d.%d.%d.%d.%d UDP",
|
||||||
|
@ -260,16 +261,16 @@ tcpdump_print(char *buf, u16_t buflen)
|
||||||
tcpflags(TCPBUF->flags, flags);
|
tcpflags(TCPBUF->flags, flags);
|
||||||
return s(flags,
|
return s(flags,
|
||||||
s(" ",
|
s(" ",
|
||||||
n(htons(TCPBUF->destport), d(
|
n(htons(TCPBUF->destport), d(
|
||||||
n(IPBUF->destipaddr[3], d(
|
n(IPBUF->destipaddr[3], d(
|
||||||
n(IPBUF->destipaddr[2], d(
|
n(IPBUF->destipaddr[2], d(
|
||||||
n(IPBUF->destipaddr[1], d(
|
n(IPBUF->destipaddr[1], d(
|
||||||
n(IPBUF->destipaddr[0],
|
n(IPBUF->destipaddr[0],
|
||||||
s(" ",
|
s(" ",
|
||||||
n(htons(TCPBUF->srcport), d(
|
n(htons(TCPBUF->srcport), d(
|
||||||
n(IPBUF->srcipaddr[3], d(
|
n(IPBUF->srcipaddr[3], d(
|
||||||
n(IPBUF->srcipaddr[2], d(
|
n(IPBUF->srcipaddr[2], d(
|
||||||
n(IPBUF->srcipaddr[1], d(
|
n(IPBUF->srcipaddr[1], d(
|
||||||
n(IPBUF->srcipaddr[0],
|
n(IPBUF->srcipaddr[0],
|
||||||
buf))))))))))))))))))))) - buf;
|
buf))))))))))))))))))))) - buf;
|
||||||
/* return sprintf(buf, "%d.%d.%d.%d.%d %d.%d.%d.%d.%d %s",
|
/* return sprintf(buf, "%d.%d.%d.%d.%d %d.%d.%d.%d.%d %s",
|
||||||
|
@ -280,6 +281,8 @@ tcpdump_print(char *buf, u16_t buflen)
|
||||||
IPBUF->destipaddr[2], IPBUF->destipaddr[3],
|
IPBUF->destipaddr[2], IPBUF->destipaddr[3],
|
||||||
htons(TCPBUF->destport),
|
htons(TCPBUF->destport),
|
||||||
flags); */
|
flags); */
|
||||||
|
} else {
|
||||||
|
strcpy(buf, "Unrecognized protocol");
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -28,13 +28,14 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* @(#)$Id: tcpdump.h,v 1.1 2006/06/17 22:41:18 adamdunkels Exp $
|
* @(#)$Id: tcpdump.h,v 1.2 2006/10/09 11:53:56 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
#ifndef __TCPDUMP_H__
|
#ifndef __TCPDUMP_H__
|
||||||
#define __TCPDUMP_H__
|
#define __TCPDUMP_H__
|
||||||
|
|
||||||
#include "uip.h"
|
#include "uip.h"
|
||||||
|
|
||||||
int tcpdump_print(char *buf, u16_t buflen);
|
int tcpdump_format(u8_t *packet, u16_t *len,
|
||||||
|
char *printbuf, u16_t printbuflen);
|
||||||
|
|
||||||
#endif /* __TCPDUMP_H__ */
|
#endif /* __TCPDUMP_H__ */
|
||||||
|
|
Loading…
Reference in a new issue