Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 06649C433EF for ; Mon, 22 Nov 2021 18:20:38 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240089AbhKVSXn (ORCPT ); Mon, 22 Nov 2021 13:23:43 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42748 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237217AbhKVSXi (ORCPT ); Mon, 22 Nov 2021 13:23:38 -0500 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 336B6C061574 for ; Mon, 22 Nov 2021 10:20:32 -0800 (PST) Received: from gallifrey.ext.pengutronix.de ([2001:67c:670:201:5054:ff:fe8d:eefb] helo=[IPv6:::1]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1mpDvQ-0004Re-Vt; Mon, 22 Nov 2021 19:20:21 +0100 Message-ID: <82c5da8862abaa430ee52b57e15d29a67106d61f.camel@pengutronix.de> Subject: Re: [PATCH V3 0/9] arm64: imx8mn: Enable more imx8m Nano functions From: Lucas Stach To: Tim Harvey , Adam Ford Cc: Fabio Estevam , Linux ARM Mailing List , Adam Ford-BE , Ariel D'Alessandro , Krzysztof Kozlowski , Device Tree Mailing List , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , NXP Linux Team , open list Date: Mon, 22 Nov 2021 19:20:18 +0100 In-Reply-To: References: <20211104161804.587250-1-aford173@gmail.com> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.40.4 (3.40.4-1.fc34) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-SA-Exim-Connect-IP: 2001:67c:670:201:5054:ff:fe8d:eefb X-SA-Exim-Mail-From: l.stach@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Montag, dem 22.11.2021 um 09:59 -0800 schrieb Tim Harvey: > On Sun, Nov 21, 2021 at 7:25 AM Adam Ford wrote: > > > > On Sun, Nov 21, 2021 at 8:34 AM Adam Ford wrote: > > > > > > On Sun, Nov 21, 2021 at 8:21 AM Fabio Estevam wrote: > > > > > > > > Hi Adam, > > > > > > > > On Sun, Nov 21, 2021 at 11:17 AM Adam Ford wrote: > > > > > > > > > I am using https://source.codeaurora.org/external/imx/imx-atf/log/?h=lf_v2.4 > > > > > > > > > > Since the driver sending SMCC commands to ATF isn't doing that, I > > > > > assume it's safe to use the linux power-domain drivers with the ATF > > > > > from NXP's kernel. > > > > > > > > > > If you can point me to the repo you think I should be using, I'll give it a try. > > > > > > > > Do you know if the mainline TF-A repo v2.5 works too? > > > > https://github.com/ARM-software/arm-trusted-firmware/tree/v2.5 > > > > > > That's good to know. > > > > > > I just built it into U-Boot: > > > > > > NOTICE: BL31: v2.5(release):v2.5 > > > NOTICE: BL31: Built : 08:24:13, Nov 21 2021 > > > > > > The Etnaviv driver is still loading without hanging > > > > > > root@beacon-imx8mn-kit:~# dmesg |grep -i etna > > > [ 12.393936] etnaviv etnaviv: bound 38000000.gpu (ops gpu_ops [etnaviv]) > > > [ 12.400676] etnaviv-gpu 38000000.gpu: model: GC7000, revision: 6203 > > > [ 12.641297] [drm] Initialized etnaviv 1.3.0 20151214 for etnaviv on minor 0 > > > > > > > > > > Tim, > > > > Which version of Nano do you have? Not all Nano SoC's have a GPU from > > looking at the datasheet [1] . I am using MIMX8MN2CVTIZAA (Nano Solo) > > > > [1] - https://www.nxp.com/docs/en/data-sheet/IMX8MNIEC.pdf > > > > Adam, > > The board I have here has MIMX8MN5CVTIZAA so i.MX 8M Nano QuadLite > with 'No GPU' as you expected. > > So I have to add the following to keep my board from hanging after your series: > diff --git a/arch/arm64/boot/dts/freescale/imx8mn-venice-gw7902.dts > b/arch/arm64/boot/dts/freescale/imx8mn-venice-gw7902.dts > index 236f425e1570..0d256a607b7c 100644 > --- a/arch/arm64/boot/dts/freescale/imx8mn-venice-gw7902.dts > +++ b/arch/arm64/boot/dts/freescale/imx8mn-venice-gw7902.dts > @@ -251,6 +251,10 @@ > }; > }; > > +&gpu { > + status = "disabled"; > +}; > + > &i2c1 { > clock-frequency = <100000>; > pinctrl-names = "default"; > > This situation is similar to the one I encountered with the > imx8mm-venice-gw7901 where adding the GPC node caused my board (which > did not power the GPU) to hang until I added disables to the > device-tree with commit 7973009235e2 ("arm64: dts: > imx8mm-venice-gw7901.dts: disable pgc_gpumix"). It feels painful to > have to add patches to keep things from hanging after additional > functionality is added to dt but perhaps that is more common than I > think esp for SoC's like IMX8M which have a lot of lingering support > still coming in. > Yea, it's unfortunate that those patches break your board, but I guess we need to accept this, while there is still a lot of feature work going on. > I don't mind at all submitting the above patch to fix my board after > your series is accepted as I think that having an IMX8MN with 'no gpu' > is perhaps less likely than having one with a GPU and thus we probably > shouldn't mark the node as disabled and force everyone that has a GPU > to go and enable it. > > I wonder however if we should think about adding something to etnaviv > to check the capability so that the same dt could be used with both > CPU variants? etnaviv or really the kernel at all is not the place to handle this. The DT is supposed to describe the hardware and the kernel should be able to trust this description. If there is some way to read the chip capabilities and avoid having too much DT variants in the kernel, the right place to handle this is the software running before the kernel is started, i.e. your bootloader. Barebox for example reads the SCU fuses on i.MX6 and removes the DT nodes for the fused off CPU cores on i.MX6S and i.MX6D. Regards, Lucas