Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp8648346rwb; Tue, 13 Dec 2022 08:47:14 -0800 (PST) X-Google-Smtp-Source: AA0mqf4AQBm8SLtrp8cNsBmVKfq6iy6IV8iPxEOGgv+p5x8ngntrk/t0hVp546fbC0R49AzMAsql X-Received: by 2002:a17:903:228b:b0:189:d979:22a with SMTP id b11-20020a170903228b00b00189d979022amr26368803plh.29.1670950034231; Tue, 13 Dec 2022 08:47:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1670950034; cv=none; d=google.com; s=arc-20160816; b=Ama0LHNBejfJogDh0dInDAJE5PrwvKWYwOVCpMtjuCQT89Ooq8vM7+z69b11kRpXyl qUvvDg25WoVh1A3ZoBKy52CQzP0BkBm8kjo6zqGoNGnLDme/Nt2FqmZ85ldcYyLf/zCs T06cnvnrWFHR/URyi54UBz//UHuJ4LCcmtvGvQuuuDJmKr0njtfoubU5pxNyXfvY/45s xPckZKa2eBE2mkMh3BB+TNun17Mkf8uUKTMkwlsTEBAXnlI66zPA1o8u/JzKPCx6ByFf SE9+sziNOg7HfbYFyHtfKJmfeCfQuiKW8+q2wuKcgAh1v+Y+N/f8qocuF/1ON5x+whns X+7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=ksqSWoZG4XNv4Y4DMVsiT2rFuQBSb9BU/xJ4iKDBrqI=; b=N5vRlFq/dQ5xnsRxzNsnRvuEXVKeWwtHTj759LUC+f/2JCX+/msg+Zt/G6JF2ExSQb ZprtzTRUuMZHItZxd8GRtG9m6cgib/xUyO88rZRQHlLUj2QusC3f2Sry8PtVsGs4Vy6R gytPeYlPn5wfR+hJWSdh1tIO/qp+m4aN29UmcYAU9g2xeURPx4dBuJEALSzlUbhiGdb3 mR0ToM/zWI1R+ddb5zKaEJokrTrn9+lfQxNRp5vjEe6QlquZheDcA+DB2gk6kPJmbVCh MNG2ORo01gUFtNw7xm213TscHMuZSlogVkze+UuG8P5Dlxt1q7CAN8h9KEDKNQT0Djfc n/Ow== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q18-20020a17090311d200b0018994773049si155674plh.589.2022.12.13.08.47.04; Tue, 13 Dec 2022 08:47:14 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236173AbiLMP3a (ORCPT + 72 others); Tue, 13 Dec 2022 10:29:30 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59820 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235463AbiLMP3Y (ORCPT ); Tue, 13 Dec 2022 10:29:24 -0500 Received: from mail-oo1-f49.google.com (mail-oo1-f49.google.com [209.85.161.49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BA30C1F2DB; Tue, 13 Dec 2022 07:29:22 -0800 (PST) Received: by mail-oo1-f49.google.com with SMTP id w4-20020a4aaf04000000b004a1ab217cecso2409837oon.13; Tue, 13 Dec 2022 07:29:22 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=ksqSWoZG4XNv4Y4DMVsiT2rFuQBSb9BU/xJ4iKDBrqI=; b=KU88n0HeSrdXC2gHoj1hYWBNeBhQq8CbdcyQKFCKng3ICZuPt49DzG738qvj49C0cV D8OoA94mniCsj4MfFGfi69a1Js0ZkzPXXNi9gf8nIg3J20IBDAugxeD1t+h96vL/QQ/1 HTvYEInktmm7TStmyHX/QQ5o1oJFZa3a8py1fiHSgIQ1CiDybM+4R6JFV5QRNkhcWqBh BFHM+5cbk7KL3fnmevJxaGR63FRAcMOx0cXdXrk5CaoZddx4CaPHfpACOiZQUcF38Tcd nfSs+2EhDmnJ43tt8YrK2DYj4hAjF6cqF40qe40MLUG4I6mZV0I6oYywdFfHl2fOUSe9 5hLw== X-Gm-Message-State: ANoB5pleYiSlNgkNpTmld/3QJ6Bp9DG9RhEMJEeVv1cTZpYiT4C2IKQt Aq+U+JcU3VxJVngnHq0hDQ== X-Received: by 2002:a4a:4f89:0:b0:4a3:51a2:f8ba with SMTP id c131-20020a4a4f89000000b004a351a2f8bamr9897765oob.6.1670945361110; Tue, 13 Dec 2022 07:29:21 -0800 (PST) Received: from robh_at_kernel.org (66-90-144-107.dyn.grandenetworks.net. [66.90.144.107]) by smtp.gmail.com with ESMTPSA id k15-20020a4ad10f000000b0049bfbf7c5a8sm1219110oor.38.2022.12.13.07.29.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 13 Dec 2022 07:29:20 -0800 (PST) Received: (nullmailer pid 1312070 invoked by uid 1000); Tue, 13 Dec 2022 15:29:20 -0000 Date: Tue, 13 Dec 2022 09:29:20 -0600 From: Rob Herring To: Linus Walleij , Alexander Sverdlin Cc: devicetree@vger.kernel.org, Frank Rowand , linux-kernel@vger.kernel.org, Arnd Bergmann , Nikita Shubin , Hartley Sweeten , Lukasz Majewski , Linus Walleij Subject: Re: [PATCH] of: fdt: Honor CONFIG_CMDLINE* even without /chosen node Message-ID: <20221213152920.GA1025576-robh@kernel.org> References: <11af73e05bad75e4ef49067515e3214f6d944b3d.camel@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-1.4 required=5.0 tests=BAYES_00, FREEMAIL_ENVFROM_END_DIGIT,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS autolearn=no 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 On Tue, Dec 13, 2022 at 09:51:33AM +0100, Linus Walleij wrote: > On Mon, Dec 12, 2022 at 7:01 AM Alexander Sverdlin > wrote: > > > I do not read a strict requirement on /chosen node in either ePAPR or in > > Documentation/devicetree. Help text for CONFIG_CMDLINE and > > CONFIG_CMDLINE_EXTEND doesn't make their behavior explicitly dependent on > > the presence of /chosen or the presense of /chosen/bootargs. > > > > However the early check for /chosen and bailing out in > > early_init_dt_scan_chosen() skips CONFIG_CMDLINE handling which is not > > really related to /chosen node or the particular method of passing cmdline > > from bootloader. > > > > This leads to counterintuitive combinations (assuming > > CONFIG_CMDLINE_EXTEND=y): > > > > a) bootargs="foo", CONFIG_CMDLINE="bar" => cmdline=="foo bar" > > b) /chosen missing, CONFIG_CMDLINE="bar" => cmdline=="" > > c) bootargs="", CONFIG_CMDLINE="bar" => cmdline==" bar" > > > > Move CONFIG_CMDLINE handling outside of early_init_dt_scan_chosen() so that > > cases b and c above result in the same cmdline. > > > > Signed-off-by: Alexander Sverdlin > > Excellent debugging Alexander! > Reviewed-by: Linus Walleij > > I also think this should go to stable. We have to be careful there. This could change behavior on a working system. A system taking the cmdline entirely from a built kernel and no initrd is going to be pretty customized already, I think they can carry a patch. What platform is this anyways? This has actually been known for some time[1][2]. My concern in the past (besides wanting all the cmdline manipulation being common) was MIPS. MIPS in particular has lots of sources for cmdline and ways to combine it. However, MIPS has since stopped using this code and does their own parsing (not great either IMO). Rob [1] https://lore.kernel.org/all/CAL_Jsq+CgxWbCMz_qwLbMJS3fYwKyCMBGVS501-5ShXywyDAXA@mail.gmail.com/ [2] https://lore.kernel.org/all/CAL_Jsq+n4e5_ptuh89CJibViGS_bgHz0A+Ki-uwtcGU38+mHXQ@mail.gmail.com/