|
@@ -9274,7 +9274,7 @@ hdd_display_netif_queue_history_compact(struct hdd_context *hdd_ctx)
|
|
|
|
|
|
bytes_written = 0;
|
|
|
|
|
|
- hdd_for_each_adapter(hdd_ctx, adapter) {
|
|
|
+ hdd_for_each_adapter_dev_held(hdd_ctx, adapter) {
|
|
|
curr_time = qdf_system_ticks();
|
|
|
total = curr_time - adapter->start_time;
|
|
|
delta = curr_time - adapter->last_time;
|
|
@@ -9318,6 +9318,8 @@ hdd_display_netif_queue_history_compact(struct hdd_context *hdd_ctx)
|
|
|
temp_str);
|
|
|
|
|
|
adapter_num++;
|
|
|
+ /* dev_put has to be done here */
|
|
|
+ dev_put(adapter->dev);
|
|
|
}
|
|
|
|
|
|
/* using QDF_TRACE to avoid printing function name */
|
|
@@ -9332,6 +9334,95 @@ hdd_display_netif_queue_history_compact(struct hdd_context *hdd_ctx)
|
|
|
|
|
|
/* Max size of a single netdev tx queue state string. e.g. "1: 0x1" */
|
|
|
#define HDD_NETDEV_TX_Q_STATE_STRLEN 15
|
|
|
+/**
|
|
|
+ * wlan_hdd_display_adapter_netif_queue_stats() - display adapter based
|
|
|
+ * netif queue stats
|
|
|
+ * @adapter: hdd adapter
|
|
|
+ *
|
|
|
+ * Return: none
|
|
|
+ */
|
|
|
+static void
|
|
|
+wlan_hdd_display_adapter_netif_queue_stats(struct hdd_adapter *adapter)
|
|
|
+{
|
|
|
+ int i;
|
|
|
+ qdf_time_t total, pause, unpause, curr_time, delta;
|
|
|
+ struct hdd_netif_queue_history *q_hist_ptr;
|
|
|
+ char q_status_buf[NUM_TX_QUEUES * HDD_NETDEV_TX_Q_STATE_STRLEN] = {0};
|
|
|
+
|
|
|
+ hdd_nofl_debug("Netif queue operation statistics:");
|
|
|
+ hdd_nofl_debug("vdev_id %d device mode %d",
|
|
|
+ adapter->vdev_id, adapter->device_mode);
|
|
|
+ hdd_nofl_debug("Current pause_map %x", adapter->pause_map);
|
|
|
+ curr_time = qdf_system_ticks();
|
|
|
+ total = curr_time - adapter->start_time;
|
|
|
+ delta = curr_time - adapter->last_time;
|
|
|
+ if (adapter->pause_map) {
|
|
|
+ pause = adapter->total_pause_time + delta;
|
|
|
+ unpause = adapter->total_unpause_time;
|
|
|
+ } else {
|
|
|
+ unpause = adapter->total_unpause_time + delta;
|
|
|
+ pause = adapter->total_pause_time;
|
|
|
+ }
|
|
|
+ hdd_nofl_debug("Total: %ums Pause: %ums Unpause: %ums",
|
|
|
+ qdf_system_ticks_to_msecs(total),
|
|
|
+ qdf_system_ticks_to_msecs(pause),
|
|
|
+ qdf_system_ticks_to_msecs(unpause));
|
|
|
+ hdd_nofl_debug("reason_type: pause_cnt: unpause_cnt: pause_time");
|
|
|
+
|
|
|
+ for (i = WLAN_CONTROL_PATH; i < WLAN_REASON_TYPE_MAX; i++) {
|
|
|
+ qdf_time_t pause_delta = 0;
|
|
|
+
|
|
|
+ if (adapter->pause_map & (1 << i))
|
|
|
+ pause_delta = delta;
|
|
|
+
|
|
|
+ /* using hdd_log to avoid printing function name */
|
|
|
+ hdd_nofl_debug("%s: %d: %d: %ums",
|
|
|
+ hdd_reason_type_to_string(i),
|
|
|
+ adapter->queue_oper_stats[i].pause_count,
|
|
|
+ adapter->queue_oper_stats[i].
|
|
|
+ unpause_count,
|
|
|
+ qdf_system_ticks_to_msecs(
|
|
|
+ adapter->queue_oper_stats[i].
|
|
|
+ total_pause_time + pause_delta));
|
|
|
+ }
|
|
|
+
|
|
|
+ hdd_nofl_debug("Netif queue operation history: Total entries: %d current index %d(-1) time %u",
|
|
|
+ WLAN_HDD_MAX_HISTORY_ENTRY,
|
|
|
+ adapter->history_index,
|
|
|
+ qdf_system_ticks_to_msecs(qdf_system_ticks()));
|
|
|
+
|
|
|
+ hdd_nofl_debug("%2s%20s%50s%30s%10s %s",
|
|
|
+ "#", "time(ms)", "action_type", "reason_type",
|
|
|
+ "pause_map", "netdev-queue-status");
|
|
|
+
|
|
|
+ for (i = 0; i < WLAN_HDD_MAX_HISTORY_ENTRY; i++) {
|
|
|
+ /* using hdd_log to avoid printing function name */
|
|
|
+ if (adapter->queue_oper_history[i].time == 0)
|
|
|
+ continue;
|
|
|
+ q_hist_ptr = &adapter->queue_oper_history[i];
|
|
|
+ wlan_hdd_dump_queue_history_state(q_hist_ptr,
|
|
|
+ q_status_buf,
|
|
|
+ sizeof(q_status_buf));
|
|
|
+ hdd_nofl_debug("%2d%20u%50s%30s%10x %s",
|
|
|
+ i, qdf_system_ticks_to_msecs(
|
|
|
+ adapter->queue_oper_history[i].time),
|
|
|
+ hdd_action_type_to_string(
|
|
|
+ adapter->queue_oper_history[i].
|
|
|
+ netif_action),
|
|
|
+ hdd_reason_type_to_string(
|
|
|
+ adapter->queue_oper_history[i].
|
|
|
+ netif_reason),
|
|
|
+ adapter->queue_oper_history[i].pause_map,
|
|
|
+ q_status_buf);
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+void
|
|
|
+wlan_hdd_display_adapter_netif_queue_history(struct hdd_adapter *adapter)
|
|
|
+{
|
|
|
+ wlan_hdd_display_adapter_netif_queue_stats(adapter);
|
|
|
+}
|
|
|
+
|
|
|
/**
|
|
|
* wlan_hdd_display_netif_queue_history() - display netif queue history
|
|
|
* @hdd_ctx: hdd context
|
|
@@ -9342,86 +9433,21 @@ void
|
|
|
wlan_hdd_display_netif_queue_history(struct hdd_context *hdd_ctx,
|
|
|
enum qdf_stats_verbosity_level verb_lvl)
|
|
|
{
|
|
|
- int i;
|
|
|
struct hdd_adapter *adapter = NULL;
|
|
|
- qdf_time_t total, pause, unpause, curr_time, delta;
|
|
|
- struct hdd_netif_queue_history *q_hist_ptr;
|
|
|
- char q_status_buf[NUM_TX_QUEUES * HDD_NETDEV_TX_Q_STATE_STRLEN] = {0};
|
|
|
|
|
|
if (verb_lvl == QDF_STATS_VERBOSITY_LEVEL_LOW) {
|
|
|
hdd_display_netif_queue_history_compact(hdd_ctx);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
- hdd_for_each_adapter(hdd_ctx, adapter) {
|
|
|
- if (adapter->vdev_id == CDP_INVALID_VDEV_ID)
|
|
|
+ hdd_for_each_adapter_dev_held(hdd_ctx, adapter) {
|
|
|
+ if (adapter->vdev_id == CDP_INVALID_VDEV_ID) {
|
|
|
+ dev_put(adapter->dev);
|
|
|
continue;
|
|
|
- hdd_nofl_debug("Netif queue operation statistics:");
|
|
|
- hdd_nofl_debug("vdev_id %d device mode %d",
|
|
|
- adapter->vdev_id, adapter->device_mode);
|
|
|
- hdd_nofl_debug("Current pause_map %x", adapter->pause_map);
|
|
|
- curr_time = qdf_system_ticks();
|
|
|
- total = curr_time - adapter->start_time;
|
|
|
- delta = curr_time - adapter->last_time;
|
|
|
- if (adapter->pause_map) {
|
|
|
- pause = adapter->total_pause_time + delta;
|
|
|
- unpause = adapter->total_unpause_time;
|
|
|
- } else {
|
|
|
- unpause = adapter->total_unpause_time + delta;
|
|
|
- pause = adapter->total_pause_time;
|
|
|
- }
|
|
|
- hdd_nofl_debug("Total: %ums Pause: %ums Unpause: %ums",
|
|
|
- qdf_system_ticks_to_msecs(total),
|
|
|
- qdf_system_ticks_to_msecs(pause),
|
|
|
- qdf_system_ticks_to_msecs(unpause));
|
|
|
- hdd_nofl_debug("reason_type: pause_cnt: unpause_cnt: pause_time");
|
|
|
-
|
|
|
- for (i = WLAN_CONTROL_PATH; i < WLAN_REASON_TYPE_MAX; i++) {
|
|
|
- qdf_time_t pause_delta = 0;
|
|
|
-
|
|
|
- if (adapter->pause_map & (1 << i))
|
|
|
- pause_delta = delta;
|
|
|
-
|
|
|
- /* using hdd_log to avoid printing function name */
|
|
|
- hdd_nofl_debug("%s: %d: %d: %ums",
|
|
|
- hdd_reason_type_to_string(i),
|
|
|
- adapter->queue_oper_stats[i].pause_count,
|
|
|
- adapter->queue_oper_stats[i].
|
|
|
- unpause_count,
|
|
|
- qdf_system_ticks_to_msecs(
|
|
|
- adapter->queue_oper_stats[i].
|
|
|
- total_pause_time + pause_delta));
|
|
|
- }
|
|
|
-
|
|
|
- hdd_nofl_debug("Netif queue operation history: Total entries: %d current index %d(-1) time %u",
|
|
|
- WLAN_HDD_MAX_HISTORY_ENTRY,
|
|
|
- adapter->history_index,
|
|
|
- qdf_system_ticks_to_msecs(qdf_system_ticks()));
|
|
|
-
|
|
|
- hdd_nofl_debug("%2s%20s%50s%30s%10s %s",
|
|
|
- "#", "time(ms)", "action_type", "reason_type",
|
|
|
- "pause_map", "netdev-queue-status");
|
|
|
-
|
|
|
- for (i = 0; i < WLAN_HDD_MAX_HISTORY_ENTRY; i++) {
|
|
|
- /* using hdd_log to avoid printing function name */
|
|
|
- if (adapter->queue_oper_history[i].time == 0)
|
|
|
- continue;
|
|
|
- q_hist_ptr = &adapter->queue_oper_history[i];
|
|
|
- wlan_hdd_dump_queue_history_state(q_hist_ptr,
|
|
|
- q_status_buf,
|
|
|
- sizeof(q_status_buf));
|
|
|
- hdd_nofl_debug("%2d%20u%50s%30s%10x %s",
|
|
|
- i, qdf_system_ticks_to_msecs(
|
|
|
- adapter->queue_oper_history[i].time),
|
|
|
- hdd_action_type_to_string(
|
|
|
- adapter->queue_oper_history[i].
|
|
|
- netif_action),
|
|
|
- hdd_reason_type_to_string(
|
|
|
- adapter->queue_oper_history[i].
|
|
|
- netif_reason),
|
|
|
- adapter->queue_oper_history[i].pause_map,
|
|
|
- q_status_buf);
|
|
|
}
|
|
|
+ wlan_hdd_display_adapter_netif_queue_stats(adapter);
|
|
|
+ /* dev_put has to be done here */
|
|
|
+ dev_put(adapter->dev);
|
|
|
}
|
|
|
}
|
|
|
|