Commit 666854ea authored by Bui Quang Minh's avatar Bui Quang Minh Committed by Jakub Kicinski

ice: ensure the copied buf is NUL terminated

Currently, we allocate a count-sized kernel buffer and copy count bytes
from userspace to that buffer. Later, we use sscanf on this buffer but we
don't ensure that the string is terminated inside the buffer, this can lead
to OOB read when using sscanf. Fix this issue by using memdup_user_nul
instead of memdup_user.

Fixes: 96a9a934 ("ice: configure FW logging")
Fixes: 73671c31 ("ice: enable FW logging")
Reviewed-by: default avatarPrzemek Kitszel <przemyslaw.kitszel@intel.com>
Signed-off-by: default avatarBui Quang Minh <minhquangbui99@gmail.com>
Link: https://lore.kernel.org/r/20240424-fix-oob-read-v2-1-f1f1b53a10f4@gmail.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 52afb15e
...@@ -171,7 +171,7 @@ ice_debugfs_module_write(struct file *filp, const char __user *buf, ...@@ -171,7 +171,7 @@ ice_debugfs_module_write(struct file *filp, const char __user *buf,
if (*ppos != 0 || count > 8) if (*ppos != 0 || count > 8)
return -EINVAL; return -EINVAL;
cmd_buf = memdup_user(buf, count); cmd_buf = memdup_user_nul(buf, count);
if (IS_ERR(cmd_buf)) if (IS_ERR(cmd_buf))
return PTR_ERR(cmd_buf); return PTR_ERR(cmd_buf);
...@@ -257,7 +257,7 @@ ice_debugfs_nr_messages_write(struct file *filp, const char __user *buf, ...@@ -257,7 +257,7 @@ ice_debugfs_nr_messages_write(struct file *filp, const char __user *buf,
if (*ppos != 0 || count > 4) if (*ppos != 0 || count > 4)
return -EINVAL; return -EINVAL;
cmd_buf = memdup_user(buf, count); cmd_buf = memdup_user_nul(buf, count);
if (IS_ERR(cmd_buf)) if (IS_ERR(cmd_buf))
return PTR_ERR(cmd_buf); return PTR_ERR(cmd_buf);
...@@ -332,7 +332,7 @@ ice_debugfs_enable_write(struct file *filp, const char __user *buf, ...@@ -332,7 +332,7 @@ ice_debugfs_enable_write(struct file *filp, const char __user *buf,
if (*ppos != 0 || count > 2) if (*ppos != 0 || count > 2)
return -EINVAL; return -EINVAL;
cmd_buf = memdup_user(buf, count); cmd_buf = memdup_user_nul(buf, count);
if (IS_ERR(cmd_buf)) if (IS_ERR(cmd_buf))
return PTR_ERR(cmd_buf); return PTR_ERR(cmd_buf);
...@@ -428,7 +428,7 @@ ice_debugfs_log_size_write(struct file *filp, const char __user *buf, ...@@ -428,7 +428,7 @@ ice_debugfs_log_size_write(struct file *filp, const char __user *buf,
if (*ppos != 0 || count > 5) if (*ppos != 0 || count > 5)
return -EINVAL; return -EINVAL;
cmd_buf = memdup_user(buf, count); cmd_buf = memdup_user_nul(buf, count);
if (IS_ERR(cmd_buf)) if (IS_ERR(cmd_buf))
return PTR_ERR(cmd_buf); return PTR_ERR(cmd_buf);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment