📄 tmtest.adb
字号:
---- 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 + -