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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [cc/] [cc3120b.ada] - Rev 720

Compare with Previous | Blame | View Log

-- CC3120B.ADA
 
--                             Grant of Unlimited Rights
--
--     Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
--     F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained 
--     unlimited rights in the software and documentation contained herein.
--     Unlimited rights are defined in DFAR 252.227-7013(a)(19).  By making 
--     this public release, the Government intends to confer upon all 
--     recipients unlimited rights  equal to those held by the Government.  
--     These rights include rights to use, duplicate, release or disclose the 
--     released technical data and computer software in whole or in part, in 
--     any manner and for any purpose whatsoever, and to have or permit others 
--     to do so.
--
--                                    DISCLAIMER
--
--     ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
--     DISCLOSED ARE AS IS.  THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED 
--     WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
--     SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE 
--     OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
--     PARTICULAR PURPOSE OF SAID MATERIAL.
--*
-- CHECK THAT TASKS ARE NOT COPIED AS GENERIC IN OUT PARMS.
 
-- DAT 8/27/81
-- SPS 4/6/82
-- JBG 3/23/83
 
WITH REPORT; USE REPORT;
 
PROCEDURE CC3120B IS
BEGIN
     TEST ("CC3120B", "TASKS ARE NOT COPIED AS GENERIC PARAMETERS");
 
     DECLARE
          PACKAGE P IS
               TYPE T IS LIMITED PRIVATE;
               PROCEDURE UPDT (TPARM: IN T; I : IN OUT INTEGER);
          PRIVATE
               TASK TYPE T1 IS
                    ENTRY GET (I : OUT INTEGER);
                    ENTRY PUT (I : IN INTEGER);
               END T1;
               TYPE T IS RECORD
                    C : T1;
               END RECORD;
          END P;
          USE P;
          TT : T;
          GENERIC
               TYPE T IS LIMITED PRIVATE;
               T1 : IN OUT T;
               WITH PROCEDURE UPDT (TPARM : IN T; I: IN OUT INTEGER)
                    IS <> ;
          PROCEDURE PR;
 
          PROCEDURE PR IS
               I : INTEGER;
          BEGIN
               I := 5;
                                        -- PR.I
                                        -- UPDT.I      UPDT.T1.I
                                        --   5            4
               UPDT (T1, I); 
                                        --   4            5
               IF I /= 4 THEN
                    FAILED ("BAD VALUE 1");
               END IF;
               I := 6;
                                        --   6            5
               UPDT (T1, I);
                                        --   5            6
               IF I /= 5 THEN
                    FAILED ("BAD VALUE 3");
               END IF;
               RAISE TASKING_ERROR;
               FAILED ("INCORRECT RAISE STATEMENT");
          END PR;
 
          PACKAGE BODY P IS
               PROCEDURE UPDT (TPARM : IN T; I : IN OUT INTEGER) IS
                    V : INTEGER := I;
                    -- UPDT.I => V
                    -- T1.I => UPDT.I
                    -- V => T1.I
               BEGIN
                    TPARM.C.GET (I);
                    TPARM.C.PUT (V);
               END UPDT;
 
               TASK BODY T1 IS
                    I : INTEGER;
               BEGIN
                    I := 1;
                    LOOP
                         SELECT
                              ACCEPT GET (I : OUT INTEGER) DO
                                   I := T1.I;
                              END GET;
                         OR
                              ACCEPT PUT (I : IN INTEGER) DO
                                   T1.I := I;
                              END PUT;
                         OR
                              TERMINATE;
                         END SELECT;
                    END LOOP;
               END T1;
          END P;
     BEGIN
          DECLARE
               X : INTEGER := 2;
               PROCEDURE PPP IS NEW PR (T, TT);
          BEGIN
                                        -- X
                                        -- UPDT.I      UPDT.T1.I
                                        --   2            1
               UPDT (TT, X);
                                        --   1            2
               X := X + 3;
                                        --   4            2
               UPDT (TT, X);
                                        --   2            4
               IF X /= 2 THEN 
                    FAILED ("WRONG VALUE FOR X");
               END IF;
               BEGIN
                    PPP;
                    FAILED ("PPP NOT CALLED");
               EXCEPTION
                    WHEN TASKING_ERROR => NULL;
               END;
               X := 12;
                                        --   12           6
               UPDT (TT, X);
                                        --   6            12
               IF X /= 6 THEN
                    FAILED ("WRONG FINAL VALUE IN TASK");
               END IF;
          END;
     END;
 
     RESULT;
END CC3120B;
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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