diff mbox series

cpupower: remove stringop-truncation waring

Message ID 20180821120225.3516-1-anders.roxell@linaro.org
State Accepted
Commit 8a7e2d2ea080d10a189a1d611344b0330468ebc3
Headers show
Series cpupower: remove stringop-truncation waring | expand

Commit Message

Anders Roxell Aug. 21, 2018, 12:02 p.m. UTC
The strncpy doesn't null terminate the string because the size is too
short by one byte.

parse.c: In function ‘prepare_default_config’:
parse.c:148:2: warning: ‘strncpy’ output truncated before terminating
    nul copying 8 bytes from a string of the same length
    [-Wstringop-truncation]
  strncpy(config->governor, "ondemand", 8);
  ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Passing the length of the input argument to strncpy() is almost always
wrong and provides no extra benefit over strcpy(), and since 'ondemand'
fits within 15 bytes" and it null terminates the string its safe to use
strcpy().

Fixes: 7fe2f6399a84 ("cpupowerutils - cpufrequtils extended with quite some features")
Signed-off-by: Anders Roxell <anders.roxell@linaro.org>

---
 tools/power/cpupower/bench/parse.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

-- 
2.18.0

Comments

shuah Aug. 27, 2018, 5:46 p.m. UTC | #1
On 08/21/2018 06:02 AM, Anders Roxell wrote:
> The strncpy doesn't null terminate the string because the size is too

> short by one byte.

> 

> parse.c: In function ‘prepare_default_config’:

> parse.c:148:2: warning: ‘strncpy’ output truncated before terminating

>     nul copying 8 bytes from a string of the same length

>     [-Wstringop-truncation]

>   strncpy(config->governor, "ondemand", 8);

>   ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

> 

> Passing the length of the input argument to strncpy() is almost always

> wrong and provides no extra benefit over strcpy(), and since 'ondemand'

> fits within 15 bytes" and it null terminates the string its safe to use

> strcpy().

> 

> Fixes: 7fe2f6399a84 ("cpupowerutils - cpufrequtils extended with quite some features")

> Signed-off-by: Anders Roxell <anders.roxell@linaro.org>

> ---

>  tools/power/cpupower/bench/parse.c | 2 +-

>  1 file changed, 1 insertion(+), 1 deletion(-)

> 

> diff --git a/tools/power/cpupower/bench/parse.c b/tools/power/cpupower/bench/parse.c

> index 9ba8a44ad2a7..91b5b768ffd2 100644

> --- a/tools/power/cpupower/bench/parse.c

> +++ b/tools/power/cpupower/bench/parse.c

> @@ -145,7 +145,7 @@ struct config *prepare_default_config()

>  	config->cpu = 0;

>  	config->prio = SCHED_HIGH;

>  	config->verbose = 0;

> -	strncpy(config->governor, "ondemand", 8);

> +	strcpy(config->governor, "ondemand");

This change is fine, however continuing to use strncpy with sizeof(config->governor).

thanks,
-- Shuah
shuah Aug. 28, 2018, 9:48 p.m. UTC | #2
On 08/28/2018 03:31 AM, Anders Roxell wrote:
> The strncpy doesn't null terminate the string because the size is too

> short by one byte.

> 

> parse.c: In function ‘prepare_default_config’:

> parse.c:148:2: warning: ‘strncpy’ output truncated before terminating

>     nul copying 8 bytes from a string of the same length

>     [-Wstringop-truncation]

>   strncpy(config->governor, "ondemand", 8);

>   ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

> 

> The normal method of passing the length of the destination buffer works

> correctly here.

> 

> Fixes: 7fe2f6399a84 ("cpupowerutils - cpufrequtils extended with quite some features")

> Signed-off-by: Anders Roxell <anders.roxell@linaro.org>

> ---

>  tools/power/cpupower/bench/parse.c | 2 +-

>  1 file changed, 1 insertion(+), 1 deletion(-)

> 

> diff --git a/tools/power/cpupower/bench/parse.c b/tools/power/cpupower/bench/parse.c

> index 9ba8a44ad2a7..84caee38418f 100644

> --- a/tools/power/cpupower/bench/parse.c

> +++ b/tools/power/cpupower/bench/parse.c

> @@ -145,7 +145,7 @@ struct config *prepare_default_config()

>  	config->cpu = 0;

>  	config->prio = SCHED_HIGH;

>  	config->verbose = 0;

> -	strncpy(config->governor, "ondemand", 8);

> +	strncpy(config->governor, "ondemand", sizeof(config->governor));

>  

>  	config->output = stdout;

>  

> 


Thanks. Applied to cpupower git for 4.19-rc3

thanks,
-- Shuah
diff mbox series

Patch

diff --git a/tools/power/cpupower/bench/parse.c b/tools/power/cpupower/bench/parse.c
index 9ba8a44ad2a7..91b5b768ffd2 100644
--- a/tools/power/cpupower/bench/parse.c
+++ b/tools/power/cpupower/bench/parse.c
@@ -145,7 +145,7 @@  struct config *prepare_default_config()
 	config->cpu = 0;
 	config->prio = SCHED_HIGH;
 	config->verbose = 0;
-	strncpy(config->governor, "ondemand", 8);
+	strcpy(config->governor, "ondemand");
 
 	config->output = stdout;