From: Steven Rostedt Impact: clean up This removes the open coded parsing of a word sent in by the user and replaces it with copy_strtok_from_user. Also removes cnt < 0 check since cnt is unsigned. Also uses (*ppos) += cnt, instead of file->pos += cnt. Signed-off-by: Steven Rostedt --- kernel/trace/ftrace.c | 48 ++++++++++++++++-------------------------------- 1 files changed, 16 insertions(+), 32 deletions(-) diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 963dc14..4ed0a8e 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c @@ -2083,10 +2083,9 @@ ftrace_graph_write(struct file *file, const char __user *ubuf, unsigned long *array; size_t read = 0; ssize_t ret; - int index = 0; - char ch; + int copied; - if (!cnt || cnt < 0) + if (!cnt) return 0; mutex_lock(&graph_lock); @@ -2102,48 +2101,33 @@ ftrace_graph_write(struct file *file, const char __user *ubuf, } else array = file->private_data; - ret = get_user(ch, ubuf++); - if (ret) + ret = copy_strtok_from_user(buffer, ubuf, FTRACE_BUFF_MAX + 1, + cnt, &copied, SPACES); + if (ret < 0) goto out; - read++; - cnt--; - /* skip white space */ - while (cnt && isspace(ch)) { - ret = get_user(ch, ubuf++); - if (ret) - goto out; - read++; - cnt--; + /* We only read white space. */ + if (!copied) { + (*ppos) += cnt; + ret = cnt; + goto out; } - if (isspace(ch)) { - *ppos += read; - ret = read; + /* Check if we hit a terminating space */ + if (buffer[copied - 1] != 0) { + /* This does not deal with split words */ + ret = -EINVAL; goto out; } - while (cnt && !isspace(ch)) { - if (index < FTRACE_BUFF_MAX) - buffer[index++] = ch; - else { - ret = -EINVAL; - goto out; - } - ret = get_user(ch, ubuf++); - if (ret) - goto out; - read++; - cnt--; - } - buffer[index] = 0; + read = ret; /* we allow only one expression at a time */ ret = ftrace_set_func(array, &ftrace_graph_count, buffer); if (ret) goto out; - file->f_pos += read; + (*ppos) += read; ret = read; out: -- 1.5.6.5 -- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/