From: Florian Fainelli Date: Fri, 19 Mar 2021 04:03:33 +0000 (-0700) Subject: ARM: Qualify enabling of swiotlb_init() X-Git-Tag: v5.13-rc1~58^2~3 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=fcf044891c84e38fc90eb736b818781bccf94e38;p=thirdparty%2Flinux.git ARM: Qualify enabling of swiotlb_init() We do not need a SWIOTLB unless we have DRAM that is addressable beyond the arm_dma_limit. Compare max_pfn with arm_dma_pfn_limit to determine whether we do need a SWIOTLB to be initialized. Fixes: ad3c7b18c5b3 ("arm: use swiotlb for bounce buffering on LPAE configs") Signed-off-by: Florian Fainelli Signed-off-by: Konrad Rzeszutek Wilk --- diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index 828a2561b2295..8356bf1daa282 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c @@ -301,7 +301,11 @@ static void __init free_highpages(void) void __init mem_init(void) { #ifdef CONFIG_ARM_LPAE - swiotlb_init(1); + if (swiotlb_force == SWIOTLB_FORCE || + max_pfn > arm_dma_pfn_limit) + swiotlb_init(1); + else + swiotlb_force = SWIOTLB_NO_FORCE; #endif set_max_mapnr(pfn_to_page(max_pfn) - mem_map);