Lines Matching refs:dev

14 static ssize_t mt7921_thermal_temp_show(struct device *dev,  in mt7921_thermal_temp_show()  argument
20 struct mt792x_phy *phy = dev_get_drvdata(dev); in mt7921_thermal_temp_show()
21 struct mt792x_dev *mdev = phy->dev; in mt7921_thermal_temp_show()
54 name = devm_kasprintf(&wiphy->dev, GFP_KERNEL, "mt7921_%s", in mt7921_thermal_init()
57 hwmon = devm_hwmon_device_register_with_groups(&wiphy->dev, name, phy, in mt7921_thermal_init()
71 struct mt792x_dev *dev = mt792x_hw_dev(hw); in mt7921_regd_notifier() local
73 memcpy(dev->mt76.alpha2, request->alpha2, sizeof(dev->mt76.alpha2)); in mt7921_regd_notifier()
74 dev->mt76.region = request->dfs_region; in mt7921_regd_notifier()
75 dev->country_ie_env = request->country_ie_env; in mt7921_regd_notifier()
77 mt792x_mutex_acquire(dev); in mt7921_regd_notifier()
78 mt7921_mcu_set_clc(dev, request->alpha2, request->country_ie_env); in mt7921_regd_notifier()
81 mt792x_mutex_release(dev); in mt7921_regd_notifier()
84 int mt7921_mac_init(struct mt792x_dev *dev) in mt7921_mac_init() argument
88 mt76_rmw_field(dev, MT_MDP_DCR1, MT_MDP_DCR1_MAX_RX_LEN, 1536); in mt7921_mac_init()
90 mt76_set(dev, MT_MDP_DCR0, MT_MDP_DCR0_DAMSDU_EN); in mt7921_mac_init()
92 mt76_set(dev, MT_MDP_DCR0, MT_MDP_DCR0_RX_HDR_TRANS_EN); in mt7921_mac_init()
95 mt7921_mac_wtbl_update(dev, i, in mt7921_mac_init()
98 mt792x_mac_init_band(dev, i); in mt7921_mac_init()
100 return mt76_connac_mcu_set_rts_thresh(&dev->mt76, 0x92b, 0); in mt7921_mac_init()
104 static int __mt7921_init_hardware(struct mt792x_dev *dev) in __mt7921_init_hardware() argument
111 mt76_wr(dev, MT_SWDEF_MODE, MT_SWDEF_NORMAL_MODE); in __mt7921_init_hardware()
112 ret = mt792x_mcu_init(dev); in __mt7921_init_hardware()
116 mt76_eeprom_override(&dev->mphy); in __mt7921_init_hardware()
118 ret = mt7921_mcu_set_eeprom(dev); in __mt7921_init_hardware()
122 ret = mt7921_mac_init(dev); in __mt7921_init_hardware()
127 static int mt7921_init_hardware(struct mt792x_dev *dev) in mt7921_init_hardware() argument
131 set_bit(MT76_STATE_INITIALIZED, &dev->mphy.state); in mt7921_init_hardware()
134 ret = __mt7921_init_hardware(dev); in mt7921_init_hardware()
138 mt792x_init_reset(dev); in mt7921_init_hardware()
142 dev_err(dev->mt76.dev, "hardware init failed\n"); in mt7921_init_hardware()
151 struct mt792x_dev *dev = container_of(work, struct mt792x_dev, in mt7921_init_work() local
155 ret = mt7921_init_hardware(dev); in mt7921_init_work()
159 mt76_set_stream_caps(&dev->mphy, true); in mt7921_init_work()
160 mt7921_set_stream_he_caps(&dev->phy); in mt7921_init_work()
162 ret = mt76_register_device(&dev->mt76, true, mt76_rates, in mt7921_init_work()
165 dev_err(dev->mt76.dev, "register device failed\n"); in mt7921_init_work()
170 ret = mt7921_init_debugfs(dev); in mt7921_init_work()
172 dev_err(dev->mt76.dev, "register debugfs failed\n"); in mt7921_init_work()
178 ret = mt7921_thermal_init(&dev->phy); in mt7921_init_work()
180 dev_err(dev->mt76.dev, "thermal init failed\n"); in mt7921_init_work()
186 dev->hw_init_done = true; in mt7921_init_work()
188 mt76_connac_mcu_set_deep_sleep(&dev->mt76, dev->pm.ds_enable); in mt7921_init_work()
191 int mt7921_register_device(struct mt792x_dev *dev) in mt7921_register_device() argument
193 struct ieee80211_hw *hw = mt76_hw(dev); in mt7921_register_device()
196 dev->phy.dev = dev; in mt7921_register_device()
197 dev->phy.mt76 = &dev->mt76.phy; in mt7921_register_device()
198 dev->mt76.phy.priv = &dev->phy; in mt7921_register_device()
199 dev->mt76.tx_worker.fn = mt792x_tx_worker; in mt7921_register_device()
201 INIT_DELAYED_WORK(&dev->pm.ps_work, mt792x_pm_power_save_work); in mt7921_register_device()
202 INIT_WORK(&dev->pm.wake_work, mt792x_pm_wake_work); in mt7921_register_device()
203 spin_lock_init(&dev->pm.wake.lock); in mt7921_register_device()
204 mutex_init(&dev->pm.mutex); in mt7921_register_device()
205 init_waitqueue_head(&dev->pm.wait); in mt7921_register_device()
206 if (mt76_is_sdio(&dev->mt76)) in mt7921_register_device()
207 init_waitqueue_head(&dev->mt76.sdio.wait); in mt7921_register_device()
208 spin_lock_init(&dev->pm.txq_lock); in mt7921_register_device()
209 INIT_DELAYED_WORK(&dev->mphy.mac_work, mt792x_mac_work); in mt7921_register_device()
210 INIT_DELAYED_WORK(&dev->phy.scan_work, mt7921_scan_work); in mt7921_register_device()
211 INIT_DELAYED_WORK(&dev->coredump.work, mt7921_coredump_work); in mt7921_register_device()
213 INIT_WORK(&dev->ipv6_ns_work, mt7921_set_ipv6_ns_work); in mt7921_register_device()
214 skb_queue_head_init(&dev->ipv6_ns_list); in mt7921_register_device()
216 skb_queue_head_init(&dev->phy.scan_event_list); in mt7921_register_device()
217 skb_queue_head_init(&dev->coredump.msg_list); in mt7921_register_device()
219 INIT_WORK(&dev->reset_work, mt7921_mac_reset_work); in mt7921_register_device()
220 INIT_WORK(&dev->init_work, mt7921_init_work); in mt7921_register_device()
222 INIT_WORK(&dev->phy.roc_work, mt7921_roc_work); in mt7921_register_device()
223 timer_setup(&dev->phy.roc_timer, mt792x_roc_timer, 0); in mt7921_register_device()
224 init_waitqueue_head(&dev->phy.roc_wait); in mt7921_register_device()
226 dev->pm.idle_timeout = MT792x_PM_TIMEOUT; in mt7921_register_device()
227 dev->pm.stats.last_wake_event = jiffies; in mt7921_register_device()
228 dev->pm.stats.last_doze_event = jiffies; in mt7921_register_device()
229 if (!mt76_is_usb(&dev->mt76)) { in mt7921_register_device()
230 dev->pm.enable_user = true; in mt7921_register_device()
231 dev->pm.enable = true; in mt7921_register_device()
232 dev->pm.ds_enable_user = true; in mt7921_register_device()
233 dev->pm.ds_enable = true; in mt7921_register_device()
236 if (!mt76_is_mmio(&dev->mt76)) in mt7921_register_device()
239 mt792x_init_acpi_sar(dev); in mt7921_register_device()
241 ret = mt792x_init_wcid(dev); in mt7921_register_device()
250 dev->mphy.sband_2g.sband.ht_cap.cap |= in mt7921_register_device()
253 dev->mphy.sband_5g.sband.ht_cap.cap |= in mt7921_register_device()
256 dev->mphy.sband_5g.sband.vht_cap.cap |= in mt7921_register_device()
262 if (is_mt7922(&dev->mt76)) in mt7921_register_device()
263 dev->mphy.sband_5g.sband.vht_cap.cap |= in mt7921_register_device()
267 dev->mphy.hw->wiphy->available_antennas_rx = dev->mphy.chainmask; in mt7921_register_device()
268 dev->mphy.hw->wiphy->available_antennas_tx = dev->mphy.chainmask; in mt7921_register_device()
270 queue_work(system_wq, &dev->init_work); in mt7921_register_device()