2018-10-14 19:28:18 +08:00
|
|
|
/*
|
2022-01-20 20:53:47 +08:00
|
|
|
* Copyright (c) 2006-2022, RT-Thread Development Team
|
2018-10-14 19:28:18 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
2020-09-08 10:26:03 +08:00
|
|
|
* 2020-09-07 Meco Man combine gcc armcc iccarm
|
2021-02-12 12:14:45 +08:00
|
|
|
* 2021-02-12 Meco Man move all definitions located in <clock_time.h> to this file
|
2018-10-14 19:28:18 +08:00
|
|
|
*/
|
2022-01-08 23:29:41 +08:00
|
|
|
|
2021-09-11 23:25:43 +08:00
|
|
|
#ifndef __SYS_TIME_H__
|
|
|
|
#define __SYS_TIME_H__
|
2015-05-04 20:35:28 +08:00
|
|
|
|
2021-02-12 01:30:41 +08:00
|
|
|
#include <rtconfig.h>
|
2021-09-18 23:37:19 +08:00
|
|
|
#include <sys/types.h>
|
|
|
|
#include <stdint.h>
|
2015-05-04 20:35:28 +08:00
|
|
|
#include <time.h>
|
2022-01-03 22:38:04 +08:00
|
|
|
#ifdef _WIN32
|
2022-04-07 14:24:11 +08:00
|
|
|
typedef __time64_t time_t;
|
|
|
|
#endif /* _WIN32 */
|
2015-05-04 20:35:28 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* __cplusplus */
|
2015-05-04 20:35:28 +08:00
|
|
|
|
2022-10-24 09:27:56 +08:00
|
|
|
#undef CLOCKS_PER_SEC
|
|
|
|
#define CLOCKS_PER_SEC RT_TICK_PER_SECOND
|
|
|
|
|
2021-07-22 00:35:08 +08:00
|
|
|
/* timezone */
|
2023-08-12 12:44:36 +08:00
|
|
|
/* this method of representing timezones has been abandoned */
|
2021-05-02 09:24:41 +08:00
|
|
|
#define DST_NONE 0 /* not on dst */
|
2022-12-29 15:18:36 +08:00
|
|
|
|
2021-09-18 23:37:19 +08:00
|
|
|
struct timezone
|
|
|
|
{
|
|
|
|
int tz_minuteswest; /* minutes west of Greenwich */
|
|
|
|
int tz_dsttime; /* type of dst correction */
|
2021-07-22 00:35:08 +08:00
|
|
|
};
|
|
|
|
|
2023-08-12 12:44:36 +08:00
|
|
|
/* lightweight timezone and daylight saving time */
|
|
|
|
#ifdef RT_LIBC_USING_LIGHT_TZ_DST
|
|
|
|
void rt_tz_set(int32_t offset_sec);
|
|
|
|
int32_t rt_tz_get(void);
|
|
|
|
int8_t rt_tz_is_dst(void);
|
|
|
|
#endif /* RT_LIBC_USING_LIGHT_TZ_DST */
|
|
|
|
|
|
|
|
struct itimerspec;
|
|
|
|
|
2024-02-23 17:49:15 +08:00
|
|
|
/* 'struct timeval' is defined on __x86_64__ toolchain */
|
|
|
|
#if !defined(__x86_64__) && !defined(_TIMEVAL_DEFINED)
|
|
|
|
#define _TIMEVAL_DEFINED
|
|
|
|
struct timeval
|
|
|
|
{
|
|
|
|
time_t tv_sec; /* seconds */
|
|
|
|
suseconds_t tv_usec; /* and microseconds */
|
|
|
|
};
|
|
|
|
#endif /* _TIMEVAL_DEFINED */
|
|
|
|
|
|
|
|
#if defined(_GNU_SOURCE) && (defined(__x86_64__) || defined(__i386__) || defined(RT_USING_SMART))
|
2023-06-07 11:46:18 +08:00
|
|
|
/* linux x86 platform gcc use! */
|
|
|
|
#define _TIMEVAL_DEFINED
|
|
|
|
/* Values for the first argument to `getitimer' and `setitimer'. */
|
|
|
|
enum __itimer_which
|
|
|
|
{
|
|
|
|
/* Timers run in real time. */
|
|
|
|
ITIMER_REAL = 0,
|
|
|
|
#define ITIMER_REAL ITIMER_REAL
|
|
|
|
/* Timers run only when the process is executing. */
|
|
|
|
ITIMER_VIRTUAL = 1,
|
|
|
|
#define ITIMER_VIRTUAL ITIMER_VIRTUAL
|
|
|
|
/* Timers run when the process is executing and when
|
|
|
|
the system is executing on behalf of the process. */
|
|
|
|
ITIMER_PROF = 2
|
|
|
|
#define ITIMER_PROF ITIMER_PROF
|
|
|
|
};
|
|
|
|
|
|
|
|
struct itimerval
|
|
|
|
{
|
|
|
|
/* Value to put into `it_value' when the timer expires. */
|
|
|
|
struct timeval it_interval;
|
|
|
|
/* Time to the next timer expiration. */
|
|
|
|
struct timeval it_value;
|
|
|
|
};
|
2024-02-23 17:49:15 +08:00
|
|
|
#endif /* defined(_GNU_SOURCE) && (defined(__x86_64__) || defined(__i386__)) || defined(RT_USING_SMART) */
|
2015-05-04 20:35:28 +08:00
|
|
|
|
2022-04-22 01:20:18 +08:00
|
|
|
#if defined(__ARMCC_VERSION) || defined(_WIN32) || (defined(__ICCARM__) && (__VER__ < 8010001))
|
2021-09-18 23:37:19 +08:00
|
|
|
struct timespec
|
|
|
|
{
|
|
|
|
time_t tv_sec; /* seconds */
|
|
|
|
long tv_nsec; /* and nanoseconds */
|
|
|
|
};
|
2022-04-22 01:20:18 +08:00
|
|
|
#endif /* defined(__ARMCC_VERSION) || defined(_WIN32) || (defined(__ICCARM__) && (__VER__ < 8010001)) */
|
2022-01-20 20:53:47 +08:00
|
|
|
|
2022-04-07 14:24:11 +08:00
|
|
|
#if !(defined(__GNUC__) && !defined(__ARMCC_VERSION)/*GCC*/)
|
2022-01-20 20:53:47 +08:00
|
|
|
/*
|
|
|
|
* Structure defined by POSIX.1b to be like a itimerval, but with
|
|
|
|
* timespecs. Used in the timer_*() system calls.
|
|
|
|
*/
|
|
|
|
struct itimerspec
|
|
|
|
{
|
|
|
|
struct timespec it_interval;
|
|
|
|
struct timespec it_value;
|
|
|
|
};
|
2022-04-07 14:24:11 +08:00
|
|
|
#endif /* !(defined(__GNUC__) && !defined(__ARMCC_VERSION)) */
|
2021-09-18 23:37:19 +08:00
|
|
|
|
2021-02-08 00:56:31 +08:00
|
|
|
int stime(const time_t *t);
|
2021-02-05 13:13:22 +08:00
|
|
|
time_t timegm(struct tm * const t);
|
2021-02-08 00:56:31 +08:00
|
|
|
int gettimeofday(struct timeval *tv, struct timezone *tz);
|
|
|
|
int settimeofday(const struct timeval *tv, const struct timezone *tz);
|
2022-11-23 10:40:50 +08:00
|
|
|
|
|
|
|
#if defined(__ARMCC_VERSION) || defined (__ICCARM__) || defined(_WIN32)
|
2021-04-15 14:01:55 +08:00
|
|
|
struct tm *gmtime_r(const time_t *timep, struct tm *r);
|
2022-01-20 20:53:47 +08:00
|
|
|
char* asctime_r(const struct tm *t, char *buf);
|
|
|
|
char *ctime_r(const time_t * tim_p, char * result);
|
2022-01-06 05:43:44 +08:00
|
|
|
struct tm* localtime_r(const time_t* t, struct tm* r);
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* defined(__ARMCC_VERSION) || defined (__ICCARM__) || defined(_WIN32) */
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
struct tm* gmtime(const time_t* t);
|
2022-01-06 05:43:44 +08:00
|
|
|
struct tm* localtime(const time_t* t);
|
|
|
|
time_t mktime(struct tm* const t);
|
|
|
|
char* ctime(const time_t* tim_p);
|
|
|
|
time_t time(time_t* t);
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* _WIN32 */
|
2015-05-04 20:35:28 +08:00
|
|
|
|
2022-01-07 01:22:11 +08:00
|
|
|
#ifdef RT_USING_POSIX_DELAY
|
|
|
|
int nanosleep(const struct timespec *rqtp, struct timespec *rmtp);
|
|
|
|
#endif /* RT_USING_POSIX_DELAY */
|
|
|
|
|
2021-02-12 01:30:41 +08:00
|
|
|
#define MILLISECOND_PER_SECOND 1000UL
|
|
|
|
#define MICROSECOND_PER_SECOND 1000000UL
|
|
|
|
#define NANOSECOND_PER_SECOND 1000000000UL
|
|
|
|
|
|
|
|
#define MILLISECOND_PER_TICK (MILLISECOND_PER_SECOND / RT_TICK_PER_SECOND)
|
|
|
|
#define MICROSECOND_PER_TICK (MICROSECOND_PER_SECOND / RT_TICK_PER_SECOND)
|
|
|
|
#define NANOSECOND_PER_TICK (NANOSECOND_PER_SECOND / RT_TICK_PER_SECOND)
|
|
|
|
|
2022-12-03 12:07:44 +08:00
|
|
|
#if defined(RT_USING_POSIX_CLOCK) || defined (RT_USING_POSIX_TIMER)
|
|
|
|
/* POSIX clock and timer */
|
|
|
|
|
2023-07-17 20:11:58 +08:00
|
|
|
#ifndef CLOCK_REALTIME_COARSE
|
|
|
|
#define CLOCK_REALTIME_COARSE 0
|
|
|
|
#endif /* CLOCK_REALTIME_COARSE */
|
|
|
|
|
2021-02-12 01:30:41 +08:00
|
|
|
#ifndef CLOCK_REALTIME
|
2023-07-17 20:11:58 +08:00
|
|
|
#define CLOCK_REALTIME 1
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* CLOCK_REALTIME */
|
2021-02-12 01:30:41 +08:00
|
|
|
|
|
|
|
#define CLOCK_CPUTIME_ID 2
|
|
|
|
|
|
|
|
#ifndef CLOCK_PROCESS_CPUTIME_ID
|
|
|
|
#define CLOCK_PROCESS_CPUTIME_ID CLOCK_CPUTIME_ID
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* CLOCK_PROCESS_CPUTIME_ID */
|
|
|
|
|
2021-02-12 01:30:41 +08:00
|
|
|
#ifndef CLOCK_THREAD_CPUTIME_ID
|
2023-07-17 20:11:58 +08:00
|
|
|
#define CLOCK_THREAD_CPUTIME_ID 3
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* CLOCK_THREAD_CPUTIME_ID */
|
2021-02-12 01:30:41 +08:00
|
|
|
|
|
|
|
#ifndef CLOCK_MONOTONIC
|
|
|
|
#define CLOCK_MONOTONIC 4
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* CLOCK_MONOTONIC */
|
2022-12-03 12:07:44 +08:00
|
|
|
|
2023-07-17 20:11:58 +08:00
|
|
|
#ifndef CLOCK_MONOTONIC_RAW
|
|
|
|
#define CLOCK_MONOTONIC_RAW 5
|
|
|
|
#endif /* CLOCK_MONOTONIC_RAW */
|
|
|
|
|
|
|
|
#ifndef CLOCK_MONOTONIC_COARSE
|
|
|
|
#define CLOCK_MONOTONIC_COARSE 6
|
|
|
|
#endif /* CLOCK_MONOTONIC_COARSE */
|
|
|
|
|
|
|
|
#ifndef CLOCK_BOOTTIME
|
|
|
|
#define CLOCK_BOOTTIME 7
|
|
|
|
#endif /* CLOCK_BOOTTIME */
|
|
|
|
|
|
|
|
#ifndef CLOCK_REALTIME_ALARM
|
|
|
|
#define CLOCK_REALTIME_ALARM 8
|
|
|
|
#endif /* CLOCK_REALTIME_ALARM */
|
|
|
|
|
|
|
|
#ifndef CLOCK_BOOTTIME_ALARM
|
|
|
|
#define CLOCK_BOOTTIME_ALARM 9
|
|
|
|
#endif /* CLOCK_BOOTTIME_ALARM */
|
|
|
|
|
|
|
|
#ifndef CLOCK_SGI_CYCLE
|
|
|
|
#define CLOCK_SGI_CYCLE 10 // newlib says they don't have this definition, make the compiler happy
|
|
|
|
#endif /* CLOCK_SGI_CYCLE */
|
|
|
|
|
2023-06-14 11:29:56 +08:00
|
|
|
#ifndef TIMER_ABSTIME
|
|
|
|
#define TIMER_ABSTIME 4
|
|
|
|
#endif /* TIMER_ABSTIME */
|
|
|
|
|
2022-12-03 12:07:44 +08:00
|
|
|
#ifdef CLOCK_TAI
|
|
|
|
#define CLOCK_ID_MAX CLOCK_TAI
|
|
|
|
#else
|
|
|
|
#define CLOCK_ID_MAX CLOCK_MONOTONIC
|
|
|
|
#endif
|
2023-07-17 20:11:58 +08:00
|
|
|
|
|
|
|
#ifndef CLOCK_TAI
|
|
|
|
#define CLOCK_TAI 11 // newlib says they don't have this definition, make the compiler happy
|
|
|
|
#endif /* CLOCK_TAI */
|
|
|
|
|
2022-01-20 20:53:47 +08:00
|
|
|
#endif /* defined(RT_USING_POSIX_CLOCK) || defined (RT_USING_POSIX_TIMER) */
|
2021-02-12 01:30:41 +08:00
|
|
|
|
2022-01-20 20:53:47 +08:00
|
|
|
#ifdef RT_USING_POSIX_CLOCK
|
2021-02-12 01:30:41 +08:00
|
|
|
int clock_getres (clockid_t clockid, struct timespec *res);
|
|
|
|
int clock_gettime (clockid_t clockid, struct timespec *tp);
|
|
|
|
int clock_settime (clockid_t clockid, const struct timespec *tp);
|
2021-12-17 15:34:17 +08:00
|
|
|
int clock_nanosleep(clockid_t clockid, int flags, const struct timespec *rqtp, struct timespec *rmtp);
|
2021-07-22 00:35:08 +08:00
|
|
|
int rt_timespec_to_tick(const struct timespec *time);
|
2021-12-17 15:34:17 +08:00
|
|
|
#endif /* RT_USING_POSIX_CLOCK */
|
2021-02-12 01:30:41 +08:00
|
|
|
|
2022-01-20 20:53:47 +08:00
|
|
|
#ifdef RT_USING_POSIX_TIMER
|
2022-12-03 12:07:44 +08:00
|
|
|
#include <sys/signal.h>
|
2022-01-20 20:53:47 +08:00
|
|
|
int timer_create(clockid_t clockid, struct sigevent *evp, timer_t *timerid);
|
|
|
|
int timer_delete(timer_t timerid);
|
|
|
|
int timer_getoverrun(timer_t timerid);
|
|
|
|
int timer_gettime(timer_t timerid, struct itimerspec *its);
|
2022-11-23 10:40:50 +08:00
|
|
|
int timer_settime(timer_t timerid, int flags, const struct itimerspec *value, struct itimerspec *ovalue);
|
2022-01-20 20:53:47 +08:00
|
|
|
#endif /* RT_USING_POSIX_TIMER */
|
|
|
|
|
2015-05-04 20:35:28 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
2022-11-23 10:40:50 +08:00
|
|
|
#endif /* __cplusplus */
|
2015-05-04 20:35:28 +08:00
|
|
|
|
|
|
|
#endif /* _SYS_TIME_H_ */
|