mirror of
https://github.com/rd-stuffs/msm-4.14.git
synced 2025-02-20 11:45:48 +08:00
tracing: Make sure variable string fields are NULL-terminated
The strncpy() currently being used for variable string fields can result in a lack of termination if the string length is equal to the field size. Use the safer strscpy() instead, which will guarantee termination. Signed-off-by: Tom Zanussi <tom.zanussi@linux.intel.com> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Signed-off-by: azrim <mirzaspc@gmail.com>
This commit is contained in:
parent
40b04275b1
commit
275dac7c56
@ -669,7 +669,7 @@ static notrace void trace_event_raw_event_synth(void *__data,
|
||||
char *str_val = (char *)(long)var_ref_vals[var_ref_idx + i];
|
||||
char *str_field = (char *)&entry->fields[n_u64];
|
||||
|
||||
strncpy(str_field, str_val, STR_VAR_LEN_MAX);
|
||||
strscpy(str_field, str_val, STR_VAR_LEN_MAX);
|
||||
n_u64 += STR_VAR_LEN_MAX / sizeof(u64);
|
||||
} else {
|
||||
entry->fields[n_u64] = var_ref_vals[var_ref_idx + i];
|
||||
@ -3092,7 +3092,7 @@ static inline void __update_field_vars(struct tracing_map_elt *elt,
|
||||
char *str = elt_data->field_var_str[j++];
|
||||
char *val_str = (char *)(uintptr_t)var_val;
|
||||
|
||||
strncpy(str, val_str, STR_VAR_LEN_MAX);
|
||||
strscpy(str, val_str, STR_VAR_LEN_MAX);
|
||||
var_val = (u64)(uintptr_t)str;
|
||||
}
|
||||
tracing_map_set_var(elt, var_idx, var_val);
|
||||
|
Loading…
x
Reference in New Issue
Block a user