diff options
author | Sean Anderson <seanga2@gmail.com> | 2023-10-07 21:53:12 -0400 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2023-11-05 16:11:38 -0500 |
commit | 798962cedd7e30f95e9a3a6126276b77086a6d08 (patch) | |
tree | aa09907d4d2f1308a7796a91ed1f9d996ce37faa /include/net.h | |
parent | a56e30e65f2549fd8dff32ecfe24992178414f09 (diff) | |
download | u-boot-798962cedd7e30f95e9a3a6126276b77086a6d08.tar.gz u-boot-798962cedd7e30f95e9a3a6126276b77086a6d08.tar.bz2 u-boot-798962cedd7e30f95e9a3a6126276b77086a6d08.zip |
net: Add option for tracing packets
Add an option to trace all packets send/received. This can be helpful when
debugging protocol issues, as the packets can then be imported into
wireshark [1] and analyzed further.
[1] https://www.wireshark.org/docs/wsug_html_chunked/ChIOImportSection.html
Signed-off-by: Sean Anderson <seanga2@gmail.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
Diffstat (limited to 'include/net.h')
-rw-r--r-- | include/net.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/include/net.h b/include/net.h index e254df7d7f..e63a946002 100644 --- a/include/net.h +++ b/include/net.h @@ -16,6 +16,7 @@ #include <asm/cache.h> #include <asm/byteorder.h> /* for nton* / ntoh* stuff */ #include <env.h> +#include <hexdump.h> #include <log.h> #include <time.h> #include <linux/if_ether.h> @@ -29,6 +30,7 @@ struct udevice; #define DEBUG_DEV_PKT 0 /* Packets or info directed to the device */ #define DEBUG_NET_PKT 0 /* Packets on info on the network at large */ #define DEBUG_INT_STATE 0 /* Internal network state changes */ +#define DEBUG_NET_PKT_TRACE 0 /* Trace all packet data */ /* * The number of receive packet buffers, and the required packet buffer @@ -640,6 +642,8 @@ uchar * net_get_async_tx_pkt_buf(void); /* Transmit a packet */ static inline void net_send_packet(uchar *pkt, int len) { + if (DEBUG_NET_PKT_TRACE) + print_hex_dump_bytes("tx: ", DUMP_PREFIX_OFFSET, pkt, len); /* Currently no way to return errors from eth_send() */ (void) eth_send(pkt, len); } |