blob: 04e6733f4825fe2df3139d02292158c16cefcda0 [file] [log] [blame]
developerbbd45e12023-05-19 08:22:06 +08001From db8ca122f32340716f8f130485f7df58cc0d436a Mon Sep 17 00:00:00 2001
developerc9233442023-04-04 06:06:17 +08002From: StanleyYP Wang <StanleyYP.Wang@mediatek.com>
developerc670d342023-04-06 15:04:19 +08003Date: Thu, 30 Mar 2023 15:12:37 +0800
developerbbd45e12023-05-19 08:22:06 +08004Subject: [PATCH 1025/1033] wifi: mt76: mt7915: add E3 re-bonding for low yield
developerc9233442023-04-04 06:06:17 +08005 rate issue
6
7Signed-off-by: StanleyYP Wang <StanleyYP.Wang@mediatek.com>
8---
developerc670d342023-04-06 15:04:19 +08009 mt7915/eeprom.c | 28 ++++++++++++++++++++++++++++
10 mt7915/mt7915.h | 1 +
11 2 files changed, 29 insertions(+)
developerc9233442023-04-04 06:06:17 +080012
13diff --git a/mt7915/eeprom.c b/mt7915/eeprom.c
developerbbd45e12023-05-19 08:22:06 +080014index fd08d42..3b44a9d 100644
developerc9233442023-04-04 06:06:17 +080015--- a/mt7915/eeprom.c
16+++ b/mt7915/eeprom.c
developerbbd45e12023-05-19 08:22:06 +080017@@ -244,6 +244,32 @@ void mt7915_eeprom_parse_hw_cap(struct mt7915_dev *dev,
developerc9233442023-04-04 06:06:17 +080018 dev->chainshift = hweight8(dev->mphy.chainmask);
19 }
20
21+void mt7915_eeprom_rebonding(struct mt7915_dev *dev)
22+{
23+#define MT7976_ADIE_MASK BIT(1)
24+#define MT7986_ADIE1_EFFUSE_OFFSET 0x1000
25+#define MT7986_ADIE1_MT7976C_OFFSET 0x270
26+#define MT7986_ADIE1_E3_OFFSET 0x271
developerc670d342023-04-06 15:04:19 +080027+ u32 adie_offset, offset, sku = mt7915_check_adie(dev, true);
28+ u8 read_buf[MT7915_EEPROM_BLOCK_SIZE], *eeprom = dev->mt76.eeprom.data;
29+
developerc9233442023-04-04 06:06:17 +080030+
31+ if (!(sku & MT7976_ADIE_MASK))
32+ return;
33+
34+ adie_offset = (sku == MT7976_DUAL_ADIE) ? MT7986_ADIE1_EFFUSE_OFFSET : 0;
35+
36+ /* 7976 A-Die, To identify MT7976C */
developerc670d342023-04-06 15:04:19 +080037+ offset = MT7986_ADIE1_MT7976C_OFFSET + adie_offset;
38+ mt7915_mcu_get_eeprom(dev, offset, read_buf);
39+ eeprom[MT7986_ADIE1_MT7976C_OFFSET] = read_buf[offset % MT7915_EEPROM_BLOCK_SIZE];
developerc9233442023-04-04 06:06:17 +080040+
41+ /* E3 re-binding */
developerc670d342023-04-06 15:04:19 +080042+ offset = MT7986_ADIE1_E3_OFFSET + adie_offset;
43+ mt7915_mcu_get_eeprom(dev, offset, read_buf);
44+ eeprom[MT7986_ADIE1_E3_OFFSET] = read_buf[offset % MT7915_EEPROM_BLOCK_SIZE];
developerc9233442023-04-04 06:06:17 +080045+}
46+
47 int mt7915_eeprom_init(struct mt7915_dev *dev)
48 {
49 int ret;
developerbbd45e12023-05-19 08:22:06 +080050@@ -280,6 +306,8 @@ int mt7915_eeprom_init(struct mt7915_dev *dev)
developerc9233442023-04-04 06:06:17 +080051 return ret;
52 }
53
54+ mt7915_eeprom_rebonding(dev);
55+
56 ret = mt7915_eeprom_load_precal(dev);
57 if (ret)
58 return ret;
developerc9233442023-04-04 06:06:17 +080059diff --git a/mt7915/mt7915.h b/mt7915/mt7915.h
developerbbd45e12023-05-19 08:22:06 +080060index b3a0f2a..e2f196b 100644
developerc9233442023-04-04 06:06:17 +080061--- a/mt7915/mt7915.h
62+++ b/mt7915/mt7915.h
developerbbd45e12023-05-19 08:22:06 +080063@@ -554,6 +554,7 @@ u32 mt7915_wed_init_buf(void *ptr, dma_addr_t phys, int token_id);
developerc9233442023-04-04 06:06:17 +080064
65 int mt7915_register_device(struct mt7915_dev *dev);
66 void mt7915_unregister_device(struct mt7915_dev *dev);
67+void mt7915_eeprom_rebonding(struct mt7915_dev *dev);
68 int mt7915_eeprom_init(struct mt7915_dev *dev);
69 void mt7915_eeprom_parse_hw_cap(struct mt7915_dev *dev,
70 struct mt7915_phy *phy);
developerc9233442023-04-04 06:06:17 +080071--
developerc670d342023-04-06 15:04:19 +0800722.18.0
developerc9233442023-04-04 06:06:17 +080073