324 lines
8.8 KiB
C
324 lines
8.8 KiB
C
/****************************************************************************
|
|
|
|
Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED.
|
|
|
|
This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT
|
|
be copied by any method or incorporated into another program without
|
|
the express written consent of Aerospace C.Power. This Information or any portion
|
|
thereof remains the property of Aerospace C.Power. The Information contained herein
|
|
is believed to be accurate and Aerospace C.Power assumes no responsibility or
|
|
liability for its use in any way and conveys no license or title under
|
|
any patent or copyright and makes no representation or warranty that this
|
|
Information is free from patent or copyright infringement.
|
|
|
|
****************************************************************************/
|
|
|
|
#include "app_main.h"
|
|
#include "app_common.h"
|
|
|
|
uint8_t g_printf_enable = true;
|
|
|
|
uint32_t get_random_num32(uint32_t min, uint32_t max)
|
|
{
|
|
uint32_t random = 0;
|
|
uint32_t module = max + 1 - min;
|
|
|
|
if (module == 0) {
|
|
module = 0xffffffff;
|
|
}
|
|
|
|
random = os_rand();
|
|
|
|
return (uint32_t)((random % module) + min);
|
|
}
|
|
|
|
/* Set Carrier Communication Frequency Band */
|
|
void app_set_freq_band(uint8_t band_id)
|
|
{
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
APP_PRINTF("[INF] %s Set band to id:%d", __FUNCTION__, band_id);
|
|
|
|
iot_plc_set_freq_band(app_entry->app_hdl, IOT_PLC_API_REQ_ID_DEFAULT, band_id);
|
|
|
|
return;
|
|
}
|
|
|
|
/* Set scan band bitmap */
|
|
void app_set_scan_band_bitmap(uint8_t *band_bitmap)
|
|
{
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
APP_PRINT_BUF("[INF]Set scan band bitmap", band_bitmap, IOT_PLC_BAND_BITMAP_SIZE);
|
|
|
|
iot_plc_set_scan_band_bitmap(app_entry->app_hdl, IOT_PLC_API_REQ_ID_DEFAULT,
|
|
band_bitmap, IOT_PLC_BAND_BITMAP_SIZE);
|
|
|
|
return;
|
|
}
|
|
|
|
void app_get_user_info(app_user_info_t *user_info)
|
|
{
|
|
iot_pkt_t *pkt_buf;
|
|
uint8_t temp[2];
|
|
|
|
pkt_buf = iot_pkt_alloc(sizeof(iot_build_info_t), IOT_APP_DEMO_MID);
|
|
if (NULL == pkt_buf) {
|
|
APP_PRINTF("[ERR] %s Packet Alloc Failed !!", __FUNCTION__);
|
|
return;
|
|
}
|
|
|
|
iot_build_info_t *info = (iot_build_info_t *)iot_pkt_put(pkt_buf, sizeof(iot_build_info_t));
|
|
iot_version_get_user_build_info(info);
|
|
|
|
user_info->sw_ver = APP_VER2BCD(iot_version_micro(), APP_SW_VERSION_R, iot_version_build());
|
|
user_info->boot_ver = APP_BOOT_VER;
|
|
user_info->year = info->year;
|
|
user_info->month = info->month;
|
|
user_info->day = info->day;
|
|
|
|
temp[0] = (uint8_t)(MANU_CODE);
|
|
temp[1] = (uint8_t)(MANU_CODE>>8);
|
|
os_mem_cpy(user_info->manu_code,temp, sizeof(user_info->manu_code));
|
|
temp[0] = (uint8_t)(WQ_CHIP3011);
|
|
temp[1] = (uint8_t)(WQ_CHIP3011>>8);
|
|
os_mem_cpy(user_info->chip_code,temp,sizeof(user_info->chip_code));
|
|
iot_pkt_free(pkt_buf);
|
|
|
|
return;
|
|
}
|
|
|
|
uint8_t *app_get_cco_mac_addr(void)
|
|
{
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
return app_entry->dev.cco_addr;
|
|
}
|
|
|
|
uint8_t *app_get_mac_addr(void)
|
|
{
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
return app_entry->dev.mac_addr;
|
|
}
|
|
|
|
void app_set_mac_addr(uint8_t *mac)
|
|
{
|
|
iot_plc_cfg_set_req_t cfg;
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
APP_PRINTF("[INF] Set Device MAC: %02x-%02x-%02x-%02x-%02x-%02x",
|
|
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
|
|
os_mem_set(&cfg, 0, sizeof(cfg));
|
|
|
|
cfg.addr_valid = 1;
|
|
cfg.addr_type = IOT_PLC_MAC_ADDR_TYPE_MODULE;
|
|
iot_mac_addr_cpy(cfg.addr, mac);
|
|
cfg.reset = 1;
|
|
|
|
iot_plc_set_cfg(app_entry->app_hdl, IOT_PLC_API_REQ_ID_DEFAULT, &cfg);
|
|
}
|
|
|
|
uint8_t app_get_online_state(void)
|
|
{
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
return app_entry->dev.dev_ready;
|
|
}
|
|
|
|
uint8_t app_get_log_enable(void)
|
|
{
|
|
return g_printf_enable;
|
|
}
|
|
|
|
void app_set_log_enable(uint8_t flag)
|
|
{
|
|
g_printf_enable = flag;
|
|
}
|
|
|
|
uint16_t app_timer_callback(timer_id_t tid, void *arg)
|
|
{
|
|
iot_task_msg_t *msg;
|
|
app_msg_t *task_msg;
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
msg = iot_task_alloc_msg_with_reserved(app_entry->msg_task.handle, 0);
|
|
if (NULL == msg) {
|
|
APP_PRINTF("[ERR] %s Alloc MSG Buffer Failed !!", __FUNCTION__);
|
|
return ERR_FAIL;
|
|
}
|
|
|
|
task_msg = (app_msg_t *)msg;
|
|
task_msg->msg.type = E_APP_MSG_TIMER;
|
|
task_msg->msg.id = (app_timer_id_e)arg;
|
|
task_msg->data = (void*)tid;
|
|
iot_task_queue_msg(app_entry->msg_task.handle, &task_msg->msg, APP_TASK_MSG_PRIO);
|
|
|
|
return ERR_OK;
|
|
}
|
|
|
|
timer_id_t app_timer_start(app_timer_id_e id, uint32_t period, uint8_t type)
|
|
{
|
|
timer_id_t tm_id = 0;
|
|
|
|
/* Create a timer */
|
|
tm_id = os_create_timer(IOT_APP_DEMO_MID, type,
|
|
(os_timer_func_t)app_timer_callback, (void *)id);
|
|
if (0 == tm_id) {
|
|
APP_PRINTF("[ERR] %s Create Timer %d Failed !!", __FUNCTION__, id);
|
|
return tm_id;
|
|
}
|
|
|
|
/* Start the timer */
|
|
os_start_timer(tm_id, period);
|
|
|
|
return tm_id;
|
|
}
|
|
|
|
uint8_t app_get_net_enable(void)
|
|
{
|
|
app_entity_t *app_entry = app_get_main_entry();
|
|
|
|
return app_entry->net_enable;
|
|
}
|
|
|
|
void app_set_net_enable(uint8_t flag)
|
|
{
|
|
app_entity_t *app_entry = app_get_main_entry();
|
|
|
|
flag = !!flag;
|
|
if (flag != app_entry->net_enable) {
|
|
app_entry->net_enable = flag;
|
|
if (flag) {
|
|
iot_plc_start_nw_fmt(app_entry->app_hdl, 0);
|
|
} else {
|
|
iot_plc_stop_nw_fmt(app_entry->app_hdl);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* send data to dst_addr throw plc, add app_custom_data before data */
|
|
uint16_t app_plc_tx(uint8_t *data, uint16_t data_length, uint8_t *dst_addr,
|
|
uint16_t id, append_tx_info_t *tx_info)
|
|
{
|
|
iot_pkt_t *pkt;
|
|
uint8_t *frame;
|
|
uint16_t frame_length;
|
|
app_custom_data *custom_data;
|
|
append_tx_info_t def_tx_info = {0};
|
|
|
|
if (NULL == data || 0 == data_length) {
|
|
APP_PRINTF("[ERR] %s Frame is NULL !!", __FUNCTION__);
|
|
return ERR_FAIL;
|
|
}
|
|
|
|
if(!iot_mac_addr_valid(dst_addr)) {
|
|
APP_PRINTF("[ERR] invalid dst addr, data[%d] dropped !!", data_length);
|
|
return ERR_FAIL;
|
|
}
|
|
|
|
frame_length = data_length + sizeof(app_custom_data) + sizeof(append_tx_info_t);
|
|
pkt = iot_pkt_alloc(frame_length, IOT_APP_DEMO_MID);
|
|
if (NULL == pkt) {
|
|
APP_PRINTF("[ERR] %s Packet Alloc Failed !!", __FUNCTION__);
|
|
return ERR_FAIL;
|
|
}
|
|
|
|
frame = iot_pkt_put(pkt, frame_length);
|
|
if (tx_info) {
|
|
/* fill tx_info if trans not NULL, else use default 0 */
|
|
os_mem_cpy(frame, tx_info, sizeof(append_tx_info_t));
|
|
} else {
|
|
os_mem_cpy(frame, &def_tx_info, sizeof(append_tx_info_t));
|
|
}
|
|
frame += sizeof(append_tx_info_t);
|
|
custom_data = (app_custom_data*)frame;
|
|
custom_data->id = id;
|
|
iot_mac_addr_cpy(custom_data->mac, dst_addr);
|
|
frame += sizeof(app_custom_data);
|
|
os_mem_cpy(frame, data, data_length);
|
|
|
|
APP_PRINT_BUF("[PLC_TX]", iot_pkt_data(pkt), iot_pkt_data_len(pkt));
|
|
|
|
APP_PRINTF("pkt id[%x] will be sent to "MAC_FMT, custom_data->id,
|
|
MAC_ARG(custom_data->mac));
|
|
|
|
if (ERR_OK != app_post_msg(E_APP_MSG_PROCESS, E_CMD_ID_SEND_DATA_TO_PLC,
|
|
(void*)pkt)) {
|
|
APP_PRINTF("[ERR] %s Post MSG Failed !!", __FUNCTION__);
|
|
iot_pkt_free(pkt);
|
|
return ERR_FAIL;
|
|
}
|
|
|
|
return ERR_OK;
|
|
}
|
|
|
|
#if PLC_SUPPORT_CCO_ROLE
|
|
void app_ntb_to_us(uint8_t *data)
|
|
{
|
|
uint8_t *pdata = data;
|
|
uint8_t i;
|
|
uint32_t timebuf;
|
|
uint32_t timebuf_next;
|
|
uint8_t overflow_sign = false;
|
|
|
|
/* current_type is not smaller than overflow_index means value is
|
|
* overflow, the value should add a (0xFFFFFFFF / 25)
|
|
*/
|
|
for (i = CCO_TX_TIME; i <= CCO_RX_TIME; i++) {
|
|
pdata = data + sizeof(uint32_t) * i;
|
|
timebuf =iot_bytes_to_uint32(pdata, 0);
|
|
if ((overflow_sign == false) && (i < CCO_RX_TIME)) {
|
|
timebuf_next = iot_bytes_to_uint32(pdata + sizeof(uint32_t), 0);
|
|
if (timebuf > timebuf_next) {
|
|
overflow_sign = true;
|
|
}
|
|
}
|
|
|
|
if (overflow_sign) {
|
|
timebuf = (timebuf + (0xFFFFFFFF % 25)) / 25 + 0xFFFFFFFF / 25;
|
|
} else {
|
|
timebuf /= 25;
|
|
}
|
|
iot_uint32_to_bytes(timebuf, pdata, 0);
|
|
}
|
|
}
|
|
#endif /* PLC_SUPPORT_CCO_ROLE */
|
|
|
|
void delay_timer_get(uint8_t *data, uint8_t time_type, uint32_t set_time)
|
|
{
|
|
uint32_t cur_time ;
|
|
app_entity_t *app_entry = NULL;
|
|
|
|
app_entry = app_get_main_entry();
|
|
|
|
if (set_time == 0) {
|
|
cur_time = iot_plc_get_ntb(app_entry->app_hdl);
|
|
} else {
|
|
cur_time = set_time;
|
|
}
|
|
|
|
if (time_type > CCO_RX_TIME) {
|
|
APP_PRINTF("[ERR] %s get type error", __FUNCTION__);
|
|
return;
|
|
}
|
|
|
|
os_mem_cpy(data + sizeof(uint32_t) * time_type , &cur_time, sizeof(uint32_t));
|
|
APP_PRINT_BUF("now timer is :", data, sizeof(delay_time_test));
|
|
}
|
|
|