diff options
author | Wey-Yi Guy <wey-yi.w.guy@intel.com> | 2010-08-23 10:57:10 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-08-25 14:34:52 -0400 |
commit | fbba94104fb44d2f984e767cd8ac1edd80cb03d5 (patch) | |
tree | 6bb65b7ffb3ae8c8165efc11c593e094cb23a8c6 /drivers/net/wireless | |
parent | 5d297d50653ba0c498e0b1e7b72b6611651357aa (diff) |
iwlagn: parsing uart message and take actions
1. Based on uart message from uCode, re-configure BT kill ack mask
messages from uCode
2. send REPLY_BT_COEX_SCO command to uCode based on the uart frame
received from uCode
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-6000.c | 116 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn-ucode.c | 5 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn.c | 16 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-commands.h | 110 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-dev.h | 4 |
5 files changed, 235 insertions, 16 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-6000.c b/drivers/net/wireless/iwlwifi/iwl-6000.c index 54b59dadf2a8..e4873cc2a57a 100644 --- a/drivers/net/wireless/iwlwifi/iwl-6000.c +++ b/drivers/net/wireless/iwlwifi/iwl-6000.c | |||
@@ -221,17 +221,17 @@ static void iwl6000g2b_send_bt_config(struct iwl_priv *priv) | |||
221 | struct iwl6000g2b_bt_cmd bt_cmd = { | 221 | struct iwl6000g2b_bt_cmd bt_cmd = { |
222 | .max_kill = IWL6000G2B_BT_MAX_KILL_DEFAULT, | 222 | .max_kill = IWL6000G2B_BT_MAX_KILL_DEFAULT, |
223 | .bt3_timer_t7_value = IWL6000G2B_BT3_T7_DEFAULT, | 223 | .bt3_timer_t7_value = IWL6000G2B_BT3_T7_DEFAULT, |
224 | .kill_ack_mask = IWL6000G2B_BT_KILL_ACK_MASK_DEFAULT, | ||
225 | .kill_cts_mask = IWL6000G2B_BT_KILL_CTS_MASK_DEFAULT, | ||
226 | .bt3_prio_sample_time = IWL6000G2B_BT3_PRIO_SAMPLE_DEFAULT, | 224 | .bt3_prio_sample_time = IWL6000G2B_BT3_PRIO_SAMPLE_DEFAULT, |
227 | .bt3_timer_t2_value = IWL6000G2B_BT3_T2_DEFAULT, | 225 | .bt3_timer_t2_value = IWL6000G2B_BT3_T2_DEFAULT, |
228 | .valid = IWL6000G2B_BT_VALID_ENABLE_FLAGS, | ||
229 | }; | 226 | }; |
230 | 227 | ||
231 | BUILD_BUG_ON(sizeof(iwl6000g2b_def_3w_lookup) != | 228 | BUILD_BUG_ON(sizeof(iwl6000g2b_def_3w_lookup) != |
232 | sizeof(bt_cmd.bt3_lookup_table)); | 229 | sizeof(bt_cmd.bt3_lookup_table)); |
233 | 230 | ||
234 | bt_cmd.prio_boost = priv->cfg->bt_prio_boost; | 231 | bt_cmd.prio_boost = priv->cfg->bt_prio_boost; |
232 | bt_cmd.kill_ack_mask = priv->kill_ack_mask; | ||
233 | bt_cmd.kill_cts_mask = priv->kill_cts_mask; | ||
234 | bt_cmd.valid = priv->bt_valid; | ||
235 | 235 | ||
236 | /* | 236 | /* |
237 | * Configure BT coex mode to "no coexistence" when the | 237 | * Configure BT coex mode to "no coexistence" when the |
@@ -245,7 +245,6 @@ static void iwl6000g2b_send_bt_config(struct iwl_priv *priv) | |||
245 | bt_cmd.flags = IWL6000G2B_BT_FLAG_CHANNEL_INHIBITION | | 245 | bt_cmd.flags = IWL6000G2B_BT_FLAG_CHANNEL_INHIBITION | |
246 | IWL6000G2B_BT_FLAG_COEX_MODE_3W << | 246 | IWL6000G2B_BT_FLAG_COEX_MODE_3W << |
247 | IWL6000G2B_BT_FLAG_COEX_MODE_SHIFT; | 247 | IWL6000G2B_BT_FLAG_COEX_MODE_SHIFT; |
248 | bt_cmd.valid |= IWL6000G2B_BT_ALL_VALID_MSK; | ||
249 | } | 248 | } |
250 | 249 | ||
251 | if (priv->bt_full_concurrent) | 250 | if (priv->bt_full_concurrent) |
@@ -453,6 +452,93 @@ static void iwl6000g2b_bt_traffic_change_work(struct work_struct *work) | |||
453 | mutex_unlock(&priv->mutex); | 452 | mutex_unlock(&priv->mutex); |
454 | } | 453 | } |
455 | 454 | ||
455 | static void iwlagn_print_uartmsg(struct iwl_priv *priv, | ||
456 | struct iwl_bt_uart_msg *uart_msg) | ||
457 | { | ||
458 | IWL_DEBUG_NOTIF(priv, "Message Type = 0x%X, SSN = 0x%X, " | ||
459 | "Update Req = 0x%X", | ||
460 | (BT_UART_MSG_FRAME1MSGTYPE_MSK & uart_msg->frame1) >> | ||
461 | BT_UART_MSG_FRAME1MSGTYPE_POS, | ||
462 | (BT_UART_MSG_FRAME1SSN_MSK & uart_msg->frame1) >> | ||
463 | BT_UART_MSG_FRAME1SSN_POS, | ||
464 | (BT_UART_MSG_FRAME1UPDATEREQ_MSK & uart_msg->frame1) >> | ||
465 | BT_UART_MSG_FRAME1UPDATEREQ_POS); | ||
466 | |||
467 | IWL_DEBUG_NOTIF(priv, "Open connections = 0x%X, Traffic load = 0x%X, " | ||
468 | "Chl_SeqN = 0x%X, In band = 0x%X", | ||
469 | (BT_UART_MSG_FRAME2OPENCONNECTIONS_MSK & uart_msg->frame2) >> | ||
470 | BT_UART_MSG_FRAME2OPENCONNECTIONS_POS, | ||
471 | (BT_UART_MSG_FRAME2TRAFFICLOAD_MSK & uart_msg->frame2) >> | ||
472 | BT_UART_MSG_FRAME2TRAFFICLOAD_POS, | ||
473 | (BT_UART_MSG_FRAME2CHLSEQN_MSK & uart_msg->frame2) >> | ||
474 | BT_UART_MSG_FRAME2CHLSEQN_POS, | ||
475 | (BT_UART_MSG_FRAME2INBAND_MSK & uart_msg->frame2) >> | ||
476 | BT_UART_MSG_FRAME2INBAND_POS); | ||
477 | |||
478 | IWL_DEBUG_NOTIF(priv, "SCO/eSCO = 0x%X, Sniff = 0x%X, A2DP = 0x%X, " | ||
479 | "ACL = 0x%X, Master = 0x%X, OBEX = 0x%X", | ||
480 | (BT_UART_MSG_FRAME3SCOESCO_MSK & uart_msg->frame3) >> | ||
481 | BT_UART_MSG_FRAME3SCOESCO_POS, | ||
482 | (BT_UART_MSG_FRAME3SNIFF_MSK & uart_msg->frame3) >> | ||
483 | BT_UART_MSG_FRAME3SNIFF_POS, | ||
484 | (BT_UART_MSG_FRAME3A2DP_MSK & uart_msg->frame3) >> | ||
485 | BT_UART_MSG_FRAME3A2DP_POS, | ||
486 | (BT_UART_MSG_FRAME3ACL_MSK & uart_msg->frame3) >> | ||
487 | BT_UART_MSG_FRAME3ACL_POS, | ||
488 | (BT_UART_MSG_FRAME3MASTER_MSK & uart_msg->frame3) >> | ||
489 | BT_UART_MSG_FRAME3MASTER_POS, | ||
490 | (BT_UART_MSG_FRAME3OBEX_MSK & uart_msg->frame3) >> | ||
491 | BT_UART_MSG_FRAME3OBEX_POS); | ||
492 | |||
493 | IWL_DEBUG_NOTIF(priv, "Idle duration = 0x%X", | ||
494 | (BT_UART_MSG_FRAME4IDLEDURATION_MSK & uart_msg->frame4) >> | ||
495 | BT_UART_MSG_FRAME4IDLEDURATION_POS); | ||
496 | |||
497 | IWL_DEBUG_NOTIF(priv, "Tx Activity = 0x%X, Rx Activity = 0x%X, " | ||
498 | "eSCO Retransmissions = 0x%X", | ||
499 | (BT_UART_MSG_FRAME5TXACTIVITY_MSK & uart_msg->frame5) >> | ||
500 | BT_UART_MSG_FRAME5TXACTIVITY_POS, | ||
501 | (BT_UART_MSG_FRAME5RXACTIVITY_MSK & uart_msg->frame5) >> | ||
502 | BT_UART_MSG_FRAME5RXACTIVITY_POS, | ||
503 | (BT_UART_MSG_FRAME5ESCORETRANSMIT_MSK & uart_msg->frame5) >> | ||
504 | BT_UART_MSG_FRAME5ESCORETRANSMIT_POS); | ||
505 | |||
506 | IWL_DEBUG_NOTIF(priv, "Sniff Interval = 0x%X, Discoverable = 0x%X", | ||
507 | (BT_UART_MSG_FRAME6SNIFFINTERVAL_MSK & uart_msg->frame6) >> | ||
508 | BT_UART_MSG_FRAME6SNIFFINTERVAL_POS, | ||
509 | (BT_UART_MSG_FRAME6DISCOVERABLE_MSK & uart_msg->frame6) >> | ||
510 | BT_UART_MSG_FRAME6DISCOVERABLE_POS); | ||
511 | |||
512 | IWL_DEBUG_NOTIF(priv, "Sniff Activity = 0x%X, Inquiry/Page SR Mode = " | ||
513 | "0x%X, Connectable = 0x%X", | ||
514 | (BT_UART_MSG_FRAME7SNIFFACTIVITY_MSK & uart_msg->frame7) >> | ||
515 | BT_UART_MSG_FRAME7SNIFFACTIVITY_POS, | ||
516 | (BT_UART_MSG_FRAME7INQUIRYPAGESRMODE_MSK & uart_msg->frame7) >> | ||
517 | BT_UART_MSG_FRAME7INQUIRYPAGESRMODE_POS, | ||
518 | (BT_UART_MSG_FRAME7CONNECTABLE_MSK & uart_msg->frame7) >> | ||
519 | BT_UART_MSG_FRAME7CONNECTABLE_POS); | ||
520 | } | ||
521 | |||
522 | static void iwl6000g2b_set_kill_ack_msk(struct iwl_priv *priv, | ||
523 | struct iwl_bt_uart_msg *uart_msg) | ||
524 | { | ||
525 | u8 kill_ack_msk; | ||
526 | __le32 bt_kill_ack_msg[2] = { | ||
527 | cpu_to_le32(0xFFFFFFF), cpu_to_le32(0xFFFFFC00) }; | ||
528 | |||
529 | kill_ack_msk = (((BT_UART_MSG_FRAME3A2DP_MSK | | ||
530 | BT_UART_MSG_FRAME3SNIFF_MSK | | ||
531 | BT_UART_MSG_FRAME3SCOESCO_MSK) & | ||
532 | uart_msg->frame3) == 0) ? 1 : 0; | ||
533 | if (priv->kill_ack_mask != bt_kill_ack_msg[kill_ack_msk]) { | ||
534 | priv->bt_valid |= IWL6000G2B_BT_VALID_KILL_ACK_MASK; | ||
535 | priv->kill_ack_mask = bt_kill_ack_msg[kill_ack_msk]; | ||
536 | /* schedule to send runtime bt_config */ | ||
537 | queue_work(priv->workqueue, &priv->bt_runtime_config); | ||
538 | } | ||
539 | |||
540 | } | ||
541 | |||
456 | static void iwl6000g2b_bt_coex_profile_notif(struct iwl_priv *priv, | 542 | static void iwl6000g2b_bt_coex_profile_notif(struct iwl_priv *priv, |
457 | struct iwl_rx_mem_buffer *rxb) | 543 | struct iwl_rx_mem_buffer *rxb) |
458 | { | 544 | { |
@@ -460,16 +546,13 @@ static void iwl6000g2b_bt_coex_profile_notif(struct iwl_priv *priv, | |||
460 | struct iwl_rx_packet *pkt = rxb_addr(rxb); | 546 | struct iwl_rx_packet *pkt = rxb_addr(rxb); |
461 | struct iwl_bt_coex_profile_notif *coex = &pkt->u.bt_coex_profile_notif; | 547 | struct iwl_bt_coex_profile_notif *coex = &pkt->u.bt_coex_profile_notif; |
462 | struct iwl6000g2b_bt_sco_cmd sco_cmd = { .flags = 0 }; | 548 | struct iwl6000g2b_bt_sco_cmd sco_cmd = { .flags = 0 }; |
549 | struct iwl_bt_uart_msg *uart_msg = &coex->last_bt_uart_msg; | ||
463 | 550 | ||
464 | IWL_DEBUG_NOTIF(priv, "BT Coex notification:\n"); | 551 | IWL_DEBUG_NOTIF(priv, "BT Coex notification:\n"); |
465 | IWL_DEBUG_NOTIF(priv, " status: %d\n", coex->bt_status); | 552 | IWL_DEBUG_NOTIF(priv, " status: %d\n", coex->bt_status); |
466 | IWL_DEBUG_NOTIF(priv, " traffic load: %d\n", coex->bt_traffic_load); | 553 | IWL_DEBUG_NOTIF(priv, " traffic load: %d\n", coex->bt_traffic_load); |
467 | IWL_DEBUG_NOTIF(priv, " CI compliance: %d\n", coex->bt_ci_compliance); | 554 | IWL_DEBUG_NOTIF(priv, " CI compliance: %d\n", coex->bt_ci_compliance); |
468 | IWL_DEBUG_NOTIF(priv, " UART msg: %.2x:%.2x:%.2x:%.2x:%.2x:%.2x:" | 555 | iwlagn_print_uartmsg(priv, uart_msg); |
469 | "%.2x:%.2x\n", | ||
470 | coex->uart_msg[0], coex->uart_msg[1], coex->uart_msg[2], | ||
471 | coex->uart_msg[3], coex->uart_msg[4], coex->uart_msg[5], | ||
472 | coex->uart_msg[6], coex->uart_msg[7]); | ||
473 | 556 | ||
474 | priv->notif_bt_traffic_load = coex->bt_traffic_load; | 557 | priv->notif_bt_traffic_load = coex->bt_traffic_load; |
475 | 558 | ||
@@ -481,14 +564,19 @@ static void iwl6000g2b_bt_coex_profile_notif(struct iwl_priv *priv, | |||
481 | &priv->bt_traffic_change_work); | 564 | &priv->bt_traffic_change_work); |
482 | } | 565 | } |
483 | 566 | ||
484 | /* FIXME: add defines for this check */ | 567 | if (priv->bt_sco_active != |
485 | priv->bt_sco_active = coex->uart_msg[3] & 1; | 568 | (uart_msg->frame3 & BT_UART_MSG_FRAME3SCOESCO_MSK)) { |
486 | if (priv->bt_sco_active) | 569 | priv->bt_sco_active = uart_msg->frame3 & |
487 | sco_cmd.flags |= IWL6000G2B_BT_SCO_ACTIVE; | 570 | BT_UART_MSG_FRAME3SCOESCO_MSK; |
488 | iwl_send_cmd_pdu_async(priv, REPLY_BT_COEX_SCO, | 571 | if (priv->bt_sco_active) |
572 | sco_cmd.flags |= IWL6000G2B_BT_SCO_ACTIVE; | ||
573 | iwl_send_cmd_pdu_async(priv, REPLY_BT_COEX_SCO, | ||
489 | sizeof(sco_cmd), &sco_cmd, NULL); | 574 | sizeof(sco_cmd), &sco_cmd, NULL); |
575 | } | ||
490 | } | 576 | } |
491 | 577 | ||
578 | iwl6000g2b_set_kill_ack_msk(priv, uart_msg); | ||
579 | |||
492 | /* FIXME: based on notification, adjust the prio_boost */ | 580 | /* FIXME: based on notification, adjust the prio_boost */ |
493 | 581 | ||
494 | spin_lock_irqsave(&priv->lock, flags); | 582 | spin_lock_irqsave(&priv->lock, flags); |
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c b/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c index 2dc569bc7e8f..771ceffb8f8b 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn-ucode.c | |||
@@ -464,7 +464,12 @@ int iwlagn_alive_notify(struct iwl_priv *priv) | |||
464 | if (priv->cfg->advanced_bt_coexist) { | 464 | if (priv->cfg->advanced_bt_coexist) { |
465 | /* Configure Bluetooth device coexistence support */ | 465 | /* Configure Bluetooth device coexistence support */ |
466 | /* need to perform this before any calibration */ | 466 | /* need to perform this before any calibration */ |
467 | priv->bt_valid = IWL6000G2B_BT_ALL_VALID_MSK; | ||
468 | priv->kill_ack_mask = IWL6000G2B_BT_KILL_ACK_MASK_DEFAULT; | ||
469 | priv->kill_cts_mask = IWL6000G2B_BT_KILL_CTS_MASK_DEFAULT; | ||
467 | priv->cfg->ops->hcmd->send_bt_config(priv); | 470 | priv->cfg->ops->hcmd->send_bt_config(priv); |
471 | priv->bt_valid = IWL6000G2B_BT_VALID_ENABLE_FLAGS; | ||
472 | |||
468 | if (bt_coex_active && priv->iw_mode != NL80211_IFTYPE_ADHOC) { | 473 | if (bt_coex_active && priv->iw_mode != NL80211_IFTYPE_ADHOC) { |
469 | iwlagn_send_prio_tbl(priv); | 474 | iwlagn_send_prio_tbl(priv); |
470 | iwlagn_send_bt_env(priv, IWL_BT_COEX_ENV_OPEN, | 475 | iwlagn_send_bt_env(priv, IWL_BT_COEX_ENV_OPEN, |
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.c b/drivers/net/wireless/iwlwifi/iwl-agn.c index 06e89d474d04..0c457be7bc01 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn.c | |||
@@ -614,6 +614,20 @@ static void iwl_bg_beacon_update(struct work_struct *work) | |||
614 | iwl_send_beacon_cmd(priv); | 614 | iwl_send_beacon_cmd(priv); |
615 | } | 615 | } |
616 | 616 | ||
617 | static void iwl_bg_bt_runtime_config(struct work_struct *work) | ||
618 | { | ||
619 | struct iwl_priv *priv = | ||
620 | container_of(work, struct iwl_priv, bt_runtime_config); | ||
621 | |||
622 | if (test_bit(STATUS_EXIT_PENDING, &priv->status)) | ||
623 | return; | ||
624 | |||
625 | /* dont send host command if rf-kill is on */ | ||
626 | if (!iwl_is_ready_rf(priv)) | ||
627 | return; | ||
628 | priv->cfg->ops->hcmd->send_bt_config(priv); | ||
629 | } | ||
630 | |||
617 | static void iwl_bg_bt_full_concurrency(struct work_struct *work) | 631 | static void iwl_bg_bt_full_concurrency(struct work_struct *work) |
618 | { | 632 | { |
619 | struct iwl_priv *priv = | 633 | struct iwl_priv *priv = |
@@ -3895,6 +3909,7 @@ static void iwl_setup_deferred_work(struct iwl_priv *priv) | |||
3895 | INIT_WORK(&priv->run_time_calib_work, iwl_bg_run_time_calib_work); | 3909 | INIT_WORK(&priv->run_time_calib_work, iwl_bg_run_time_calib_work); |
3896 | INIT_WORK(&priv->tx_flush, iwl_bg_tx_flush); | 3910 | INIT_WORK(&priv->tx_flush, iwl_bg_tx_flush); |
3897 | INIT_WORK(&priv->bt_full_concurrency, iwl_bg_bt_full_concurrency); | 3911 | INIT_WORK(&priv->bt_full_concurrency, iwl_bg_bt_full_concurrency); |
3912 | INIT_WORK(&priv->bt_runtime_config, iwl_bg_bt_runtime_config); | ||
3898 | INIT_DELAYED_WORK(&priv->init_alive_start, iwl_bg_init_alive_start); | 3913 | INIT_DELAYED_WORK(&priv->init_alive_start, iwl_bg_init_alive_start); |
3899 | INIT_DELAYED_WORK(&priv->alive_start, iwl_bg_alive_start); | 3914 | INIT_DELAYED_WORK(&priv->alive_start, iwl_bg_alive_start); |
3900 | 3915 | ||
@@ -3938,6 +3953,7 @@ static void iwl_cancel_deferred_work(struct iwl_priv *priv) | |||
3938 | cancel_work_sync(&priv->run_time_calib_work); | 3953 | cancel_work_sync(&priv->run_time_calib_work); |
3939 | cancel_work_sync(&priv->beacon_update); | 3954 | cancel_work_sync(&priv->beacon_update); |
3940 | cancel_work_sync(&priv->bt_full_concurrency); | 3955 | cancel_work_sync(&priv->bt_full_concurrency); |
3956 | cancel_work_sync(&priv->bt_runtime_config); | ||
3941 | del_timer_sync(&priv->statistics_periodic); | 3957 | del_timer_sync(&priv->statistics_periodic); |
3942 | del_timer_sync(&priv->ucode_trace); | 3958 | del_timer_sync(&priv->ucode_trace); |
3943 | } | 3959 | } |
diff --git a/drivers/net/wireless/iwlwifi/iwl-commands.h b/drivers/net/wireless/iwlwifi/iwl-commands.h index e742f994ff82..7369c52d42dd 100644 --- a/drivers/net/wireless/iwlwifi/iwl-commands.h +++ b/drivers/net/wireless/iwlwifi/iwl-commands.h | |||
@@ -4057,7 +4057,7 @@ struct iwl_coex_event_resp { | |||
4057 | 4057 | ||
4058 | /* | 4058 | /* |
4059 | * BT Status notification | 4059 | * BT Status notification |
4060 | * REPLY_BT_COEX_PROFILE_NOTIF = 0xcb | 4060 | * REPLY_BT_COEX_PROFILE_NOTIF = 0xce |
4061 | */ | 4061 | */ |
4062 | enum iwl_bt_coex_profile_traffic_load { | 4062 | enum iwl_bt_coex_profile_traffic_load { |
4063 | IWL_BT_COEX_TRAFFIC_LOAD_NONE = 0, | 4063 | IWL_BT_COEX_TRAFFIC_LOAD_NONE = 0, |
@@ -4070,8 +4070,114 @@ enum iwl_bt_coex_profile_traffic_load { | |||
4070 | */ | 4070 | */ |
4071 | }; | 4071 | }; |
4072 | 4072 | ||
4073 | #define BT_UART_MSG_FRAME1MSGTYPE_POS (0) | ||
4074 | #define BT_UART_MSG_FRAME1MSGTYPE_MSK \ | ||
4075 | (0x7 << BT_UART_MSG_FRAME1MSGTYPE_POS) | ||
4076 | #define BT_UART_MSG_FRAME1SSN_POS (3) | ||
4077 | #define BT_UART_MSG_FRAME1SSN_MSK \ | ||
4078 | (0x3 << BT_UART_MSG_FRAME1SSN_POS) | ||
4079 | #define BT_UART_MSG_FRAME1UPDATEREQ_POS (5) | ||
4080 | #define BT_UART_MSG_FRAME1UPDATEREQ_MSK \ | ||
4081 | (0x1 << BT_UART_MSG_FRAME1UPDATEREQ_POS) | ||
4082 | #define BT_UART_MSG_FRAME1RESERVED_POS (6) | ||
4083 | #define BT_UART_MSG_FRAME1RESERVED_MSK \ | ||
4084 | (0x3 << BT_UART_MSG_FRAME1RESERVED_POS) | ||
4085 | |||
4086 | #define BT_UART_MSG_FRAME2OPENCONNECTIONS_POS (0) | ||
4087 | #define BT_UART_MSG_FRAME2OPENCONNECTIONS_MSK \ | ||
4088 | (0x3 << BT_UART_MSG_FRAME2OPENCONNECTIONS_POS) | ||
4089 | #define BT_UART_MSG_FRAME2TRAFFICLOAD_POS (2) | ||
4090 | #define BT_UART_MSG_FRAME2TRAFFICLOAD_MSK \ | ||
4091 | (0x3 << BT_UART_MSG_FRAME2TRAFFICLOAD_POS) | ||
4092 | #define BT_UART_MSG_FRAME2CHLSEQN_POS (4) | ||
4093 | #define BT_UART_MSG_FRAME2CHLSEQN_MSK \ | ||
4094 | (0x1 << BT_UART_MSG_FRAME2CHLSEQN_POS) | ||
4095 | #define BT_UART_MSG_FRAME2INBAND_POS (5) | ||
4096 | #define BT_UART_MSG_FRAME2INBAND_MSK \ | ||
4097 | (0x1 << BT_UART_MSG_FRAME2INBAND_POS) | ||
4098 | #define BT_UART_MSG_FRAME2RESERVED_POS (6) | ||
4099 | #define BT_UART_MSG_FRAME2RESERVED_MSK \ | ||
4100 | (0x3 << BT_UART_MSG_FRAME2RESERVED_POS) | ||
4101 | |||
4102 | #define BT_UART_MSG_FRAME3SCOESCO_POS (0) | ||
4103 | #define BT_UART_MSG_FRAME3SCOESCO_MSK \ | ||
4104 | (0x1 << BT_UART_MSG_FRAME3SCOESCO_POS) | ||
4105 | #define BT_UART_MSG_FRAME3SNIFF_POS (1) | ||
4106 | #define BT_UART_MSG_FRAME3SNIFF_MSK \ | ||
4107 | (0x1 << BT_UART_MSG_FRAME3SNIFF_POS) | ||
4108 | #define BT_UART_MSG_FRAME3A2DP_POS (2) | ||
4109 | #define BT_UART_MSG_FRAME3A2DP_MSK \ | ||
4110 | (0x1 << BT_UART_MSG_FRAME3A2DP_POS) | ||
4111 | #define BT_UART_MSG_FRAME3ACL_POS (3) | ||
4112 | #define BT_UART_MSG_FRAME3ACL_MSK \ | ||
4113 | (0x1 << BT_UART_MSG_FRAME3ACL_POS) | ||
4114 | #define BT_UART_MSG_FRAME3MASTER_POS (4) | ||
4115 | #define BT_UART_MSG_FRAME3MASTER_MSK \ | ||
4116 | (0x1 << BT_UART_MSG_FRAME3MASTER_POS) | ||
4117 | #define BT_UART_MSG_FRAME3OBEX_POS (5) | ||
4118 | #define BT_UART_MSG_FRAME3OBEX_MSK \ | ||
4119 | (0x1 << BT_UART_MSG_FRAME3OBEX_POS) | ||
4120 | #define BT_UART_MSG_FRAME3RESERVED_POS (6) | ||
4121 | #define BT_UART_MSG_FRAME3RESERVED_MSK \ | ||
4122 | (0x3 << BT_UART_MSG_FRAME3RESERVED_POS) | ||
4123 | |||
4124 | #define BT_UART_MSG_FRAME4IDLEDURATION_POS (0) | ||
4125 | #define BT_UART_MSG_FRAME4IDLEDURATION_MSK \ | ||
4126 | (0x3F << BT_UART_MSG_FRAME4IDLEDURATION_POS) | ||
4127 | #define BT_UART_MSG_FRAME4RESERVED_POS (6) | ||
4128 | #define BT_UART_MSG_FRAME4RESERVED_MSK \ | ||
4129 | (0x3 << BT_UART_MSG_FRAME4RESERVED_POS) | ||
4130 | |||
4131 | #define BT_UART_MSG_FRAME5TXACTIVITY_POS (0) | ||
4132 | #define BT_UART_MSG_FRAME5TXACTIVITY_MSK \ | ||
4133 | (0x3 << BT_UART_MSG_FRAME5TXACTIVITY_POS) | ||
4134 | #define BT_UART_MSG_FRAME5RXACTIVITY_POS (2) | ||
4135 | #define BT_UART_MSG_FRAME5RXACTIVITY_MSK \ | ||
4136 | (0x3 << BT_UART_MSG_FRAME5RXACTIVITY_POS) | ||
4137 | #define BT_UART_MSG_FRAME5ESCORETRANSMIT_POS (4) | ||
4138 | #define BT_UART_MSG_FRAME5ESCORETRANSMIT_MSK \ | ||
4139 | (0x3 << BT_UART_MSG_FRAME5ESCORETRANSMIT_POS) | ||
4140 | #define BT_UART_MSG_FRAME5RESERVED_POS (6) | ||
4141 | #define BT_UART_MSG_FRAME5RESERVED_MSK \ | ||
4142 | (0x3 << BT_UART_MSG_FRAME5RESERVED_POS) | ||
4143 | |||
4144 | #define BT_UART_MSG_FRAME6SNIFFINTERVAL_POS (0) | ||
4145 | #define BT_UART_MSG_FRAME6SNIFFINTERVAL_MSK \ | ||
4146 | (0x1F << BT_UART_MSG_FRAME6SNIFFINTERVAL_POS) | ||
4147 | #define BT_UART_MSG_FRAME6DISCOVERABLE_POS (5) | ||
4148 | #define BT_UART_MSG_FRAME6DISCOVERABLE_MSK \ | ||
4149 | (0x1 << BT_UART_MSG_FRAME6DISCOVERABLE_POS) | ||
4150 | #define BT_UART_MSG_FRAME6RESERVED_POS (6) | ||
4151 | #define BT_UART_MSG_FRAME6RESERVED_MSK \ | ||
4152 | (0x3 << BT_UART_MSG_FRAME6RESERVED_POS) | ||
4153 | |||
4154 | #define BT_UART_MSG_FRAME7SNIFFACTIVITY_POS (0) | ||
4155 | #define BT_UART_MSG_FRAME7SNIFFACTIVITY_MSK \ | ||
4156 | (0x7 << BT_UART_MSG_FRAME7SNIFFACTIVITY_POS) | ||
4157 | #define BT_UART_MSG_FRAME7INQUIRYPAGESRMODE_POS (3) | ||
4158 | #define BT_UART_MSG_FRAME7INQUIRYPAGESRMODE_MSK \ | ||
4159 | (0x3 << BT_UART_MSG_FRAME7INQUIRYPAGESRMODE_POS) | ||
4160 | #define BT_UART_MSG_FRAME7CONNECTABLE_POS (5) | ||
4161 | #define BT_UART_MSG_FRAME7CONNECTABLE_MSK \ | ||
4162 | (0x1 << BT_UART_MSG_FRAME7CONNECTABLE_POS) | ||
4163 | #define BT_UART_MSG_FRAME7RESERVED_POS (6) | ||
4164 | #define BT_UART_MSG_FRAME7RESERVED_MSK \ | ||
4165 | (0x3 << BT_UART_MSG_FRAME7RESERVED_POS) | ||
4166 | |||
4167 | |||
4168 | struct iwl_bt_uart_msg { | ||
4169 | u8 header; | ||
4170 | u8 frame1; | ||
4171 | u8 frame2; | ||
4172 | u8 frame3; | ||
4173 | u8 frame4; | ||
4174 | u8 frame5; | ||
4175 | u8 frame6; | ||
4176 | u8 frame7; | ||
4177 | } __attribute__((packed)); | ||
4178 | |||
4073 | struct iwl_bt_coex_profile_notif { | 4179 | struct iwl_bt_coex_profile_notif { |
4074 | u8 uart_msg[8]; | 4180 | struct iwl_bt_uart_msg last_bt_uart_msg; |
4075 | u8 bt_status; /* 0 - off, 1 - on */ | 4181 | u8 bt_status; /* 0 - off, 1 - on */ |
4076 | u8 bt_traffic_load; /* 0 .. 3? */ | 4182 | u8 bt_traffic_load; /* 0 .. 3? */ |
4077 | u8 bt_ci_compliance; /* 0 - not complied, 1 - complied */ | 4183 | u8 bt_ci_compliance; /* 0 - not complied, 1 - complied */ |
diff --git a/drivers/net/wireless/iwlwifi/iwl-dev.h b/drivers/net/wireless/iwlwifi/iwl-dev.h index bb92a7f01988..e0d524d633bb 100644 --- a/drivers/net/wireless/iwlwifi/iwl-dev.h +++ b/drivers/net/wireless/iwlwifi/iwl-dev.h | |||
@@ -1370,6 +1370,9 @@ struct iwl_priv { | |||
1370 | bool bt_sco_active; | 1370 | bool bt_sco_active; |
1371 | bool bt_full_concurrent; | 1371 | bool bt_full_concurrent; |
1372 | bool bt_ant_couple_ok; | 1372 | bool bt_ant_couple_ok; |
1373 | __le32 kill_ack_mask; | ||
1374 | __le32 kill_cts_mask; | ||
1375 | __le16 bt_valid; | ||
1373 | u8 bt_ci_compliance; | 1376 | u8 bt_ci_compliance; |
1374 | struct work_struct bt_traffic_change_work; | 1377 | struct work_struct bt_traffic_change_work; |
1375 | 1378 | ||
@@ -1392,6 +1395,7 @@ struct iwl_priv { | |||
1392 | struct work_struct start_internal_scan; | 1395 | struct work_struct start_internal_scan; |
1393 | struct work_struct tx_flush; | 1396 | struct work_struct tx_flush; |
1394 | struct work_struct bt_full_concurrency; | 1397 | struct work_struct bt_full_concurrency; |
1398 | struct work_struct bt_runtime_config; | ||
1395 | 1399 | ||
1396 | struct tasklet_struct irq_tasklet; | 1400 | struct tasklet_struct irq_tasklet; |
1397 | 1401 | ||