2040 lines
62 KiB
C
2040 lines
62 KiB
C
|
#include <stdio.h>
|
|||
|
#include <stdlib.h>
|
|||
|
#include <string.h>
|
|||
|
#include <unistd.h>
|
|||
|
#include <sys/time.h>
|
|||
|
#include <time.h>
|
|||
|
#include <uv.h>
|
|||
|
#include <dbus/dbus.h>
|
|||
|
#include <readline/readline.h>
|
|||
|
#include <uthash/utstring.h>
|
|||
|
|
|||
|
#include "log.h"
|
|||
|
#include "libuv_dbus.h"
|
|||
|
#include "crypto.h"
|
|||
|
#include "json_struct.h"
|
|||
|
#include "config_engine.h"
|
|||
|
#include "ota.h"
|
|||
|
#include "skins.h"
|
|||
|
#include "assistant.h"
|
|||
|
#include "inet_api.h"
|
|||
|
#include "skins_res.h"
|
|||
|
#include "server_addr.h"
|
|||
|
|
|||
|
static MOD_INFO_TABLE g_ModInfo;
|
|||
|
static uv_timer_t g_tmTest;
|
|||
|
static uv_barrier_t g_tmSync;
|
|||
|
static uv_loop_t* pUserLoop = NULL;
|
|||
|
static int g_isExitLoop = 0;
|
|||
|
|
|||
|
static void test_task_new(uv_thread_cb pCallback, void* pParams);
|
|||
|
|
|||
|
static void OnCfgMsgCb(DBUS_CMD cmd, PCFG_ITEM pMsg, int err)
|
|||
|
{
|
|||
|
fprintf(stdout, "Cmd = %d, Cfg = %s\n", cmd, pMsg->pKeyName);
|
|||
|
|
|||
|
if(err != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Cmd %d Error: %d\n", cmd, err);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
switch(cmd)
|
|||
|
{
|
|||
|
case CMD_CFG_GET_RSP:
|
|||
|
CfgItemPrint("Add Configure: ", pMsg);
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __dBusDeameonCb(MODULE_NAME modName, int status)
|
|||
|
{
|
|||
|
#if 1
|
|||
|
if(status)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Daemon(%d) Msg: [%s]\n", modName, status == 0 ? "Connect" : "Disconnect");
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Info, "Daemon(%d) Msg: [%s]\n", modName, status == 0 ? "Connect" : "Disconnect");
|
|||
|
}
|
|||
|
#endif
|
|||
|
if(modName == MODULE_OTA && status == 0)
|
|||
|
{
|
|||
|
int ret = DBusSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_SYSTEM_STANDBY, "{\"status\" : 0}");
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send Standby Command: %d\n", ret);
|
|||
|
}
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Set Exit Loop\n");
|
|||
|
g_isExitLoop = TRUE;
|
|||
|
}
|
|||
|
|
|||
|
static void KeyEventCb(uint16_t uType, uint16_t uKey, int32_t iValue)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Info, "type = %u, code = %u, value = %u\n", uType, uKey, iValue);
|
|||
|
}
|
|||
|
|
|||
|
static void __uvThreadOTA(void *pParams)
|
|||
|
{
|
|||
|
OTA_DATA_INFO otaInfo;
|
|||
|
POTA_DATA_INFO pInfo = NULL;
|
|||
|
int ret;
|
|||
|
int version = (int)(intptr_t)pParams;
|
|||
|
|
|||
|
memset(&otaInfo, 0, sizeof(OTA_DATA_INFO));
|
|||
|
|
|||
|
if(version == 130)
|
|||
|
{
|
|||
|
otaInfo.version = 132;
|
|||
|
strcpy(otaInfo.otaFileInfo.url, "http://10.241.0.70/tina/tina_r16_ota_132.tar.gz");
|
|||
|
strcpy(otaInfo.otaFileInfo.md5, "3bda58a2eb4e90fbb35b0d33db44cf57");
|
|||
|
otaInfo.otaFileInfo.size = 22966488;
|
|||
|
}
|
|||
|
else if(version == 132)
|
|||
|
{
|
|||
|
otaInfo.version = 133;
|
|||
|
strcpy(otaInfo.otaFileInfo.url, "http://10.241.0.70/tina/tina_r16_ota_133.tar.gz");
|
|||
|
strcpy(otaInfo.otaFileInfo.md5, "c4085cb33d6dbd5ae5fdae948365023c");
|
|||
|
otaInfo.otaFileInfo.size = 22966524;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
otaInfo.version = 4;
|
|||
|
strcpy(otaInfo.otaFileInfo.url, "http://api.multimedia.netease.com/imgtest/ota/tina_r16_ota_133.tar.gz");
|
|||
|
strcpy(otaInfo.otaFileInfo.md5, "c4085cb33d6dbd5ae5fdae948365023c");
|
|||
|
otaInfo.otaFileInfo.size = 22963814;
|
|||
|
}
|
|||
|
|
|||
|
otaInfo.otaCmd = OTA_CMD_DOWNLOAD;
|
|||
|
otaInfo.otaMode = OTA_MODE_FORCE_NOW;
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_OTA_NOTIFY,
|
|||
|
JSON_ENGINE_OTA_REQ,
|
|||
|
&otaInfo, TRUE);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send OTA Command: OTA_CMD_DOWNLOAD --> %d\n", ret);
|
|||
|
}
|
|||
|
|
|||
|
#if 0
|
|||
|
static void __radomAlarmItem(PASSISTANT_ITEM_INFO pInfo)
|
|||
|
{
|
|||
|
static unsigned int alarmId = 0;
|
|||
|
time_t tmVal = time(NULL);
|
|||
|
struct tm *pTmNow = localtime(&tmVal);
|
|||
|
|
|||
|
if(pInfo == NULL)
|
|||
|
{
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
memset(pInfo, 0, sizeof(ALARM_ITEM_INFO));
|
|||
|
|
|||
|
pInfo->alarmId = __sync_fetch_and_add(&alarmId, 1);
|
|||
|
pInfo->itemType = (random() % 2 == 0) ? ALARM_TYPE_REMAIND : ALARM_TYPE_CLOCK;
|
|||
|
pInfo->priority = random() % 10;
|
|||
|
pInfo->repeatMode = random() % (REPEAT_MODE_EVERY_YEAR_DAY + 1);
|
|||
|
|
|||
|
pTmNow->tm_hour = random() % 24;
|
|||
|
pTmNow->tm_min = random() % 60;
|
|||
|
|
|||
|
//strftime(pInfo->strDateTime, MAX_DT_LEN, "%Y-%m-%d %H:%M", pTmNow);
|
|||
|
sprintf(pInfo->strTips, "TTS %llu", pInfo->itemId);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
static PDBUS_MSG_PACK DBusOnMessage(uv_loop_t* pLoop, DBusConnection* pConn, PDBUS_MSG_PACK pMsg)
|
|||
|
{
|
|||
|
int i, ret, err;
|
|||
|
uint32_t tm = LIBUV_CURRENT_TIME_US();
|
|||
|
PCFG_API_RSP pRsp = NULL;
|
|||
|
POTA_RSP_STATUS pOTAStatus = NULL;
|
|||
|
//PALARM_RSP_STATUS pAlarmStatus = NULL;
|
|||
|
//PALARM_SYNC_INFO pSyncInfo = NULL;
|
|||
|
static unsigned int iCnt = 0;
|
|||
|
|
|||
|
if(!pMsg || !pLoop || !pConn)
|
|||
|
{
|
|||
|
return NULL;
|
|||
|
}
|
|||
|
|
|||
|
#if 1
|
|||
|
if(iCnt++ % 1000 == 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Info, "Receive: %s\n", pMsg->pMsg);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
//LOG_EX(LOG_Info, "Process Message(%u --> 0x%08X) at [%lu.%06lu]: cmd = %u, size = %u, key = %d, msg(%d) = [%s]\n",
|
|||
|
// pMsg->msgSrc, pMsg->msgDests, tm / 1000000, tm % 1000000, pMsg->busCmd, pMsg->msgSize, pMsg->msgKey, pMsg->msgSize, pMsg->pMsg);
|
|||
|
|
|||
|
switch(pMsg->busCmd)
|
|||
|
{
|
|||
|
case CMD_CALL_DIAL:
|
|||
|
LOG_EX(LOG_Debug, "Recv: %s\n", pMsg->pMsg);
|
|||
|
break;
|
|||
|
|
|||
|
case CMD_MISC_OTA:
|
|||
|
print_hex_dump_bytes("OTA", DUMP_PREFIX_ADDRESS, pMsg->pMsg, (pMsg->msgSize > 128) ? 128 : pMsg->msgSize);
|
|||
|
break;
|
|||
|
|
|||
|
case CMD_CFG_GET_RSP:
|
|||
|
pRsp = (PCFG_API_RSP)Json2Struct(pMsg->pMsg, JSON_ENGINE_CFG_RSP, TRUE, &err);
|
|||
|
|
|||
|
if(pRsp == NULL || err != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "CMD_CFG_GET: pRsp = %p, err = %d\n", pRsp, err);
|
|||
|
return (NULL);
|
|||
|
}
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Get Configure: [%s](%d) --> \"%s\"\n", pRsp->keyName, pRsp->keyType, pRsp->keyValue);
|
|||
|
|
|||
|
free(pRsp);
|
|||
|
break;
|
|||
|
|
|||
|
case CMD_OTA_STATUS:
|
|||
|
pOTAStatus = (POTA_RSP_STATUS)Json2Struct(pMsg->pMsg, JSON_ENGINE_OTA_RSP, TRUE, &err);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "%s --> %d(0x%08X)\n", otaStatusName(pOTAStatus->status), pOTAStatus->val, pOTAStatus->val);
|
|||
|
|
|||
|
if(pOTAStatus->status == OTA_CURRENT_VERSION)
|
|||
|
{
|
|||
|
test_task_new(__uvThreadOTA, (void*)(intptr_t)pOTAStatus->val);
|
|||
|
}
|
|||
|
|
|||
|
free(pOTAStatus);
|
|||
|
break;
|
|||
|
|
|||
|
case CMD_ALARM_SYNC_REQ:
|
|||
|
LOG_EX(LOG_Debug, "Receive CMD_ALARM_SYNC_REQ Command\n");
|
|||
|
|
|||
|
if(iCnt++ > 0)
|
|||
|
{
|
|||
|
break;
|
|||
|
}
|
|||
|
#if 0
|
|||
|
const char *pAddCmd = "{\"data\":[{\"createTime\":1509419640000,\"id\":672,\"label\":1,\"type\":8,\"status\":1,"
|
|||
|
"\"updateTime\":1509419640000,\"vboxDate\":{\"dayofMonth\":\"17\",\"dayofWeek\":"
|
|||
|
"\"1,2,3,4,5\",\"hour\":\"0\",\"minute\":\"0\",\"month\":\"11\",\"second\":\"10\",\"year\":\"\"},"
|
|||
|
"\"vboxid\":\"0-52AEDB2DF9F45FEB\",\"voiceName\":\"音效2\",\"voiceType\":2},"
|
|||
|
"{\"createTime\":1509419547000,\"id\":671,\"label\":0,\"type\":1,\"status\":1,\"updateTime\":"
|
|||
|
"1509419547000,\"vboxDate\":{\"dayofMonth\":\"\",\"dayofWeek\":\"\",\"hour\":\"0\","
|
|||
|
"\"minute\":\"0\",\"month\":\"\",\"second\":\"10\",\"year\":\"\"},\"vboxid\":\"0-52AEDB2DF9F45FEB\","
|
|||
|
"\"voiceName\":\"音效2\",\"voiceType\":2}]}";
|
|||
|
#else
|
|||
|
#if 0
|
|||
|
const char *pAddCmd = "{\"data\":[{\"id\":6734,\"vboxid\":\"0-D04CDF28BB622AF7\",\"label\":0,"
|
|||
|
"\"type\":1,\"voiceType\":1,\"voiceName\":\"音效1\",\"status\":2,"
|
|||
|
"\"updateTime\":1515576709000,\"createTime\":1515576709000,"
|
|||
|
"\"vboxDate\":{\"second\":\"0\",\"minute\":\"41\",\"hour\":\"18\","
|
|||
|
"\"dayofMonth\":\"10\",\"month\":\"1\",\"dayofWeek\":\"3\",\"year\":"
|
|||
|
"\"2018\"}},{\"id\":6733,\"vboxid\":\"0-D04CDF28BB622AF7\",\"label\":0,"
|
|||
|
"\"type\":1,\"voiceType\":1,\"voiceName\":\"音效1\",\"status\":2,"
|
|||
|
"\"updateTime\":1515576701000,\"createTime\":1515576701000,\"vboxDate\":"
|
|||
|
"{\"second\":\"0\",\"minute\":\"42\",\"hour\":\"18\",\"dayofMonth\":\"10\","
|
|||
|
"\"month\":\"1\",\"dayofWeek\":\"3\",\"year\":\"2018\"}}]}";
|
|||
|
#else
|
|||
|
const char *pAddCmd = "{\"data\":[{\"id\":8136,\"vboxid\":\"0-ADC8ED8631B2032D\",\"label\":0,"
|
|||
|
"\"type\":3,\"voiceType\":1,\"voiceName\":\"音效1\",\"status\":2,"
|
|||
|
"\"updateTime\":1520841240000,\"createTime\":1520841240000,"
|
|||
|
"\"vboxDate\":{\"second\":\"\",\"minute\":\"56\",\"hour\":\"9\","
|
|||
|
"\"dayofMonth\":\"13\",\"month\":\"3\",\"dayofWeek\":\"2\","
|
|||
|
"\"year\":\"2018\"}}]}";
|
|||
|
#endif
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
ALARM_SYNC_INFO alarmInfo;
|
|||
|
ALARM_REMOVE_INFO rmInfo;
|
|||
|
|
|||
|
memset(&alarmInfo, 0, sizeof(ALARM_SYNC_INFO));
|
|||
|
memset(&rmInfo, 0, sizeof(ALARM_REMOVE_INFO));
|
|||
|
|
|||
|
alarmInfo.nItems = 10;
|
|||
|
//alarmInfo.cmd = CMD_ALARM_SYNC_RSP;
|
|||
|
alarmInfo.pAlarmInfo = (PALARM_ITEM_INFO)malloc(sizeof(ALARM_ITEM_INFO) * 10);
|
|||
|
|
|||
|
for(i = 0; i < 10; i++)
|
|||
|
{
|
|||
|
__radomAlarmItem(&alarmInfo.pAlarmInfo[i]);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_ALARM].modAliase,
|
|||
|
CMD_ALARM_SYNC_RSP,
|
|||
|
JSON_ENGINE_ALARM_SYNC_RSP,
|
|||
|
&alarmInfo, TRUE);
|
|||
|
#endif
|
|||
|
ret = DBusSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_ALARM].modAliase,
|
|||
|
CMD_ALARM_SYNC_RSP,
|
|||
|
pAddCmd);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send Alarm Command: JSON_ENGINE_ALARM_SYNC_RSP --> %d\n", ret);
|
|||
|
#if 0
|
|||
|
rmInfo.nItems = 3;
|
|||
|
|
|||
|
for(i = 0; i < 3; i++)
|
|||
|
{
|
|||
|
// rmInfo.rmItemId[i] = alarmInfo.pAlarmInfo[i * 2].alarmId;
|
|||
|
}
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_ALARM].modAliase,
|
|||
|
CMD_ALARM_REMOVE,
|
|||
|
JSON_ENGINE_ALARM_REMOVE,
|
|||
|
&rmInfo, TRUE);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send Alarm Command: JSON_ENGINE_ALARM_SYNC_RSP --> %d\n", ret);
|
|||
|
|
|||
|
free(alarmInfo.pAlarmInfo);
|
|||
|
#endif
|
|||
|
break;
|
|||
|
#if 0
|
|||
|
case CMD_ALARM_STATUS:
|
|||
|
//LOG_EX(LOG_Debug, "CMD_ALARM_STATUS: %s\n", (const char *)pMsg->pMsg);
|
|||
|
pAlarmStatus = (PALARM_RSP_STATUS)Json2Struct(pMsg->pMsg, JSON_ENGINE_ALARM_STATUS, TRUE, &err);
|
|||
|
LOG_EX(LOG_Debug, "%s --> %d(0x%08X)\n", alarmStatusName(pAlarmStatus->cmd), pAlarmStatus->val, pAlarmStatus->val);
|
|||
|
|
|||
|
free(pAlarmStatus);
|
|||
|
break;
|
|||
|
|
|||
|
case CMD_ALARM_NOTIFY_EVT:
|
|||
|
//LOG_EX(LOG_Debug, "CMD_ALARM_NOTIFY_EVT: %s\n", (const char *)pMsg->pMsg);
|
|||
|
pSyncInfo = (PALARM_SYNC_INFO)Json2Struct((const char *)pMsg->pMsg, JSON_ENGINE_ALARM_SYNC_RSP, TRUE, &err);
|
|||
|
|
|||
|
if(pSyncInfo)
|
|||
|
{
|
|||
|
__printAlarmSyncInfo("CMD_ALARM_NOTIFY_EVT", pSyncInfo);
|
|||
|
free(pSyncInfo);
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
#endif
|
|||
|
default:
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
return NULL;
|
|||
|
}
|
|||
|
|
|||
|
static unsigned int g_Delay = 1000;
|
|||
|
static void uvSndLessCb(uv_timer_t* pTimer)
|
|||
|
{
|
|||
|
#if 0
|
|||
|
DBusConnection* pBus = (DBusConnection*)pTimer->data;
|
|||
|
unsigned char* pData = (unsigned char*)malloc(2048);
|
|||
|
|
|||
|
memset(pData, 0x3f, 2048);
|
|||
|
*pData = 0;
|
|||
|
|
|||
|
if(g_ModInfo.modName != MODULE_CONTROLLER)
|
|||
|
{
|
|||
|
DBusSendToCommand(pBus, g_pModInfoTable[MODULE_CONTROLLER].modAliase, CMD_MISC_OTA, pData, 2048);
|
|||
|
}
|
|||
|
|
|||
|
free(pData);
|
|||
|
#endif
|
|||
|
LOG_EX(LOG_Info, "Timer Runing delay = %u ....\n", g_Delay);
|
|||
|
uv_barrier_wait(&g_tmSync);
|
|||
|
// AESEncrypto();
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
#define TEST_AES_LEN (93)
|
|||
|
|
|||
|
void test_evp_aes(void)
|
|||
|
{
|
|||
|
int i;
|
|||
|
unsigned char enData[ALIGN_AES_BLOCK(TEST_AES_LEN)];
|
|||
|
unsigned char* pData = (unsigned char*)malloc(ALIGN_AES_BLOCK(TEST_AES_LEN));
|
|||
|
int outSize = 0;
|
|||
|
char* pKey = "0123456789abcedf";
|
|||
|
|
|||
|
for(i = 0; i < TEST_AES_LEN; i++)
|
|||
|
{
|
|||
|
enData[i] = i % 0xFF;
|
|||
|
}
|
|||
|
|
|||
|
strcpy(enData, "hello world");
|
|||
|
|
|||
|
fprintf(stdout, "EvpAESEncrypto: %s\n",
|
|||
|
EvpAESEncrypto(enData, TEST_AES_LEN, pData, &outSize, (unsigned char*)pKey) == 0 ? "Success" : "Fail");
|
|||
|
|
|||
|
print_hex_dump_bytes("en_", 2, pData, outSize);
|
|||
|
fprintf(stdout, "enc: %s --> %s\n",enData, EvpBase64EncodeNoAlignV2(pData, outSize));
|
|||
|
|
|||
|
memset(enData, 0, ALIGN_AES_BLOCK(TEST_AES_LEN));
|
|||
|
|
|||
|
fprintf(stdout, "EvpAESDecrypto: %s\n",
|
|||
|
EvpAESDecrypto(pData, outSize, enData, &outSize, (unsigned char*)pKey) == 0 ? "Success" : "Fail");
|
|||
|
|
|||
|
fprintf(stdout, "dec:%s\n", (char*)enData);
|
|||
|
free(pData);
|
|||
|
}
|
|||
|
|
|||
|
static void uvTimeoutCb(uv_timer_t* pTimer)
|
|||
|
{
|
|||
|
PCFG_ITEM pItem = NULL;
|
|||
|
|
|||
|
int ret = 0;
|
|||
|
|
|||
|
if((ret = CfgGetKeyValue("Age", &pItem)) == 0)
|
|||
|
{
|
|||
|
CfgItemPrint("Get KeyValue: ", pItem);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Get Key [Age] Error: %d\n", ret);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void EVPEncryptCb(CRYPTO_TYPE type,
|
|||
|
const unsigned char* pData,
|
|||
|
int iSize,
|
|||
|
const unsigned char* pSrcData,
|
|||
|
int iError)
|
|||
|
{
|
|||
|
int i = 0;
|
|||
|
|
|||
|
if(iError == 0)
|
|||
|
{
|
|||
|
if(type == CRYPTO_AES_ENCRYPT)
|
|||
|
{
|
|||
|
char* pKey = "xajhuang12345678";
|
|||
|
unsigned char* enData = (unsigned char*)malloc(ALIGN_AES_BLOCK(TEST_AES_LEN));
|
|||
|
|
|||
|
memset(enData, 0, ALIGN_AES_BLOCK(TEST_AES_LEN));
|
|||
|
|
|||
|
print_hex_dump_bytes("AES_Encrypt_", DUMP_PREFIX_ADDRESS, pData, iSize);
|
|||
|
|
|||
|
i = EvpAddCryptoTask(CRYPTO_AES_DECRYPT, (unsigned char*)pData, iSize, enData, pKey, EVPEncryptCb);
|
|||
|
|
|||
|
if(i != 0)
|
|||
|
{
|
|||
|
free(enData);
|
|||
|
LOG_EX(LOG_Error, "EvpAddCryptoTask Error: %d\n", i);
|
|||
|
}
|
|||
|
}
|
|||
|
else if(type == CRYPTO_AES_DECRYPT)
|
|||
|
{
|
|||
|
print_hex_dump_bytes("AES_Decrypt_", DUMP_PREFIX_ADDRESS, pData, iSize);
|
|||
|
}
|
|||
|
else if(type == CRYPTO_BASE64_ENCODE)
|
|||
|
{
|
|||
|
int ret = 0;
|
|||
|
|
|||
|
LOG_EX(LOG_Info, "Base64(%d):[\n%s]\n", iSize, (char*)pData);
|
|||
|
ret = EvpAddCryptoTask(CRYPTO_BASE64_DECODE, (unsigned char*)pData, iSize, NULL, NULL, EVPEncryptCb);
|
|||
|
|
|||
|
if(ret != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "EvpAddCryptoTask Error: %d\n", ret);
|
|||
|
}
|
|||
|
}
|
|||
|
else if(type == CRYPTO_BASE64_DECODE)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Info, "Base64(%d):[\n%s]\n", iSize, (char*)pData);
|
|||
|
}
|
|||
|
else if(type == CRYPTO_MD5_FILE)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Info, "%s MD5 value [%s]\n", (char*)pSrcData, (char*)pData);
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "pData = %p, iError = %d\n", pData, iError);
|
|||
|
}
|
|||
|
|
|||
|
free((void*)pData);
|
|||
|
}
|
|||
|
|
|||
|
static void test_aes_async(void)
|
|||
|
{
|
|||
|
int i;
|
|||
|
unsigned char enData[ALIGN_AES_BLOCK(TEST_AES_LEN)];
|
|||
|
unsigned char* pData = (unsigned char*)malloc(ALIGN_AES_BLOCK(TEST_AES_LEN));
|
|||
|
int outSize = 0;
|
|||
|
char* pKey = "xajhuang12345678";
|
|||
|
|
|||
|
for(i = 0; i < TEST_AES_LEN; i++)
|
|||
|
{
|
|||
|
enData[i] = i % 0xFF;
|
|||
|
}
|
|||
|
|
|||
|
i = EvpAddCryptoTask(CRYPTO_BASE64_ENCODE, enData, TEST_AES_LEN, pData, pKey, EVPEncryptCb);
|
|||
|
|
|||
|
if(i != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "EvpAddCryptoTask Error: %d\n", i);
|
|||
|
free(pData);
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
static void test_base64_async(void)
|
|||
|
{
|
|||
|
int ret = 0;
|
|||
|
#if 1
|
|||
|
const char* pSrc = "Wikiversity is a Wikimedia Foundation project devoted to learning resources, learning projects, \
|
|||
|
and research for use in all levels, types, and styles of education from pre-school to university, including professional \
|
|||
|
training and informal learning. We invite teachers, students, and researchers to join us in creating open educational \
|
|||
|
resources and collaborative learning communities. \
|
|||
|
This page is an index of all Wikiversity help and maintenance pages. The following articles contain guidance and \
|
|||
|
information about Editing, Policies and guidelines, and participating in the Wikiversity community. \
|
|||
|
Having trouble finding out what you need to know? If it is not covered by the FAQ, try asking at the Colloquium.";
|
|||
|
#else
|
|||
|
const char *pSrc = "http://www.164.com";
|
|||
|
#endif
|
|||
|
const char *pBase64 = EvpBase64EncodeNoAlign(pSrc);
|
|||
|
const char *pDecode = EvpBase64DecodeNoAlign(pBase64);
|
|||
|
|
|||
|
fprintf(stdout, "Encode:\n%s\n", pBase64);
|
|||
|
fprintf(stdout, "Decode:\n%s\n", pDecode);
|
|||
|
|
|||
|
#if 0
|
|||
|
ret = EvpAddCryptoTask(CRYPTO_BASE64_ENCODE, (unsigned char*)pSrc, strlen(pSrc), NULL, NULL, EVPEncryptCb);
|
|||
|
|
|||
|
if(ret != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "EvpAddCryptoTask Error: %d\n", ret);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
static void test_md5file_async(void)
|
|||
|
{
|
|||
|
int ret = 0;
|
|||
|
const char* pFile = "/root/time.txt";
|
|||
|
|
|||
|
ret = EvpAddCryptoTask(CRYPTO_MD5_FILE, (unsigned char*)pFile, strlen(pFile), NULL, NULL, EVPEncryptCb);
|
|||
|
|
|||
|
if(ret != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "EvpAddCryptoTask Error: %d\n", ret);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void test_s2j_task(void)
|
|||
|
{
|
|||
|
PLAYER_TO_CTRL plyCtl;
|
|||
|
PPLAYER_TO_CTRL pPlyCtl = NULL;
|
|||
|
int err;
|
|||
|
const char* pJson = NULL;
|
|||
|
|
|||
|
strcpy(plyCtl.musicUuid, "http://www.164.com");
|
|||
|
plyCtl.plySt = 1;
|
|||
|
plyCtl.curPos = 12133;
|
|||
|
plyCtl.duration = 321000;
|
|||
|
|
|||
|
pJson = Struct2Json(&plyCtl, JSON_ENGINE_P2C, TRUE, &err);
|
|||
|
|
|||
|
if(pJson != NULL)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Json:\n %s\n", pJson);
|
|||
|
|
|||
|
pPlyCtl = (PPLAYER_TO_CTRL)Json2Struct(pJson, JSON_ENGINE_P2C, TRUE, &err);
|
|||
|
|
|||
|
if(pPlyCtl != NULL)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Struct:\nmusicUuid: %s\nplySt: %d\ncurPos: %d\nduration: %d\n",
|
|||
|
pPlyCtl->musicUuid, pPlyCtl->plySt, pPlyCtl->curPos, pPlyCtl->duration);
|
|||
|
|
|||
|
free(pPlyCtl);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Json2Struct Test Error\n");
|
|||
|
}
|
|||
|
|
|||
|
free((void*)pJson);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "test error\n");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
extern const char* __ota_Notify_REQ2Json(void *pData);
|
|||
|
extern void* __json2OTA_Notify_REQ(const char *pJsonS);
|
|||
|
static void __uvThreadTestOTA(void *pParam)
|
|||
|
{
|
|||
|
int err = 0, i = 0;
|
|||
|
int ret;
|
|||
|
const char *pMD5 = NULL;
|
|||
|
|
|||
|
char* strMenu[] = {
|
|||
|
"Usage:\n",
|
|||
|
|
|||
|
"OTA Cmd download : download\n",
|
|||
|
"OTA Cmd local : local\n",
|
|||
|
"OTA Cmd exec : exec\n",
|
|||
|
"Batch Test : batch\n",
|
|||
|
"Set Config : ready\n",
|
|||
|
"Exit : quit\n",
|
|||
|
};
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
char *pInput = NULL;
|
|||
|
char *pSub = NULL;
|
|||
|
|
|||
|
|
|||
|
for(i = 0; i < sizeof(strMenu) / sizeof(strMenu[0]); i++)
|
|||
|
{
|
|||
|
fprintf(stdout, "%s", strMenu[i]);
|
|||
|
}
|
|||
|
|
|||
|
pInput = readline("Please Choise:");
|
|||
|
|
|||
|
if(pInput == NULL)
|
|||
|
{
|
|||
|
continue;
|
|||
|
}
|
|||
|
|
|||
|
pSub = strtok(pInput, " ");
|
|||
|
i = 0;
|
|||
|
|
|||
|
while(pSub != NULL)
|
|||
|
{
|
|||
|
OTA_DATA_INFO otaInfo;
|
|||
|
POTA_DATA_INFO pInfo = NULL;
|
|||
|
|
|||
|
memset(&otaInfo, 0, sizeof(OTA_DATA_INFO));
|
|||
|
|
|||
|
otaInfo.version = 1;
|
|||
|
|
|||
|
if(strcmp(pSub, "download") == 0)
|
|||
|
{
|
|||
|
otaInfo.otaCmd = OTA_CMD_DOWNLOAD;
|
|||
|
otaInfo.otaMode = OTA_MODE_NORMAL;
|
|||
|
otaInfo.otaFileInfo.size = 21484772;
|
|||
|
strcpy(otaInfo.otaFileInfo.url, "http://10.241.0.70/tina/tina_r16_ota.tar.gz");
|
|||
|
strcpy(otaInfo.otaFileInfo.md5, "2d58366a0846f6345730e28b021816d0");
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_OTA_NOTIFY,
|
|||
|
JSON_ENGINE_OTA_REQ,
|
|||
|
&otaInfo, TRUE);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send OTA Command %s: %d\n", pSub, ret);
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "local") == 0)
|
|||
|
{
|
|||
|
otaInfo.otaCmd = OTA_CMD_USED_LOCAL_IMAGE;
|
|||
|
otaInfo.otaMode = OTA_MODE_FORCE_NOW;
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_OTA_NOTIFY,
|
|||
|
JSON_ENGINE_OTA_REQ,
|
|||
|
&otaInfo, TRUE);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send OTA Command %s: %d\n", pSub, ret);
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "exec") == 0)
|
|||
|
{
|
|||
|
otaInfo.otaCmd = OTA_CMD_EXEC;
|
|||
|
otaInfo.otaMode = OTA_MODE_FORCE_NOW;
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_OTA_NOTIFY,
|
|||
|
JSON_ENGINE_OTA_REQ,
|
|||
|
&otaInfo, TRUE);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send OTA Command %s: %d\n", pSub, ret);
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "batch") == 0)
|
|||
|
{
|
|||
|
#if 0
|
|||
|
int err;
|
|||
|
POTA_DATA_INFO pInfo = NULL;
|
|||
|
const char *pJson = NULL;
|
|||
|
#endif
|
|||
|
|
|||
|
#if 0
|
|||
|
pJson = Struct2Json(&otaInfo, JSON_ENGINE_OTA_REQ, TRUE, &err);
|
|||
|
fprintf(stdout, "Json(%p->%d): \n%s\n", &otaInfo, err, pJson);
|
|||
|
|
|||
|
|
|||
|
|
|||
|
pInfo = (POTA_DATA_INFO)Json2Struct(pJson, JSON_ENGINE_OTA_REQ, TRUE, &err);
|
|||
|
if(pInfo)
|
|||
|
{
|
|||
|
fprintf(stdout, "JsonInfo: \n%s\n", __ota_Notify_REQ2Json(pInfo));
|
|||
|
}
|
|||
|
|
|||
|
#else
|
|||
|
pMD5 = EvpMD5HashBufV2((const unsigned char *)&otaInfo, sizeof(OTA_DATA_INFO));
|
|||
|
|
|||
|
err = 0;
|
|||
|
for(i = 0; i < 1000000; i++)
|
|||
|
{
|
|||
|
POTA_DATA_INFO pOInfo = (POTA_DATA_INFO)malloc(sizeof(OTA_DATA_INFO));
|
|||
|
|
|||
|
memcpy(pOInfo, &otaInfo, sizeof(OTA_DATA_INFO));
|
|||
|
|
|||
|
ret = DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_OTA_NOTIFY,
|
|||
|
JSON_ENGINE_OTA_REQ,
|
|||
|
pOInfo, TRUE);
|
|||
|
|
|||
|
free(pOInfo);
|
|||
|
|
|||
|
if(ret != 0)
|
|||
|
{
|
|||
|
err++;
|
|||
|
break;
|
|||
|
//fprintf(stderr, "ret = %d\n", ret);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
//fprintf(stdout, "send [%d]: %d\n", i, err);
|
|||
|
//LOG_EX(LOG_Debug, "Send OTA Command: %d\n", ret);
|
|||
|
//usleep(1000);
|
|||
|
}
|
|||
|
|
|||
|
fprintf(stdout, "%s\n", pMD5);
|
|||
|
free((void*)pMD5);
|
|||
|
//fprintf(stdout, "send [%d]: %d\n", i, err);
|
|||
|
#endif
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "ready") == 0)
|
|||
|
{
|
|||
|
ret = DBusSendToCommand(NULL,
|
|||
|
g_pModInfoTable[MODULE_OTA].modAliase,
|
|||
|
CMD_SYSTEM_STANDBY, "{\"status\" : 0}");
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Send Standby Command: %d\n", ret);
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "quit") == 0)
|
|||
|
{
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
pSub = strtok(NULL, " ");
|
|||
|
}
|
|||
|
|
|||
|
free(pInput);
|
|||
|
|
|||
|
usleep(1000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __uvThreadTimer(void *pParams)
|
|||
|
{
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
uv_barrier_init(&g_tmSync, 2);
|
|||
|
|
|||
|
g_Delay += 1000;
|
|||
|
uv_timer_stop(&g_tmTest);
|
|||
|
LOG_EX(LOG_Info, "Re Start Timer %u...\n", g_Delay);
|
|||
|
uv_timer_start(&g_tmTest, uvSndLessCb, g_Delay, 0);
|
|||
|
|
|||
|
uv_barrier_wait(&g_tmSync);
|
|||
|
uv_barrier_destroy(&g_tmSync);
|
|||
|
|
|||
|
sleep(1);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __uvThreadTestConfigure(void *pParams)
|
|||
|
{
|
|||
|
int i = 0;
|
|||
|
int ret;
|
|||
|
|
|||
|
char* g_Menu[] = {
|
|||
|
"Usage:\n",
|
|||
|
"Get Config : get <keyName>\n",
|
|||
|
"Set Config : set <keyName> <keyType> <value> <savetoDb>\n",
|
|||
|
"Change Config : change <keyName> <value> <savetoDb>\n",
|
|||
|
"Exit: quit\n",
|
|||
|
};
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
char *pInput = NULL;
|
|||
|
char *pSub = NULL;
|
|||
|
|
|||
|
|
|||
|
for(i = 0; i < sizeof(g_Menu) / sizeof(g_Menu[0]); i++)
|
|||
|
{
|
|||
|
fprintf(stdout, "%s", g_Menu[i]);
|
|||
|
}
|
|||
|
|
|||
|
pInput = readline("Please Choise:");
|
|||
|
|
|||
|
if(pInput == NULL)
|
|||
|
{
|
|||
|
continue;
|
|||
|
}
|
|||
|
|
|||
|
pSub = strtok(pInput, " ");
|
|||
|
i = 0;
|
|||
|
|
|||
|
while(pSub != NULL)
|
|||
|
{
|
|||
|
if(strcmp(pSub, "get") == 0)
|
|||
|
{
|
|||
|
char* pKeyName = strtok(NULL, " ");
|
|||
|
|
|||
|
if(pKeyName != NULL && strlen(pKeyName) > 0)
|
|||
|
{
|
|||
|
CFG_ITEM* pCfg;
|
|||
|
ret = CfgGetKeyValue(pKeyName, &pCfg);
|
|||
|
|
|||
|
if(ret == 0)
|
|||
|
{
|
|||
|
CfgItemPrint("GetLocalCfg: ", pCfg);
|
|||
|
}
|
|||
|
else if(ret == -ERR_CFG_WAIT_RSP)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Wait for server response\n");
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Get Configure [%s] Error: %d\n", pKeyName, ret);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "set") == 0)
|
|||
|
{
|
|||
|
char* pKeyName = strtok(NULL, " ");
|
|||
|
char *pKeyType = strtok(NULL, " ");
|
|||
|
char* pKeyValue = strtok(NULL, " ");
|
|||
|
char* pSaveTo = strtok(NULL, " ");
|
|||
|
|
|||
|
if(pKeyName && pKeyValue && pKeyType && pSaveTo
|
|||
|
&& strlen(pKeyName) > 0 && strlen(pKeyValue) > 0 && strlen(pKeyType) > 0 && strlen(pSaveTo) > 0)
|
|||
|
{
|
|||
|
CFG_ITEM item;
|
|||
|
|
|||
|
item.pKeyName = pKeyName;
|
|||
|
item.keyType = strtoul(pKeyType, NULL, 10);
|
|||
|
|
|||
|
if(item.keyType == CFG_TYPE_STRING)
|
|||
|
{
|
|||
|
item.pStrValue = pKeyValue;
|
|||
|
}
|
|||
|
else if(item.keyType == CFG_TYPE_INT)
|
|||
|
{
|
|||
|
item.intValue = strtol(pKeyValue, NULL, 10);
|
|||
|
}
|
|||
|
else if(item.keyType == CFG_TYPE_DOUBLE)
|
|||
|
{
|
|||
|
item.doubleValue = strtod(pKeyValue, NULL);
|
|||
|
}
|
|||
|
|
|||
|
ret = CfgAddKeyValue(pKeyName, &item, strtol(pSaveTo, NULL, 10));
|
|||
|
|
|||
|
if(ret == 0)
|
|||
|
{
|
|||
|
CfgItemPrint("Add Configure: ", &item);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Add Configure [%s] Error: %d\n", pKeyName, ret);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else if(strcmp(pSub, "quit") == 0)
|
|||
|
{
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
pSub = strtok(NULL, " ");
|
|||
|
}
|
|||
|
|
|||
|
usleep(1000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void test_task_new(uv_thread_cb pCallback, void* pParams)
|
|||
|
{
|
|||
|
uv_thread_t uvSyncThread;
|
|||
|
|
|||
|
uv_thread_create(&uvSyncThread, pCallback, pParams);
|
|||
|
}
|
|||
|
|
|||
|
#define WAKE_CACHE_SIZE (10)
|
|||
|
|
|||
|
static unsigned char g_AudioCache[WAKE_CACHE_SIZE];
|
|||
|
static unsigned int g_wtPos = 0;
|
|||
|
static unsigned int g_tolCache = 0;
|
|||
|
|
|||
|
static void __cacheCAEAudio(unsigned char* pBuf, unsigned int iSize)
|
|||
|
{
|
|||
|
if(iSize > WAKE_CACHE_SIZE)
|
|||
|
{
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
memmove(g_AudioCache, g_AudioCache + iSize, WAKE_CACHE_SIZE - iSize);
|
|||
|
memcpy(g_AudioCache + WAKE_CACHE_SIZE - iSize, pBuf, iSize);
|
|||
|
}
|
|||
|
|
|||
|
static void test_move_data(void)
|
|||
|
{
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
static void __onAlarmCb(unsigned int tmId, unsigned int status, void *pUserData)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Time %u On......\n", tmId);
|
|||
|
}
|
|||
|
|
|||
|
static int g_isExitApp = FALSE;
|
|||
|
|
|||
|
static void uvExitLoopCb(uv_timer_t *pParams)
|
|||
|
{
|
|||
|
DEBUG_CODE_LINE();
|
|||
|
uv_stop(GetDBusDefaultLoop());
|
|||
|
}
|
|||
|
|
|||
|
static void __uvLoopExit(void *pParams)
|
|||
|
{
|
|||
|
int ret = 0;
|
|||
|
uv_timer_t tmExit;
|
|||
|
uv_loop_t* pLoop = GetDBusDefaultLoop();
|
|||
|
DBusConnection* pBus = DBusWithLibuvInit(pLoop, g_ModInfo.modAliase,
|
|||
|
DBusOnMessage,
|
|||
|
__dBusDeameonCb,
|
|||
|
NULL, //KeyEventCb,
|
|||
|
&ret);
|
|||
|
|
|||
|
if(pBus == NULL)
|
|||
|
{
|
|||
|
fprintf(stderr, "DBusWithLibuvInit Error: %d\n", ret);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
DBusBoardcastCommand(NULL, 0x11, 10, "xajhuang");
|
|||
|
|
|||
|
//test_task_new(uvExitLoopCb, NULL);
|
|||
|
uv_timer_init(pLoop, &tmExit);
|
|||
|
uv_timer_start(&tmExit, uvExitLoopCb, 3000, 3000);
|
|||
|
|
|||
|
DEBUG_CODE_LINE();
|
|||
|
//RunUVLoop(pLoop);
|
|||
|
uv_run(pLoop, UV_RUN_DEFAULT);
|
|||
|
//uv_loop_close(pLoop);
|
|||
|
DEBUG_CODE_LINE();
|
|||
|
|
|||
|
g_isExitApp = TRUE;
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
static void __fs_event_handle_cb(uv_fs_event_t *pEvent, const char *pFileName, int events, int status)
|
|||
|
{
|
|||
|
char path[MAX_PATH];
|
|||
|
size_t pathSize = MAX_PATH - 1;
|
|||
|
|
|||
|
memset(path, 0, MAX_PATH);
|
|||
|
uv_fs_event_getpath(pEvent, path, &pathSize);
|
|||
|
|
|||
|
fprintf(stdout, "%s: %d, %d\n", path, events, status);
|
|||
|
}
|
|||
|
|
|||
|
static void __onPrgCb(const char *pReqUrl, const char *pTaskUuid, unsigned char uPercent, void *pUserData)
|
|||
|
{
|
|||
|
static unsigned char preCnt = 0;
|
|||
|
|
|||
|
if(preCnt != uPercent)
|
|||
|
{
|
|||
|
preCnt = uPercent;
|
|||
|
LOG_EX(LOG_Debug, "[%s](%s): %u%%\n", pReqUrl, pTaskUuid, uPercent);
|
|||
|
}
|
|||
|
|
|||
|
if(uPercent > 50)
|
|||
|
{
|
|||
|
//InetCancelDownload(pTaskUuid);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static unsigned int g_DlCount = 0;
|
|||
|
static void __onDlCb(void *pData, unsigned int size, const char *pReqUrl, const char* pDlPath, const char *pTaskUuid, int iFinished, void *pUserData)
|
|||
|
{
|
|||
|
if(g_DlCount > 0)
|
|||
|
{
|
|||
|
g_DlCount--;
|
|||
|
}
|
|||
|
|
|||
|
if(iFinished == 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Request(%s): [%s] --> [%s] Response: [%u] OK\n", pTaskUuid, pReqUrl, pDlPath, size);
|
|||
|
}
|
|||
|
else if(iFinished == 1)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Request(%s): [%s] --> [%s] Response: [%u] Error\n", pTaskUuid, pReqUrl, pDlPath, size);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Download Error Code: %d\n", iFinished);
|
|||
|
}
|
|||
|
#if 1
|
|||
|
if(iFinished != 0)
|
|||
|
{
|
|||
|
const char* pId = InetHttpDlFileAsync(pReqUrl,
|
|||
|
pDlPath,
|
|||
|
__onDlCb,
|
|||
|
NULL,//__onPrgCb,
|
|||
|
NULL);
|
|||
|
|
|||
|
LOG_EX(LOG_Debug, "Download ID: %s\n", pId);
|
|||
|
}
|
|||
|
#endif
|
|||
|
}
|
|||
|
|
|||
|
static void __uvTestSkin(void *pParams)
|
|||
|
{
|
|||
|
int tolItems = sizeof(g_SkinDefaultResTable) / sizeof(g_SkinDefaultResTable[0]);
|
|||
|
#if 0
|
|||
|
char *pUpg = "[ \
|
|||
|
{ \
|
|||
|
\"createTime\": 1510570174000, \
|
|||
|
\"enable\": 1, \
|
|||
|
\"id\": 3, \
|
|||
|
\"md5\": \"af065860c3667ca2508c283d660990f7\", \
|
|||
|
\"osType\": 0, \
|
|||
|
\"remark\": \"音效1文件\", \
|
|||
|
\"resourceName\": \"v111\", \
|
|||
|
\"resourceType\": 1, \
|
|||
|
\"resourceVersion\": \"v0.3.1\", \
|
|||
|
\"size\": 164460, \
|
|||
|
\"updateTime\": 1510570227000, \
|
|||
|
\"url\": \"http://vbox-resource.nos.netease.com/d627159f-bccd-4364-bccc-f196c2b83ffd.mp3\", \
|
|||
|
\"versionId\": 10, \
|
|||
|
\"versionName\": \"0.0.9\", \
|
|||
|
\"versionOsType\": \"0\" \
|
|||
|
} ]";
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
static int i = 0;
|
|||
|
|
|||
|
while(i++ < 100)
|
|||
|
{
|
|||
|
char *pKeyName = (char*)(g_SkinDefaultResTable[random() % tolItems].pKeyName);
|
|||
|
char *pResPath = GetSkinsResource(pKeyName, NULL, NULL, NULL);
|
|||
|
LOG_EX(LOG_Debug, "[%s] = {%s}\n", pKeyName, pResPath);
|
|||
|
|
|||
|
free(pResPath);
|
|||
|
sleep(3);
|
|||
|
}
|
|||
|
#else
|
|||
|
for(int i = 0; i < tolItems; i++)
|
|||
|
{
|
|||
|
int tmUsed = 0;
|
|||
|
struct timeval tmStart, tmEnd;
|
|||
|
char *pKeyName = (char*)(g_SkinDefaultResTable[i].pKeyName);
|
|||
|
char *pResPath = NULL;
|
|||
|
|
|||
|
gettimeofday(&tmStart, NULL);
|
|||
|
pResPath = GetSkinsResource(pKeyName, NULL, NULL, NULL);
|
|||
|
gettimeofday(&tmEnd, NULL);
|
|||
|
|
|||
|
tmUsed = (tmEnd.tv_sec * 1000000 + tmEnd.tv_usec) - (tmStart.tv_sec * 1000000 + tmStart.tv_usec);
|
|||
|
LOG_EX(LOG_Debug, "(%d):[%s] = {%s}\n", tmUsed, pKeyName, pResPath);
|
|||
|
|
|||
|
free(pResPath);
|
|||
|
}
|
|||
|
#if 0
|
|||
|
fprintf(stdout, "-----------------------\n");
|
|||
|
for(int i = 0; i < tolItems; i++)
|
|||
|
{
|
|||
|
int tmUsed = 0;
|
|||
|
struct timeval tmStart, tmEnd;
|
|||
|
char *pKeyName = (char*)(g_SkinDefaultResTable[i].pKeyName);
|
|||
|
char *pResPath = NULL;
|
|||
|
|
|||
|
gettimeofday(&tmStart, NULL);
|
|||
|
pResPath = GetSkinsResource(pKeyName, NULL, NULL, NULL);
|
|||
|
gettimeofday(&tmEnd, NULL);
|
|||
|
|
|||
|
tmUsed = (tmEnd.tv_sec * 1000000 + tmEnd.tv_usec) - (tmStart.tv_sec * 1000000 + tmStart.tv_usec);
|
|||
|
LOG_EX(LOG_Debug, "(%d):[%s] = {%s}\n", tmUsed, pKeyName, pResPath);
|
|||
|
|
|||
|
free(pResPath);
|
|||
|
}
|
|||
|
#endif
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
SkinUpgrade(pUpg);
|
|||
|
|
|||
|
sleep(5);
|
|||
|
|
|||
|
GetSkinsResource("v111", NULL, NULL, NULL);
|
|||
|
#endif
|
|||
|
}
|
|||
|
|
|||
|
static LOG_LEVEL g_logLevelInfo[] = {
|
|||
|
LOG_Fatal, LOG_Error, LOG_Warn, LOG_Debug, LOG_Info,
|
|||
|
LOG_Test, LOG_Call, LOG_Devp, LOG_Step, LOG_Unknown, LOG_All, LOG_Close
|
|||
|
};
|
|||
|
|
|||
|
static void __uvLogTestProc(void *pParams)
|
|||
|
{
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
//SysPointMark("-----------------------------------------------------\n");
|
|||
|
|
|||
|
for(int i = 0; i < sizeof(g_logLevelInfo) / sizeof(g_logLevelInfo[0]); i++)
|
|||
|
{
|
|||
|
UT_string* pString = NULL;
|
|||
|
|
|||
|
utstring_new(pString);
|
|||
|
utstring_printf(pString, "This is LogLevel %s\n", LogLeveToString(g_logLevelInfo[i]));
|
|||
|
//SysPointMark(utstring_body(pString));
|
|||
|
LOG_EX(g_logLevelInfo[i], "This is LogLevel %s\n", LogLeveToString(g_logLevelInfo[i]));
|
|||
|
utstring_free(pString);
|
|||
|
}
|
|||
|
|
|||
|
sleep(1);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __uvLogCtrlProc(void *pParams)
|
|||
|
{
|
|||
|
int i = 0;
|
|||
|
int ret;
|
|||
|
|
|||
|
const char* g_Menu[] = {
|
|||
|
"Usage: enable/disable <modName> <operation> [params1] [params2]\n"
|
|||
|
" help\n",
|
|||
|
" quit\n",
|
|||
|
};
|
|||
|
|
|||
|
const char* pOptMenu[] = {
|
|||
|
"\n operation:\n"
|
|||
|
" |--------------------------------------------------------------------------|\n",
|
|||
|
" | command | operation | params1 | params2 |\n",
|
|||
|
" |--------------------------------------------------------------------------|\n",
|
|||
|
" | enable | | | |\n",
|
|||
|
" |----------| 0: Set log level | Log level | Unused |\n",
|
|||
|
" | disable | | | |\n",
|
|||
|
" |----------|---------------------|-----------------------|-----------------|\n",
|
|||
|
" | enable | | | |\n",
|
|||
|
" |----------| 1: Print to file | Unused | Unused |\n",
|
|||
|
" | disable | | | |\n",
|
|||
|
" |----------|---------------------|-----------------------|-----------------|\n",
|
|||
|
" | enable | | | |\n",
|
|||
|
" |----------| 2: Backup to email | Unused | Unused |\n",
|
|||
|
" | disable | | | |\n",
|
|||
|
" |----------|---------------------|-----------------------|-----------------|\n",
|
|||
|
" | enable | | Log server ip address | Log server port |\n",
|
|||
|
" |----------| 3: Send to network |-----------------------|-----------------|\n",
|
|||
|
" | disable | | Unused | Unused |\n",
|
|||
|
" |--------------------------------------------------------------------------|\n",
|
|||
|
};
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
char *pInput = NULL;
|
|||
|
char *pCmd = NULL;
|
|||
|
|
|||
|
for(i = 0; i < sizeof(g_Menu) / sizeof(g_Menu[0]); i++)
|
|||
|
{
|
|||
|
fprintf(stdout, "%s", g_Menu[i]);
|
|||
|
}
|
|||
|
|
|||
|
pInput = readline("Enter Command:");
|
|||
|
|
|||
|
if(pInput == NULL)
|
|||
|
{
|
|||
|
continue;
|
|||
|
}
|
|||
|
#if 1
|
|||
|
pCmd = strtok(pInput, " ");
|
|||
|
i = 0;
|
|||
|
|
|||
|
while(pCmd != NULL)
|
|||
|
{
|
|||
|
if(strcmp(pCmd, "help") == 0)
|
|||
|
{
|
|||
|
for(i = 0; i < sizeof(g_pModInfoTable) / sizeof(g_pModInfoTable[0]); i++)
|
|||
|
{
|
|||
|
if(i == 0)
|
|||
|
{
|
|||
|
fprintf(stdout, " modName : %-2d --> %s\n",
|
|||
|
i, ModuleNameToString(g_pModInfoTable[i].modName));
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
fprintf(stdout, "%15s%-2d --> %s\n", "",
|
|||
|
i, ModuleNameToString(g_pModInfoTable[i].modName));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
for(i = 0; i < sizeof(g_logLevelInfo) / sizeof(g_logLevelInfo[0]); i++)
|
|||
|
{
|
|||
|
if(i == 0)
|
|||
|
{
|
|||
|
fprintf(stdout, "\n Log Level: %-2d --> %s\n", i, LogLeveToString(g_logLevelInfo[i]));
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
fprintf(stdout, "%15s%-2d --> %s\n", "", i, LogLeveToString(g_logLevelInfo[i]));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
for(i = 0; i < sizeof(pOptMenu) / sizeof(pOptMenu[0]); i++)
|
|||
|
{
|
|||
|
fprintf(stdout, "%s", pOptMenu[i]);
|
|||
|
}
|
|||
|
}
|
|||
|
else if(strcmp(pCmd, "enable") == 0
|
|||
|
|| strcmp(pCmd, "disable") == 0)
|
|||
|
{
|
|||
|
LOG_CFG_PROTOCOL logItem;
|
|||
|
int iCmd, iMod;
|
|||
|
char *pParams1 = NULL, *pParams2 = NULL;
|
|||
|
char* pMod = strtok(NULL, " ");
|
|||
|
char* pOperat = strtok(NULL, " ");
|
|||
|
|
|||
|
if(pMod == NULL || strlen(pMod) == 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Input <modName> error, see help\n");
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
if(pOperat == NULL || strlen(pOperat) == 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Input <operation> error, see help\n");
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
iMod = strtol(pMod, NULL, 10);
|
|||
|
|
|||
|
if(iMod < 0 || iMod >= MODULE_MAX)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Input <modName> error: %s(%d)\n", pMod, iMod);
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
iCmd = strtol(pOperat, NULL, 10);
|
|||
|
|
|||
|
memset(&logItem, 0, sizeof(LOG_CFG_PROTOCOL));
|
|||
|
|
|||
|
|
|||
|
|
|||
|
switch(iCmd)
|
|||
|
{
|
|||
|
case 0:
|
|||
|
pParams1 = strtok(NULL, " ");
|
|||
|
if(pParams1 && strlen(pParams1) > 0)
|
|||
|
{
|
|||
|
int logLevel = strtol(pParams1, NULL, 10);
|
|||
|
|
|||
|
if(logLevel >= 0 && logLevel < sizeof(g_logLevelInfo) / sizeof(g_logLevelInfo[0]))
|
|||
|
{
|
|||
|
fprintf(stdout, "%s %d 0x%08X\n", pCmd, iCmd, g_logLevelInfo[logLevel]);
|
|||
|
|
|||
|
logItem.cfgCmd = CMD_LOG_LEVEL;
|
|||
|
logItem.iParams2 = (strcmp(pCmd, "disable") == 0) ? FALSE : TRUE;
|
|||
|
logItem.iParams1 = g_logLevelInfo[logLevel];
|
|||
|
|
|||
|
DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[iMod].modAliase,
|
|||
|
CMD_LOG_CONFIG,
|
|||
|
JSON_ENGINE_LOG_CFG_CMD,
|
|||
|
&logItem, TRUE);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Input <pParams1> error, see help\n");
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Input <pParams1> error, see help\n");
|
|||
|
}
|
|||
|
break;
|
|||
|
|
|||
|
case 1:
|
|||
|
logItem.cfgCmd = CMD_LOG_FILE;
|
|||
|
logItem.iParams1 = (strcmp(pCmd, "disable") == 0) ? FALSE : TRUE;
|
|||
|
DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[iMod].modAliase,
|
|||
|
CMD_LOG_CONFIG,
|
|||
|
JSON_ENGINE_LOG_CFG_CMD,
|
|||
|
&logItem, TRUE);
|
|||
|
break;
|
|||
|
|
|||
|
case 2:
|
|||
|
logItem.cfgCmd = CMD_LOG_MAIL;
|
|||
|
logItem.iParams1 = (strcmp(pCmd, "disable") == 0) ? FALSE : TRUE;
|
|||
|
DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[iMod].modAliase,
|
|||
|
CMD_LOG_CONFIG,
|
|||
|
JSON_ENGINE_LOG_CFG_CMD,
|
|||
|
&logItem, TRUE);
|
|||
|
break;
|
|||
|
|
|||
|
case 3:
|
|||
|
pParams1 = strtok(NULL, " ");
|
|||
|
|
|||
|
logItem.cfgCmd = CMD_LOG_NETWORK;
|
|||
|
if(pParams1 == NULL || strlen(pParams1) == 0)
|
|||
|
{
|
|||
|
|
|||
|
logItem.iParams1 = 0;
|
|||
|
DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[iMod].modAliase,
|
|||
|
CMD_LOG_CONFIG,
|
|||
|
JSON_ENGINE_LOG_CFG_CMD,
|
|||
|
&logItem, TRUE);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
pParams2 = strtok(NULL, " ");
|
|||
|
|
|||
|
if(pParams2 != NULL && strlen(pParams2) > 0)
|
|||
|
{
|
|||
|
logItem.iParams1 = inet_addr(pParams1);
|
|||
|
logItem.iParams2 = strtol(pParams2, NULL, 10);
|
|||
|
DBusJsonSendToCommand(NULL,
|
|||
|
g_pModInfoTable[iMod].modAliase,
|
|||
|
CMD_LOG_CONFIG,
|
|||
|
JSON_ENGINE_LOG_CFG_CMD,
|
|||
|
&logItem, TRUE);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Input <pParams> error, pParams2 = %s\n",
|
|||
|
SAFE_STRING_VALUE(pParams2));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
default:
|
|||
|
LOG_EX(LOG_Error, "Unknown operation(0-3) %s, see help\n", pOperat);
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
#if 0
|
|||
|
char* pKeyName = strtok(NULL, " ");
|
|||
|
char *pKeyType = strtok(NULL, " ");
|
|||
|
char* pKeyValue = strtok(NULL, " ");
|
|||
|
char* pSaveTo = strtok(NULL, " ");
|
|||
|
|
|||
|
if(pKeyName && pKeyValue && pKeyType && pSaveTo
|
|||
|
&& strlen(pKeyName) > 0 && strlen(pKeyValue) > 0 && strlen(pKeyType) > 0 && strlen(pSaveTo) > 0)
|
|||
|
{
|
|||
|
CFG_ITEM item;
|
|||
|
|
|||
|
item.pKeyName = pKeyName;
|
|||
|
item.keyType = strtoul(pKeyType, NULL, 10);
|
|||
|
|
|||
|
if(item.keyType == CFG_TYPE_STRING)
|
|||
|
{
|
|||
|
item.pStrValue = pKeyValue;
|
|||
|
}
|
|||
|
else if(item.keyType == CFG_TYPE_INT)
|
|||
|
{
|
|||
|
item.intValue = strtol(pKeyValue, NULL, 10);
|
|||
|
}
|
|||
|
else if(item.keyType == CFG_TYPE_DOUBLE)
|
|||
|
{
|
|||
|
item.doubleValue = strtod(pKeyValue, NULL);
|
|||
|
}
|
|||
|
|
|||
|
ret = CfgAddKeyValue(pKeyName, &item, strtol(pSaveTo, NULL, 10));
|
|||
|
|
|||
|
if(ret == 0)
|
|||
|
{
|
|||
|
CfgItemPrint("Add Configure: ", &item);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Add Configure [%s] Error: %d\n", pKeyName, ret);
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
}
|
|||
|
else if(strcmp(pCmd, "quit") == 0)
|
|||
|
{
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
pCmd = strtok(NULL, " ");
|
|||
|
}
|
|||
|
#endif
|
|||
|
usleep(1000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __uvMsgSendTestProc(void *pParams)
|
|||
|
{
|
|||
|
char buf[DBUS_MSG_MAX_PAD_SIZE];
|
|||
|
unsigned int i = 0;
|
|||
|
|
|||
|
memset(buf, 'a', DBUS_MSG_MAX_PAD_SIZE - 1);
|
|||
|
buf[DBUS_MSG_MAX_PAD_SIZE - 1] = 0;
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
// memset(buf, 0, 256);
|
|||
|
// sprintf(buf, "%u", i);
|
|||
|
|
|||
|
fprintf(stdout, "Send Message: %u\n", i);
|
|||
|
DBusSendToCommand(NULL, g_pModInfoTable[MODULE_CONTROLLER].modAliase, CMD_CALL_DIAL, buf);
|
|||
|
i++;
|
|||
|
sleep(3);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __uvMsgRecvProc(void *pParams)
|
|||
|
{
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
PDBUS_MSG_PACK pMsg = DBusGetMessage();
|
|||
|
PLIBUV_DBUS_PARAMS pInfo = DBusLibuvGetRuntime();
|
|||
|
|
|||
|
do
|
|||
|
{
|
|||
|
if(pMsg && pInfo)
|
|||
|
{
|
|||
|
//static PDBUS_MSG_PACK DBusOnMessage(uv_loop_t* pLoop, DBusConnection* pConn, PDBUS_MSG_PACK pMsg)
|
|||
|
DBusOnMessage(pInfo->pLoop, pInfo->pBus, pMsg);
|
|||
|
DBusMsgCleanup(pMsg);
|
|||
|
}
|
|||
|
|
|||
|
pMsg = DBusGetMessage();
|
|||
|
} while(pMsg && pInfo);
|
|||
|
|
|||
|
|
|||
|
usleep(100);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
void test_dbus(void)
|
|||
|
{
|
|||
|
DBusError error;
|
|||
|
DBusConnection* pBus = NULL;
|
|||
|
|
|||
|
dbus_error_init(&error);
|
|||
|
|
|||
|
pBus = dbus_bus_get(DBUS_BUS_SYSTEM, &error);
|
|||
|
|
|||
|
if (dbus_error_is_set(&error))
|
|||
|
{
|
|||
|
fprintf(stdout, "dbus: Could not acquire the session bus\n");
|
|||
|
|
|||
|
dbus_error_free(&error);
|
|||
|
return;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
fprintf(stdout, "Create Session OK\n");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static unsigned int g_Count1 = 0;
|
|||
|
static void __uvThreadRun(void *pParams)
|
|||
|
{
|
|||
|
g_Count1++;
|
|||
|
usleep(10);
|
|||
|
}
|
|||
|
|
|||
|
static void __uvThreadTestProc(void *pParams)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Test Create Thread\n");
|
|||
|
|
|||
|
for(int i = 0; i < 1000; i++)
|
|||
|
{
|
|||
|
test_task_new(__uvThreadRun, NULL);
|
|||
|
usleep(1);
|
|||
|
}
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Current Cnt: %u\n", g_Count1);
|
|||
|
sleep(1);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
#include "fifo.h"
|
|||
|
|
|||
|
static DECLARE_KFIFO(g_TestFifo, unsigned char, 128);
|
|||
|
|
|||
|
static void __fifoPut(void *pParams)
|
|||
|
{
|
|||
|
int ret = 0;
|
|||
|
static unsigned char val = 0;
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
for(int i = 0; i < 130; i++)
|
|||
|
{
|
|||
|
if(kfifo_avail(&g_TestFifo) < 1)
|
|||
|
{
|
|||
|
ret = kfifo_out(&g_TestFifo, NULL, 1);
|
|||
|
}
|
|||
|
|
|||
|
ret = kfifo_in_locked(&g_TestFifo, &val, 1);
|
|||
|
|
|||
|
if(ret != 1)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Add %d ret %d\n", val, ret);
|
|||
|
}
|
|||
|
val++;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
usleep(10);
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __fifoGet(void *pParams)
|
|||
|
{
|
|||
|
unsigned char val[128];
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
int len = kfifo_len(&g_TestFifo);
|
|||
|
|
|||
|
if(len > 0)
|
|||
|
{
|
|||
|
len = kfifo_out_locked(&g_TestFifo, val, len);
|
|||
|
|
|||
|
print_hex_dump_bytes("", DUMP_PREFIX_OFFSET, val, len);
|
|||
|
fprintf(stdout, "Peek %d\n", len);
|
|||
|
}
|
|||
|
|
|||
|
usleep(1000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __uvThreadTestFifo(void *pParams)
|
|||
|
{
|
|||
|
INIT_KFIFO(g_TestFifo);
|
|||
|
|
|||
|
test_task_new(__fifoPut, NULL);
|
|||
|
sleep(3);
|
|||
|
test_task_new(__fifoGet, NULL);
|
|||
|
}
|
|||
|
|
|||
|
#if 0
|
|||
|
static inline int round_up_pow_of_two(unsigned long x)
|
|||
|
{
|
|||
|
x |= (x >> 1);
|
|||
|
x |= (x >> 2);
|
|||
|
x |= (x >> 4);
|
|||
|
x |= (x >> 8);
|
|||
|
x |= (x >> 16);
|
|||
|
return x + 1;
|
|||
|
}
|
|||
|
|
|||
|
#define WAKE_CACHE_DATA_SIZE1 (1920000U)
|
|||
|
#endif
|
|||
|
|
|||
|
typedef struct
|
|||
|
{
|
|||
|
char* mcuCmd;
|
|||
|
} BYPASS_INFO, *PBYPASS_INFO;
|
|||
|
|
|||
|
typedef struct
|
|||
|
{
|
|||
|
BYPASS_INFO reported;
|
|||
|
} SHADOW_STATE, *PSHADOW_STATE;
|
|||
|
|
|||
|
typedef struct
|
|||
|
{
|
|||
|
char* method;
|
|||
|
int version;
|
|||
|
SHADOW_STATE state;
|
|||
|
} SHADOW_UPDATE, *PSHADOW_UPDATE;
|
|||
|
|
|||
|
static const char* __shadow2Json(PSHADOW_UPDATE pInfo)
|
|||
|
{
|
|||
|
cJSON *pRoot, *pStatus, *pReports;
|
|||
|
|
|||
|
const char* pJsonS;
|
|||
|
|
|||
|
pRoot = cJSON_CreateObject();
|
|||
|
|
|||
|
cJSON_AddNumberToObject(pRoot, "version", pInfo->version);
|
|||
|
cJSON_AddItemToObject(pRoot, "method", cJSON_CreateString(pInfo->method));
|
|||
|
|
|||
|
pStatus = cJSON_CreateObject();
|
|||
|
pReports = cJSON_CreateObject();
|
|||
|
|
|||
|
cJSON_AddItemToObject(pRoot, "status", pStatus);
|
|||
|
cJSON_AddItemToObject(pStatus, "reports", pReports);
|
|||
|
cJSON_AddItemToObject(pReports, "mcuCmd", cJSON_CreateString(pInfo->state.reported.mcuCmd));
|
|||
|
|
|||
|
|
|||
|
pJsonS = cJSON_Print(pRoot);
|
|||
|
|
|||
|
|
|||
|
cJSON_Delete(pRoot);
|
|||
|
|
|||
|
return pJsonS;
|
|||
|
}
|
|||
|
|
|||
|
static void __dlThreadRuntimeCb(void *pParams)
|
|||
|
{
|
|||
|
pthread_detach(pthread_self());
|
|||
|
pthread_exit(0);
|
|||
|
}
|
|||
|
|
|||
|
static void __uvThreadTest(void *pParams)
|
|||
|
{
|
|||
|
for(int i = 0; i < 100000; i++)
|
|||
|
{
|
|||
|
uv_thread_t uvThread;
|
|||
|
int err = uv_thread_create(&uvThread, __dlThreadRuntimeCb, NULL);
|
|||
|
|
|||
|
if(err != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Create Thread Error: %d(%d)\n", err, i);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if(i % 1000 == 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "Create Thread: %d\n", i);
|
|||
|
}
|
|||
|
usleep(1000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static void __dlTestThread(void* p)
|
|||
|
{
|
|||
|
static char* testURL[] = {
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192932533Alianwang003.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192932594Alianwang004.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192932882Alianwang005.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192933094Alianwang006.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192933355Alianwang007.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192933571Alianwang008.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192933805Alianwang009.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192934929Ashiyong002.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192935659Ashiyong003.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192935729Ashiyong004.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192936130Ashiyong005.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192936192Ashiyong006.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192936289S001.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192936471S002.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192937566S006.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192937735S007.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192937793S008.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192938129S009.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192938262S010.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192938975S011.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192933845Alianwang010.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192933937Alianwang011.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180309192934678Ashiyong001.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180605170040224Alianwang012.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180605170146178Alianwang014.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180605170324285Alianwang013.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180605165854636Alianwang002.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180607095314669S004-13DB.mp3",
|
|||
|
"http://vbox-resource.nos.netease.com/20180607095347590S0053DB.mp3",
|
|||
|
"https://vbox-resource.nos-hz.163yun.com/20180625120349098S003+3.mp3",
|
|||
|
};
|
|||
|
|
|||
|
//while(TRUE)
|
|||
|
{
|
|||
|
for(int i = 0; i < sizeof(testURL) / sizeof(testURL[2]); i++)
|
|||
|
{
|
|||
|
char buf[256];
|
|||
|
|
|||
|
g_DlCount++;
|
|||
|
memset(buf, 0, 256);
|
|||
|
sprintf(buf, "./dl_%d.mp3", i);
|
|||
|
InetHttpDlFileAsync(testURL[i],
|
|||
|
buf,
|
|||
|
__onDlCb,
|
|||
|
NULL,//__onPrgCb,
|
|||
|
NULL);
|
|||
|
}
|
|||
|
|
|||
|
while(g_DlCount)
|
|||
|
{
|
|||
|
usleep(100000);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
int main(int argc, char **argv)
|
|||
|
{
|
|||
|
int i, j, ret = 0;
|
|||
|
DBusConnection* pBus = NULL;
|
|||
|
uv_timer_t uvSndLess, uvSndMore;
|
|||
|
uv_loop_t* pLoop = GetDBusDefaultLoop();
|
|||
|
int modIdx = -1;
|
|||
|
char buf[256];
|
|||
|
|
|||
|
#if 0
|
|||
|
FILE* pFile = fopen("/mnt/UDISK/time.txt", "w+");
|
|||
|
|
|||
|
fprintf(stdout, "WAKE_CACHE_DATA_SIZE1(%u) --> %u\n", WAKE_CACHE_DATA_SIZE1, round_up_pow_of_two(WAKE_CACHE_DATA_SIZE1));
|
|||
|
|
|||
|
fprintf(stdout, "127 --> %u\n", roundup_pow_of_two(127));
|
|||
|
|
|||
|
fprintf(stdout, "3 --> %u\n", roundup_pow_of_two(3));
|
|||
|
|
|||
|
fprintf(stdout, "256 --> %u\n", roundup_pow_of_two(256));
|
|||
|
|
|||
|
fprintf(stdout, "1024 * 2 - 1 --> %u\n", roundup_pow_of_two(1024 * 2 - 1));
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
fprintf(stdout, "Wait system reboot for 10s");
|
|||
|
ret = system("sync && ubus call system watchdog \'{\"stop\" : true}\'");
|
|||
|
|
|||
|
sleep(20);
|
|||
|
|
|||
|
fprintf(stdout, "Wait WDT 20s End\n");
|
|||
|
#endif
|
|||
|
|
|||
|
#if 0
|
|||
|
int fd = open("/dev/watchdog", O_WRONLY);
|
|||
|
|
|||
|
if(fd == -1)
|
|||
|
{
|
|||
|
perror("Open WDT");
|
|||
|
}
|
|||
|
|
|||
|
sleep(20);
|
|||
|
|
|||
|
fprintf(stdout, "Wait WDT 20s\n");
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef PLATFORM_R16
|
|||
|
#endif
|
|||
|
|
|||
|
//fprintf(stdout, "uv_default_loop = %p\n", pLoop);
|
|||
|
|
|||
|
if(argc <= 1)
|
|||
|
{
|
|||
|
fprintf(stderr, "usage: ./dbus-r16.exe <0-%d>\n", MODULE_MAX - 1);
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
modIdx = strtol(argv[1], NULL, 10);
|
|||
|
|
|||
|
if(modIdx >= MODULE_MAX || modIdx < 0)
|
|||
|
{
|
|||
|
fprintf(stderr, "Bad params of %s, max value is %d\n", argv[1], MODULE_MAX - 1);
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
memcpy(&g_ModInfo, &g_pModInfoTable[modIdx], sizeof(MOD_INFO_TABLE));
|
|||
|
|
|||
|
pBus = DBusWithLibuvInit(pLoop, g_ModInfo.modAliase,
|
|||
|
DBusOnMessage,
|
|||
|
NULL,
|
|||
|
NULL,
|
|||
|
&ret);
|
|||
|
|
|||
|
if(pBus == NULL)
|
|||
|
{
|
|||
|
fprintf(stderr, "DBusWithLibuvInit Error: %d\n", ret);
|
|||
|
exit(1);
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
//test_task_new(__uvThreadTest, NULL);
|
|||
|
|
|||
|
DumpCurServerAddr("Default");
|
|||
|
|
|||
|
#if 1
|
|||
|
for(int i = 0; i < 1; i++)
|
|||
|
{
|
|||
|
char buf[256];
|
|||
|
|
|||
|
memset(buf, 0, 256);
|
|||
|
|
|||
|
sprintf(buf, "dl_%d.bin", i);
|
|||
|
|
|||
|
InetHttpDlFileAsync("http://10.240.84.163/tina_r16_ota_21.tar.gz",
|
|||
|
//"https://vbox-resource.nos-hz.163yun.com/20180628092806976tina_r16_ota_32.tar.gz",
|
|||
|
buf,
|
|||
|
__onDlCb,
|
|||
|
NULL,//__onPrgCb,
|
|||
|
NULL);
|
|||
|
}
|
|||
|
#endif
|
|||
|
//SetCurrentServerMode(DEV_MODE);
|
|||
|
//DumpCurServerAddr("DEV_MODE");
|
|||
|
|
|||
|
#if 0
|
|||
|
SetCurrentServerMode(TEST_MODE);
|
|||
|
DumpCurServerAddr("TEST_MODE");
|
|||
|
|
|||
|
SetCurrentServerMode(PUBLISH_MODE);
|
|||
|
DumpCurServerAddr("PUBLISH_MODE");
|
|||
|
#endif
|
|||
|
|
|||
|
//test_task_new(__uvMsgRecvProc, NULL);
|
|||
|
|
|||
|
//HttpPostLogFile("{}");
|
|||
|
|
|||
|
//SysPointMarkInit("123456", -1, -1);
|
|||
|
|
|||
|
//SysPointMarkUpload();
|
|||
|
#if 0
|
|||
|
for(int i = 0; i < 1000; i++)
|
|||
|
{
|
|||
|
void* pMalloc = malloc(1024 * 1024);
|
|||
|
|
|||
|
if(pMalloc == NULL)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "%d: Malloc Error\n", i);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "%d: Malloc %p\n", i, pMalloc);
|
|||
|
|
|||
|
memset(pMalloc, 0, 1024 * 1024);
|
|||
|
}
|
|||
|
|
|||
|
usleep(100000);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
#if 0
|
|||
|
g_pOnKevEvt = (uv_fs_event_t*)malloc(sizeof(uv_fs_event_t));
|
|||
|
|
|||
|
uv_fs_event_init(pLoop, g_pOnKevEvt);
|
|||
|
|
|||
|
uv_fs_event_start(g_pOnKevEvt, run_command, "./1.txt", UV_FS_EVENT_RECURSIVE);
|
|||
|
#endif
|
|||
|
|
|||
|
//test_task_new(__dlTestThread, NULL);
|
|||
|
#if 0
|
|||
|
if(modIdx == 20)
|
|||
|
{
|
|||
|
IHW_EnableLogLevel(LOG_All, 1);
|
|||
|
test_task_new(__uvLogCtrlProc, NULL);
|
|||
|
}
|
|||
|
else if(modIdx == 19)
|
|||
|
{
|
|||
|
test_task_new(__uvLogTestProc, NULL);
|
|||
|
}
|
|||
|
else if(modIdx == 21)
|
|||
|
{
|
|||
|
test_task_new(__uvMsgSendTestProc, NULL);
|
|||
|
}
|
|||
|
else if(modIdx == 15)
|
|||
|
{
|
|||
|
test_task_new(__uvThreadTestProc, NULL);
|
|||
|
}
|
|||
|
else if(modIdx == 16)
|
|||
|
{
|
|||
|
test_task_new(__uvThreadTestFifo, NULL);
|
|||
|
}
|
|||
|
#endif
|
|||
|
//LOG_EX(LOG_Debug, "Chip Serial: [%s]\n", GetCpuSerial());
|
|||
|
//LOG_EX(LOG_Debug, "Chip ID: [%s]\n", GetCpuChipId());
|
|||
|
|
|||
|
//LOG_BUF(LOG_Error, g_pModInfoTable, 64);
|
|||
|
|
|||
|
// DBusWithLibuvCfgInit(OnCfgMsgCb);
|
|||
|
|
|||
|
#if 0
|
|||
|
uv_timer_init(pLoop, &uvSndLess);
|
|||
|
uvSndLess.data = pBus;
|
|||
|
uv_timer_start(&uvSndLess, uvSndLessCb, 1000, 3000);
|
|||
|
#endif
|
|||
|
//uv_timer_init(pLoop, &uvSndMore);
|
|||
|
//uv_timer_start(&uvSndMore, uvTimeoutCb, 3000, 10000);
|
|||
|
//EvpEncrypto();
|
|||
|
//LOG_EX(LOG_Info, "Struct --> Json: [%s]\n", Struct2Json(NULL, 0));
|
|||
|
|
|||
|
//Json2Struct(NULL, 0);
|
|||
|
|
|||
|
//free((void*)EvpBase64Encode(pSrc));
|
|||
|
|
|||
|
//LOG_EX(LOG_Debug, "Base")
|
|||
|
//free((void*)EvpMD5HashFile("/root/time.txt"));
|
|||
|
//test_evp_aes();
|
|||
|
//test_aes_async();
|
|||
|
//test_base64_async();
|
|||
|
//test_md5file_async();
|
|||
|
//test_task_new(__uvThreadTestConfigure);
|
|||
|
//test_task_new(__uvThreadTestOTA, NULL);
|
|||
|
//test_task_new(__uvThreadTimer, NULL);
|
|||
|
//uv_timer_init(GetDBusDefaultLoop(), &g_tmTest);
|
|||
|
//LOG_EX(LOG_Info, "Start Timer............\n");
|
|||
|
//uv_timer_start(&g_tmTest, uvSndLessCb, g_Delay, 0);
|
|||
|
|
|||
|
//test_task_new(__uvThreadTimer, NULL);
|
|||
|
//test_s2j_task();
|
|||
|
|
|||
|
//test_base64_async();
|
|||
|
|
|||
|
//test_move_data();
|
|||
|
|
|||
|
//AlarmTimerInit(pLoop);
|
|||
|
|
|||
|
#if 0
|
|||
|
for(i = REPEAT_MODE_NONE; i <= REPEAT_MODE_HOLIDAY; i++)
|
|||
|
{
|
|||
|
{
|
|||
|
AlarmTimerAdd2(2017 - 1900, 11 - 1, 28,
|
|||
|
13, 50, 30,
|
|||
|
0,
|
|||
|
i,
|
|||
|
NULL, 0, 0, NULL, NULL);
|
|||
|
|
|||
|
AlarmTimerAdd2(2017-1900, 11-1, 28,
|
|||
|
23, 50, 30,
|
|||
|
0,
|
|||
|
i,
|
|||
|
NULL, 0, 1, NULL, NULL);
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
struct tm localTime;
|
|||
|
time_t timeStamp = time((time_t*)NULL) + 10;
|
|||
|
localtime_r(&timeStamp, &localTime);
|
|||
|
|
|||
|
AlarmTimerAdd(2018-1900, 6-1, 26,
|
|||
|
localTime.tm_hour, localTime.tm_min, localTime.tm_sec,
|
|||
|
0,
|
|||
|
REPEAT_MODE_MONTH_LAST_DAY,
|
|||
|
__onAlarmCb, 0, NULL, NULL);
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
for(i = REPEAT_MODE_NONE; i <= REPEAT_MODE_HOLIDAY; i++)
|
|||
|
{
|
|||
|
struct tm localTime;
|
|||
|
|
|||
|
localtime_r(&timeStamp, &localTime);
|
|||
|
|
|||
|
AlarmTimerAdd(2017-1900, 11-1, 29,
|
|||
|
localTime.tm_hour, localTime.tm_min, localTime.tm_sec,
|
|||
|
0,
|
|||
|
1,
|
|||
|
NULL, 0, i % 2, NULL, NULL);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
//InetSmtpSendEmail();
|
|||
|
|
|||
|
#if 1
|
|||
|
#if 1
|
|||
|
|
|||
|
#endif
|
|||
|
#if 0
|
|||
|
if(modIdx == 18)
|
|||
|
{
|
|||
|
SkinInit();
|
|||
|
//SkinIsVerifyRes(TRUE);
|
|||
|
#if 0
|
|||
|
char* path = "/mnt/UDISK/skinupgrade.txt";
|
|||
|
char* pUpgCmd = "[{\"createTime\":1517832224000,\"enable\":1,\"id\":170,"
|
|||
|
"\"md5\":\"0c8d2d487e485cf3553d7e2818ac42d9\",\"osType\":0,"
|
|||
|
"\"remark\":\"101\",\"resourceName\":\"v101\",\"resourceType\":1,"
|
|||
|
"\"resourceVersion\":\"0.3.2\",\"size\":33734,\"updateTime\":1517832224000,"
|
|||
|
"\"url\":\"http://vbox-resource.nos.netease.com/2536ded2-71a5-40ab-98dc-fe824fbbfb64.mp3\","
|
|||
|
"\"versionId\":68,\"versionName\":\"0.3.2\",\"versionOsType\":\"0\"}]";
|
|||
|
|
|||
|
|
|||
|
FILE* pFp = fopen(path, "rw");
|
|||
|
int fileSize = 0;
|
|||
|
|
|||
|
GET_FILE_SIZE(path, fileSize);
|
|||
|
|
|||
|
|
|||
|
fprintf(stdout, "%s size = %d\n", path, fileSize);
|
|||
|
|
|||
|
if(pFp && fileSize > 0)
|
|||
|
{
|
|||
|
char* pData = (char*)malloc(fileSize);
|
|||
|
|
|||
|
ret = fread(pData, fileSize, 1, pFp);
|
|||
|
|
|||
|
fprintf(stdout, "Read: %s\n", pData);
|
|||
|
|
|||
|
fclose(pFp);
|
|||
|
|
|||
|
SkinUpgrade(pData);
|
|||
|
|
|||
|
free(pData);
|
|||
|
}
|
|||
|
#else
|
|||
|
//const char* GetSkinsResource(const char [in] *pKeyName, int [out] *pResType, int [out] *pVersion, const char [out] **pComeFrom)
|
|||
|
|
|||
|
//fprintf(stdout, "[v001] = {%s}\n", GetSkinsResource("v001", NULL, NULL, NULL));
|
|||
|
//fprintf(stdout, "[v109] = {%s}\n", GetSkinsResource("v109", NULL, NULL, NULL));
|
|||
|
//fprintf(stdout, "[v311] = {%s}\n", GetSkinsResource("v311", NULL, NULL, NULL));
|
|||
|
|
|||
|
//test_task_new(__uvTestSkin, NULL);
|
|||
|
#endif
|
|||
|
}
|
|||
|
#endif
|
|||
|
#endif
|
|||
|
|
|||
|
#if 0
|
|||
|
#define MAIL_SENDER ("pv1_es2@163.com")
|
|||
|
#define SENDER_PASSWORD ("pv1Dev163")
|
|||
|
#define MAIL_RECEIVER ("pv1_es2@163.com")
|
|||
|
#define MAIL_SERVER ("smtps://smtp.163.com")
|
|||
|
//#else
|
|||
|
#define MAIL_SENDER ("pv1_es2@hotmail.com")
|
|||
|
#define SENDER_PASSWORD ("netEase163")
|
|||
|
#define MAIL_RECEIVER ("pv1_es2@163.com")
|
|||
|
#define MAIL_SERVER ("smtp://smtp-mail.outlook.com")
|
|||
|
#endif
|
|||
|
|
|||
|
#if 0
|
|||
|
SMTP_MAIL_CONFIG smtpCfg;
|
|||
|
memset(&smtpCfg, 0, sizeof(SMTP_MAIL_CONFIG));
|
|||
|
|
|||
|
smtpCfg.pUserName = MAIL_SENDER;
|
|||
|
smtpCfg.pPassword = SENDER_PASSWORD;
|
|||
|
smtpCfg.pSmtpServer = MAIL_SERVER;
|
|||
|
|
|||
|
const char *pFrom = MAIL_SENDER;
|
|||
|
const char *pTo[] = {"pv1_es2@163.com", "pv1_es2@126.com", NULL};
|
|||
|
const char *pCc[] = {"xajhuang@qq.com", "xajhuang@163.com", NULL};
|
|||
|
const char *pTitle = "Log Message";
|
|||
|
const char *pMessage = "Hi All: This is log backup mail.";
|
|||
|
const char *pAttact[] = {"mail.txt", "time.txt", NULL};
|
|||
|
|
|||
|
InetSmtpSendEmail(pFrom, pTo, pCc, pTitle, pMessage, pAttact, &smtpCfg);
|
|||
|
#endif
|
|||
|
|
|||
|
// InetHttpUploadFileSync(UPL_HTTP_URL, "./time.txt");
|
|||
|
#if 0
|
|||
|
if((i = GZipFileCompress("./input.txt", "./input.gz")) != 0)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Error, "Create Gzip File Error: %d\n", i);
|
|||
|
}
|
|||
|
//#else
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
for(i = 0; i < 3010; i++)
|
|||
|
{
|
|||
|
LOG_EX(LOG_Debug, "This is log %d\n", j++);
|
|||
|
}
|
|||
|
|
|||
|
sleep(1);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
RunUVLoop(pLoop);
|
|||
|
|
|||
|
while(TRUE)
|
|||
|
{
|
|||
|
usleep(1000);
|
|||
|
}
|
|||
|
|
|||
|
return (0);
|
|||
|
}
|