Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp1062855imm; Sat, 26 May 2018 20:05:31 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqwwQu3IlbXXVmwovaAgXCz0vHHEzC2YDUHDqM3d+HnnizBUExQA1V7cMNm6TxQZkVtvy71 X-Received: by 2002:a65:4c05:: with SMTP id u5-v6mr6446613pgq.388.1527390331032; Sat, 26 May 2018 20:05:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527390331; cv=none; d=google.com; s=arc-20160816; b=MFy+P6QIq5kx5rxI4/ELPFPVDtej4t0yKt653p3hdLTVWigbmO3RlAygy2Yd45GrPd m67D0TBHwFjH6Rf+vjnJm2/uqkLMe4HSFFzbygaAFfm+ZW1krk5uadyDuwD70DtXDsJN mDozc8xUebGnAyNXUaC/rEPyijf3+23FuJIuAb9Q+wteDWqTcLwK1faftpY8F3l2YMD0 22bDlJid68D/o5LMalRCMfXMMDaZ9Yjn7iD7M1AKnKrBWzBGDwpVoqVMP+i5YsR+aion FLJ5rJHCwX1UrZ2L04TL2GFv99FEa6VRb2OXGkTyYeKepy2YtFb47FZoQaFutkN+inzU aPag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:message-id :in-reply-to:subject:cc:to:from:date:arc-authentication-results; bh=cDfycQIdgz+RU0JBmIA1BskBL6JNIFRkRRCryc2rIz8=; b=PZJEv5SFKfetMr+HW+2cMtA5O53jGr+/FNXzykKk7l/G/Bp5ZVVaMGiuVgnwc5JZ2l /L8oZXKyoZN/9jBPYcS2NRqFf2rXDjEpkPRWWu5mh5bpt7S784JyZ1+xWhqEpIbitXUE xkpQQNKsFVPYzPDk7bGHbXYj6S19n1ThCEI/kERaj4rwYSQ+IttOTQxYOxaTBPDQ8TBQ 0QIDQsDm9Js8yYfbXuZG7DqDTh7kCrj8bXfvfSFHJZiIARSRtl+s4LXA/EX2FFTJL/2D bsnZvRZpUhcdTHtXEspwR1ht4An4XvPRicB9iJKooqm/ztuzAaorNQFku5uGDpiuvtIY P+Dw== 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 g130-v6si26819265pfc.366.2018.05.26.20.04.43; Sat, 26 May 2018 20:05:31 -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 S1032559AbeE0DBP (ORCPT + 99 others); Sat, 26 May 2018 23:01:15 -0400 Received: from kvm5.telegraphics.com.au ([98.124.60.144]:58716 "EHLO kvm5.telegraphics.com.au" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1032539AbeE0DBO (ORCPT ); Sat, 26 May 2018 23:01:14 -0400 Received: from localhost (localhost.localdomain [127.0.0.1]) by kvm5.telegraphics.com.au (Postfix) with ESMTP id AA7A529CDE; Sat, 26 May 2018 23:01:12 -0400 (EDT) Date: Sun, 27 May 2018 13:01:11 +1000 (AEST) From: Finn Thain To: Guenter Roeck cc: Joshua Thompson , Greg Ungerer , Geert Uytterhoeven , linux-m68k@lists.linux-m68k.org, linux-kernel@vger.kernel.org Subject: Re: [RFC PATCH] m68k: set dma and coherent masks for Macintosh SONIC based ethernet In-Reply-To: <1527378785-13326-1-git-send-email-linux@roeck-us.net> Message-ID: References: <1527378785-13326-1-git-send-email-linux@roeck-us.net> MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, 26 May 2018, Guenter Roeck wrote: > As of commit 205e1b7f51e4 ("dma-mapping: warn when there is no > coherent_dma_mask") the NatSemi SONIC Ethernet driver is issuing the > following warning on driver initialization on Macintosh q800 systems. > > SONIC ethernet @50f0a000, MAC 08:00:07:12:34:56, IRQ 3 > ------------[ cut here ]------------ > WARNING: CPU: 0 PID: 1 at ./include/linux/dma-mapping.h:516 macsonic_init+0x6a/0x15a > Modules linked in: > CPU: 0 PID: 1 Comm: swapper Not tainted 4.17.0-rc6-mac-00286-g527f47c #1 > Stack from 0781fdd8: > 0781fdd8 003615b3 000181ba 000005c4 07a24cbc 00000000 00000000 000020e8 > 07a24800 002c196c 0001824e 00334c06 00000204 001f782a 00000009 00000000 > 00000000 003358d9 001f782a 00334c06 00000204 00000003 00000000 07a24800 > 002b5cb6 000372ec 001f8b1a 07a24800 00359203 50f0a000 07a14a48 00000003 > 00000000 07845c0a 0039dcca 003c835c 003c835c 0035b924 001c19de 07845c00 > 07845c0a 0039dcca 001c06dc 07845c0a 0781fed8 00000007 0054d040 07845c0a > Call Trace: [<000181ba>] __warn+0xc0/0xc2 > [<000020e8>] do_one_initcall+0x0/0x140 > [<0001824e>] warn_slowpath_null+0x26/0x2c > [<001f782a>] macsonic_init+0x6a/0x15a > [<001f782a>] macsonic_init+0x6a/0x15a > [<002b5cb6>] memcmp+0x0/0x2a > [<000372ec>] printk+0x0/0x18 > [<001f8b1a>] mac_sonic_platform_probe+0x380/0x404 > > As per the warning the coherent_dma_mask is not set on this device. > There is nothing special about the DMA memory coherency on this hardware > so we can just set the mask to 32bits in the platform data for the FEC > ethernet devices. > > Signed-off-by: Guenter Roeck Acked-by: Finn Thain Geert, assuming that Guenter's patch is acceptable, would you also accept a similar patch for the "macmace" platform device? > --- > Modeled after f61e64310b75 ("m68k: set dma and coherent masks for platform > FEC ethernets"). > > RFC: Is "nothing special about the DMA memory coherency" correect ? > As I understand it, "cache-coherence" is meaningless unless you have multiple CPU cores and caches. If there's only one CPU core, its cache can't be said to be "coherent" or "non-coherent". Moreover, DMA (direct memory access) concerns an IO device and a memory, not a cache, so the term "coherent dma" is bogus IMHO. -- > arch/m68k/mac/config.c | 12 +++++++++++- > 1 file changed, 11 insertions(+), 1 deletion(-) > > diff --git a/arch/m68k/mac/config.c b/arch/m68k/mac/config.c > index 0c3275aa0197..8e0476daddb8 100644 > --- a/arch/m68k/mac/config.c > +++ b/arch/m68k/mac/config.c > @@ -17,6 +17,7 @@ > #include > #include > #include > +#include > /* keyb */ > #include > #include > @@ -971,6 +972,15 @@ static const struct resource mac_scsi_ccl_rsrc[] __initconst = { > }, > }; > > +static struct platform_device macsonic_dev = { > + .name = "macsonic", > + .id = -1, > + .dev = { > + .dma_mask = &macsonic_dev.dev.coherent_dma_mask, > + .coherent_dma_mask = DMA_BIT_MASK(32), > + }, > +}; > + > int __init mac_platform_init(void) > { > u8 *swim_base; > @@ -1088,7 +1098,7 @@ int __init mac_platform_init(void) > > if (macintosh_config->ether_type == MAC_ETHER_SONIC || > macintosh_config->expansion_type == MAC_EXP_PDS_COMM) > - platform_device_register_simple("macsonic", -1, NULL, 0); > + platform_device_register(&macsonic_dev); > > if (macintosh_config->expansion_type == MAC_EXP_PDS || > macintosh_config->expansion_type == MAC_EXP_PDS_COMM) > -- > 2.7.4 >