unplugged-kernel/drivers/mmc/host/mediatek/ComboA/mt6765/autok_dvfs.h

61 lines
1.9 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#ifndef _AUTOK_DVFS_H_
#define _AUTOK_DVFS_H_
#include "msdc_cust.h"
#include "autok.h"
//#define VCOREFS_READY
#if defined(VCOREFS_READY)
#include <linux/pm_qos.h>
#include "helio-dvfsrc-opp.h"
#endif
enum AUTOK_VCORE {
AUTOK_VCORE_LEVEL0 = 0,
AUTOK_VCORE_LEVEL1,
AUTOK_VCORE_LEVEL2,
AUTOK_VCORE_LEVEL3,
AUTOK_VCORE_MERGE,
AUTOK_VCORE_NUM = AUTOK_VCORE_MERGE
};
#define MSDC_DVFS_TIMEOUT (HZ/100 * 5) /* 10ms x5 */
#define MSDC_DVFS_SET_SIZE 0x48
#define MSDC_TOP_SET_SIZE 0x30
#define SDIO_DVFS_TIMEOUT (HZ/100 * 5) /* 10ms x5 */
/* Enable later@Peter */
/* #define SDIO_HW_DVFS_CONDITIONAL */
/**********************************************************
* Function Declaration *
**********************************************************/
extern int sdio_autok_res_exist(struct msdc_host *host);
extern int sdio_autok_res_apply(struct msdc_host *host, int vcore);
extern int sdio_autok_res_save(struct msdc_host *host, int vcore, u8 *res);
extern void sdio_autok_wait_dvfs_ready(void);
extern int emmc_execute_dvfs_autok(struct msdc_host *host, u32 opcode);
extern int sd_execute_dvfs_autok(struct msdc_host *host, u32 opcode);
extern void sdio_execute_dvfs_autok(struct msdc_host *host);
extern int autok_res_check(u8 *res_h, u8 *res_l);
extern void sdio_set_hw_dvfs(int vcore, int done, struct msdc_host *host);
extern void sdio_dvfs_reg_restore(struct msdc_host *host);
extern void msdc_dump_autok(char **buff, unsigned long *size,
struct seq_file *m, struct msdc_host *host);
extern void msdc_dvfs_reg_backup_init(struct msdc_host *host);
extern void msdc_dvfs_reg_restore(struct msdc_host *host);
#ifdef SD_RUNTIME_AUTOK_MERGE
extern int sd_runtime_autok_merge(struct msdc_host *host);
#endif
#ifdef EMMC_RUNTIME_AUTOK_MERGE
extern int emmc_runtime_autok_merge(u32 opcode);
#endif
#endif /* _AUTOK_DVFS_H_ */