blob: 1d311d2296ec9b496f0a4093a3614cc67fc0c8ce [file] [log] [blame]
// Copyright 2016 The Fuchsia Authors
// Copyright (c) 2008-2013 Travis Geiselbrecht
//
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file or at
// https://opensource.org/licenses/MIT
#ifndef ZIRCON_KERNEL_INCLUDE_TRACE_H_
#define ZIRCON_KERNEL_INCLUDE_TRACE_H_
#include <stdio.h>
//#define __FUNC__ __PRETTY_FUNCTION__
#define __FUNC__ __func__
/* trace routines */
#define TRACE_ENTRY printf("%s: entry\n", __FUNC__)
#define TRACE_EXIT printf("%s: exit\n", __FUNC__)
#define TRACE_ENTRY_OBJ printf("%s: entry obj %p\n", __FUNC__, this)
#define TRACE_EXIT_OBJ printf("%s: exit obj %p\n", __FUNC__, this)
#define TRACE printf("%s:%d\n", __FUNC__, __LINE__)
#define TRACEF(str, x...) \
do { \
printf("%s:%d: " str, __FUNC__, __LINE__, ##x); \
} while (0)
/* trace routines that work if LOCAL_TRACE is set */
#define LTRACE_ENTRY \
do { \
if (LOCAL_TRACE) { \
TRACE_ENTRY; \
} \
} while (0)
#define LTRACE_EXIT \
do { \
if (LOCAL_TRACE) { \
TRACE_EXIT; \
} \
} while (0)
#define LTRACE_ENTRY_OBJ \
do { \
if (LOCAL_TRACE) { \
TRACE_ENTRY_OBJ; \
} \
} while (0)
#define LTRACE_EXIT_OBJ \
do { \
if (LOCAL_TRACE) { \
TRACE_EXIT_OBJ; \
} \
} while (0)
#define LTRACE \
do { \
if (LOCAL_TRACE) { \
TRACE; \
} \
} while (0)
#define LTRACEF(x...) \
do { \
if (LOCAL_TRACE) { \
TRACEF(x); \
} \
} while (0)
#define LTRACEF_LEVEL(level, x...) \
do { \
if (LOCAL_TRACE >= (level)) { \
TRACEF(x); \
} \
} while (0)
#endif // ZIRCON_KERNEL_INCLUDE_TRACE_H_