⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tmtest.adb

📁 RTEMS (Real-Time Executive for Multiprocessor Systems) is a free open source real-time operating sys
💻 ADB
字号:
----  TMTEST / BODY----  DESCRIPTION:----  This package is the implementation of Test 21 of the RTEMS--  Timing Test Suite.----  DEPENDENCIES: ----  ----  COPYRIGHT (c) 1989-1997.--  On-Line Applications Research Corporation (OAR).----  The license and distribution terms for this file may in--  the file LICENSE in this distribution or at--  http://www.rtems.com/license/LICENSE.----  $Id: tmtest.adb,v 1.4.4.2 2003/09/04 18:43:40 joel Exp $--with INTERFACES; use INTERFACES;with RTEMS;with RTEMS_CALLING_OVERHEAD;with TEST_SUPPORT;with TEXT_IO;with TIME_TEST_SUPPORT;with UNSIGNED32_IO;package body TMTEST is--PAGE-- --  INIT--   procedure INIT (      ARGUMENT : in     RTEMS.TASK_ARGUMENT   ) is      ID     : RTEMS.ID;      STATUS : RTEMS.STATUS_CODES;   begin      TEXT_IO.NEW_LINE( 2 );      TEXT_IO.PUT_LINE( "*** TIME TEST 21 ***" );      RTEMS.TASK_CREATE(          RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),         250,         2048,          RTEMS.DEFAULT_MODES,         RTEMS.DEFAULT_ATTRIBUTES,         ID,         STATUS      );      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE TASK_1" );      RTEMS.TASK_START( ID, TMTEST.TASK_1'ACCESS, 0, STATUS );      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START TASK1" );      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );   end INIT;--PAGE-- --  TASK_1--   procedure TASK_1 (      ARGUMENT : in     RTEMS.TASK_ARGUMENT   ) is      INDEX    : RTEMS.UNSIGNED32;      ID       : RTEMS.ID;      OVERHEAD : RTEMS.UNSIGNED32;      STATUS   : RTEMS.STATUS_CODES;   begin      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT      loop         RTEMS.TASK_CREATE(             INDEX,            254,            1024,             RTEMS.DEFAULT_MODES,            RTEMS.DEFAULT_ATTRIBUTES,            ID,            STATUS         );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );         RTEMS.MESSAGE_QUEUE_CREATE(             INDEX,            TIME_TEST_SUPPORT.OPERATION_COUNT,            16,            RTEMS.DEFAULT_ATTRIBUTES,            ID,            STATUS         );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );         RTEMS.SEMAPHORE_CREATE(             INDEX,            TIME_TEST_SUPPORT.OPERATION_COUNT,            RTEMS.DEFAULT_ATTRIBUTES,            RTEMS.NO_PRIORITY,            ID,            STATUS         );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_CREATE" );         RTEMS.REGION_CREATE(             INDEX,            TMTEST.REGION_AREA'ADDRESS,            2048,            16,            RTEMS.DEFAULT_ATTRIBUTES,            ID,            STATUS         );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "REGION_CREATE" );         RTEMS.PARTITION_CREATE(             INDEX,            TMTEST.PARTITION_AREA'ADDRESS,            2048,            128,            RTEMS.DEFAULT_ATTRIBUTES,            ID,            STATUS         );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "PARTITION_CREATE" );         RTEMS.PORT_CREATE(             INDEX,            TMTEST.INTERNAL_PORT_AREA'ADDRESS,            TMTEST.EXTERNAL_PORT_AREA'ADDRESS,            16#FF#,            ID,            STATUS         );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "PORT_CREATE" );         RTEMS.TIMER_CREATE( INDEX, ID, STATUS );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TIMER_CREATE" );         RTEMS.RATE_MONOTONIC_CREATE( INDEX, ID, STATUS );         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "RATE_MONOTONIC_CREATE" );      end loop;      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            TIMER_DRIVER.EMPTY_FUNCTION;         end loop;      OVERHEAD := TIMER_DRIVER.READ_TIMER;      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.TASK_IDENT( INDEX, RTEMS.SEARCH_ALL_NODES, ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.TASK_IDENT       );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.MESSAGE_QUEUE_IDENT(                INDEX,                RTEMS.SEARCH_ALL_NODES,                ID,                STATUS             );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "MESSAGE_QUEUE_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_IDENT      );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.SEMAPHORE_IDENT(                INDEX,                RTEMS.SEARCH_ALL_NODES,                ID,                STATUS            );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "SEMAPHORE_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.SEMAPHORE_IDENT      );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.PARTITION_IDENT(                INDEX,                RTEMS.SEARCH_ALL_NODES,                ID,                STATUS            );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "PARTITION_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.PARTITION_IDENT      );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.REGION_IDENT( INDEX, ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "REGION_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.REGION_IDENT      );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.PORT_IDENT( INDEX, ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "PORT_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.PORT_IDENT      );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.TIMER_IDENT( INDEX, ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TIMER_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.TIMER_IDENT      );      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            RTEMS.RATE_MONOTONIC_IDENT( INDEX, ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "RATE_MONOTONIC_IDENT",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         RTEMS_CALLING_OVERHEAD.RATE_MONOTONIC_IDENT      );      RTEMS.SHUTDOWN_EXECUTIVE( 0 );   end TASK_1;end TMTEST;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -