1*d6b92ffaSHans Petter Selasky /* 2*d6b92ffaSHans Petter Selasky * Copyright (c) 2004-2006 Voltaire, Inc. All rights reserved. 3*d6b92ffaSHans Petter Selasky * Copyright (c) 2002-2005 Mellanox Technologies LTD. All rights reserved. 4*d6b92ffaSHans Petter Selasky * Copyright (c) 1996-2003 Intel Corporation. All rights reserved. 5*d6b92ffaSHans Petter Selasky * 6*d6b92ffaSHans Petter Selasky * This software is available to you under a choice of one of two 7*d6b92ffaSHans Petter Selasky * licenses. You may choose to be licensed under the terms of the GNU 8*d6b92ffaSHans Petter Selasky * General Public License (GPL) Version 2, available from the file 9*d6b92ffaSHans Petter Selasky * COPYING in the main directory of this source tree, or the 10*d6b92ffaSHans Petter Selasky * OpenIB.org BSD license below: 11*d6b92ffaSHans Petter Selasky * 12*d6b92ffaSHans Petter Selasky * Redistribution and use in source and binary forms, with or 13*d6b92ffaSHans Petter Selasky * without modification, are permitted provided that the following 14*d6b92ffaSHans Petter Selasky * conditions are met: 15*d6b92ffaSHans Petter Selasky * 16*d6b92ffaSHans Petter Selasky * - Redistributions of source code must retain the above 17*d6b92ffaSHans Petter Selasky * copyright notice, this list of conditions and the following 18*d6b92ffaSHans Petter Selasky * disclaimer. 19*d6b92ffaSHans Petter Selasky * 20*d6b92ffaSHans Petter Selasky * - Redistributions in binary form must reproduce the above 21*d6b92ffaSHans Petter Selasky * copyright notice, this list of conditions and the following 22*d6b92ffaSHans Petter Selasky * disclaimer in the documentation and/or other materials 23*d6b92ffaSHans Petter Selasky * provided with the distribution. 24*d6b92ffaSHans Petter Selasky * 25*d6b92ffaSHans Petter Selasky * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 26*d6b92ffaSHans Petter Selasky * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 27*d6b92ffaSHans Petter Selasky * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 28*d6b92ffaSHans Petter Selasky * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 29*d6b92ffaSHans Petter Selasky * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 30*d6b92ffaSHans Petter Selasky * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 31*d6b92ffaSHans Petter Selasky * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 32*d6b92ffaSHans Petter Selasky * SOFTWARE. 33*d6b92ffaSHans Petter Selasky * 34*d6b92ffaSHans Petter Selasky */ 35*d6b92ffaSHans Petter Selasky 36*d6b92ffaSHans Petter Selasky /* 37*d6b92ffaSHans Petter Selasky * Abstract: 38*d6b92ffaSHans Petter Selasky * Debug Macros. 39*d6b92ffaSHans Petter Selasky */ 40*d6b92ffaSHans Petter Selasky 41*d6b92ffaSHans Petter Selasky #ifndef _CL_DEBUG_OSD_H_ 42*d6b92ffaSHans Petter Selasky #define _CL_DEBUG_OSD_H_ 43*d6b92ffaSHans Petter Selasky 44*d6b92ffaSHans Petter Selasky #include <complib/cl_types.h> 45*d6b92ffaSHans Petter Selasky 46*d6b92ffaSHans Petter Selasky #ifdef __cplusplus 47*d6b92ffaSHans Petter Selasky # define BEGIN_C_DECLS extern "C" { 48*d6b92ffaSHans Petter Selasky # define END_C_DECLS } 49*d6b92ffaSHans Petter Selasky #else /* !__cplusplus */ 50*d6b92ffaSHans Petter Selasky # define BEGIN_C_DECLS 51*d6b92ffaSHans Petter Selasky # define END_C_DECLS 52*d6b92ffaSHans Petter Selasky #endif /* __cplusplus */ 53*d6b92ffaSHans Petter Selasky 54*d6b92ffaSHans Petter Selasky BEGIN_C_DECLS 55*d6b92ffaSHans Petter Selasky #if !defined(__MODULE__) 56*d6b92ffaSHans Petter Selasky #define __MODULE__ "" 57*d6b92ffaSHans Petter Selasky #define __MOD_DELIMITER__ "" 58*d6b92ffaSHans Petter Selasky #else /* !defined(__MODULE__) */ 59*d6b92ffaSHans Petter Selasky #define __MOD_DELIMITER__ ":" 60*d6b92ffaSHans Petter Selasky #endif /* !defined(__MODULE__) */ 61*d6b92ffaSHans Petter Selasky /* 62*d6b92ffaSHans Petter Selasky * Define specifiers for print functions based on the platform 63*d6b92ffaSHans Petter Selasky */ 64*d6b92ffaSHans Petter Selasky #ifdef __IA64__ 65*d6b92ffaSHans Petter Selasky #define PRIdSIZE_T "ld" 66*d6b92ffaSHans Petter Selasky #else 67*d6b92ffaSHans Petter Selasky #define PRIdSIZE_T "d" 68*d6b92ffaSHans Petter Selasky #endif 69*d6b92ffaSHans Petter Selasky #include <inttypes.h> 70*d6b92ffaSHans Petter Selasky #include <stdio.h> 71*d6b92ffaSHans Petter Selasky #define cl_msg_out printf 72*d6b92ffaSHans Petter Selasky #if defined( _DEBUG_ ) 73*d6b92ffaSHans Petter Selasky #define cl_dbg_out printf 74*d6b92ffaSHans Petter Selasky #else 75*d6b92ffaSHans Petter Selasky #define cl_dbg_out foo 76*d6b92ffaSHans Petter Selasky #endif /* _DEBUG_ */ 77*d6b92ffaSHans Petter Selasky /* 78*d6b92ffaSHans Petter Selasky * The following macros are used internally by the CL_ENTER, CL_TRACE, 79*d6b92ffaSHans Petter Selasky * CL_TRACE_EXIT, and CL_EXIT macros. 80*d6b92ffaSHans Petter Selasky */ 81*d6b92ffaSHans Petter Selasky #define _CL_DBG_ENTER \ 82*d6b92ffaSHans Petter Selasky ("%s%s%s() [\n", __MODULE__, __MOD_DELIMITER__, __func__) 83*d6b92ffaSHans Petter Selasky #define _CL_DBG_EXIT \ 84*d6b92ffaSHans Petter Selasky ("%s%s%s() ]\n", __MODULE__, __MOD_DELIMITER__, __func__) 85*d6b92ffaSHans Petter Selasky #define _CL_DBG_INFO \ 86*d6b92ffaSHans Petter Selasky ("%s%s%s(): ", __MODULE__, __MOD_DELIMITER__, __func__) 87*d6b92ffaSHans Petter Selasky #define _CL_DBG_ERROR \ 88*d6b92ffaSHans Petter Selasky ("%s%s%s() !ERROR!: ", __MODULE__, __MOD_DELIMITER__, __func__) 89*d6b92ffaSHans Petter Selasky #define CL_CHK_STK 90*d6b92ffaSHans Petter Selasky END_C_DECLS 91*d6b92ffaSHans Petter Selasky #endif /* _CL_DEBUG_OSD_H_ */ 92