blob: b06c5403dd89b38078e58ccecf36676766c76a21 [file] [log] [blame]
developerd8126d12023-02-17 11:50:45 +08001From 2cd8e8385970f43311305c6849b31cd86cc40f5a Mon Sep 17 00:00:00 2001
developere2cfb522022-12-08 18:09:45 +08002From: StanleyYP Wang <StanleyYP.Wang@mediatek.com>
3Date: Thu, 13 Oct 2022 13:22:05 +0800
developer60a3d662023-02-07 15:24:34 +08004Subject: [PATCH 1127/1133] mt76: mt7915: add E3 re-bonding for low yield rate
developere2cfb522022-12-08 18:09:45 +08005 issue
6
7Signed-off-by: StanleyYP Wang <StanleyYP.Wang@mediatek.com>
8---
9 mt7915/eeprom.c | 27 ++++++++++++++++++++++++++-
10 mt7915/mcu.c | 13 ++++++++++---
11 mt7915/mt7915.h | 3 ++-
12 3 files changed, 38 insertions(+), 5 deletions(-)
13
14diff --git a/mt7915/eeprom.c b/mt7915/eeprom.c
developer60a3d662023-02-07 15:24:34 +080015index 54803e8e..849275e1 100644
developere2cfb522022-12-08 18:09:45 +080016--- a/mt7915/eeprom.c
17+++ b/mt7915/eeprom.c
developerc5ce7502022-12-19 11:33:22 +080018@@ -132,7 +132,7 @@ static int mt7915_eeprom_load(struct mt7915_dev *dev)
developeraa5b1b22022-12-13 17:05:25 +080019 /* read eeprom data from efuse */
20 block_num = DIV_ROUND_UP(eeprom_size, eeprom_blk_size);
21 for (i = 0; i < block_num; i++) {
22- ret = mt7915_mcu_get_eeprom(dev, i * eeprom_blk_size);
23+ ret = mt7915_mcu_get_eeprom(dev, i * eeprom_blk_size, NULL);
24 if (ret < 0)
25 return ret;
26 }
developerc5ce7502022-12-19 11:33:22 +080027@@ -239,6 +239,29 @@ void mt7915_eeprom_parse_hw_cap(struct mt7915_dev *dev,
developere2cfb522022-12-08 18:09:45 +080028 dev->chainshift = hweight8(dev->mphy.chainmask);
29 }
30
31+void mt7915_eeprom_rebonding(struct mt7915_dev *dev)
32+{
33+#define MT7976_ADIE_MASK BIT(1)
34+#define MT7986_ADIE1_EFFUSE_OFFSET 0x1000
35+#define MT7986_ADIE1_MT7976C_OFFSET 0x270
36+#define MT7986_ADIE1_E3_OFFSET 0x271
37+ u32 adie_offset, sku = mt7915_check_adie(dev, true);
38+ u8 read_buf, *eeprom = dev->mt76.eeprom.data;
39+
40+ if (!(sku & MT7976_ADIE_MASK))
41+ return;
42+
43+ adie_offset = (sku == MT7976_DUAL_ADIE) ? MT7986_ADIE1_EFFUSE_OFFSET : 0;
44+
45+ /* 7976 A-Die, To identify MT7976C */
46+ mt7915_mcu_get_eeprom(dev, MT7986_ADIE1_MT7976C_OFFSET + adie_offset, &read_buf);
47+ eeprom[MT7986_ADIE1_MT7976C_OFFSET] = read_buf;
48+
49+ /* E3 re-binding */
50+ mt7915_mcu_get_eeprom(dev, MT7986_ADIE1_E3_OFFSET + adie_offset, &read_buf);
51+ eeprom[MT7986_ADIE1_E3_OFFSET] = read_buf;
52+}
53+
54 int mt7915_eeprom_init(struct mt7915_dev *dev)
55 {
56 int ret;
developerc5ce7502022-12-19 11:33:22 +080057@@ -275,6 +298,8 @@ int mt7915_eeprom_init(struct mt7915_dev *dev)
developere2cfb522022-12-08 18:09:45 +080058 return ret;
59 }
60
61+ mt7915_eeprom_rebonding(dev);
62+
63 ret = mt7915_eeprom_load_precal(dev);
64 if (ret)
65 return ret;
66diff --git a/mt7915/mcu.c b/mt7915/mcu.c
developerd8126d12023-02-17 11:50:45 +080067index ebe00300..292351fb 100644
developere2cfb522022-12-08 18:09:45 +080068--- a/mt7915/mcu.c
69+++ b/mt7915/mcu.c
developerd8126d12023-02-17 11:50:45 +080070@@ -2886,7 +2886,7 @@ int mt7915_mcu_set_eeprom(struct mt7915_dev *dev, bool flash_mode)
developere2cfb522022-12-08 18:09:45 +080071 &req, sizeof(req), true);
72 }
73
74-int mt7915_mcu_get_eeprom(struct mt7915_dev *dev, u32 offset)
75+int mt7915_mcu_get_eeprom(struct mt7915_dev *dev, u32 offset, u8 *read_buf)
76 {
77 struct mt7915_mcu_eeprom_info req = {
78 .addr = cpu_to_le32(round_down(offset,
developerd8126d12023-02-17 11:50:45 +080079@@ -2904,8 +2904,15 @@ int mt7915_mcu_get_eeprom(struct mt7915_dev *dev, u32 offset)
developere2cfb522022-12-08 18:09:45 +080080 return ret;
81
82 res = (struct mt7915_mcu_eeprom_info *)skb->data;
83- buf = dev->mt76.eeprom.data + le32_to_cpu(res->addr);
84- memcpy(buf, res->data, MT7915_EEPROM_BLOCK_SIZE);
85+
86+ if (read_buf) {
87+ u32 offs = offset % MT7915_EEPROM_BLOCK_SIZE;
88+ *read_buf = res->data[offs];
89+ } else {
90+ buf = dev->mt76.eeprom.data + le32_to_cpu(res->addr);
91+ memcpy(buf, res->data, MT7915_EEPROM_BLOCK_SIZE);
92+ }
93+
94 dev_kfree_skb(skb);
95
96 return 0;
97diff --git a/mt7915/mt7915.h b/mt7915/mt7915.h
developerd8126d12023-02-17 11:50:45 +080098index fbe68ef9..332f63b5 100644
developere2cfb522022-12-08 18:09:45 +080099--- a/mt7915/mt7915.h
100+++ b/mt7915/mt7915.h
developerd8126d12023-02-17 11:50:45 +0800101@@ -558,6 +558,7 @@ u32 mt7915_wed_init_buf(void *ptr, dma_addr_t phys, int token_id);
developere2cfb522022-12-08 18:09:45 +0800102
103 int mt7915_register_device(struct mt7915_dev *dev);
104 void mt7915_unregister_device(struct mt7915_dev *dev);
105+void mt7915_eeprom_rebonding(struct mt7915_dev *dev);
106 int mt7915_eeprom_init(struct mt7915_dev *dev);
107 void mt7915_eeprom_parse_hw_cap(struct mt7915_dev *dev,
108 struct mt7915_phy *phy);
developerd8126d12023-02-17 11:50:45 +0800109@@ -612,7 +613,7 @@ int mt7915_mcu_set_fixed_rate_ctrl(struct mt7915_dev *dev,
developere2cfb522022-12-08 18:09:45 +0800110 struct ieee80211_sta *sta,
111 void *data, u32 field);
112 int mt7915_mcu_set_eeprom(struct mt7915_dev *dev, bool flash_mode);
113-int mt7915_mcu_get_eeprom(struct mt7915_dev *dev, u32 offset);
114+int mt7915_mcu_get_eeprom(struct mt7915_dev *dev, u32 offset, u8 *read_buf);
115 int mt7915_mcu_get_eeprom_free_block(struct mt7915_dev *dev, u8 *block_num);
116 int mt7915_mcu_set_mac(struct mt7915_dev *dev, int band, bool enable,
117 bool hdr_trans);
118--
developer60a3d662023-02-07 15:24:34 +08001192.18.0
developere2cfb522022-12-08 18:09:45 +0800120