mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-07 06:24:35 +08:00
Merge pull request #1397 from armink/fix_newlib
[Components/libc] Add gettimeofday to newlib libc.
This commit is contained in:
commit
feb275db42
@ -1,23 +1,25 @@
|
|||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <rtthread.h>
|
||||||
|
|
||||||
|
#if defined(RT_USING_DEVICE) && defined(RT_USING_RTC)
|
||||||
int gettimeofday(struct timeval *tp, void *ignore)
|
int gettimeofday(struct timeval *tp, void *ignore)
|
||||||
{
|
{
|
||||||
time_t time;
|
time_t time;
|
||||||
rt_device_t device;
|
rt_device_t device;
|
||||||
|
|
||||||
device = rt_device_find("rtc");
|
device = rt_device_find("rtc");
|
||||||
if (device != RT_NULL)
|
if (device != RT_NULL)
|
||||||
{
|
{
|
||||||
rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time);
|
rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time);
|
||||||
if (tp != RT_NULL)
|
if (tp != RT_NULL)
|
||||||
{
|
{
|
||||||
tp->tv_sec = time;
|
tp->tv_sec = time;
|
||||||
tp->tv_usec = 0;
|
tp->tv_usec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return time;
|
return time;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
@ -1,23 +1,25 @@
|
|||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <rtthread.h>
|
||||||
|
|
||||||
|
#if defined(RT_USING_DEVICE) && defined(RT_USING_RTC)
|
||||||
int gettimeofday(struct timeval *tp, void *ignore)
|
int gettimeofday(struct timeval *tp, void *ignore)
|
||||||
{
|
{
|
||||||
time_t time;
|
time_t time;
|
||||||
rt_device_t device;
|
rt_device_t device;
|
||||||
|
|
||||||
device = rt_device_find("rtc");
|
device = rt_device_find("rtc");
|
||||||
if (device != RT_NULL)
|
if (device != RT_NULL)
|
||||||
{
|
{
|
||||||
rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time);
|
rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time);
|
||||||
if (tp != RT_NULL)
|
if (tp != RT_NULL)
|
||||||
{
|
{
|
||||||
tp->tv_sec = time;
|
tp->tv_sec = time;
|
||||||
tp->tv_usec = 0;
|
tp->tv_usec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return time;
|
return time;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
25
components/libc/compilers/newlib/time.c
Normal file
25
components/libc/compilers/newlib/time.c
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
#include <sys/time.h>
|
||||||
|
#include <rtthread.h>
|
||||||
|
|
||||||
|
#if defined(RT_USING_DEVICE) && defined(RT_USING_RTC)
|
||||||
|
int gettimeofday(struct timeval *tp, void *ignore)
|
||||||
|
{
|
||||||
|
time_t time;
|
||||||
|
rt_device_t device;
|
||||||
|
|
||||||
|
device = rt_device_find("rtc");
|
||||||
|
if (device != RT_NULL)
|
||||||
|
{
|
||||||
|
rt_device_control(device, RT_DEVICE_CTRL_RTC_GET_TIME, &time);
|
||||||
|
if (tp != RT_NULL)
|
||||||
|
{
|
||||||
|
tp->tv_sec = time;
|
||||||
|
tp->tv_usec = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return time;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
x
Reference in New Issue
Block a user