320 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			320 lines
		
	
	
		
			9.3 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 "os_utils_api.h"
 | |
| 
 | |
| #include "iot_board.h"
 | |
| #include "iot_io_api.h"
 | |
| #include "iot_upgrade_api.h"
 | |
| 
 | |
| #include "iot_cli.h"
 | |
| #include "iot_cli_host_interface.h"
 | |
| #include "iot_cli_plc_module.h"
 | |
| #include "iot_cli_common.h"
 | |
| #include "iot_cli_plc_tx_rx.h"
 | |
| #include "iot_cli_set_info.h"
 | |
| 
 | |
| extern iot_plc_host_config_t *host_config;
 | |
| extern iot_cli_t cli;
 | |
| 
 | |
| timer_id_t set_info_timer;
 | |
| uint8_t    set_id;
 | |
| 
 | |
| #if (IOT_STA_CONTROL_MODE == IOT_STA_CONTROL_TYPE_STA)
 | |
| static void cli_set_vendor_local_ack(uint8_t *src_mac)
 | |
| {
 | |
|     cli_vendor_report report;
 | |
|     report.set_id = set_id;
 | |
|     iot_mac_addr_cpy(report.dst, host_config->mac_addr);
 | |
|     iot_cli_send_to_host(CLI_MSGID_SET_VENDOR_ACK,
 | |
|         (uint8_t*)&report, sizeof(cli_vendor_report), src_mac);
 | |
| }
 | |
| #endif
 | |
| 
 | |
| /* cli set vendor handler */
 | |
| void cli_set_vendor(
 | |
|     uint8_t *buffer, uint32_t bufferlen, uint8_t *src_mac)
 | |
| {
 | |
|     (void)src_mac;
 | |
|     cli_vendor_info *vendor_info =
 | |
|         (cli_vendor_info *)buffer;
 | |
| 
 | |
|     if ((!vendor_info) || (bufferlen < sizeof(*vendor_info))) {
 | |
|         iot_printf("dev save vendor, invalid para\n");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     if (host_config->dev_role != IOT_PLC_DEV_ROLE_CCO) {
 | |
| 
 | |
|         if (set_id != vendor_info->set_id)
 | |
|         {
 | |
|             iot_printf("sta set vendor %lu %lu\n",
 | |
|                 set_id, vendor_info->set_id);
 | |
|             iot_board_save_user_vendor_id(vendor_info->vendor);
 | |
|             set_id = vendor_info->set_id;
 | |
|         } else {
 | |
|             iot_printf("sta vendor already set\n");
 | |
|         }
 | |
| 
 | |
| #if (IOT_STA_CONTROL_MODE == IOT_STA_CONTROL_TYPE_STA)
 | |
|         cli_set_vendor_local_ack(src_mac);
 | |
| #else
 | |
|         if (!os_is_timer_active(set_info_timer) &&
 | |
|             vendor_info->control) {
 | |
|             if (vendor_info->report_window >
 | |
|                 CLI_SET_VENDOR_TIME_WINDOW) {
 | |
|                 vendor_info->report_window =
 | |
|                     CLI_SET_VENDOR_TIME_WINDOW;
 | |
|             }
 | |
|             os_start_timer(set_info_timer,
 | |
|                 os_rand() % vendor_info->report_window);
 | |
|         }
 | |
| #endif
 | |
|     }
 | |
| #if PLC_SUPPORT_CCO_ROLE
 | |
|     else {
 | |
|         cli_set_vendor_ack ack;
 | |
| 
 | |
|         ack.result = 0;
 | |
|         iot_cli_send_to_host(CLI_MSGID_SET_VENDOR_ACK,
 | |
|             (uint8_t *)&ack, sizeof(ack), src_mac);
 | |
| 
 | |
|         if (iot_mac_addr_cmp(host_config->mac_addr, vendor_info->dst))
 | |
|         {
 | |
|             // set cco
 | |
|             if (set_id != vendor_info->set_id) {
 | |
|                 iot_printf("cco set vendor %lu %lu\n",
 | |
|                     set_id, vendor_info->set_id);
 | |
|                 iot_board_save_user_vendor_id(vendor_info->vendor);
 | |
|                 set_id = vendor_info->set_id;
 | |
|             } else {
 | |
|                 iot_printf("cco vendor already set\n");
 | |
|             }
 | |
|         } else {
 | |
|             // set sta
 | |
|             uint8_t send_type = IOT_PLC_MSG_TYPE_UNICAST;
 | |
| 
 | |
|             // store requet id for vendor report
 | |
|             host_config->cli_request_id =
 | |
|                 add_addr_to_mapping_table(src_mac);
 | |
| 
 | |
|             // check if broadcast
 | |
|             if (iot_mac_is_bcast(vendor_info->dst)) {
 | |
|                 send_type = IOT_PLC_MSG_TYPE_BCAST;
 | |
|             }
 | |
| 
 | |
|             iot_printf("cco forward set cmd stype %lu\n", send_type);
 | |
|             iot_cli_host_send_data_plc(
 | |
|                 send_type, CLI_MSGID_SET_VENDOR,
 | |
|                 vendor_info->dst, buffer, bufferlen);
 | |
|         }
 | |
|     }
 | |
| #endif
 | |
| }
 | |
| 
 | |
| /* dev save build info func */
 | |
| static void cli_dev_save_build_info(cli_build_info *build_info)
 | |
| {
 | |
|     iot_build_info_t iot_build_info;
 | |
| 
 | |
|     if (!build_info) {
 | |
|         iot_printf("dev save build info, invalid para\n");
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     iot_build_info.sw_ver = build_info->sw_ver;
 | |
|     iot_build_info.year = build_info->year;
 | |
|     iot_build_info.month = build_info->month;
 | |
|     iot_build_info.day = build_info->day;
 | |
|     iot_build_info.hour = build_info->hour;
 | |
|     iot_build_info.min = build_info->min;
 | |
|     iot_build_info.sec = build_info->sec;
 | |
|     iot_board_save_user_build_info(&iot_build_info);
 | |
| }
 | |
| 
 | |
| /* cli set build info handler */
 | |
| void cli_set_build_info(
 | |
|     uint8_t *buffer, uint32_t bufferlen, uint8_t *src_mac)
 | |
| {
 | |
|     (void)src_mac;
 | |
|     cli_build_info *build_info =
 | |
|         (cli_build_info *)buffer;
 | |
| 
 | |
|     if ((!build_info) || (bufferlen < sizeof(*build_info))) {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     if (host_config->dev_role != IOT_PLC_DEV_ROLE_CCO) {
 | |
| 
 | |
|         if (set_id != build_info->set_id)
 | |
|         {
 | |
|             iot_printf("sta set build info %lu %lu %lu\n",
 | |
|                 set_id, build_info->set_id, build_info->sw_ver);
 | |
|             cli_dev_save_build_info(build_info);
 | |
|             set_id = build_info->set_id;
 | |
|         } else {
 | |
|             iot_printf("sta build info already set\n");
 | |
|         }
 | |
| 
 | |
|         if (!os_is_timer_active(set_info_timer) &&
 | |
|             build_info->control) {
 | |
|             if (build_info->report_window >
 | |
|                 CLI_SET_VENDOR_TIME_WINDOW) {
 | |
|                 build_info->report_window =
 | |
|                     CLI_SET_VENDOR_TIME_WINDOW;
 | |
|             }
 | |
|             os_start_timer(
 | |
|                 set_info_timer,
 | |
|                 os_rand() % build_info->report_window);
 | |
|         }
 | |
|     }
 | |
| #if PLC_SUPPORT_CCO_ROLE
 | |
|     else {
 | |
|         cli_set_build_info_ack ack;
 | |
| 
 | |
|         ack.result = 0;
 | |
|         iot_cli_send_to_host(CLI_MSGID_SET_BUILD_INFO_ACK,
 | |
|             (uint8_t *)&ack, sizeof(ack), src_mac);
 | |
| 
 | |
|         if (iot_mac_addr_cmp(host_config->mac_addr, build_info->dst))
 | |
|         {
 | |
|             // set cco
 | |
|             if (set_id != build_info->set_id) {
 | |
|                 iot_printf("cco set build info %lu %lu\n",
 | |
|                     set_id, build_info->set_id);
 | |
|                 cli_dev_save_build_info(build_info);
 | |
|                 set_id = build_info->set_id;
 | |
|             } else {
 | |
|                 iot_printf("cco build info already set\n");
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             // set sta
 | |
|             uint8_t send_type = IOT_PLC_MSG_TYPE_UNICAST;
 | |
| 
 | |
|             // store requet id for vendor report
 | |
|             host_config->cli_request_id = add_addr_to_mapping_table(src_mac);
 | |
| 
 | |
|             // check if broadcast
 | |
|             if (iot_mac_is_bcast(build_info->dst)) {
 | |
|                 send_type = IOT_PLC_MSG_TYPE_BCAST;
 | |
|             }
 | |
| 
 | |
|             iot_printf("cco forward set cmd stype %lu\n", send_type);
 | |
| 
 | |
|             iot_cli_host_send_data_plc(send_type, CLI_MSGID_SET_BUILD_INFO,
 | |
|                 build_info->dst, buffer, bufferlen);
 | |
|         }
 | |
|     }
 | |
| #endif
 | |
| }
 | |
| 
 | |
| #if PLC_SUPPORT_CCO_ROLE
 | |
| /* cco handle venfor report from sta */
 | |
| void cli_set_vendor_report(
 | |
|     uint8_t *buffer, uint32_t bufferlen, uint8_t *src_mac)
 | |
| {
 | |
|     (void)src_mac;
 | |
|     uint8_t *addr =
 | |
|         get_addr_from_mapping_table(host_config->cli_request_id);
 | |
| 
 | |
|     iot_cli_send_to_host(CLI_MSGID_VENDOR_REPORT,
 | |
|         buffer, bufferlen, addr);
 | |
| }
 | |
| 
 | |
| /* cco handle build info from sta */
 | |
| void cli_set_build_info_report(
 | |
|     uint8_t *buffer, uint32_t bufferlen, uint8_t *src_mac)
 | |
| {
 | |
|     (void)src_mac;
 | |
|     uint8_t *addr =
 | |
|         get_addr_from_mapping_table(host_config->cli_request_id);
 | |
| 
 | |
|     iot_cli_send_to_host(CLI_MSGID_BUILD_INFO_REPORT,
 | |
|         buffer, bufferlen, addr);
 | |
| }
 | |
| #endif
 | |
| 
 | |
| /* timer for set info */
 | |
| static void iot_cli_set_info_timer(timer_id_t timer_id, void *arg)
 | |
| {
 | |
|     (void)timer_id;
 | |
|     (void)arg;
 | |
| 
 | |
|     iot_task_msg_t *msg;
 | |
|     msg = iot_cli_create_cli_msg(IOT_CLI_SET_TIMER, NULL);
 | |
| 
 | |
|     if (msg) {
 | |
|         iot_task_queue_msg(cli.cli_task_h, msg, IOT_CLI_QUEUE_TIMER);
 | |
|     }
 | |
| }
 | |
| 
 | |
| /* check if set venfor */
 | |
| static uint8_t iot_cli_is_set_vendor()
 | |
| {
 | |
|     if (set_id <= CLI_SET_VENDOR_ID_MAX)
 | |
|     {
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| static void iot_cli_info_reset_report()
 | |
| {
 | |
|     if (iot_cli_is_set_vendor()) {
 | |
|         cli_vendor_report report;
 | |
|         report.set_id = set_id;
 | |
|         iot_mac_addr_cpy(report.dst, host_config->mac_addr);
 | |
|         iot_cli_host_send_data_plc(IOT_PLC_MSG_TYPE_UNICAST,
 | |
|             CLI_MSGID_VENDOR_REPORT, host_config->cco_mac,
 | |
|             (uint8_t*)&report, sizeof(cli_vendor_report));
 | |
|     } else {
 | |
|         cli_build_info_report report;
 | |
|         report.set_id = set_id;
 | |
|         iot_mac_addr_cpy(report.dst, host_config->mac_addr);
 | |
|         iot_cli_host_send_data_plc(IOT_PLC_MSG_TYPE_UNICAST,
 | |
|             CLI_MSGID_BUILD_INFO_REPORT, host_config->cco_mac,
 | |
|             (uint8_t*)&report, sizeof(cli_build_info_report));
 | |
|     }
 | |
| }
 | |
| 
 | |
| /* handle set timer msg */
 | |
| void iot_cli_set_info_handle_timer_msg()
 | |
| {
 | |
|     iot_cli_info_reset_report();
 | |
|     // stop timer
 | |
|     os_stop_timer(set_info_timer);
 | |
| }
 | |
| 
 | |
| /* init cli set info */
 | |
| void iot_cli_set_info_init()
 | |
| {
 | |
|     set_id = 0;
 | |
|     if (host_config->dev_role != IOT_PLC_DEV_ROLE_CCO)
 | |
|     {
 | |
|         set_info_timer = os_create_timer(IOT_CLI_MID, 1,
 | |
|             iot_cli_set_info_timer, NULL);
 | |
|     }
 | |
| }
 | |
| 
 | |
| /* sta handle leave when ver change */
 | |
| void iot_cli_user_ver_change_reset()
 | |
| {
 | |
|     if (set_id > 0) {
 | |
|         iot_upgrade_reset();
 | |
|     }
 | |
| }
 |