提交 de5b8e8e 编写于 作者: N NeilBrown 提交者: J. Bruce Fields

lockd: fix arg parsing for grace_period and timeout.

If you try to set grace_period or timeout via a module parameter
to lockd, and do this on a big-endian machine where

   sizeof(int) != sizeof(unsigned long)

it won't work.  This number given will be effectively shifted right
by the difference in those two sizes.

So cast kp->arg properly to get correct result.

Cc: stable@kernel.org
Signed-off-by: NNeilBrown <neilb@suse.de>
Signed-off-by: NJ. Bruce Fields <bfields@redhat.com>
上级 cec56c8f
...@@ -440,7 +440,7 @@ static int param_set_##name(const char *val, struct kernel_param *kp) \ ...@@ -440,7 +440,7 @@ static int param_set_##name(const char *val, struct kernel_param *kp) \
__typeof__(type) num = which_strtol(val, &endp, 0); \ __typeof__(type) num = which_strtol(val, &endp, 0); \
if (endp == val || *endp || num < (min) || num > (max)) \ if (endp == val || *endp || num < (min) || num > (max)) \
return -EINVAL; \ return -EINVAL; \
*((int *) kp->arg) = num; \ *((type *) kp->arg) = num; \
return 0; \ return 0; \
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册