annotate gcc/testsuite/ada/acats/tests/cd/cd30001.a @ 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 -- CD30001.A
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 --
kono
parents:
diff changeset
26 -- OBJECTIVE:
kono
parents:
diff changeset
27 -- Check that X'Address produces a useful result when X is an aliased
kono
parents:
diff changeset
28 -- object.
kono
parents:
diff changeset
29 -- Check that X'Address produces a useful result when X is an object of
kono
parents:
diff changeset
30 -- a by-reference type.
kono
parents:
diff changeset
31 -- Check that X'Address produces a useful result when X is an entity
kono
parents:
diff changeset
32 -- whose Address has been specified.
kono
parents:
diff changeset
33 --
kono
parents:
diff changeset
34 -- Check that aliased objects and subcomponents are allocated on storage
kono
parents:
diff changeset
35 -- element boundaries. Check that objects and subcomponents of by
kono
parents:
diff changeset
36 -- reference types are allocated on storage element boundaries.
kono
parents:
diff changeset
37 --
kono
parents:
diff changeset
38 -- Check that for an array X, X'Address points at the first component
kono
parents:
diff changeset
39 -- of the array, and not at the array bounds.
kono
parents:
diff changeset
40 --
kono
parents:
diff changeset
41 -- TEST DESCRIPTION:
kono
parents:
diff changeset
42 -- This test defines a data structure (an array of records) where each
kono
parents:
diff changeset
43 -- aspect of the data structure is aliased. The test checks 'Address
kono
parents:
diff changeset
44 -- for each "layer" of aliased objects.
kono
parents:
diff changeset
45 --
kono
parents:
diff changeset
46 -- APPLICABILITY CRITERIA:
kono
parents:
diff changeset
47 -- All implementations must attempt to compile this test.
kono
parents:
diff changeset
48 --
kono
parents:
diff changeset
49 -- For implementations validating against Systems Programming Annex (C):
kono
parents:
diff changeset
50 -- this test must execute and report PASSED.
kono
parents:
diff changeset
51 --
kono
parents:
diff changeset
52 -- For implementations not validating against Annex C:
kono
parents:
diff changeset
53 -- this test may report compile time errors at one or more points
kono
parents:
diff changeset
54 -- indicated by "-- ANX-C RQMT", in which case it may be graded as inapplicable.
kono
parents:
diff changeset
55 -- Otherwise, the test must execute and report PASSED.
kono
parents:
diff changeset
56 --
kono
parents:
diff changeset
57 --
kono
parents:
diff changeset
58 -- CHANGE HISTORY:
kono
parents:
diff changeset
59 -- 22 JUL 95 SAIC Initial version
kono
parents:
diff changeset
60 -- 08 MAY 96 SAIC Reinforced for 2.1
kono
parents:
diff changeset
61 -- 16 FEB 98 EDS Modified documentation
kono
parents:
diff changeset
62 --!
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 ----------------------------------------------------------------- CD30001_0
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 with SPPRT13;
kono
parents:
diff changeset
67 package CD30001_0 is
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 -- Check that X'Address produces a useful result when X is an aliased
kono
parents:
diff changeset
70 -- object.
kono
parents:
diff changeset
71 -- Check that X'Address produces a useful result when X is an object of
kono
parents:
diff changeset
72 -- a by-reference type.
kono
parents:
diff changeset
73 -- Check that X'Address produces a useful result when X is an entity
kono
parents:
diff changeset
74 -- whose Address has been specified.
kono
parents:
diff changeset
75 -- (using the new form of "for X'Address use ...")
kono
parents:
diff changeset
76 --
kono
parents:
diff changeset
77 -- Check that aliased objects and subcomponents are allocated on storage
kono
parents:
diff changeset
78 -- element boundaries. Check that objects and subcomponents of by
kono
parents:
diff changeset
79 -- reference types are allocated on storage element boundaries.
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 type Simple_Enum_Type is (Just, A, Little, Bit);
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 type Data is record
kono
parents:
diff changeset
84 Aliased_Comp_1 : aliased Simple_Enum_Type;
kono
parents:
diff changeset
85 Aliased_Comp_2 : aliased Simple_Enum_Type;
kono
parents:
diff changeset
86 end record;
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 type Array_W_Aliased_Comps is array(1..2) of aliased Data;
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 Aliased_Object : aliased Array_W_Aliased_Comps;
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 Specific_Object : aliased Array_W_Aliased_Comps;
kono
parents:
diff changeset
93 for Specific_Object'Address use SPPRT13.Variable_Address2; -- ANX-C RQMT.
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 procedure TC_Check_Aliased_Addresses;
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 procedure TC_Check_Specific_Addresses;
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 procedure TC_Check_By_Reference_Types;
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 end CD30001_0;
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 with Report;
kono
parents:
diff changeset
106 with System.Storage_Elements;
kono
parents:
diff changeset
107 with System.Address_To_Access_Conversions;
kono
parents:
diff changeset
108 package body CD30001_0 is
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 package Simple_Enum_Type_Ref_Conv is
kono
parents:
diff changeset
111 new System.Address_To_Access_Conversions(Simple_Enum_Type);
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 package Data_Ref_Conv is new System.Address_To_Access_Conversions(Data);
kono
parents:
diff changeset
114
kono
parents:
diff changeset
115 package Array_W_Aliased_Comps_Ref_Conv is
kono
parents:
diff changeset
116 new System.Address_To_Access_Conversions(Array_W_Aliased_Comps);
kono
parents:
diff changeset
117
kono
parents:
diff changeset
118 use type System.Address;
kono
parents:
diff changeset
119 use type System.Storage_Elements.Integer_Address;
kono
parents:
diff changeset
120 use type System.Storage_Elements.Storage_Offset;
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 procedure TC_Check_Aliased_Addresses is
kono
parents:
diff changeset
123 use type Simple_Enum_Type_Ref_Conv.Object_Pointer;
kono
parents:
diff changeset
124 use type Data_Ref_Conv.Object_Pointer;
kono
parents:
diff changeset
125 use type Array_W_Aliased_Comps_Ref_Conv.Object_Pointer;
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 begin
kono
parents:
diff changeset
128
kono
parents:
diff changeset
129 -- Check the object Aliased_Object
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 if Aliased_Object'Address not in System.Address then
kono
parents:
diff changeset
132 Report.Failed("Aliased_Object'Address not an address");
kono
parents:
diff changeset
133 end if;
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 if Array_W_Aliased_Comps_Ref_Conv.To_Pointer(Aliased_Object'Address)
kono
parents:
diff changeset
136 /= Aliased_Object'Unchecked_Access then
kono
parents:
diff changeset
137 Report.Failed
kono
parents:
diff changeset
138 ("'Unchecked_Access does not match expected address value");
kono
parents:
diff changeset
139 end if;
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 -- Check the element Aliased_Object(1)
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143 if Data_Ref_Conv.To_Address( Aliased_Object(1)'Access )
kono
parents:
diff changeset
144 /= Aliased_Object(1)'Address then
kono
parents:
diff changeset
145 Report.Failed
kono
parents:
diff changeset
146 ("Array element 'Access does not match expected address value");
kono
parents:
diff changeset
147 end if;
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149 -- Check that Array'Address points at the first component...
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 if Array_W_Aliased_Comps_Ref_Conv.To_Address( Aliased_Object'Access )
kono
parents:
diff changeset
152 /= Aliased_Object(1)'Address then
kono
parents:
diff changeset
153 Report.Failed
kono
parents:
diff changeset
154 ("Address of array object does not equal address of first component");
kono
parents:
diff changeset
155 end if;
kono
parents:
diff changeset
156
kono
parents:
diff changeset
157 -- Check the components of Aliased_Object(2)
kono
parents:
diff changeset
158
kono
parents:
diff changeset
159 if Simple_Enum_Type_Ref_Conv.To_Address(
kono
parents:
diff changeset
160 Aliased_Object(2).Aliased_Comp_1'Unchecked_Access)
kono
parents:
diff changeset
161 not in System.Address then
kono
parents:
diff changeset
162 Report.Failed("Component 2 'Unchecked_Access not a valid address");
kono
parents:
diff changeset
163 end if;
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 if Aliased_Object(2).Aliased_Comp_2'Address not in System.Address then
kono
parents:
diff changeset
166 Report.Failed("Component 2 not located at a valid address ");
kono
parents:
diff changeset
167 end if;
kono
parents:
diff changeset
168
kono
parents:
diff changeset
169 end TC_Check_Aliased_Addresses;
kono
parents:
diff changeset
170
kono
parents:
diff changeset
171 procedure TC_Check_Specific_Addresses is
kono
parents:
diff changeset
172 use type System.Address;
kono
parents:
diff changeset
173 use type System.Storage_Elements.Integer_Address;
kono
parents:
diff changeset
174 use type Simple_Enum_Type_Ref_Conv.Object_Pointer;
kono
parents:
diff changeset
175 use type Data_Ref_Conv.Object_Pointer;
kono
parents:
diff changeset
176 use type Array_W_Aliased_Comps_Ref_Conv.Object_Pointer;
kono
parents:
diff changeset
177 begin
kono
parents:
diff changeset
178
kono
parents:
diff changeset
179 -- Check the object Specific_Object
kono
parents:
diff changeset
180
kono
parents:
diff changeset
181 if System.Storage_Elements.To_Integer(Specific_Object'Address)
kono
parents:
diff changeset
182 /= System.Storage_Elements.To_Integer(SPPRT13.Variable_Address2) then
kono
parents:
diff changeset
183 Report.Failed
kono
parents:
diff changeset
184 ("Specific_Object not at address specified in representation clause");
kono
parents:
diff changeset
185 end if;
kono
parents:
diff changeset
186
kono
parents:
diff changeset
187 if Array_W_Aliased_Comps_Ref_Conv.To_Pointer(SPPRT13.Variable_Address2)
kono
parents:
diff changeset
188 /= Specific_Object'Unchecked_Access then
kono
parents:
diff changeset
189 Report.Failed("Specific_Object'Unchecked_Access not expected value");
kono
parents:
diff changeset
190 end if;
kono
parents:
diff changeset
191
kono
parents:
diff changeset
192 -- Check the element Specific_Object(1)
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 if Data_Ref_Conv.To_Address( Specific_Object(1)'Access )
kono
parents:
diff changeset
195 /= Specific_Object(1)'Address then
kono
parents:
diff changeset
196 Report.Failed
kono
parents:
diff changeset
197 ("Specific Array element 'Access does not correspond to the "
kono
parents:
diff changeset
198 & "elements 'Address");
kono
parents:
diff changeset
199 end if;
kono
parents:
diff changeset
200
kono
parents:
diff changeset
201 -- Check that Array'Address points at the first component...
kono
parents:
diff changeset
202
kono
parents:
diff changeset
203 if Array_W_Aliased_Comps_Ref_Conv.To_Address( Specific_Object'Access )
kono
parents:
diff changeset
204 /= Specific_Object(1)'Address then
kono
parents:
diff changeset
205 Report.Failed
kono
parents:
diff changeset
206 ("Address of array object does not equal address of first component");
kono
parents:
diff changeset
207 end if;
kono
parents:
diff changeset
208
kono
parents:
diff changeset
209 -- Check the components of Specific_Object(2)
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 if Simple_Enum_Type_Ref_Conv.To_Address(
kono
parents:
diff changeset
212 Specific_Object(1).Aliased_Comp_1'Access)
kono
parents:
diff changeset
213 not in System.Address then
kono
parents:
diff changeset
214 Report.Failed("Access value of first record component for object at " &
kono
parents:
diff changeset
215 "specific address not a valid address");
kono
parents:
diff changeset
216 end if;
kono
parents:
diff changeset
217
kono
parents:
diff changeset
218 if Specific_Object(2).Aliased_Comp_2'Address not in System.Address then
kono
parents:
diff changeset
219 Report.Failed("Second record component for object at specific " &
kono
parents:
diff changeset
220 "address not located at a valid address");
kono
parents:
diff changeset
221 end if;
kono
parents:
diff changeset
222
kono
parents:
diff changeset
223 end TC_Check_Specific_Addresses;
kono
parents:
diff changeset
224
kono
parents:
diff changeset
225 -- Check that X'Address produces a useful result when X is an object of
kono
parents:
diff changeset
226 -- a by-reference type.
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 type Tagged_But_Not_Exciting is tagged record
kono
parents:
diff changeset
229 A_Bit_Of_Data : Boolean;
kono
parents:
diff changeset
230 end record;
kono
parents:
diff changeset
231
kono
parents:
diff changeset
232 Tagged_Object : Tagged_But_Not_Exciting;
kono
parents:
diff changeset
233
kono
parents:
diff changeset
234 procedure Muck_With_Addresses( It : in out Tagged_But_Not_Exciting;
kono
parents:
diff changeset
235 Its_Address : in System.Address ) is
kono
parents:
diff changeset
236 begin
kono
parents:
diff changeset
237 if It'Address /= Its_Address then
kono
parents:
diff changeset
238 Report.Failed("Address of object passed by reference does not " &
kono
parents:
diff changeset
239 "match address of object passed" );
kono
parents:
diff changeset
240 end if;
kono
parents:
diff changeset
241 end Muck_With_Addresses;
kono
parents:
diff changeset
242
kono
parents:
diff changeset
243 procedure TC_Check_By_Reference_Types is
kono
parents:
diff changeset
244 begin
kono
parents:
diff changeset
245 Muck_With_Addresses( Tagged_Object, Tagged_Object'Address );
kono
parents:
diff changeset
246 end TC_Check_By_Reference_Types;
kono
parents:
diff changeset
247
kono
parents:
diff changeset
248 end CD30001_0;
kono
parents:
diff changeset
249
kono
parents:
diff changeset
250 ------------------------------------------------------------------- CD30001
kono
parents:
diff changeset
251
kono
parents:
diff changeset
252 with Report;
kono
parents:
diff changeset
253 with CD30001_0;
kono
parents:
diff changeset
254 procedure CD30001 is
kono
parents:
diff changeset
255
kono
parents:
diff changeset
256 begin -- Main test procedure.
kono
parents:
diff changeset
257
kono
parents:
diff changeset
258 Report.Test ("CD30001",
kono
parents:
diff changeset
259 "Check that X'Address produces a useful result when X is " &
kono
parents:
diff changeset
260 "an aliased object, or an entity whose Address has been " &
kono
parents:
diff changeset
261 "specified" );
kono
parents:
diff changeset
262
kono
parents:
diff changeset
263 -- Check that X'Address produces a useful result when X is an aliased
kono
parents:
diff changeset
264 -- object.
kono
parents:
diff changeset
265 --
kono
parents:
diff changeset
266 -- Check that aliased objects and subcomponents are allocated on storage
kono
parents:
diff changeset
267 -- element boundaries. Check that objects and subcomponents of by
kono
parents:
diff changeset
268 -- reference types are allocated on storage element boundaries.
kono
parents:
diff changeset
269
kono
parents:
diff changeset
270 CD30001_0.TC_Check_Aliased_Addresses;
kono
parents:
diff changeset
271
kono
parents:
diff changeset
272 -- Check that X'Address produces a useful result when X is an entity
kono
parents:
diff changeset
273 -- whose Address has been specified.
kono
parents:
diff changeset
274
kono
parents:
diff changeset
275 CD30001_0.TC_Check_Specific_Addresses;
kono
parents:
diff changeset
276
kono
parents:
diff changeset
277 -- Check that X'Address produces a useful result when X is an object of
kono
parents:
diff changeset
278 -- a by-reference type.
kono
parents:
diff changeset
279
kono
parents:
diff changeset
280 CD30001_0.TC_Check_By_Reference_Types;
kono
parents:
diff changeset
281
kono
parents:
diff changeset
282 Report.Result;
kono
parents:
diff changeset
283
kono
parents:
diff changeset
284 end CD30001;