Merge "[qca-nss-drv] Resolved crash observed in 64-bit build"
diff --git a/nss_ipv4.c b/nss_ipv4.c
index a1b8f90..d2ca05f 100644
--- a/nss_ipv4.c
+++ b/nss_ipv4.c
@@ -414,7 +414,6 @@
 	}
 }
 
-
 /*
  * nss_ipv4_conn_cfg_process_callback()
  *	Call back function for the ipv4 connection configure process
@@ -477,8 +476,17 @@
 
 	nirccm = &nim.msg.rule_conn_cfg;
 	nirccm->num_conn = htonl(conn);
-	nirccm->ce_mem = dma_map_single(NULL, (void *)nss_ipv4_ct_info.ce_mem, nss_ipv4_ct_info.ce_table_size, DMA_TO_DEVICE);
-	nirccm->cme_mem = dma_map_single(NULL, (void *)nss_ipv4_ct_info.cme_mem, nss_ipv4_ct_info.cme_table_size, DMA_TO_DEVICE);
+	nirccm->ce_mem = dma_map_single(nss_ctx->dev, (void *)nss_ipv4_ct_info.ce_mem, nss_ipv4_ct_info.ce_table_size, DMA_TO_DEVICE);
+	if (unlikely(dma_mapping_error(nss_ctx->dev, nirccm->ce_mem))) {
+		nss_warning("%p: DMA mapping failed for virtual address = %p", nss_ctx, (void *)nss_ipv4_ct_info.ce_mem);
+		goto fail;
+	}
+
+	nirccm->cme_mem = dma_map_single(nss_ctx->dev, (void *)nss_ipv4_ct_info.cme_mem, nss_ipv4_ct_info.cme_table_size, DMA_TO_DEVICE);
+	if (unlikely(dma_mapping_error(nss_ctx->dev, nirccm->cme_mem))) {
+		nss_warning("%p: DMA mapping failed for virtual address = %p", nss_ctx, (void *)nss_ipv4_ct_info.cme_mem);
+		goto fail;
+	}
 
 	nss_tx_status = nss_ipv4_tx(nss_ctx, &nim);
 	if (nss_tx_status != NSS_TX_SUCCESS) {
diff --git a/nss_ipv6.c b/nss_ipv6.c
index 73eeea9..6aa4df2 100644
--- a/nss_ipv6.c
+++ b/nss_ipv6.c
@@ -486,8 +486,17 @@
 
 	nirccm = &nim.msg.rule_conn_cfg;
 	nirccm->num_conn = htonl(conn);
-	nirccm->ce_mem = (nss_ptr_t)dma_map_single(NULL, (void *)nss_ipv6_ct_info.ce_mem, nss_ipv6_ct_info.ce_table_size, DMA_TO_DEVICE);
-	nirccm->cme_mem = (nss_ptr_t)dma_map_single(NULL, (void *)nss_ipv6_ct_info.cme_mem, nss_ipv6_ct_info.cme_table_size, DMA_TO_DEVICE);
+	nirccm->ce_mem = dma_map_single(nss_ctx->dev, (void *)nss_ipv6_ct_info.ce_mem, nss_ipv6_ct_info.ce_table_size, DMA_TO_DEVICE);
+	if (unlikely(dma_mapping_error(nss_ctx->dev, nirccm->ce_mem))) {
+		nss_warning("%p: DMA mapping failed for virtual address = %p", nss_ctx, (void *)nss_ipv6_ct_info.ce_mem);
+		goto fail;
+	}
+
+	nirccm->cme_mem = dma_map_single(nss_ctx->dev, (void *)nss_ipv6_ct_info.cme_mem, nss_ipv6_ct_info.cme_table_size, DMA_TO_DEVICE);
+	if (unlikely(dma_mapping_error(nss_ctx->dev, nirccm->cme_mem))) {
+		nss_warning("%p: DMA mapping failed for virtual address = %p", nss_ctx, (void *)nss_ipv6_ct_info.cme_mem);
+		goto fail;
+	}
 
 	nss_tx_status = nss_ipv6_tx(nss_ctx, &nim);
 	if (nss_tx_status != NSS_TX_SUCCESS) {