Эх сурвалжийг харах

qcacmn: Add qdf api support for mtrace logging

Currently mtrace messages are getting recorded in circular
queue but are not getting used for DIAG Infrastructure.
Add support to print the mtrace messages on DIAG infrastructure in
format such that there will be two 32 bit fields printed on the
logs. These two fields will be constructed as explained below:
1. First field will be constructed using below bit positions:
   a. Bit 0 – 14 ( 15 Bits Lsb ) will contain the messageIDs
   b. The bit 15-22 will represent the destination module,
      and the 23-30 will represent the source module which is
      initiating the message.
   c. Bit 31 will represent whether the message is from host
      or from FW. If bit is 0, it indicates the message is
      from host and if it is 1 it indicates the message is
      from FW.
2. Second field will be constructed using below bit positions:
   a. First 16 bits (From LSB )will be used for counter.
   b. Next 8 bits would be the vdev id.
   c. Remaining 8 bits are reserved for future use.

Here counter is static unsigned 16 bit value which will be
used to keep track of number of logs given to QXDM and out of
these logs how many logs have been missed.

Change-Id: I4cec762ef17222d6adda9fd3e283c101afb92955
CRs-Fixed: 2290898
Ashish Kumar Dhanotiya 6 жил өмнө
parent
commit
27bcaf88dd

+ 51 - 0
qdf/inc/qdf_trace.h

@@ -529,6 +529,7 @@ static inline
 void qdf_trace_enable(uint32_t bitmask_of_module_id, uint8_t enable)
 {
 }
+
 static inline
 void qdf_trace(uint8_t module, uint8_t code, uint16_t session, uint32_t data)
 {
@@ -548,6 +549,56 @@ QDF_STATUS qdf_trace_spin_lock_init(void)
 #endif
 #endif
 
+#ifdef ENABLE_MTRACE_LOG
+/**
+ * qdf_mtrace_log() - Logs a message tracepoint to DIAG
+ * Infrastructure.
+ * @src_module: Enum of source module (basically module id)
+ * from where the message with message_id is posted.
+ * @dst_module: Enum of destination module (basically module id)
+ * to which the message with message_id is posted.
+ * @message_id: Id of the message to be posted
+ * @vdev_id: Vdev Id
+ *
+ * This function logs to the DIAG Infrastructure a tracepoint for a
+ * message being sent from a source module to a destination module
+ * with a specific ID for the benefit of a specific vdev.
+ * For non-vdev messages vdev_id will be NO_SESSION
+ * Return: None
+ */
+void qdf_mtrace_log(QDF_MODULE_ID src_module, QDF_MODULE_ID dst_module,
+		    uint16_t message_id, uint8_t vdev_id);
+#else
+static inline
+void qdf_mtrace_log(QDF_MODULE_ID src_module, QDF_MODULE_ID dst_module,
+		    uint16_t message_id, uint8_t vdev_id)
+{
+}
+#endif
+
+/**
+ * qdf_mtrace() - puts the messages in to ring-buffer
+ * and logs a message tracepoint to DIAG Infrastructure.
+ * @src_module: Enum of source module (basically module id)
+ * from where the message with message_id is posted.
+ * @dst_module: Enum of destination module (basically module id)
+ * to which the message with message_id is posted.
+ * @message_id: Id of the message to be posted
+ * @vdev_id: Vdev Id
+ * @data: Actual message contents
+ *
+ * This function will be called from each module which wants to record the
+ * messages in circular queue. Before calling this function make sure you
+ * have registered your module with qdf through qdf_trace_register function.
+ * In addition of the recording the messages in circular queue this function
+ * will log the message tracepoint to the  DIAG infrastructure.
+ * these logs will be later used by post processing script.
+ *
+ * Return: None
+ */
+void qdf_mtrace(QDF_MODULE_ID src_module, QDF_MODULE_ID dst_module,
+		uint16_t message_id, uint8_t vdev_id, uint32_t data);
+
 #ifdef CONFIG_DP_TRACE
 void qdf_dp_set_proto_bitmap(uint32_t val);
 void qdf_dp_trace_set_verbosity(uint32_t val);

+ 27 - 1
qdf/linux/src/qdf_trace.c

@@ -514,7 +514,7 @@ qdf_export_symbol(qdf_trace_deinit);
 /**
  * qdf_trace() - puts the messages in to ring-buffer
  * @module: Enum of module, basically module id.
- * @param: Code to be recorded
+ * @code: Code to be recorded
  * @session: Session ID of the log
  * @data: Actual message contents
  *
@@ -580,6 +580,32 @@ void qdf_trace(uint8_t module, uint8_t code, uint16_t session, uint32_t data)
 }
 qdf_export_symbol(qdf_trace);
 
+#ifdef ENABLE_MTRACE_LOG
+void qdf_mtrace_log(QDF_MODULE_ID src_module, QDF_MODULE_ID dst_module,
+		    uint16_t message_id, uint8_t vdev_id)
+{
+	uint32_t trace_log, payload;
+	static uint16_t counter;
+
+	trace_log = (src_module << 23) | (dst_module << 15) | message_id;
+	payload = (vdev_id << 16) | counter++;
+
+	QDF_TRACE(src_module, QDF_TRACE_LEVEL_TRACE, "%x %x",
+		  trace_log, payload);
+}
+
+qdf_export_symbol(qdf_mtrace_log);
+#endif
+
+void qdf_mtrace(QDF_MODULE_ID src_module, QDF_MODULE_ID dst_module,
+		uint16_t message_id, uint8_t vdev_id, uint32_t data)
+{
+	qdf_trace(src_module, message_id, vdev_id, data);
+	qdf_mtrace_log(src_module, dst_module, message_id, vdev_id);
+}
+
+qdf_export_symbol(qdf_mtrace);
+
 /**
  * qdf_trace_spin_lock_init() - initializes the lock variable before use
  *