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

📄 tmtest.adb

📁 RTEMS (Real-Time Executive for Multiprocessor Systems) is a free open source real-time operating sys
💻 ADB
📖 第 1 页 / 共 3 页
字号:
----  TMTEST / BODY----  DESCRIPTION:----  This package is the implementation of Calling Overhead Test 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.7.2.2 2003/09/04 18:43:40 joel Exp $--with DUMMY_RTEMS;with INTERFACES; use INTERFACES;with RTEMS;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      STATUS : RTEMS.STATUS_CODES;   begin      TEXT_IO.NEW_LINE( 2 );      TEXT_IO.PUT_LINE( "*** TIME TEST OVERHEAD ***" );      TIMER_DRIVER.SET_FIND_AVERAGE_OVERHEAD( TRUE );      TMTEST.TASK_NAME( 1 ) := RTEMS.BUILD_NAME(  'T', 'A', '1', ' ' );      RTEMS.TASK_CREATE(          TMTEST.TASK_NAME( 1 ),          254,          2048,          RTEMS.DEFAULT_MODES,         RTEMS.DEFAULT_ATTRIBUTES,         TMTEST.TASK_ID( 1 ),         STATUS      );      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA1" );      RTEMS.TASK_START(         TMTEST.TASK_ID( 1 ),         TMTEST.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-- --  TIMER_HANDLER--   procedure TIMER_HANDLER (      IGNORED_ID      : in     RTEMS.ID;      IGNORED_ADDRESS : in     RTEMS.ADDRESS   ) is   begin      NULL;   end TIMER_HANDLER;--PAGE-- --  ISR_HANDLER--   procedure ISR_HANDLER (      VECTOR : in     RTEMS.VECTOR_NUMBER   ) is   begin      NULL;   end ISR_HANDLER;--PAGE-- --  ASR_HANDLER--   procedure ASR_HANDLER (      SIGNALS : in     RTEMS.SIGNAL_SET   ) is   begin      NULL;   end ASR_HANDLER;--PAGE-- --  TASK_1--   CPU_TABLE      : aliased RTEMS.CPU_TABLE;   procedure TASK_1 (      ARGUMENT : in     RTEMS.TASK_ARGUMENT   ) is      NAME           : RTEMS.NAME;      INDEX          : RTEMS.UNSIGNED32;      OVERHEAD       : RTEMS.UNSIGNED32;      ID             : RTEMS.ID;      IN_PRIORITY    : RTEMS.TASK_PRIORITY;      OUT_PRIORITY   : RTEMS.TASK_PRIORITY;      IN_MODE        : RTEMS.MODE;      MASK           : RTEMS.MODE;      OUT_MODE       : RTEMS.MODE;      NOTE           : RTEMS.UNSIGNED32;      TIME           : RTEMS.TIME_OF_DAY;      TIMEOUT        : RTEMS.INTERVAL;      SIGNALS        : RTEMS.SIGNAL_SET;      ADDRESS_1      : RTEMS.ADDRESS;      EVENTS         : RTEMS.SIGNAL_SET;      BUFFER         : TMTEST.BUFFER;      BUFFER_POINTER : RTEMS.ADDRESS;      MESSAGE_SIZE   : RTEMS.UNSIGNED32;      COUNT          : RTEMS.UNSIGNED32;      MAJOR          : RTEMS.DEVICE_MAJOR_NUMBER;      MINOR          : RTEMS.DEVICE_MINOR_NUMBER;      ERROR          : RTEMS.UNSIGNED32;      STATUS         : RTEMS.STATUS_CODES;   begin      NAME := RTEMS.BUILD_NAME(  'N', 'A', 'M', 'E' );      BUFFER_POINTER := BUFFER'ADDRESS;     -- INITIALIZE_EXECUTIVE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.INITIALIZE_EXECUTIVE(                RTEMS.CONFIGURATION,               CPU_TABLE'ACCESS            );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "INITIALIZE_EXECUTIVE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- SHUTDOWN_EXECUTIVE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.SHUTDOWN_EXECUTIVE( ERROR );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "SHUTDOWN_EXECUTIVE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_CREATE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_CREATE(                NAME,                IN_PRIORITY,                2048,                RTEMS.DEFAULT_MODES,                RTEMS.DEFAULT_ATTRIBUTES,                ID,                STATUS             );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_CREATE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_IDENT      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_IDENT(               NAME,               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,         0      );-- TASK_START      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_START( ID, TMTEST.TASK_1'ACCESS, 0, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_START",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_RESTART      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_RESTART( ID, 0, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_RESTART",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_DELETE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_DELETE( ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_DELETE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_SUSPEND      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_SUSPEND( ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_SUSPEND",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_RESUME      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_RESUME( ID, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_RESUME",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_SET_PRIORITY      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_SET_PRIORITY(                ID,                IN_PRIORITY,                OUT_PRIORITY,                STATUS             );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_SET_PRIORITY",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_MODE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_MODE(                IN_MODE,                MASK,               OUT_MODE,                STATUS             );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_MODE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_GET_NOTE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_GET_NOTE( ID, 1, NOTE, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_GET_NOTE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_SET_NOTE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_SET_NOTE( ID, 1, NOTE, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_SET_NOTE",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_WAKE_WHEN      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_WAKE_WHEN( TIME, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_WAKE_WHEN",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- TASK_WAKE_AFTER      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TASK_WAKE_AFTER( TIMEOUT, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "TASK_WAKE_AFTER",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,         OVERHEAD,         0      );-- INTERRUPT_CATCH      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.INTERRUPT_CATCH(                TMTEST.ISR_HANDLER'ADDRESS,                 RTEMS.VECTOR_NUMBER'FIRST,               ADDRESS_1,               STATUS            );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "INTERRUPT_CATCH",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- CLOCK_GET      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.CLOCK_GET( RTEMS.CLOCK_GET_TOD, TIME'ADDRESS, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "CLOCK_GET",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- CLOCK_SET      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.CLOCK_SET( TIME, STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "CLOCK_SET",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );-- CLOCK_TICK      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.CLOCK_TICK( STATUS );         end loop;      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;      TIME_TEST_SUPPORT.PUT_TIME(          "CLOCK_TICK",         TMTEST.END_TIME,          TIME_TEST_SUPPORT.OPERATION_COUNT,          OVERHEAD,         0      );TEST_SUPPORT.PAUSE;-- TIMER_CREATE      TIMER_DRIVER.INITIALIZE;         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT         loop            DUMMY_RTEMS.TIMER_CREATE( NAME, ID, STATUS );         end loop;

⌨️ 快捷键说明

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