summaryrefslogblamecommitdiffstats
path: root/drivers/gpu/nvgpu/include/nvgpu/log.h
blob: 45a6ec11047e7d43f2b87f3850479b00933c4992 (plain) (tree)


















                                                                            


                         




                     

              






























































































                                                                                









                                                                         
                                                                
 

















































                                                                                
/*
 * Copyright (c) 2017, NVIDIA CORPORATION.  All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope 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.  If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef __NVGPU_DEBUGGING_H__
#define __NVGPU_DEBUGGING_H__

#include <nvgpu/types.h>
#include <nvgpu/bitops.h>

struct gk20a;

enum nvgpu_log_type {
	ERROR,
	WARNING,
	DEBUG,
	INFO,
};

/*
 * Each OS must implement these functions. They handle the OS specific nuances
 * of printing data to a UART, log, whatever.
 */
__attribute__((format (printf, 5, 6)))
void __nvgpu_log_msg(struct gk20a *g, const char *func_name, int line,
		     enum nvgpu_log_type type, const char *fmt, ...);

__attribute__((format (printf, 5, 6)))
void __nvgpu_log_dbg(struct gk20a *g, u32 log_mask,
		     const char *func_name, int line,
		     const char *fmt, ...);

/*
 * Use this define to set a default mask.
 */
#define NVGPU_DEFAULT_DBG_MASK		(0)

enum nvgpu_log_categories {
	gpu_dbg_info       = BIT(0),	/* Lightly verbose info. */
	gpu_dbg_fn         = BIT(1),	/* Function name tracing. */
	gpu_dbg_reg        = BIT(2),	/* Register accesses; very verbose. */
	gpu_dbg_pte        = BIT(3),	/* GMMU PTEs. */
	gpu_dbg_intr       = BIT(4),	/* Interrupts. */
	gpu_dbg_pmu        = BIT(5),	/* gk20a pmu. */
	gpu_dbg_clk        = BIT(6),	/* gk20a clk. */
	gpu_dbg_map        = BIT(7),	/* Memory mappings. */
	gpu_dbg_map_v      = BIT(8),	/* Verbose mem mappings. */
	gpu_dbg_gpu_dbg    = BIT(9),	/* GPU debugger/profiler. */
	gpu_dbg_cde        = BIT(10),	/* cde info messages. */
	gpu_dbg_cde_ctx    = BIT(11),	/* cde context usage messages. */
	gpu_dbg_ctxsw      = BIT(12),	/* ctxsw tracing. */
	gpu_dbg_sched      = BIT(13),	/* Sched control tracing. */
	gpu_dbg_sema       = BIT(14),	/* Semaphore debugging. */
	gpu_dbg_sema_v     = BIT(15),	/* Verbose semaphore debugging. */
	gpu_dbg_pmu_pstate = BIT(16),	/* p state controlled by pmu. */
	gpu_dbg_xv         = BIT(17),	/* XVE debugging. */
	gpu_dbg_shutdown   = BIT(18),	/* GPU shutdown tracing. */
	gpu_dbg_kmem       = BIT(19),	/* Kmem tracking debugging. */
	gpu_dbg_mem        = BIT(31),	/* memory accesses; very verbose. */
};

/**
 * nvgpu_log_mask_enabled - Check if logging is enabled
 *
 * @g        - The GPU.
 * @log_mask - The mask the check against.
 *
 * Check if, given the passed mask, logging would actually happen. This is
 * useful for avoiding calling the logging function many times when we know that
 * said prints would not happen. For example for-loops of log statements in
 * critical paths.
 */
int nvgpu_log_mask_enabled(struct gk20a *g, u32 log_mask);

/**
 * nvgpu_log - Print a debug message
 *
 * @g        - The GPU.
 * @log_mask - A mask defining when the print should happen. See enum
 *             %nvgpu_log_categories.
 * @fmt      - A format string (printf style).
 * @arg...   - Arguments for the format string.
 *
 * Print a message if the log_mask matches the enabled debugging.
 */
#define nvgpu_log(g, log_mask, fmt, arg...)				\
	__nvgpu_log_dbg(g, log_mask, __func__, __LINE__, fmt, ##arg);	\

/**
 * nvgpu_err - Print an error
 *
 * @g        - The GPU.
 * @fmt      - A format string (printf style).
 * @arg...   - Arguments for the format string.
 *
 * Uncondtionally print an error message.
 */
#define nvgpu_err(g, fmt, arg...)					\
	__nvgpu_log_msg(g, __func__, __LINE__, ERROR, fmt, ##arg)

/**
 * nvgpu_err - Print a warning
 *
 * @g        - The GPU.
 * @fmt      - A format string (printf style).
 * @arg...   - Arguments for the format string.
 *
 * Uncondtionally print a warming message.
 */
#define nvgpu_warn(g, fmt, arg...)					\
	__nvgpu_log_msg(g, __func__, __LINE__, WARNING, fmt, ##arg)

/**
 * nvgpu_info - Print an info message
 *
 * @g        - The GPU.
 * @fmt      - A format string (printf style).
 * @arg...   - Arguments for the format string.
 *
 * Unconditionally print an information message.
 */
#define nvgpu_info(g, fmt, arg...)					\
	__nvgpu_log_msg(g, __func__, __LINE__, INFO, fmt, ##arg)

/*
 * Some convenience macros.
 */
#define nvgpu_log_fn(g, fmt, arg...)	nvgpu_log(g, gpu_dbg_fn, fmt, ##arg)
#define nvgpu_log_info(g, fmt, arg...)	nvgpu_log(g, gpu_dbg_info, fmt, ##arg)

/******************************************************************************
 * The old legacy debugging API minus some parts that are unnecessary.        *
 * Please, please, please do not use this!!! This is still around to aid      *
 * transitioning to the new API.                                              *
 *                                                                            *
 * This changes up the print formats to be closer to the new APIs formats.    *
 * Also it removes the dev_warn() and dev_err() usage. Those arguments are    *
 * ignored now.                                                               *
 ******************************************************************************/

/*
 * This exist for backwards compatibility with the old debug/logging API. If you
 * want ftrace support use the new API!
 */
extern u32 nvgpu_dbg_mask;

#define gk20a_dbg(log_mask, fmt, arg...)				\
	do {								\
		if (((log_mask) & nvgpu_dbg_mask) != 0)			\
			__nvgpu_log_msg(NULL, __func__, __LINE__,	\
					DEBUG, fmt "\n", ##arg);	\
	} while (0)

#define gk20a_err(d, fmt, arg...)					\
	do {								\
		__nvgpu_log_msg(NULL, __func__, __LINE__, ERROR,	\
				fmt "\n", ##arg);			\
		(void)(d);						\
	} while (0)

#define gk20a_warn(d, fmt, arg...)					\
	do {								\
		__nvgpu_log_msg(NULL, __func__, __LINE__, WARNING,	\
				fmt "\n", ##arg);			\
		(void)(d);						\
	} while (0)

/*
 * Some convenience macros.
 */
#define gk20a_dbg_fn(fmt, arg...)	gk20a_dbg(gpu_dbg_fn, fmt, ##arg)
#define gk20a_dbg_info(fmt, arg...)	gk20a_dbg(gpu_dbg_info, fmt, ##arg)

#endif