📄 icmpdump.c
字号:
/* ICMP header tracing
*/
#include <stdio.h>
#include "global.h"
#include "mbuf.h"
#include "internet.h"
#include "netuser.h"
#include "icmp.h"
#include "trace.h"
#include "ip.h"
/* Dump an ICMP header */
void
icmp_dump(fp,bpp,source,dest,check)
FILE *fp;
struct mbuf **bpp;
int32 source,dest;
int check; /* If 0, bypass checksum verify */
{
struct icmp icmp;
uint16 csum;
if(bpp == NULL || *bpp == NULL)
return;
csum = cksum(NULL,*bpp,len_p(*bpp));
ntohicmp(&icmp,bpp);
fprintf(fp,"ICMP: type %s",smsg(Icmptypes,ICMP_TYPES,icmp.type));
switch(icmp.type){
case ICMP_DEST_UNREACH:
fprintf(fp," code %s",smsg(Unreach,NUNREACH,icmp.code));
break;
case ICMP_REDIRECT:
fprintf(fp," code %s",smsg(Redirect,NREDIRECT,icmp.code));
fprintf(fp," new gateway %s",inet_ntoa(icmp.args.address));
break;
case ICMP_TIME_EXCEED:
fprintf(fp," code %s",smsg(Exceed,NEXCEED,icmp.code));
break;
case ICMP_PARAM_PROB:
fprintf(fp," pointer %u",icmp.args.pointer);
break;
case ICMP_ECHO:
case ICMP_ECHO_REPLY:
case ICMP_INFO_RQST:
case ICMP_INFO_REPLY:
case ICMP_TIMESTAMP:
case ICMP_TIME_REPLY:
fprintf(fp," id %u seq %u",icmp.args.echo.id,icmp.args.echo.seq);
break;
case ICMP_IPSP:
fprintf(fp," %s",smsg(Said_icmp,NIPSP,icmp.code));
break;
}
if(check && csum != 0){
fprintf(fp," CHECKSUM ERROR (%u)",csum);
}
putc('\n',fp);
/* Dump the offending IP header, if any */
switch(icmp.type){
case ICMP_DEST_UNREACH:
case ICMP_TIME_EXCEED:
case ICMP_PARAM_PROB:
case ICMP_QUENCH:
case ICMP_REDIRECT:
case ICMP_IPSP:
fprintf(fp,"Returned ");
ip_dump(fp,bpp,0);
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -