hwmon: (dell-smm) Fail in ioctl I8K_BIOS_VERSION when bios version is not a number
ABI of I8K_BIOS_VERSION ioctl can return only number. But new BIOS versions contain also other characters, which does not fit into that ABI. So in case of non digit values return -EINVAL. Reported-by: Mario Limonciello <Mario_Limonciello@dell.com> Signed-off-by: Pali Rohár <pali.rohar@gmail.com> Signed-off-by: Guenter Roeck <linux@roeck-us.net>
This commit is contained in:
parent
5edb56491d
commit
053ea64081
|
@ -35,6 +35,7 @@
|
||||||
#include <linux/uaccess.h>
|
#include <linux/uaccess.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
|
#include <linux/ctype.h>
|
||||||
|
|
||||||
#include <linux/i8k.h>
|
#include <linux/i8k.h>
|
||||||
|
|
||||||
|
@ -387,6 +388,10 @@ i8k_ioctl_unlocked(struct file *fp, unsigned int cmd, unsigned long arg)
|
||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case I8K_BIOS_VERSION:
|
case I8K_BIOS_VERSION:
|
||||||
|
if (!isdigit(bios_version[0]) || !isdigit(bios_version[1]) ||
|
||||||
|
!isdigit(bios_version[2]))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
val = (bios_version[0] << 16) |
|
val = (bios_version[0] << 16) |
|
||||||
(bios_version[1] << 8) | bios_version[2];
|
(bios_version[1] << 8) | bios_version[2];
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue