Lines Matching +full:rates +full:- +full:ofdm
1 // SPDX-License-Identifier: ISC
9 #include <linux/nvmem-consumer.h>
15 struct device_node *np = dev->dev->of_node; in mt76_get_of_eeprom_data()
19 data = of_get_property(np, "mediatek,eeprom-data", &size); in mt76_get_of_eeprom_data()
21 return -ENOENT; in mt76_get_of_eeprom_data()
24 return -EINVAL; in mt76_get_of_eeprom_data()
34 struct device_node *np = dev->dev->of_node; in mt76_get_of_data_from_mtd()
43 list = of_get_property(np, "mediatek,mtd-eeprom", &size); in mt76_get_of_data_from_mtd()
45 return -ENOENT; in mt76_get_of_data_from_mtd()
49 return -ENOENT; in mt76_get_of_data_from_mtd()
53 return -EINVAL; in mt76_get_of_data_from_mtd()
57 part = np->name; in mt76_get_of_data_from_mtd()
66 ret = -EINVAL; in mt76_get_of_data_from_mtd()
76 dev_err(dev->dev, "reading EEPROM from mtd %s failed: %i\n", in mt76_get_of_data_from_mtd()
82 ret = -EINVAL; in mt76_get_of_data_from_mtd()
86 if (of_property_read_bool(dev->dev->of_node, "big-endian")) { in mt76_get_of_data_from_mtd()
97 dev->test_mtd.name = devm_kstrdup(dev->dev, part, GFP_KERNEL); in mt76_get_of_data_from_mtd()
98 if (!dev->test_mtd.name) { in mt76_get_of_data_from_mtd()
99 ret = -ENOMEM; in mt76_get_of_data_from_mtd()
102 dev->test_mtd.offset = offset; in mt76_get_of_data_from_mtd()
109 return -ENOENT; in mt76_get_of_data_from_mtd()
117 struct device_node *np = dev->dev->of_node; in mt76_get_of_data_from_nvmem()
134 ret = -EINVAL; in mt76_get_of_data_from_nvmem()
149 struct device_node *np = dev->dev->of_node; in mt76_get_of_eeprom()
153 return -ENOENT; in mt76_get_of_eeprom()
169 struct mt76_dev *dev = phy->dev; in mt76_eeprom_override()
170 struct device_node *np = dev->dev->of_node; in mt76_eeprom_override()
172 of_get_mac_address(np, phy->macaddr); in mt76_eeprom_override()
174 if (!is_valid_ether_addr(phy->macaddr)) { in mt76_eeprom_override()
175 eth_random_addr(phy->macaddr); in mt76_eeprom_override()
176 dev_info(dev->dev, in mt76_eeprom_override()
178 phy->macaddr); in mt76_eeprom_override()
200 struct device_node *np = dev->dev->of_node; in mt76_find_power_limits_node()
210 if (dev->region < ARRAY_SIZE(region_names)) in mt76_find_power_limits_node()
211 region_name = region_names[dev->region]; in mt76_find_power_limits_node()
213 np = of_get_child_by_name(np, "power-limits"); in mt76_find_power_limits_node()
226 if (mt76_string_prop_find(country, dev->alpha2) || in mt76_find_power_limits_node()
243 if (!prop || !prop->value || prop->length < min * 4) in mt76_get_of_array()
246 *len = prop->length; in mt76_get_of_array()
248 return prop->value; in mt76_get_of_array()
264 if (chan->hw_value >= be32_to_cpu(val[0]) && in mt76_find_channel_node()
265 chan->hw_value <= be32_to_cpu(val[1])) in mt76_find_channel_node()
269 len -= 2 * sizeof(*val); in mt76_find_channel_node()
284 val = mt76_get_of_array(np, "txs-delta", &len, nss); in mt76_get_txs_delta()
288 return be32_to_cpu(val[nss - 1]); in mt76_get_txs_delta()
325 if (--cur > 0) in mt76_apply_multi_array_limit()
329 len -= pwr_len + 1; in mt76_apply_multi_array_limit()
342 struct mt76_dev *dev = phy->dev; in mt76_get_rate_power_limits()
346 u32 mcs_rates = dev->drv->mcs_rates; in mt76_get_rate_power_limits()
347 u32 ru_rates = ARRAY_SIZE(dest->ru[0]); in mt76_get_rate_power_limits()
365 switch (chan->band) { in mt76_get_rate_power_limits()
379 snprintf(name, sizeof(name), "txpower-%cg", band); in mt76_get_rate_power_limits()
388 txs_delta = mt76_get_txs_delta(np, hweight16(phy->chainmask)); in mt76_get_rate_power_limits()
390 val = mt76_get_of_array(np, "rates-cck", &len, ARRAY_SIZE(dest->cck)); in mt76_get_rate_power_limits()
391 mt76_apply_array_limit(dest->cck, ARRAY_SIZE(dest->cck), val, in mt76_get_rate_power_limits()
394 val = mt76_get_of_array(np, "rates-ofdm", in mt76_get_rate_power_limits()
395 &len, ARRAY_SIZE(dest->ofdm)); in mt76_get_rate_power_limits()
396 mt76_apply_array_limit(dest->ofdm, ARRAY_SIZE(dest->ofdm), val, in mt76_get_rate_power_limits()
399 val = mt76_get_of_array(np, "rates-mcs", &len, mcs_rates + 1); in mt76_get_rate_power_limits()
400 mt76_apply_multi_array_limit(dest->mcs[0], ARRAY_SIZE(dest->mcs[0]), in mt76_get_rate_power_limits()
401 ARRAY_SIZE(dest->mcs), val, len, in mt76_get_rate_power_limits()
404 val = mt76_get_of_array(np, "rates-ru", &len, ru_rates + 1); in mt76_get_rate_power_limits()
405 mt76_apply_multi_array_limit(dest->ru[0], ARRAY_SIZE(dest->ru[0]), in mt76_get_rate_power_limits()
406 ARRAY_SIZE(dest->ru), val, len, in mt76_get_rate_power_limits()
416 dev->eeprom.size = len; in mt76_eeprom_init()
417 dev->eeprom.data = devm_kzalloc(dev->dev, len, GFP_KERNEL); in mt76_eeprom_init()
418 if (!dev->eeprom.data) in mt76_eeprom_init()
419 return -ENOMEM; in mt76_eeprom_init()
421 return !mt76_get_of_eeprom(dev, dev->eeprom.data, len); in mt76_eeprom_init()