Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp303911ybi; Thu, 1 Aug 2019 19:27:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqwIn7b6YR9W9K/tm8bxM7roPtjZ+BpL4rDCNqpfOQQ9JiVcA3Gj5qOCDJol6kSPcELPG6sV X-Received: by 2002:a63:e213:: with SMTP id q19mr120352807pgh.180.1564712857921; Thu, 01 Aug 2019 19:27:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564712857; cv=none; d=google.com; s=arc-20160816; b=ISSBuF4HzJ+AJq+zFEqtw5HDZ5dk4fCjtK9NJRMVD1GEO0Bc748HOv1r0pCOeDq0Bb tmBPJGACVN/0zEzPCSfyuNrEeQSPz9M7LNl7AO746vm7Zd5wxhJs7rQkDUrLsqxEaLVN NmjgH0eTWEw+5rTbmLYb1ZcIeUXeAy/DtS2KZ6DTX7mIBXm/K2niWtEa9jOW5qBAft9h OePtktYWGtHA2yyK2f1xbT4J56Xz9zJK7iqg0vBWU+SClLEiI4o4+LYAALN61vFUBA7w SUs/qIBrJefX/ab7bwEvNvSeufDU0KbqerSG6eu66ECbM/O65iY5oUOTw4fg/BSHN169 5lJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=A/JEprKOo3XQFYMzYvttJ9D89Rk+PL3gbi4n0kq+uZY=; b=OR9fO0Yn5mBUfoiEon1YPg9Qfbv55WjLsLDZbIPwA39rtEmALrl6xvnTprx6GGp6sV Tg6UcHWYDBEp/zolek7/2GTXdPI60QjNAGKgpuqO6yoOVEc3Uii0ZeJ6N44S+/wzcfoT C7Nl2bJJ3JsF7Bag2qE0r2dN9iEovCYtmc+r5xHCHfoOzcr0j9GB5+DddWe2XoFdNfk1 oScbDhJ2qcjCvvlBwyS6flzqTpHHJqUK8xOwSxAFTOXxadl6q4J7zBy/PHCMascWP4Ej sKLiqXFFroySqppyigdPgLmRqkYApCKTqpRmC6+/RPxuLSYfQ/s7dktiPlUP2COIpf35 5heA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@alliedtelesis.co.nz header.s=mail181024 header.b=cbGOYfl3; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=alliedtelesis.co.nz Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n13si36033667pff.46.2019.08.01.19.27.22; Thu, 01 Aug 2019 19:27:37 -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=@alliedtelesis.co.nz header.s=mail181024 header.b=cbGOYfl3; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=alliedtelesis.co.nz Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390011AbfHAWuO (ORCPT + 99 others); Thu, 1 Aug 2019 18:50:14 -0400 Received: from gate2.alliedtelesis.co.nz ([202.36.163.20]:46341 "EHLO gate2.alliedtelesis.co.nz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732058AbfHAWuO (ORCPT ); Thu, 1 Aug 2019 18:50:14 -0400 Received: from mmarshal3.atlnz.lc (mmarshal3.atlnz.lc [10.32.18.43]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by gate2.alliedtelesis.co.nz (Postfix) with ESMTPS id 93F9E886BF; Fri, 2 Aug 2019 10:50:10 +1200 (NZST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=alliedtelesis.co.nz; s=mail181024; t=1564699810; bh=A/JEprKOo3XQFYMzYvttJ9D89Rk+PL3gbi4n0kq+uZY=; h=From:To:Cc:Subject:Date; b=cbGOYfl38VKhW+sOjwodouRzMm10xVaFwlej6uzAqQiSiDFunF/khMVqybwYooplf sMS/T6n9k5uO21DBeBZWPpz8O9g5JDOk1SGAmfQFXxQcvORKaeYt8/nZanAIp0PFlc RIiYeZil627gx9p5LlDuzKHlhL+Y38z3vY6QBzzwtZP0tYtn5lMsQui2Tn5upyr4wh tgNJXaXx4Y9dTfcT9ca6OOj7yG05LQ9XxCmbqzgWlOo4rYE53mk4lyyj12mL3svGaU fZuJzMMePaJZo43UWeEroxjMQWRilKT7YHC3OsQW8LbcxBbIXtoNvBlhNByUxhvto8 CoNu30wwXXZqg== Received: from smtp (Not Verified[10.32.16.33]) by mmarshal3.atlnz.lc with Trustwave SEG (v7,5,8,10121) id ; Fri, 02 Aug 2019 10:50:09 +1200 Received: from chrisp-dl.ws.atlnz.lc (chrisp-dl.ws.atlnz.lc [10.33.22.30]) by smtp (Postfix) with ESMTP id 6DED913EC73; Fri, 2 Aug 2019 10:50:12 +1200 (NZST) Received: by chrisp-dl.ws.atlnz.lc (Postfix, from userid 1030) id 3657C1E0504; Fri, 2 Aug 2019 10:50:10 +1200 (NZST) From: Chris Packham To: benh@kernel.crashing.org, paulus@samba.org, mpe@ellerman.id.au, christophe.leroy@c-s.fr, malat@debian.org Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org, Chris Packham Subject: [PATCH v3] powerpc: Support CMDLINE_EXTEND Date: Fri, 2 Aug 2019 10:50:06 +1200 Message-Id: <20190801225006.21952-1-chris.packham@alliedtelesis.co.nz> X-Mailer: git-send-email 2.22.0 MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable x-atlnz-ls: pat Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Bring powerpc in line with other architectures that support extending or overriding the bootloader provided command line. The current behaviour is most like CMDLINE_FROM_BOOTLOADER where the bootloader command line is preferred but the kernel config can provide a fallback so CMDLINE_FROM_BOOTLOADER is the default. CMDLINE_EXTEND can be used to append the CMDLINE from the kernel config to the one provided by the bootloader. Signed-off-by: Chris Packham --- Changes in v3: - don't use BUG_ON in prom_strlcat - rearrange things to eliminate prom_strlcpy Changes in v2: - incorporate ideas from Christope's patch https://patchwork.ozlabs.org/p= atch/1074126/ - support CMDLINE_FORCE arch/powerpc/Kconfig | 20 +++++++++++++++++- arch/powerpc/kernel/prom_init.c | 36 ++++++++++++++++++++++----------- 2 files changed, 43 insertions(+), 13 deletions(-) diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index 77f6ebf97113..d413fe1b4058 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig @@ -852,15 +852,33 @@ config CMDLINE some command-line options at build time by entering them here. In most cases you will need to specify the root device here. =20 +choice + prompt "Kernel command line type" if CMDLINE !=3D "" + default CMDLINE_FROM_BOOTLOADER + +config CMDLINE_FROM_BOOTLOADER + bool "Use bootloader kernel arguments if available" + help + Uses the command-line options passed by the boot loader. If + the boot loader doesn't provide any, the default kernel command + string provided in CMDLINE will be used. + +config CMDLINE_EXTEND + bool "Extend bootloader kernel arguments" + help + The command-line arguments provided by the boot loader will be + appended to the default kernel command string. + config CMDLINE_FORCE bool "Always use the default kernel command string" - depends on CMDLINE_BOOL help Always use the default kernel command string, even if the boot loader passes other arguments to the kernel. This is useful if you cannot or don't want to change the command-line options your boot loader passes to the kernel. =20 +endchoice + config EXTRA_TARGETS string "Additional default image types" help diff --git a/arch/powerpc/kernel/prom_init.c b/arch/powerpc/kernel/prom_i= nit.c index 514707ef6779..1c7010cc6ec9 100644 --- a/arch/powerpc/kernel/prom_init.c +++ b/arch/powerpc/kernel/prom_init.c @@ -298,16 +298,24 @@ static char __init *prom_strstr(const char *s1, con= st char *s2) return NULL; } =20 -static size_t __init prom_strlcpy(char *dest, const char *src, size_t si= ze) -{ - size_t ret =3D prom_strlen(src); +static size_t __init prom_strlcat(char *dest, const char *src, size_t co= unt) +{ + size_t dsize =3D prom_strlen(dest); + size_t len =3D prom_strlen(src); + size_t res =3D dsize + len; + + /* This would be a bug */ + if (dsize >=3D count) + return count; + + dest +=3D dsize; + count -=3D dsize; + if (len >=3D count) + len =3D count-1; + memcpy(dest, src, len); + dest[len] =3D 0; + return res; =20 - if (size) { - size_t len =3D (ret >=3D size) ? size - 1 : ret; - memcpy(dest, src, len); - dest[len] =3D '\0'; - } - return ret; } =20 #ifdef CONFIG_PPC_PSERIES @@ -759,10 +767,14 @@ static void __init early_cmdline_parse(void) =20 prom_cmd_line[0] =3D 0; p =3D prom_cmd_line; - if ((long)prom.chosen > 0) + + if (!IS_ENABLED(CONFIG_CMDLINE_FORCE) && (long)prom.chosen > 0) l =3D prom_getprop(prom.chosen, "bootargs", p, COMMAND_LINE_SIZE-1); - if (IS_ENABLED(CONFIG_CMDLINE_BOOL) && (l <=3D 0 || p[0] =3D=3D '\0')) = /* dbl check */ - prom_strlcpy(prom_cmd_line, CONFIG_CMDLINE, sizeof(prom_cmd_line)); + + if (IS_ENABLED(CONFIG_CMDLINE_EXTEND) || l <=3D 0 || p[0] =3D=3D '\0') + prom_strlcat(prom_cmd_line, " " CONFIG_CMDLINE, + sizeof(prom_cmd_line)); + prom_printf("command line: %s\n", prom_cmd_line); =20 #ifdef CONFIG_PPC64 --=20 2.22.0