提交 555d5b70 编写于 作者: G Guillaume Nault 提交者: David S. Miller

ppp: clarify parsing of user supplied data in ppp_set_compress()

* Split big conditional statement.
  * Check (data.length <= CCP_MAX_OPTION_LENGTH) only once.
  * Don't read ccp_option[1] if not initialised.

Reading uninitialised ccp_option[1] was harmless, because this could
only happen when data.length was 0 or 1. So even then, we couldn't pass
the (ccp_option[1] < 2 || ccp_option[1] > data.length) test anyway.
Signed-off-by: NGuillaume Nault <g.nault@alphalink.fr>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 4fee7dab
...@@ -2429,13 +2429,15 @@ ppp_set_compress(struct ppp *ppp, unsigned long arg) ...@@ -2429,13 +2429,15 @@ ppp_set_compress(struct ppp *ppp, unsigned long arg)
unsigned char ccp_option[CCP_MAX_OPTION_LENGTH]; unsigned char ccp_option[CCP_MAX_OPTION_LENGTH];
err = -EFAULT; err = -EFAULT;
if (copy_from_user(&data, (void __user *) arg, sizeof(data)) || if (copy_from_user(&data, (void __user *) arg, sizeof(data)))
(data.length <= CCP_MAX_OPTION_LENGTH &&
copy_from_user(ccp_option, (void __user *) data.ptr, data.length)))
goto out; goto out;
if (data.length > CCP_MAX_OPTION_LENGTH)
goto out;
if (copy_from_user(ccp_option, (void __user *) data.ptr, data.length))
goto out;
err = -EINVAL; err = -EINVAL;
if (data.length > CCP_MAX_OPTION_LENGTH || if (data.length < 2 || ccp_option[1] < 2 || ccp_option[1] > data.length)
ccp_option[1] < 2 || ccp_option[1] > data.length)
goto out; goto out;
cp = try_then_request_module( cp = try_then_request_module(
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册