blob: 6db8f962be6ed092b5d87a2318b1eeebf0eaf294 [file] [log] [blame]
-- C94002A.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 A UNIT WITH DEPENDENT TASKS CREATED BY (LOCAL)
-- ALLOCATORS DOES NOT TERMINATE UNTIL ALL DEPENDENT TASKS ARE
-- TERMINATED.
-- SUBTESTS ARE:
-- (A, B) A SIMPLE TASK ALLOCATOR, IN A BLOCK.
-- (C, D) A RECORD OF TASK ALLOCATOR, IN A FUNCTION.
-- (E, F) A RECORD OF ARRAY OF TASK ALLOCATOR, IN A TASK BODY.
-- THIS TEST CONTAINS SHARED VARIABLES AND RACE CONDITIONS.
-- JRK 10/2/81
-- SPS 11/2/82
-- SPS 11/21/82
-- JRK 11/29/82
-- TBN 8/25/86 REDUCED DELAYS; ADDED LIMITED PRIVATE TYPES;
-- INCLUDED EXITS BY RAISING AN EXCEPTION.
-- PWN 01/31/95 REMOVED PRAGMA PRIORITY FOR ADA 9X.
with Impdef;
WITH REPORT; USE REPORT;
WITH SYSTEM; USE SYSTEM;
PROCEDURE C94002A IS
PACKAGE P IS
MY_EXCEPTION : EXCEPTION;
GLOBAL : INTEGER;
TASK TYPE T1 IS
ENTRY E (I : INTEGER);
END T1;
TYPE T2 IS LIMITED PRIVATE;
PROCEDURE CALL_ENTRY (A : T2; B : INTEGER);
PRIVATE
TASK TYPE T2 IS
ENTRY E (I : INTEGER);
END T2;
END P;
PACKAGE BODY P IS
TASK BODY T1 IS
LOCAL : INTEGER;
BEGIN
ACCEPT E (I : INTEGER) DO
LOCAL := I;
END E;
DELAY 30.0 * Impdef.One_Second; -- SINCE THE PARENT UNIT HAS HIGHER
-- PRIORITY AT THIS POINT, IT WILL
-- RECEIVE CONTROL AND TERMINATE IF
-- THE ERROR IS PRESENT.
GLOBAL := LOCAL;
END T1;
TASK BODY T2 IS
LOCAL : INTEGER;
BEGIN
ACCEPT E (I : INTEGER) DO
LOCAL := I;
END E;
DELAY 30.0 * Impdef.One_Second;
GLOBAL := LOCAL;
END T2;
PROCEDURE CALL_ENTRY (A : T2; B : INTEGER) IS
BEGIN
A.E (B);
END CALL_ENTRY;
END P;
USE P;
BEGIN
TEST ("C94002A", "CHECK THAT A UNIT WITH DEPENDENT TASKS " &
"CREATED BY (LOCAL) ALLOCATORS DOES NOT " &
"TERMINATE UNTIL ALL DEPENDENT TASKS " &
"ARE TERMINATED");
--------------------------------------------------
GLOBAL := IDENT_INT (0);
BEGIN -- (A)
DECLARE
TYPE A_T IS ACCESS T1;
A : A_T;
BEGIN
IF EQUAL (3, 3) THEN
A := NEW T1;
A.ALL.E (IDENT_INT(1));
RAISE MY_EXCEPTION;
END IF;
END;
FAILED ("MY_EXCEPTION WAS NOT RAISED - 1");
EXCEPTION
WHEN MY_EXCEPTION =>
IF GLOBAL /= 1 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"BLOCK EXIT - 1");
END IF;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION RAISED - 1");
END; -- (A)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (B)
TYPE A_T IS ACCESS T2;
A : A_T;
BEGIN -- (B)
IF EQUAL (3, 3) THEN
A := NEW T2;
CALL_ENTRY (A.ALL, IDENT_INT(2));
END IF;
END; -- (B)
IF GLOBAL /= 2 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"BLOCK EXIT - 2");
END IF;
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (C)
I : INTEGER;
FUNCTION F RETURN INTEGER IS
TYPE RT;
TYPE ART IS ACCESS RT;
TYPE RT IS
RECORD
A : ART;
T : T1;
END RECORD;
LIST : ART;
TEMP : ART;
BEGIN
FOR I IN 1 .. IDENT_INT (1) LOOP
TEMP := NEW RT;
TEMP.A := LIST;
LIST := TEMP;
LIST.T.E (IDENT_INT(3));
END LOOP;
RETURN 0;
END F;
BEGIN -- (C)
I := F;
IF GLOBAL /= 3 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"FUNCTION EXIT - 3");
END IF;
END; -- (C)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (D)
I : INTEGER;
FUNCTION F RETURN INTEGER IS
TYPE RT;
TYPE ART IS ACCESS RT;
TYPE RT IS
RECORD
A : ART;
T : T2;
END RECORD;
LIST : ART;
TEMP : ART;
BEGIN
FOR I IN 1 .. IDENT_INT (1) LOOP
TEMP := NEW RT;
TEMP.A := LIST;
LIST := TEMP;
CALL_ENTRY (LIST.T, IDENT_INT(4));
IF EQUAL (3, 3) THEN
RAISE MY_EXCEPTION;
END IF;
END LOOP;
RETURN 0;
END F;
BEGIN -- (D)
I := F;
FAILED ("MY_EXCEPTION WAS NOT RAISED - 4");
EXCEPTION
WHEN MY_EXCEPTION =>
IF GLOBAL /= 4 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"FUNCTION EXIT - 4");
END IF;
WHEN OTHERS =>
FAILED ("UNEXPECTED EXCEPTION RAISED - 4");
END; -- (D)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (E)
LOOP_COUNT : INTEGER := 0;
CUT_OFF : CONSTANT := 5 * 60; -- FIVE MINUTE DELAY.
TASK TSK IS
ENTRY ENT;
END TSK;
TASK BODY TSK IS
TYPE ARR IS ARRAY (1..1) OF T1;
TYPE RAT;
TYPE ARAT IS ACCESS RAT;
TYPE RAT IS
RECORD
A : ARAT;
T : ARR;
END RECORD;
LIST : ARAT;
TEMP : ARAT;
BEGIN
FOR I IN 1 .. IDENT_INT (1) LOOP
TEMP := NEW RAT;
TEMP.A := LIST;
LIST := TEMP;
LIST.T(1).E (IDENT_INT(5));
IF EQUAL (3, 3) THEN
RAISE MY_EXCEPTION;
END IF;
END LOOP;
END TSK;
BEGIN -- (E)
WHILE NOT TSK'TERMINATED AND LOOP_COUNT < CUT_OFF LOOP
DELAY 1.0 * Impdef.One_Second;
LOOP_COUNT := LOOP_COUNT + 1;
END LOOP;
IF LOOP_COUNT >= CUT_OFF THEN
FAILED ("DEPENDENT TASK NOT TERMINATED WITHIN FIVE " &
"MINUTES - 5");
END IF;
IF GLOBAL /= 5 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"TASK EXIT - 5");
END IF;
END; -- (E)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (F)
LOOP_COUNT : INTEGER := 0;
CUT_OFF : CONSTANT := 5 * 60; -- FIVE MINUTE DELAY.
TASK TSK IS
ENTRY ENT;
END TSK;
TASK BODY TSK IS
TYPE ARR IS ARRAY (1..1) OF T2;
TYPE RAT;
TYPE ARAT IS ACCESS RAT;
TYPE RAT IS
RECORD
A : ARAT;
T : ARR;
END RECORD;
LIST : ARAT;
TEMP : ARAT;
BEGIN
FOR I IN 1 .. IDENT_INT (1) LOOP
TEMP := NEW RAT;
TEMP.A := LIST;
LIST := TEMP;
CALL_ENTRY (LIST.T(1), IDENT_INT(6));
END LOOP;
END TSK;
BEGIN -- (F)
WHILE NOT TSK'TERMINATED AND LOOP_COUNT < CUT_OFF LOOP
DELAY 1.0 * Impdef.One_Second;
LOOP_COUNT := LOOP_COUNT + 1;
END LOOP;
IF LOOP_COUNT >= CUT_OFF THEN
FAILED ("DEPENDENT TASK NOT TERMINATED WITHIN FIVE " &
"MINUTES - 6");
END IF;
IF GLOBAL /= 6 THEN
FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &
"TASK EXIT - 6");
END IF;
END; -- (F)
RESULT;
END C94002A;