kernel-brax3-ubuntu-touch/drivers/misc/mediatek/apusys/mnoc/1.5/common/mnoc_drv.h
erascape f319b992b1 kernel-5.15: Initial import brax3 UT kernel
* halium configs enabled

Signed-off-by: erascape <erascape@proton.me>
2025-09-23 15:17:10 +00:00

75 lines
1.8 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2020 MediaTek Inc.
*/
#ifndef __APUSYS_MNOC_DRV_H__
#define __APUSYS_MNOC_DRV_H__
#include "mnoc_plat_internal.h"
#include "apusys_core.h"
/* struct for put mnoc relate information, such as qos, pmu, register, etc.
* then set and get with dev_set_drvdata/dev_get_drvdata
*/
struct apu_mnoc {
struct device *dev;
/* below is kboject for /sys/kernel/apumnoc */
struct kobject *root_dir;
struct engine_pm_qos_counter *engines;
};
#define APUSYS_MNOC_DEV_NAME "apusys_mnoc"
#define APUSYS_MNOC_LOG_PREFIX "[apusys][mnoc]"
#define LOG_ERR(x, args...) \
pr_info(APUSYS_MNOC_LOG_PREFIX "[error] %s " x, __func__, ##args)
#define LOG_WARN(x, args...) \
pr_info(APUSYS_MNOC_LOG_PREFIX "[warn] %s " x, __func__, ##args)
#define LOG_INFO(x, args...) \
pr_info(APUSYS_MNOC_LOG_PREFIX "[info] %s " x, __func__, ##args)
#define DEBUG_TAG LOG_DEBUG("\n")
#define LOG_DEBUG(x, args...) \
{ \
if (mnoc_log_level > 0) \
pr_info(APUSYS_MNOC_LOG_PREFIX "[debug] %s/%d "\
x, __func__, __LINE__, ##args); \
}
#define LOG_DETAIL(x, args...) \
{ \
if (mnoc_log_level > 1) \
pr_info(APUSYS_MNOC_LOG_PREFIX "[detail] %s/%d "\
x, __func__, __LINE__, ##args); \
}
#define INT_STA_PRINTF(m, x, args...)\
{ \
if (m != NULL) \
seq_printf(m, x, ##args); \
else \
pr_info(APUSYS_MNOC_LOG_PREFIX "[isr_work] %s/%d "\
x, __func__, __LINE__, ##args); \
}
extern void __iomem *mnoc_base;
extern void __iomem *mnoc_int_base;
extern void __iomem *mnoc_apu_conn_base;
extern void __iomem *mnoc_slp_prot_base1;
extern void __iomem *mnoc_slp_prot_base2;
extern spinlock_t mnoc_spinlock;
extern bool mnoc_reg_valid;
extern int mnoc_log_level;
extern struct mnoc_plat_drv mnoc_drv;
int mnoc_rv_setup(struct apusys_core_info *info);
void mnoc_rv_clear(void);
#endif