diff options
| author | Guenter Roeck <[email protected]> | 2018-09-06 09:47:51 -0700 | 
|---|---|---|
| committer | Guenter Roeck <[email protected]> | 2018-09-07 09:33:36 -0700 | 
| commit | c793279c77035053e67937f5743c6ebfc303e7c5 (patch) | |
| tree | fd73514bf79e780e793b70e7bd5ae32b481f3d61 /drivers/usb/cdns3/cdns3-pci-wrap.c | |
| parent | e3f3d7ab00cd459d0f7a839758a4542f4d4b8ac8 (diff) | |
hwmon: (nct6775) Fix access to fan pulse registers
Not all fans have a fan pulse register. This can result in reading
beyond the end of REG_FAN_PULSES and FAN_PULSE_SHIFT arrays,
and was reported by smatch as possible error.
1672          for (i = 0; i < ARRAY_SIZE(data->rpm); i++) {
                              ^^^^^^^^^^^^^^^^^^^^^^^^
			      This is a 7 element array.
...
1685                  data->fan_pulses[i] =
1686                    (nct6775_read_value(data, data->REG_FAN_PULSES[i])
1687                          >> data->FAN_PULSE_SHIFT[i]) & 0x03;
                                 ^^^^^^^^^^^^^^^^^^^^^^^^
				 FAN_PULSE_SHIFT is either 5 or 6
				 elements.
To fix the problem, we have to ensure that all REG_FAN_PULSES and
FAN_PULSE_SHIFT have the appropriate length, and that REG_FAN_PULSES
is only read if the register actually exists.
Fixes: 6c009501ff200 ("hwmon: (nct6775) Add support for NCT6102D/6106D")
Reported-by: Dan Carpenter <[email protected]>
Signed-off-by: Guenter Roeck <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-pci-wrap.c')
0 files changed, 0 insertions, 0 deletions