فهرست منبع

qcacld-3.0: Add DP tracing API to DP component

Add DP tracing API to DP component

Change-Id: Ic55d62a533e4960b258644b9bdc96e856d010bf4
CRs-Fixed: 3165203
Amit Mehta 3 سال پیش
والد
کامیت
1fd4974449

+ 18 - 0
components/dp/core/inc/wlan_dp_main.h

@@ -509,4 +509,22 @@ void *dp_get_arp_request_ctx(struct wlan_objmgr_psoc *psoc)
  */
 QDF_STATUS dp_get_arp_stats_event_handler(struct wlan_objmgr_psoc *psoc,
 					  struct dp_rsp_stats *rsp);
+
+/**
+ * dp_trace_init() - Initialize DP trace
+ * @psoc: psoc handle
+ *
+ * Return: None
+ */
+
+void dp_trace_init(struct wlan_objmgr_psoc *psoc);
+
+/**
+ * dp_set_dump_dp_trace() - set DP trace dump level
+ * @cmd_type : command type
+ * @count: count
+ *
+ * Return: None
+ */
+void dp_set_dump_dp_trace(uint16_t cmd_type, uint16_t count);
 #endif

+ 152 - 0
components/dp/core/src/wlan_dp_main.c

@@ -154,6 +154,158 @@ int is_dp_intf_valid(struct wlan_dp_intf *dp_intf)
 	return validate_interface_id(dp_intf->intf_id);
 }
 
+#ifdef CONFIG_DP_TRACE
+/**
+ * dp_convert_string_to_u8_array() - used to convert string into u8 array
+ * @str: String to be converted
+ * @array: Array where converted value is stored
+ * @len: Length of the populated array
+ * @array_max_len: Maximum length of the array
+ * @to_hex: true, if conversion required for hex string
+ *
+ * This API is called to convert string (each byte separated by
+ * a comma) into an u8 array
+ *
+ * Return: QDF_STATUS
+ */
+static QDF_STATUS dp_convert_string_to_array(char *str, uint8_t *array,
+					     uint8_t *len,
+					     uint16_t array_max_len,
+					     bool to_hex)
+{
+	char *format, *s = str;
+
+	if (!str || !array || !len)
+		return QDF_STATUS_E_INVAL;
+
+	format = (to_hex) ? "%02x" : "%d";
+
+	*len = 0;
+	while ((s) && (*len < array_max_len)) {
+		int val;
+		/* Increment length only if sscanf successfully extracted
+		 * one element. Any other return value means error.
+		 * Ignore it.
+		 */
+		if (sscanf(s, format, &val) == 1) {
+			array[*len] = (uint8_t)val;
+			*len += 1;
+		}
+
+		s = strpbrk(s, ",");
+		if (s)
+			s++;
+	}
+
+	return QDF_STATUS_SUCCESS;
+}
+
+/**
+ * dp_string_to_u8_array() - used to convert string into u8 array
+ * @str: String to be converted
+ * @array: Array where converted value is stored
+ * @len: Length of the populated array
+ * @array_max_len: Maximum length of the array
+ *
+ * Return: QDF_STATUS
+ */
+static
+QDF_STATUS dp_string_to_u8_array(char *str, uint8_t *array,
+				 uint8_t *len, uint16_t array_max_len)
+{
+	return dp_convert_string_to_array(str, array, len,
+					  array_max_len, false);
+}
+
+void dp_trace_init(struct wlan_objmgr_psoc *psoc)
+{
+	struct wlan_dp_psoc_context *dp_ctx;
+	struct wlan_dp_psoc_cfg *config;
+	bool live_mode = DP_TRACE_CONFIG_DEFAULT_LIVE_MODE;
+	uint8_t thresh = DP_TRACE_CONFIG_DEFAULT_THRESH;
+	uint16_t thresh_time_limit = DP_TRACE_CONFIG_DEFAULT_THRESH_TIME_LIMIT;
+	uint8_t verbosity = DP_TRACE_CONFIG_DEFAULT_VERBOSTY;
+	uint32_t proto_bitmap = DP_TRACE_CONFIG_DEFAULT_BITMAP;
+	uint8_t config_params[DP_TRACE_CONFIG_NUM_PARAMS];
+	uint8_t num_entries = 0;
+	uint32_t bw_compute_interval;
+
+	dp_ctx = dp_psoc_get_priv(psoc);
+	if (!dp_ctx) {
+		dp_err("Unable to get DP context");
+		return;
+	}
+
+	config = &dp_ctx->dp_cfg;
+
+	qdf_dp_set_proto_event_bitmap(config->dp_proto_event_bitmap);
+
+	if (!config->enable_dp_trace) {
+		dp_err("dp trace is disabled from ini");
+		return;
+	}
+
+	dp_string_to_u8_array(config->dp_trace_config, config_params,
+			      &num_entries, sizeof(config_params));
+
+	/* calculating, num bw timer intervals in a second (1000ms) */
+	bw_compute_interval = DP_BUS_BW_CFG(config->bus_bw_compute_interval);
+
+	if (bw_compute_interval <= 1000 && bw_compute_interval > 0) {
+		thresh_time_limit = 1000 / bw_compute_interval;
+	} else if (bw_compute_interval > 1000) {
+		dp_err("busBandwidthComputeInterval > 1000, using 1000");
+		thresh_time_limit = 1;
+	} else {
+		dp_err("busBandwidthComputeInterval is 0, using defaults");
+	}
+
+	switch (num_entries) {
+	case 4:
+		proto_bitmap = config_params[3];
+		/* fallthrough */
+	case 3:
+		verbosity = config_params[2];
+		/* fallthrough */
+	case 2:
+		thresh = config_params[1];
+		/* fallthrough */
+	case 1:
+		live_mode = config_params[0];
+		/* fallthrough */
+	default:
+		dp_debug("live_mode %u thresh %u time_limit %u verbosity %u bitmap 0x%x",
+			 live_mode, thresh, thresh_time_limit,
+			 verbosity, proto_bitmap);
+	};
+
+	qdf_dp_trace_init(live_mode, thresh, thresh_time_limit,
+			  verbosity, proto_bitmap);
+}
+
+void dp_set_dump_dp_trace(uint16_t cmd_type, uint16_t count)
+{
+	dp_debug("DUMP_DP_TRACE_LEVEL: %d %d",
+		 cmd_type, count);
+	if (cmd_type == DUMP_DP_TRACE)
+		qdf_dp_trace_dump_all(count, QDF_TRACE_DEFAULT_PDEV_ID);
+	else if (cmd_type == ENABLE_DP_TRACE_LIVE_MODE)
+		qdf_dp_trace_enable_live_mode();
+	else if (cmd_type == CLEAR_DP_TRACE_BUFFER)
+		qdf_dp_trace_clear_buffer();
+	else if (cmd_type == DISABLE_DP_TRACE_LIVE_MODE)
+		qdf_dp_trace_disable_live_mode();
+}
+#else
+static void dp_trace_init(struct wlan_dp_psoc_cfg *config)
+{
+}
+
+void dp_set_dump_dp_trace(uint16_t cmd_type, uint16_t count)
+{
+}
+#endif
+
 static void dp_cfg_init(struct wlan_dp_psoc_context *ctx)
 {
 }

+ 11 - 0
components/dp/dispatcher/inc/wlan_dp_cfg.h

@@ -53,5 +53,16 @@
  */
 #define DP_TRACE_CONFIG_DEFAULT_THRESH_TIME_LIMIT (10)
 
+/* Default proto bitmap in case its missing in gDptraceConfig string */
+#define DP_TRACE_CONFIG_DEFAULT_BITMAP \
+			(QDF_NBUF_PKT_TRAC_TYPE_EAPOL |\
+			QDF_NBUF_PKT_TRAC_TYPE_DHCP |\
+			QDF_NBUF_PKT_TRAC_TYPE_MGMT_ACTION |\
+			QDF_NBUF_PKT_TRAC_TYPE_ARP |\
+			QDF_NBUF_PKT_TRAC_TYPE_ICMP |\
+			QDF_NBUF_PKT_TRAC_TYPE_ICMPv6)\
+
+/* Default verbosity, in case its missing in gDptraceConfig string*/
+#define DP_TRACE_CONFIG_DEFAULT_VERBOSTY QDF_DP_TRACE_VERBOSITY_LOW
 #endif
 #endif /* WLAN_DP_CFG_H__ */

+ 9 - 0
components/dp/dispatcher/inc/wlan_dp_ucfg_api.h

@@ -666,6 +666,15 @@ void ucfg_dp_set_nud_stats_cb(struct wlan_objmgr_psoc *psoc, void *cookie);
  */
 void ucfg_dp_clear_nud_stats_cb(struct wlan_objmgr_psoc *psoc);
 
+/**
+ * ucfg_dp_set_dump_dp_trace() - set DP Trace
+ * @cmd_type : command
+ * @count : Number of lines to dump
+ *
+ * Return: None
+ */
+void ucfg_dp_set_dump_dp_trace(uint16_t cmd_type, uint16_t count);
+
 /**
  * ucfg_dp_req_get_arp_stats() - Send Get ARP set request to FW
  * @psoc: psoc context

+ 6 - 0
components/dp/dispatcher/src/wlan_dp_ucfg_api.c

@@ -364,6 +364,7 @@ QDF_STATUS ucfg_dp_psoc_open(struct wlan_objmgr_psoc *psoc)
 	ucfg_dp_store_qdf_dev(psoc);
 	dp_rtpm_tput_policy_init(psoc);
 	dp_register_pmo_handler();
+	dp_trace_init(psoc);
 	dp_bus_bandwidth_init(psoc);
 
 	return QDF_STATUS_SUCCESS;
@@ -965,6 +966,11 @@ void ucfg_dp_clear_nud_stats_cb(struct wlan_objmgr_psoc *psoc)
 	sb_ops->dp_arp_stats_unregister_event_handler(psoc);
 }
 
+void ucfg_dp_set_dump_dp_trace(uint16_t cmd_type, uint16_t count)
+{
+	dp_set_dump_dp_trace(cmd_type, count);
+}
+
 QDF_STATUS
 ucfg_dp_req_get_arp_stats(struct wlan_objmgr_psoc *psoc,
 			  struct dp_get_arp_stats_params *params)