Files
zTC1/TC1/main.c
Zip fa570549a9 fix:优化sntp服务
fix:主函数中初始化增加错误判断处理
代码格式化
2019-01-29 15:56:25 +08:00

113 lines
3.3 KiB
C

#include "main.h"
#include "user_key.h"
#include "user_wifi.h"
#include "user_rtc.h"
#include "user_mqtt_client.h"
#define os_log(format, ...) custom_log("TC1", format, ##__VA_ARGS__)
char rtc_init=0;
system_config_t * sys_config;
user_config_t * user_config;
mico_gpio_t Relay[Relay_NUM] = { Relay_0, Relay_1, Relay_2, Relay_3, Relay_4, Relay_5 };
/* MICO system callback: Restore default configuration provided by application */
void appRestoreDefault_callback( void * const user_config_data, uint32_t size )
{
int i, j;
UNUSED_PARAMETER( size );
sprintf( mico_system_context_get( )->micoSystemConfig.name, ZTC1_NAME );
user_config_t* userConfigDefault = user_config_data;
userConfigDefault->idx = -1;
for(i=0;i<PLUG_NUM;i++)
{
userConfigDefault->plug[i].idx=-1;
sprintf( userConfigDefault->plug[i].name, "²å×ù%d",i );
for(j=0;j<PLUG_TIME_TASK_NUM;j++)
{
userConfigDefault->plug[i].task[j].hour=0;
userConfigDefault->plug[i].task[j].minute=0;
userConfigDefault->plug[i].task[j].repeat=0x80;
userConfigDefault->plug[i].task[j].on=0;
userConfigDefault->plug[i].task[j].action=1;
}
}
}
int application_start( void )
{
int i, j;
os_log( "Start" );
OSStatus err = kNoErr;
/* Create mico system context and read application's config data from flash */
sys_config = mico_system_context_init( sizeof(user_config_t) );
user_config = ((system_context_t *) sys_config)->user_config_data;
require_action( user_config, exit, err = kNoMemoryErr );
err = mico_system_init( sys_config );
require_noerr( err, exit );
for ( i = 0; i < Relay_NUM; i++ )
{
MicoGpioInitialize( Relay[i], OUTPUT_PUSH_PULL );
//MicoGpioOutputHigh(Relay[i]);
}
MicoGpioInitialize( (mico_gpio_t) Button, INPUT_PULL_UP );
if ( !MicoGpioInputGet( Button ) )
{ //¿ª»úʱ°´Å¥×´Ì¬
os_log( "wifi_start_easylink" );
wifi_status = WIFI_STATE_NOEASYLINK; //wifi_initÖÐÆô¶¯easylink
}
MicoGpioInitialize( (mico_gpio_t) MICO_GPIO_5, OUTPUT_PUSH_PULL );
led( 0 );
if ( user_config->plug[0].task[0].hour < 0 || user_config->plug[0].task[0].hour > 23 )
{
os_log( "WARNGIN: user params restored!" );
err = mico_system_context_restore( sys_config );
require_noerr( err, exit );
}
os_log( "idx:%d",user_config->idx );
for ( i = 0; i < PLUG_NUM; i++ )
{
os_log("plug_%d:",i);
os_log("\tname:%s:",user_config->plug[i].name);
os_log("\tidx:%d:",user_config->plug[i].idx);
for ( j = 0; j < PLUG_TIME_TASK_NUM; j++ )
{
os_log("\t\ton:%d\t %02d:%02d repeat:0x%X",user_config->plug[i].task[j].on,
user_config->plug[i].task[j].hour,user_config->plug[i].task[j].minute,
user_config->plug[i].task[j].repeat);
}
}
wifi_init( );
key_init( );
err = user_mqtt_init( );
require_noerr( err, exit );
err = user_rtc_init();
require_noerr( err, exit );
while ( 1 )
{
// mico_thread_msleep(500);
// MicoGpioOutputTrigger(MICO_GPIO_5);
// mico_gpio_output_toggle( MICO_SYS_LED );
// mico_rtos_delay_milliseconds(1000);
}
exit:
os_log("application_start ERROR!");
return 0;
}