annotate gcc/testsuite/ada/acats/tests/c9/c94008c.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 -- C94008C.ADA
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 -- Grant of Unlimited Rights
kono
parents:
diff changeset
4 --
kono
parents:
diff changeset
5 -- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
kono
parents:
diff changeset
6 -- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
kono
parents:
diff changeset
7 -- unlimited rights in the software and documentation contained herein.
kono
parents:
diff changeset
8 -- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
kono
parents:
diff changeset
9 -- this public release, the Government intends to confer upon all
kono
parents:
diff changeset
10 -- recipients unlimited rights equal to those held by the Government.
kono
parents:
diff changeset
11 -- These rights include rights to use, duplicate, release or disclose the
kono
parents:
diff changeset
12 -- released technical data and computer software in whole or in part, in
kono
parents:
diff changeset
13 -- any manner and for any purpose whatsoever, and to have or permit others
kono
parents:
diff changeset
14 -- to do so.
kono
parents:
diff changeset
15 --
kono
parents:
diff changeset
16 -- DISCLAIMER
kono
parents:
diff changeset
17 --
kono
parents:
diff changeset
18 -- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
kono
parents:
diff changeset
19 -- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
kono
parents:
diff changeset
20 -- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
kono
parents:
diff changeset
21 -- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
kono
parents:
diff changeset
22 -- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
kono
parents:
diff changeset
23 -- PARTICULAR PURPOSE OF SAID MATERIAL.
kono
parents:
diff changeset
24 --*
kono
parents:
diff changeset
25 -- CHECK THAT SELECT WITH TERMINATE ALTERNATIVE WORKS CORRECTLY WITH
kono
parents:
diff changeset
26 -- NESTED TASKS.
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 -- THIS TEST CONTAINS RACE CONDITIONS AND USES A GENERIC INSTANCE THAT
kono
parents:
diff changeset
29 -- CONTAINS TASKS.
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 -- JEAN-PIERRE ROSEN 24 FEBRUARY 1984
kono
parents:
diff changeset
32 -- JRK 4/7/86
kono
parents:
diff changeset
33 -- JBG 8/29/86 ELIMINATED SHARED VARIABLES; ADDED GENERIC UNIT
kono
parents:
diff changeset
34 -- PWN 11/30/94 REMOVED PRAGMA PRIORITY INSTANCES FOR ADA 9X.
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 with Impdef;
kono
parents:
diff changeset
37 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
38 WITH SYSTEM; USE SYSTEM;
kono
parents:
diff changeset
39 PROCEDURE C94008C IS
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 -- GENERIC UNIT FOR DOING UPDATES OF SHARED VARIABLES
kono
parents:
diff changeset
43 GENERIC
kono
parents:
diff changeset
44 TYPE HOLDER_TYPE IS PRIVATE;
kono
parents:
diff changeset
45 TYPE VALUE_TYPE IS PRIVATE;
kono
parents:
diff changeset
46 INITIAL_VALUE : HOLDER_TYPE;
kono
parents:
diff changeset
47 WITH PROCEDURE SET (HOLDER : OUT HOLDER_TYPE;
kono
parents:
diff changeset
48 VALUE : IN HOLDER_TYPE) IS <>;
kono
parents:
diff changeset
49 WITH PROCEDURE UPDATE (HOLDER : IN OUT HOLDER_TYPE;
kono
parents:
diff changeset
50 VALUE : IN VALUE_TYPE) IS <>;
kono
parents:
diff changeset
51 PACKAGE SHARED IS
kono
parents:
diff changeset
52 PROCEDURE SET (VALUE : IN HOLDER_TYPE);
kono
parents:
diff changeset
53 PROCEDURE UPDATE (VALUE : IN VALUE_TYPE);
kono
parents:
diff changeset
54 FUNCTION GET RETURN HOLDER_TYPE;
kono
parents:
diff changeset
55 END SHARED;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 PACKAGE BODY SHARED IS
kono
parents:
diff changeset
58 TASK SHARE IS
kono
parents:
diff changeset
59 ENTRY SET (VALUE : IN HOLDER_TYPE);
kono
parents:
diff changeset
60 ENTRY UPDATE (VALUE : IN VALUE_TYPE);
kono
parents:
diff changeset
61 ENTRY READ (VALUE : OUT HOLDER_TYPE);
kono
parents:
diff changeset
62 END SHARE;
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 TASK BODY SHARE IS
kono
parents:
diff changeset
65 VARIABLE : HOLDER_TYPE;
kono
parents:
diff changeset
66 BEGIN
kono
parents:
diff changeset
67 LOOP
kono
parents:
diff changeset
68 SELECT
kono
parents:
diff changeset
69 ACCEPT SET (VALUE : IN HOLDER_TYPE) DO
kono
parents:
diff changeset
70 SHARED.SET (VARIABLE, VALUE);
kono
parents:
diff changeset
71 END SET;
kono
parents:
diff changeset
72 OR
kono
parents:
diff changeset
73 ACCEPT UPDATE (VALUE : IN VALUE_TYPE) DO
kono
parents:
diff changeset
74 SHARED.UPDATE (VARIABLE, VALUE);
kono
parents:
diff changeset
75 END UPDATE;
kono
parents:
diff changeset
76 OR
kono
parents:
diff changeset
77 ACCEPT READ (VALUE : OUT HOLDER_TYPE) DO
kono
parents:
diff changeset
78 VALUE := VARIABLE;
kono
parents:
diff changeset
79 END READ;
kono
parents:
diff changeset
80 OR
kono
parents:
diff changeset
81 TERMINATE;
kono
parents:
diff changeset
82 END SELECT;
kono
parents:
diff changeset
83 END LOOP;
kono
parents:
diff changeset
84 END SHARE;
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 PROCEDURE SET (VALUE : IN HOLDER_TYPE) IS
kono
parents:
diff changeset
87 BEGIN
kono
parents:
diff changeset
88 SHARE.SET (VALUE);
kono
parents:
diff changeset
89 END SET;
kono
parents:
diff changeset
90
kono
parents:
diff changeset
91 PROCEDURE UPDATE (VALUE : IN VALUE_TYPE) IS
kono
parents:
diff changeset
92 BEGIN
kono
parents:
diff changeset
93 SHARE.UPDATE (VALUE);
kono
parents:
diff changeset
94 END UPDATE;
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 FUNCTION GET RETURN HOLDER_TYPE IS
kono
parents:
diff changeset
97 VALUE : HOLDER_TYPE;
kono
parents:
diff changeset
98 BEGIN
kono
parents:
diff changeset
99 SHARE.READ (VALUE);
kono
parents:
diff changeset
100 RETURN VALUE;
kono
parents:
diff changeset
101 END GET;
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 BEGIN
kono
parents:
diff changeset
104 SHARE.SET (INITIAL_VALUE); -- SET INITIAL VALUE
kono
parents:
diff changeset
105 END SHARED;
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 PACKAGE EVENTS IS
kono
parents:
diff changeset
108
kono
parents:
diff changeset
109 TYPE EVENT_TYPE IS
kono
parents:
diff changeset
110 RECORD
kono
parents:
diff changeset
111 TRACE : STRING (1..4) := "....";
kono
parents:
diff changeset
112 LENGTH : NATURAL := 0;
kono
parents:
diff changeset
113 END RECORD;
kono
parents:
diff changeset
114
kono
parents:
diff changeset
115 PROCEDURE UPDATE (VAR : IN OUT EVENT_TYPE; VAL : CHARACTER);
kono
parents:
diff changeset
116 PROCEDURE SET (VAR : OUT EVENT_TYPE; VAL : EVENT_TYPE);
kono
parents:
diff changeset
117 END EVENTS;
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 PACKAGE COUNTER IS
kono
parents:
diff changeset
120 PROCEDURE UPDATE (VAR : IN OUT INTEGER; VAL : INTEGER);
kono
parents:
diff changeset
121 PROCEDURE SET (VAR : OUT INTEGER; VAL : INTEGER);
kono
parents:
diff changeset
122 END COUNTER;
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 PACKAGE BODY COUNTER IS
kono
parents:
diff changeset
125 PROCEDURE UPDATE (VAR : IN OUT INTEGER; VAL : INTEGER) IS
kono
parents:
diff changeset
126 BEGIN
kono
parents:
diff changeset
127 VAR := VAR + VAL;
kono
parents:
diff changeset
128 END UPDATE;
kono
parents:
diff changeset
129
kono
parents:
diff changeset
130 PROCEDURE SET (VAR : OUT INTEGER; VAL : INTEGER) IS
kono
parents:
diff changeset
131 BEGIN
kono
parents:
diff changeset
132 VAR := VAL;
kono
parents:
diff changeset
133 END SET;
kono
parents:
diff changeset
134 END COUNTER;
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 PACKAGE BODY EVENTS IS
kono
parents:
diff changeset
137 PROCEDURE UPDATE (VAR : IN OUT EVENT_TYPE; VAL : CHARACTER) IS
kono
parents:
diff changeset
138 BEGIN
kono
parents:
diff changeset
139 VAR.LENGTH := VAR.LENGTH + 1;
kono
parents:
diff changeset
140 VAR.TRACE(VAR.LENGTH) := VAL;
kono
parents:
diff changeset
141 END UPDATE;
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143 PROCEDURE SET (VAR : OUT EVENT_TYPE; VAL : EVENT_TYPE) IS
kono
parents:
diff changeset
144 BEGIN
kono
parents:
diff changeset
145 VAR := VAL;
kono
parents:
diff changeset
146 END SET;
kono
parents:
diff changeset
147
kono
parents:
diff changeset
148 END EVENTS;
kono
parents:
diff changeset
149
kono
parents:
diff changeset
150 USE EVENTS, COUNTER;
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 PACKAGE TRACE IS NEW SHARED (EVENT_TYPE, CHARACTER, ("....", 0));
kono
parents:
diff changeset
153 PACKAGE TERMINATE_COUNT IS NEW SHARED (INTEGER, INTEGER, 0);
kono
parents:
diff changeset
154
kono
parents:
diff changeset
155 FUNCTION ENTER_TERMINATE RETURN BOOLEAN IS
kono
parents:
diff changeset
156 BEGIN
kono
parents:
diff changeset
157 TERMINATE_COUNT.UPDATE (1);
kono
parents:
diff changeset
158 RETURN TRUE;
kono
parents:
diff changeset
159 END ENTER_TERMINATE;
kono
parents:
diff changeset
160
kono
parents:
diff changeset
161 BEGIN -- C94008C
kono
parents:
diff changeset
162
kono
parents:
diff changeset
163 TEST ("C94008C", "CHECK CORRECT OPERATION OF SELECT WITH " &
kono
parents:
diff changeset
164 "TERMINATE ALTERNATIVE");
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 DECLARE
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 PROCEDURE EVENT (VAR : CHARACTER) RENAMES TRACE.UPDATE;
kono
parents:
diff changeset
169
kono
parents:
diff changeset
170 TASK T1 IS
kono
parents:
diff changeset
171 ENTRY E1;
kono
parents:
diff changeset
172 END T1;
kono
parents:
diff changeset
173
kono
parents:
diff changeset
174 TASK BODY T1 IS
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 TASK T2 IS
kono
parents:
diff changeset
177 ENTRY E2;
kono
parents:
diff changeset
178 END T2;
kono
parents:
diff changeset
179
kono
parents:
diff changeset
180 TASK BODY T2 IS
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 TASK T3 IS
kono
parents:
diff changeset
183 ENTRY E3;
kono
parents:
diff changeset
184 END T3;
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 TASK BODY T3 IS
kono
parents:
diff changeset
187 BEGIN
kono
parents:
diff changeset
188 SELECT
kono
parents:
diff changeset
189 ACCEPT E3;
kono
parents:
diff changeset
190 OR WHEN ENTER_TERMINATE => TERMINATE;
kono
parents:
diff changeset
191 END SELECT;
kono
parents:
diff changeset
192 EVENT ('D');
kono
parents:
diff changeset
193 END T3;
kono
parents:
diff changeset
194
kono
parents:
diff changeset
195 BEGIN -- T2
kono
parents:
diff changeset
196
kono
parents:
diff changeset
197 SELECT
kono
parents:
diff changeset
198 ACCEPT E2;
kono
parents:
diff changeset
199 OR WHEN ENTER_TERMINATE => TERMINATE;
kono
parents:
diff changeset
200 END SELECT;
kono
parents:
diff changeset
201
kono
parents:
diff changeset
202 DELAY 10.0 * Impdef.One_Second;
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 IF TERMINATE_COUNT.GET /= 1 THEN
kono
parents:
diff changeset
205 DELAY 20.0 * Impdef.One_Long_Second;
kono
parents:
diff changeset
206 END IF;
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 IF TERMINATE_COUNT.GET /= 1 THEN
kono
parents:
diff changeset
209 FAILED ("30 SECOND DELAY NOT ENOUGH - 1 ");
kono
parents:
diff changeset
210 END IF;
kono
parents:
diff changeset
211
kono
parents:
diff changeset
212 EVENT ('C');
kono
parents:
diff changeset
213 T1.E1;
kono
parents:
diff changeset
214 T3.E3;
kono
parents:
diff changeset
215 END T2;
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 BEGIN -- T1;
kono
parents:
diff changeset
218
kono
parents:
diff changeset
219 SELECT
kono
parents:
diff changeset
220 ACCEPT E1;
kono
parents:
diff changeset
221 OR WHEN ENTER_TERMINATE => TERMINATE;
kono
parents:
diff changeset
222 END SELECT;
kono
parents:
diff changeset
223
kono
parents:
diff changeset
224 EVENT ('B');
kono
parents:
diff changeset
225 TERMINATE_COUNT.SET (0);
kono
parents:
diff changeset
226 T2.E2;
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 SELECT
kono
parents:
diff changeset
229 ACCEPT E1;
kono
parents:
diff changeset
230 OR WHEN ENTER_TERMINATE => TERMINATE;
kono
parents:
diff changeset
231 END SELECT;
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 SELECT
kono
parents:
diff changeset
234 ACCEPT E1;
kono
parents:
diff changeset
235 OR TERMINATE; -- ONLY THIS ONE EVER CHOSEN.
kono
parents:
diff changeset
236 END SELECT;
kono
parents:
diff changeset
237
kono
parents:
diff changeset
238 FAILED ("TERMINATE NOT SELECTED IN T1");
kono
parents:
diff changeset
239 END T1;
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 BEGIN
kono
parents:
diff changeset
242
kono
parents:
diff changeset
243 DELAY 10.0 * Impdef.One_Second; -- WAIT FOR T1, T2, AND T3 TO GET TO SELECT STMTS.
kono
parents:
diff changeset
244
kono
parents:
diff changeset
245 IF TERMINATE_COUNT.GET /= 3 THEN
kono
parents:
diff changeset
246 DELAY 20.0 * Impdef.One_Long_Second;
kono
parents:
diff changeset
247 END IF;
kono
parents:
diff changeset
248
kono
parents:
diff changeset
249 IF TERMINATE_COUNT.GET /= 3 THEN
kono
parents:
diff changeset
250 FAILED ("30 SECOND DELAY NOT ENOUGH - 2");
kono
parents:
diff changeset
251 END IF;
kono
parents:
diff changeset
252
kono
parents:
diff changeset
253 EVENT ('A');
kono
parents:
diff changeset
254 T1.E1;
kono
parents:
diff changeset
255
kono
parents:
diff changeset
256 EXCEPTION
kono
parents:
diff changeset
257 WHEN OTHERS => FAILED ("EXCEPTION IN MAIN BLOCK");
kono
parents:
diff changeset
258 END;
kono
parents:
diff changeset
259
kono
parents:
diff changeset
260 IF TRACE.GET.TRACE /= "ABCD" THEN
kono
parents:
diff changeset
261 FAILED ("INCORRECT ORDER OF EVENTS: " & TRACE.GET.TRACE);
kono
parents:
diff changeset
262 END IF;
kono
parents:
diff changeset
263
kono
parents:
diff changeset
264 RESULT;
kono
parents:
diff changeset
265 END C94008C;