diff options
| -rw-r--r-- | netsniff-ng.c | 17 | 
1 files changed, 9 insertions, 8 deletions
| diff --git a/netsniff-ng.c b/netsniff-ng.c index f22137d..b9077a3 100644 --- a/netsniff-ng.c +++ b/netsniff-ng.c @@ -170,7 +170,7 @@ static inline bool dump_to_pcap(struct ctx *ctx)  static void pcap_to_xmit(struct ctx *ctx)  {  	uint8_t *out = NULL; -	int irq, ifindex, fd = 0, ret; +	int ifindex, fd = 0, ret;  	size_t size;  	unsigned int it = 0;  	unsigned long trunced = 0; @@ -240,7 +240,7 @@ static void pcap_to_xmit(struct ctx *ctx)  	dissector_init_all(ctx->print_mode);  	if (ctx->cpu >= 0 && ifindex > 0) { -		irq = device_irq_number(ctx->device_out); +		int irq = device_irq_number(ctx->device_out);  		device_set_irq_affinity(irq, ctx->cpu);  		if (ctx->verbose) @@ -815,17 +815,16 @@ static void print_pcap_file_stats(int sock, struct ctx *ctx)  static void walk_t3_block(struct block_desc *pbd, struct ctx *ctx,  			  int sock, int *fd, unsigned long *frame_count)  { -	uint8_t *packet; -	int num_pkts = pbd->h1.num_pkts, i, ret; +	int num_pkts = pbd->h1.num_pkts, i;  	struct tpacket3_hdr *hdr; -	pcap_pkthdr_t phdr;  	struct sockaddr_ll *sll;  	hdr = (void *) ((uint8_t *) pbd + pbd->h1.offset_to_first_pkt);  	sll = (void *) ((uint8_t *) hdr + TPACKET_ALIGN(sizeof(*hdr)));  	for (i = 0; i < num_pkts && likely(sigint == 0); ++i) { -		packet = ((uint8_t *) hdr + hdr->tp_mac); +		uint8_t *packet = ((uint8_t *) hdr + hdr->tp_mac); +		pcap_pkthdr_t phdr;  		if (ctx->packet_type != -1)  			if (ctx->packet_type != sll->sll_pkttype) @@ -834,6 +833,8 @@ static void walk_t3_block(struct block_desc *pbd, struct ctx *ctx,  		(*frame_count)++;  		if (dump_to_pcap(ctx)) { +			int ret; +  			tpacket3_hdr_to_pcap_pkthdr(hdr, sll, &phdr, ctx->magic);  			ret = __pcap_io->write_pcap(*fd, &phdr, ctx->magic, packet, @@ -880,7 +881,7 @@ next:  static void recv_only_or_dump(struct ctx *ctx)  {  	short ifflags = 0; -	int sock, irq, ifindex, fd = 0, ret; +	int sock, ifindex, fd = 0, ret;  	size_t size;  	unsigned int it = 0;  	struct ring rx_ring; @@ -928,7 +929,7 @@ static void recv_only_or_dump(struct ctx *ctx)  	dissector_init_all(ctx->print_mode);  	if (ctx->cpu >= 0 && ifindex > 0) { -		irq = device_irq_number(ctx->device_in); +		int irq = device_irq_number(ctx->device_in);  		device_set_irq_affinity(irq, ctx->cpu);  		if (ctx->verbose) | 
