mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	The M4U IP blocks in mt2712 is MTK's generation2 M4U which use the ARM Short-descriptor like mt8173, and most of the HW registers are the same. The difference is that there are 2 M4U HWs in mt2712 while there's only one in mt8173. The purpose of 2 M4U HWs is for balance the bandwidth. Normally if there are 2 M4U HWs, there should be 2 iommu domains, each M4U has a iommu domain. Signed-off-by: Yong Wu <yong.wu@mediatek.com> Signed-off-by: Joerg Roedel <jroedel@suse.de>
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (c) 2015-2016 MediaTek Inc.
 | 
						|
 * Author: Yong Wu <yong.wu@mediatek.com>
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU General Public License version 2 as
 | 
						|
 * published by the Free Software Foundation.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful,
 | 
						|
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
 * GNU General Public License for more details.
 | 
						|
 */
 | 
						|
#ifndef MTK_IOMMU_SMI_H
 | 
						|
#define MTK_IOMMU_SMI_H
 | 
						|
 | 
						|
#include <linux/bitops.h>
 | 
						|
#include <linux/device.h>
 | 
						|
 | 
						|
#ifdef CONFIG_MTK_SMI
 | 
						|
 | 
						|
#define MTK_LARB_NR_MAX		16
 | 
						|
 | 
						|
#define MTK_SMI_MMU_EN(port)	BIT(port)
 | 
						|
 | 
						|
struct mtk_smi_larb_iommu {
 | 
						|
	struct device *dev;
 | 
						|
	unsigned int   mmu;
 | 
						|
};
 | 
						|
 | 
						|
struct mtk_smi_iommu {
 | 
						|
	unsigned int larb_nr;
 | 
						|
	struct mtk_smi_larb_iommu larb_imu[MTK_LARB_NR_MAX];
 | 
						|
};
 | 
						|
 | 
						|
/*
 | 
						|
 * mtk_smi_larb_get: Enable the power domain and clocks for this local arbiter.
 | 
						|
 *                   It also initialize some basic setting(like iommu).
 | 
						|
 * mtk_smi_larb_put: Disable the power domain and clocks for this local arbiter.
 | 
						|
 * Both should be called in non-atomic context.
 | 
						|
 *
 | 
						|
 * Returns 0 if successful, negative on failure.
 | 
						|
 */
 | 
						|
int mtk_smi_larb_get(struct device *larbdev);
 | 
						|
void mtk_smi_larb_put(struct device *larbdev);
 | 
						|
 | 
						|
#else
 | 
						|
 | 
						|
static inline int mtk_smi_larb_get(struct device *larbdev)
 | 
						|
{
 | 
						|
	return 0;
 | 
						|
}
 | 
						|
 | 
						|
static inline void mtk_smi_larb_put(struct device *larbdev) { }
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#endif
 |