mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 22:41:21 +02:00 
			
		
		
		
	Add support for capturing ethernet packets and storing them in memory in PCAP(2.4) format, later to be analyzed by any PCAP viewer software (IE. Wireshark) This feature greatly assist debugging network issues such as detecting dropped packets, packet corruption etc. Signed-off-by: Ramon Fried <rfried.dev@gmail.com> Reviewed-by: Alex Marginean <alexm.osslist@gmail.com> Tested-by: Alex Marginean <alexm.osslist@gmail.com> Acked-by: Joe Hershberger <joe.hershberger@ni.com>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * Copyright 2019
 | |
|  * Ramon Fried <rfried.dev@gmail.com>
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * pcap_init() - Initialize PCAP memory buffer
 | |
|  *
 | |
|  * @paddr	physicaly memory address to store buffer
 | |
|  * @size	maximum size of capture file in memory
 | |
|  *
 | |
|  * @return	0 on success, -ERROR on error
 | |
|  */
 | |
| int pcap_init(phys_addr_t paddr, unsigned long size);
 | |
| 
 | |
| /**
 | |
|  * pcap_start_stop() - start / stop pcap capture
 | |
|  *
 | |
|  * @start	if true, start capture if false stop capture
 | |
|  *
 | |
|  * @return	0 on success, -ERROR on error
 | |
|  */
 | |
| int pcap_start_stop(bool start);
 | |
| 
 | |
| /**
 | |
|  * pcap_clear() - clear pcap capture buffer and statistics
 | |
|  *
 | |
|  * @return	0 on success, -ERROR on error
 | |
|  */
 | |
| int pcap_clear(void);
 | |
| 
 | |
| /**
 | |
|  * pcap_print_status() - print status of pcap capture
 | |
|  *
 | |
|  * @return	0 on success, -ERROR on error
 | |
|  */
 | |
| int pcap_print_status(void);
 | |
| 
 | |
| /**
 | |
|  * pcap_active() - check if pcap is enabled
 | |
|  *
 | |
|  * @return	TRUE if active, FALSE if not.
 | |
|  */
 | |
| bool pcap_active(void);
 | |
| 
 | |
| /**
 | |
|  * pcap_post() - Post a packet to PCAP file
 | |
|  *
 | |
|  * @packet:	packet to post
 | |
|  * @len:	packet length in bytes
 | |
|  * @outgoing	packet direction (outgoing/incoming)
 | |
|  * @return	0 on success, -ERROR on error
 | |
|  */
 | |
| int pcap_post(const void *packet, size_t len, bool outgoing);
 |