Merge "[qca-nss-drv] Wi-Fi Log"
diff --git a/Makefile b/Makefile
index 20355c4..c769de7 100644
--- a/Makefile
+++ b/Makefile
@@ -112,6 +112,7 @@
 			nss_vlan_log.o \
 			nss_tstamp.o \
 			nss_wifi.o \
+			nss_wifi_log.o \
 			nss_wifi_stats.o \
 			nss_wifi_vdev.o \
 			nss_wifi_if.o \
diff --git a/Makefile.fsm b/Makefile.fsm
index 323843a..7f23771 100644
--- a/Makefile.fsm
+++ b/Makefile.fsm
@@ -98,6 +98,7 @@
 			nss_vlan.o \
 			nss_vlan_log.o \
 			nss_wifi.o \
+			nss_wifi_log.o \
 			nss_wifi_stats.o \
 			nss_wifi_if.o \
 			nss_wifi_if_stats.o \
diff --git a/exports/nss_wifi.h b/exports/nss_wifi.h
index 6669b1e..4be0258 100644
--- a/exports/nss_wifi.h
+++ b/exports/nss_wifi.h
@@ -124,6 +124,7 @@
 	NSS_WIFI_EMSG_PEERID_INVALID,
 	NSS_WIFI_EMSG_PEER_INVALID,
 	NSS_WIFI_EMSG_UNKNOWN_CMD,
+	NSS_WIFI_EMSG_MAX,
 };
 
 /**
diff --git a/nss_wifi.c b/nss_wifi.c
index cffd3d3..ca60fd6 100644
--- a/nss_wifi.c
+++ b/nss_wifi.c
@@ -16,6 +16,7 @@
 
 #include "nss_tx_rx_common.h"
 #include "nss_wifi_stats.h"
+#include "nss_wifi_log.h"
 
 /*
  * nss_wifi_get_context()
@@ -41,6 +42,11 @@
 	BUG_ON(((ncm->interface < NSS_WIFI_INTERFACE0) || (ncm->interface > NSS_WIFI_INTERFACE2)));
 
 	/*
+	 * Trace messages.
+	 */
+	nss_wifi_log_rx_msg(ntm);
+
+	/*
 	 * Is this a valid request/response packet?
 	 */
 	if (ncm->type >= NSS_WIFI_MAX_MSG) {
@@ -111,6 +117,11 @@
 {
 	struct nss_cmn_msg *ncm = &msg->cm;
 
+	/*
+	 * Trace messages.
+	 */
+	nss_wifi_log_tx_msg(msg);
+
 	if (ncm->type > NSS_WIFI_MAX_MSG) {
 		nss_warning("%p: wifi message type out of range: %d", nss_ctx, ncm->type);
 		return NSS_TX_FAILURE;
diff --git a/nss_wifi_log.c b/nss_wifi_log.c
new file mode 100644
index 0000000..19ce0dc
--- /dev/null
+++ b/nss_wifi_log.c
@@ -0,0 +1,806 @@
+/*
+ **************************************************************************
+ * Copyright (c) 2018, The Linux Foundation. All rights reserved.
+ * Permission to use, copy, modify, and/or distribute this software for
+ * any purpose with or without fee is hereby granted, provided that the
+ * above copyright notice and this permission notice appear in all copies.
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
+ * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ **************************************************************************
+ */
+
+/*
+ * nss_wifi_log.c
+ *	NSS WIFI logger file.
+ */
+
+#include "nss_core.h"
+
+/*
+ * nss_wifi_log_message_types_str
+ *	WIFI message strings
+ */
+static int8_t *nss_wifi_log_message_types_str[NSS_WIFI_MAX_MSG] __maybe_unused = {
+	"WIFI INIT MSG",
+	"WIFI POST RECV MSG",
+	"WIFI HTT INIT MSG",
+	"WIFI TX INIT MSG",
+	"WIFI RAW SEND MSG",
+	"WIFI MGMT SEND MSG",
+	"WIFI WDS PEER ADD MSG",
+	"WIFI WDS PEER DEL MSG",
+	"WIFI STOP MSG",
+	"WIFI RESET MSG",
+	"WIFI STATS MSG",
+	"WIFI PEER FREELIST APPEND MSG",
+	"WIFI RX REORDER ARRAY FREELIST APPEND MSG",
+	"WIFI SEND PEER MEMORY REQUEST MSG",
+	"WIFI SEND RRA MEMORY REQUEST MSG",
+	"WIFI FW STATS MSG",
+	"WIFI MONITOR FILTER SET MSG",
+	"WIFI PEER BS STATE MSG",
+	"WIFI MSDU TTL SET MSG",
+	"WIFI RX VOW EXTSTATS SET MSG",
+	"WIFI PKTLOG CFG MSG",
+	"WIFI ENABLE PERPKT TXSTATS MSG",
+	"WIFI IGMP MLD TOS OVERRIDE MSG",
+	"WIFI OL STATS CFG MSG",
+	"WIFI OL STATS MSG",
+	"WIFI TX QUEUE CFG MSG",
+	"WIFI TX MIN THRESHOLD CFG MSG",
+	"WIFI DBDC PROCESS ENABLE MSG",
+	"WIFI PRIMARY RADIO SET MSG",
+	"WIFI FORCE CLIENT MCAST TRAFFIC SET MSG",
+	"WIFI STORE OTHER PDEV STAVAP MSG",
+	"WIFI STA KICKOUT MSG",
+	"WIFI WNM PEER RX ACTIVITY MSG",
+	"WIFI PEER STATS MSG",
+	"WIFI WDS VENDOR MSG",
+	"WIFI TX CAPTURE SET MSG",
+	"WIFI ALWAYS PRIMARY SET MSG",
+	"WIFI FLUSH HTT CMD MSG",
+	"WIFI CMD MSG",
+	"WIFI ENABLE OL STATSV2 MSG",
+	"WIFI OL PEER TIME MSG",
+};
+
+/*
+ * nss_wifi_log_error_response_types_str
+ *	Strings for error types for WIFI messages
+ */
+static int8_t *nss_wifi_log_error_response_types_str[NSS_WIFI_EMSG_MAX] __maybe_unused = {
+	"WIFI NO ERROR",
+	"WIFI UNKNOWN MSG",
+	"WIFI MGMT DLEN",
+	"WIFI MGMT SEND",
+	"WIFI CE INIT FAIL",
+	"WIFI PDEV INIT FAIL",
+	"WIFI HTT INIT FAIL",
+	"WIFI PEER ADD",
+	"WIFI WIFI START FAIL",
+	"WIFI STATE NOT RESET",
+	"WIFI STATE NOT INIT DONE",
+	"WIFI STATE NULL CE HANDLE",
+	"WIFI STATE NOT CE READY",
+	"WIFI STATE NOT HTT READY",
+	"WIFI FW STATS DLEN",
+	"WIFI FW STATS SEND",
+	"WIFI STATE TX INIT FAILED",
+	"WIFI IGMP MLD TOS OVERRIDE CFG",
+	"WIFI PDEV INVALID",
+	"WIFI OTHER PDEV STAVAP INVALID",
+	"WIFI HTT SEND FAIL",
+	"WIFI CE RING INIT",
+	"WIFI NOTIFY CB",
+	"WIFI PEERID INVALID",
+	"WIFI PEER INVALID",
+	"WIFI UNKNOWN CMD"
+};
+
+/*
+ * nss_wifi_log_init_msg()
+ *	Log NSS WIFI Init message.
+ */
+static void nss_wifi_log_init_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_init_msg *nwim __maybe_unused = &ncm->msg.initmsg;
+
+	nss_trace("%p: NSS WIFI Init Message:\n"
+		"WIFI Radio ID: %d\n"
+		"WIFI PCI Memory Address: %x\n"
+		"WIFI Target Type: %d\n"
+		"WIFI MU MIMO Enhancement Enable Flag: %d\n"
+		"WIFI Transmit Copy Engine Source Ring:\n"
+		"\tNumber of Entries: %d\n"
+		"\tNumber of Entries Mask: %x\n"
+		"\tInitial Software Index: %d\n"
+		"\tInitial Write Index: %d\n"
+		"\tInitial Hardware Index: %d\n"
+		"\tPhysical Address: %x\n"
+		"\tVirtual Address: %x\n"
+		"WIFI Transmit Copy Engine Dest Ring:\n"
+		"\tNumber of Entries: %d\n"
+		"\tNumber of Entries Mask: %x\n"
+		"\tInitial Software Index: %d\n"
+		"\tInitial Write Index: %d\n"
+		"\tInitial Hardware Index: %d\n"
+		"\tPhysical Address: %x\n"
+		"\tVirtual Address: %x\n"
+		"WIFI Transmit Control Address of PCIe Bar: %x\n"
+		"WIFI Receive Copy Engine Source Ring:\n"
+		"\tNumber of Entries: %d\n"
+		"\tNumber of Entries Mask: %x\n"
+		"\tInitial Software Index: %d\n"
+		"\tInitial Write Index: %d\n"
+		"\tInitial Hardware Index: %d\n"
+		"\tPhysical Address: %x\n"
+		"\tVirtual Address: %x\n"
+		"WIFI Receive Copy Engine Dest Ring:\n"
+		"\tNumber of Entries: %d\n"
+		"\tNumber of Entries Mask: %x\n"
+		"\tInitial Software Index: %d\n"
+		"\tInitial Write Index: %d\n"
+		"\tInitial Hardware Index: %d\n"
+		"\tPhysical Address: %x\n"
+		"\tVirtual Address: %x\n"
+		"WIFI Receive Control Address of PCIe Bar: %x\n"
+		"WIFI Bypass Network Process: %d",
+		nwim, nwim->radio_id,
+		nwim->pci_mem, nwim->target_type,
+		nwim->mu_mimo_enhancement_en, nwim->ce_tx_state.src_ring.nentries,
+		nwim->ce_tx_state.src_ring.nentries_mask, nwim->ce_tx_state.src_ring.sw_index,
+		nwim->ce_tx_state.src_ring.write_index, nwim->ce_tx_state.src_ring.hw_index,
+		nwim->ce_tx_state.src_ring.base_addr_CE_space, nwim->ce_tx_state.src_ring.base_addr_owner_space,
+		nwim->ce_tx_state.dest_ring.nentries, nwim->ce_tx_state.dest_ring.nentries_mask,
+		nwim->ce_tx_state.dest_ring.sw_index, nwim->ce_tx_state.dest_ring.write_index,
+		nwim->ce_tx_state.dest_ring.hw_index, nwim->ce_tx_state.dest_ring.base_addr_CE_space,
+		nwim->ce_tx_state.dest_ring.base_addr_owner_space, nwim->ce_tx_state.ctrl_addr,
+		nwim->ce_rx_state.src_ring.nentries, nwim->ce_rx_state.src_ring.nentries_mask,
+		nwim->ce_rx_state.src_ring.sw_index, nwim->ce_rx_state.src_ring.write_index,
+		nwim->ce_rx_state.src_ring.hw_index, nwim->ce_rx_state.src_ring.base_addr_CE_space,
+		nwim->ce_rx_state.src_ring.base_addr_owner_space, nwim->ce_rx_state.dest_ring.nentries,
+		nwim->ce_rx_state.dest_ring.nentries_mask, nwim->ce_rx_state.dest_ring.sw_index,
+		nwim->ce_rx_state.dest_ring.write_index, nwim->ce_rx_state.dest_ring.hw_index,
+		nwim->ce_rx_state.dest_ring.base_addr_CE_space, nwim->ce_rx_state.dest_ring.base_addr_owner_space,
+		nwim->ce_rx_state.ctrl_addr, nwim->bypass_nw_process);
+}
+
+/*
+ * nss_wifi_log_stop_msg()
+ *	Log NSS WIFI Init message.
+ */
+static void nss_wifi_log_stop_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_stop_msg *nwsm __maybe_unused = &ncm->msg.stopmsg;
+	nss_trace("%p: NSS WIFI Init Message:\n"
+		"WIFI Radio ID: %d\n",
+		nwsm, nwsm->radio_id);
+}
+
+/*
+ * nss_wifi_log_reset_msg()
+ *	Log NSS WIFI Init message.
+ */
+static void nss_wifi_log_reset_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_reset_msg *nwrm __maybe_unused = &ncm->msg.resetmsg;
+	nss_trace("%p: NSS WIFI Init Message:\n"
+		"WIFI Radio ID: %d\n",
+		nwrm, nwrm->radio_id);
+}
+
+/*
+ * nss_wifi_log_htt_init_msg()
+ *	Log NSS WIFI HTT Init message.
+ */
+static void nss_wifi_log_htt_init_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_htt_init_msg *nwim __maybe_unused = &ncm->msg.httinitmsg;
+	nss_trace("%p: NSS WIFI HTT Init Message:\n"
+		"WIFI Radio ID: %d\n"
+		"WIFI Ring Size: %d\n"
+		"WIFI Fill Level: %d\n"
+		"WIFI MAC Hardware Ring Phy Address: %x\n"
+		"WIFI MAC Hardware Ring Virtual Address: %x\n"
+		"WIFI Hardware Ring Index Phy Address: %x\n"
+		"WIFI Hardware Ring Index Virtual Address: %x\n",
+		nwim, nwim->radio_id,
+		nwim->ringsize, nwim->fill_level,
+		nwim->paddrs_ringptr, nwim->paddrs_ringpaddr,
+		nwim->alloc_idx_paddr, nwim->alloc_idx_vaddr);
+}
+
+/*
+ * nss_wifi_log_tx_init_msg()
+ *	Log NSS TX HTT Init message.
+ */
+static void nss_wifi_log_tx_init_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_tx_init_msg *nwim __maybe_unused = &ncm->msg.pdevtxinitmsg;
+	nss_trace("%p: NSS WIFI HTT Init Message:\n"
+		"WIFI Radio ID: %d\n"
+		"WIFI Number of Descriptor Pools Allocated: %d\n"
+		"WIFI TX Descriptor Array: %x\n"
+		"WIFI MAC extenstion descriptor Address: %x\n"
+		"WIFI WLAN MAC extenstion descriptor size: %d\n"
+		"WIFI HTT Tx descriptor memory start virtual address: %x\n"
+		"WIFI HTT Tx descriptor memory base virtual address: %x\n"
+		"WIFI HTT Tx descriptor memory offset: %x\n"
+		"WIFI Firmware shared TID map: %x\n",
+		nwim, nwim->radio_id,
+		nwim->desc_pool_size, nwim->tx_desc_array,
+		nwim->wlanextdesc_addr, nwim->wlanextdesc_size,
+		nwim->htt_tx_desc_base_vaddr, nwim->htt_tx_desc_base_paddr,
+		nwim->htt_tx_desc_offset, nwim->pmap_addr);
+}
+
+/*
+ * nss_wifi_log_rawsend_msg()
+ *	Log NSS WIFI RAW Send message.
+ */
+static void nss_wifi_log_rawsend_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_rawsend_msg *nwrm __maybe_unused = &ncm->msg.rawmsg;
+	nss_trace("%p: NSS WIFI RAW Send Message:\n"
+		"WIFI Radio ID: %d\n"
+		"WIFI Size of Raw Data: %d\n"
+		"WIFI Raw Data: %p",
+		nwrm, nwrm->radio_id,
+		nwrm->len, nwrm->array);
+}
+
+/*
+ * nss_wifi_log_mgmtsend_msg()
+ *	Log NSS WIFI Management Send message.
+ */
+static void nss_wifi_log_mgmtsend_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_mgmtsend_msg *nwmm __maybe_unused = &ncm->msg.mgmtmsg;
+	nss_trace("%p: NSS WIFI Management Send Message:\n"
+		"WIFI Descriptor ID: %d\n"
+		"WIFI Size of Management Data: %d\n"
+		"WIFI Management Data: %p",
+		nwmm, nwmm->desc_id,
+		nwmm->len, nwmm->array);
+}
+
+/*
+ * nss_wifi_log_wds_peer_msg()
+ *	Log NSS WIFI WDS Peer message.
+ */
+static void nss_wifi_log_wds_peer_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_wds_peer_msg *nwmm __maybe_unused = &ncm->msg.pdevwdspeermsg;
+	nss_trace("%p: NSS WIFI WDS Peer Message:\n"
+		"WIFI Dest MAC: %pM\n"
+		"WIFI Peer MAC: %pM\n",
+		nwmm, nwmm->dest_mac,
+		nwmm->peer_mac);
+}
+
+/*
+ * nss_wifi_log_peer_freelist_append_msg()
+ *	Log NSS WIFI Create/Append Freelist message
+ */
+static void nss_wifi_log_peer_freelist_append_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_peer_freelist_append_msg *nwpm __maybe_unused = &ncm->msg.peer_freelist_append;
+	nss_trace("%p: NSS WIFI Create/Append Freelist Message:\n"
+		"WIFI Starting Address of Peer Freelist Pool: %x\n"
+		"WIFI Length of freelist pool: %d\n"
+		"WIFI Number of Peers supported in freelist pool: %d\n",
+		nwpm, nwpm->addr,
+		nwpm->length, nwpm->num_peers);
+}
+
+/*
+ * nss_wifi_log_rx_reorder_array_freelist_append_msg()
+ *	Log NSS WIFI RX Reorder Array Freelist message
+ */
+static void nss_wifi_log_rx_reorder_array_freelist_append_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_rx_reorder_array_freelist_append_msg *nwpm __maybe_unused = &ncm->msg.rx_reorder_array_freelist_append;
+	nss_trace("%p: NSS WIFI RX Reorder Array Freelist Message:\n"
+		"WIFI Starting Address of TIDQ Freelist Pool: %x\n"
+		"WIFI Length of TIDQ freelist pool: %d\n"
+		"WIFI Number of Rx reorder array entries supported in freelist pool: %d\n",
+		nwpm, nwpm->addr,
+		nwpm->length, nwpm->num_rra);
+}
+
+/*
+ * nss_wifi_log_set_filter_msg()
+ *	Log NSS WIFI Set Filter message
+ */
+static void nss_wifi_log_set_filter_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_monitor_set_filter_msg *nwfm __maybe_unused = &ncm->msg.monitor_filter_msg;
+	nss_trace("%p: NSS WIFI Set Filter Message:\n"
+		"WIFI Filter Type: %dn",
+		nwfm, nwfm->filter_type);
+}
+
+/*
+ * nss_wifi_log_peer_activity_msg()
+ *	Log NSS WIFI Get Active Peer for Radio message
+ */
+static void nss_wifi_log_peer_activity_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_bs_peer_activity *nwpm __maybe_unused = &ncm->msg.peer_activity;
+	nss_trace("%p: NSS WIFI Get Active Peer Message:\n"
+		"WIFI Number of Entries in Peer ID Array: %d\n"
+		"WIFI PEER ID: %d\n",
+		nwpm, nwpm->nentries,
+		nwpm->peer_id[0]);
+}
+
+/*
+ * nss_wifi_rx_vow_extstats_set_msg()
+ *	Log NSS WIFI VoW Extended Statistics Set Message.
+ */
+static void nss_wifi_log_rx_vow_extstats_set_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_rx_vow_extstats_set_msg *nwpm __maybe_unused = &ncm->msg.vow_extstats_msg;
+	nss_trace("%p: NSS WIFI VoW Extended Statistics Set Message:\n"
+		"WIFI VoW Extended Statistics Enable:: %d\n",
+		nwpm, nwpm->vow_extstats_en);
+}
+
+/*
+ * nss_wifi_log_pktlog_cfg_msg()
+ *	Log NSS WIFI Packet Log Configuration Message.
+ */
+static void nss_wifi_log_pktlog_cfg_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_pktlog_cfg_msg *nwpm __maybe_unused = &ncm->msg.pcm_msg;
+	nss_trace("%p: NSS WIFI Packet Log Configuration Message:\n"
+		"WIFI Packet Log Enable: %d\n"
+		"WIFI PAcket Log buffer Size: %d\n"
+		"WIFI Size of packet log header: %d\n"
+		"WIFI Offset for the MSDU ID: %d\n",
+		nwpm, nwpm->enable,
+		nwpm->bufsize, nwpm->hdrsize,
+		nwpm->msdu_id_offset);
+}
+
+/*
+ * nss_wifi_log_enable_perpkt_txstats_msg()
+ *	Log NSS WIFI Enable TX Stats Message.
+ */
+static void nss_wifi_log_enable_perpkt_txstats_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_enable_perpkt_txstats_msg *nwpm __maybe_unused = &ncm->msg.ept_msg;
+	nss_trace("%p: NSS WIFI Enable TX Stats Message:\n"
+		"WIFI TX Stats Enable Flag: %d\n",
+		nwpm, nwpm->perpkt_txstats_flag);
+}
+
+/*
+ * nss_wifi_log_override_tos_msg()
+ *	Log NSS WIFI Override TOS Message.
+ */
+static void nss_wifi_log_override_tos_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_igmp_mld_override_tos_msg *nwpm __maybe_unused = &ncm->msg.wigmpmldtm_msg;
+	nss_trace("%p: NSS WIFI Override TOS Message:\n"
+		"WIFI enable TID override Flag: %d\n"
+		"WIFI Value of TID to be overriden: %d\n",
+		nwpm, nwpm->igmp_mld_ovride_tid_en,
+		nwpm->igmp_mld_ovride_tid_val);
+}
+
+/*
+ * nss_wifi_log_ol_stats_cfg_msg()
+ *	Log NSS WIFI Offload Stats Config Message.
+ */
+static void nss_wifi_log_ol_stats_cfg_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_ol_stats_cfg_msg *nwpm __maybe_unused = &ncm->msg.scm_msg;
+	nss_trace("%p: NSS WIFI Enable/Disable Offload Stats Message:\n"
+		"WIFI enable/disable offload stats config: %d\n",
+		nwpm, nwpm->stats_cfg);
+}
+
+/*
+ * nss_wifi_log_tx_queue_cfg_msg()
+ *	Log NSS WIFI TX Queue Configuration message.
+ */
+static void nss_wifi_log_tx_queue_cfg_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_tx_queue_cfg_msg *nwpm __maybe_unused = &ncm->msg.wtxqcm;
+	nss_trace("%p: NSS WIFI TX Queue Config Message:\n"
+		"WIFI TX Queue Size: %d\n"
+		"WIFI TX Queue Range: %d\n",
+		nwpm, nwpm->size, nwpm->range);
+}
+
+/*
+ * nss_wifi_log_tx_min_threshold_cfg()
+ *	Log NSS WIFI TX Queue Min Threshold Configuration message.
+ */
+static void nss_wifi_log_tx_min_threshold_cfg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_tx_min_threshold_cfg_msg *nwpm __maybe_unused = &ncm->msg.wtx_min_threshold_cm;
+	nss_trace("%p: NSS WIFI TX Queue Min Threshold Config Message:\n"
+		"WIFI TX Queue Min Threshold Value: %d\n",
+		nwpm, nwpm->min_threshold);
+}
+
+/*
+ * nss_wifi_log_dbdc_process_enable_msg()
+ *	Log NSS WIFI DBDC repeater process configuration.
+ */
+static void nss_wifi_log_dbdc_process_enable_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_dbdc_process_enable_msg *nwpm __maybe_unused = &ncm->msg.dbdcpe_msg;
+	nss_trace("%p: NSS WIFI DBDC repeater process configuration:\n"
+		"WIFI DBDC Process Enable Flag: %d\n",
+		nwpm, nwpm->dbdc_process_enable);
+}
+
+/*
+ * nss_wifi_log_primary_radio_set_msg()
+ *	Log NSS WIFI Primary Radio Set message.
+ */
+static void nss_wifi_log_primary_radio_set_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_primary_radio_set_msg *nwpm __maybe_unused = &ncm->msg.wprs_msg;
+	nss_trace("%p: NSS WIFI Primary Radio Set Message:\n"
+		"WIFI Current Radio as Primary Radio Enable/Disable Flag: %d\n",
+		nwpm, nwpm->flag);
+}
+
+/*
+ * nss_wifi_log_force_client_mcast_traffic_set_msg()
+ *	Log NSS WIFI Force Multicat Traffic for Radio
+ */
+static void nss_wifi_log_force_client_mcast_traffic_set_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_force_client_mcast_traffic_set_msg *nwpm __maybe_unused = &ncm->msg.wfcmts_msg;
+	nss_trace("%p: NSS WIFI Force Multicat Traffic for Radio Message:\n"
+		"WIFI Radio Multicast Traffic Flag: %d\n",
+		nwpm, nwpm->flag);
+}
+
+/*
+ * nss_wifi_log_store_other_pdev_stavap_msg()
+ *	Log NSS WIFI Store Other Radio Station VAP Message.
+ */
+static void nss_wifi_log_store_other_pdev_stavap_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_store_other_pdev_stavap_msg *nwpm __maybe_unused = &ncm->msg.wsops_msg;
+	nss_trace("%p: NSS WIFI Store Other Radio Station VAP Message:\n"
+		"WIFI Station VAP Interface Number: %d\n",
+		nwpm, nwpm->stavap_ifnum);
+}
+
+/*
+ * nss_wifi_log_sta_kickout_msg()
+ *	Log NSS WIFI Station Kickout Message.
+ */
+static void nss_wifi_log_sta_kickout_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_sta_kickout_msg *nwpm __maybe_unused = &ncm->msg.sta_kickout_msg;
+	nss_trace("%p: NSS WIFI Station Kickout Message:\n"
+		"WIFI PEER ID: %d\n",
+		nwpm, nwpm->peer_id);
+}
+
+/*
+ * nss_wifi_log_wnm_peer_rx_activity()
+ *	Log NSS WIFI RX Active State Information of Peer.
+ */
+static void nss_wifi_log_wnm_peer_rx_activity(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_wnm_peer_rx_activity_msg *nwpm __maybe_unused = &ncm->msg.wprm;
+	nss_trace("%p: NSS WIFI RX Active State Information of Peer:\n"
+		"WIFI Peer ID: %p\n"
+		"WIFI Number of Entries: %d\n",
+		nwpm, nwpm->peer_id, nwpm->nentries);
+}
+
+/*
+ * nss_wifi_log_wds_extn_peer_cfg_msg()
+ *	Log NSS WIFI WDS Extension Enabled Configuraion Message.
+ */
+static void nss_wifi_log_wds_extn_peer_cfg_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_wds_extn_peer_cfg_msg *nwpm __maybe_unused = &ncm->msg.wpeercfg;
+	nss_trace("%p: NSS WIFI Extension Enabled Configuraion Message:\n"
+		"WIFI Peer MAC Address: %pM\n"
+		"WIFI WDS Flags: %d\n"
+		"WIFI Peer ID: %d\n",
+		nwpm, nwpm->mac_addr, nwpm->wds_flags,
+		nwpm->peer_id);
+}
+
+/*
+ * nss_wifi_log_tx_capture_msg()
+ *	Log NSS WIFI Enable TX Capture Message.
+ */
+static void nss_wifi_log_tx_capture_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_tx_capture_msg *nwpm __maybe_unused = &ncm->msg.tx_capture_msg;
+	nss_trace("%p: NSS WIFI Enable TX Capture Message:\n"
+		"WIFI TX Capture Enable Flag: %d\n",
+		nwpm, nwpm->tx_capture_enable);
+}
+
+/*
+ * nss_wifi_log_always_primary_set_msg()
+ *	Log NSS WIFI Always Set Current Radio Primary Message.
+ */
+static void nss_wifi_log_always_primary_set_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_always_primary_set_msg *nwpm __maybe_unused = &ncm->msg.waps_msg;
+	nss_trace("%p: NSS WIFI Always Set Current Radio Primary Message:\n"
+		"WIFI Always Set Flag: %d\n",
+		nwpm, nwpm->flag);
+}
+
+/*
+ * nss_wifi_log_cmd_msg()
+ *	Log NSS WIFI PDEV Command Message.
+ */
+static void nss_wifi_log_cmd_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_cmd_msg *nwpm __maybe_unused = &ncm->msg.wcmdm;
+	nss_trace("%p: NSS WIFI PDEV Command Message:\n"
+		"WIFI Type of Command: %d\n"
+		"WIFI Value of Command: %d\n",
+		nwpm, nwpm->cmd, nwpm->value);
+}
+
+/*
+ * nss_wifi_log_enable_ol_statsv2_msg()
+ *	Log NSS WIFI Enable Version 2 of TX/RX Stats
+ */
+static void nss_wifi_log_enable_ol_statsv2_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_enable_ol_statsv2 *nwpm __maybe_unused = &ncm->msg.wesh_msg;
+	nss_trace("%p: NSS WIFI Enable Version 2 of TX/RX Stats:\n"
+		"WIFI Enable Version 2 Stats: %d\n",
+		nwpm, nwpm->enable_ol_statsv2);
+}
+
+/*
+ * nss_wifi_log_enable_ol_peer_time_msg()
+ *	Log NSS WIFI Enable Per Peer Stats to Host
+ */
+static void nss_wifi_log_enable_ol_peer_time_msg(struct nss_wifi_msg *ncm)
+{
+	struct nss_wifi_ol_peer_time_msg *nwpm __maybe_unused = &ncm->msg.wopt_msg;
+	int32_t i;
+
+	nss_trace("%p: NSS WIFI Enable Per PEer Stats to Host:\n"
+		"WIFI Number of Peers: %d\n"
+		"WIFI Peed ID: %d\n",
+		nwpm, nwpm->npeers,
+		nwpm->tstats[0].peer_id);
+	/*
+	 * Continuation of the log.
+	 */
+	nss_trace("WIFI TX Timestamp:\n");
+	nss_trace("\tSum of sojourn for each packet:");
+	for (i = 0; i < NSS_WIFI_TX_NUM_TOS_TIDS; i++) {
+		nss_trace("\t\t%d = %x", i, nwpm->tstats[0].sum[i].sum_tx);
+	}
+	nss_trace("\tNumber of MSDU per peer per TID:");
+	for (i = 0; i < NSS_WIFI_TX_NUM_TOS_TIDS; i++) {
+		nss_trace("\t\t%d = %x", i, nwpm->tstats[0].sum[i].sum_msdus);
+	}
+	nss_trace("WIFI Exponential Weighted Average:");
+	for (i = 0; i < NSS_WIFI_TX_NUM_TOS_TIDS; i++) {
+		nss_trace("\t%d = %d", i, nwpm->tstats[0].avg[i]);
+	}
+}
+
+/*
+ * nss_wifi_log_verbose()
+ *	Log message contents.
+ */
+static void nss_wifi_log_verbose(struct nss_wifi_msg *ncm)
+{
+	switch (ncm->cm.type) {
+	case NSS_WIFI_INIT_MSG:
+		nss_wifi_log_init_msg(ncm);
+		break;
+
+	case NSS_WIFI_HTT_INIT_MSG:
+		nss_wifi_log_htt_init_msg(ncm);
+		break;
+
+	case NSS_WIFI_TX_INIT_MSG:
+		nss_wifi_log_tx_init_msg(ncm);
+		break;
+
+	case NSS_WIFI_RAW_SEND_MSG:
+		nss_wifi_log_rawsend_msg(ncm);
+		break;
+
+	case NSS_WIFI_MGMT_SEND_MSG:
+		nss_wifi_log_mgmtsend_msg(ncm);
+		break;
+
+	case NSS_WIFI_WDS_PEER_ADD_MSG:
+		nss_wifi_log_wds_peer_msg(ncm);
+		break;
+
+	case NSS_WIFI_WDS_PEER_DEL_MSG:
+		nss_wifi_log_wds_peer_msg(ncm);
+		break;
+
+	case NSS_WIFI_STOP_MSG:
+		nss_wifi_log_stop_msg(ncm);
+		break;
+
+	case NSS_WIFI_RESET_MSG:
+		nss_wifi_log_reset_msg(ncm);
+		break;
+
+	case NSS_WIFI_PEER_FREELIST_APPEND_MSG:
+		nss_wifi_log_peer_freelist_append_msg(ncm);
+		break;
+
+	case NSS_WIFI_RX_REORDER_ARRAY_FREELIST_APPEND_MSG:
+		nss_wifi_log_rx_reorder_array_freelist_append_msg(ncm);
+		break;
+
+	case NSS_WIFI_MONITOR_FILTER_SET_MSG:
+		nss_wifi_log_set_filter_msg(ncm);
+		break;
+
+	case NSS_WIFI_PEER_BS_STATE_MSG:
+		nss_wifi_log_peer_activity_msg(ncm);
+		break;
+
+	case NSS_WIFI_RX_VOW_EXTSTATS_SET_MSG:
+		nss_wifi_log_rx_vow_extstats_set_msg(ncm);
+		break;
+
+	case NSS_WIFI_PKTLOG_CFG_MSG:
+		nss_wifi_log_pktlog_cfg_msg(ncm);
+		break;
+
+	case NSS_WIFI_ENABLE_PERPKT_TXSTATS_MSG:
+		nss_wifi_log_enable_perpkt_txstats_msg(ncm);
+		break;
+
+	case NSS_WIFI_IGMP_MLD_TOS_OVERRIDE_MSG:
+		nss_wifi_log_override_tos_msg(ncm);
+		break;
+
+	case NSS_WIFI_OL_STATS_CFG_MSG:
+		nss_wifi_log_ol_stats_cfg_msg(ncm);
+		break;
+
+	case NSS_WIFI_TX_QUEUE_CFG_MSG:
+		nss_wifi_log_tx_queue_cfg_msg(ncm);
+		break;
+
+	case NSS_WIFI_TX_MIN_THRESHOLD_CFG_MSG:
+		nss_wifi_log_tx_min_threshold_cfg(ncm);
+		break;
+
+	case NSS_WIFI_DBDC_PROCESS_ENABLE_MSG:
+		nss_wifi_log_dbdc_process_enable_msg(ncm);
+		break;
+
+	case NSS_WIFI_PRIMARY_RADIO_SET_MSG:
+		nss_wifi_log_primary_radio_set_msg(ncm);
+		break;
+
+	case NSS_WIFI_FORCE_CLIENT_MCAST_TRAFFIC_SET_MSG:
+		nss_wifi_log_force_client_mcast_traffic_set_msg(ncm);
+		break;
+
+	case NSS_WIFI_STORE_OTHER_PDEV_STAVAP_MSG:
+		nss_wifi_log_store_other_pdev_stavap_msg(ncm);
+		break;
+
+	case NSS_WIFI_STA_KICKOUT_MSG:
+		nss_wifi_log_sta_kickout_msg(ncm);
+		break;
+
+	case NSS_WIFI_WNM_PEER_RX_ACTIVITY_MSG:
+		nss_wifi_log_wnm_peer_rx_activity(ncm);
+		break;
+
+	case NSS_WIFI_WDS_VENDOR_MSG:
+		nss_wifi_log_wds_extn_peer_cfg_msg(ncm);
+		break;
+
+	case NSS_WIFI_TX_CAPTURE_SET_MSG:
+		nss_wifi_log_tx_capture_msg(ncm);
+		break;
+
+	case NSS_WIFI_ALWAYS_PRIMARY_SET_MSG:
+		nss_wifi_log_always_primary_set_msg(ncm);
+		break;
+
+	case NSS_WIFI_CMD_MSG:
+		nss_wifi_log_cmd_msg(ncm);
+		break;
+
+	case NSS_WIFI_ENABLE_OL_STATSV2_MSG:
+		nss_wifi_log_enable_ol_statsv2_msg(ncm);
+		break;
+
+	case NSS_WIFI_OL_PEER_TIME_MSG:
+		nss_wifi_log_enable_ol_peer_time_msg(ncm);
+		break;
+
+	case NSS_WIFI_FLUSH_HTT_CMD_MSG:
+	case NSS_WIFI_OL_STATS_MSG:
+	case NSS_WIFI_MSDU_TTL_SET_MSG:
+	case NSS_WIFI_PEER_STATS_MSG:
+	case NSS_WIFI_FW_STATS_MSG:
+	case NSS_WIFI_SEND_RRA_MEMORY_REQUEST_MSG:
+	case NSS_WIFI_STATS_MSG:
+	case NSS_WIFI_POST_RECV_MSG:
+	case NSS_WIFI_SEND_PEER_MEMORY_REQUEST_MSG:
+		/*
+		 * No log for these valid messages.
+		 */
+		break;
+
+	default:
+		nss_warning("%p: Invalid message type\n", ncm);
+		break;
+	}
+}
+
+/*
+ * nss_wifi_log_tx_msg()
+ *	Log messages transmitted to FW.
+ */
+void nss_wifi_log_tx_msg(struct nss_wifi_msg *ncm)
+{
+	if (ncm->cm.type >= NSS_WIFI_MAX_MSG) {
+		nss_warning("%p: Invalid message type\n", ncm);
+		return;
+	}
+
+	nss_info("%p: type[%d]:%s\n", ncm, ncm->cm.type, nss_wifi_log_message_types_str[ncm->cm.type]);
+	nss_wifi_log_verbose(ncm);
+}
+
+/*
+ * nss_wifi_log_rx_msg()
+ *	Log messages received from FW.
+ */
+void nss_wifi_log_rx_msg(struct nss_wifi_msg *ncm)
+{
+	if (ncm->cm.response >= NSS_CMN_RESPONSE_LAST) {
+		nss_warning("%p: Invalid response\n", ncm);
+		return;
+	}
+
+	if (ncm->cm.response == NSS_CMN_RESPONSE_NOTIFY || (ncm->cm.response == NSS_CMN_RESPONSE_ACK)) {
+		nss_info("%p: type[%d]:%s, response[%d]:%s\n", ncm, ncm->cm.type,
+			nss_wifi_log_message_types_str[ncm->cm.type],
+			ncm->cm.response, nss_cmn_response_str[ncm->cm.response]);
+		goto verbose;
+	}
+
+	if (ncm->cm.error >= NSS_WIFI_EMSG_MAX) {
+		nss_warning("%p: msg failure - type[%d]:%s, response[%d]:%s, error[%d]:Invalid error\n",
+			ncm, ncm->cm.type, nss_wifi_log_message_types_str[ncm->cm.type],
+			ncm->cm.response, nss_cmn_response_str[ncm->cm.response],
+			ncm->cm.error);
+		goto verbose;
+	}
+
+	nss_info("%p: msg nack - type[%d]:%s, response[%d]:%s, error[%d]:%s\n",
+		ncm, ncm->cm.type, nss_wifi_log_message_types_str[ncm->cm.type],
+		ncm->cm.response, nss_cmn_response_str[ncm->cm.response],
+		ncm->cm.error, nss_wifi_log_error_response_types_str[ncm->cm.error]);
+
+verbose:
+	nss_wifi_log_verbose(ncm);
+}
diff --git a/nss_wifi_log.h b/nss_wifi_log.h
new file mode 100644
index 0000000..c47a62b
--- /dev/null
+++ b/nss_wifi_log.h
@@ -0,0 +1,37 @@
+/*
+ ******************************************************************************
+ * Copyright (c) 2018, The Linux Foundation. All rights reserved.
+ * Permission to use, copy, modify, and/or distribute this software for
+ * any purpose with or without fee is hereby granted, provided that the
+ * above copyright notice and this permission notice appear in all copies.
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
+ * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ * ****************************************************************************
+ */
+
+#ifndef __NSS_WIFI_LOG_H__
+#define __NSS_WIFI_LOG_H__
+
+/*
+ * nss_WIFI_log.h
+ *	NSS WIFI Log Header File
+ */
+
+/*
+ * nss_WIFI_log_tx_msg
+ *	Logs a WIFI message that is sent to the NSS firmware.
+ */
+void nss_wifi_log_tx_msg(struct nss_wifi_msg *ncm);
+
+/*
+ * nss_WIFI_log_rx_msg
+ *	Logs a WIFI message that is received from the NSS firmware.
+ */
+void nss_wifi_log_rx_msg(struct nss_wifi_msg *ncm);
+
+#endif /* __NSS_WIFI_LOG_H__ */