mirror of
https://github.com/oopuuu/zTC1.git
synced 2025-12-13 21:48:25 +08:00
148 lines
4.0 KiB
C
148 lines
4.0 KiB
C
#include "http_server/web_log.h"
|
||
#include "main.h"
|
||
#include "user_gpio.h"
|
||
#include "sntp.h"
|
||
#include "mqtt_server/user_mqtt_client.h"
|
||
|
||
void RtcThread(mico_thread_arg_t arg);
|
||
|
||
OSStatus UserSntpGetTime()
|
||
{
|
||
OSStatus err = kNoErr;
|
||
ntp_timestamp_t current_time;
|
||
|
||
struct hostent * hostent_content = NULL;
|
||
char ** pptr = NULL;
|
||
struct in_addr ipp;
|
||
|
||
ipp.s_addr = 0xd248912c;
|
||
err = sntp_get_time(&ipp, ¤t_time);
|
||
|
||
if (err != kNoErr)
|
||
{
|
||
int ntp_count = 5;
|
||
char* ntp_hosts[5] = {
|
||
"pool.ntp.org",
|
||
"cn.ntp.org.cn",
|
||
"cn.pool.ntp.org",
|
||
"s1a.time.edu.cn",
|
||
"ntp.sjtu.edu.cn",
|
||
};
|
||
|
||
int i = 0;
|
||
for (; i < ntp_count; i++)
|
||
{
|
||
hostent_content = gethostbyname(ntp_hosts[i]);
|
||
if (hostent_content == NULL)
|
||
{
|
||
rtc_log("gethostbyname(%s)", ntp_hosts[i]);
|
||
continue;
|
||
}
|
||
pptr = hostent_content->h_addr_list;
|
||
ipp.s_addr = *(uint32_t *)(*pptr);
|
||
err = sntp_get_time(&ipp, ¤t_time);
|
||
if (err == kNoErr)
|
||
{
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
|
||
if (err != kNoErr)
|
||
{
|
||
rtc_log("sntp_get_time4 err[%d]", err);
|
||
return err;
|
||
}
|
||
|
||
mico_utc_time_ms_t utc_time_ms = (uint64_t)current_time.seconds * (uint64_t)1000
|
||
+ (current_time.microseconds / 1000);
|
||
mico_time_set_utc_time_ms(&utc_time_ms);
|
||
return kNoErr;
|
||
}
|
||
|
||
OSStatus UserRtcInit(void)
|
||
{
|
||
OSStatus err = kNoErr;
|
||
|
||
/* start rtc client */
|
||
err = mico_rtos_create_thread(NULL, MICO_APPLICATION_PRIORITY, "rtc",
|
||
(mico_thread_function_t) RtcThread,
|
||
0x1000, 0);
|
||
require_noerr_string(err, exit, "ERROR: Unable to start the rtc thread.");
|
||
|
||
if (kNoErr != err) rtc_log("ERROR1, app thread exit err: %d kNoErr[%d]", err, kNoErr);
|
||
|
||
exit:
|
||
return err;
|
||
}
|
||
|
||
void RtcThread(mico_thread_arg_t arg)
|
||
{
|
||
OSStatus err = kUnknownErr;
|
||
LinkStatusTypeDef LinkStatus;
|
||
// mico_rtc_time_t rtc_time;
|
||
|
||
mico_utc_time_t utc_time;
|
||
mico_utc_time_t utc_time_last = 0;
|
||
while (1)
|
||
{ //涓婄數鍚庤繛鎺ヤ簡wifi鎵嶅紑濮嬭蛋鏃跺惁鍒欑瓑寰呰繛鎺<E7B99B>
|
||
micoWlanGetLinkStatus(&LinkStatus);
|
||
if (LinkStatus.is_connected == 1)
|
||
{
|
||
err = UserSntpGetTime();
|
||
if (err == kNoErr)
|
||
{
|
||
rtc_log("sntp success!");
|
||
rtc_init = 1;
|
||
break;
|
||
}
|
||
}
|
||
mico_rtos_thread_sleep(3);
|
||
}
|
||
|
||
while (1)
|
||
{
|
||
mico_time_get_utc_time(&utc_time);
|
||
utc_time += 28800;
|
||
|
||
if (utc_time_last != utc_time)
|
||
{
|
||
utc_time_last = utc_time;
|
||
total_time++;
|
||
}
|
||
|
||
struct tm * currentTime = localtime((const time_t *) &utc_time);
|
||
// rtc_time.sec = currentTime->tm_sec;
|
||
// rtc_time.min = currentTime->tm_min;
|
||
// rtc_time.hr = currentTime->tm_hour;
|
||
//
|
||
// rtc_time.date = currentTime->tm_mday;
|
||
// rtc_time.weekday = currentTime->tm_wday;
|
||
// rtc_time.month = currentTime->tm_mon + 1;
|
||
// rtc_time.year = (currentTime->tm_year + 1900) % 100;
|
||
|
||
// MicoRtcSetTime(&rtc_time); //MicoRtc涓嶈嚜鍔ㄨ蛋鏃<E89B8B>!
|
||
|
||
//SNTP鏈嶅姟 寮<>鏈哄強姣忓皬鏃舵牎鍑嗕竴娆<E7ABB4>
|
||
if (rtc_init != 1 || (currentTime->tm_sec == 0 && currentTime->tm_min == 0))
|
||
{
|
||
micoWlanGetLinkStatus(&LinkStatus);
|
||
if (LinkStatus.is_connected == 1)
|
||
{
|
||
err = UserSntpGetTime();
|
||
if (err == kNoErr)
|
||
rtc_init = 1;
|
||
else
|
||
rtc_init = 2;
|
||
}
|
||
}
|
||
|
||
mico_rtos_thread_msleep(900);
|
||
}
|
||
|
||
// exit:
|
||
rtc_log("EXIT: rtc exit with err = %d.", err);
|
||
mico_rtos_delete_thread(NULL);
|
||
}
|
||
|