mirror of
				https://git.proxmox.com/git/mirror_frr
				synced 2025-10-31 23:16:07 +00:00 
			
		
		
		
	 50872b0804
			
		
	
	
		50872b0804
		
	
	
	
	
		
			
			Add a detailed debugging command for NHT tracking and add the detailed output to the log about why we make some decisions that we are. I tried to model this like the rib processing detailed debugs that we added a few months back. Signed-off-by: Donald Sharp <sharpd@cumulusnetworks.com>
		
			
				
	
	
		
			116 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Zebra debug related function
 | |
|  * Copyright (C) 1999 Kunihiro Ishiguro
 | |
|  *
 | |
|  * This file is part of GNU Zebra.
 | |
|  *
 | |
|  * GNU Zebra is free software; you can redistribute it and/or modify it
 | |
|  * under the terms of the GNU General Public License as published by the
 | |
|  * Free Software Foundation; either version 2, or (at your option) any
 | |
|  * later version.
 | |
|  *
 | |
|  * GNU Zebra is distributed in the hope that it will be useful, but
 | |
|  * WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License along
 | |
|  * with this program; see the file COPYING; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 | |
|  */
 | |
| 
 | |
| #ifndef _ZEBRA_DEBUG_H
 | |
| #define _ZEBRA_DEBUG_H
 | |
| 
 | |
| #include "lib/vty.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /* Debug flags. */
 | |
| #define ZEBRA_DEBUG_EVENT   0x01
 | |
| 
 | |
| #define ZEBRA_DEBUG_PACKET  0x01
 | |
| #define ZEBRA_DEBUG_SEND    0x20
 | |
| #define ZEBRA_DEBUG_RECV    0x40
 | |
| #define ZEBRA_DEBUG_DETAIL  0x80
 | |
| 
 | |
| #define ZEBRA_DEBUG_KERNEL  0x01
 | |
| #define ZEBRA_DEBUG_KERNEL_MSGDUMP_SEND 0x20
 | |
| #define ZEBRA_DEBUG_KERNEL_MSGDUMP_RECV 0x40
 | |
| 
 | |
| #define ZEBRA_DEBUG_RIB     0x01
 | |
| #define ZEBRA_DEBUG_RIB_DETAILED   0x02
 | |
| 
 | |
| #define ZEBRA_DEBUG_FPM     0x01
 | |
| 
 | |
| #define ZEBRA_DEBUG_NHT 0x01
 | |
| #define ZEBRA_DEBUG_NHT_DETAILED 0x02
 | |
| 
 | |
| #define ZEBRA_DEBUG_MPLS    0x01
 | |
| 
 | |
| #define ZEBRA_DEBUG_VXLAN   0x01
 | |
| 
 | |
| #define ZEBRA_DEBUG_PW      0x01
 | |
| 
 | |
| #define ZEBRA_DEBUG_DPLANE           0x01
 | |
| #define ZEBRA_DEBUG_DPLANE_DETAILED  0x02
 | |
| 
 | |
| #define ZEBRA_DEBUG_MLAG    0x01
 | |
| 
 | |
| /* Debug related macro. */
 | |
| #define IS_ZEBRA_DEBUG_EVENT  (zebra_debug_event & ZEBRA_DEBUG_EVENT)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_PACKET (zebra_debug_packet & ZEBRA_DEBUG_PACKET)
 | |
| #define IS_ZEBRA_DEBUG_SEND   (zebra_debug_packet & ZEBRA_DEBUG_SEND)
 | |
| #define IS_ZEBRA_DEBUG_RECV   (zebra_debug_packet & ZEBRA_DEBUG_RECV)
 | |
| #define IS_ZEBRA_DEBUG_DETAIL (zebra_debug_packet & ZEBRA_DEBUG_DETAIL)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_KERNEL (zebra_debug_kernel & ZEBRA_DEBUG_KERNEL)
 | |
| #define IS_ZEBRA_DEBUG_KERNEL_MSGDUMP_SEND                                     \
 | |
| 	(zebra_debug_kernel & ZEBRA_DEBUG_KERNEL_MSGDUMP_SEND)
 | |
| #define IS_ZEBRA_DEBUG_KERNEL_MSGDUMP_RECV                                     \
 | |
| 	(zebra_debug_kernel & ZEBRA_DEBUG_KERNEL_MSGDUMP_RECV)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_RIB                                                     \
 | |
| 	(zebra_debug_rib & (ZEBRA_DEBUG_RIB | ZEBRA_DEBUG_RIB_DETAILED))
 | |
| #define IS_ZEBRA_DEBUG_RIB_DETAILED  (zebra_debug_rib & ZEBRA_DEBUG_RIB_DETAILED)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_FPM (zebra_debug_fpm & ZEBRA_DEBUG_FPM)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_NHT  (zebra_debug_nht & ZEBRA_DEBUG_NHT)
 | |
| #define IS_ZEBRA_DEBUG_NHT_DETAILED (zebra_debug_nht & ZEBRA_DEBUG_NHT_DETAILED)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_MPLS  (zebra_debug_mpls & ZEBRA_DEBUG_MPLS)
 | |
| #define IS_ZEBRA_DEBUG_VXLAN (zebra_debug_vxlan & ZEBRA_DEBUG_VXLAN)
 | |
| #define IS_ZEBRA_DEBUG_PW  (zebra_debug_pw & ZEBRA_DEBUG_PW)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_DPLANE (zebra_debug_dplane & ZEBRA_DEBUG_DPLANE)
 | |
| #define IS_ZEBRA_DEBUG_DPLANE_DETAIL \
 | |
| 	(zebra_debug_dplane & ZEBRA_DEBUG_DPLANE_DETAILED)
 | |
| 
 | |
| #define IS_ZEBRA_DEBUG_MLAG (zebra_debug_mlag & ZEBRA_DEBUG_MLAG)
 | |
| 
 | |
| extern unsigned long zebra_debug_event;
 | |
| extern unsigned long zebra_debug_packet;
 | |
| extern unsigned long zebra_debug_kernel;
 | |
| extern unsigned long zebra_debug_rib;
 | |
| extern unsigned long zebra_debug_fpm;
 | |
| extern unsigned long zebra_debug_nht;
 | |
| extern unsigned long zebra_debug_mpls;
 | |
| extern unsigned long zebra_debug_vxlan;
 | |
| extern unsigned long zebra_debug_pw;
 | |
| extern unsigned long zebra_debug_dplane;
 | |
| extern unsigned long zebra_debug_mlag;
 | |
| 
 | |
| extern void zebra_debug_init(void);
 | |
| 
 | |
| DECLARE_HOOK(zebra_debug_show_debugging, (struct vty *vty), (vty));
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* _ZEBRA_DEBUG_H */
 |