/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright (C) 2015 MediaTek Inc. */ #ifndef __CCCI_PLATFORM_H__ #define __CCCI_PLATFORM_H__ #include #include "ccci_config.h" #include "ccci_common_config.h" #include "modem_sys.h" struct ccci_plat_val { void __iomem *infra_ao_base; unsigned int md_gen; unsigned long offset_epof_md1; void __iomem *md_plat_info; }; static struct ccci_plat_val md_cd_plat_val_ptr; #define ccci_write32(b, a, v) \ do { \ writel(v, (b) + (a)); \ mb(); /* make sure register access in order */ \ } while (0) #define ccci_write16(b, a, v) \ do { \ writew(v, (b) + (a)); \ mb(); /* make sure register access in order */ \ } while (0) #define ccci_write8(b, a, v) \ do { \ writeb(v, (b) + (a)); \ mb(); /* make sure register access in order */ \ } while (0) #define ccci_read32(b, a) ioread32((void __iomem *)((b)+(a))) #define ccci_read16(b, a) ioread16((void __iomem *)((b)+(a))) #define ccci_read8(b, a) ioread8((void __iomem *)((b)+(a))) #ifdef SET_EMI_STEP_BY_STAGE void ccci_set_mem_access_protection_1st_stage(struct ccci_modem *md); void ccci_set_mem_access_protection_second_stage(int md_id); #endif //void ccci_get_platform_version(char *ver); int ccci_platform_init(struct ccci_modem *md); void ccci_platform_common_init(struct ccci_modem *md); void ccci_platform_init_6779(struct ccci_modem *md); int ccci_plat_common_init(void); //void ccci_set_clk_cg(struct ccci_modem *md, unsigned int is_on); #ifdef ENABLE_DRAM_API extern phys_addr_t get_max_DRAM_size(void); #endif int Is_MD_EMI_voilation(void); #define MD_IN_DEBUG(md) (0) #endif /* __CCCI_PLATFORM_H__ */