linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] nios2: force the string buffer NULL-terminated
@ 2019-08-05 10:17 Wang Xiayang
  2019-10-02  0:52 ` Ley Foon Tan
  0 siblings, 1 reply; 2+ messages in thread
From: Wang Xiayang @ 2019-08-05 10:17 UTC (permalink / raw)
  Cc: lftan, rppt, nios2-dev, linux-kernel, Wang Xiayang

strncpy() does not ensure NULL-termination when the input string
size equals to the destination buffer size COMMAND_LINE_SIZE.
Besides, grep under arch/ with 'boot_command_line' shows
no other arch-specific code uses strncpy() when copying
boot_command_line.

Use strlcpy() instead.

This issue is identified by a Coccinelle script.

Signed-off-by: Wang Xiayang <xywang.sjtu@sjtu.edu.cn>
---
 arch/nios2/kernel/setup.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/arch/nios2/kernel/setup.c b/arch/nios2/kernel/setup.c
index 6bbd4ae2beb0..4cf35b09c0ec 100644
--- a/arch/nios2/kernel/setup.c
+++ b/arch/nios2/kernel/setup.c
@@ -123,7 +123,7 @@ asmlinkage void __init nios2_boot_init(unsigned r4, unsigned r5, unsigned r6,
 		dtb_passed = r6;
 
 		if (r7)
-			strncpy(cmdline_passed, (char *)r7, COMMAND_LINE_SIZE);
+			strlcpy(cmdline_passed, (char *)r7, COMMAND_LINE_SIZE);
 	}
 #endif
 
@@ -131,10 +131,10 @@ asmlinkage void __init nios2_boot_init(unsigned r4, unsigned r5, unsigned r6,
 
 #ifndef CONFIG_CMDLINE_FORCE
 	if (cmdline_passed[0])
-		strncpy(boot_command_line, cmdline_passed, COMMAND_LINE_SIZE);
+		strlcpy(boot_command_line, cmdline_passed, COMMAND_LINE_SIZE);
 #ifdef CONFIG_NIOS2_CMDLINE_IGNORE_DTB
 	else
-		strncpy(boot_command_line, CONFIG_CMDLINE, COMMAND_LINE_SIZE);
+		strlcpy(boot_command_line, CONFIG_CMDLINE, COMMAND_LINE_SIZE);
 #endif
 #endif
 
-- 
2.11.0


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

* Re: [PATCH] nios2: force the string buffer NULL-terminated
  2019-08-05 10:17 [PATCH] nios2: force the string buffer NULL-terminated Wang Xiayang
@ 2019-10-02  0:52 ` Ley Foon Tan
  0 siblings, 0 replies; 2+ messages in thread
From: Ley Foon Tan @ 2019-10-02  0:52 UTC (permalink / raw)
  To: Wang Xiayang; +Cc: rppt, linux-kernel

On Mon, 2019-08-05 at 18:17 +0800, Wang Xiayang wrote:
> strncpy() does not ensure NULL-termination when the input string
> size equals to the destination buffer size COMMAND_LINE_SIZE.
> Besides, grep under arch/ with 'boot_command_line' shows
> no other arch-specific code uses strncpy() when copying
> boot_command_line.
> 
> Use strlcpy() instead.
> 
> This issue is identified by a Coccinelle script.
> 
> Signed-off-by: Wang Xiayang <xywang.sjtu@sjtu.edu.cn>
Merged to v5.4-rc1. Thanks.


Acked-by: Ley Foon Tan <ley.foon.tan@intel.com>


> ---
>  arch/nios2/kernel/setup.c | 6 +++---
>  1 file changed, 3 insertions(+), 3 deletions(-)
> 
> diff --git a/arch/nios2/kernel/setup.c b/arch/nios2/kernel/setup.c
> index 6bbd4ae2beb0..4cf35b09c0ec 100644
> --- a/arch/nios2/kernel/setup.c
> +++ b/arch/nios2/kernel/setup.c
> @@ -123,7 +123,7 @@ asmlinkage void __init nios2_boot_init(unsigned
> r4, unsigned r5, unsigned r6,
>                 dtb_passed = r6;
> 
>                 if (r7)
> -                       strncpy(cmdline_passed, (char *)r7,
> COMMAND_LINE_SIZE);
> +                       strlcpy(cmdline_passed, (char *)r7,
> COMMAND_LINE_SIZE);
>         }
>  #endif
> 
> @@ -131,10 +131,10 @@ asmlinkage void __init nios2_boot_init(unsigned
> r4, unsigned r5, unsigned r6,
> 
>  #ifndef CONFIG_CMDLINE_FORCE
>         if (cmdline_passed[0])
> -               strncpy(boot_command_line, cmdline_passed,
> COMMAND_LINE_SIZE);
> +               strlcpy(boot_command_line, cmdline_passed,
> COMMAND_LINE_SIZE);
>  #ifdef CONFIG_NIOS2_CMDLINE_IGNORE_DTB
>         else
> -               strncpy(boot_command_line, CONFIG_CMDLINE,
> COMMAND_LINE_SIZE);
> +               strlcpy(boot_command_line, CONFIG_CMDLINE,
> COMMAND_LINE_SIZE);
>  #endif
>  #endif
> 
> --
> 2.11.0
> 
> 
> ________________________________
> 
> Confidentiality Notice.
> This message may contain information that is confidential or
> otherwise protected from disclosure. If you are not the intended
> recipient, you are hereby notified that any use, disclosure,
> dissemination, distribution, or copying of this message, or any
> attachments, is strictly prohibited. If you have received this
> message in error, please advise the sender by reply e-mail, and
> delete the message and any attachments. Thank you.

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

end of thread, other threads:[~2019-10-02  0:53 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-08-05 10:17 [PATCH] nios2: force the string buffer NULL-terminated Wang Xiayang
2019-10-02  0:52 ` Ley Foon Tan

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).