kernel-brax3-ubuntu-touch/drivers/gpu/mediatek/ged/include/ged_kpi.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

86 lines
2.6 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#ifndef __GED_KPI_H__
#define __GED_KPI_H__
#include "ged_type.h"
#include "ged_bridge_id.h"
/* To-Do: EAS*/
/*#include "eas_ctrl.h"*/
#include <linux/sched.h>
#include <linux/cpufreq.h>
#include <linux/topology.h>
GED_ERROR ged_kpi_dequeue_buffer_ts(int pid,
u64 ullWdnd,
int i32FrameID,
int fence_fd,
int isSF);
GED_ERROR ged_kpi_queue_buffer_ts(int pid,
u64 ullWdnd,
int i32FrameID,
int fence,
int QedBuffer_length);
GED_ERROR ged_kpi_acquire_buffer_ts(int pid, u64 ullWdnd, int i32FrameID);
GED_ERROR ged_kpi_sw_vsync(void);
GED_ERROR ged_kpi_hw_vsync(void);
int ged_kpi_get_uncompleted_count(void);
unsigned int ged_kpi_get_cur_fps(void);
unsigned int ged_kpi_get_cur_avg_cpu_time(void);
unsigned int ged_kpi_get_cur_avg_gpu_time(void);
unsigned int ged_kpi_get_cur_avg_response_time(void);
unsigned int ged_kpi_get_cur_avg_gpu_remained_time(void);
unsigned int ged_kpi_get_cur_avg_cpu_remained_time(void);
unsigned int ged_kpi_get_cur_avg_gpu_freq(void);
void ged_kpi_get_latest_perf_state(long long *t_cpu_remained,
long long *t_gpu_remained,
long *t_cpu_target,
long *t_gpu_target);
GED_ERROR ged_kpi_system_init(void);
void ged_kpi_system_exit(void);
bool ged_kpi_set_cpu_remained_time(long long t_cpu_remained,
int QedBuffer_length);
bool ged_kpi_set_gpu_dvfs_hint(int t_gpu_target, int t_gpu_cur);
unsigned int ged_kpi_enabled(void);
void ged_kpi_set_target_FPS(u64 ulID, int target_FPS);
void ged_kpi_set_target_FPS_margin(u64 ulID, int target_FPS,
int target_FPS_margin, int eara_fps_margin, int cpu_time);
#if defined(MTK_GPU_FW_IDLE)
int ged_kpi_get_fw_idle_mode(void);
int ged_kpi_is_fw_idle_policy_enable(void);
void ged_kpi_set_fw_idle_mode(unsigned int mode);
void ged_kpi_enable_fw_idle_policy(unsigned int mode);
#endif /* MTK_GPU_FW_IDLE */
void ged_kpi_update_t_gpu_latest_uncompleted(void);
struct ged_risky_bq_info {
struct {
long long t_gpu;
int t_gpu_target;
unsigned long long risk;
unsigned long long ullWnd;
} completed_bq, uncompleted_bq;
unsigned int total_gpu_completed_count;
};
GED_ERROR ged_kpi_timer_based_pick_riskyBQ(struct ged_risky_bq_info *info);
int ged_kpi_get_main_bq_uncomplete_count(void);
/* For Gift Usage */
GED_ERROR ged_kpi_query_dvfs_freq_pred(int *gpu_freq_cur
, int *gpu_freq_max, int *gpu_freq_pred);
GED_ERROR ged_kpi_query_gpu_dvfs_info(struct GED_BRIDGE_OUT_QUERY_GPU_DVFS_INFO *out);
GED_ERROR ged_kpi_set_gift_status(int mode);
GED_ERROR ged_kpi_set_gift_target_pid(int pid);
extern spinlock_t gsGpuUtilLock;
// extern unsigned int g_gpufreqv2;
#endif