summaryrefslogtreecommitdiff
path: root/c/src/ada-tests/sptests/sp08
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>1997-06-02 20:19:03 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>1997-06-02 20:19:03 +0000
commit6d4e604be8b43c0555cd1c9531fe78ae199a1189 (patch)
treeadc303bfeaddf541a8f45ea1597f43bf8bf7a09d /c/src/ada-tests/sptests/sp08
parenta94c5a5d6992b6dca9afec09352ab80db4643078 (diff)
Initial revision
Diffstat (limited to 'c/src/ada-tests/sptests/sp08')
-rw-r--r--c/src/ada-tests/sptests/sp08/sptest.adb351
-rw-r--r--c/src/ada-tests/sptests/sp08/sptest.ads129
2 files changed, 480 insertions, 0 deletions
diff --git a/c/src/ada-tests/sptests/sp08/sptest.adb b/c/src/ada-tests/sptests/sp08/sptest.adb
new file mode 100644
index 0000000000..722af5d6b4
--- /dev/null
+++ b/c/src/ada-tests/sptests/sp08/sptest.adb
@@ -0,0 +1,351 @@
+--
+-- SPTEST / BODY
+--
+-- DESCRIPTION:
+--
+-- This package is the implementation of Test 8 of the RTEMS
+-- Single Processor Test Suite.
+--
+-- DEPENDENCIES:
+--
+--
+--
+-- COPYRIGHT (c) 1989, 1990, 1991, 1992, 1993, 1994.
+-- On-Line Applications Research Corporation (OAR).
+-- All rights assigned to U.S. Government, 1994.
+--
+-- This material may be reproduced by or for the U.S. Government pursuant
+-- to the copyright license under the clause at DFARS 252.227-7013. This
+-- notice must appear in all copies of this file and its derivatives.
+--
+-- sptest.adb,v 1.3 1995/07/12 19:41:36 joel Exp
+--
+
+with INTERFACES; use INTERFACES;
+with RTEMS;
+with TEST_SUPPORT;
+with TEXT_IO;
+with UNSIGNED32_IO;
+
+package body SPTEST is
+
+--PAGE
+--
+-- INIT
+--
+
+ procedure INIT (
+ ARGUMENT : in RTEMS.TASK_ARGUMENT
+ ) is
+ STATUS : RTEMS.STATUS_CODES;
+ begin
+
+ TEXT_IO.NEW_LINE( 2 );
+ TEXT_IO.PUT_LINE( "*** TEST 8 ***" );
+
+ SPTEST.TASK_NAME( 1 ) := RTEMS.BUILD_NAME( 'T', 'A', '1', ' ' );
+
+ RTEMS.TASK_CREATE(
+ SPTEST.TASK_NAME( 1 ),
+ 1,
+ 2048,
+ RTEMS.DEFAULT_MODES,
+ RTEMS.DEFAULT_ATTRIBUTES,
+ SPTEST.TASK_ID( 1 ),
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA1" );
+
+ RTEMS.TASK_START(
+ SPTEST.TASK_ID( 1 ),
+ SPTEST.TASK_1'ACCESS,
+ 0,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA1" );
+
+ RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
+
+ end INIT;
+
+--PAGE
+--
+-- PUT_MODE
+--
+
+ procedure PUT_MODE(
+ COMMENT : in STRING;
+ OUTPUT_MODE : in RTEMS.MODE
+ ) is
+ begin
+
+ TEXT_IO.PUT( COMMENT );
+ UNSIGNED32_IO.PUT( OUTPUT_MODE, BASE => 16, WIDTH => 8 );
+ TEXT_IO.NEW_LINE;
+
+ end PUT_MODE;
+
+--PAGE
+--
+-- TASK_1
+--
+
+ procedure TASK_1 (
+ ARGUMENT : in RTEMS.TASK_ARGUMENT
+ ) is
+ PREVIOUS_MODE : RTEMS.MODE;
+ STATUS : RTEMS.STATUS_CODES;
+ begin
+
+-- BEGINNING OF ASR
+
+ RTEMS.TASK_MODE(
+ RTEMS.ASR,
+ RTEMS.ASR_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - ASR - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.NO_ASR,
+ RTEMS.ASR_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - NO_ASR - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.NO_ASR,
+ RTEMS.ASR_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - NO_ASR - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.ASR,
+ RTEMS.ASR_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - ASR - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+-- END OF ASR
+
+-- BEGINNING OF TIMESLICE
+
+ RTEMS.TASK_MODE(
+ RTEMS.NO_TIMESLICE,
+ RTEMS.TIMESLICE_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - NO_TIMESLICE - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.TIMESLICE,
+ RTEMS.TIMESLICE_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - TIMESLICE - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.TIMESLICE,
+ RTEMS.TIMESLICE_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - TIMESLICE - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.NO_TIMESLICE,
+ RTEMS.TIMESLICE_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - NO_TIMESLICE - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+-- END OF TIMESLICE
+
+-- BEGINNING OF PREEMPT
+
+ RTEMS.TASK_MODE(
+ RTEMS.PREEMPT,
+ RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - PREEMPT - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.NO_PREEMPT,
+ RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - NO_PREEMPT - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.NO_PREEMPT,
+ RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - NO_PREEMPT - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.PREEMPT,
+ RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - PREEMPT - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+-- END OF PREEMPT
+
+-- BEGINNING OF INTERRUPT LEVEL
+
+ RTEMS.TASK_MODE(
+ RTEMS.INTERRUPT_LEVEL( 3 ),
+ RTEMS.INTERRUPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - INTERRUPT_LEVEL( 3 ) - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.INTERRUPT_LEVEL( 5 ),
+ RTEMS.INTERRUPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - INTERRUPT_LEVEL( 5 ) - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+-- END OF INTERRUPT LEVEL
+
+-- BEGINNING OF COMBINATIONS
+
+ RTEMS.TASK_MODE(
+ RTEMS.INTERRUPT_LEVEL( 3 ) + RTEMS.NO_ASR +
+ RTEMS.TIMESLICE + RTEMS.NO_PREEMPT,
+ RTEMS.INTERRUPT_MASK + RTEMS.ASR_MASK +
+ RTEMS.TIMESLICE_MASK + RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - set all modes - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.INTERRUPT_LEVEL( 3 ) + RTEMS.NO_ASR +
+ RTEMS.TIMESLICE + RTEMS.NO_PREEMPT,
+ RTEMS.INTERRUPT_MASK + RTEMS.ASR_MASK +
+ RTEMS.TIMESLICE_MASK + RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - set all modes - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+ RTEMS.TASK_MODE(
+ RTEMS.INTERRUPT_LEVEL( 0 ) + RTEMS.ASR +
+ RTEMS.NO_TIMESLICE + RTEMS.PREEMPT,
+ RTEMS.INTERRUPT_MASK + RTEMS.ASR_MASK +
+ RTEMS.TIMESLICE_MASK + RTEMS.PREEMPT_MASK,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - clear all modes - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+-- END OF COMBINATIONS
+
+-- BEGINNING OF CURRENT MODE
+
+ RTEMS.TASK_MODE(
+ RTEMS.CURRENT_MODE,
+ RTEMS.CURRENT_MODE,
+ PREVIOUS_MODE,
+ STATUS
+ );
+ TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
+ SPTEST.PUT_MODE(
+ "TA1 - task_mode - get current mode - previous mode: ",
+ PREVIOUS_MODE
+ );
+
+-- END OF CURRENT MODE
+
+ TEXT_IO.PUT_LINE( "*** END OF TEST 8 ***" );
+ RTEMS.SHUTDOWN_EXECUTIVE( 0 );
+ end TASK_1;
+
+end SPTEST;
diff --git a/c/src/ada-tests/sptests/sp08/sptest.ads b/c/src/ada-tests/sptests/sp08/sptest.ads
new file mode 100644
index 0000000000..f985758e4d
--- /dev/null
+++ b/c/src/ada-tests/sptests/sp08/sptest.ads
@@ -0,0 +1,129 @@
+--
+-- SPTEST / SPECIFICATION
+--
+-- DESCRIPTION:
+--
+-- This package is the specification for Test 8 of the RTEMS
+-- Single Processor Test Suite.
+--
+-- DEPENDENCIES:
+--
+--
+--
+-- COPYRIGHT (c) 1989, 1990, 1991, 1992, 1993, 1994.
+-- On-Line Applications Research Corporation (OAR).
+-- All rights assigned to U.S. Government, 1994.
+--
+-- This material may be reproduced by or for the U.S. Government pursuant
+-- to the copyright license under the clause at DFARS 252.227-7013. This
+-- notice must appear in all copies of this file and its derivatives.
+--
+-- sptest.ads,v 1.3 1995/07/12 19:41:37 joel Exp
+--
+
+with CLOCK_DRIVER;
+with RTEMS;
+
+package SPTEST is
+
+--
+-- These arrays contain the IDs and NAMEs of all RTEMS tasks created
+-- by this test.
+--
+
+ TASK_ID : array ( RTEMS.UNSIGNED32 range 1 .. 3 ) of RTEMS.ID;
+ TASK_NAME : array ( RTEMS.UNSIGNED32 range 1 .. 3 ) of RTEMS.NAME;
+
+--
+-- INIT
+--
+-- DESCRIPTION:
+--
+-- This RTEMS task initializes the application.
+--
+
+ procedure INIT (
+ ARGUMENT : in RTEMS.TASK_ARGUMENT
+ );
+
+--
+-- PUT_MODE
+--
+-- DESCRIPTION:
+--
+-- This subprogram prints the COMMENT and the OUTPUT_MODE followed
+-- by a carriage return.
+--
+
+ procedure PUT_MODE(
+ COMMENT : in STRING;
+ OUTPUT_MODE : in RTEMS.MODE
+ );
+
+--
+-- TASK_1
+--
+-- DESCRIPTION:
+--
+-- This RTEMS task tests the TASK_MODE directive of the Task Manager.
+--
+
+ procedure TASK_1 (
+ ARGUMENT : in RTEMS.TASK_ARGUMENT
+ );
+
+--
+-- This is the Driver Address Table for this test.
+--
+
+ DEVICE_DRIVERS : aliased RTEMS.DRIVER_ADDRESS_TABLE( 1 .. 1 ) :=
+ (1=>
+ (
+ CLOCK_DRIVER.INITIALIZE'ACCESS, -- Initialization
+ RTEMS.NO_DRIVER_ENTRY, -- Open
+ RTEMS.NO_DRIVER_ENTRY, -- Close
+ RTEMS.NO_DRIVER_ENTRY, -- Read
+ RTEMS.NO_DRIVER_ENTRY, -- Write
+ RTEMS.NO_DRIVER_ENTRY -- Control
+ )
+ );
+
+--
+-- This is the Initialization Tasks Table for this test.
+--
+
+ INITIALIZATION_TASKS : aliased RTEMS.INITIALIZATION_TASKS_TABLE( 1 .. 1 ) :=
+ (1=>
+ (
+ RTEMS.BUILD_NAME( 'U', 'I', '1', ' ' ), -- task name
+ 2048, -- stack size
+ 1, -- priority
+ RTEMS.DEFAULT_ATTRIBUTES, -- attributes
+ SPTEST.INIT'ACCESS, -- entry point
+ RTEMS.NO_PREEMPT, -- initial mode
+ 0 -- argument list
+ )
+ );
+
+--
+-- This is the Configuration Table for this test.
+--
+
+ CONFIGURATION : aliased RTEMS.CONFIGURATION_TABLE := (
+ RTEMS.NULL_ADDRESS, -- will be replaced by BSP
+ 64 * 1024, -- executive RAM size
+ 10, -- maximum # tasks
+ 0, -- maximum # timers
+ 0, -- maximum # semaphores
+ 0, -- maximum # message queues
+ 0, -- maximum # messages
+ 0, -- maximum # partitions
+ 0, -- maximum # regions
+ 0, -- maximum # dp memory areas
+ 0, -- maximum # periods
+ 0, -- maximum # user extensions
+ RTEMS.MILLISECONDS_TO_MICROSECONDS(10), -- # us in a tick
+ 100 -- # ticks in a timeslice
+ );
+
+end SPTEST;