⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bpf_dump.c

📁 网卡驱动相关实例 这是和网卡NT KMD驱动程序有关的一些资料和例子。主要是以下三方面内容: 3.1 article 一些有用的文档 3.2 Canberra 网络诊听工具Ethern
💻 C
字号:
/* * Copyright (c) 1992, 1993, 1994, 1995, 1996 *	The Regents of the University of California.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that: (1) source code distributions * retain the above copyright notice and this paragraph in its entirety, (2) * distributions including binary code include the above copyright notice and * this paragraph in its entirety in the documentation or other materials * provided with the distribution, and (3) all advertising materials mentioning * features or use of this software display the following acknowledgement: * ``This product includes software developed by the University of California, * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of * the University nor the names of its contributors may be used to endorse * or promote products derived from this software without specific prior * written permission. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */#ifndef lintstatic const char rcsid[] =    "@(#) $Header: bpf_dump.c,v 1.9 96/09/26 23:11:04 leres Exp $ (LBL)";#endif#include <sys/types.h>
#ifndef WIN32
#include <sys/time.h>
#else
#include <sys/timeb.h>
#include <time.h>
#endif
#include <pcap.h>#include <stdio.h>
#include "interface.h"extern void bpf_dump(struct bpf_program *, int);voidbpf_dump(struct bpf_program *p, int option){	struct bpf_insn *insn;	int i;	int n = p->bf_len;	insn = p->bf_insns;	if (option > 2) {		printf("%d\n", n);		for (i = 0; i < n; ++insn, ++i) {			printf("%u %u %u %u\n", insn->code,			       insn->jt, insn->jf, insn->k);		}		return ;	}	if (option > 1) {		for (i = 0; i < n; ++insn, ++i)			printf("{ 0x%x, %d, %d, 0x%08x },\n",			       insn->code, insn->jt, insn->jf, insn->k);		return;	}	for (i = 0; i < n; ++insn, ++i) {#ifdef BDEBUG		extern int bids[];		printf(bids[i] > 0 ? "[%02d]" : " -- ", bids[i] - 1);#endif		puts(bpf_image(insn, i));	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -