OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [c4/] [c41303w.ada] - Blame information for rev 720

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 720 jeremybenn
-- C41303W.ADA
2
 
3
--                             Grant of Unlimited Rights
4
--
5
--     Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
6
--     F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained 
7
--     unlimited rights in the software and documentation contained herein.
8
--     Unlimited rights are defined in DFAR 252.227-7013(a)(19).  By making 
9
--     this public release, the Government intends to confer upon all 
10
--     recipients unlimited rights  equal to those held by the Government.  
11
--     These rights include rights to use, duplicate, release or disclose the 
12
--     released technical data and computer software in whole or in part, in 
13
--     any manner and for any purpose whatsoever, and to have or permit others 
14
--     to do so.
15
--
16
--                                    DISCLAIMER
17
--
18
--     ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
19
--     DISCLOSED ARE AS IS.  THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED 
20
--     WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
21
--     SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE 
22
--     OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
23
--     PARTICULAR PURPOSE OF SAID MATERIAL.
24
--*
25
-- CHECK THAT THE NOTATION  L.ALL  IS ALLOWED IF  L  IS THE NAME OF AN
26
--     ACCESS OBJECT DESIGNATING A RECORD, AN ARRAY, A SCALAR, OR
27
--     ANOTHER ACCESS OBJECT.
28
-- CHECK THAT IF  A  IS AN IDENTIFIER DENOTING AN ACCESS OBJECT WHICH
29
--     IN TURN DESIGNATES AN ACCESS OBJECT, THE FORM  A.ALL.ALL  IS
30
--     ACCEPTED.
31
 
32
 
33
-- THIS OBJECTIVE IS COVERED IN SEVERAL TESTS. IN THE FOLLOWING DIAGRAM,
34
--     THE PORTION COVERED BY THE CURRENT TEST IS MARKED BY 'X' .
35
 
36
 
37
--                              ||   ASSIGNMT  |  PROC. PARAMETERS
38
--                              ||  ():=  :=() | IN   OUT    IN OUT
39
--      ========================||=============|====================
40
--                 ACC REC      ||             |
41
--                --------------||-------------|--------------------
42
--       1 '.ALL'  ACC ARR      ||             |
43
--                --------------||-------------|--------------------
44
--                 ACC SCLR     ||             |
45
--      ========================||=============|====================
46
--                 ACC ACC REC  ||             |
47
--                --------------||-------------|--------------------
48
--       1 '.ALL'  ACC ACC ARR  ||             |
49
--                --------------||-------------|--------------------
50
--                 ACC ACC SCLR ||             |
51
--      ========================||=============|====================
52
--                 ACC ACC REC  ||             |
53
--                --------------||-------------|--------------------
54
--       2 '.ALL'  ACC ACC ARR  ||             |
55
--                --------------||-------------|--------------------
56
--                 ACC ACC SCLR ||             |     XXXXXXXXX
57
--      ============================================================
58
 
59
 
60
-- RM  1/29/82
61
-- SPS 12/2/82
62
 
63
 
64
WITH REPORT;
65
USE REPORT;
66
PROCEDURE C41303W IS
67
 
68
 
69
BEGIN
70
 
71
     TEST ( "C41303W" , "CHECK THAT IF  A  IS AN IDENTIFIER DENOTING" &
72
                        " AN ACCESS OBJECT WHICH IN TURN DESIGNATES"  &
73
                        " AN ACCESS OBJECT,  THE FORM  A.ALL.ALL  IS" &
74
                        " ACCEPTED" );
75
 
76
 
77
     -------------------------------------------------------------------
78
     ---------------  ACCESS TO ACCESS TO SCALAR  ----------------------
79
 
80
     DECLARE
81
 
82
          TYPE  NEWINT  IS  NEW INTEGER ;
83
 
84
          NEWINT_CONST    :  NEWINT  :=  ( 813 );
85
          NEWINT_VAR      :  NEWINT  :=  NEWINT_CONST  ;
86
          NEWINT_VAR0     :  NEWINT  :=  NEWINT_CONST  ;
87
          NEWINT_CONST2   :  NEWINT  :=  ( 707 );
88
 
89
          TYPE  ACCNEWINT  IS  ACCESS NEWINT ;
90
 
91
          TYPE  ACC_ACCNEWINT  IS  ACCESS ACCNEWINT ;
92
 
93
          ACC_ACCNEWINT_VAR  :  ACC_ACCNEWINT  :=  NEW ACCNEWINT'(
94
                                                   NEW NEWINT' (
95
                                                   NEWINT_CONST2
96
                                                              )
97
                                                                );
98
 
99
          ACC_ACCNEWINT_VAR0 :  ACC_ACCNEWINT  :=  NEW ACCNEWINT'(
100
                                                   NEW NEWINT' (
101
                                                   NEWINT_CONST2
102
                                                              )
103
                                                                );
104
 
105
          PROCEDURE  R_ASSIGN( R_IN    : IN      NEWINT ;
106
                               R_INOUT : IN OUT  NEWINT )  IS
107
          BEGIN
108
               NEWINT_VAR   :=  R_IN    ;
109
               NEWINT_VAR0  :=  R_INOUT ;
110
          END ;
111
 
112
 
113
          PROCEDURE  L_ASSIGN( L_OUT   :    OUT  NEWINT ;
114
                               L_INOUT : IN OUT  NEWINT )  IS
115
          BEGIN
116
               L_OUT   :=  NEWINT_CONST ;
117
               L_INOUT :=  NEWINT_CONST ;
118
          END ;
119
 
120
 
121
     BEGIN
122
 
123
 
124
          R_ASSIGN( ACC_ACCNEWINT_VAR.ALL.ALL  ,
125
                    ACC_ACCNEWINT_VAR0.ALL.ALL );
126
 
127
          IF  NEWINT_VAR /= NEWINT_CONST2
128
          THEN
129
               FAILED( "ACC2 NEWINT, RIGHT SIDE (1), WRONG VAL." );
130
          END IF;
131
 
132
          IF  NEWINT_VAR0 /= NEWINT_CONST2
133
          THEN
134
               FAILED( "ACC2 NEWINT, RIGHT SIDE (2), WRONG VAL." );
135
          END IF;
136
 
137
 
138
          L_ASSIGN( ACC_ACCNEWINT_VAR.ALL.ALL  ,
139
                    ACC_ACCNEWINT_VAR0.ALL.ALL );
140
 
141
          IF  NEWINT_CONST /= ACC_ACCNEWINT_VAR.ALL.ALL
142
          THEN
143
               FAILED( "ACC2 NEWINT, LEFT SIDE (1), WRONG VAL." );
144
          END IF;
145
 
146
          IF  NEWINT_CONST /= ACC_ACCNEWINT_VAR0.ALL.ALL
147
          THEN
148
               FAILED( "ACC2 NEWINT, LEFT SIDE (2), WRONG VAL." );
149
          END IF;
150
 
151
 
152
     END ;
153
 
154
     -------------------------------------------------------------------
155
 
156
     RESULT;
157
 
158
 
159
END C41303W;

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.