staging: align to fix warnings of line over 80 characters
Align to fix multiple warnings of line over 80 characters. Issue detected by checkpatch tool. Signed-off-by: Jules Irenge <jbi.octave@gmail.com> Link: https://lore.kernel.org/r/20191113110052.14855-1-jbi.octave@gmail.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
7a3674898d
commit
8c7128c4cf
|
@ -188,7 +188,9 @@ static int wfx_sdio_probe(struct sdio_func *func,
|
||||||
|
|
||||||
bus->func = func;
|
bus->func = func;
|
||||||
sdio_set_drvdata(func, bus);
|
sdio_set_drvdata(func, bus);
|
||||||
func->card->quirks |= MMC_QUIRK_LENIENT_FN0 | MMC_QUIRK_BLKSZ_FOR_BYTE_MODE | MMC_QUIRK_BROKEN_BYTE_MODE_512;
|
func->card->quirks |= MMC_QUIRK_LENIENT_FN0 |
|
||||||
|
MMC_QUIRK_BLKSZ_FOR_BYTE_MODE |
|
||||||
|
MMC_QUIRK_BROKEN_BYTE_MODE_512;
|
||||||
|
|
||||||
sdio_claim_host(func);
|
sdio_claim_host(func);
|
||||||
ret = sdio_enable_func(func);
|
ret = sdio_enable_func(func);
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
struct wfx_vif;
|
struct wfx_vif;
|
||||||
struct sk_buff;
|
struct sk_buff;
|
||||||
|
|
||||||
void wfx_rx_cb(struct wfx_vif *wvif, struct hif_ind_rx *arg, struct sk_buff *skb);
|
void wfx_rx_cb(struct wfx_vif *wvif, struct hif_ind_rx *arg,
|
||||||
|
struct sk_buff *skb);
|
||||||
|
|
||||||
#endif /* WFX_DATA_RX_H */
|
#endif /* WFX_DATA_RX_H */
|
||||||
|
|
|
@ -72,7 +72,8 @@ static int wfx_counters_show(struct seq_file *seq, void *v)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
#define PUT_COUNTER(name) \
|
#define PUT_COUNTER(name) \
|
||||||
seq_printf(seq, "%24s %d\n", #name ":", le32_to_cpu(counters.count_##name))
|
seq_printf(seq, "%24s %d\n", #name ":",\
|
||||||
|
le32_to_cpu(counters.count_##name))
|
||||||
|
|
||||||
PUT_COUNTER(tx_packets);
|
PUT_COUNTER(tx_packets);
|
||||||
PUT_COUNTER(tx_multicast_frames);
|
PUT_COUNTER(tx_multicast_frames);
|
||||||
|
@ -211,7 +212,8 @@ struct dbgfs_hif_msg {
|
||||||
int ret;
|
int ret;
|
||||||
};
|
};
|
||||||
|
|
||||||
static ssize_t wfx_send_hif_msg_write(struct file *file, const char __user *user_buf,
|
static ssize_t wfx_send_hif_msg_write(struct file *file,
|
||||||
|
const char __user *user_buf,
|
||||||
size_t count, loff_t *ppos)
|
size_t count, loff_t *ppos)
|
||||||
{
|
{
|
||||||
struct dbgfs_hif_msg *context = file->private_data;
|
struct dbgfs_hif_msg *context = file->private_data;
|
||||||
|
@ -236,7 +238,8 @@ static ssize_t wfx_send_hif_msg_write(struct file *file, const char __user *user
|
||||||
kfree(request);
|
kfree(request);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
context->ret = wfx_cmd_send(wdev, request, context->reply, sizeof(context->reply), false);
|
context->ret = wfx_cmd_send(wdev, request, context->reply,
|
||||||
|
sizeof(context->reply), false);
|
||||||
|
|
||||||
kfree(request);
|
kfree(request);
|
||||||
complete(&context->complete);
|
complete(&context->complete);
|
||||||
|
@ -299,8 +302,10 @@ int wfx_debug_init(struct wfx_dev *wdev)
|
||||||
debugfs_create_file("counters", 0444, d, wdev, &wfx_counters_fops);
|
debugfs_create_file("counters", 0444, d, wdev, &wfx_counters_fops);
|
||||||
debugfs_create_file("rx_stats", 0444, d, wdev, &wfx_rx_stats_fops);
|
debugfs_create_file("rx_stats", 0444, d, wdev, &wfx_rx_stats_fops);
|
||||||
debugfs_create_file("send_pds", 0200, d, wdev, &wfx_send_pds_fops);
|
debugfs_create_file("send_pds", 0200, d, wdev, &wfx_send_pds_fops);
|
||||||
debugfs_create_file("burn_slk_key", 0200, d, wdev, &wfx_burn_slk_key_fops);
|
debugfs_create_file("burn_slk_key", 0200, d, wdev,
|
||||||
debugfs_create_file("send_hif_msg", 0600, d, wdev, &wfx_send_hif_msg_fops);
|
&wfx_burn_slk_key_fops);
|
||||||
|
debugfs_create_file("send_hif_msg", 0600, d, wdev,
|
||||||
|
&wfx_send_hif_msg_fops);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,11 +107,14 @@ int get_firmware(struct wfx_dev *wdev, u32 keyset_chip,
|
||||||
const char *data;
|
const char *data;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
snprintf(filename, sizeof(filename), "%s_%02X.sec", wdev->pdata.file_fw, keyset_chip);
|
snprintf(filename, sizeof(filename), "%s_%02X.sec", wdev->pdata.file_fw,
|
||||||
|
keyset_chip);
|
||||||
ret = firmware_request_nowarn(fw, filename, wdev->dev);
|
ret = firmware_request_nowarn(fw, filename, wdev->dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_info(wdev->dev, "can't load %s, falling back to %s.sec\n", filename, wdev->pdata.file_fw);
|
dev_info(wdev->dev, "can't load %s, falling back to %s.sec\n",
|
||||||
snprintf(filename, sizeof(filename), "%s.sec", wdev->pdata.file_fw);
|
filename, wdev->pdata.file_fw);
|
||||||
|
snprintf(filename, sizeof(filename), "%s.sec",
|
||||||
|
wdev->pdata.file_fw);
|
||||||
ret = request_firmware(fw, filename, wdev->dev);
|
ret = request_firmware(fw, filename, wdev->dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(wdev->dev, "can't load %s\n", filename);
|
dev_err(wdev->dev, "can't load %s\n", filename);
|
||||||
|
@ -164,7 +167,8 @@ static int wait_ncp_status(struct wfx_dev *wdev, u32 status)
|
||||||
return -ETIMEDOUT;
|
return -ETIMEDOUT;
|
||||||
}
|
}
|
||||||
if (ktime_compare(now, start))
|
if (ktime_compare(now, start))
|
||||||
dev_dbg(wdev->dev, "chip answer after %lldus\n", ktime_us_delta(now, start));
|
dev_dbg(wdev->dev, "chip answer after %lldus\n",
|
||||||
|
ktime_us_delta(now, start));
|
||||||
else
|
else
|
||||||
dev_dbg(wdev->dev, "chip answer immediately\n");
|
dev_dbg(wdev->dev, "chip answer immediately\n");
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -188,15 +192,18 @@ static int upload_firmware(struct wfx_dev *wdev, const u8 *data, size_t len)
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
now = ktime_get();
|
now = ktime_get();
|
||||||
if (offs + DNLD_BLOCK_SIZE - bytes_done < DNLD_FIFO_SIZE)
|
if (offs +
|
||||||
|
DNLD_BLOCK_SIZE - bytes_done < DNLD_FIFO_SIZE)
|
||||||
break;
|
break;
|
||||||
if (ktime_after(now, ktime_add_ms(start, DCA_TIMEOUT)))
|
if (ktime_after(now, ktime_add_ms(start, DCA_TIMEOUT)))
|
||||||
return -ETIMEDOUT;
|
return -ETIMEDOUT;
|
||||||
}
|
}
|
||||||
if (ktime_compare(now, start))
|
if (ktime_compare(now, start))
|
||||||
dev_dbg(wdev->dev, "answer after %lldus\n", ktime_us_delta(now, start));
|
dev_dbg(wdev->dev, "answer after %lldus\n",
|
||||||
|
ktime_us_delta(now, start));
|
||||||
|
|
||||||
ret = sram_write_dma_safe(wdev, WFX_DNLD_FIFO + (offs % DNLD_FIFO_SIZE),
|
ret = sram_write_dma_safe(wdev, WFX_DNLD_FIFO +
|
||||||
|
(offs % DNLD_FIFO_SIZE),
|
||||||
data + offs, DNLD_BLOCK_SIZE);
|
data + offs, DNLD_BLOCK_SIZE);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -220,10 +227,14 @@ static void print_boot_status(struct wfx_dev *wdev)
|
||||||
dev_info(wdev->dev, "no error reported by secure boot\n");
|
dev_info(wdev->dev, "no error reported by secure boot\n");
|
||||||
} else {
|
} else {
|
||||||
sram_reg_read(wdev, WFX_ERR_INFO, &val32);
|
sram_reg_read(wdev, WFX_ERR_INFO, &val32);
|
||||||
if (val32 < ARRAY_SIZE(fwio_error_strings) && fwio_error_strings[val32])
|
if (val32 < ARRAY_SIZE(fwio_error_strings) &&
|
||||||
dev_info(wdev->dev, "secure boot error: %s\n", fwio_error_strings[val32]);
|
fwio_error_strings[val32])
|
||||||
|
dev_info(wdev->dev, "secure boot error: %s\n",
|
||||||
|
fwio_error_strings[val32]);
|
||||||
else
|
else
|
||||||
dev_info(wdev->dev, "secure boot error: Unknown (0x%02x)\n", val32);
|
dev_info(wdev->dev,
|
||||||
|
"secure boot error: Unknown (0x%02x)\n",
|
||||||
|
val32);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -262,9 +273,13 @@ static int load_firmware_secure(struct wfx_dev *wdev)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
sram_reg_write(wdev, WFX_DNLD_FIFO, 0xFFFFFFFF); // Fifo init
|
sram_reg_write(wdev, WFX_DNLD_FIFO, 0xFFFFFFFF); // Fifo init
|
||||||
sram_write_dma_safe(wdev, WFX_DCA_FW_VERSION, "\x01\x00\x00\x00", FW_VERSION_SIZE);
|
sram_write_dma_safe(wdev, WFX_DCA_FW_VERSION, "\x01\x00\x00\x00",
|
||||||
sram_write_dma_safe(wdev, WFX_DCA_FW_SIGNATURE, fw->data + fw_offset, FW_SIGNATURE_SIZE);
|
FW_VERSION_SIZE);
|
||||||
sram_write_dma_safe(wdev, WFX_DCA_FW_HASH, fw->data + fw_offset + FW_SIGNATURE_SIZE, FW_HASH_SIZE);
|
sram_write_dma_safe(wdev, WFX_DCA_FW_SIGNATURE, fw->data + fw_offset,
|
||||||
|
FW_SIGNATURE_SIZE);
|
||||||
|
sram_write_dma_safe(wdev, WFX_DCA_FW_HASH,
|
||||||
|
fw->data + fw_offset + FW_SIGNATURE_SIZE,
|
||||||
|
FW_HASH_SIZE);
|
||||||
sram_reg_write(wdev, WFX_DCA_IMAGE_SIZE, fw->size - header_size);
|
sram_reg_write(wdev, WFX_DCA_IMAGE_SIZE, fw->size - header_size);
|
||||||
sram_reg_write(wdev, WFX_DCA_HOST_STATUS, HOST_UPLOAD_PENDING);
|
sram_reg_write(wdev, WFX_DCA_HOST_STATUS, HOST_UPLOAD_PENDING);
|
||||||
ret = wait_ncp_status(wdev, NCP_DOWNLOAD_PENDING);
|
ret = wait_ncp_status(wdev, NCP_DOWNLOAD_PENDING);
|
||||||
|
@ -272,10 +287,12 @@ static int load_firmware_secure(struct wfx_dev *wdev)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
start = ktime_get();
|
start = ktime_get();
|
||||||
ret = upload_firmware(wdev, fw->data + header_size, fw->size - header_size);
|
ret = upload_firmware(wdev, fw->data + header_size,
|
||||||
|
fw->size - header_size);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto error;
|
goto error;
|
||||||
dev_dbg(wdev->dev, "firmware load after %lldus\n", ktime_us_delta(ktime_get(), start));
|
dev_dbg(wdev->dev, "firmware load after %lldus\n",
|
||||||
|
ktime_us_delta(ktime_get(), start));
|
||||||
|
|
||||||
sram_reg_write(wdev, WFX_DCA_HOST_STATUS, HOST_UPLOAD_COMPLETE);
|
sram_reg_write(wdev, WFX_DCA_HOST_STATUS, HOST_UPLOAD_COMPLETE);
|
||||||
ret = wait_ncp_status(wdev, NCP_AUTH_OK);
|
ret = wait_ncp_status(wdev, NCP_AUTH_OK);
|
||||||
|
@ -310,10 +327,12 @@ static int init_gpr(struct wfx_dev *wdev)
|
||||||
};
|
};
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(gpr_init); i++) {
|
for (i = 0; i < ARRAY_SIZE(gpr_init); i++) {
|
||||||
ret = igpr_reg_write(wdev, gpr_init[i].index, gpr_init[i].value);
|
ret = igpr_reg_write(wdev, gpr_init[i].index,
|
||||||
|
gpr_init[i].value);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
dev_dbg(wdev->dev, " index %02x: %08x\n", gpr_init[i].index, gpr_init[i].value);
|
dev_dbg(wdev->dev, " index %02x: %08x\n", gpr_init[i].index,
|
||||||
|
gpr_init[i].value);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -348,7 +367,8 @@ int wfx_init_device(struct wfx_dev *wdev)
|
||||||
|
|
||||||
hw_revision = FIELD_GET(CFG_DEVICE_ID_MAJOR, reg);
|
hw_revision = FIELD_GET(CFG_DEVICE_ID_MAJOR, reg);
|
||||||
if (hw_revision == 0 || hw_revision > 2) {
|
if (hw_revision == 0 || hw_revision > 2) {
|
||||||
dev_err(wdev->dev, "bad hardware revision number: %d\n", hw_revision);
|
dev_err(wdev->dev, "bad hardware revision number: %d\n",
|
||||||
|
hw_revision);
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
hw_type = FIELD_GET(CFG_DEVICE_ID_TYPE, reg);
|
hw_type = FIELD_GET(CFG_DEVICE_ID_TYPE, reg);
|
||||||
|
@ -375,7 +395,8 @@ int wfx_init_device(struct wfx_dev *wdev)
|
||||||
return -ETIMEDOUT;
|
return -ETIMEDOUT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dev_dbg(wdev->dev, "chip wake up after %lldus\n", ktime_us_delta(now, start));
|
dev_dbg(wdev->dev, "chip wake up after %lldus\n",
|
||||||
|
ktime_us_delta(now, start));
|
||||||
|
|
||||||
ret = config_reg_write_bits(wdev, CFG_CPU_RESET, 0);
|
ret = config_reg_write_bits(wdev, CFG_CPU_RESET, 0);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
|
@ -383,6 +404,10 @@ int wfx_init_device(struct wfx_dev *wdev)
|
||||||
ret = load_firmware_secure(wdev);
|
ret = load_firmware_secure(wdev);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
ret = config_reg_write_bits(wdev, CFG_DIRECT_ACCESS_MODE | CFG_IRQ_ENABLE_DATA | CFG_IRQ_ENABLE_WRDY, CFG_IRQ_ENABLE_DATA);
|
ret = config_reg_write_bits(wdev,
|
||||||
|
CFG_DIRECT_ACCESS_MODE |
|
||||||
|
CFG_IRQ_ENABLE_DATA |
|
||||||
|
CFG_IRQ_ENABLE_WRDY,
|
||||||
|
CFG_IRQ_ENABLE_DATA);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,8 @@
|
||||||
#include "secure_link.h"
|
#include "secure_link.h"
|
||||||
#include "hif_api_cmd.h"
|
#include "hif_api_cmd.h"
|
||||||
|
|
||||||
static int hif_generic_confirm(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_generic_confirm(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
// All confirm messages start with status
|
// All confirm messages start with status
|
||||||
int status = le32_to_cpu(*((__le32 *) buf));
|
int status = le32_to_cpu(*((__le32 *) buf));
|
||||||
|
@ -33,7 +34,8 @@ static int hif_generic_confirm(struct wfx_dev *wdev, struct hif_msg *hif, void *
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cmd != wdev->hif_cmd.buf_send->id) {
|
if (cmd != wdev->hif_cmd.buf_send->id) {
|
||||||
dev_warn(wdev->dev, "chip response mismatch request: 0x%.2x vs 0x%.2x\n",
|
dev_warn(wdev->dev,
|
||||||
|
"chip response mismatch request: 0x%.2x vs 0x%.2x\n",
|
||||||
cmd, wdev->hif_cmd.buf_send->id);
|
cmd, wdev->hif_cmd.buf_send->id);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -70,7 +72,8 @@ static int hif_tx_confirm(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_multi_tx_confirm(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_multi_tx_confirm(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
struct hif_cnf_multi_transmit *body = buf;
|
struct hif_cnf_multi_transmit *body = buf;
|
||||||
struct hif_cnf_tx *buf_loc = (struct hif_cnf_tx *) &body->tx_conf_payload;
|
struct hif_cnf_tx *buf_loc = (struct hif_cnf_tx *) &body->tx_conf_payload;
|
||||||
|
@ -90,7 +93,8 @@ static int hif_multi_tx_confirm(struct wfx_dev *wdev, struct hif_msg *hif, void
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_startup_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_startup_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
struct hif_ind_startup *body = buf;
|
struct hif_ind_startup *body = buf;
|
||||||
|
|
||||||
|
@ -108,7 +112,8 @@ static int hif_startup_indication(struct wfx_dev *wdev, struct hif_msg *hif, voi
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_wakeup_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_wakeup_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
if (!wdev->pdata.gpio_wakeup
|
if (!wdev->pdata.gpio_wakeup
|
||||||
|| !gpiod_get_value(wdev->pdata.gpio_wakeup)) {
|
|| !gpiod_get_value(wdev->pdata.gpio_wakeup)) {
|
||||||
|
@ -118,7 +123,8 @@ static int hif_wakeup_indication(struct wfx_dev *wdev, struct hif_msg *hif, void
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_keys_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_keys_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
struct hif_ind_sl_exchange_pub_keys *body = buf;
|
struct hif_ind_sl_exchange_pub_keys *body = buf;
|
||||||
|
|
||||||
|
@ -131,13 +137,15 @@ static int hif_keys_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_receive_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf, struct sk_buff *skb)
|
static int hif_receive_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf, struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
||||||
struct hif_ind_rx *body = buf;
|
struct hif_ind_rx *body = buf;
|
||||||
|
|
||||||
if (!wvif) {
|
if (!wvif) {
|
||||||
dev_warn(wdev->dev, "ignore rx data for non-existent vif %d\n", hif->interface);
|
dev_warn(wdev->dev, "ignore rx data for non-existent vif %d\n",
|
||||||
|
hif->interface);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
skb_pull(skb, sizeof(struct hif_msg) + sizeof(struct hif_ind_rx));
|
skb_pull(skb, sizeof(struct hif_msg) + sizeof(struct hif_ind_rx));
|
||||||
|
@ -146,7 +154,8 @@ static int hif_receive_indication(struct wfx_dev *wdev, struct hif_msg *hif, voi
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_event_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_event_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
||||||
struct hif_ind_event *body = buf;
|
struct hif_ind_event *body = buf;
|
||||||
|
@ -173,7 +182,8 @@ static int hif_event_indication(struct wfx_dev *wdev, struct hif_msg *hif, void
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_pm_mode_complete_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_pm_mode_complete_indication(struct wfx_dev *wdev,
|
||||||
|
struct hif_msg *hif, void *buf)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
||||||
|
|
||||||
|
@ -183,7 +193,8 @@ static int hif_pm_mode_complete_indication(struct wfx_dev *wdev, struct hif_msg
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_scan_complete_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_scan_complete_indication(struct wfx_dev *wdev,
|
||||||
|
struct hif_msg *hif, void *buf)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
||||||
struct hif_ind_scan_cmpl *body = buf;
|
struct hif_ind_scan_cmpl *body = buf;
|
||||||
|
@ -194,7 +205,8 @@ static int hif_scan_complete_indication(struct wfx_dev *wdev, struct hif_msg *hi
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_join_complete_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_join_complete_indication(struct wfx_dev *wdev,
|
||||||
|
struct hif_msg *hif, void *buf)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
||||||
|
|
||||||
|
@ -204,7 +216,8 @@ static int hif_join_complete_indication(struct wfx_dev *wdev, struct hif_msg *hi
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_suspend_resume_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_suspend_resume_indication(struct wfx_dev *wdev,
|
||||||
|
struct hif_msg *hif, void *buf)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
struct wfx_vif *wvif = wdev_to_wvif(wdev, hif->interface);
|
||||||
struct hif_ind_suspend_resume_tx *body = buf;
|
struct hif_ind_suspend_resume_tx *body = buf;
|
||||||
|
@ -215,7 +228,8 @@ static int hif_suspend_resume_indication(struct wfx_dev *wdev, struct hif_msg *h
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_error_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_error_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
struct hif_ind_error *body = buf;
|
struct hif_ind_error *body = buf;
|
||||||
u8 *pRollback = (u8 *) body->data;
|
u8 *pRollback = (u8 *) body->data;
|
||||||
|
@ -223,31 +237,39 @@ static int hif_error_indication(struct wfx_dev *wdev, struct hif_msg *hif, void
|
||||||
|
|
||||||
switch (body->type) {
|
switch (body->type) {
|
||||||
case HIF_ERROR_FIRMWARE_ROLLBACK:
|
case HIF_ERROR_FIRMWARE_ROLLBACK:
|
||||||
dev_err(wdev->dev, "asynchronous error: firmware rollback error %d\n", *pRollback);
|
dev_err(wdev->dev,
|
||||||
|
"asynchronous error: firmware rollback error %d\n",
|
||||||
|
*pRollback);
|
||||||
break;
|
break;
|
||||||
case HIF_ERROR_FIRMWARE_DEBUG_ENABLED:
|
case HIF_ERROR_FIRMWARE_DEBUG_ENABLED:
|
||||||
dev_err(wdev->dev, "asynchronous error: firmware debug feature enabled\n");
|
dev_err(wdev->dev, "asynchronous error: firmware debug feature enabled\n");
|
||||||
break;
|
break;
|
||||||
case HIF_ERROR_OUTDATED_SESSION_KEY:
|
case HIF_ERROR_OUTDATED_SESSION_KEY:
|
||||||
dev_err(wdev->dev, "asynchronous error: secure link outdated key: %#.8x\n", *pStatus);
|
dev_err(wdev->dev, "asynchronous error: secure link outdated key: %#.8x\n",
|
||||||
|
*pStatus);
|
||||||
break;
|
break;
|
||||||
case HIF_ERROR_INVALID_SESSION_KEY:
|
case HIF_ERROR_INVALID_SESSION_KEY:
|
||||||
dev_err(wdev->dev, "asynchronous error: invalid session key\n");
|
dev_err(wdev->dev, "asynchronous error: invalid session key\n");
|
||||||
break;
|
break;
|
||||||
case HIF_ERROR_OOR_VOLTAGE:
|
case HIF_ERROR_OOR_VOLTAGE:
|
||||||
dev_err(wdev->dev, "asynchronous error: out-of-range overvoltage: %#.8x\n", *pStatus);
|
dev_err(wdev->dev, "asynchronous error: out-of-range overvoltage: %#.8x\n",
|
||||||
|
*pStatus);
|
||||||
break;
|
break;
|
||||||
case HIF_ERROR_PDS_VERSION:
|
case HIF_ERROR_PDS_VERSION:
|
||||||
dev_err(wdev->dev, "asynchronous error: wrong PDS payload or version: %#.8x\n", *pStatus);
|
dev_err(wdev->dev,
|
||||||
|
"asynchronous error: wrong PDS payload or version: %#.8x\n",
|
||||||
|
*pStatus);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
dev_err(wdev->dev, "asynchronous error: unknown (%d)\n", body->type);
|
dev_err(wdev->dev, "asynchronous error: unknown (%d)\n",
|
||||||
|
body->type);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_generic_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_generic_indication(struct wfx_dev *wdev, struct hif_msg *hif,
|
||||||
|
void *buf)
|
||||||
{
|
{
|
||||||
struct hif_ind_generic *body = buf;
|
struct hif_ind_generic *body = buf;
|
||||||
|
|
||||||
|
@ -255,23 +277,29 @@ static int hif_generic_indication(struct wfx_dev *wdev, struct hif_msg *hif, voi
|
||||||
case HIF_GENERIC_INDICATION_TYPE_RAW:
|
case HIF_GENERIC_INDICATION_TYPE_RAW:
|
||||||
return 0;
|
return 0;
|
||||||
case HIF_GENERIC_INDICATION_TYPE_STRING:
|
case HIF_GENERIC_INDICATION_TYPE_STRING:
|
||||||
dev_info(wdev->dev, "firmware says: %s\n", (char *) body->indication_data.raw_data);
|
dev_info(wdev->dev, "firmware says: %s\n",
|
||||||
|
(char *) body->indication_data.raw_data);
|
||||||
return 0;
|
return 0;
|
||||||
case HIF_GENERIC_INDICATION_TYPE_RX_STATS:
|
case HIF_GENERIC_INDICATION_TYPE_RX_STATS:
|
||||||
mutex_lock(&wdev->rx_stats_lock);
|
mutex_lock(&wdev->rx_stats_lock);
|
||||||
// Older firmware send a generic indication beside RxStats
|
// Older firmware send a generic indication beside RxStats
|
||||||
if (!wfx_api_older_than(wdev, 1, 4))
|
if (!wfx_api_older_than(wdev, 1, 4))
|
||||||
dev_info(wdev->dev, "Rx test ongoing. Temperature: %d°C\n", body->indication_data.rx_stats.current_temp);
|
dev_info(wdev->dev, "Rx test ongoing. Temperature: %d°C\n",
|
||||||
memcpy(&wdev->rx_stats, &body->indication_data.rx_stats, sizeof(wdev->rx_stats));
|
body->indication_data.rx_stats.current_temp);
|
||||||
|
memcpy(&wdev->rx_stats, &body->indication_data.rx_stats,
|
||||||
|
sizeof(wdev->rx_stats));
|
||||||
mutex_unlock(&wdev->rx_stats_lock);
|
mutex_unlock(&wdev->rx_stats_lock);
|
||||||
return 0;
|
return 0;
|
||||||
default:
|
default:
|
||||||
dev_err(wdev->dev, "generic_indication: unknown indication type: %#.8x\n", body->indication_type);
|
dev_err(wdev->dev,
|
||||||
|
"generic_indication: unknown indication type: %#.8x\n",
|
||||||
|
body->indication_type);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hif_exception_indication(struct wfx_dev *wdev, struct hif_msg *hif, void *buf)
|
static int hif_exception_indication(struct wfx_dev *wdev,
|
||||||
|
struct hif_msg *hif, void *buf)
|
||||||
{
|
{
|
||||||
size_t len = hif->len - 4; // drop header
|
size_t len = hif->len - 4; // drop header
|
||||||
dev_err(wdev->dev, "firmware exception\n");
|
dev_err(wdev->dev, "firmware exception\n");
|
||||||
|
|
|
@ -24,7 +24,8 @@ void wfx_init_hif_cmd(struct wfx_hif_cmd *hif_cmd)
|
||||||
mutex_init(&hif_cmd->key_renew_lock);
|
mutex_init(&hif_cmd->key_renew_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wfx_fill_header(struct hif_msg *hif, int if_id, unsigned int cmd, size_t size)
|
static void wfx_fill_header(struct hif_msg *hif, int if_id, unsigned int cmd,
|
||||||
|
size_t size)
|
||||||
{
|
{
|
||||||
if (if_id == -1)
|
if (if_id == -1)
|
||||||
if_id = 2;
|
if_id = 2;
|
||||||
|
@ -47,7 +48,8 @@ static void *wfx_alloc_hif(size_t body_len, struct hif_msg **hif)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int wfx_cmd_send(struct wfx_dev *wdev, struct hif_msg *request, void *reply, size_t reply_len, bool async)
|
int wfx_cmd_send(struct wfx_dev *wdev, struct hif_msg *request, void *reply,
|
||||||
|
size_t reply_len, bool async)
|
||||||
{
|
{
|
||||||
const char *mib_name = "";
|
const char *mib_name = "";
|
||||||
const char *mib_sep = "";
|
const char *mib_sep = "";
|
||||||
|
@ -100,7 +102,8 @@ int wfx_cmd_send(struct wfx_dev *wdev, struct hif_msg *request, void *reply, siz
|
||||||
wdev->hif_cmd.buf_send = NULL;
|
wdev->hif_cmd.buf_send = NULL;
|
||||||
mutex_unlock(&wdev->hif_cmd.lock);
|
mutex_unlock(&wdev->hif_cmd.lock);
|
||||||
|
|
||||||
if (ret && (cmd == HIF_REQ_ID_READ_MIB || cmd == HIF_REQ_ID_WRITE_MIB)) {
|
if (ret &&
|
||||||
|
(cmd == HIF_REQ_ID_READ_MIB || cmd == HIF_REQ_ID_WRITE_MIB)) {
|
||||||
mib_name = get_mib_name(((u16 *) request)[2]);
|
mib_name = get_mib_name(((u16 *) request)[2]);
|
||||||
mib_sep = "/";
|
mib_sep = "/";
|
||||||
}
|
}
|
||||||
|
@ -170,7 +173,8 @@ int hif_reset(struct wfx_vif *wvif, bool reset_stat)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int hif_read_mib(struct wfx_dev *wdev, int vif_id, u16 mib_id, void *val, size_t val_len)
|
int hif_read_mib(struct wfx_dev *wdev, int vif_id, u16 mib_id, void *val,
|
||||||
|
size_t val_len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
|
@ -183,11 +187,13 @@ int hif_read_mib(struct wfx_dev *wdev, int vif_id, u16 mib_id, void *val, size_t
|
||||||
ret = wfx_cmd_send(wdev, hif, reply, buf_len, false);
|
ret = wfx_cmd_send(wdev, hif, reply, buf_len, false);
|
||||||
|
|
||||||
if (!ret && mib_id != reply->mib_id) {
|
if (!ret && mib_id != reply->mib_id) {
|
||||||
dev_warn(wdev->dev, "%s: confirmation mismatch request\n", __func__);
|
dev_warn(wdev->dev,
|
||||||
|
"%s: confirmation mismatch request\n", __func__);
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
}
|
}
|
||||||
if (ret == -ENOMEM)
|
if (ret == -ENOMEM)
|
||||||
dev_err(wdev->dev, "buffer is too small to receive %s (%zu < %d)\n",
|
dev_err(wdev->dev,
|
||||||
|
"buffer is too small to receive %s (%zu < %d)\n",
|
||||||
get_mib_name(mib_id), val_len, reply->length);
|
get_mib_name(mib_id), val_len, reply->length);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
memcpy(val, &reply->mib_data, reply->length);
|
memcpy(val, &reply->mib_data, reply->length);
|
||||||
|
@ -198,7 +204,8 @@ int hif_read_mib(struct wfx_dev *wdev, int vif_id, u16 mib_id, void *val, size_t
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int hif_write_mib(struct wfx_dev *wdev, int vif_id, u16 mib_id, void *val, size_t val_len)
|
int hif_write_mib(struct wfx_dev *wdev, int vif_id, u16 mib_id, void *val,
|
||||||
|
size_t val_len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
|
@ -236,7 +243,8 @@ int hif_scan(struct wfx_vif *wvif, const struct wfx_scan_params *arg)
|
||||||
cpu_to_le32s(&body->min_channel_time);
|
cpu_to_le32s(&body->min_channel_time);
|
||||||
cpu_to_le32s(&body->max_channel_time);
|
cpu_to_le32s(&body->max_channel_time);
|
||||||
cpu_to_le32s(&body->tx_power_level);
|
cpu_to_le32s(&body->tx_power_level);
|
||||||
memcpy(ptr, arg->ssids, arg->scan_req.num_of_ssi_ds * sizeof(struct hif_ssid_def));
|
memcpy(ptr, arg->ssids,
|
||||||
|
arg->scan_req.num_of_ssi_ds * sizeof(struct hif_ssid_def));
|
||||||
ssids = (struct hif_ssid_def *) ptr;
|
ssids = (struct hif_ssid_def *) ptr;
|
||||||
for (i = 0; i < body->num_of_ssi_ds; ++i)
|
for (i = 0; i < body->num_of_ssi_ds; ++i)
|
||||||
cpu_to_le32s(&ssids[i].ssid_length);
|
cpu_to_le32s(&ssids[i].ssid_length);
|
||||||
|
@ -281,16 +289,19 @@ int hif_join(struct wfx_vif *wvif, const struct hif_req_join *arg)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int hif_set_bss_params(struct wfx_vif *wvif, const struct hif_req_set_bss_params *arg)
|
int hif_set_bss_params(struct wfx_vif *wvif,
|
||||||
|
const struct hif_req_set_bss_params *arg)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
struct hif_req_set_bss_params *body = wfx_alloc_hif(sizeof(*body), &hif);
|
struct hif_req_set_bss_params *body = wfx_alloc_hif(sizeof(*body),
|
||||||
|
&hif);
|
||||||
|
|
||||||
memcpy(body, arg, sizeof(*body));
|
memcpy(body, arg, sizeof(*body));
|
||||||
cpu_to_le16s(&body->aid);
|
cpu_to_le16s(&body->aid);
|
||||||
cpu_to_le32s(&body->operational_rate_set);
|
cpu_to_le32s(&body->operational_rate_set);
|
||||||
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_SET_BSS_PARAMS, sizeof(*body));
|
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_SET_BSS_PARAMS,
|
||||||
|
sizeof(*body));
|
||||||
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
||||||
kfree(hif);
|
kfree(hif);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -308,7 +319,8 @@ int hif_add_key(struct wfx_dev *wdev, const struct hif_req_add_key *arg)
|
||||||
if (wfx_api_older_than(wdev, 1, 5))
|
if (wfx_api_older_than(wdev, 1, 5))
|
||||||
// Legacy firmwares expect that add_key to be sent on right
|
// Legacy firmwares expect that add_key to be sent on right
|
||||||
// interface.
|
// interface.
|
||||||
wfx_fill_header(hif, arg->int_id, HIF_REQ_ID_ADD_KEY, sizeof(*body));
|
wfx_fill_header(hif, arg->int_id, HIF_REQ_ID_ADD_KEY,
|
||||||
|
sizeof(*body));
|
||||||
else
|
else
|
||||||
wfx_fill_header(hif, -1, HIF_REQ_ID_ADD_KEY, sizeof(*body));
|
wfx_fill_header(hif, -1, HIF_REQ_ID_ADD_KEY, sizeof(*body));
|
||||||
ret = wfx_cmd_send(wdev, hif, NULL, 0, false);
|
ret = wfx_cmd_send(wdev, hif, NULL, 0, false);
|
||||||
|
@ -329,18 +341,21 @@ int hif_remove_key(struct wfx_dev *wdev, int idx)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int hif_set_edca_queue_params(struct wfx_vif *wvif, const struct hif_req_edca_queue_params *arg)
|
int hif_set_edca_queue_params(struct wfx_vif *wvif,
|
||||||
|
const struct hif_req_edca_queue_params *arg)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
struct hif_req_edca_queue_params *body = wfx_alloc_hif(sizeof(*body), &hif);
|
struct hif_req_edca_queue_params *body = wfx_alloc_hif(sizeof(*body),
|
||||||
|
&hif);
|
||||||
|
|
||||||
// NOTE: queues numerotation are not the same between WFx and Linux
|
// NOTE: queues numerotation are not the same between WFx and Linux
|
||||||
memcpy(body, arg, sizeof(*body));
|
memcpy(body, arg, sizeof(*body));
|
||||||
cpu_to_le16s(&body->cw_min);
|
cpu_to_le16s(&body->cw_min);
|
||||||
cpu_to_le16s(&body->cw_max);
|
cpu_to_le16s(&body->cw_max);
|
||||||
cpu_to_le16s(&body->tx_op_limit);
|
cpu_to_le16s(&body->tx_op_limit);
|
||||||
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_EDCA_QUEUE_PARAMS, sizeof(*body));
|
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_EDCA_QUEUE_PARAMS,
|
||||||
|
sizeof(*body));
|
||||||
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
||||||
kfree(hif);
|
kfree(hif);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -379,10 +394,12 @@ int hif_beacon_transmit(struct wfx_vif *wvif, bool enable_beaconing)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
struct hif_req_beacon_transmit *body = wfx_alloc_hif(sizeof(*body), &hif);
|
struct hif_req_beacon_transmit *body = wfx_alloc_hif(sizeof(*body),
|
||||||
|
&hif);
|
||||||
|
|
||||||
body->enable_beaconing = enable_beaconing ? 1 : 0;
|
body->enable_beaconing = enable_beaconing ? 1 : 0;
|
||||||
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_BEACON_TRANSMIT, sizeof(*body));
|
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_BEACON_TRANSMIT,
|
||||||
|
sizeof(*body));
|
||||||
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
||||||
kfree(hif);
|
kfree(hif);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -421,16 +438,20 @@ int hif_update_ie(struct wfx_vif *wvif, const struct hif_ie_flags *target_frame,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int hif_sl_send_pub_keys(struct wfx_dev *wdev, const uint8_t *pubkey, const uint8_t *pubkey_hmac)
|
int hif_sl_send_pub_keys(struct wfx_dev *wdev, const uint8_t *pubkey,
|
||||||
|
const uint8_t *pubkey_hmac)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
struct hif_req_sl_exchange_pub_keys *body = wfx_alloc_hif(sizeof(*body), &hif);
|
struct hif_req_sl_exchange_pub_keys *body = wfx_alloc_hif(sizeof(*body),
|
||||||
|
&hif);
|
||||||
|
|
||||||
body->algorithm = HIF_SL_CURVE25519;
|
body->algorithm = HIF_SL_CURVE25519;
|
||||||
memcpy(body->host_pub_key, pubkey, sizeof(body->host_pub_key));
|
memcpy(body->host_pub_key, pubkey, sizeof(body->host_pub_key));
|
||||||
memcpy(body->host_pub_key_mac, pubkey_hmac, sizeof(body->host_pub_key_mac));
|
memcpy(body->host_pub_key_mac, pubkey_hmac,
|
||||||
wfx_fill_header(hif, -1, HIF_REQ_ID_SL_EXCHANGE_PUB_KEYS, sizeof(*body));
|
sizeof(body->host_pub_key_mac));
|
||||||
|
wfx_fill_header(hif, -1, HIF_REQ_ID_SL_EXCHANGE_PUB_KEYS,
|
||||||
|
sizeof(*body));
|
||||||
ret = wfx_cmd_send(wdev, hif, NULL, 0, false);
|
ret = wfx_cmd_send(wdev, hif, NULL, 0, false);
|
||||||
kfree(hif);
|
kfree(hif);
|
||||||
// Compatibility with legacy secure link
|
// Compatibility with legacy secure link
|
||||||
|
@ -457,7 +478,8 @@ int hif_sl_set_mac_key(struct wfx_dev *wdev, const u8 *slk_key,
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct hif_msg *hif;
|
struct hif_msg *hif;
|
||||||
struct hif_req_set_sl_mac_key *body = wfx_alloc_hif(sizeof(*body), &hif);
|
struct hif_req_set_sl_mac_key *body = wfx_alloc_hif(sizeof(*body),
|
||||||
|
&hif);
|
||||||
|
|
||||||
memcpy(body->key_value, slk_key, sizeof(body->key_value));
|
memcpy(body->key_value, slk_key, sizeof(body->key_value));
|
||||||
body->otp_or_ram = destination;
|
body->otp_or_ram = destination;
|
||||||
|
|
|
@ -57,8 +57,9 @@ static inline int hif_get_counters_table(struct wfx_dev *wdev,
|
||||||
return hif_read_mib(wdev, 0, HIF_MIB_ID_COUNTERS_TABLE,
|
return hif_read_mib(wdev, 0, HIF_MIB_ID_COUNTERS_TABLE,
|
||||||
arg, sizeof(struct hif_mib_count_table));
|
arg, sizeof(struct hif_mib_count_table));
|
||||||
} else {
|
} else {
|
||||||
return hif_read_mib(wdev, 0, HIF_MIB_ID_EXTENDED_COUNTERS_TABLE,
|
return hif_read_mib(wdev, 0,
|
||||||
arg, sizeof(struct hif_mib_extended_count_table));
|
HIF_MIB_ID_EXTENDED_COUNTERS_TABLE, arg,
|
||||||
|
sizeof(struct hif_mib_extended_count_table));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +113,8 @@ static inline int hif_beacon_filter_control(struct wfx_vif *wvif,
|
||||||
.bcn_count = cpu_to_le32(beacon_count),
|
.bcn_count = cpu_to_le32(beacon_count),
|
||||||
};
|
};
|
||||||
return hif_write_mib(wvif->wdev, wvif->id,
|
return hif_write_mib(wvif->wdev, wvif->id,
|
||||||
HIF_MIB_ID_BEACON_FILTER_ENABLE, &arg, sizeof(arg));
|
HIF_MIB_ID_BEACON_FILTER_ENABLE,
|
||||||
|
&arg, sizeof(arg));
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int hif_set_operational_mode(struct wfx_dev *wdev,
|
static inline int hif_set_operational_mode(struct wfx_dev *wdev,
|
||||||
|
@ -173,7 +175,8 @@ static inline int hif_set_association_mode(struct wfx_vif *wvif,
|
||||||
static inline int hif_set_tx_rate_retry_policy(struct wfx_vif *wvif,
|
static inline int hif_set_tx_rate_retry_policy(struct wfx_vif *wvif,
|
||||||
struct hif_mib_set_tx_rate_retry_policy *arg)
|
struct hif_mib_set_tx_rate_retry_policy *arg)
|
||||||
{
|
{
|
||||||
size_t size = struct_size(arg, tx_rate_retry_policy, arg->num_tx_rate_policies);
|
size_t size = struct_size(arg, tx_rate_retry_policy,
|
||||||
|
arg->num_tx_rate_policies);
|
||||||
|
|
||||||
return hif_write_mib(wvif->wdev, wvif->id,
|
return hif_write_mib(wvif->wdev, wvif->id,
|
||||||
HIF_MIB_ID_SET_TX_RATE_RETRY_POLICY, arg, size);
|
HIF_MIB_ID_SET_TX_RATE_RETRY_POLICY, arg, size);
|
||||||
|
|
|
@ -34,12 +34,14 @@ static int read32(struct wfx_dev *wdev, int reg, u32 *val)
|
||||||
*val = ~0; // Never return undefined value
|
*val = ~0; // Never return undefined value
|
||||||
if (!tmp)
|
if (!tmp)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
ret = wdev->hwbus_ops->copy_from_io(wdev->hwbus_priv, reg, tmp, sizeof(u32));
|
ret = wdev->hwbus_ops->copy_from_io(wdev->hwbus_priv, reg, tmp,
|
||||||
|
sizeof(u32));
|
||||||
if (ret >= 0)
|
if (ret >= 0)
|
||||||
*val = le32_to_cpu(*tmp);
|
*val = le32_to_cpu(*tmp);
|
||||||
kfree(tmp);
|
kfree(tmp);
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err(wdev->dev, "%s: bus communication error: %d\n", __func__, ret);
|
dev_err(wdev->dev, "%s: bus communication error: %d\n",
|
||||||
|
__func__, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,10 +53,12 @@ static int write32(struct wfx_dev *wdev, int reg, u32 val)
|
||||||
if (!tmp)
|
if (!tmp)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
*tmp = cpu_to_le32(val);
|
*tmp = cpu_to_le32(val);
|
||||||
ret = wdev->hwbus_ops->copy_to_io(wdev->hwbus_priv, reg, tmp, sizeof(u32));
|
ret = wdev->hwbus_ops->copy_to_io(wdev->hwbus_priv, reg, tmp,
|
||||||
|
sizeof(u32));
|
||||||
kfree(tmp);
|
kfree(tmp);
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err(wdev->dev, "%s: bus communication error: %d\n", __func__, ret);
|
dev_err(wdev->dev, "%s: bus communication error: %d\n",
|
||||||
|
__func__, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,7 +106,8 @@ err:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int indirect_read(struct wfx_dev *wdev, int reg, u32 addr, void *buf, size_t len)
|
static int indirect_read(struct wfx_dev *wdev, int reg, u32 addr, void *buf,
|
||||||
|
size_t len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
int i;
|
int i;
|
||||||
|
@ -152,7 +157,8 @@ err:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int indirect_write(struct wfx_dev *wdev, int reg, u32 addr, const void *buf, size_t len)
|
static int indirect_write(struct wfx_dev *wdev, int reg, u32 addr,
|
||||||
|
const void *buf, size_t len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -165,7 +171,8 @@ static int indirect_write(struct wfx_dev *wdev, int reg, u32 addr, const void *b
|
||||||
return wdev->hwbus_ops->copy_to_io(wdev->hwbus_priv, reg, buf, len);
|
return wdev->hwbus_ops->copy_to_io(wdev->hwbus_priv, reg, buf, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int indirect_read_locked(struct wfx_dev *wdev, int reg, u32 addr, void *buf, size_t len)
|
static int indirect_read_locked(struct wfx_dev *wdev, int reg, u32 addr,
|
||||||
|
void *buf, size_t len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -176,7 +183,8 @@ static int indirect_read_locked(struct wfx_dev *wdev, int reg, u32 addr, void *b
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int indirect_write_locked(struct wfx_dev *wdev, int reg, u32 addr, const void *buf, size_t len)
|
static int indirect_write_locked(struct wfx_dev *wdev, int reg, u32 addr,
|
||||||
|
const void *buf, size_t len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -187,7 +195,8 @@ static int indirect_write_locked(struct wfx_dev *wdev, int reg, u32 addr, const
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int indirect_read32_locked(struct wfx_dev *wdev, int reg, u32 addr, u32 *val)
|
static int indirect_read32_locked(struct wfx_dev *wdev, int reg, u32 addr,
|
||||||
|
u32 *val)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
__le32 *tmp = kmalloc(sizeof(u32), GFP_KERNEL);
|
__le32 *tmp = kmalloc(sizeof(u32), GFP_KERNEL);
|
||||||
|
@ -203,7 +212,8 @@ static int indirect_read32_locked(struct wfx_dev *wdev, int reg, u32 addr, u32 *
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int indirect_write32_locked(struct wfx_dev *wdev, int reg, u32 addr, u32 val)
|
static int indirect_write32_locked(struct wfx_dev *wdev, int reg, u32 addr,
|
||||||
|
u32 val)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
__le32 *tmp = kmalloc(sizeof(u32), GFP_KERNEL);
|
__le32 *tmp = kmalloc(sizeof(u32), GFP_KERNEL);
|
||||||
|
@ -225,11 +235,13 @@ int wfx_data_read(struct wfx_dev *wdev, void *buf, size_t len)
|
||||||
|
|
||||||
WARN((long) buf & 3, "%s: unaligned buffer", __func__);
|
WARN((long) buf & 3, "%s: unaligned buffer", __func__);
|
||||||
wdev->hwbus_ops->lock(wdev->hwbus_priv);
|
wdev->hwbus_ops->lock(wdev->hwbus_priv);
|
||||||
ret = wdev->hwbus_ops->copy_from_io(wdev->hwbus_priv, WFX_REG_IN_OUT_QUEUE, buf, len);
|
ret = wdev->hwbus_ops->copy_from_io(wdev->hwbus_priv,
|
||||||
|
WFX_REG_IN_OUT_QUEUE, buf, len);
|
||||||
_trace_io_read(WFX_REG_IN_OUT_QUEUE, buf, len);
|
_trace_io_read(WFX_REG_IN_OUT_QUEUE, buf, len);
|
||||||
wdev->hwbus_ops->unlock(wdev->hwbus_priv);
|
wdev->hwbus_ops->unlock(wdev->hwbus_priv);
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err(wdev->dev, "%s: bus communication error: %d\n", __func__, ret);
|
dev_err(wdev->dev, "%s: bus communication error: %d\n",
|
||||||
|
__func__, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -239,11 +251,13 @@ int wfx_data_write(struct wfx_dev *wdev, const void *buf, size_t len)
|
||||||
|
|
||||||
WARN((long) buf & 3, "%s: unaligned buffer", __func__);
|
WARN((long) buf & 3, "%s: unaligned buffer", __func__);
|
||||||
wdev->hwbus_ops->lock(wdev->hwbus_priv);
|
wdev->hwbus_ops->lock(wdev->hwbus_priv);
|
||||||
ret = wdev->hwbus_ops->copy_to_io(wdev->hwbus_priv, WFX_REG_IN_OUT_QUEUE, buf, len);
|
ret = wdev->hwbus_ops->copy_to_io(wdev->hwbus_priv,
|
||||||
|
WFX_REG_IN_OUT_QUEUE, buf, len);
|
||||||
_trace_io_write(WFX_REG_IN_OUT_QUEUE, buf, len);
|
_trace_io_write(WFX_REG_IN_OUT_QUEUE, buf, len);
|
||||||
wdev->hwbus_ops->unlock(wdev->hwbus_priv);
|
wdev->hwbus_ops->unlock(wdev->hwbus_priv);
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err(wdev->dev, "%s: bus communication error: %d\n", __func__, ret);
|
dev_err(wdev->dev, "%s: bus communication error: %d\n",
|
||||||
|
__func__, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,8 +37,13 @@ int ahb_reg_write(struct wfx_dev *wdev, u32 addr, u32 val);
|
||||||
#define CFG_ERR_HOST_NO_IN_QUEUE 0x00000040
|
#define CFG_ERR_HOST_NO_IN_QUEUE 0x00000040
|
||||||
#define CFG_ERR_HOST_CRC_MISS 0x00000080 // only with SDIO
|
#define CFG_ERR_HOST_CRC_MISS 0x00000080 // only with SDIO
|
||||||
#define CFG_SPI_IGNORE_CS 0x00000080 // only with SPI
|
#define CFG_SPI_IGNORE_CS 0x00000080 // only with SPI
|
||||||
#define CFG_WORD_MODE_MASK 0x00000300 // Bytes ordering (only writable in SPI):
|
/* Bytes ordering (only writable in SPI): */
|
||||||
#define CFG_WORD_MODE0 0x00000000 // B1,B0,B3,B2 (In SPI, register address and CONFIG data always use this mode)
|
#define CFG_WORD_MODE_MASK 0x00000300
|
||||||
|
/*
|
||||||
|
* B1,B0,B3,B2 (In SPI, register address and
|
||||||
|
* CONFIG data always use this mode)
|
||||||
|
*/
|
||||||
|
#define CFG_WORD_MODE0 0x00000000
|
||||||
#define CFG_WORD_MODE1 0x00000100 // B3,B2,B1,B0
|
#define CFG_WORD_MODE1 0x00000100 // B3,B2,B1,B0
|
||||||
#define CFG_WORD_MODE2 0x00000200 // B0,B1,B2,B3 (SDIO)
|
#define CFG_WORD_MODE2 0x00000200 // B0,B1,B2,B3 (SDIO)
|
||||||
#define CFG_DIRECT_ACCESS_MODE 0x00000400 // Direct or queue access mode
|
#define CFG_DIRECT_ACCESS_MODE 0x00000400 // Direct or queue access mode
|
||||||
|
|
|
@ -171,28 +171,36 @@ static int wfx_add_key(struct wfx_vif *wvif, struct ieee80211_sta *sta,
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
k = &wdev->keys[idx];
|
k = &wdev->keys[idx];
|
||||||
k->int_id = wvif->id;
|
k->int_id = wvif->id;
|
||||||
if (key->cipher == WLAN_CIPHER_SUITE_WEP40 || key->cipher == WLAN_CIPHER_SUITE_WEP104) {
|
if (key->cipher == WLAN_CIPHER_SUITE_WEP40 ||
|
||||||
|
key->cipher == WLAN_CIPHER_SUITE_WEP104) {
|
||||||
if (pairwise)
|
if (pairwise)
|
||||||
k->type = fill_wep_pair(&k->key.wep_pairwise_key, key, sta->addr);
|
k->type = fill_wep_pair(&k->key.wep_pairwise_key, key,
|
||||||
|
sta->addr);
|
||||||
else
|
else
|
||||||
k->type = fill_wep_group(&k->key.wep_group_key, key);
|
k->type = fill_wep_group(&k->key.wep_group_key, key);
|
||||||
} else if (key->cipher == WLAN_CIPHER_SUITE_TKIP) {
|
} else if (key->cipher == WLAN_CIPHER_SUITE_TKIP) {
|
||||||
if (pairwise)
|
if (pairwise)
|
||||||
k->type = fill_tkip_pair(&k->key.tkip_pairwise_key, key, sta->addr);
|
k->type = fill_tkip_pair(&k->key.tkip_pairwise_key, key,
|
||||||
|
sta->addr);
|
||||||
else
|
else
|
||||||
k->type = fill_tkip_group(&k->key.tkip_group_key, key, &seq, wvif->vif->type);
|
k->type = fill_tkip_group(&k->key.tkip_group_key, key,
|
||||||
|
&seq, wvif->vif->type);
|
||||||
} else if (key->cipher == WLAN_CIPHER_SUITE_CCMP) {
|
} else if (key->cipher == WLAN_CIPHER_SUITE_CCMP) {
|
||||||
if (pairwise)
|
if (pairwise)
|
||||||
k->type = fill_ccmp_pair(&k->key.aes_pairwise_key, key, sta->addr);
|
k->type = fill_ccmp_pair(&k->key.aes_pairwise_key, key,
|
||||||
|
sta->addr);
|
||||||
else
|
else
|
||||||
k->type = fill_ccmp_group(&k->key.aes_group_key, key, &seq);
|
k->type = fill_ccmp_group(&k->key.aes_group_key, key,
|
||||||
|
&seq);
|
||||||
} else if (key->cipher == WLAN_CIPHER_SUITE_SMS4) {
|
} else if (key->cipher == WLAN_CIPHER_SUITE_SMS4) {
|
||||||
if (pairwise)
|
if (pairwise)
|
||||||
k->type = fill_sms4_pair(&k->key.wapi_pairwise_key, key, sta->addr);
|
k->type = fill_sms4_pair(&k->key.wapi_pairwise_key, key,
|
||||||
|
sta->addr);
|
||||||
else
|
else
|
||||||
k->type = fill_sms4_group(&k->key.wapi_group_key, key);
|
k->type = fill_sms4_group(&k->key.wapi_group_key, key);
|
||||||
} else if (key->cipher == WLAN_CIPHER_SUITE_AES_CMAC) {
|
} else if (key->cipher == WLAN_CIPHER_SUITE_AES_CMAC) {
|
||||||
k->type = fill_aes_cmac_group(&k->key.igtk_group_key, key, &seq);
|
k->type = fill_aes_cmac_group(&k->key.igtk_group_key, key,
|
||||||
|
&seq);
|
||||||
} else {
|
} else {
|
||||||
dev_warn(wdev->dev, "unsupported key type %d\n", key->cipher);
|
dev_warn(wdev->dev, "unsupported key type %d\n", key->cipher);
|
||||||
wfx_free_key(wdev, idx);
|
wfx_free_key(wdev, idx);
|
||||||
|
|
|
@ -99,7 +99,8 @@ static const struct ieee80211_supported_band wfx_band_2ghz = {
|
||||||
.ht_cap = {
|
.ht_cap = {
|
||||||
// Receive caps
|
// Receive caps
|
||||||
.cap = IEEE80211_HT_CAP_GRN_FLD | IEEE80211_HT_CAP_SGI_20 |
|
.cap = IEEE80211_HT_CAP_GRN_FLD | IEEE80211_HT_CAP_SGI_20 |
|
||||||
IEEE80211_HT_CAP_MAX_AMSDU | (1 << IEEE80211_HT_CAP_RX_STBC_SHIFT),
|
IEEE80211_HT_CAP_MAX_AMSDU |
|
||||||
|
(1 << IEEE80211_HT_CAP_RX_STBC_SHIFT),
|
||||||
.ht_supported = 1,
|
.ht_supported = 1,
|
||||||
.ampdu_factor = IEEE80211_HT_MAX_AMPDU_16K,
|
.ampdu_factor = IEEE80211_HT_MAX_AMPDU_16K,
|
||||||
.ampdu_density = IEEE80211_HT_MPDU_DENSITY_NONE,
|
.ampdu_density = IEEE80211_HT_MPDU_DENSITY_NONE,
|
||||||
|
@ -163,14 +164,17 @@ bool wfx_api_older_than(struct wfx_dev *wdev, int major, int minor)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct gpio_desc *wfx_get_gpio(struct device *dev, int override, const char *label)
|
struct gpio_desc *wfx_get_gpio(struct device *dev, int override,
|
||||||
|
const char *label)
|
||||||
{
|
{
|
||||||
struct gpio_desc *ret;
|
struct gpio_desc *ret;
|
||||||
char label_buf[256];
|
char label_buf[256];
|
||||||
|
|
||||||
if (override >= 0) {
|
if (override >= 0) {
|
||||||
snprintf(label_buf, sizeof(label_buf), "wfx_%s", label);
|
snprintf(label_buf, sizeof(label_buf), "wfx_%s", label);
|
||||||
ret = ERR_PTR(devm_gpio_request_one(dev, override, GPIOF_OUT_INIT_LOW, label_buf));
|
ret = ERR_PTR(devm_gpio_request_one(dev, override,
|
||||||
|
GPIOF_OUT_INIT_LOW,
|
||||||
|
label_buf));
|
||||||
if (!ret)
|
if (!ret)
|
||||||
ret = gpio_to_desc(override);
|
ret = gpio_to_desc(override);
|
||||||
} else if (override == -1) {
|
} else if (override == -1) {
|
||||||
|
@ -182,10 +186,12 @@ struct gpio_desc *wfx_get_gpio(struct device *dev, int override, const char *lab
|
||||||
if (!ret || PTR_ERR(ret) == -ENOENT)
|
if (!ret || PTR_ERR(ret) == -ENOENT)
|
||||||
dev_warn(dev, "gpio %s is not defined\n", label);
|
dev_warn(dev, "gpio %s is not defined\n", label);
|
||||||
else
|
else
|
||||||
dev_warn(dev, "error while requesting gpio %s\n", label);
|
dev_warn(dev,
|
||||||
|
"error while requesting gpio %s\n", label);
|
||||||
ret = NULL;
|
ret = NULL;
|
||||||
} else {
|
} else {
|
||||||
dev_dbg(dev, "using gpio %d for %s\n", desc_to_gpio(ret), label);
|
dev_dbg(dev,
|
||||||
|
"using gpio %d for %s\n", desc_to_gpio(ret), label);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -215,7 +221,8 @@ int wfx_send_pds(struct wfx_dev *wdev, unsigned char *buf, size_t len)
|
||||||
buf[i] = 0;
|
buf[i] = 0;
|
||||||
dev_dbg(wdev->dev, "send PDS '%s}'\n", buf + start);
|
dev_dbg(wdev->dev, "send PDS '%s}'\n", buf + start);
|
||||||
buf[i] = '}';
|
buf[i] = '}';
|
||||||
ret = hif_configuration(wdev, buf + start, i - start + 1);
|
ret = hif_configuration(wdev, buf + start,
|
||||||
|
i - start + 1);
|
||||||
if (ret == HIF_STATUS_FAILURE) {
|
if (ret == HIF_STATUS_FAILURE) {
|
||||||
dev_err(wdev->dev, "PDS bytes %d to %d: invalid data (unsupported options?)\n", start, i);
|
dev_err(wdev->dev, "PDS bytes %d to %d: invalid data (unsupported options?)\n", start, i);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -243,7 +250,8 @@ static int wfx_send_pdata_pds(struct wfx_dev *wdev)
|
||||||
|
|
||||||
ret = request_firmware(&pds, wdev->pdata.file_pds, wdev->dev);
|
ret = request_firmware(&pds, wdev->pdata.file_pds, wdev->dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(wdev->dev, "can't load PDS file %s\n", wdev->pdata.file_pds);
|
dev_err(wdev->dev, "can't load PDS file %s\n",
|
||||||
|
wdev->pdata.file_pds);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
tmp_buf = kmemdup(pds->data, pds->size, GFP_KERNEL);
|
tmp_buf = kmemdup(pds->data, pds->size, GFP_KERNEL);
|
||||||
|
@ -282,7 +290,8 @@ struct wfx_dev *wfx_init_common(struct device *dev,
|
||||||
hw->queues = 4;
|
hw->queues = 4;
|
||||||
hw->max_rates = 8;
|
hw->max_rates = 8;
|
||||||
hw->max_rate_tries = 15;
|
hw->max_rate_tries = 15;
|
||||||
hw->extra_tx_headroom = sizeof(struct hif_sl_msg_hdr) + sizeof(struct hif_msg)
|
hw->extra_tx_headroom = sizeof(struct hif_sl_msg_hdr) +
|
||||||
|
sizeof(struct hif_msg)
|
||||||
+ sizeof(struct hif_req_tx)
|
+ sizeof(struct hif_req_tx)
|
||||||
+ 4 /* alignment */ + 8 /* TKIP IV */;
|
+ 4 /* alignment */ + 8 /* TKIP IV */;
|
||||||
hw->wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) |
|
hw->wiphy->interface_modes = BIT(NL80211_IFTYPE_STATION) |
|
||||||
|
@ -297,7 +306,8 @@ struct wfx_dev *wfx_init_common(struct device *dev,
|
||||||
hw->wiphy->iface_combinations = wfx_iface_combinations;
|
hw->wiphy->iface_combinations = wfx_iface_combinations;
|
||||||
hw->wiphy->bands[NL80211_BAND_2GHZ] = devm_kmalloc(dev, sizeof(wfx_band_2ghz), GFP_KERNEL);
|
hw->wiphy->bands[NL80211_BAND_2GHZ] = devm_kmalloc(dev, sizeof(wfx_band_2ghz), GFP_KERNEL);
|
||||||
// FIXME: also copy wfx_rates and wfx_2ghz_chantable
|
// FIXME: also copy wfx_rates and wfx_2ghz_chantable
|
||||||
memcpy(hw->wiphy->bands[NL80211_BAND_2GHZ], &wfx_band_2ghz, sizeof(wfx_band_2ghz));
|
memcpy(hw->wiphy->bands[NL80211_BAND_2GHZ], &wfx_band_2ghz,
|
||||||
|
sizeof(wfx_band_2ghz));
|
||||||
|
|
||||||
wdev = hw->priv;
|
wdev = hw->priv;
|
||||||
wdev->hw = hw;
|
wdev->hw = hw;
|
||||||
|
@ -305,7 +315,8 @@ struct wfx_dev *wfx_init_common(struct device *dev,
|
||||||
wdev->hwbus_ops = hwbus_ops;
|
wdev->hwbus_ops = hwbus_ops;
|
||||||
wdev->hwbus_priv = hwbus_priv;
|
wdev->hwbus_priv = hwbus_priv;
|
||||||
memcpy(&wdev->pdata, pdata, sizeof(*pdata));
|
memcpy(&wdev->pdata, pdata, sizeof(*pdata));
|
||||||
of_property_read_string(dev->of_node, "config-file", &wdev->pdata.file_pds);
|
of_property_read_string(dev->of_node, "config-file",
|
||||||
|
&wdev->pdata.file_pds);
|
||||||
wdev->pdata.gpio_wakeup = wfx_get_gpio(dev, gpio_wakeup, "wakeup");
|
wdev->pdata.gpio_wakeup = wfx_get_gpio(dev, gpio_wakeup, "wakeup");
|
||||||
wfx_sl_fill_pdata(dev, &wdev->pdata);
|
wfx_sl_fill_pdata(dev, &wdev->pdata);
|
||||||
|
|
||||||
|
@ -344,7 +355,8 @@ int wfx_probe(struct wfx_dev *wdev)
|
||||||
if (err)
|
if (err)
|
||||||
goto err1;
|
goto err1;
|
||||||
|
|
||||||
err = wait_for_completion_interruptible_timeout(&wdev->firmware_ready, 10 * HZ);
|
err = wait_for_completion_interruptible_timeout(&wdev->firmware_ready,
|
||||||
|
10 * HZ);
|
||||||
if (err <= 0) {
|
if (err <= 0) {
|
||||||
if (err == 0) {
|
if (err == 0) {
|
||||||
dev_err(wdev->dev, "timeout while waiting for startup indication. IRQ configuration error?\n");
|
dev_err(wdev->dev, "timeout while waiting for startup indication. IRQ configuration error?\n");
|
||||||
|
@ -359,16 +371,19 @@ int wfx_probe(struct wfx_dev *wdev)
|
||||||
dev_info(wdev->dev, "started firmware %d.%d.%d \"%s\" (API: %d.%d, keyset: %02X, caps: 0x%.8X)\n",
|
dev_info(wdev->dev, "started firmware %d.%d.%d \"%s\" (API: %d.%d, keyset: %02X, caps: 0x%.8X)\n",
|
||||||
wdev->hw_caps.firmware_major, wdev->hw_caps.firmware_minor,
|
wdev->hw_caps.firmware_major, wdev->hw_caps.firmware_minor,
|
||||||
wdev->hw_caps.firmware_build, wdev->hw_caps.firmware_label,
|
wdev->hw_caps.firmware_build, wdev->hw_caps.firmware_label,
|
||||||
wdev->hw_caps.api_version_major, wdev->hw_caps.api_version_minor,
|
wdev->hw_caps.api_version_major,
|
||||||
|
wdev->hw_caps.api_version_minor,
|
||||||
wdev->keyset, *((u32 *) &wdev->hw_caps.capabilities));
|
wdev->keyset, *((u32 *) &wdev->hw_caps.capabilities));
|
||||||
snprintf(wdev->hw->wiphy->fw_version, sizeof(wdev->hw->wiphy->fw_version),
|
snprintf(wdev->hw->wiphy->fw_version,
|
||||||
|
sizeof(wdev->hw->wiphy->fw_version),
|
||||||
"%d.%d.%d",
|
"%d.%d.%d",
|
||||||
wdev->hw_caps.firmware_major,
|
wdev->hw_caps.firmware_major,
|
||||||
wdev->hw_caps.firmware_minor,
|
wdev->hw_caps.firmware_minor,
|
||||||
wdev->hw_caps.firmware_build);
|
wdev->hw_caps.firmware_build);
|
||||||
|
|
||||||
if (wfx_api_older_than(wdev, 1, 0)) {
|
if (wfx_api_older_than(wdev, 1, 0)) {
|
||||||
dev_err(wdev->dev, "unsupported firmware API version (expect 1 while firmware returns %d)\n",
|
dev_err(wdev->dev,
|
||||||
|
"unsupported firmware API version (expect 1 while firmware returns %d)\n",
|
||||||
wdev->hw_caps.api_version_major);
|
wdev->hw_caps.api_version_major);
|
||||||
err = -ENOTSUPP;
|
err = -ENOTSUPP;
|
||||||
goto err1;
|
goto err1;
|
||||||
|
@ -376,7 +391,8 @@ int wfx_probe(struct wfx_dev *wdev)
|
||||||
|
|
||||||
err = wfx_sl_init(wdev);
|
err = wfx_sl_init(wdev);
|
||||||
if (err && wdev->hw_caps.capabilities.link_mode == SEC_LINK_ENFORCED) {
|
if (err && wdev->hw_caps.capabilities.link_mode == SEC_LINK_ENFORCED) {
|
||||||
dev_err(wdev->dev, "chip require secure_link, but can't negociate it\n");
|
dev_err(wdev->dev,
|
||||||
|
"chip require secure_link, but can't negociate it\n");
|
||||||
goto err1;
|
goto err1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -386,15 +402,18 @@ int wfx_probe(struct wfx_dev *wdev)
|
||||||
wdev->hw->wiphy->bands[NL80211_BAND_2GHZ]->channels[13].flags |= IEEE80211_CHAN_DISABLED;
|
wdev->hw->wiphy->bands[NL80211_BAND_2GHZ]->channels[13].flags |= IEEE80211_CHAN_DISABLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
dev_dbg(wdev->dev, "sending configuration file %s\n", wdev->pdata.file_pds);
|
dev_dbg(wdev->dev, "sending configuration file %s\n",
|
||||||
|
wdev->pdata.file_pds);
|
||||||
err = wfx_send_pdata_pds(wdev);
|
err = wfx_send_pdata_pds(wdev);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto err1;
|
goto err1;
|
||||||
|
|
||||||
wdev->pdata.gpio_wakeup = gpio_saved;
|
wdev->pdata.gpio_wakeup = gpio_saved;
|
||||||
if (wdev->pdata.gpio_wakeup) {
|
if (wdev->pdata.gpio_wakeup) {
|
||||||
dev_dbg(wdev->dev, "enable 'quiescent' power mode with gpio %d and PDS file %s\n",
|
dev_dbg(wdev->dev,
|
||||||
desc_to_gpio(wdev->pdata.gpio_wakeup), wdev->pdata.file_pds);
|
"enable 'quiescent' power mode with gpio %d and PDS file %s\n",
|
||||||
|
desc_to_gpio(wdev->pdata.gpio_wakeup),
|
||||||
|
wdev->pdata.file_pds);
|
||||||
gpiod_set_value(wdev->pdata.gpio_wakeup, 1);
|
gpiod_set_value(wdev->pdata.gpio_wakeup, 1);
|
||||||
control_reg_write(wdev, 0);
|
control_reg_write(wdev, 0);
|
||||||
hif_set_operational_mode(wdev, HIF_OP_POWER_MODE_QUIESCENT);
|
hif_set_operational_mode(wdev, HIF_OP_POWER_MODE_QUIESCENT);
|
||||||
|
@ -411,13 +430,15 @@ int wfx_probe(struct wfx_dev *wdev)
|
||||||
ether_addr_copy(wdev->addresses[i].addr, macaddr);
|
ether_addr_copy(wdev->addresses[i].addr, macaddr);
|
||||||
wdev->addresses[i].addr[ETH_ALEN - 1] += i;
|
wdev->addresses[i].addr[ETH_ALEN - 1] += i;
|
||||||
} else {
|
} else {
|
||||||
ether_addr_copy(wdev->addresses[i].addr, wdev->hw_caps.mac_addr[i]);
|
ether_addr_copy(wdev->addresses[i].addr,
|
||||||
|
wdev->hw_caps.mac_addr[i]);
|
||||||
}
|
}
|
||||||
if (!is_valid_ether_addr(wdev->addresses[i].addr)) {
|
if (!is_valid_ether_addr(wdev->addresses[i].addr)) {
|
||||||
dev_warn(wdev->dev, "using random MAC address\n");
|
dev_warn(wdev->dev, "using random MAC address\n");
|
||||||
eth_random_addr(wdev->addresses[i].addr);
|
eth_random_addr(wdev->addresses[i].addr);
|
||||||
}
|
}
|
||||||
dev_info(wdev->dev, "MAC address %d: %pM\n", i, wdev->addresses[i].addr);
|
dev_info(wdev->dev, "MAC address %d: %pM\n", i,
|
||||||
|
wdev->addresses[i].addr);
|
||||||
}
|
}
|
||||||
wdev->hw->wiphy->n_addresses = ARRAY_SIZE(wdev->addresses);
|
wdev->hw->wiphy->n_addresses = ARRAY_SIZE(wdev->addresses);
|
||||||
wdev->hw->wiphy->addresses = wdev->addresses;
|
wdev->hw->wiphy->addresses = wdev->addresses;
|
||||||
|
|
|
@ -42,7 +42,8 @@ void wfx_tx_flush(struct wfx_dev *wdev)
|
||||||
!wdev->hif.tx_buffers_used,
|
!wdev->hif.tx_buffers_used,
|
||||||
msecs_to_jiffies(3000));
|
msecs_to_jiffies(3000));
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
dev_warn(wdev->dev, "cannot flush tx buffers (%d still busy)\n", wdev->hif.tx_buffers_used);
|
dev_warn(wdev->dev, "cannot flush tx buffers (%d still busy)\n",
|
||||||
|
wdev->hif.tx_buffers_used);
|
||||||
wfx_pending_dump_old_frames(wdev, 3000);
|
wfx_pending_dump_old_frames(wdev, 3000);
|
||||||
// FIXME: drop pending frames here
|
// FIXME: drop pending frames here
|
||||||
wdev->chip_frozen = 1;
|
wdev->chip_frozen = 1;
|
||||||
|
@ -121,7 +122,8 @@ void wfx_tx_queues_wait_empty_vif(struct wfx_vif *wvif)
|
||||||
} while (!done);
|
} while (!done);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wfx_tx_queue_clear(struct wfx_dev *wdev, struct wfx_queue *queue, struct sk_buff_head *gc_list)
|
static void wfx_tx_queue_clear(struct wfx_dev *wdev, struct wfx_queue *queue,
|
||||||
|
struct sk_buff_head *gc_list)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
struct sk_buff *item;
|
struct sk_buff *item;
|
||||||
|
@ -189,7 +191,8 @@ size_t wfx_tx_queue_get_num_queued(struct wfx_queue *queue,
|
||||||
ret = skb_queue_len(&queue->queue);
|
ret = skb_queue_len(&queue->queue);
|
||||||
} else {
|
} else {
|
||||||
ret = 0;
|
ret = 0;
|
||||||
for (i = 0, bit = 1; i < ARRAY_SIZE(queue->link_map_cache); ++i, bit <<= 1) {
|
for (i = 0, bit = 1; i < ARRAY_SIZE(queue->link_map_cache);
|
||||||
|
++i, bit <<= 1) {
|
||||||
if (link_id_map & bit)
|
if (link_id_map & bit)
|
||||||
ret += queue->link_map_cache[i];
|
ret += queue->link_map_cache[i];
|
||||||
}
|
}
|
||||||
|
@ -198,7 +201,8 @@ size_t wfx_tx_queue_get_num_queued(struct wfx_queue *queue,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wfx_tx_queue_put(struct wfx_dev *wdev, struct wfx_queue *queue, struct sk_buff *skb)
|
void wfx_tx_queue_put(struct wfx_dev *wdev, struct wfx_queue *queue,
|
||||||
|
struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
struct wfx_queue_stats *stats = &wdev->tx_queue_stats;
|
struct wfx_queue_stats *stats = &wdev->tx_queue_stats;
|
||||||
struct wfx_tx_priv *tx_priv = wfx_skb_tx_priv(skb);
|
struct wfx_tx_priv *tx_priv = wfx_skb_tx_priv(skb);
|
||||||
|
@ -315,7 +319,8 @@ void wfx_pending_dump_old_frames(struct wfx_dev *wdev, unsigned int limit_ms)
|
||||||
skb_queue_walk(&stats->pending, skb) {
|
skb_queue_walk(&stats->pending, skb) {
|
||||||
tx_priv = wfx_skb_tx_priv(skb);
|
tx_priv = wfx_skb_tx_priv(skb);
|
||||||
req = wfx_skb_txreq(skb);
|
req = wfx_skb_txreq(skb);
|
||||||
if (ktime_after(now, ktime_add_ms(tx_priv->xmit_timestamp, limit_ms))) {
|
if (ktime_after(now, ktime_add_ms(tx_priv->xmit_timestamp,
|
||||||
|
limit_ms))) {
|
||||||
if (first) {
|
if (first) {
|
||||||
dev_info(wdev->dev, "frames stuck in firmware since %dms or more:\n",
|
dev_info(wdev->dev, "frames stuck in firmware since %dms or more:\n",
|
||||||
limit_ms);
|
limit_ms);
|
||||||
|
@ -329,7 +334,8 @@ void wfx_pending_dump_old_frames(struct wfx_dev *wdev, unsigned int limit_ms)
|
||||||
spin_unlock_bh(&stats->pending.lock);
|
spin_unlock_bh(&stats->pending.lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int wfx_pending_get_pkt_us_delay(struct wfx_dev *wdev, struct sk_buff *skb)
|
unsigned int wfx_pending_get_pkt_us_delay(struct wfx_dev *wdev,
|
||||||
|
struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
ktime_t now = ktime_get();
|
ktime_t now = ktime_get();
|
||||||
struct wfx_tx_priv *tx_priv = wfx_skb_tx_priv(skb);
|
struct wfx_tx_priv *tx_priv = wfx_skb_tx_priv(skb);
|
||||||
|
@ -376,7 +382,8 @@ static bool hif_handle_tx_data(struct wfx_vif *wvif, struct sk_buff *skb,
|
||||||
case NL80211_IFTYPE_AP:
|
case NL80211_IFTYPE_AP:
|
||||||
if (!wvif->state) {
|
if (!wvif->state) {
|
||||||
action = do_drop;
|
action = do_drop;
|
||||||
} else if (!(BIT(tx_priv->raw_link_id) & (BIT(0) | wvif->link_id_map))) {
|
} else if (!(BIT(tx_priv->raw_link_id) &
|
||||||
|
(BIT(0) | wvif->link_id_map))) {
|
||||||
dev_warn(wvif->wdev->dev, "a frame with expired link-id is dropped\n");
|
dev_warn(wvif->wdev->dev, "a frame with expired link-id is dropped\n");
|
||||||
action = do_drop;
|
action = do_drop;
|
||||||
}
|
}
|
||||||
|
@ -462,7 +469,8 @@ static int wfx_get_prio_queue(struct wfx_vif *wvif,
|
||||||
/* override winner if bursting */
|
/* override winner if bursting */
|
||||||
if (winner >= 0 && wvif->wdev->tx_burst_idx >= 0 &&
|
if (winner >= 0 && wvif->wdev->tx_burst_idx >= 0 &&
|
||||||
winner != wvif->wdev->tx_burst_idx &&
|
winner != wvif->wdev->tx_burst_idx &&
|
||||||
!wfx_tx_queue_get_num_queued(&wvif->wdev->tx_queue[winner], tx_allowed_mask & urgent) &&
|
!wfx_tx_queue_get_num_queued(&wvif->wdev->tx_queue[winner],
|
||||||
|
tx_allowed_mask & urgent) &&
|
||||||
wfx_tx_queue_get_num_queued(&wvif->wdev->tx_queue[wvif->wdev->tx_burst_idx], tx_allowed_mask))
|
wfx_tx_queue_get_num_queued(&wvif->wdev->tx_queue[wvif->wdev->tx_burst_idx], tx_allowed_mask))
|
||||||
winner = wvif->wdev->tx_burst_idx;
|
winner = wvif->wdev->tx_burst_idx;
|
||||||
|
|
||||||
|
@ -536,10 +544,13 @@ struct hif_msg *wfx_tx_queues_get(struct wfx_dev *wdev)
|
||||||
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
||||||
spin_lock_bh(&wvif->ps_state_lock);
|
spin_lock_bh(&wvif->ps_state_lock);
|
||||||
|
|
||||||
not_found = wfx_tx_queue_mask_get(wvif, &vif_queue, &vif_tx_allowed_mask, &vif_more);
|
not_found = wfx_tx_queue_mask_get(wvif, &vif_queue,
|
||||||
|
&vif_tx_allowed_mask,
|
||||||
|
&vif_more);
|
||||||
|
|
||||||
if (wvif->mcast_buffered && (not_found || !vif_more) &&
|
if (wvif->mcast_buffered && (not_found || !vif_more) &&
|
||||||
(wvif->mcast_tx || !wvif->sta_asleep_mask)) {
|
(wvif->mcast_tx ||
|
||||||
|
!wvif->sta_asleep_mask)) {
|
||||||
wvif->mcast_buffered = false;
|
wvif->mcast_buffered = false;
|
||||||
if (wvif->mcast_tx) {
|
if (wvif->mcast_tx) {
|
||||||
wvif->mcast_tx = false;
|
wvif->mcast_tx = false;
|
||||||
|
|
|
@ -47,13 +47,15 @@ bool wfx_tx_queues_is_empty(struct wfx_dev *wdev);
|
||||||
void wfx_tx_queues_wait_empty_vif(struct wfx_vif *wvif);
|
void wfx_tx_queues_wait_empty_vif(struct wfx_vif *wvif);
|
||||||
struct hif_msg *wfx_tx_queues_get(struct wfx_dev *wdev);
|
struct hif_msg *wfx_tx_queues_get(struct wfx_dev *wdev);
|
||||||
|
|
||||||
void wfx_tx_queue_put(struct wfx_dev *wdev, struct wfx_queue *queue, struct sk_buff *skb);
|
void wfx_tx_queue_put(struct wfx_dev *wdev, struct wfx_queue *queue,
|
||||||
|
struct sk_buff *skb);
|
||||||
size_t wfx_tx_queue_get_num_queued(struct wfx_queue *queue, u32 link_id_map);
|
size_t wfx_tx_queue_get_num_queued(struct wfx_queue *queue, u32 link_id_map);
|
||||||
|
|
||||||
struct sk_buff *wfx_pending_get(struct wfx_dev *wdev, u32 packet_id);
|
struct sk_buff *wfx_pending_get(struct wfx_dev *wdev, u32 packet_id);
|
||||||
int wfx_pending_remove(struct wfx_dev *wdev, struct sk_buff *skb);
|
int wfx_pending_remove(struct wfx_dev *wdev, struct sk_buff *skb);
|
||||||
int wfx_pending_requeue(struct wfx_dev *wdev, struct sk_buff *skb);
|
int wfx_pending_requeue(struct wfx_dev *wdev, struct sk_buff *skb);
|
||||||
unsigned int wfx_pending_get_pkt_us_delay(struct wfx_dev *wdev, struct sk_buff *skb);
|
unsigned int wfx_pending_get_pkt_us_delay(struct wfx_dev *wdev,
|
||||||
|
struct sk_buff *skb);
|
||||||
void wfx_pending_dump_old_frames(struct wfx_dev *wdev, unsigned int limit_ms);
|
void wfx_pending_dump_old_frames(struct wfx_dev *wdev, unsigned int limit_ms);
|
||||||
|
|
||||||
#endif /* WFX_QUEUE_H */
|
#endif /* WFX_QUEUE_H */
|
||||||
|
|
|
@ -12,7 +12,8 @@
|
||||||
#include "sta.h"
|
#include "sta.h"
|
||||||
#include "hif_tx_mib.h"
|
#include "hif_tx_mib.h"
|
||||||
|
|
||||||
static void __ieee80211_scan_completed_compat(struct ieee80211_hw *hw, bool aborted)
|
static void __ieee80211_scan_completed_compat(struct ieee80211_hw *hw,
|
||||||
|
bool aborted)
|
||||||
{
|
{
|
||||||
struct cfg80211_scan_info info = {
|
struct cfg80211_scan_info info = {
|
||||||
.aborted = aborted ? 1 : 0,
|
.aborted = aborted ? 1 : 0,
|
||||||
|
@ -159,7 +160,8 @@ void wfx_scan_work(struct work_struct *work)
|
||||||
|
|
||||||
if (!wvif->scan.req || wvif->scan.curr == wvif->scan.end) {
|
if (!wvif->scan.req || wvif->scan.curr == wvif->scan.end) {
|
||||||
if (wvif->scan.output_power != wvif->wdev->output_power)
|
if (wvif->scan.output_power != wvif->wdev->output_power)
|
||||||
hif_set_output_power(wvif, wvif->wdev->output_power * 10);
|
hif_set_output_power(wvif,
|
||||||
|
wvif->wdev->output_power * 10);
|
||||||
|
|
||||||
if (wvif->scan.status < 0)
|
if (wvif->scan.status < 0)
|
||||||
dev_warn(wvif->wdev->dev, "scan failed\n");
|
dev_warn(wvif->wdev->dev, "scan failed\n");
|
||||||
|
@ -172,7 +174,8 @@ void wfx_scan_work(struct work_struct *work)
|
||||||
wfx_scan_restart_delayed(wvif);
|
wfx_scan_restart_delayed(wvif);
|
||||||
wfx_tx_unlock(wvif->wdev);
|
wfx_tx_unlock(wvif->wdev);
|
||||||
mutex_unlock(&wvif->wdev->conf_mutex);
|
mutex_unlock(&wvif->wdev->conf_mutex);
|
||||||
__ieee80211_scan_completed_compat(wvif->wdev->hw, wvif->scan.status ? 1 : 0);
|
__ieee80211_scan_completed_compat(wvif->wdev->hw,
|
||||||
|
wvif->scan.status ? 1 : 0);
|
||||||
up(&wvif->scan.lock);
|
up(&wvif->scan.lock);
|
||||||
if (wvif->state == WFX_STATE_STA &&
|
if (wvif->state == WFX_STATE_STA &&
|
||||||
!(wvif->powersave_mode.pm_mode.enter_psm))
|
!(wvif->powersave_mode.pm_mode.enter_psm))
|
||||||
|
@ -211,7 +214,8 @@ void wfx_scan_work(struct work_struct *work)
|
||||||
scan.scan_req.scan_flags.fbg = 1;
|
scan.scan_req.scan_flags.fbg = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
scan.ch = kcalloc(scan.scan_req.num_of_channels, sizeof(u8), GFP_KERNEL);
|
scan.ch = kcalloc(scan.scan_req.num_of_channels,
|
||||||
|
sizeof(u8), GFP_KERNEL);
|
||||||
|
|
||||||
if (!scan.ch) {
|
if (!scan.ch) {
|
||||||
wvif->scan.status = -ENOMEM;
|
wvif->scan.status = -ENOMEM;
|
||||||
|
@ -273,7 +277,8 @@ void wfx_scan_complete_cb(struct wfx_vif *wvif, struct hif_ind_scan_cmpl *arg)
|
||||||
|
|
||||||
void wfx_scan_timeout(struct work_struct *work)
|
void wfx_scan_timeout(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, scan.timeout.work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
scan.timeout.work);
|
||||||
|
|
||||||
if (atomic_xchg(&wvif->scan.in_progress, 0)) {
|
if (atomic_xchg(&wvif->scan.in_progress, 0)) {
|
||||||
if (wvif->scan.status > 0) {
|
if (wvif->scan.status > 0) {
|
||||||
|
|
|
@ -100,7 +100,8 @@ void wfx_cqm_bssloss_sm(struct wfx_vif *wvif, int init, int good, int bad)
|
||||||
skb = ieee80211_nullfunc_get(wvif->wdev->hw, wvif->vif, false);
|
skb = ieee80211_nullfunc_get(wvif->wdev->hw, wvif->vif, false);
|
||||||
if (!skb)
|
if (!skb)
|
||||||
goto end;
|
goto end;
|
||||||
memset(IEEE80211_SKB_CB(skb), 0, sizeof(*IEEE80211_SKB_CB(skb)));
|
memset(IEEE80211_SKB_CB(skb), 0,
|
||||||
|
sizeof(*IEEE80211_SKB_CB(skb)));
|
||||||
IEEE80211_SKB_CB(skb)->control.vif = wvif->vif;
|
IEEE80211_SKB_CB(skb)->control.vif = wvif->vif;
|
||||||
IEEE80211_SKB_CB(skb)->driver_rates[0].idx = 0;
|
IEEE80211_SKB_CB(skb)->driver_rates[0].idx = 0;
|
||||||
IEEE80211_SKB_CB(skb)->driver_rates[0].count = 1;
|
IEEE80211_SKB_CB(skb)->driver_rates[0].count = 1;
|
||||||
|
@ -177,8 +178,10 @@ static int wfx_set_mcast_filter(struct wfx_vif *wvif,
|
||||||
for (i = 0; i < fp->num_addresses; i++) {
|
for (i = 0; i < fp->num_addresses; i++) {
|
||||||
filter_addr_val.condition_idx = i;
|
filter_addr_val.condition_idx = i;
|
||||||
filter_addr_val.address_type = HIF_MAC_ADDR_A1;
|
filter_addr_val.address_type = HIF_MAC_ADDR_A1;
|
||||||
ether_addr_copy(filter_addr_val.mac_address, fp->address_list[i]);
|
ether_addr_copy(filter_addr_val.mac_address,
|
||||||
ret = hif_set_mac_addr_condition(wvif, &filter_addr_val);
|
fp->address_list[i]);
|
||||||
|
ret = hif_set_mac_addr_condition(wvif,
|
||||||
|
&filter_addr_val);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
config.mac_cond |= 1 << i;
|
config.mac_cond |= 1 << i;
|
||||||
|
@ -243,7 +246,8 @@ void wfx_update_filtering(struct wfx_vif *wvif)
|
||||||
bf_ctrl.bcn_count = 1;
|
bf_ctrl.bcn_count = 1;
|
||||||
n_filter_ies = 0;
|
n_filter_ies = 0;
|
||||||
} else if (!is_sta) {
|
} else if (!is_sta) {
|
||||||
bf_ctrl.enable = HIF_BEACON_FILTER_ENABLE | HIF_BEACON_FILTER_AUTO_ERP;
|
bf_ctrl.enable = HIF_BEACON_FILTER_ENABLE |
|
||||||
|
HIF_BEACON_FILTER_AUTO_ERP;
|
||||||
bf_ctrl.bcn_count = 0;
|
bf_ctrl.bcn_count = 0;
|
||||||
n_filter_ies = 2;
|
n_filter_ies = 2;
|
||||||
} else {
|
} else {
|
||||||
|
@ -254,9 +258,11 @@ void wfx_update_filtering(struct wfx_vif *wvif)
|
||||||
|
|
||||||
ret = hif_set_rx_filter(wvif, filter_bssid, fwd_probe_req);
|
ret = hif_set_rx_filter(wvif, filter_bssid, fwd_probe_req);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
ret = hif_set_beacon_filter_table(wvif, n_filter_ies, filter_ies);
|
ret = hif_set_beacon_filter_table(wvif, n_filter_ies,
|
||||||
|
filter_ies);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
ret = hif_beacon_filter_control(wvif, bf_ctrl.enable, bf_ctrl.bcn_count);
|
ret = hif_beacon_filter_control(wvif, bf_ctrl.enable,
|
||||||
|
bf_ctrl.bcn_count);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
ret = wfx_set_mcast_filter(wvif, &wvif->mcast_filter);
|
ret = wfx_set_mcast_filter(wvif, &wvif->mcast_filter);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -265,12 +271,14 @@ void wfx_update_filtering(struct wfx_vif *wvif)
|
||||||
|
|
||||||
static void wfx_update_filtering_work(struct work_struct *work)
|
static void wfx_update_filtering_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, update_filtering_work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
update_filtering_work);
|
||||||
|
|
||||||
wfx_update_filtering(wvif);
|
wfx_update_filtering(wvif);
|
||||||
}
|
}
|
||||||
|
|
||||||
u64 wfx_prepare_multicast(struct ieee80211_hw *hw, struct netdev_hw_addr_list *mc_list)
|
u64 wfx_prepare_multicast(struct ieee80211_hw *hw,
|
||||||
|
struct netdev_hw_addr_list *mc_list)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
struct netdev_hw_addr *ha;
|
struct netdev_hw_addr *ha;
|
||||||
|
@ -280,12 +288,14 @@ u64 wfx_prepare_multicast(struct ieee80211_hw *hw, struct netdev_hw_addr_list *m
|
||||||
|
|
||||||
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
||||||
memset(&wvif->mcast_filter, 0x00, sizeof(wvif->mcast_filter));
|
memset(&wvif->mcast_filter, 0x00, sizeof(wvif->mcast_filter));
|
||||||
if (!count || count > ARRAY_SIZE(wvif->mcast_filter.address_list))
|
if (!count ||
|
||||||
|
count > ARRAY_SIZE(wvif->mcast_filter.address_list))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
netdev_hw_addr_list_for_each(ha, mc_list) {
|
netdev_hw_addr_list_for_each(ha, mc_list) {
|
||||||
ether_addr_copy(wvif->mcast_filter.address_list[i], ha->addr);
|
ether_addr_copy(wvif->mcast_filter.address_list[i],
|
||||||
|
ha->addr);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
wvif->mcast_filter.enable = true;
|
wvif->mcast_filter.enable = true;
|
||||||
|
@ -307,7 +317,8 @@ void wfx_configure_filter(struct ieee80211_hw *hw,
|
||||||
|
|
||||||
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
||||||
down(&wvif->scan.lock);
|
down(&wvif->scan.lock);
|
||||||
wvif->filter_bssid = (*total_flags & (FIF_OTHER_BSS | FIF_PROBE_REQ)) ? 0 : 1;
|
wvif->filter_bssid = (*total_flags &
|
||||||
|
(FIF_OTHER_BSS | FIF_PROBE_REQ)) ? 0 : 1;
|
||||||
wvif->disable_beacon_filter = !(*total_flags & FIF_PROBE_REQ);
|
wvif->disable_beacon_filter = !(*total_flags & FIF_PROBE_REQ);
|
||||||
wfx_fwd_probe_req(wvif, true);
|
wfx_fwd_probe_req(wvif, true);
|
||||||
wfx_update_filtering(wvif);
|
wfx_update_filtering(wvif);
|
||||||
|
@ -381,8 +392,10 @@ int wfx_set_pm(struct wfx_vif *wvif, const struct hif_req_set_pm_mode *arg)
|
||||||
pm.pm_mode.fast_psm = 0;
|
pm.pm_mode.fast_psm = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!wait_for_completion_timeout(&wvif->set_pm_mode_complete, msecs_to_jiffies(300)))
|
if (!wait_for_completion_timeout(&wvif->set_pm_mode_complete,
|
||||||
dev_warn(wvif->wdev->dev, "timeout while waiting of set_pm_mode_complete\n");
|
msecs_to_jiffies(300)))
|
||||||
|
dev_warn(wvif->wdev->dev,
|
||||||
|
"timeout while waiting of set_pm_mode_complete\n");
|
||||||
ret = hif_set_pm(wvif, &pm);
|
ret = hif_set_pm(wvif, &pm);
|
||||||
// FIXME: why ?
|
// FIXME: why ?
|
||||||
if (-ETIMEDOUT == wvif->scan.status)
|
if (-ETIMEDOUT == wvif->scan.status)
|
||||||
|
@ -442,7 +455,8 @@ void wfx_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
wvif = (struct wfx_vif *) vif->drv_priv;
|
wvif = (struct wfx_vif *) vif->drv_priv;
|
||||||
if (wvif->vif->type == NL80211_IFTYPE_MONITOR)
|
if (wvif->vif->type == NL80211_IFTYPE_MONITOR)
|
||||||
drop = true;
|
drop = true;
|
||||||
if (wvif->vif->type == NL80211_IFTYPE_AP && !wvif->enable_beacon)
|
if (wvif->vif->type == NL80211_IFTYPE_AP &&
|
||||||
|
!wvif->enable_beacon)
|
||||||
drop = true;
|
drop = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -494,7 +508,8 @@ static void wfx_event_handler_work(struct work_struct *work)
|
||||||
*/
|
*/
|
||||||
wvif->delayed_link_loss = 1;
|
wvif->delayed_link_loss = 1;
|
||||||
/* Also start a watchdog. */
|
/* Also start a watchdog. */
|
||||||
schedule_delayed_work(&wvif->bss_loss_work, 5 * HZ);
|
schedule_delayed_work(&wvif->bss_loss_work,
|
||||||
|
5 * HZ);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case HIF_EVENT_IND_BSSREGAINED:
|
case HIF_EVENT_IND_BSSREGAINED:
|
||||||
|
@ -502,13 +517,17 @@ static void wfx_event_handler_work(struct work_struct *work)
|
||||||
cancel_work_sync(&wvif->unjoin_work);
|
cancel_work_sync(&wvif->unjoin_work);
|
||||||
break;
|
break;
|
||||||
case HIF_EVENT_IND_RCPI_RSSI:
|
case HIF_EVENT_IND_RCPI_RSSI:
|
||||||
wfx_event_report_rssi(wvif, event->evt.event_data.rcpi_rssi);
|
wfx_event_report_rssi(wvif,
|
||||||
|
event->evt.event_data.rcpi_rssi);
|
||||||
break;
|
break;
|
||||||
case HIF_EVENT_IND_PS_MODE_ERROR:
|
case HIF_EVENT_IND_PS_MODE_ERROR:
|
||||||
dev_warn(wvif->wdev->dev, "error while processing power save request\n");
|
dev_warn(wvif->wdev->dev,
|
||||||
|
"error while processing power save request\n");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
dev_warn(wvif->wdev->dev, "unhandled event indication: %.2x\n", event->evt.event_id);
|
dev_warn(wvif->wdev->dev,
|
||||||
|
"unhandled event indication: %.2x\n",
|
||||||
|
event->evt.event_id);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -517,14 +536,16 @@ static void wfx_event_handler_work(struct work_struct *work)
|
||||||
|
|
||||||
static void wfx_bss_loss_work(struct work_struct *work)
|
static void wfx_bss_loss_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, bss_loss_work.work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
bss_loss_work.work);
|
||||||
|
|
||||||
ieee80211_connection_loss(wvif->vif);
|
ieee80211_connection_loss(wvif->vif);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wfx_bss_params_work(struct work_struct *work)
|
static void wfx_bss_params_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, bss_params_work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
bss_params_work);
|
||||||
|
|
||||||
mutex_lock(&wvif->wdev->conf_mutex);
|
mutex_lock(&wvif->wdev->conf_mutex);
|
||||||
wvif->bss_params.bss_flags.lost_count_only = 1;
|
wvif->bss_params.bss_flags.lost_count_only = 1;
|
||||||
|
@ -535,9 +556,11 @@ static void wfx_bss_params_work(struct work_struct *work)
|
||||||
|
|
||||||
static void wfx_set_beacon_wakeup_period_work(struct work_struct *work)
|
static void wfx_set_beacon_wakeup_period_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, set_beacon_wakeup_period_work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
set_beacon_wakeup_period_work);
|
||||||
|
|
||||||
hif_set_beacon_wakeup_period(wvif, wvif->dtim_period, wvif->dtim_period);
|
hif_set_beacon_wakeup_period(wvif, wvif->dtim_period,
|
||||||
|
wvif->dtim_period);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wfx_do_unjoin(struct wfx_vif *wvif)
|
static void wfx_do_unjoin(struct wfx_vif *wvif)
|
||||||
|
@ -546,7 +569,8 @@ static void wfx_do_unjoin(struct wfx_vif *wvif)
|
||||||
|
|
||||||
if (atomic_read(&wvif->scan.in_progress)) {
|
if (atomic_read(&wvif->scan.in_progress)) {
|
||||||
if (wvif->delayed_unjoin)
|
if (wvif->delayed_unjoin)
|
||||||
dev_dbg(wvif->wdev->dev, "delayed unjoin is already scheduled\n");
|
dev_dbg(wvif->wdev->dev,
|
||||||
|
"delayed unjoin is already scheduled\n");
|
||||||
else
|
else
|
||||||
wvif->delayed_unjoin = true;
|
wvif->delayed_unjoin = true;
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -588,7 +612,8 @@ done:
|
||||||
mutex_unlock(&wvif->wdev->conf_mutex);
|
mutex_unlock(&wvif->wdev->conf_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wfx_set_mfp(struct wfx_vif *wvif, struct cfg80211_bss *bss)
|
static void wfx_set_mfp(struct wfx_vif *wvif,
|
||||||
|
struct cfg80211_bss *bss)
|
||||||
{
|
{
|
||||||
const int pairwise_cipher_suite_count_offset = 8 / sizeof(u16);
|
const int pairwise_cipher_suite_count_offset = 8 / sizeof(u16);
|
||||||
const int pairwise_cipher_suite_size = 4 / sizeof(u16);
|
const int pairwise_cipher_suite_size = 4 / sizeof(u16);
|
||||||
|
@ -629,7 +654,8 @@ static void wfx_do_join(struct wfx_vif *wvif)
|
||||||
.preamble_type = conf->use_short_preamble ? HIF_PREAMBLE_SHORT : HIF_PREAMBLE_LONG,
|
.preamble_type = conf->use_short_preamble ? HIF_PREAMBLE_SHORT : HIF_PREAMBLE_LONG,
|
||||||
.probe_for_join = 1,
|
.probe_for_join = 1,
|
||||||
.atim_window = 0,
|
.atim_window = 0,
|
||||||
.basic_rate_set = wfx_rate_mask_to_hw(wvif->wdev, conf->basic_rates),
|
.basic_rate_set = wfx_rate_mask_to_hw(wvif->wdev,
|
||||||
|
conf->basic_rates),
|
||||||
};
|
};
|
||||||
|
|
||||||
if (wvif->channel->flags & IEEE80211_CHAN_NO_IR)
|
if (wvif->channel->flags & IEEE80211_CHAN_NO_IR)
|
||||||
|
@ -640,7 +666,8 @@ static void wfx_do_join(struct wfx_vif *wvif)
|
||||||
|
|
||||||
bssid = wvif->vif->bss_conf.bssid;
|
bssid = wvif->vif->bss_conf.bssid;
|
||||||
|
|
||||||
bss = cfg80211_get_bss(wvif->wdev->hw->wiphy, wvif->channel, bssid, NULL, 0,
|
bss = cfg80211_get_bss(wvif->wdev->hw->wiphy, wvif->channel,
|
||||||
|
bssid, NULL, 0,
|
||||||
IEEE80211_BSS_TYPE_ANY, IEEE80211_PRIVACY_ANY);
|
IEEE80211_BSS_TYPE_ANY, IEEE80211_PRIVACY_ANY);
|
||||||
|
|
||||||
if (!bss && !conf->ibss_joined) {
|
if (!bss && !conf->ibss_joined) {
|
||||||
|
@ -816,7 +843,8 @@ static int wfx_start_ap(struct wfx_vif *wvif)
|
||||||
.beacon_interval = conf->beacon_int,
|
.beacon_interval = conf->beacon_int,
|
||||||
.dtim_period = conf->dtim_period,
|
.dtim_period = conf->dtim_period,
|
||||||
.preamble_type = conf->use_short_preamble ? HIF_PREAMBLE_SHORT : HIF_PREAMBLE_LONG,
|
.preamble_type = conf->use_short_preamble ? HIF_PREAMBLE_SHORT : HIF_PREAMBLE_LONG,
|
||||||
.basic_rate_set = wfx_rate_mask_to_hw(wvif->wdev, conf->basic_rates),
|
.basic_rate_set = wfx_rate_mask_to_hw(wvif->wdev,
|
||||||
|
conf->basic_rates),
|
||||||
};
|
};
|
||||||
|
|
||||||
memset(start.ssid, 0, sizeof(start.ssid));
|
memset(start.ssid, 0, sizeof(start.ssid));
|
||||||
|
@ -928,7 +956,8 @@ static int wfx_ht_ampdu_density(const struct wfx_ht_info *ht_info)
|
||||||
return ht_info->ht_cap.ampdu_density;
|
return ht_info->ht_cap.ampdu_density;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wfx_join_finalize(struct wfx_vif *wvif, struct ieee80211_bss_conf *info)
|
static void wfx_join_finalize(struct wfx_vif *wvif,
|
||||||
|
struct ieee80211_bss_conf *info)
|
||||||
{
|
{
|
||||||
struct ieee80211_sta *sta = NULL;
|
struct ieee80211_sta *sta = NULL;
|
||||||
struct hif_mib_set_association_mode association_mode = { };
|
struct hif_mib_set_association_mode association_mode = { };
|
||||||
|
@ -952,7 +981,8 @@ static void wfx_join_finalize(struct wfx_vif *wvif, struct ieee80211_bss_conf *i
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
||||||
/* Non Greenfield stations present */
|
/* Non Greenfield stations present */
|
||||||
if (wvif->ht_info.operation_mode & IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT)
|
if (wvif->ht_info.operation_mode &
|
||||||
|
IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT)
|
||||||
hif_dual_cts_protection(wvif, true);
|
hif_dual_cts_protection(wvif, true);
|
||||||
else
|
else
|
||||||
hif_dual_cts_protection(wvif, false);
|
hif_dual_cts_protection(wvif, false);
|
||||||
|
@ -1011,7 +1041,9 @@ void wfx_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
filter.condition_idx = i;
|
filter.condition_idx = i;
|
||||||
if (i < nb_arp_addr) {
|
if (i < nb_arp_addr) {
|
||||||
// Caution: type of arp_addr_list[i] is __be32
|
// Caution: type of arp_addr_list[i] is __be32
|
||||||
memcpy(filter.ipv4_address, &info->arp_addr_list[i], sizeof(filter.ipv4_address));
|
memcpy(filter.ipv4_address,
|
||||||
|
&info->arp_addr_list[i],
|
||||||
|
sizeof(filter.ipv4_address));
|
||||||
filter.arp_enable = HIF_ARP_NS_FILTERING_ENABLE;
|
filter.arp_enable = HIF_ARP_NS_FILTERING_ENABLE;
|
||||||
} else {
|
} else {
|
||||||
filter.arp_enable = HIF_ARP_NS_FILTERING_DISABLE;
|
filter.arp_enable = HIF_ARP_NS_FILTERING_DISABLE;
|
||||||
|
@ -1028,7 +1060,8 @@ void wfx_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
wfx_upload_beacon(wvif);
|
wfx_upload_beacon(wvif);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (changed & BSS_CHANGED_BEACON_ENABLED && wvif->state != WFX_STATE_IBSS) {
|
if (changed & BSS_CHANGED_BEACON_ENABLED &&
|
||||||
|
wvif->state != WFX_STATE_IBSS) {
|
||||||
if (wvif->enable_beacon != info->enable_beacon) {
|
if (wvif->enable_beacon != info->enable_beacon) {
|
||||||
hif_beacon_transmit(wvif, info->enable_beacon);
|
hif_beacon_transmit(wvif, info->enable_beacon);
|
||||||
wvif->enable_beacon = info->enable_beacon;
|
wvif->enable_beacon = info->enable_beacon;
|
||||||
|
@ -1061,7 +1094,8 @@ void wfx_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
|
|
||||||
if (changed &
|
if (changed &
|
||||||
(BSS_CHANGED_ASSOC | BSS_CHANGED_BSSID |
|
(BSS_CHANGED_ASSOC | BSS_CHANGED_BSSID |
|
||||||
BSS_CHANGED_IBSS | BSS_CHANGED_BASIC_RATES | BSS_CHANGED_HT)) {
|
BSS_CHANGED_IBSS | BSS_CHANGED_BASIC_RATES |
|
||||||
|
BSS_CHANGED_HT)) {
|
||||||
if (info->assoc) {
|
if (info->assoc) {
|
||||||
if (wvif->state < WFX_STATE_PRE_STA) {
|
if (wvif->state < WFX_STATE_PRE_STA) {
|
||||||
ieee80211_connection_loss(vif);
|
ieee80211_connection_loss(vif);
|
||||||
|
@ -1077,7 +1111,8 @@ void wfx_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
if (info->assoc || info->ibss_joined)
|
if (info->assoc || info->ibss_joined)
|
||||||
wfx_join_finalize(wvif, info);
|
wfx_join_finalize(wvif, info);
|
||||||
else
|
else
|
||||||
memset(&wvif->bss_params, 0, sizeof(wvif->bss_params));
|
memset(&wvif->bss_params, 0,
|
||||||
|
sizeof(wvif->bss_params));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1132,7 +1167,8 @@ void wfx_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
hif_set_rcpi_rssi_threshold(wvif, &th);
|
hif_set_rcpi_rssi_threshold(wvif, &th);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (changed & BSS_CHANGED_TXPOWER && info->txpower != wdev->output_power) {
|
if (changed & BSS_CHANGED_TXPOWER &&
|
||||||
|
info->txpower != wdev->output_power) {
|
||||||
wdev->output_power = info->txpower;
|
wdev->output_power = info->txpower;
|
||||||
hif_set_output_power(wvif, wdev->output_power * 10);
|
hif_set_output_power(wvif, wdev->output_power * 10);
|
||||||
}
|
}
|
||||||
|
@ -1247,7 +1283,8 @@ int wfx_set_tim(struct ieee80211_hw *hw, struct ieee80211_sta *sta, bool set)
|
||||||
|
|
||||||
static void wfx_mcast_start_work(struct work_struct *work)
|
static void wfx_mcast_start_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, mcast_start_work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
mcast_start_work);
|
||||||
long tmo = wvif->dtim_period * TU_TO_JIFFIES(wvif->beacon_int + 20);
|
long tmo = wvif->dtim_period * TU_TO_JIFFIES(wvif->beacon_int + 20);
|
||||||
|
|
||||||
cancel_work_sync(&wvif->mcast_stop_work);
|
cancel_work_sync(&wvif->mcast_stop_work);
|
||||||
|
@ -1262,7 +1299,8 @@ static void wfx_mcast_start_work(struct work_struct *work)
|
||||||
|
|
||||||
static void wfx_mcast_stop_work(struct work_struct *work)
|
static void wfx_mcast_stop_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = container_of(work, struct wfx_vif, mcast_stop_work);
|
struct wfx_vif *wvif = container_of(work, struct wfx_vif,
|
||||||
|
mcast_stop_work);
|
||||||
|
|
||||||
if (wvif->aid0_bit_set) {
|
if (wvif->aid0_bit_set) {
|
||||||
del_timer_sync(&wvif->mcast_timeout);
|
del_timer_sync(&wvif->mcast_timeout);
|
||||||
|
@ -1310,7 +1348,8 @@ void wfx_suspend_resume(struct wfx_vif *wvif,
|
||||||
if (!arg->suspend_resume_flags.resume)
|
if (!arg->suspend_resume_flags.resume)
|
||||||
wvif->mcast_tx = false;
|
wvif->mcast_tx = false;
|
||||||
else
|
else
|
||||||
wvif->mcast_tx = wvif->aid0_bit_set && wvif->mcast_buffered;
|
wvif->mcast_tx = wvif->aid0_bit_set &&
|
||||||
|
wvif->mcast_buffered;
|
||||||
if (wvif->mcast_tx) {
|
if (wvif->mcast_tx) {
|
||||||
cancel_tmo = true;
|
cancel_tmo = true;
|
||||||
wfx_bh_request_tx(wvif->wdev);
|
wfx_bh_request_tx(wvif->wdev);
|
||||||
|
@ -1358,7 +1397,8 @@ int wfx_assign_vif_chanctx(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wfx_unassign_vif_chanctx(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
void wfx_unassign_vif_chanctx(struct ieee80211_hw *hw,
|
||||||
|
struct ieee80211_vif *vif,
|
||||||
struct ieee80211_chanctx_conf *conf)
|
struct ieee80211_chanctx_conf *conf)
|
||||||
{
|
{
|
||||||
struct wfx_vif *wvif = (struct wfx_vif *) vif->drv_priv;
|
struct wfx_vif *wvif = (struct wfx_vif *) vif->drv_priv;
|
||||||
|
@ -1392,14 +1432,19 @@ int wfx_config(struct ieee80211_hw *hw, u32 changed)
|
||||||
if (changed & IEEE80211_CONF_CHANGE_PS) {
|
if (changed & IEEE80211_CONF_CHANGE_PS) {
|
||||||
wvif = NULL;
|
wvif = NULL;
|
||||||
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
while ((wvif = wvif_iterate(wdev, wvif)) != NULL) {
|
||||||
memset(&wvif->powersave_mode, 0, sizeof(wvif->powersave_mode));
|
memset(&wvif->powersave_mode, 0,
|
||||||
|
sizeof(wvif->powersave_mode));
|
||||||
if (conf->flags & IEEE80211_CONF_PS) {
|
if (conf->flags & IEEE80211_CONF_PS) {
|
||||||
wvif->powersave_mode.pm_mode.enter_psm = 1;
|
wvif->powersave_mode.pm_mode.enter_psm = 1;
|
||||||
if (conf->dynamic_ps_timeout > 0) {
|
if (conf->dynamic_ps_timeout > 0) {
|
||||||
wvif->powersave_mode.pm_mode.fast_psm = 1;
|
wvif->powersave_mode.pm_mode.fast_psm = 1;
|
||||||
// Firmware does not support more than 128ms
|
/*
|
||||||
|
* Firmware does not support more than
|
||||||
|
* 128ms
|
||||||
|
*/
|
||||||
wvif->powersave_mode.fast_psm_idle_period =
|
wvif->powersave_mode.fast_psm_idle_period =
|
||||||
min(conf->dynamic_ps_timeout * 2, 255);
|
min(conf->dynamic_ps_timeout *
|
||||||
|
2, 255);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (wvif->state == WFX_STATE_STA && wvif->bss_params.aid)
|
if (wvif->state == WFX_STATE_STA && wvif->bss_params.aid)
|
||||||
|
@ -1515,7 +1560,8 @@ int wfx_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
|
||||||
|
|
||||||
init_completion(&wvif->set_pm_mode_complete);
|
init_completion(&wvif->set_pm_mode_complete);
|
||||||
complete(&wvif->set_pm_mode_complete);
|
complete(&wvif->set_pm_mode_complete);
|
||||||
INIT_WORK(&wvif->set_beacon_wakeup_period_work, wfx_set_beacon_wakeup_period_work);
|
INIT_WORK(&wvif->set_beacon_wakeup_period_work,
|
||||||
|
wfx_set_beacon_wakeup_period_work);
|
||||||
INIT_WORK(&wvif->update_filtering_work, wfx_update_filtering_work);
|
INIT_WORK(&wvif->update_filtering_work, wfx_update_filtering_work);
|
||||||
INIT_WORK(&wvif->bss_params_work, wfx_bss_params_work);
|
INIT_WORK(&wvif->bss_params_work, wfx_bss_params_work);
|
||||||
INIT_WORK(&wvif->set_cts_work, wfx_set_cts_work);
|
INIT_WORK(&wvif->set_cts_work, wfx_set_cts_work);
|
||||||
|
@ -1525,7 +1571,8 @@ int wfx_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
|
||||||
|
|
||||||
hif_set_macaddr(wvif, vif->addr);
|
hif_set_macaddr(wvif, vif->addr);
|
||||||
for (i = 0; i < IEEE80211_NUM_ACS; i++) {
|
for (i = 0; i < IEEE80211_NUM_ACS; i++) {
|
||||||
memcpy(&wvif->edca.params[i], &default_edca_params[i], sizeof(default_edca_params[i]));
|
memcpy(&wvif->edca.params[i], &default_edca_params[i],
|
||||||
|
sizeof(default_edca_params[i]));
|
||||||
wvif->edca.uapsd_enable[i] = false;
|
wvif->edca.uapsd_enable[i] = false;
|
||||||
hif_set_edca_queue_params(wvif, &wvif->edca.params[i]);
|
hif_set_edca_queue_params(wvif, &wvif->edca.params[i]);
|
||||||
}
|
}
|
||||||
|
|
|
@ -86,11 +86,13 @@ void wfx_change_chanctx(struct ieee80211_hw *hw,
|
||||||
struct ieee80211_chanctx_conf *conf, u32 changed);
|
struct ieee80211_chanctx_conf *conf, u32 changed);
|
||||||
int wfx_assign_vif_chanctx(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
int wfx_assign_vif_chanctx(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
struct ieee80211_chanctx_conf *conf);
|
struct ieee80211_chanctx_conf *conf);
|
||||||
void wfx_unassign_vif_chanctx(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
void wfx_unassign_vif_chanctx(struct ieee80211_hw *hw,
|
||||||
|
struct ieee80211_vif *vif,
|
||||||
struct ieee80211_chanctx_conf *conf);
|
struct ieee80211_chanctx_conf *conf);
|
||||||
|
|
||||||
// WSM Callbacks
|
// WSM Callbacks
|
||||||
void wfx_suspend_resume(struct wfx_vif *wvif, struct hif_ind_suspend_resume_tx *arg);
|
void wfx_suspend_resume(struct wfx_vif *wvif,
|
||||||
|
struct hif_ind_suspend_resume_tx *arg);
|
||||||
|
|
||||||
// Other Helpers
|
// Other Helpers
|
||||||
void wfx_cqm_bssloss_sm(struct wfx_vif *wvif, int init, int good, int bad);
|
void wfx_cqm_bssloss_sm(struct wfx_vif *wvif, int init, int good, int bad);
|
||||||
|
|
|
@ -177,14 +177,16 @@ DECLARE_EVENT_CLASS(hif_data,
|
||||||
else
|
else
|
||||||
__entry->msg_type = "REQ";
|
__entry->msg_type = "REQ";
|
||||||
if (!is_recv &&
|
if (!is_recv &&
|
||||||
(__entry->msg_id == HIF_REQ_ID_READ_MIB || __entry->msg_id == HIF_REQ_ID_WRITE_MIB)) {
|
(__entry->msg_id == HIF_REQ_ID_READ_MIB ||
|
||||||
|
__entry->msg_id == HIF_REQ_ID_WRITE_MIB)) {
|
||||||
__entry->mib = le16_to_cpup((u16 *) hif->body);
|
__entry->mib = le16_to_cpup((u16 *) hif->body);
|
||||||
header_len = 4;
|
header_len = 4;
|
||||||
} else {
|
} else {
|
||||||
__entry->mib = -1;
|
__entry->mib = -1;
|
||||||
header_len = 0;
|
header_len = 0;
|
||||||
}
|
}
|
||||||
__entry->buf_len = min_t(int, __entry->msg_len, sizeof(__entry->buf))
|
__entry->buf_len = min_t(int, __entry->msg_len,
|
||||||
|
sizeof(__entry->buf))
|
||||||
- sizeof(struct hif_msg) - header_len;
|
- sizeof(struct hif_msg) - header_len;
|
||||||
memcpy(__entry->buf, hif->body + header_len, __entry->buf_len);
|
memcpy(__entry->buf, hif->body + header_len, __entry->buf_len);
|
||||||
),
|
),
|
||||||
|
@ -203,11 +205,13 @@ DECLARE_EVENT_CLASS(hif_data,
|
||||||
DEFINE_EVENT(hif_data, hif_send,
|
DEFINE_EVENT(hif_data, hif_send,
|
||||||
TP_PROTO(struct hif_msg *hif, int tx_fill_level, bool is_recv),
|
TP_PROTO(struct hif_msg *hif, int tx_fill_level, bool is_recv),
|
||||||
TP_ARGS(hif, tx_fill_level, is_recv));
|
TP_ARGS(hif, tx_fill_level, is_recv));
|
||||||
#define _trace_hif_send(hif, tx_fill_level) trace_hif_send(hif, tx_fill_level, false)
|
#define _trace_hif_send(hif, tx_fill_level)\
|
||||||
|
trace_hif_send(hif, tx_fill_level, false)
|
||||||
DEFINE_EVENT(hif_data, hif_recv,
|
DEFINE_EVENT(hif_data, hif_recv,
|
||||||
TP_PROTO(struct hif_msg *hif, int tx_fill_level, bool is_recv),
|
TP_PROTO(struct hif_msg *hif, int tx_fill_level, bool is_recv),
|
||||||
TP_ARGS(hif, tx_fill_level, is_recv));
|
TP_ARGS(hif, tx_fill_level, is_recv));
|
||||||
#define _trace_hif_recv(hif, tx_fill_level) trace_hif_recv(hif, tx_fill_level, true)
|
#define _trace_hif_recv(hif, tx_fill_level)\
|
||||||
|
trace_hif_recv(hif, tx_fill_level, true)
|
||||||
|
|
||||||
#define wfx_reg_list_enum \
|
#define wfx_reg_list_enum \
|
||||||
wfx_reg_name(WFX_REG_CONFIG, "CONFIG") \
|
wfx_reg_name(WFX_REG_CONFIG, "CONFIG") \
|
||||||
|
@ -241,7 +245,8 @@ DECLARE_EVENT_CLASS(io_data,
|
||||||
__entry->reg = reg;
|
__entry->reg = reg;
|
||||||
__entry->addr = addr;
|
__entry->addr = addr;
|
||||||
__entry->msg_len = len;
|
__entry->msg_len = len;
|
||||||
__entry->buf_len = min_t(int, sizeof(__entry->buf), __entry->msg_len);
|
__entry->buf_len = min_t(int, sizeof(__entry->buf),
|
||||||
|
__entry->msg_len);
|
||||||
memcpy(__entry->buf, io_buf, __entry->buf_len);
|
memcpy(__entry->buf, io_buf, __entry->buf_len);
|
||||||
if (addr >= 0)
|
if (addr >= 0)
|
||||||
snprintf(__entry->addr_str, 10, "/%08x", addr);
|
snprintf(__entry->addr_str, 10, "/%08x", addr);
|
||||||
|
@ -259,12 +264,14 @@ DECLARE_EVENT_CLASS(io_data,
|
||||||
DEFINE_EVENT(io_data, io_write,
|
DEFINE_EVENT(io_data, io_write,
|
||||||
TP_PROTO(int reg, int addr, const void *io_buf, size_t len),
|
TP_PROTO(int reg, int addr, const void *io_buf, size_t len),
|
||||||
TP_ARGS(reg, addr, io_buf, len));
|
TP_ARGS(reg, addr, io_buf, len));
|
||||||
#define _trace_io_ind_write(reg, addr, io_buf, len) trace_io_write(reg, addr, io_buf, len)
|
#define _trace_io_ind_write(reg, addr, io_buf, len)\
|
||||||
|
trace_io_write(reg, addr, io_buf, len)
|
||||||
#define _trace_io_write(reg, io_buf, len) trace_io_write(reg, -1, io_buf, len)
|
#define _trace_io_write(reg, io_buf, len) trace_io_write(reg, -1, io_buf, len)
|
||||||
DEFINE_EVENT(io_data, io_read,
|
DEFINE_EVENT(io_data, io_read,
|
||||||
TP_PROTO(int reg, int addr, const void *io_buf, size_t len),
|
TP_PROTO(int reg, int addr, const void *io_buf, size_t len),
|
||||||
TP_ARGS(reg, addr, io_buf, len));
|
TP_ARGS(reg, addr, io_buf, len));
|
||||||
#define _trace_io_ind_read(reg, addr, io_buf, len) trace_io_read(reg, addr, io_buf, len)
|
#define _trace_io_ind_read(reg, addr, io_buf, len)\
|
||||||
|
trace_io_read(reg, addr, io_buf, len)
|
||||||
#define _trace_io_read(reg, io_buf, len) trace_io_read(reg, -1, io_buf, len)
|
#define _trace_io_read(reg, io_buf, len) trace_io_read(reg, -1, io_buf, len)
|
||||||
|
|
||||||
DECLARE_EVENT_CLASS(io_data32,
|
DECLARE_EVENT_CLASS(io_data32,
|
||||||
|
@ -348,7 +355,8 @@ TRACE_EVENT(bh_stats,
|
||||||
__entry->release ? "release" : "keep"
|
__entry->release ? "release" : "keep"
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
#define _trace_bh_stats(ind, req, cnf, busy, release) trace_bh_stats(ind, req, cnf, busy, release)
|
#define _trace_bh_stats(ind, req, cnf, busy, release)\
|
||||||
|
trace_bh_stats(ind, req, cnf, busy, release)
|
||||||
|
|
||||||
TRACE_EVENT(tx_stats,
|
TRACE_EVENT(tx_stats,
|
||||||
TP_PROTO(struct hif_cnf_tx *tx_cnf, struct sk_buff *skb, int delay),
|
TP_PROTO(struct hif_cnf_tx *tx_cnf, struct sk_buff *skb, int delay),
|
||||||
|
@ -365,7 +373,8 @@ TRACE_EVENT(tx_stats,
|
||||||
),
|
),
|
||||||
TP_fast_assign(
|
TP_fast_assign(
|
||||||
// Keep sync with wfx_rates definition in main.c
|
// Keep sync with wfx_rates definition in main.c
|
||||||
static const int hw_rate[] = { 0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13 };
|
static const int hw_rate[] = { 0, 1, 2, 3, 6, 7, 8, 9,
|
||||||
|
10, 11, 12, 13 };
|
||||||
struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
|
struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
|
||||||
struct ieee80211_tx_rate *rates = tx_info->driver_rates;
|
struct ieee80211_tx_rate *rates = tx_info->driver_rates;
|
||||||
int i;
|
int i;
|
||||||
|
|
|
@ -141,13 +141,15 @@ static inline struct wfx_vif *wdev_to_wvif(struct wfx_dev *wdev, int vif_id)
|
||||||
}
|
}
|
||||||
vif_id = array_index_nospec(vif_id, ARRAY_SIZE(wdev->vif));
|
vif_id = array_index_nospec(vif_id, ARRAY_SIZE(wdev->vif));
|
||||||
if (!wdev->vif[vif_id]) {
|
if (!wdev->vif[vif_id]) {
|
||||||
dev_dbg(wdev->dev, "requesting non-allocated vif: %d\n", vif_id);
|
dev_dbg(wdev->dev, "requesting non-allocated vif: %d\n",
|
||||||
|
vif_id);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
return (struct wfx_vif *) wdev->vif[vif_id]->drv_priv;
|
return (struct wfx_vif *) wdev->vif[vif_id]->drv_priv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline struct wfx_vif *wvif_iterate(struct wfx_dev *wdev, struct wfx_vif *cur)
|
static inline struct wfx_vif *wvif_iterate(struct wfx_dev *wdev,
|
||||||
|
struct wfx_vif *cur)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int mark = 0;
|
int mark = 0;
|
||||||
|
|
Loading…
Reference in New Issue