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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [c5/] [c55b07b.dep] - Rev 720

Compare with Previous | Blame | View Log

-- C55B07B.DEP

--                             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.
--*
-- OBJECTIVE:
--     CHECK THAT LOOPS OVER RANGES OF TYPE SHORT_INTEGER
--     CAN BE WRITTEN.

-- APPLICABILITY CRITERIA:
--     THIS TEST IS APPLICABLE TO IMPLEMENTATIONS WHICH SUPPORT
--     THE TYPE SHORT_INTEGER.
--
--     IF THE TYPE SHORT_INTEGER IS NOT SUPPORTED, THEN THE
--     DECLARATION OF CHECK MUST BE REJECTED.

-- HISTORY:
--     RM  07/08/82  CREATED ORIGINAL TEST.
--     BCB 01/04/88  MODIFIED HEADER.


WITH REPORT; USE REPORT;

PROCEDURE C55B07B IS

     CHECK : SHORT_INTEGER;                            -- N/A => ERROR.

     TYPE  NEW_SHORT_INTEGER  IS  NEW SHORT_INTEGER ;

     THE_COUNT : INTEGER := 777 ;   -- JUST A DUMMY...

     SI_VAR   :           SHORT_INTEGER      :=  1 ;
     SI_CON   :  CONSTANT SHORT_INTEGER      :=  1 ;

     NSI_VAR  :           NEW_SHORT_INTEGER  :=  1 ;
     NSI_CON  :  CONSTANT NEW_SHORT_INTEGER  :=  1 ;

     SUBTYPE   SI_SEGMENT  IS  SHORT_INTEGER RANGE
                               SHORT_INTEGER'LAST..SHORT_INTEGER'LAST ;

     SUBTYPE  NSI_SEGMENT  IS  NEW_SHORT_INTEGER RANGE
                               NEW_SHORT_INTEGER'FIRST..
                               NEW_SHORT_INTEGER'FIRST ;

     COUNT : INTEGER := 0;

     PROCEDURE  BUMP ( DUMMY : INTEGER )  IS
     BEGIN
          COUNT := COUNT + 1;
     END  BUMP;

BEGIN

     TEST ( "C55B07B" , "LOOPS OVER RANGES OF TYPE  SHORT_INTEGER " );

     FOR  I  IN  1..SI_CON  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  NSI_VAR..1  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  1..SHORT_INTEGER(1)  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  1..NEW_SHORT_INTEGER(1)  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  SI_SEGMENT  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  REVERSE NSI_SEGMENT  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  SHORT_INTEGER RANGE 1..1  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  NEW_SHORT_INTEGER RANGE 1..1  LOOP
          BUMP(THE_COUNT) ;
     END LOOP;

     FOR  I  IN  SHORT_INTEGER LOOP
          BUMP(THE_COUNT) ;
          EXIT WHEN  I = SHORT_INTEGER'FIRST + 1;
     END LOOP;

     FOR  I  IN  NEW_SHORT_INTEGER LOOP
          BUMP(THE_COUNT) ;
          EXIT WHEN  I = NEW_SHORT_INTEGER'FIRST + 1;
     END LOOP;


     IF  COUNT /= 12  THEN
          FAILED ("WRONG LOOP COUNT");
     END IF;


     RESULT;


END  C55B07B ;

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.