|
@@ -304,6 +304,7 @@ int pktlog_disable(struct hif_opaque_softc *scn)
|
|
|
cds_get_context(QDF_MODULE_ID_TXRX);
|
|
|
struct ol_pktlog_dev_t *pl_dev;
|
|
|
struct ath_pktlog_info *pl_info;
|
|
|
+ uint8_t save_pktlog_state;
|
|
|
|
|
|
if (txrx_pdev == NULL ||
|
|
|
txrx_pdev->pl_dev == NULL ||
|
|
@@ -313,17 +314,36 @@ int pktlog_disable(struct hif_opaque_softc *scn)
|
|
|
pl_dev = txrx_pdev->pl_dev;
|
|
|
pl_info = pl_dev->pl_info;
|
|
|
|
|
|
+ if (pl_info->curr_pkt_state == PKTLOG_OPR_IN_PROGRESS ||
|
|
|
+ pl_info->curr_pkt_state ==
|
|
|
+ PKTLOG_OPR_IN_PROGRESS_READ_START_PKTLOG_DISABLED ||
|
|
|
+ pl_info->curr_pkt_state == PKTLOG_OPR_IN_PROGRESS_READ_COMPLETE ||
|
|
|
+ pl_info->curr_pkt_state ==
|
|
|
+ PKTLOG_OPR_IN_PROGRESS_CLEARBUFF_COMPLETE)
|
|
|
+ return -EBUSY;
|
|
|
+
|
|
|
+ save_pktlog_state = pl_info->curr_pkt_state;
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_IN_PROGRESS;
|
|
|
+
|
|
|
if (pktlog_wma_post_msg(0, WMI_PDEV_PKTLOG_DISABLE_CMDID, 0, 0)) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
printk("Failed to disable pktlog in target\n");
|
|
|
return -EINVAL;
|
|
|
}
|
|
|
|
|
|
if (pl_dev->is_pktlog_cb_subscribed &&
|
|
|
wdi_pktlog_unsubscribe(txrx_pdev, pl_info->log_state)) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
printk("Cannot unsubscribe pktlog from the WDI\n");
|
|
|
return -EINVAL;
|
|
|
}
|
|
|
pl_dev->is_pktlog_cb_subscribed = false;
|
|
|
+ pl_dev->is_pktlog_cb_subscribed = false;
|
|
|
+ if (save_pktlog_state == PKTLOG_OPR_IN_PROGRESS_READ_START)
|
|
|
+ pl_info->curr_pkt_state =
|
|
|
+ PKTLOG_OPR_IN_PROGRESS_READ_START_PKTLOG_DISABLED;
|
|
|
+ else
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
@@ -346,6 +366,8 @@ void pktlog_init(struct hif_opaque_softc *scn)
|
|
|
pl_info->buf_size = PKTLOG_DEFAULT_BUFSIZE;
|
|
|
pl_info->buf = NULL;
|
|
|
pl_info->log_state = 0;
|
|
|
+ pl_info->init_saved_state = 0;
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
pl_info->sack_thr = PKTLOG_DEFAULT_SACK_THR;
|
|
|
pl_info->tail_length = PKTLOG_DEFAULT_TAIL_LENGTH;
|
|
|
pl_info->thruput_thresh = PKTLOG_DEFAULT_THRUPUT_THRESH;
|
|
@@ -399,23 +421,34 @@ int pktlog_enable(struct hif_opaque_softc *scn, int32_t log_state,
|
|
|
if (!pl_info)
|
|
|
return 0;
|
|
|
|
|
|
+ if (pl_info->curr_pkt_state < PKTLOG_OPR_IN_PROGRESS_CLEARBUFF_COMPLETE)
|
|
|
+ return -EBUSY;
|
|
|
+
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_IN_PROGRESS;
|
|
|
/* is_iwpriv_command : 0 indicates its a vendor command
|
|
|
* log_state: 0 indicates pktlog disable command
|
|
|
* vendor_cmd_send flag; false means no vendor pktlog enable
|
|
|
* command was sent previously
|
|
|
*/
|
|
|
if (is_iwpriv_command == 0 && log_state == 0 &&
|
|
|
- pl_dev->vendor_cmd_send == false)
|
|
|
+ pl_dev->vendor_cmd_send == false) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
return 0;
|
|
|
+ }
|
|
|
|
|
|
if (!pl_dev->tgt_pktlog_alloced) {
|
|
|
if (pl_info->buf == NULL) {
|
|
|
error = pktlog_alloc_buf(scn);
|
|
|
|
|
|
- if (error != 0)
|
|
|
+ if (error != 0) {
|
|
|
+ pl_info->curr_pkt_state =
|
|
|
+ PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
return error;
|
|
|
+ }
|
|
|
|
|
|
if (!pl_info->buf) {
|
|
|
+ pl_info->curr_pkt_state =
|
|
|
+ PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
printk("%s: pktlog buf alloc failed\n",
|
|
|
__func__);
|
|
|
ASSERT(0);
|
|
@@ -443,6 +476,7 @@ int pktlog_enable(struct hif_opaque_softc *scn, int32_t log_state,
|
|
|
/* WDI subscribe */
|
|
|
if ((!pl_dev->is_pktlog_cb_subscribed) &&
|
|
|
wdi_pktlog_subscribe(txrx_pdev, log_state)) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
printk("Unable to subscribe to the WDI %s\n", __func__);
|
|
|
return -EINVAL;
|
|
|
}
|
|
@@ -450,6 +484,7 @@ int pktlog_enable(struct hif_opaque_softc *scn, int32_t log_state,
|
|
|
/* WMI command to enable pktlog on the firmware */
|
|
|
if (pktlog_enable_tgt(scn, log_state, ini_triggered,
|
|
|
user_triggered)) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
printk("Device cannot be enabled, %s\n", __func__);
|
|
|
return -EINVAL;
|
|
|
}
|
|
@@ -457,12 +492,14 @@ int pktlog_enable(struct hif_opaque_softc *scn, int32_t log_state,
|
|
|
if (is_iwpriv_command == 0)
|
|
|
pl_dev->vendor_cmd_send = true;
|
|
|
} else {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
pl_dev->pl_funcs->pktlog_disable(scn);
|
|
|
if (is_iwpriv_command == 0)
|
|
|
pl_dev->vendor_cmd_send = false;
|
|
|
}
|
|
|
|
|
|
pl_info->log_state = log_state;
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
@@ -481,16 +518,25 @@ int pktlog_setsize(struct hif_opaque_softc *scn, int32_t size)
|
|
|
pl_dev = pdev_txrx_handle->pl_dev;
|
|
|
pl_info = pl_dev->pl_info;
|
|
|
|
|
|
- if (size < 0)
|
|
|
+ if (pl_info->curr_pkt_state < PKTLOG_OPR_NOT_IN_PROGRESS)
|
|
|
+ return -EBUSY;
|
|
|
+
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_IN_PROGRESS;
|
|
|
+
|
|
|
+ if (size < 0) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
return -EINVAL;
|
|
|
+ }
|
|
|
|
|
|
if (size == pl_info->buf_size) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
qdf_print("%s: Pktlog Buff Size is already of same size.",
|
|
|
__func__);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
if (pl_info->log_state) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
qdf_print("%s: Logging should be disabled before changing"
|
|
|
"buffer size.", __func__);
|
|
|
return -EINVAL;
|
|
@@ -500,6 +546,7 @@ int pktlog_setsize(struct hif_opaque_softc *scn, int32_t size)
|
|
|
if (pl_dev->is_pktlog_cb_subscribed &&
|
|
|
wdi_pktlog_unsubscribe(pdev_txrx_handle,
|
|
|
pl_info->log_state)) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
printk("Cannot unsubscribe pktlog from the WDI\n");
|
|
|
return -EFAULT;
|
|
|
}
|
|
@@ -512,7 +559,7 @@ int pktlog_setsize(struct hif_opaque_softc *scn, int32_t size)
|
|
|
qdf_print("%s: New Pktlog Buff Size is %d\n", __func__, size);
|
|
|
pl_info->buf_size = size;
|
|
|
}
|
|
|
-
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
@@ -522,6 +569,7 @@ int pktlog_clearbuff(struct hif_opaque_softc *scn, bool clear_buff)
|
|
|
cds_get_context(QDF_MODULE_ID_TXRX);
|
|
|
struct ol_pktlog_dev_t *pl_dev;
|
|
|
struct ath_pktlog_info *pl_info;
|
|
|
+ uint8_t save_pktlog_state;
|
|
|
|
|
|
if (pdev_txrx_handle == NULL ||
|
|
|
pdev_txrx_handle->pl_dev == NULL ||
|
|
@@ -534,7 +582,16 @@ int pktlog_clearbuff(struct hif_opaque_softc *scn, bool clear_buff)
|
|
|
if (!clear_buff)
|
|
|
return -EINVAL;
|
|
|
|
|
|
+ if (pl_info->curr_pkt_state < PKTLOG_OPR_IN_PROGRESS_READ_COMPLETE ||
|
|
|
+ pl_info->curr_pkt_state ==
|
|
|
+ PKTLOG_OPR_IN_PROGRESS_CLEARBUFF_COMPLETE)
|
|
|
+ return -EBUSY;
|
|
|
+
|
|
|
+ save_pktlog_state = pl_info->curr_pkt_state;
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_IN_PROGRESS;
|
|
|
+
|
|
|
if (pl_info->log_state) {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
qdf_print("%s: Logging should be disabled before clearing "
|
|
|
"pktlog buffer.", __func__);
|
|
|
return -EINVAL;
|
|
@@ -548,16 +605,24 @@ int pktlog_clearbuff(struct hif_opaque_softc *scn, bool clear_buff)
|
|
|
pl_dev->tgt_pktlog_alloced = false;
|
|
|
pl_info->buf->rd_offset = -1;
|
|
|
} else {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
qdf_print("%s: pktlog buffer size is not proper. "
|
|
|
"Existing Buf size %d", __func__,
|
|
|
pl_info->buf_size);
|
|
|
return -EFAULT;
|
|
|
}
|
|
|
} else {
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
qdf_print("%s: pktlog buff is NULL", __func__);
|
|
|
return -EFAULT;
|
|
|
}
|
|
|
|
|
|
+ if (save_pktlog_state == PKTLOG_OPR_IN_PROGRESS_READ_COMPLETE)
|
|
|
+ pl_info->curr_pkt_state =
|
|
|
+ PKTLOG_OPR_IN_PROGRESS_CLEARBUFF_COMPLETE;
|
|
|
+ else
|
|
|
+ pl_info->curr_pkt_state = PKTLOG_OPR_NOT_IN_PROGRESS;
|
|
|
+
|
|
|
return 0;
|
|
|
}
|
|
|
|