linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] powerpc/xive: fix return value of __setup handler
@ 2022-03-13  6:59 Randy Dunlap
  2022-03-14 13:10 ` Cédric Le Goater
  2022-03-21  5:05 ` Michael Ellerman
  0 siblings, 2 replies; 3+ messages in thread
From: Randy Dunlap @ 2022-03-13  6:59 UTC (permalink / raw)
  To: linuxppc-dev; +Cc: Randy Dunlap, patches, Paul Mackerras, Cédric Le Goater

__setup() handlers should return 1 to obsolete_checksetup() in
init/main.c to indicate that the boot option has been handled.
A return of 0 causes the boot option/value to be listed as an Unknown
kernel parameter and added to init's (limited) argument or environment
strings. Also, error return codes don't mean anything to
obsolete_checksetup() -- only non-zero (usually 1) or zero.
So return 1 from xive_off() and xive_store_eoi_cmdline().

Fixes: 243e25112d06 ("powerpc/xive: Native exploitation of the XIVE interrupt controller")
Fixes: c21ee04f11ae ("powerpc/xive: Add a kernel parameter for StoreEOI")
Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
From: Igor Zhbanov <i.zhbanov@omprussia.ru>
Link: lore.kernel.org/r/64644a2f-4a20-bab3-1e15-3b2cdd0defe3@omprussia.ru
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Cc: Cédric Le Goater <clg@kaod.org>
Cc: Paul Mackerras <paulus@samba.org>
---
 arch/powerpc/sysdev/xive/common.c |    6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

--- linux-next-20220310.orig/arch/powerpc/sysdev/xive/common.c
+++ linux-next-20220310/arch/powerpc/sysdev/xive/common.c
@@ -1708,20 +1708,20 @@ __be32 *xive_queue_page_alloc(unsigned i
 static int __init xive_off(char *arg)
 {
 	xive_cmdline_disabled = true;
-	return 0;
+	return 1;
 }
 __setup("xive=off", xive_off);
 
 static int __init xive_store_eoi_cmdline(char *arg)
 {
 	if (!arg)
-		return -EINVAL;
+		return 1;
 
 	if (strncmp(arg, "off", 3) == 0) {
 		pr_info("StoreEOI disabled on kernel command line\n");
 		xive_store_eoi = false;
 	}
-	return 0;
+	return 1;
 }
 __setup("xive.store-eoi=", xive_store_eoi_cmdline);
 

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH] powerpc/xive: fix return value of __setup handler
  2022-03-13  6:59 [PATCH] powerpc/xive: fix return value of __setup handler Randy Dunlap
@ 2022-03-14 13:10 ` Cédric Le Goater
  2022-03-21  5:05 ` Michael Ellerman
  1 sibling, 0 replies; 3+ messages in thread
From: Cédric Le Goater @ 2022-03-14 13:10 UTC (permalink / raw)
  To: Randy Dunlap, linuxppc-dev; +Cc: Paul Mackerras, patches

On 3/13/22 07:59, Randy Dunlap wrote:
> __setup() handlers should return 1 to obsolete_checksetup() in
> init/main.c to indicate that the boot option has been handled.
> A return of 0 causes the boot option/value to be listed as an Unknown
> kernel parameter and added to init's (limited) argument or environment
> strings. Also, error return codes don't mean anything to
> obsolete_checksetup() -- only non-zero (usually 1) or zero.
> So return 1 from xive_off() and xive_store_eoi_cmdline().
> 
> Fixes: 243e25112d06 ("powerpc/xive: Native exploitation of the XIVE interrupt controller")
> Fixes: c21ee04f11ae ("powerpc/xive: Add a kernel parameter for StoreEOI")
> Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
> From: Igor Zhbanov <i.zhbanov@omprussia.ru>
> Link: lore.kernel.org/r/64644a2f-4a20-bab3-1e15-3b2cdd0defe3@omprussia.ru
> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
> Cc: Michael Ellerman <mpe@ellerman.id.au>
> Cc: Cédric Le Goater <clg@kaod.org>
> Cc: Paul Mackerras <paulus@samba.org>

Reviewed-by: Cédric Le Goater <clg@kaod.org>


Thanks,

C.


> ---
>   arch/powerpc/sysdev/xive/common.c |    6 +++---
>   1 file changed, 3 insertions(+), 3 deletions(-)
> 
> --- linux-next-20220310.orig/arch/powerpc/sysdev/xive/common.c
> +++ linux-next-20220310/arch/powerpc/sysdev/xive/common.c
> @@ -1708,20 +1708,20 @@ __be32 *xive_queue_page_alloc(unsigned i
>   static int __init xive_off(char *arg)
>   {
>   	xive_cmdline_disabled = true;
> -	return 0;
> +	return 1;
>   }
>   __setup("xive=off", xive_off);
>   
>   static int __init xive_store_eoi_cmdline(char *arg)
>   {
>   	if (!arg)
> -		return -EINVAL;
> +		return 1;
>   
>   	if (strncmp(arg, "off", 3) == 0) {
>   		pr_info("StoreEOI disabled on kernel command line\n");
>   		xive_store_eoi = false;
>   	}
> -	return 0;
> +	return 1;
>   }
>   __setup("xive.store-eoi=", xive_store_eoi_cmdline);
>   


^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH] powerpc/xive: fix return value of __setup handler
  2022-03-13  6:59 [PATCH] powerpc/xive: fix return value of __setup handler Randy Dunlap
  2022-03-14 13:10 ` Cédric Le Goater
@ 2022-03-21  5:05 ` Michael Ellerman
  1 sibling, 0 replies; 3+ messages in thread
From: Michael Ellerman @ 2022-03-21  5:05 UTC (permalink / raw)
  To: linuxppc-dev, Randy Dunlap; +Cc: Paul Mackerras, patches, Cédric Le Goater

On Sat, 12 Mar 2022 22:59:36 -0800, Randy Dunlap wrote:
> __setup() handlers should return 1 to obsolete_checksetup() in
> init/main.c to indicate that the boot option has been handled.
> A return of 0 causes the boot option/value to be listed as an Unknown
> kernel parameter and added to init's (limited) argument or environment
> strings. Also, error return codes don't mean anything to
> obsolete_checksetup() -- only non-zero (usually 1) or zero.
> So return 1 from xive_off() and xive_store_eoi_cmdline().
> 
> [...]

Applied to powerpc/next.

[1/1] powerpc/xive: fix return value of __setup handler
      https://git.kernel.org/powerpc/c/d64e3eab75a8e1e900c0fda2410a2df8893d8f85

cheers

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2022-03-21  5:08 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-03-13  6:59 [PATCH] powerpc/xive: fix return value of __setup handler Randy Dunlap
2022-03-14 13:10 ` Cédric Le Goater
2022-03-21  5:05 ` Michael Ellerman

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).