mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
Revert "niu: fix missing checks of niu_pci_eeprom_read"
This reverts commit26fd962bde
. Because of recent interactions with developers from @umn.edu, all commits from them have been recently re-reviewed to ensure if they were correct or not. Upon review, this commit was found to be incorrect for the reasons below, so it must be reverted. It will be fixed up "correctly" in a later kernel change. The change here was incorrect. While it is nice to check if niu_pci_eeprom_read() succeeded or not when using the data, any error that might have happened was not propagated upwards properly, causing the kernel to assume that these reads were successful, which results in invalid data in the buffer that was to contain the successfully read data. Cc: Kangjie Lu <kjlu@umn.edu> Cc: Shannon Nelson <shannon.lee.nelson@gmail.com> Cc: David S. Miller <davem@davemloft.net> Fixes:26fd962bde
("niu: fix missing checks of niu_pci_eeprom_read") Cc: stable <stable@vger.kernel.org> Link: https://lore.kernel.org/r/20210503115736.2104747-23-gregkh@linuxfoundation.org Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
0c32a96d00
commit
7930742d6a
@ -8097,8 +8097,6 @@ static int niu_pci_vpd_scan_props(struct niu *np, u32 start, u32 end)
|
|||||||
start += 3;
|
start += 3;
|
||||||
|
|
||||||
prop_len = niu_pci_eeprom_read(np, start + 4);
|
prop_len = niu_pci_eeprom_read(np, start + 4);
|
||||||
if (prop_len < 0)
|
|
||||||
return prop_len;
|
|
||||||
err = niu_pci_vpd_get_propname(np, start + 5, namebuf, 64);
|
err = niu_pci_vpd_get_propname(np, start + 5, namebuf, 64);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
@ -8143,12 +8141,8 @@ static int niu_pci_vpd_scan_props(struct niu *np, u32 start, u32 end)
|
|||||||
netif_printk(np, probe, KERN_DEBUG, np->dev,
|
netif_printk(np, probe, KERN_DEBUG, np->dev,
|
||||||
"VPD_SCAN: Reading in property [%s] len[%d]\n",
|
"VPD_SCAN: Reading in property [%s] len[%d]\n",
|
||||||
namebuf, prop_len);
|
namebuf, prop_len);
|
||||||
for (i = 0; i < prop_len; i++) {
|
for (i = 0; i < prop_len; i++)
|
||||||
err = niu_pci_eeprom_read(np, off + i);
|
*prop_buf++ = niu_pci_eeprom_read(np, off + i);
|
||||||
if (err >= 0)
|
|
||||||
*prop_buf = err;
|
|
||||||
++prop_buf;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
start += len;
|
start += len;
|
||||||
|
Loading…
Reference in New Issue
Block a user