Received: by 2002:a05:6a10:7420:0:0:0:0 with SMTP id hk32csp594140pxb; Tue, 15 Feb 2022 23:11:05 -0800 (PST) X-Google-Smtp-Source: ABdhPJxuViBvjwtbw8L7+dyFw0pKw4bw768xnO+PnJxeCEKkWkgf5H0+dJF8z7ZF0Eynl5oIv48A X-Received: by 2002:a62:be0f:0:b0:4e1:9222:1ef3 with SMTP id l15-20020a62be0f000000b004e192221ef3mr1772035pff.18.1644995465529; Tue, 15 Feb 2022 23:11:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1644995465; cv=none; d=google.com; s=arc-20160816; b=zR+od5gO74LxlBoFEkf3VIXkYHfsQT5YqXL9uB9SjRK3402mPU9+8xQ+7R63PqL+eq Q1LA7WXRmjLG0EpPV1XdrYwTip+jXiVjFHf8lNlmAjZl+XJ/9IY5yfe8U3AOTxi2Hv1p nkmnhU5s0pM7TgVaW+YFmKGZGlL3G6hx5ZprF/vtmjw6BxPm8XNcA7bSHRcjkgLGi8fQ itdYem6ZxLWkG6B7z7D4wkannd2aQJPRkNAkL0tRvNMebH5x5Z4rvj0jW4QO1J7ipmt2 vecYSu+LleMsUh4aWfTB59RsAuErLLilTSyoxFDsrMXDu0VAyWsiZplMtDDXNaow/sae rmpA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=9yWBYPd6NKB6JcihsiBbZriwcIaq0EbIUxLCjaZF0zo=; b=j5k6jvj684+QUqB+D0Vv6DMRm+KW+h0420nNR089U7/WsTp/XwosEFRVuIh5XKIRNp cK2YOnXICRjfxh1/BismrVdDDQwf0ndendH12GU5/eFTb6duNRIPPnjWwYQYr/oXkmhL eFnjlZ0IrPfCq1aboAZXDDLg4cuvdXbmjg/bhF4bDtttoUZtvKKK6leYcsLbJgUY7UNr Fy0eEYqemTEkTKJVsnVAT4pAkqa0n7s5ZdXZc006VUcEsngnWXmf7GQczFcO7L1ZOwtG 38+Vag3gkIpE7lvsD0jwRM7L94cwBNL6ud/dY4X/jASza32ZpnehuzXGp+RQZUONbEeE D0MQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=maDEaz0+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id b13si35222202pfm.244.2022.02.15.23.11.05 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 15 Feb 2022 23:11:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=maDEaz0+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id F273BDA8; Tue, 15 Feb 2022 22:46:27 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240557AbiBOPfO (ORCPT + 99 others); Tue, 15 Feb 2022 10:35:14 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:41098 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234314AbiBOPeF (ORCPT ); Tue, 15 Feb 2022 10:34:05 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8072AB12F4; Tue, 15 Feb 2022 07:30:36 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id EED34615D9; Tue, 15 Feb 2022 15:30:35 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 3F114C340F2; Tue, 15 Feb 2022 15:30:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1644939035; bh=1DZitMsfscZqtj1V+5JG4H75SyoQCa4GwHKOPdzcUoA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=maDEaz0+cbVicyz+fSChrQBbDcCRapvPuRBHC+ER8jR0oCaBBwcJYwmeml9fnDFCM KBbx9l0T3XdFbMaka33ITlxcyHJia2VbXIXOZzm3fjKx5ZEub79dcmUwj/95pfQ8I8 ElkQ9BzYQeYgvDMnLZvSg9dJmoUDCvk+DJFgx+18BWuftZqItvLXc+TZDHcLUUxulo r2QzJdaxH71OpTfiZt4cYttM4kgCzz4kJmFpGVVBIjShqpKm2+b8T9GZb2StpBQi8s zvDhJbpyDhgmixXDyWfG6qjpW3yr6JDV95CGBJGEMwb01/vygEraB9I4zTBjvDEEJB 4Q7LAGQ6wvmEw== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Marc St-Amand , Harini Katakam , Nicolas Ferre , Conor Dooley , "David S . Miller" , Sasha Levin , claudiu.beznea@microchip.com, kuba@kernel.org, netdev@vger.kernel.org Subject: [PATCH AUTOSEL 5.10 22/23] net: macb: Align the dma and coherent dma masks Date: Tue, 15 Feb 2022 10:29:56 -0500 Message-Id: <20220215152957.581303-22-sashal@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220215152957.581303-1-sashal@kernel.org> References: <20220215152957.581303-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Marc St-Amand [ Upstream commit 37f7860602b5b2d99fc7465f6407f403f5941988 ] Single page and coherent memory blocks can use different DMA masks when the macb accesses physical memory directly. The kernel is clever enough to allocate pages that fit into the requested address width. When using the ARM SMMU, the DMA mask must be the same for single pages and big coherent memory blocks. Otherwise the translation tables turn into one big mess. [ 74.959909] macb ff0e0000.ethernet eth0: DMA bus error: HRESP not OK [ 74.959989] arm-smmu fd800000.smmu: Unhandled context fault: fsr=0x402, iova=0x3165687460, fsynr=0x20001, cbfrsynra=0x877, cb=1 [ 75.173939] macb ff0e0000.ethernet eth0: DMA bus error: HRESP not OK [ 75.173955] arm-smmu fd800000.smmu: Unhandled context fault: fsr=0x402, iova=0x3165687460, fsynr=0x20001, cbfrsynra=0x877, cb=1 Since using the same DMA mask does not hurt direct 1:1 physical memory mappings, this commit always aligns DMA and coherent masks. Signed-off-by: Marc St-Amand Signed-off-by: Harini Katakam Acked-by: Nicolas Ferre Tested-by: Conor Dooley Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/cadence/macb_main.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/ethernet/cadence/macb_main.c b/drivers/net/ethernet/cadence/macb_main.c index 1e8bf6b9834bb..2af464ac250ac 100644 --- a/drivers/net/ethernet/cadence/macb_main.c +++ b/drivers/net/ethernet/cadence/macb_main.c @@ -4534,7 +4534,7 @@ static int macb_probe(struct platform_device *pdev) #ifdef CONFIG_ARCH_DMA_ADDR_T_64BIT if (GEM_BFEXT(DAW64, gem_readl(bp, DCFG6))) { - dma_set_mask(&pdev->dev, DMA_BIT_MASK(44)); + dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(44)); bp->hw_dma_cap |= HW_DMA_CAP_64B; } #endif -- 2.34.1