kernel_samsung_a34x-permissive/drivers/misc/mediatek/include/mt-plat/mtk_lpae.h
2024-04-28 15:49:01 +02:00

57 lines
1.3 KiB
C
Executable file

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#ifndef __MTK_LPAE_H__
#define __MTK_LPAE_H__
#ifdef CONFIG_MTK_LM_MODE
#include <mt-plat/mtk_io.h>
#define INTERAL_MAPPING_OFFSET (0x40000000)
#define INTERAL_MAPPING_LIMIT (INTERAL_MAPPING_OFFSET + 0x80000000)
#define MT_OVERFLOW_ADDR_START 0x100000000ULL
unsigned int __attribute__((weak)) enable_4G(void)
{
return 0;
}
/* For HW modules which support 33-bit address setting */
#define CROSS_OVERFLOW_ADDR_TRANSFER(phy_addr, size, ret) \
do { \
ret = 0; \
if (enable_4G()) {\
if (((phys_addr_t)phy_addr < MT_OVERFLOW_ADDR_START)\
&& (((phys_addr_t)phy_addr + size) >= \
MT_OVERFLOW_ADDR_START)) \
ret = MT_OVERFLOW_ADDR_START - phy_addr; \
} \
} while (0) \
/* For SPM and MD32 only in ROME */
#define MAPPING_DRAM_ACCESS_ADDR(phy_addr) \
do { \
if (enable_4G()) {\
if (phy_addr >= INTERAL_MAPPING_OFFSET \
&& phy_addr < INTERAL_MAPPING_LIMIT) \
phy_addr += INTERAL_MAPPING_OFFSET; \
} \
} while (0)\
#else /* !CONFIG_ARM_LPAE */
#define CROSS_OVERFLOW_ADDR_TRANSFER(phy_addr, size, ret)
#define MAPPING_DRAM_ACCESS_ADDR(phy_addr)
#define MT_OVERFLOW_ADDR_START 0
static inline unsigned int enable_4G(void)
{
return 0;
}
#endif
#endif /*!__MTK_LPAE_H__ */