blob: fbc6ba047555b80078eb43a442baf21f0fd74e8b [file] [log] [blame]
developer20747c12022-09-16 14:09:40 +08001From 20a76d5a926f067a858a29c91bd21e0ff7ee7f10 Mon Sep 17 00:00:00 2001
developer5ce5b052022-08-17 14:30:50 +08002From: Evelyn Tsai <evelyn.tsai@mediatek.com>
3Date: Wed, 17 Aug 2022 13:40:24 +0800
developer5ce5ea42022-08-31 14:12:29 +08004Subject: [PATCH 1009/1009] mt76: mt7915: add fw_version dump
developer5ce5b052022-08-17 14:30:50 +08005
6---
7 mt76.h | 4 ++++
8 mt76_connac_mcu.c | 9 +++++++++
9 mt7915/mtk_debugfs.c | 19 +++++++++++++++++++
10 3 files changed, 32 insertions(+)
11
12diff --git a/mt76.h b/mt76.h
developer20747c12022-09-16 14:09:40 +080013index e4a248a1..b5453d35 100644
developer5ce5b052022-08-17 14:30:50 +080014--- a/mt76.h
15+++ b/mt76.h
developer20747c12022-09-16 14:09:40 +080016@@ -837,6 +837,10 @@ struct mt76_dev {
developer5ce5b052022-08-17 14:30:50 +080017 struct mt76_usb usb;
18 struct mt76_sdio sdio;
19 };
20+
21+ struct mt76_connac2_patch_hdr *patch_hdr;
22+ struct mt76_connac2_fw_trailer *wm_hdr;
23+ struct mt76_connac2_fw_trailer *wa_hdr;
24 };
25
26 struct mt76_power_limits {
27diff --git a/mt76_connac_mcu.c b/mt76_connac_mcu.c
developer20747c12022-09-16 14:09:40 +080028index ed6c9ebb..c1ed9fef 100644
developer5ce5b052022-08-17 14:30:50 +080029--- a/mt76_connac_mcu.c
30+++ b/mt76_connac_mcu.c
developer20747c12022-09-16 14:09:40 +080031@@ -2875,6 +2875,9 @@ int mt76_connac2_load_ram(struct mt76_dev *dev, const char *fw_wm,
developer5ce5b052022-08-17 14:30:50 +080032 goto out;
33 }
34
35+ dev->wm_hdr = devm_kzalloc(dev->dev, sizeof(*hdr), GFP_KERNEL);
36+ memcpy(dev->wm_hdr, hdr, sizeof(*hdr));
37+
developer20747c12022-09-16 14:09:40 +080038 hdr = (const void *)(fw->data + fw->size - sizeof(*hdr));
39 dev_info(dev->dev, "WM Firmware Version: %.10s, Build Time: %.15s\n",
40 hdr->fw_ver, hdr->build_date);
41@@ -2914,6 +2917,9 @@ int mt76_connac2_load_ram(struct mt76_dev *dev, const char *fw_wm,
developer5ce5b052022-08-17 14:30:50 +080042 goto out;
43 }
44
45+ dev->wa_hdr = devm_kzalloc(dev->dev, sizeof(*hdr), GFP_KERNEL);
46+ memcpy(dev->wa_hdr, hdr, sizeof(*hdr));
47+
48 snprintf(dev->hw->wiphy->fw_version,
49 sizeof(dev->hw->wiphy->fw_version),
50 "%.10s-%.15s", hdr->fw_ver, hdr->build_date);
developer20747c12022-09-16 14:09:40 +080051@@ -2984,6 +2990,9 @@ int mt76_connac2_load_patch(struct mt76_dev *dev, const char *fw_name)
developer5ce5b052022-08-17 14:30:50 +080052 dev_info(dev->dev, "HW/SW Version: 0x%x, Build Time: %.16s\n",
53 be32_to_cpu(hdr->hw_sw_ver), hdr->build_date);
54
55+ dev->patch_hdr = devm_kzalloc(dev->dev, sizeof(*hdr), GFP_KERNEL);
56+ memcpy(dev->patch_hdr, hdr, sizeof(*hdr));
57+
58 for (i = 0; i < be32_to_cpu(hdr->desc.n_region); i++) {
59 struct mt76_connac2_patch_sec *sec;
60 u32 len, addr, mode;
61diff --git a/mt7915/mtk_debugfs.c b/mt7915/mtk_debugfs.c
developer20747c12022-09-16 14:09:40 +080062index 222268fc..ef0c27d2 100644
developer5ce5b052022-08-17 14:30:50 +080063--- a/mt7915/mtk_debugfs.c
64+++ b/mt7915/mtk_debugfs.c
65@@ -2721,6 +2721,22 @@ static int mt7915_agginfo_read_band1(struct seq_file *s, void *data)
66 return 0;
67 }
68
69+static int mt7915_dump_version(struct seq_file *s, void *data)
70+{
71+ struct mt7915_dev *dev = dev_get_drvdata(s->private);
72+ struct mt76_dev *mdev = NULL;
developer20747c12022-09-16 14:09:40 +080073+ seq_printf(s, "Version: 2.2.5.0\n");
developer5ce5b052022-08-17 14:30:50 +080074+
75+ if (!test_bit(MT76_STATE_MCU_RUNNING, &dev->mphy.state))
76+ return 0;
77+
78+ mdev = &dev->mt76;
79+ seq_printf(s, "Rom Patch Build Time: %.16s\n", mdev->patch_hdr->build_date);
80+ seq_printf(s, "WM Patch Build Time: %.16s\n", mdev->wm_hdr->build_date);
81+ seq_printf(s, "WA Patch Build Time: %.16s\n", mdev->wa_hdr->build_date);
82+ return 0;
83+}
84+
85 /*usage: <en> <num> <len>
86 en: BIT(16) 0: sw amsdu 1: hw amsdu
87 num: GENMASK(15, 8) range 1-8
88@@ -2952,6 +2968,9 @@ int mt7915_mtk_init_debugfs(struct mt7915_phy *phy, struct dentry *dir)
89
90 debugfs_create_u8("sku_disable", 0600, dir, &dev->dbg.sku_disable);
91
92+ debugfs_create_devm_seqfile(dev->mt76.dev, "fw_version", dir,
93+ mt7915_dump_version);
94+
95 return 0;
96 }
97 #endif
98--
developer20747c12022-09-16 14:09:40 +0800992.25.1
developer5ce5b052022-08-17 14:30:50 +0800100