unplugged-kernel/drivers/misc/mediatek/eccci/mt6779/md_sys1_platform.h

109 lines
3.5 KiB
C
Raw Normal View History

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2015 MediaTek Inc.
*/
#ifndef __MD_SYS1_PLATFORM_H__
#define __MD_SYS1_PLATFORM_H__
#include <linux/skbuff.h>
#define SCP_SMEM_KEY (0x5343505f534d454d) /* SCP_SMEM magic key */
struct ccci_clk_node {
struct clk *clk_ref;
unsigned char *clk_name;
};
struct md_pll_reg {
void __iomem *md_top_clkSW;
void __iomem *md_boot_stats_select;
void __iomem *md_boot_stats;
};
struct ccci_plat_ops {
void (*init)(struct ccci_modem *md);
void (*md_dump_reg)(unsigned int md_index);
void (*cldma_hw_rst)(unsigned char md_id);
void (*set_clk_cg)(struct ccci_modem *md, unsigned int on);
int (*remap_md_reg)(struct ccci_modem *md);
void (*lock_cldma_clock_src)(int locked);
void (*lock_modem_clock_src)(int locked);
void (*dump_md_bootup_status)(struct ccci_modem *md);
void (*get_md_bootup_status)(
struct ccci_modem *md, unsigned int *buff, int length);
void (*debug_reg)(struct ccci_modem *md);
int (*pccif_send)(struct ccci_modem *md, int channel_id);
void (*check_emi_state)(struct ccci_modem *md, int polling);
int (*soft_power_off)(struct ccci_modem *md, unsigned int mode);
int (*soft_power_on)(struct ccci_modem *md, unsigned int mode);
int (*start_platform)(struct ccci_modem *md);
int (*power_on)(struct ccci_modem *md);
int (*let_md_go)(struct ccci_modem *md);
int (*power_off)(struct ccci_modem *md, unsigned int timeout);
int (*vcore_config)(unsigned int md_id, unsigned int hold_req);
};
struct md_hw_info {
/* HW info - Register Address */
unsigned long md_rgu_base;
unsigned long l1_rgu_base;
unsigned long md_boot_slave_Vector;
unsigned long md_boot_slave_Key;
unsigned long md_boot_slave_En;
unsigned long ap_ccif_base;
unsigned long md_ccif_base;
unsigned int sram_size;
void __iomem *md_ccif4_base;
/* HW info - Interrutpt ID */
unsigned int ap_ccif_irq0_id;
unsigned int ap_ccif_irq1_id;
unsigned int md_wdt_irq_id;
unsigned int ap2md_bus_timeout_irq_id;
void __iomem *md_pcore_pccif_base;
/* HW info - Interrupt flags */
unsigned long ap_ccif_irq0_flags;
unsigned long ap_ccif_irq1_flags;
unsigned long md_wdt_irq_flags;
void *hif_hw_info;
/*HW info - plat*/
struct ccci_plat_ops *plat_ptr;
struct ccci_plat_val *plat_val;
};
int ccci_modem_remove(struct platform_device *dev);
void ccci_modem_shutdown(struct platform_device *dev);
int ccci_modem_suspend(struct platform_device *dev, pm_message_t state);
int ccci_modem_resume(struct platform_device *dev);
int ccci_modem_pm_suspend(struct device *device);
int ccci_modem_pm_resume(struct device *device);
int ccci_modem_pm_restore_noirq(struct device *device);
int md_cd_low_power_notify(struct ccci_modem *md,
enum LOW_POEWR_NOTIFY_TYPE type, int level);
int md_cd_get_modem_hw_info(struct platform_device *dev_ptr,
struct ccci_dev_cfg *dev_cfg, struct md_hw_info *hw_info);
int md_cd_pccif_send(struct ccci_modem *md, int channel_id);
void ccci_notify_set_scpmem(void);
#ifndef CCCI_KMODULE_ENABLE
void md_cd_dump_pccif_reg(struct ccci_modem *md);
#endif
/* ADD_SYS_CORE */
//int ccci_modem_syssuspend(void);
//void ccci_modem_sysresume(void);
void md_dump_register_6779(unsigned int md_index);
extern unsigned int devapc_check_flag;
extern void ccci_mem_dump(int md_id, void *start_addr, int len);
extern void dump_emi_outstanding(void);
extern int ccci_modem_init_common(struct platform_device *plat_dev,
struct ccci_dev_cfg *dev_cfg, struct md_hw_info *md_hw);
extern void ccci_modem_plt_resume(struct ccci_modem *md);
extern int ccci_modem_plt_suspend(struct ccci_modem *md);
#endif /* __MD_SYS1_PLATFORM_H__ */