72 lines
2.6 KiB
C
72 lines
2.6 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/*
|
||
|
* Copyright (c) 2019 MediaTek Inc.
|
||
|
*/
|
||
|
|
||
|
#ifndef __GED_GLOBAL_H__
|
||
|
#define __GED_GLOBAL_H__
|
||
|
|
||
|
#include "ged_dvfs.h"
|
||
|
|
||
|
extern GED_LOG_BUF_HANDLE ghLogBuf_DVFS;
|
||
|
extern void (*mtk_boost_gpu_freq_fp)(void);
|
||
|
extern void (*mtk_set_bottom_gpu_freq_fp)(unsigned int idx);
|
||
|
extern unsigned int (*mtk_get_bottom_gpu_freq_fp)(void);
|
||
|
extern unsigned int (*mtk_custom_get_gpu_freq_level_count_fp)(void);
|
||
|
extern void (*mtk_custom_boost_gpu_freq_fp)(unsigned int ui32FreqLevel);
|
||
|
extern void (*mtk_custom_upbound_gpu_freq_fp)(unsigned int ui32FreqLevel);
|
||
|
extern unsigned int (*mtk_get_custom_boost_gpu_freq_fp)(void);
|
||
|
extern unsigned int (*mtk_get_custom_upbound_gpu_freq_fp)(void);
|
||
|
extern unsigned int (*mtk_get_gpu_loading_fp)(void);
|
||
|
extern unsigned int (*mtk_get_gpu_loading2_fp)(int load);
|
||
|
extern unsigned int (*mtk_get_gpu_block_fp)(void);
|
||
|
extern unsigned int (*mtk_get_gpu_idle_fp)(void);
|
||
|
extern void (*mtk_do_gpu_dvfs_fp)(unsigned long t, long phase,
|
||
|
unsigned long ul3DFenceDoneTime);
|
||
|
extern void (*mtk_gpu_dvfs_set_mode_fp)(int eMode);
|
||
|
|
||
|
extern unsigned int (*mtk_get_gpu_sub_loading_fp)(void);
|
||
|
extern unsigned long (*mtk_get_vsync_based_target_freq_fp)(void);
|
||
|
extern void (*mtk_get_gpu_dvfs_from_fp)(enum MTK_GPU_DVFS_TYPE *peType,
|
||
|
unsigned long *pulFreq);
|
||
|
|
||
|
extern unsigned long (*mtk_get_gpu_bottom_freq_fp)(void);
|
||
|
extern unsigned long (*mtk_get_gpu_custom_boost_freq_fp)(void);
|
||
|
extern unsigned long (*mtk_get_gpu_custom_upbound_freq_fp)(void);
|
||
|
|
||
|
extern void ged_monitor_3D_fence_set_enable(GED_BOOL bEnable);
|
||
|
|
||
|
extern unsigned int g_ui32EventStatus;
|
||
|
extern unsigned int g_ui32EventDebugStatus;
|
||
|
|
||
|
#ifdef GED_ENABLE_DVFS_LOADING_MODE
|
||
|
extern void (*ged_dvfs_cal_gpu_utilization_ex_fp)(
|
||
|
unsigned int *pui32Loading,
|
||
|
unsigned int *pui32Block,
|
||
|
unsigned int *pui32Idle,
|
||
|
void *Util_Ex);
|
||
|
#else
|
||
|
extern void (*ged_dvfs_cal_gpu_utilization_fp)(unsigned int *pui32Loading,
|
||
|
unsigned int *pui32Block, unsigned int *pui32Idle);
|
||
|
#endif
|
||
|
extern void (*ged_dvfs_gpu_freq_commit_fp)(unsigned long ui32NewFreqID,
|
||
|
GED_DVFS_COMMIT_TYPE eCommitType, int *pbCommited);
|
||
|
extern bool ged_gpu_power_on_notified;
|
||
|
extern bool ged_gpu_power_off_notified;
|
||
|
|
||
|
extern bool mtk_get_bottom_gpu_freq(unsigned int *pui32FreqLevel);
|
||
|
extern GED_LOG_BUF_HANDLE ghLogBuf_GED;
|
||
|
|
||
|
extern void (*mtk_gpu_sodi_entry_fp)(void);
|
||
|
extern void (*mtk_gpu_sodi_exit_fp)(void);
|
||
|
|
||
|
extern unsigned int g_gpu_timer_based_emu;
|
||
|
// calculate loading reset time stamp
|
||
|
extern unsigned long g_ulCalResetTS_us;
|
||
|
// previous calculate loading reset time stamp
|
||
|
extern unsigned long g_ulPreCalResetTS_us;
|
||
|
// last frame half, t0
|
||
|
extern unsigned long g_ulWorkingPeriod_us;
|
||
|
|
||
|
#endif
|