Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp2679123imm; Sat, 12 May 2018 18:01:51 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrg8B8gQ1ZkjL4GL7Cs/b7DV/7cWt+BeDJuNpzOdabqVMmNdWkq1PmlWfjtxa66rPymoQUX X-Received: by 2002:a63:ac1a:: with SMTP id v26-v6mr4062449pge.105.1526173311198; Sat, 12 May 2018 18:01:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526173311; cv=none; d=google.com; s=arc-20160816; b=Rv0OdJUM+9DP41THLETyadJaZoyxqs8vbSGJ3eAOw0XMwXofYN+KN24OoQndXssbo0 aLmW0kuQWK0AdrpnvEtJcwq/A8Vsih2KdDZGnwbd4kbBLDDiEd3cIGiGbIgeIs6VO2Fx ZlljNJwGNiksmkl5++UwQt1s+/Q/zd3BpLNGhrhjxuQGBwpTeAEtnBoPNizkA6vIpEnT cfznkEjGGrmMYYPRPxY7Qrwe6oEoB9j7khAmL07P6yxYWsGtklOtTK/YA/INqCxcBGfB zyciXhAChJXsNtTM9B6/u81L8yRO7CnPTjJRvdT6OtX3A7WkRS0Wp4GIQ5k6a0xNC7SM F0NQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=message-id:list-id:precedence:sender:subject:from:cc:to:date :arc-authentication-results; bh=B1Nq4QV8oX244JHQGZYpUB+PLrCWBf4+7cilDr6H/KY=; b=CMIQvfDQR13f9GWx8YUVyaD+G1w0LPUmg61WY02H8rGAzK41ILLg45MXqiK6jK+alA BNgVGzGJ1n9t1GO949+61SwTyX8zGTlSPyUbf+OnadK3uQnaksd3nzCAVhvoO4ncU+6C uqadduMrtOWDxbN0lhuKfjwps9hxPJ2dwc7FvsTM7k4WKc4YInsvq/vGK2rlLbFiZH7O AJGg7SCCk3dlhTnKH3t7yv2X3QrW/98tiNln29R/WjU26CyrnEiVSWAiEr/XdVt4qUSo 1EGVkbIr604ZmzTE6JWwT7vBkLKcddn+pPlkW4qSsTN9lfc6sG/NxU4+QW6NvCMlwP9u LEgA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h10-v6si5135521pgp.496.2018.05.12.18.01.04; Sat, 12 May 2018 18:01:51 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751660AbeEMBAx (ORCPT + 99 others); Sat, 12 May 2018 21:00:53 -0400 Received: from kvm5.telegraphics.com.au ([98.124.60.144]:57766 "EHLO kvm5.telegraphics.com.au" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751227AbeEMBAw (ORCPT ); Sat, 12 May 2018 21:00:52 -0400 Received: from localhost (localhost.localdomain [127.0.0.1]) by kvm5.telegraphics.com.au (Postfix) with ESMTP id 760422905A; Sat, 12 May 2018 21:00:47 -0400 (EDT) Date: Sun, 13 May 2018 11:00:50 +1000 To: linux-m68k@lists.linux-m68k.org, linux-kernel@vger.kernel.org Cc: Christoph Hellwig From: Finn Thain Subject: [RFC] m68k: Set up dma mask for platform devices Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Message-Id: This avoids a WARNING splat when loading the macsonic or macmace driver. Please see commit 205e1b7f51e4 ("dma-mapping: warn when there is no coherent_dma_mask"). This implementation of arch_setup_pdev_archdata() differs from the one in arch/powerpc in that this one avoids clobbering an existing dma mask. For example, this approach preserves the mask set by the initializer for struct platform_device mcf_fec0. Note that either approach would make that initializer redundant and commit f61e64310b75 ("m68k: set dma and coherent masks for platform FEC ethernets") could be reverted. --- arch/m68k/kernel/dma.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/arch/m68k/kernel/dma.c b/arch/m68k/kernel/dma.c index c01b9b8f97bf..463572c4943f 100644 --- a/arch/m68k/kernel/dma.c +++ b/arch/m68k/kernel/dma.c @@ -9,6 +9,7 @@ #include #include #include +#include #include #include #include @@ -165,3 +166,12 @@ const struct dma_map_ops m68k_dma_ops = { .sync_sg_for_device = m68k_dma_sync_sg_for_device, }; EXPORT_SYMBOL(m68k_dma_ops); + +void arch_setup_pdev_archdata(struct platform_device *pdev) +{ + if (pdev->dev.coherent_dma_mask == DMA_MASK_NONE && + pdev->dev.dma_mask == NULL) { + pdev->dev.coherent_dma_mask = DMA_BIT_MASK(32); + pdev->dev.dma_mask = &pdev->dev.coherent_dma_mask; + } +} -- 2.16.1