优化LYNQ_SMS接口以及添加对应测试demo

Change-Id: Ic3e4f4c86bd6eaa14b8ea81fbc9780032e54f118
diff --git a/mbtk/lynq_lib/src/lynq_sms.c b/mbtk/lynq_lib/src/lynq_sms.c
index c7fa721..1d28ce9 100755
--- a/mbtk/lynq_lib/src/lynq_sms.c
+++ b/mbtk/lynq_lib/src/lynq_sms.c
@@ -19,26 +19,60 @@
 static mbtk_info_handle_t* sms_info_handle = NULL;
 static char sms_center_address[128] = {0};
 
+typedef struct
+{
+    QSER_SMS_RxMsgHandlerFunc_t handlerPtr;
+    void* contextPtr;
+} lynq_sms_cb_func;
+
+static lynq_sms_cb_func lynq_sms_func_cb_handle;
+
+sms_client_handle_type g_sms_val = -1;
+
 
 void lynq_sms_state_change_cb(const void* data, int data_len)
 {
     LOGV("sms_state_change_cb()----------start\n");
     uint8 *ptr = (uint8*)data;
-        printf("3sms_state_change_cb() : %s\n", ptr);
+        //printf("3sms_state_change_cb() : %s\n", ptr);
+
+    if (!strncmp("+CMT:", ptr, 5))//丢弃无用消息
+        return ;
 
     struct SMS_Struct s = PDUDecoding(ptr);
+    /*
     printf("服务中心地址: %s\n", s.SCA);
     printf("发送方地址: %s\n", s.OA);
     printf("服务中心时间戳: %s\n", s.SCTS);
     printf("消息内容: %s\n", s.UD);
     printf("数据编码方案: %s\n", DSC_to_msg(s.DCS));
+    */
+    QSER_SMS_Msg_t* tmp_data = NULL;
+
+    tmp_data = (QSER_SMS_Msg_t*)malloc(sizeof(QSER_SMS_Msg_t));
+    memset(tmp_data,0x00, sizeof(QSER_SMS_Msg_t));
+
+    tmp_data->format = s.DCS;
+    //printf("t数据编码方案: %d\n", tmp_data->format);
+    memcpy(tmp_data->src_addr, s.OA, strlen(s.OA));
+    //printf("t发送方地址: %s\n", tmp_data->src_addr);
+    memcpy(tmp_data->timestamp, s.SCTS, strlen(s.SCTS));
+    //printf("t服务中心时间戳: %s\n", tmp_data->timestamp);
+    tmp_data->sms_data_len = strlen(s.UD);
+    //printf("t消息内容长度: %d\n", tmp_data->sms_data_len);
+    memcpy(tmp_data->sms_data, s.UD, strlen(s.UD));
+    //printf("t消息内容: %s\n", tmp_data->sms_data);
+
+    lynq_sms_func_cb_handle.handlerPtr(tmp_data, NULL);
+
+    free(tmp_data);
+    
 }
 
 
 int qser_sms_client_init(sms_client_handle_type *ph_sms)//out
 {
-    UNUSED(ph_sms);
-    int ret = SMS_OK;
+    //UNUSED(ph_sms);
 
     if(sms_info_handle == NULL)
     {
@@ -46,46 +80,64 @@
         if(sms_info_handle)
         {
             printf("creat sms_info_handle is success\n");
+            *ph_sms = sms_info_handle->client_fd;
+            g_sms_val = sms_info_handle->client_fd;
         }
         else
         {
             printf("creat sms_info_handle is fail\n");
-            ret = SMS_UNKNONW;
+            return -1;
         }
     }
 
-    return ret;
+    return 0;
 }
 
 int qser_sms_client_deinit(sms_client_handle_type h_sms)//in
 {
-    UNUSED(h_sms);
-    int ret = SMS_OK;
+    //UNUSED(h_sms);
+    if (h_sms != g_sms_val || g_sms_val == -1)
+    {
+        printf("handle NULL\n");
+        return -1;
+    }
+
 
     if(sms_info_handle)
     {
-        ret = mbtk_info_handle_free(&sms_info_handle);
+        mbtk_info_handle_free(&sms_info_handle);
+        printf("deinit sms_info_handle is succuess\n");
     }
     else
     {
         printf("deinit sms_info_handle is fail\n");
-        ret = SMS_UNKNONW;
+        return -1;
     }
 
-    return ret;
+    return 0;
 }
 
 int qser_sms_send_sms(sms_client_handle_type h_sms, QSER_sms_info_t *pt_sms_info)//in in 发送短信的内容、目的号码
 {
-    UNUSED(h_sms);
+    //UNUSED(h_sms);
     //UNUSED(pt_sms_info);
-    int ret = SMS_OK;
-    uint8_t *phone_num = NULL, *data = NULL;
+    if (h_sms != g_sms_val || g_sms_val == -1)
+    {
+        printf("handle NULL\n");
+        return -1;
+    }
+
+
+    if (pt_sms_info == NULL)
+    {
+        printf("QSER_sms_info_t NULL\n");
+        return -1;
+    }
 
     if(sms_info_handle == NULL)
     {
         printf("qser_sms_send_sms sms_info_handle NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     //QSER_sms_info_t get_sms_info;
@@ -102,6 +154,8 @@
     //get_sms_info.user_data_head = pt_sms_info->user_data_head;//长短信用户头部信息
     //get_sms_info.user_data_head_valid = pt_sms_info->user_data_head_valid;//是否是长短信
 
+    uint8_t *phone_num = NULL, *data = NULL;
+
     char cmgs[MSM_NUMBER_MAX] = {0};
     char resp[RES_NUM_MIN] = {0};
     char pdu_data[512] = {0};
@@ -122,33 +176,28 @@
     else if (pt_sms_info->format == 2)//USC2
         mode = 0;
     else
-        return SMS_ERR;
+        return -1;
 
     if(data == NULL)
     {
         printf("qser_sms_send_sms data NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     if(phone_num == NULL)
     {
         printf("qser_sms_send_sms phone_num NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
-    if((pt_sms_info->sms_data_len > 512) || (pt_sms_info->sms_data_len == 0))
+
+    if(strlen(data) > 512 || strlen(data) == 0 || strlen(phone_num) == 0)
     {
-        if(strlen(data) > 512 || strlen(data) == 0 || strlen(phone_num) == 0)
-        {
-            printf("strlen(telephony_num):%d\n", strlen(phone_num));
-            printf("strlen(msg):%d\n", strlen(data));
-            return SMS_ERR;
-        }
-        printf("strlen(msg_len):%d\n", pt_sms_info->sms_data_len);
-        return SMS_UNKNONW;//可能data_len没有赋值
+        printf("strlen(telephony_num):%d\n", strlen(phone_num));
+        printf("strlen(msg):%d\n", strlen(data));
+        return -1;
     }
 
-
     if (mode == 0)// PDU
     {
 #if 1
@@ -204,7 +253,7 @@
         if(err)
         {
             printf("Error : %d\n", err);
-            ret = SMS_ERR;
+            return -1;
         }
         else
         {
@@ -232,7 +281,7 @@
         if(err)
         {
             printf("Error : %d\n", err);
-            ret = SMS_ERR;
+            return -1;
         }
         else
         {
@@ -242,56 +291,65 @@
     else
     {
         printf("Error : mode\n");
-        ret = SMS_ERR;
+        return -1;
     }
-    return ret;
+
+    return 0;
 }
 
 //注册接收新短信
 int qser_sms_addrxmsghandler(QSER_SMS_RxMsgHandlerFunc_t handlerPtr, void* contextPtr)//in sms电话状态回调函数 in 主要是获取 上报 的内容
 {
-    UNUSED(handlerPtr);
-    UNUSED(contextPtr);
-    int ret = SMS_OK;
+    //UNUSED(handlerPtr);
+    //UNUSED(contextPtr);
 
     if(sms_info_handle == NULL)
     {
         printf("qser_sms_addrxmsghandler sms_info_handle NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     int err = mbtk_sms_cnmi_set(sms_info_handle);
     if(err)
     {
         printf("set cnmi fail\n");
-        ret = SMS_ERR;
+        return -1;
     }
 
+    lynq_sms_func_cb_handle.handlerPtr = handlerPtr;
+    lynq_sms_func_cb_handle.contextPtr = contextPtr;
+
     mbtk_sms_state_change_cb_reg(sms_info_handle, lynq_sms_state_change_cb);
 
-    return ret;
+    return 0;
 }
 
 //删除短信
 int qser_sms_deletefromstorage(sms_client_handle_type h_sms, QSER_sms_storage_info_t *pt_sms_storage)//in in 删除短信的信息
 {
-    UNUSED(h_sms);
+    //UNUSED(h_sms);
     //UNUSED(pt_sms_storage);
     char cmgd[128] = {0};
     int err = 0;
     int id_x = -1;
-    int ret = SMS_OK;
 
-    if(sms_info_handle == NULL)
+    if (h_sms != g_sms_val || g_sms_val == -1)
     {
-        printf("qser_sms_deletefromstorage sms_info_handle NULL\n");
-        return SMS_ERR;
+        printf("handle NULL\n");
+        return -1;
     }
 
+
     if(pt_sms_storage == NULL)
     {
         printf("qser_sms_deletefromstorage pt_sms_storage NULL\n");
-        return SMS_ERR;
+        return -1;
+    }
+
+    if(sms_info_handle == NULL)
+    {
+        printf("qser_sms_deletefromstorage sms_info_handle NULL\n");
+        return -1;
     }
 
     id_x = pt_sms_storage->storage_idx;//获取idx的值
@@ -311,38 +369,50 @@
     if(err)
     {
         printf("qser_sms_deletefromstorage Error : %d\n", err);
-        ret = SMS_ERR;
+        return -1;
     }
     else
     {
         printf("qser_sms_deletefromstorage set success\n");
     }
 
-    return ret;
+    return 0;
 }
 
 //获取短信中心号码
 int qser_sms_getsmscenteraddress( sms_client_handle_type h_sms,QSER_sms_service_center_cfg_t *set_sca_cfg)//in out
 {
-    UNUSED(h_sms);
+    //UNUSED(h_sms);
     //UNUSED(set_sca_cfg);
     char sms_center_addree[254] = {0};
     int len_t;
     char *p1, *p2 ,*substr;
 
-    int ret = SMS_OK;
+    if (h_sms != g_sms_val || g_sms_val == -1)
+    {
+        printf("handle NULL\n");
+        return -1;
+    }
+
+
+    if (set_sca_cfg == NULL)
+    {
+        printf("QSER_sms_service_center_cfg_t NULL\n");
+        return -1;
+    }
+
 
     if(sms_info_handle == NULL)
     {
         printf("qser_sms_getsmscenteraddress sms_info_handle NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     int err = mbtk_sms_csca_get(sms_info_handle, sms_center_addree);
     if(sms_center_addree[0] == '\0')
     {
         printf("qser_sms_getsmscenteraddress Error : %d\n", err);
-        return SMS_ERR;
+        return -1;
     }
     else
     {
@@ -365,31 +435,37 @@
         else
         {
             printf("未找到双引号内的字符串\n"); // 输出结果
-            ret = SMS_ERR;
+            return -1;
         }
     }
 
-    return ret;
+    return 0;
 }
 
 //设置短信中心号码
 int qser_sms_setsmscenteraddress( sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *get_sca_cfg)//in in
 {
-    UNUSED(h_sms);
+    //UNUSED(h_sms);
     //UNUSED(get_sca_cfg);
     char *destNum = NULL;
-    int ret = SMS_OK;
+
+    if (h_sms != g_sms_val || g_sms_val == -1)
+    {
+        printf("handle NULL\n");
+        return -1;
+    }
+
 
     if(sms_info_handle == NULL)
     {
         printf("qser_sms_setsmscenteraddress sms_info_handle NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     if(get_sca_cfg == NULL)
     {
         printf("qser_sms_setsmscenteraddress get_sca_cfg NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     destNum = get_sca_cfg->service_center_addr;
@@ -401,14 +477,14 @@
     if (destNum == NULL)
     {
         printf("qser_sms_setsmscenteraddress destNum NULL\n");
-        return SMS_ERR;
+        return -1;
     }
 
     int err = mbtk_sms_csca_set(sms_info_handle, destNum);
     if(err)
     {
         printf("Error : %d\n", err);
-        ret = SMS_ERR;
+        return -1;
     }
     else
     {
@@ -418,6 +494,6 @@
         printf("qser_sms_setsmscenteraddress success\n");
     }
 
-    return ret;
+    return 0;
 }
 
diff --git a/mbtk/test/lynq_qser_sms_test.c b/mbtk/test/lynq_qser_sms_test.c
index 9b8dfac..143ffac 100755
--- a/mbtk/test/lynq_qser_sms_test.c
+++ b/mbtk/test/lynq_qser_sms_test.c
@@ -36,6 +36,231 @@
 #include "lynq_qser_sms.h"

 

 

+#if 0

+#include <stdlib.h>

+#include <stdio.h>

+#include <string.h>

+#include <sys/types.h>

+#include <pthread.h>

+#include <unistd.h>

+#include <dlfcn.h>

+#include <stdint.h>

+#include <ctype.h>

+

+//#include"lynq-qser-sms-demo.h"

+

+

+#define SMS_BUF  64

+#define MSG_BUF  100

+

+int flag_init = 0;

+

+typedef uint32_t sim_client_handle_type;

+sms_client_handle_type  ph_sms = 2022;

+sms_client_handle_type  h_sms = 2022;

+

+

+int (*qser_sms_client_init)(sms_client_handle_type  *ph_sms);

+int (*qser_sms_client_deinit)(sms_client_handle_type h_sms);

+int (*qser_sms_send_sms)(sms_client_handle_type h_sms, QSER_sms_info_t *pt_sms_info);

+int (*qser_sms_addrxmsghandler)(QSER_SMS_RxMsgHandlerFunc_t handlerPtr, void* contextPtr);

+int (*qser_sms_deletefromstorage)(sms_client_handle_type  h_sms, QSER_sms_storage_info_t  *pt_sms_storage);

+int (*qser_sms_getsmscenteraddress)(sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *set_sca_cfg);

+int (*qser_sms_setsmscenteraddress)(sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *get_sca_cfg);

+

+void qser_sms_handler(QSER_SMS_MsgRef msgRef, void* contextPtr) {

+    printf("[%s-%d] sms handler, msgRef->sms_data = %s\n", __FUNCTION__, __LINE__, msgRef->sms_data);

+}

+

+bool isNumeric(char *phnum) {

+    int length = strlen(phnum);

+    

+    if (length == 0) {

+        return false;

+    }

+    

+    if (phnum[0] != '+' && (phnum[0] < '0' || phnum[0] > '9')) {

+        return false;

+    }

+    

+    if (phnum[0] == '+' && length < 3) {

+        return false;

+    }

+    

+    for (int i = 1; i < length; i++) {

+        if (phnum[i] < '0' || phnum[i] > '9') {

+            return false;

+        }

+    }

+    

+    return true;

+}

+

+//以下示例默认为所有API 执行都成功的情况下,依次执行后续API

+int main(int argc, char *argv[])

+{

+    int ret    = 0;

+    //char phnum[SMS_BUF]={0};

+

+    //const char *lynq_libpath_sms = "/lib/liblynq-qser-sms.so";

+    const char *lynq_libpath_sms = "/lib/liblynq_lib.so";

+    void *dlHandle_sms = dlopen(lynq_libpath_sms, RTLD_NOW);

+    

+    if (dlHandle_sms == NULL) 

+    {

+        printf("dlopen dlHandle_sms failed: %s\n", dlerror());

+        exit(EXIT_FAILURE);

+    }

+

+    if(argc != 2 || !isNumeric(argv[1]))

+    {

+        printf("[%s][%d] please input correct phnum\n",__FUNCTION__,__LINE__);

+        exit(1);

+    }

+    

+    qser_sms_client_init = (int(*)(sms_client_handle_type  *ph_sms))dlsym(dlHandle_sms,"qser_sms_client_init");

+    if(NULL != qser_sms_client_init)

+    {

+        ret = qser_sms_client_init(&ph_sms);

+        if(ret == 0)

+        {

+            printf("Run qser_sms_client_init\n");

+        }else{

+            printf("qser_sim_client_init error\n");

+        }

+     }else{

+            printf("qser_sim_client_init dlsym error\n");

+     }

+

+    sleep(2);

+

+    qser_sms_addrxmsghandler = (int(*)(QSER_SMS_RxMsgHandlerFunc_t handlerPtr, void* contextPtr))dlsym(dlHandle_sms,"qser_sms_addrxmsghandler");

+

+    if(NULL != qser_sms_addrxmsghandler)

+    {

+        ret = qser_sms_addrxmsghandler(qser_sms_handler, NULL);

+        if(ret == 0)

+    {

+        printf("qser_sms_addrxmsghandler success");

+    }else{

+        printf("qser_sms_addrxmsghandler error, ret = %d\n", ret);

+    }

+    }else{

+        printf("qser_sms_addrxmsghandler dlsym error\n");

+    }

+    

+    QSER_sms_service_center_cfg_t get_sca_cfg;

+    qser_sms_getsmscenteraddress = (int (*)(sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *get_sca_cfg))dlsym(dlHandle_sms,"qser_sms_getsmscenteraddress");

+    if(NULL != qser_sms_getsmscenteraddress)

+    {

+        ret = qser_sms_getsmscenteraddress(h_sms, &get_sca_cfg);

+        if(ret == 0)

+        {

+            printf("get smsc success,service_center_addr = %s\n",get_sca_cfg.service_center_addr);

+        }else{

+            printf("get smsc error, ret = %d\n", ret);

+        }

+    }else{

+        printf("qser_sms_getsmscenteraddress dlsym error\n");

+    }

+    sleep(1);

+    QSER_sms_service_center_cfg_t set_sca_cfg;

+    strncpy(set_sca_cfg.service_center_addr, "+8613800280500", 14);//smsc +8613800280500成都号码      +8613800230500黑龙江

+    qser_sms_setsmscenteraddress = (int (*)(sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *set_sca_cfg))dlsym(dlHandle_sms,"qser_sms_setsmscenteraddress");

+    if(NULL != qser_sms_setsmscenteraddress)

+    {

+        ret = qser_sms_setsmscenteraddress(h_sms, &set_sca_cfg);

+        if(ret == 0)

+        {

+            printf("set smsc success");

+        }else{

+            printf("set smsc error, ret = %d\n", ret);

+        }

+    }else{

+        printf("qser_sms_setsmscenteraddress dlsym error\n");

+    }

+

+    //再次查询是否设置成功

+    sleep(1);

+    qser_sms_getsmscenteraddress = (int (*)(sms_client_handle_type h_sms, QSER_sms_service_center_cfg_t *get_sca_cfg))dlsym(dlHandle_sms,"qser_sms_getsmscenteraddress");

+    if(NULL != qser_sms_getsmscenteraddress)

+    {

+        ret = qser_sms_getsmscenteraddress(h_sms, &get_sca_cfg);

+        if(ret == 0)

+        {

+            printf("get smsc success,service_center_addr = %s\n",get_sca_cfg.service_center_addr);

+        }else{

+            printf("get smsc error, ret = %d\n", ret);

+        }

+    }else{

+        printf("qser_sms_getsmscenteraddress dlsym error\n");

+    }

+

+

+    //test 7bit

+    //char telephony_num[SMS_BUF] = {};

+    char msg[MSG_BUF] = {};

+    QSER_sms_info_t  pt_sms_info;

+    //sprintf(telephony_num,"18981904623");//请用户务必替换此号码,随意向运营商发短消息极有可能被封号。

+    sprintf(msg,"hello");

+    strncpy(pt_sms_info.src_addr, argv[1], SMS_BUF);

+    strncpy(pt_sms_info.sms_data, msg, MSG_BUF);

+    pt_sms_info.format = QSER_SMS_7BIT;

+  //  printf("[%s,%d]  src_addr=%s, telephony_num = %s\n",__FUNCTION__,__LINE__, pt_sms_info.src_addr, telephony_num);

+    printf("[%s,%d]  sms_data=%s, msg = %s\n",__FUNCTION__,__LINE__, pt_sms_info.sms_data, msg);

+

+    sleep(120);

+

+    //test ucs2

+    //char telephony_num[SMS_BUF] = {};

+    char msg[MSG_BUF] = {};

+    QSER_sms_info_t  pt_sms_info;

+    //sprintf(telephony_num,"18981904623");//请用户务必替换此号码,随意向运营商发短消息极有可能被封号。

+    sprintf(msg,"你好吗");

+    strncpy(pt_sms_info.src_addr, argv[1], SMS_BUF);

+    strncpy(pt_sms_info.sms_data, msg, MSG_BUF);

+    pt_sms_info.format = QSER_SMS_UCS2;

+    //  printf("[%s,%d]  src_addr=%s, telephony_num = %s\n",__FUNCTION__,__LINE__, pt_sms_info.src_addr, telephony_num);

+    printf("[%s,%d]  sms_data=%s, msg = %s\n",__FUNCTION__,__LINE__, pt_sms_info.sms_data, msg);

+

+    qser_sms_send_sms = (int (*)(sms_client_handle_type h_sms, QSER_sms_info_t *pt_sms_info))dlsym(dlHandle_sms,"qser_sms_send_sms");

+    if(NULL != qser_sms_send_sms)

+    {

+        ret = qser_sms_send_sms(h_sms, &pt_sms_info);

+        if(ret == 0)

+        {

+            printf("send sms success");

+        }else{

+            printf("send sms error, ret = %d\n", ret);

+        }

+    }else{

+        printf("qser_sms_send_sms dlsym error\n");

+    }

+

+    sleep(120);//在此期间向模组发送短消息,即可触发“接受新短消息事件”。

+    qser_sms_client_deinit = (int (*)(sms_client_handle_type h_sms))dlsym(dlHandle_sms,"qser_sms_client_deinit");

+    if(NULL != qser_sms_client_deinit)

+    {

+        ret = qser_sms_client_deinit(h_sms);

+        if(ret == 0)

+        {

+            printf("sms deinit success");

+        }else{

+            printf("sms deinit error, ret = %d\n", ret);

+        }

+    }else{

+        printf("qser_sms_client_deinit dlsym error\n");

+    }

+    

+}

+

+#else

+

+void qser_sms_handler(QSER_SMS_MsgRef msgRef, void* contextPtr) {

+    printf("[%s-%d] sms handler, msgRef->sms_data = %s\n", __FUNCTION__, __LINE__, msgRef->sms_data);

+}

+

+

 int main(int argc, char *argv[])

 {

     char operator[10];

@@ -43,6 +268,7 @@
     char phonenumter[20] ={0};

     int opt;

     int ret, uToken; 

+    sms_client_handle_type handle = -1;

     QSER_sms_info_t test_sms_info;

     QSER_sms_service_center_cfg_t test_sca_cfg;

     QSER_sms_storage_info_t test_sms_storage;

@@ -70,8 +296,18 @@
             printf("main exit\n");

             return 0;

         case 1:

-            qser_sms_client_init(NULL);

-            break;

+            {

+                ret = qser_sms_client_init(&handle);

+                if(ret == 0)

+                {

+                    printf("Run qser_sms_client_init\n");

+                }else{

+                    printf("qser_sim_client_init error\n");

+                }

+                sleep(2);

+                //printf("test>>: handle = %d\n",handle);

+                break;

+            }

         case 2:

             {

                 memset(&test_sms_info, 0x00, sizeof(QSER_sms_info_t));

@@ -80,14 +316,14 @@
                 int len = strlen(tmp);

                 int num_len = strlen(num);

                 test_sms_info.format = 0;

-                test_sms_info.sms_data_len = len;

-                memcpy(test_sms_info.sms_data, tmp, test_sms_info.sms_data_len);

+                //test_sms_info.sms_data_len = len;

+                memcpy(test_sms_info.sms_data, tmp, len);

                 memcpy(test_sms_info.src_addr, num, num_len);

-                qser_sms_send_sms(NULL, &test_sms_info);

+                qser_sms_send_sms(handle, &test_sms_info);

                 break;

             }

         case 3:

-            qser_sms_addrxmsghandler(NULL, NULL);

+            qser_sms_addrxmsghandler(qser_sms_handler, NULL);

             break;

         case 4:

             {

@@ -97,11 +333,11 @@
                 int len = strlen(tmp);

                 int num_len = strlen(num);

                 test_sms_info.format = 2;

-                test_sms_info.sms_data_len = len;

-                memcpy(test_sms_info.sms_data, tmp, test_sms_info.sms_data_len);

+                //test_sms_info.sms_data_len = len;

+                memcpy(test_sms_info.sms_data, tmp, len);

                 memcpy(test_sms_info.src_addr, num, num_len);

 

-                qser_sms_send_sms(NULL, &test_sms_info);

+                qser_sms_send_sms(handle, &test_sms_info);

                 break;

             }

        //     printf("please input volume (0~100): \n");

@@ -121,13 +357,13 @@
             {

                 memset(&test_sms_storage, 0x00, sizeof(QSER_sms_storage_info_t));

                 test_sms_storage.storage_idx = 1;

-                qser_sms_deletefromstorage(NULL, &test_sms_storage);

+                qser_sms_deletefromstorage(handle, &test_sms_storage);

                 break;

             }

         case 7:

             {

                 memset(&test_sca_cfg, 0x00, sizeof(QSER_sms_service_center_cfg_t));

-                ret = qser_sms_getsmscenteraddress(NULL,&test_sca_cfg);

+                ret = qser_sms_getsmscenteraddress(handle,&test_sca_cfg);

                 if(!ret)

                     printf("get_smsc:%s\n", test_sca_cfg.service_center_addr);

                 break;

@@ -145,11 +381,11 @@
                 int len = strlen(num);

                 memcpy(test_sca_cfg.service_center_addr, num, len);

 

-                ret= qser_sms_setsmscenteraddress(NULL, &test_sca_cfg);

+                ret= qser_sms_setsmscenteraddress(handle, &test_sca_cfg);

                 break;

             }

         case 9:

-            qser_sms_client_deinit(NULL);

+            qser_sms_client_deinit(handle);

             break;

         default:

             break;

@@ -158,3 +394,8 @@
 

     return 0;

 }

+

+#endif

+

+

+