aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless
diff options
context:
space:
mode:
authorWey-Yi Guy <wey-yi.w.guy@intel.com>2010-08-23 10:57:10 -0400
committerJohn W. Linville <linville@tuxdriver.com>2010-08-25 14:34:52 -0400
commitfbba94104fb44d2f984e767cd8ac1edd80cb03d5 (patch)
tree6bb65b7ffb3ae8c8165efc11c593e094cb23a8c6 /drivers/net/wireless
parent5d297d50653ba0c498e0b1e7b72b6611651357aa (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.c116
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn-ucode.c5
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-agn.c16
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-commands.h110
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-dev.h4
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
455static 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
522static 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
456static void iwl6000g2b_bt_coex_profile_notif(struct iwl_priv *priv, 542static 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
617static 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
617static void iwl_bg_bt_full_concurrency(struct work_struct *work) 631static 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 */
4062enum iwl_bt_coex_profile_traffic_load { 4062enum 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
4168struct 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
4073struct iwl_bt_coex_profile_notif { 4179struct 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