[rtc]调整rtc驱动框架函数位置,功能无影响,为后续新的RTC框架铺路
This commit is contained in:
parent
6d57515316
commit
787e46c6a3
|
@ -11,10 +11,14 @@
|
||||||
#ifndef __RTC_H__
|
#ifndef __RTC_H__
|
||||||
#define __RTC_H__
|
#define __RTC_H__
|
||||||
|
|
||||||
|
#include <rtconfig.h>
|
||||||
|
|
||||||
rt_err_t set_date(rt_uint32_t year, rt_uint32_t month, rt_uint32_t day);
|
rt_err_t set_date(rt_uint32_t year, rt_uint32_t month, rt_uint32_t day);
|
||||||
rt_err_t set_time(rt_uint32_t hour, rt_uint32_t minute, rt_uint32_t second);
|
rt_err_t set_time(rt_uint32_t hour, rt_uint32_t minute, rt_uint32_t second);
|
||||||
|
|
||||||
|
#ifdef RTC_SYNC_USING_NTP
|
||||||
int rt_soft_rtc_init(void);
|
int rt_soft_rtc_init(void);
|
||||||
int rt_rtc_ntp_sync_init(void);
|
int rt_rtc_ntp_sync_init(void);
|
||||||
|
#endif /* RTC_SYNC_USING_NTP */
|
||||||
|
|
||||||
#endif /* __RTC_H__ */
|
#endif /* __RTC_H__ */
|
||||||
|
|
|
@ -11,24 +11,12 @@
|
||||||
* 2018-02-16 armink add auto sync time by NTP
|
* 2018-02-16 armink add auto sync time by NTP
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <sys/time.h>
|
#include <time.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
#include <rtthread.h>
|
#include <rtthread.h>
|
||||||
|
|
||||||
#ifdef RT_USING_RTC
|
#ifdef RT_USING_RTC
|
||||||
|
|
||||||
/* Using NTP auto sync RTC time */
|
|
||||||
#ifdef RTC_SYNC_USING_NTP
|
|
||||||
/* NTP first sync delay time for network connect, unit: second */
|
|
||||||
#ifndef RTC_NTP_FIRST_SYNC_DELAY
|
|
||||||
#define RTC_NTP_FIRST_SYNC_DELAY (30)
|
|
||||||
#endif
|
|
||||||
/* NTP sync period, unit: second */
|
|
||||||
#ifndef RTC_NTP_SYNC_PERIOD
|
|
||||||
#define RTC_NTP_SYNC_PERIOD (1L*60L*60L)
|
|
||||||
#endif
|
|
||||||
#endif /* RTC_SYNC_USING_NTP */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set system date(time not modify, local timezone).
|
* Set system date(time not modify, local timezone).
|
||||||
*
|
*
|
||||||
|
@ -129,51 +117,8 @@ rt_err_t set_time(rt_uint32_t hour, rt_uint32_t minute, rt_uint32_t second)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef RTC_SYNC_USING_NTP
|
#ifdef FINSH_USING_MSH
|
||||||
static void ntp_sync_thread_enrty(void *param)
|
|
||||||
{
|
|
||||||
extern time_t ntp_sync_to_rtc(const char *host_name);
|
|
||||||
/* first sync delay for network connect */
|
|
||||||
rt_thread_delay(RTC_NTP_FIRST_SYNC_DELAY * RT_TICK_PER_SECOND);
|
|
||||||
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
ntp_sync_to_rtc(NULL);
|
|
||||||
rt_thread_delay(RTC_NTP_SYNC_PERIOD * RT_TICK_PER_SECOND);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int rt_rtc_ntp_sync_init(void)
|
|
||||||
{
|
|
||||||
static rt_bool_t init_ok = RT_FALSE;
|
|
||||||
rt_thread_t thread;
|
|
||||||
|
|
||||||
if (init_ok)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
thread = rt_thread_create("ntp_sync", ntp_sync_thread_enrty, RT_NULL, 1536, 26, 2);
|
|
||||||
if (thread)
|
|
||||||
{
|
|
||||||
rt_thread_startup(thread);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return -RT_ENOMEM;
|
|
||||||
}
|
|
||||||
|
|
||||||
init_ok = RT_TRUE;
|
|
||||||
|
|
||||||
return RT_EOK;
|
|
||||||
}
|
|
||||||
INIT_COMPONENT_EXPORT(rt_rtc_ntp_sync_init);
|
|
||||||
#endif /* RTC_SYNC_USING_NTP */
|
|
||||||
|
|
||||||
#ifdef RT_USING_FINSH
|
|
||||||
#include <finsh.h>
|
#include <finsh.h>
|
||||||
#include <rtdevice.h>
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* show date and time (local timezone)
|
* show date and time (local timezone)
|
||||||
*/
|
*/
|
||||||
|
@ -184,12 +129,7 @@ void list_date(void)
|
||||||
now = time(RT_NULL);
|
now = time(RT_NULL);
|
||||||
rt_kprintf("%.*s\n", 25, ctime(&now));
|
rt_kprintf("%.*s\n", 25, ctime(&now));
|
||||||
}
|
}
|
||||||
FINSH_FUNCTION_EXPORT(list_date, show date and time (local timezone))
|
|
||||||
FINSH_FUNCTION_EXPORT(set_date, set date(local timezone) e.g: set_date(2010,2,28))
|
|
||||||
FINSH_FUNCTION_EXPORT(set_time, set time(local timezone) e.g: set_time(23,59,59))
|
|
||||||
|
|
||||||
|
|
||||||
#if defined(RT_USING_FINSH) && defined(FINSH_USING_MSH)
|
|
||||||
/**
|
/**
|
||||||
* get date and time or set (local timezone) [year month day hour min sec]
|
* get date and time or set (local timezone) [year month day hour min sec]
|
||||||
*/
|
*/
|
||||||
|
@ -254,7 +194,57 @@ static void date(uint8_t argc, char **argv)
|
||||||
}
|
}
|
||||||
MSH_CMD_EXPORT(list_date, show date and time (local timezone))
|
MSH_CMD_EXPORT(list_date, show date and time (local timezone))
|
||||||
MSH_CMD_EXPORT(date, get date and time or set (local timezone) [year month day hour min sec])
|
MSH_CMD_EXPORT(date, get date and time or set (local timezone) [year month day hour min sec])
|
||||||
|
#endif /* FINSH_USING_MSH */
|
||||||
|
|
||||||
|
/* Using NTP auto sync RTC time */
|
||||||
|
#ifdef RTC_SYNC_USING_NTP
|
||||||
|
/* NTP first sync delay time for network connect, unit: second */
|
||||||
|
#ifndef RTC_NTP_FIRST_SYNC_DELAY
|
||||||
|
#define RTC_NTP_FIRST_SYNC_DELAY (30)
|
||||||
|
#endif
|
||||||
|
/* NTP sync period, unit: second */
|
||||||
|
#ifndef RTC_NTP_SYNC_PERIOD
|
||||||
|
#define RTC_NTP_SYNC_PERIOD (1L*60L*60L)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void ntp_sync_thread_enrty(void *param)
|
||||||
|
{
|
||||||
|
extern time_t ntp_sync_to_rtc(const char *host_name);
|
||||||
|
/* first sync delay for network connect */
|
||||||
|
rt_thread_delay(RTC_NTP_FIRST_SYNC_DELAY * RT_TICK_PER_SECOND);
|
||||||
|
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
ntp_sync_to_rtc(NULL);
|
||||||
|
rt_thread_delay(RTC_NTP_SYNC_PERIOD * RT_TICK_PER_SECOND);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int rt_rtc_ntp_sync_init(void)
|
||||||
|
{
|
||||||
|
static rt_bool_t init_ok = RT_FALSE;
|
||||||
|
rt_thread_t thread;
|
||||||
|
|
||||||
|
if (init_ok)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
thread = rt_thread_create("ntp_sync", ntp_sync_thread_enrty, RT_NULL, 1536, 26, 2);
|
||||||
|
if (thread)
|
||||||
|
{
|
||||||
|
rt_thread_startup(thread);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return -RT_ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
init_ok = RT_TRUE;
|
||||||
|
|
||||||
|
return RT_EOK;
|
||||||
|
}
|
||||||
|
INIT_COMPONENT_EXPORT(rt_rtc_ntp_sync_init);
|
||||||
|
#endif /* RTC_SYNC_USING_NTP */
|
||||||
|
|
||||||
#endif /* defined(RT_USING_FINSH) && defined(FINSH_USING_MSH) */
|
|
||||||
#endif /* RT_USING_FINSH */
|
|
||||||
#endif /* RT_USING_RTC */
|
#endif /* RT_USING_RTC */
|
||||||
|
|
Loading…
Reference in New Issue