Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp5314346imm; Tue, 31 Jul 2018 08:55:16 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcUgYjeTCdH7jXD9J75+Gtg3ItqpslQjeO2B5p0T8nNaqcDLR84nqyu3riAjk4HqS9iVVJk X-Received: by 2002:a62:25c5:: with SMTP id l188-v6mr22602882pfl.179.1533052516684; Tue, 31 Jul 2018 08:55:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533052516; cv=none; d=google.com; s=arc-20160816; b=b8rLF9nSBmUctywt+nY3WprEAEc5EQVudlj+7YdEyKOF+tAVNGCKfhRkow4XCFY02S cvJTkXd009YiOBSceJvNtSXf/IsR6TlrQwYzFU//EoBFNCEIiqeMa81mgssEvjZyido4 rTKBjCGkeYRRCpbytc8UHUsmwb7kFGRTjRqaO7oQiwYRGiiV5L6NQP0rm2vtwGW5988e nJr+/Yla+2/uSgONaGPwg5Zs5D1BJM2L0MtEGyLyG+NbeLhwBFbhspFInozbT9C3HqFh BvmvXAGGarNgyAZ4m0VjM4URgEJSi/BrN3pjzI+lYNuSHiP5ZlEG3K+T/dCAxAMsMEAL BVEQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature:arc-authentication-results; bh=UQ2Gi6ayp4aNG8bXusYZLfpfkW1EXSVvG3cAza+b47U=; b=tNfCHQHadGZdvrmvzspynNBmvpW+BzEV4bHdZr7yjhMNC1s415gFcQUEqu3vvWoeb9 5u0RdlojhDtaGqcMQDBNq+WUNDm8vU8u4VtUOkxGyev9iUizIHCeCG+kNNGgzYyonM0N qZKXNA8RcIlOlMPK0qVcqLlWZXVvql77RNBK6gmT6rOlPy/PheKfJp9avY4H7lkBSJsj lesx2yShpy77CaXT1AtZZZ2UHnCSHC0HsVRXIjr9+tVHjo0abpukeCwecQ4hMNY9wIaU DYHyxZU9JkTqxEyvlaO4Dj3THQcrg3+7+Q8KVcq4LyMzqGtOhbs0qnzjHtFsPmYxUuSv OjjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b=phXtSifs; 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 6-v6si13008529pgz.592.2018.07.31.08.55.01; Tue, 31 Jul 2018 08:55:16 -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; dkim=pass header.i=@agner.ch header.s=dkim header.b=phXtSifs; 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 S1732496AbeGaRe0 (ORCPT + 99 others); Tue, 31 Jul 2018 13:34:26 -0400 Received: from mail.kmu-office.ch ([178.209.48.109]:58552 "EHLO mail.kmu-office.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732364AbeGaReZ (ORCPT ); Tue, 31 Jul 2018 13:34:25 -0400 Received: from webmail.kmu-office.ch (unknown [IPv6:2a02:418:6a02::a3]) by mail.kmu-office.ch (Postfix) with ESMTPSA id EEBF55C03BB; Tue, 31 Jul 2018 17:53:26 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=agner.ch; s=dkim; t=1533052406; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=UQ2Gi6ayp4aNG8bXusYZLfpfkW1EXSVvG3cAza+b47U=; b=phXtSifsbAu3qL3VnSSAlIOvX9yzvZF/jz14e6n0aJBnYSonXdI1fYKC+G6XnBvUfGSRa6 rs8U1upMAwCsgNDKECeTlioVoJ1YUXDXiUnYG7ZypbXO6+C3gWIJey7T9Ezy/tT2/7R32+ 2m+2H/mnsjUD8BuQPlithIlqDHjaWcE= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Date: Tue, 31 Jul 2018 17:53:26 +0200 From: Stefan Agner To: Robin Murphy Cc: Guenter Roeck , Christoph Hellwig , Krzysztof Kozlowski , Ard Biesheuvel , Rob Herring , Frank Rowand , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Fugang Duan Subject: Re: [BUG BISECT] Ethernet fail on VF50 (OF: Don't set default coherent DMA mask) In-Reply-To: <0e893142-a5db-d119-6eb3-f849db6b5d04@arm.com> References: <20180727140448.GA29001@lst.de> <20180728165820.GA5731@roeck-us.net> <45f7fc82-fb9c-e666-4ada-c5338d2c1c96@arm.com> <39fa11ce4b7dd151d98868f375baf818@agner.ch> <0e893142-a5db-d119-6eb3-f849db6b5d04@arm.com> Message-ID: <4339e35944851cc105ddfba03e1b990b@agner.ch> X-Sender: stefan@agner.ch User-Agent: Roundcube Webmail/1.3.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 31.07.2018 14:32, Robin Murphy wrote: > On 31/07/18 09:19, Stefan Agner wrote: >> On 30.07.2018 16:38, Robin Murphy wrote: >>> On 28/07/18 17:58, Guenter Roeck wrote: >>>> On Fri, Jul 27, 2018 at 04:04:48PM +0200, Christoph Hellwig wrote: >>>>> On Fri, Jul 27, 2018 at 03:18:14PM +0200, Krzysztof Kozlowski wrote: >>>>>> On 27 July 2018 at 15:11, Krzysztof Kozlowski wrote: >>>>>>> Hi, >>>>>>> >>>>>>> On today's next, the bisect pointed commit >>>>>>> ff33d1030a6ca87cea9a41e1a2ea7750a781ab3d as fault for my boot failures >>>>>>> with NFSv4 root on Toradex Colibri VF50 (Iris carrier board). >>>>>>> >>>>>>> Author: Robin Murphy >>>>>>> Date: Mon Jul 23 23:16:12 2018 +0100 >>>>>>> OF: Don't set default coherent DMA mask >>>>>>> >>>>>>> Board: Toradex Colibri VF50 (NXP VF500, Cortex A5, serial configured >>>>>>> with DMA) on Iris Carrier. >>>>>>> >>>>>>> It looks like problem with Freescale Ethernet driver: >>>>>>> [ 15.458477] fsl-edma 40018000.dma-controller: coherent DMA mask is unset >>>>>>> [ 15.465284] fsl-lpuart 40027000.serial: Cannot prepare cyclic DMA >>>>>>> [ 15.472086] Root-NFS: no NFS server address >>>>>>> [ 15.476359] VFS: Unable to mount root fs via NFS, trying floppy. >>>>>>> [ 15.484228] VFS: Cannot open root device "nfs" or >>>>>>> unknown-block(2,0): error -6 >>>>>>> [ 15.491664] Please append a correct "root=" boot option; here are >>>>>>> the available partitions: >>>>>>> [ 15.500188] 0100 16384 ram0 >>>>>>> [ 15.500200] (driver?) >>>>>>> [ 15.506406] Kernel panic - not syncing: VFS: Unable to mount root >>>>>>> fs on unknown-block(2,0) >>>>>>> [ 15.514747] ---[ end Kernel panic - not syncing: VFS: Unable to >>>>>>> mount root fs on unknown-block(2,0) ]--- >>>>>>> >>>>>>> Attached - defconfig and full boot log. >>>>>>> >>>>>>> Any hints? >>>>>>> Let me know if you need any more information. >>>>>> >>>>>> My Exynos boards also fail to boot on missing network: >>>>>> https://krzk.eu/#/builders/21/builds/799/steps/10/logs/serial0 >>>>>> >>>>>> As expected there are plenty of "DMA mask not set" warnings... and >>>>>> later dwc3 driver fails with: >>>>>> dwc3: probe of 12400000.dwc3 failed with error -12 >>>>>> which is probably the answer why LAN attached to USB is not present. >>>>> >>>>> Looks like all the drivers failed to set a dma mask and were lucky. >>>> >>>> I would call it a serious regression. Also, no longer setting a default >>>> coherent DMA mask is a quite substantial behavioral change, especially >>>> if and since the code worked just fine up to now. >>> >>> To reiterate, that particular side-effect was an unintentional >>> oversight, and I was simply (un)lucky enough that none of the drivers >>> I did test depended on that default mask. Sorry for the blip; please >>> check whether it's now fixed in next-20180730 as it should be. >>> >> >> Just for my understanding: >> >> Your first patch ("OF: Don't set default coherent DMA mask") sounded >> like that *not* setting default coherent DMA mask was intentionally. >> Since the commit message reads: "...the bus code has not initialised any >> default value" that was assuming that all bus code sets a default DMA >> mask which wasn't the case for "simple-bus". > > Yes, reading the patches in the order they were written is perhaps a > little unclear, but hopefully the order in which they are now applied > makes more sense. > >> So I guess that is what ("of/platform: Initialise default DMA masks") >> makes up for in the typical device tree case ("simple-bus")? > > Indeed, I'd missed the fact that the now-out-of-place-looking > initialisation in of_dma_configure() still actually belonged to > of_platform_device_create_pdata() - that patch should make the > assumptions of "OF: Don't set default coherent DMA mask" true again, > even for OF-platform devices. > >> Now, since almost all drivers are inside a soc "simple-bus" and DMA mask >> is set again, can/should we rely on the coherent DMA mask set? >> >> Or is the expectation still that this is set on driver level too? > > Ideally, we'd like all drivers to explicitly request their masks as > the documentation in DMA-API-HOWTO.txt recommends, if only to ensure > DMA is actually possible - there can be systems where even the default > 32-bit mask is no good - but clearly we're a little way off trying to > enforce that just yet. In the FEC driver case, there is an integrated DMA (uDMA). It has alignment restrictions, but can otherwise address the full 32-bit range. So something like this should do it right? if (dma_set_mask_and_coherent(dev, DMA_BIT_MASK(32))) { dev_warn(dev, "No suitable DMA available\n"); return -ENODEV; } However, that, as far as I understand, still requires that the bus set up dma_mask properly. Should I be using dma_coerce_mask_and_coherent? -- Stefan > > Robin.