xref: /dpdk/drivers/net/sfc/sfc_debug.h (revision 5e48db8c53cf2b6de1c944c392f33bc60e414c17)
144c0947bSAndrew Rybchenko /* SPDX-License-Identifier: BSD-3-Clause
2244cfa79SAndrew Rybchenko  *
344c0947bSAndrew Rybchenko  * Copyright (c) 2016-2018 Solarflare Communications Inc.
463d588ffSAndrew Rybchenko  * All rights reserved.
563d588ffSAndrew Rybchenko  *
663d588ffSAndrew Rybchenko  * This software was jointly developed between OKTET Labs (under contract
763d588ffSAndrew Rybchenko  * for Solarflare) and Solarflare Communications, Inc.
863d588ffSAndrew Rybchenko  */
963d588ffSAndrew Rybchenko 
1063d588ffSAndrew Rybchenko #ifndef _SFC_DEBUG_H_
1163d588ffSAndrew Rybchenko #define _SFC_DEBUG_H_
1263d588ffSAndrew Rybchenko 
1363d588ffSAndrew Rybchenko #include <rte_debug.h>
1463d588ffSAndrew Rybchenko 
1563d588ffSAndrew Rybchenko #ifdef RTE_LIBRTE_SFC_EFX_DEBUG
1643e9f17cSPavan Nikhilesh /* Avoid dependency from RTE_LOG_DP_LEVEL to be able to enable debug check
1763d588ffSAndrew Rybchenko  * in the driver only.
1863d588ffSAndrew Rybchenko  */
1963d588ffSAndrew Rybchenko #define SFC_ASSERT(exp)			RTE_VERIFY(exp)
2063d588ffSAndrew Rybchenko #else
2163d588ffSAndrew Rybchenko /* If the driver debug is not enabled, follow DPDK debug/non-debug */
2263d588ffSAndrew Rybchenko #define SFC_ASSERT(exp)			RTE_ASSERT(exp)
2363d588ffSAndrew Rybchenko #endif
2463d588ffSAndrew Rybchenko 
25ba641f20SAndrew Rybchenko /* Log PMD message, automatically add prefix and \n */
26ba641f20SAndrew Rybchenko #define sfc_panic(sa, fmt, args...) \
27ba641f20SAndrew Rybchenko 	do {								\
28b7be9f43SAndrew Rybchenko 		const struct sfc_adapter *_sa = (sa);			\
29ba641f20SAndrew Rybchenko 									\
30*5e48db8cSIvan Malov 		rte_panic("sfc " PCI_PRI_FMT				\
31*5e48db8cSIvan Malov 			  " #%" PRIu16 ": " fmt "\n",			\
32b7be9f43SAndrew Rybchenko 			  _sa->pci_addr.domain, _sa->pci_addr.bus,	\
33b7be9f43SAndrew Rybchenko 			  _sa->pci_addr.devid, _sa->pci_addr.function,	\
34b7be9f43SAndrew Rybchenko 			  _sa->port_id, ##args);			\
35ba641f20SAndrew Rybchenko 	} while (0)
36ba641f20SAndrew Rybchenko 
3763d588ffSAndrew Rybchenko #endif /* _SFC_DEBUG_H_ */
38