mirror of
git://nv-tegra.nvidia.com/linux-hwpm.git
synced 2025-12-23 09:46:59 +03:00
Add a driver for programming the Tegra SOC HWPM path. SOC HWPM allows performance monitoring of various Tegra IPs. The profiling tests cases are configured through IOCTLs sent by a userspace profiling app. The IOCTLs provide the following features: - IP discovery and reservation - Buffer management - Whitelist query - Register read/write ops Bug 200702306 Bug 3305495 Change-Id: I65003b126e01bd03d856767c55aa2424bcfd11fb Signed-off-by: Adeel Raza <araza@nvidia.com> Reviewed-on: https://git-master.nvidia.com/r/c/linux-t23x/+/2515148 Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com> GVS: Gerrit_Virtual_Submit Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
40 lines
1.3 KiB
C
40 lines
1.3 KiB
C
/*
|
|
* tegra-soc-hwpm-log.h:
|
|
* This is the logging API header for the Tegra SOC HWPM driver.
|
|
*
|
|
* Copyright (c) 2021, 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 TEGRA_SOC_HWPM_LOG_H
|
|
#define TEGRA_SOC_HWPM_LOG_H
|
|
|
|
#define TEGRA_SOC_HWPM_MODULE_NAME "tegra-soc-hwpm"
|
|
|
|
enum tegra_soc_hwpm_log_type {
|
|
tegra_soc_hwpm_log_err, /* Error prints */
|
|
tegra_soc_hwpm_log_dbg, /* Debug prints */
|
|
};
|
|
|
|
#define tegra_soc_hwpm_err(fmt, arg...) \
|
|
tegra_soc_hwpm_log(__func__, __LINE__, tegra_soc_hwpm_log_err, \
|
|
fmt, ##arg)
|
|
#define tegra_soc_hwpm_dbg(fmt, arg...) \
|
|
tegra_soc_hwpm_log(__func__, __LINE__, tegra_soc_hwpm_log_dbg, \
|
|
fmt, ##arg)
|
|
|
|
void tegra_soc_hwpm_log(const char *func, int line, int type, const char *fmt, ...);
|
|
|
|
#endif /* TEGRA_SOC_HWPM_LOG_H */
|