File: time.h

package info (click to toggle)
glibc 2.19-11
  • links: PTS, VCS
  • area: main
  • in suites: jessie
  • size: 202,392 kB
  • ctags: 140,042
  • sloc: ansic: 969,214; asm: 241,208; sh: 10,046; makefile: 8,471; cpp: 3,595; perl: 2,077; pascal: 1,839; awk: 1,704; yacc: 317; sed: 73
file content (102 lines) | stat: -rw-r--r-- 3,558 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/* System-dependent timing definitions.  FreeBSD version.
   Copyright (C) 1996-1997, 1999, 2000, 2002 Free Software Foundation, Inc.
   This file is part of the GNU C Library.

   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.

   The GNU C Library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; if not, write to the Free
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
   02111-1307 USA.  */

/*
 * Never include this file directly; use <time.h> instead.
 */

#ifndef __need_timeval
# ifndef _BITS_TIME_H
#  define _BITS_TIME_H	1

/* ISO/IEC 9899:1990 7.12.1: <time.h>
   The macro `CLOCKS_PER_SEC' is the number per second of the value
   returned by the `clock' function. */
/* CAE XSH, Issue 4, Version 2: <time.h>
   The value of CLOCKS_PER_SEC is required to be 1 million on all
   XSI-conformant systems. */
#  define CLOCKS_PER_SEC  1000000l

#  if !defined __STRICT_ANSI__ && !defined __USE_XOPEN2K
/* Even though CLOCKS_PER_SEC has such a strange value CLK_TCK
   presents the real value for clock ticks per second for the system.  */
#   define CLK_TCK 128
#  endif

#  ifdef __USE_POSIX199309
/* Identifier for system-wide realtime clock.  */
#   define CLOCK_REALTIME		0
/* Monotonic system-wide clock.  */
#   define CLOCK_MONOTONIC		4
/* These are BSD specific clocks.  */
#   ifdef __USE_BSD
#    define CLOCK_VIRTUAL		1
#    define CLOCK_PROF			2
#    define CLOCK_UPTIME    5               /* FreeBSD-specific. */
#    define CLOCK_UPTIME_PRECISE    7       /* FreeBSD-specific. */
#    define CLOCK_UPTIME_FAST       8       /* FreeBSD-specific. */
#    define CLOCK_REALTIME_PRECISE  9       /* FreeBSD-specific. */
#    define CLOCK_REALTIME_FAST     10      /* FreeBSD-specific. */
#    define CLOCK_MONOTONIC_PRECISE 11      /* FreeBSD-specific. */
#    define CLOCK_MONOTONIC_FAST    12      /* FreeBSD-specific. */
#    define CLOCK_SECOND    13              /* FreeBSD-specific. */
#   endif
/* Thread-specific CPU-time clock.  */
#   define CLOCK_THREAD_CPUTIME_ID	14
/* High-resolution timer from the CPU.  */
#   define CLOCK_PROCESS_CPUTIME_ID	15
#   ifdef __USE_BSD
#     define CPUCLOCK_WHICH_PID 0
#     define CPUCLOCK_WHICH_TID 1
#   endif

/* Flag to indicate time is absolute.  */
#   define TIMER_RELTIME	0   /* relative timer */
#   define TIMER_ABSTIME	1   /* absolute timer */
#  endif


/* Getkerninfo clock information structure */
struct clockinfo
  {
    int hz;		/* clock frequency */
    int tick;		/* micro-seconds per hz tick */
    int spare;
    int stathz;		/* statistics clock frequency */
    int profhz;		/* profiling clock frequency */
  };

# endif	/* bits/time.h */
#endif

#ifdef __need_timeval
# undef __need_timeval
# ifndef _STRUCT_TIMEVAL
#  define _STRUCT_TIMEVAL	1
#  include <bits/types.h>

/* A time value that is accurate to the nearest
   microsecond but also has a range of years.  */
struct timeval
  {
    __time_t tv_sec;		/* Seconds.  */
    __suseconds_t tv_usec;	/* Microseconds.  */
  };
# endif	/* struct timeval */
#endif	/* need timeval */