From a300adf15342aa4d3b030698d40d61edb6272ea0 Mon Sep 17 00:00:00 2001
From: fujuntang <fujuntang@smartai.com>
Date: 星期二, 07 九月 2021 11:51:20 +0800
Subject: [PATCH] resize the buf allocation as dynamic allocate.

---
 src/bh_api.cpp |   43 +++++++++++++++++++++++++++++++++++++++----
 1 files changed, 39 insertions(+), 4 deletions(-)

diff --git a/src/bh_api.cpp b/src/bh_api.cpp
index 4a3b7a8..d773369 100644
--- a/src/bh_api.cpp
+++ b/src/bh_api.cpp
@@ -1042,8 +1042,8 @@
   int key;
   int size;
   int sec, nsec;
-  char topics_buf[MAX_STR_LEN] = { 0x00 };
-  char data_buf[MAX_STR_LEN * 3] = { 0x00 }; 
+  char *topics_buf = NULL;
+  char *data_buf = NULL; 
 
   struct _ReadSubReply
   {
@@ -1091,11 +1091,43 @@
     if (len > size) {
       len = size;
     }
-    strncpy(topics_buf, (char *)buf, len > (sizeof(topics_buf) - 1) ? (sizeof(topics_buf) - 1) : len);
+    
+    topics_buf = (char *)malloc(len + 10);
+    if (topics_buf == NULL) {
+      
+      rv = EBUS_NO_MEM;
+      memset(errString, 0x00, sizeof(errString));
+      strncpy(errString, bus_strerror(rv), sizeof(errString));
+      
+      logger->error("in BHRequest: Out of memory!\n");
+      
+      pthread_mutex_unlock(&mutex);
+
+      return false;
+    }
+    memset(topics_buf, 0x00, len + 10);
+    
+    strncpy(topics_buf, (char *)buf, len);
     
     if (len < size) {
-      len = strlen(topics_buf) + 1;
+      
+      data_buf = (char *)malloc(size - len + 10);
+      if (data_buf == NULL) {
+        
+        rv = EBUS_NO_MEM;
+        memset(errString, 0x00, sizeof(errString));
+        strncpy(errString, bus_strerror(rv), sizeof(errString));
+        
+        logger->error("in BHRequest: Out of memory!\n");
+        
+        free(topics_buf);
+        pthread_mutex_unlock(&mutex);
 
+        return false;
+      }
+      memset(data_buf, 0x00, size - len + 10);
+
+      len = strlen(topics_buf) + 1;
       strncpy(data_buf, (char *)buf + len, size - len);
     }
 
@@ -1114,6 +1146,9 @@
       *proc_id = malloc(*proc_id_len);
       memcpy(*proc_id, rsr.proc_id.data(), *proc_id_len);
     }
+    
+    free(topics_buf);
+    free(data_buf);
 
     ::bhome_msg::MsgPublish Mp; 
     Mp.set_topic(rsr.topic);

--
Gitblit v1.8.0