/* $Id: debug.h 93115 2022-01-01 11:31:46Z vboxsync $ */ /** @file * NAT - debug helpers (declarations/defines). */ /* * Copyright (C) 2006-2022 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ /* * This code is based on: * * Copyright (c) 1995 Danny Gasparovski. * * Please read the file COPYRIGHT for the * terms and conditions of the copyright. */ #ifndef _DEBUG_H_ #define _DEBUG_H_ #include /* we've excluded stdio.h */ #define FILE void int debug_init (PNATState); void ipstats (PNATState); void tcpstats (PNATState); void udpstats (PNATState); void icmpstats (PNATState); void mbufstats (PNATState); void sockstats (PNATState); #ifdef LOG_ENABLED # define TCP_STATE_SWITCH_TO(tp, new_tcp_state) \ do { \ Log2(("%R[tcpcb793] switch to %R[tcpstate] -> %R[tcpstate]\n", (tp), (tp->t_state) ,(new_tcp_state))); \ if ((tp)->t_socket) \ Log2(("%R[tcpcb793] %R[natsock]\n", (tp), (tp)->t_socket)); \ (tp)->t_state = (new_tcp_state); \ } while (0) #else # define TCP_STATE_SWITCH_TO(tp, new_tcp_state) (tp)->t_state = (new_tcp_state) #endif /* TCP CB state validity macro definitions * we need to be sure that TCP is in right state. * TCP_ACCEPTABLE_STATEX(tp, (X-states here)) */ #ifdef DEBUG_vvl # define TCP_ACCEPTABLE_STATE1(tp, tcp_state1) Assert((tp)->t_state == (tcp_state)) # define TCP_ACCEPTABLE_STATE2(tp, tcp_state1, tcp_state2) \ Assert( (tp)->t_state == (tcp_state1) \ || (tp)->t_state == (tcp_state2) ); \ #else # define TCP_ACCEPTABLE_STATE1(tp, tcp_state1) do { } while(0) # define TCP_ACCEPTABLE_STATE2(tp, tcp_state1, tcp_state2) do { } while(0) #endif #endif