annotate gcc/ada/libgnat/s-osprim__darwin.adb @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ------------------------------------------------------------------------------
kono
parents:
diff changeset
2 -- --
kono
parents:
diff changeset
3 -- GNAT RUN-TIME LIBRARY (GNARL) COMPONENTS --
kono
parents:
diff changeset
4 -- --
kono
parents:
diff changeset
5 -- S Y S T E M . O S _ P R I M I T I V E S --
kono
parents:
diff changeset
6 -- --
kono
parents:
diff changeset
7 -- B o d y --
kono
parents:
diff changeset
8 -- --
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
9 -- Copyright (C) 1998-2018, Free Software Foundation, Inc. --
111
kono
parents:
diff changeset
10 -- --
kono
parents:
diff changeset
11 -- GNARL is free software; you can redistribute it and/or modify it under --
kono
parents:
diff changeset
12 -- terms of the GNU General Public License as published by the Free Soft- --
kono
parents:
diff changeset
13 -- ware Foundation; either version 3, or (at your option) any later ver- --
kono
parents:
diff changeset
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
kono
parents:
diff changeset
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
kono
parents:
diff changeset
16 -- or FITNESS FOR A PARTICULAR PURPOSE. --
kono
parents:
diff changeset
17 -- --
kono
parents:
diff changeset
18 -- As a special exception under Section 7 of GPL version 3, you are granted --
kono
parents:
diff changeset
19 -- additional permissions described in the GCC Runtime Library Exception, --
kono
parents:
diff changeset
20 -- version 3.1, as published by the Free Software Foundation. --
kono
parents:
diff changeset
21 -- --
kono
parents:
diff changeset
22 -- You should have received a copy of the GNU General Public License and --
kono
parents:
diff changeset
23 -- a copy of the GCC Runtime Library Exception along with this program; --
kono
parents:
diff changeset
24 -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see --
kono
parents:
diff changeset
25 -- <http://www.gnu.org/licenses/>. --
kono
parents:
diff changeset
26 -- --
kono
parents:
diff changeset
27 -- GNARL was developed by the GNARL team at Florida State University. --
kono
parents:
diff changeset
28 -- Extensive contributions were provided by Ada Core Technologies, Inc. --
kono
parents:
diff changeset
29 -- --
kono
parents:
diff changeset
30 ------------------------------------------------------------------------------
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 -- This version is for darwin
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 package body System.OS_Primitives is
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 -- ??? These definitions are duplicated from System.OS_Interface
kono
parents:
diff changeset
37 -- because we don't want to depend on any package. Consider removing
kono
parents:
diff changeset
38 -- these declarations in System.OS_Interface and move these ones in
kono
parents:
diff changeset
39 -- the spec.
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 type struct_timezone is record
kono
parents:
diff changeset
42 tz_minuteswest : Integer;
kono
parents:
diff changeset
43 tz_dsttime : Integer;
kono
parents:
diff changeset
44 end record;
kono
parents:
diff changeset
45 pragma Convention (C, struct_timezone);
kono
parents:
diff changeset
46 type struct_timezone_ptr is access all struct_timezone;
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 type time_t is new Long_Integer;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 type struct_timeval is record
kono
parents:
diff changeset
51 tv_sec : time_t;
kono
parents:
diff changeset
52 tv_usec : Integer;
kono
parents:
diff changeset
53 end record;
kono
parents:
diff changeset
54 pragma Convention (C, struct_timeval);
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 function gettimeofday
kono
parents:
diff changeset
57 (tv : not null access struct_timeval;
kono
parents:
diff changeset
58 tz : struct_timezone_ptr) return Integer;
kono
parents:
diff changeset
59 pragma Import (C, gettimeofday, "gettimeofday");
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 type timespec is record
kono
parents:
diff changeset
62 tv_sec : time_t;
kono
parents:
diff changeset
63 tv_nsec : Long_Integer;
kono
parents:
diff changeset
64 end record;
kono
parents:
diff changeset
65 pragma Convention (C, timespec);
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 function nanosleep (rqtp, rmtp : not null access timespec) return Integer;
kono
parents:
diff changeset
68 pragma Import (C, nanosleep, "nanosleep");
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 -----------
kono
parents:
diff changeset
71 -- Clock --
kono
parents:
diff changeset
72 -----------
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 function Clock return Duration is
kono
parents:
diff changeset
75 TV : aliased struct_timeval;
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 Result : Integer;
kono
parents:
diff changeset
78 pragma Unreferenced (Result);
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 begin
kono
parents:
diff changeset
81 -- The return codes for gettimeofday are as follows (from man pages):
kono
parents:
diff changeset
82 -- EPERM settimeofday is called by someone other than the superuser
kono
parents:
diff changeset
83 -- EINVAL Timezone (or something else) is invalid
kono
parents:
diff changeset
84 -- EFAULT One of tv or tz pointed outside accessible address space
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 -- None of these codes signal a potential clock skew, hence the return
kono
parents:
diff changeset
87 -- value is never checked.
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 Result := gettimeofday (TV'Access, null);
kono
parents:
diff changeset
90 return Duration (TV.tv_sec) + Duration (TV.tv_usec) / 10#1#E6;
kono
parents:
diff changeset
91 end Clock;
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 -----------------
kono
parents:
diff changeset
94 -- To_Timespec --
kono
parents:
diff changeset
95 -----------------
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 function To_Timespec (D : Duration) return timespec;
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 function To_Timespec (D : Duration) return timespec is
kono
parents:
diff changeset
100 S : time_t;
kono
parents:
diff changeset
101 F : Duration;
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 begin
kono
parents:
diff changeset
104 S := time_t (Long_Long_Integer (D));
kono
parents:
diff changeset
105 F := D - Duration (S);
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 -- If F has negative value due to a round-up, adjust for positive F
kono
parents:
diff changeset
108 -- value.
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 if F < 0.0 then
kono
parents:
diff changeset
111 S := S - 1;
kono
parents:
diff changeset
112 F := F + 1.0;
kono
parents:
diff changeset
113 end if;
kono
parents:
diff changeset
114
kono
parents:
diff changeset
115 return
kono
parents:
diff changeset
116 timespec'(tv_sec => S,
kono
parents:
diff changeset
117 tv_nsec => Long_Integer (Long_Long_Integer (F * 10#1#E9)));
kono
parents:
diff changeset
118 end To_Timespec;
kono
parents:
diff changeset
119
kono
parents:
diff changeset
120 -----------------
kono
parents:
diff changeset
121 -- Timed_Delay --
kono
parents:
diff changeset
122 -----------------
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 procedure Timed_Delay
kono
parents:
diff changeset
125 (Time : Duration;
kono
parents:
diff changeset
126 Mode : Integer)
kono
parents:
diff changeset
127 is
kono
parents:
diff changeset
128 Request : aliased timespec;
kono
parents:
diff changeset
129 Remaind : aliased timespec;
kono
parents:
diff changeset
130 Rel_Time : Duration;
kono
parents:
diff changeset
131 Abs_Time : Duration;
kono
parents:
diff changeset
132 Base_Time : constant Duration := Clock;
kono
parents:
diff changeset
133 Check_Time : Duration := Base_Time;
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 Result : Integer;
kono
parents:
diff changeset
136 pragma Unreferenced (Result);
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 begin
kono
parents:
diff changeset
139 if Mode = Relative then
kono
parents:
diff changeset
140 Rel_Time := Time;
kono
parents:
diff changeset
141 Abs_Time := Time + Check_Time;
kono
parents:
diff changeset
142 else
kono
parents:
diff changeset
143 Rel_Time := Time - Check_Time;
kono
parents:
diff changeset
144 Abs_Time := Time;
kono
parents:
diff changeset
145 end if;
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 if Rel_Time > 0.0 then
kono
parents:
diff changeset
148 loop
kono
parents:
diff changeset
149 Request := To_Timespec (Rel_Time);
kono
parents:
diff changeset
150 Result := nanosleep (Request'Access, Remaind'Access);
kono
parents:
diff changeset
151 Check_Time := Clock;
kono
parents:
diff changeset
152
kono
parents:
diff changeset
153 exit when Abs_Time <= Check_Time or else Check_Time < Base_Time;
kono
parents:
diff changeset
154
kono
parents:
diff changeset
155 Rel_Time := Abs_Time - Check_Time;
kono
parents:
diff changeset
156 end loop;
kono
parents:
diff changeset
157 end if;
kono
parents:
diff changeset
158 end Timed_Delay;
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 ----------------
kono
parents:
diff changeset
161 -- Initialize --
kono
parents:
diff changeset
162 ----------------
kono
parents:
diff changeset
163
kono
parents:
diff changeset
164 procedure Initialize is
kono
parents:
diff changeset
165 begin
kono
parents:
diff changeset
166 null;
kono
parents:
diff changeset
167 end Initialize;
kono
parents:
diff changeset
168
kono
parents:
diff changeset
169 end System.OS_Primitives;