Lines Matching refs:dev

13 static ssize_t mt7921_thermal_temp_show(struct device *dev,  in mt7921_thermal_temp_show()  argument
19 struct mt792x_phy *phy = dev_get_drvdata(dev); in mt7921_thermal_temp_show()
20 struct mt792x_dev *mdev = phy->dev; in mt7921_thermal_temp_show()
53 name = devm_kasprintf(&wiphy->dev, GFP_KERNEL, "mt7921_%s", in mt7921_thermal_init()
56 hwmon = devm_hwmon_device_register_with_groups(&wiphy->dev, name, phy, in mt7921_thermal_init()
69 struct mt792x_dev *dev = mt792x_hw_dev(hw); in mt7921_regd_notifier() local
71 memcpy(dev->mt76.alpha2, request->alpha2, sizeof(dev->mt76.alpha2)); in mt7921_regd_notifier()
72 dev->mt76.region = request->dfs_region; in mt7921_regd_notifier()
73 dev->country_ie_env = request->country_ie_env; in mt7921_regd_notifier()
75 mt792x_mutex_acquire(dev); in mt7921_regd_notifier()
76 mt7921_mcu_set_clc(dev, request->alpha2, request->country_ie_env); in mt7921_regd_notifier()
79 mt792x_mutex_release(dev); in mt7921_regd_notifier()
82 int mt7921_mac_init(struct mt792x_dev *dev) in mt7921_mac_init() argument
86 mt76_rmw_field(dev, MT_MDP_DCR1, MT_MDP_DCR1_MAX_RX_LEN, 1536); in mt7921_mac_init()
88 mt76_set(dev, MT_MDP_DCR0, MT_MDP_DCR0_DAMSDU_EN); in mt7921_mac_init()
90 mt76_set(dev, MT_MDP_DCR0, MT_MDP_DCR0_RX_HDR_TRANS_EN); in mt7921_mac_init()
93 mt7921_mac_wtbl_update(dev, i, in mt7921_mac_init()
96 mt792x_mac_init_band(dev, i); in mt7921_mac_init()
98 return mt76_connac_mcu_set_rts_thresh(&dev->mt76, 0x92b, 0); in mt7921_mac_init()
102 static int __mt7921_init_hardware(struct mt792x_dev *dev) in __mt7921_init_hardware() argument
109 mt76_wr(dev, MT_SWDEF_MODE, MT_SWDEF_NORMAL_MODE); in __mt7921_init_hardware()
110 ret = mt792x_mcu_init(dev); in __mt7921_init_hardware()
114 mt76_eeprom_override(&dev->mphy); in __mt7921_init_hardware()
116 ret = mt7921_mcu_set_eeprom(dev); in __mt7921_init_hardware()
120 ret = mt7921_mac_init(dev); in __mt7921_init_hardware()
125 static int mt7921_init_hardware(struct mt792x_dev *dev) in mt7921_init_hardware() argument
129 set_bit(MT76_STATE_INITIALIZED, &dev->mphy.state); in mt7921_init_hardware()
132 ret = __mt7921_init_hardware(dev); in mt7921_init_hardware()
136 mt792x_init_reset(dev); in mt7921_init_hardware()
140 dev_err(dev->mt76.dev, "hardware init failed\n"); in mt7921_init_hardware()
149 struct mt792x_dev *dev = container_of(work, struct mt792x_dev, in mt7921_init_work() local
153 ret = mt7921_init_hardware(dev); in mt7921_init_work()
157 mt76_set_stream_caps(&dev->mphy, true); in mt7921_init_work()
158 mt7921_set_stream_he_caps(&dev->phy); in mt7921_init_work()
160 ret = mt76_register_device(&dev->mt76, true, mt76_rates, in mt7921_init_work()
163 dev_err(dev->mt76.dev, "register device failed\n"); in mt7921_init_work()
167 ret = mt7921_init_debugfs(dev); in mt7921_init_work()
169 dev_err(dev->mt76.dev, "register debugfs failed\n"); in mt7921_init_work()
173 ret = mt7921_thermal_init(&dev->phy); in mt7921_init_work()
175 dev_err(dev->mt76.dev, "thermal init failed\n"); in mt7921_init_work()
180 dev->hw_init_done = true; in mt7921_init_work()
182 mt76_connac_mcu_set_deep_sleep(&dev->mt76, dev->pm.ds_enable); in mt7921_init_work()
185 int mt7921_register_device(struct mt792x_dev *dev) in mt7921_register_device() argument
187 struct ieee80211_hw *hw = mt76_hw(dev); in mt7921_register_device()
190 dev->phy.dev = dev; in mt7921_register_device()
191 dev->phy.mt76 = &dev->mt76.phy; in mt7921_register_device()
192 dev->mt76.phy.priv = &dev->phy; in mt7921_register_device()
193 dev->mt76.tx_worker.fn = mt792x_tx_worker; in mt7921_register_device()
195 INIT_DELAYED_WORK(&dev->pm.ps_work, mt792x_pm_power_save_work); in mt7921_register_device()
196 INIT_WORK(&dev->pm.wake_work, mt792x_pm_wake_work); in mt7921_register_device()
197 spin_lock_init(&dev->pm.wake.lock); in mt7921_register_device()
198 mutex_init(&dev->pm.mutex); in mt7921_register_device()
199 init_waitqueue_head(&dev->pm.wait); in mt7921_register_device()
200 if (mt76_is_sdio(&dev->mt76)) in mt7921_register_device()
201 init_waitqueue_head(&dev->mt76.sdio.wait); in mt7921_register_device()
202 spin_lock_init(&dev->pm.txq_lock); in mt7921_register_device()
203 INIT_DELAYED_WORK(&dev->mphy.mac_work, mt792x_mac_work); in mt7921_register_device()
204 INIT_DELAYED_WORK(&dev->phy.scan_work, mt7921_scan_work); in mt7921_register_device()
205 INIT_DELAYED_WORK(&dev->coredump.work, mt7921_coredump_work); in mt7921_register_device()
207 INIT_WORK(&dev->ipv6_ns_work, mt7921_set_ipv6_ns_work); in mt7921_register_device()
208 skb_queue_head_init(&dev->ipv6_ns_list); in mt7921_register_device()
210 skb_queue_head_init(&dev->phy.scan_event_list); in mt7921_register_device()
211 skb_queue_head_init(&dev->coredump.msg_list); in mt7921_register_device()
213 INIT_WORK(&dev->reset_work, mt7921_mac_reset_work); in mt7921_register_device()
214 INIT_WORK(&dev->init_work, mt7921_init_work); in mt7921_register_device()
216 INIT_WORK(&dev->phy.roc_work, mt7921_roc_work); in mt7921_register_device()
217 timer_setup(&dev->phy.roc_timer, mt792x_roc_timer, 0); in mt7921_register_device()
218 init_waitqueue_head(&dev->phy.roc_wait); in mt7921_register_device()
220 dev->pm.idle_timeout = MT792x_PM_TIMEOUT; in mt7921_register_device()
221 dev->pm.stats.last_wake_event = jiffies; in mt7921_register_device()
222 dev->pm.stats.last_doze_event = jiffies; in mt7921_register_device()
223 if (!mt76_is_usb(&dev->mt76)) { in mt7921_register_device()
224 dev->pm.enable_user = true; in mt7921_register_device()
225 dev->pm.enable = true; in mt7921_register_device()
226 dev->pm.ds_enable_user = true; in mt7921_register_device()
227 dev->pm.ds_enable = true; in mt7921_register_device()
230 if (!mt76_is_mmio(&dev->mt76)) in mt7921_register_device()
233 mt792x_init_acpi_sar(dev); in mt7921_register_device()
235 ret = mt792x_init_wcid(dev); in mt7921_register_device()
244 dev->mphy.sband_2g.sband.ht_cap.cap |= in mt7921_register_device()
247 dev->mphy.sband_5g.sband.ht_cap.cap |= in mt7921_register_device()
250 dev->mphy.sband_5g.sband.vht_cap.cap |= in mt7921_register_device()
256 if (is_mt7922(&dev->mt76)) in mt7921_register_device()
257 dev->mphy.sband_5g.sband.vht_cap.cap |= in mt7921_register_device()
261 dev->mphy.hw->wiphy->available_antennas_rx = dev->mphy.chainmask; in mt7921_register_device()
262 dev->mphy.hw->wiphy->available_antennas_tx = dev->mphy.chainmask; in mt7921_register_device()
264 queue_work(system_wq, &dev->init_work); in mt7921_register_device()