1 ------------------------------------------------------------------------------
3 -- GNAT RUN-TIME COMPONENTS --
5 -- A D A . R E A L _ T I M E --
9 -- Copyright (C) 1992-2015, Free Software Foundation, Inc. --
11 -- This specification is derived from the Ada Reference Manual for use with --
12 -- GNAT. The copyright notice above, and the license provisions that follow --
13 -- apply solely to the contents of the part following the private keyword. --
15 -- GNAT is free software; you can redistribute it and/or modify it under --
16 -- terms of the GNU General Public License as published by the Free Soft- --
17 -- ware Foundation; either version 3, or (at your option) any later ver- --
18 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
19 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
20 -- or FITNESS FOR A PARTICULAR PURPOSE. --
22 -- As a special exception under Section 7 of GPL version 3, you are granted --
23 -- additional permissions described in the GCC Runtime Library Exception, --
24 -- version 3.1, as published by the Free Software Foundation. --
26 -- You should have received a copy of the GNU General Public License and --
27 -- a copy of the GCC Runtime Library Exception along with this program; --
28 -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see --
29 -- <http://www.gnu.org/licenses/>. --
31 -- GNAT was originally developed by the GNAT team at New York University. --
32 -- Extensive contributions were provided by Ada Core Technologies Inc. --
34 ------------------------------------------------------------------------------
36 with System
.Task_Primitives
.Operations
;
37 pragma Elaborate_All
(System
.Task_Primitives
.Operations
);
39 package Ada
.Real_Time
is
42 Time_First
: constant Time
;
43 Time_Last
: constant Time
;
44 Time_Unit
: constant := 10#
1.0#E
-9;
46 type Time_Span
is private;
47 Time_Span_First
: constant Time_Span
;
48 Time_Span_Last
: constant Time_Span
;
49 Time_Span_Zero
: constant Time_Span
;
50 Time_Span_Unit
: constant Time_Span
;
52 Tick
: constant Time_Span
;
53 function Clock
return Time
;
55 function "+" (Left
: Time
; Right
: Time_Span
) return Time
;
56 function "+" (Left
: Time_Span
; Right
: Time
) return Time
;
57 function "-" (Left
: Time
; Right
: Time_Span
) return Time
;
58 function "-" (Left
: Time
; Right
: Time
) return Time_Span
;
60 function "<" (Left
, Right
: Time
) return Boolean;
61 function "<=" (Left
, Right
: Time
) return Boolean;
62 function ">" (Left
, Right
: Time
) return Boolean;
63 function ">=" (Left
, Right
: Time
) return Boolean;
65 function "+" (Left
, Right
: Time_Span
) return Time_Span
;
66 function "-" (Left
, Right
: Time_Span
) return Time_Span
;
67 function "-" (Right
: Time_Span
) return Time_Span
;
68 function "*" (Left
: Time_Span
; Right
: Integer) return Time_Span
;
69 function "*" (Left
: Integer; Right
: Time_Span
) return Time_Span
;
70 function "/" (Left
, Right
: Time_Span
) return Integer;
71 function "/" (Left
: Time_Span
; Right
: Integer) return Time_Span
;
73 function "abs" (Right
: Time_Span
) return Time_Span
;
75 function "<" (Left
, Right
: Time_Span
) return Boolean;
76 function "<=" (Left
, Right
: Time_Span
) return Boolean;
77 function ">" (Left
, Right
: Time_Span
) return Boolean;
78 function ">=" (Left
, Right
: Time_Span
) return Boolean;
80 function To_Duration
(TS
: Time_Span
) return Duration;
81 function To_Time_Span
(D
: Duration) return Time_Span
;
83 function Nanoseconds
(NS
: Integer) return Time_Span
;
84 function Microseconds
(US
: Integer) return Time_Span
;
85 function Milliseconds
(MS
: Integer) return Time_Span
;
87 function Seconds
(S
: Integer) return Time_Span
;
88 pragma Ada_05
(Seconds
);
90 function Minutes
(M
: Integer) return Time_Span
;
91 pragma Ada_05
(Minutes
);
93 type Seconds_Count
is new Long_Long_Integer;
94 -- Seconds_Count needs 64 bits, since the type Time has the full range of
95 -- Duration. The delta of Duration is 10 ** (-9), so the maximum number of
96 -- seconds is 2**63/10**9 = 8*10**9 which does not quite fit in 32 bits.
97 -- However, rather than make this explicitly 64-bits we derive from
98 -- Long_Long_Integer. In normal usage this will have the same effect. But
99 -- in the case of CodePeer with a target configuration file with a maximum
100 -- integer size of 32, it allows analysis of this unit.
102 procedure Split
(T
: Time
; SC
: out Seconds_Count
; TS
: out Time_Span
);
103 function Time_Of
(SC
: Seconds_Count
; TS
: Time_Span
) return Time
;
106 -- Time and Time_Span are represented in 64-bit Duration value in
107 -- nanoseconds. For example, 1 second and 1 nanosecond is represented
108 -- as the stored integer 1_000_000_001. This is for the 64-bit Duration
109 -- case, not clear if this also is used for 32-bit Duration values.
111 type Time
is new Duration;
113 Time_First
: constant Time
:= Time
'First;
115 Time_Last
: constant Time
:= Time
'Last;
117 type Time_Span
is new Duration;
119 Time_Span_First
: constant Time_Span
:= Time_Span
'First;
121 Time_Span_Last
: constant Time_Span
:= Time_Span
'Last;
123 Time_Span_Zero
: constant Time_Span
:= 0.0;
125 Time_Span_Unit
: constant Time_Span
:= 10#
1.0#E
-9;
127 Tick
: constant Time_Span
:=
128 Time_Span
(System
.Task_Primitives
.Operations
.RT_Resolution
);
130 pragma Import
(Intrinsic
, "<");
131 pragma Import
(Intrinsic
, "<=");
132 pragma Import
(Intrinsic
, ">");
133 pragma Import
(Intrinsic
, ">=");
134 pragma Import
(Intrinsic
, "abs");
136 pragma Inline
(Microseconds
);
137 pragma Inline
(Milliseconds
);
138 pragma Inline
(Nanoseconds
);
139 pragma Inline
(Seconds
);
140 pragma Inline
(Minutes
);