mirror of
https://github.com/torvalds/linux.git
synced 2026-06-05 04:56:13 +02:00
wifi: mt76: mt7915: add chip id condition in mt7915_check_eeprom()
When flash mode is enabled, and the eeprom data in the flash is not for the current chipset, it'll still be checked valid, and the default eeprom bin won't be loaded. (e.g., mt7915 NIC inserted with mt7916 eeprom data in the flash.) Fix this kind of case by adding chip id into consideration in mt7915_check_eeprom(). Reported-by: Cheng-Ji Li <cheng-ji.li@mediatek.com> Signed-off-by: Shayne Chen <shayne.chen@mediatek.com> Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
2f2d86309e
commit
3b2f02861f
|
|
@ -33,11 +33,14 @@ static int mt7915_check_eeprom(struct mt7915_dev *dev)
|
|||
u8 *eeprom = dev->mt76.eeprom.data;
|
||||
u16 val = get_unaligned_le16(eeprom);
|
||||
|
||||
#define CHECK_EEPROM_ERR(match) (match ? 0 : -EINVAL)
|
||||
switch (val) {
|
||||
case 0x7915:
|
||||
return CHECK_EEPROM_ERR(is_mt7915(&dev->mt76));
|
||||
case 0x7916:
|
||||
return CHECK_EEPROM_ERR(is_mt7916(&dev->mt76));
|
||||
case 0x7986:
|
||||
return 0;
|
||||
return CHECK_EEPROM_ERR(is_mt7986(&dev->mt76));
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user