Back to home page

LXR

 
 

    


Warning, /testsuites/ada/support/time_test_support.adb is written in an unsupported language. File is not indexed.

0001 -- SPDX-License-Identifier: BSD-2-Clause
0002 
0003 --
0004 --  TIME_TEST_SUPPORT / SPECIFICATION
0005 --
0006 --  DESCRIPTION:
0007 --
0008 --  This package provides routines which aid the individual tests in
0009 --  the Timing Test Suite and simplify their design and operation.
0010 --
0011 --  DEPENDENCIES: 
0012 --
0013 --  
0014 --
0015 --  COPYRIGHT (c) 1989-2009.
0016 --  On-Line Applications Research Corporation (OAR).
0017 --
0018 --  Redistribution and use in source and binary forms, with or without
0019 --  modification, are permitted provided that the following conditions
0020 --  are met:
0021 --  1. Redistributions of source code must retain the above copyright
0022 --     notice, this list of conditions and the following disclaimer.
0023 --  2. Redistributions in binary form must reproduce the above copyright
0024 --     notice, this list of conditions and the following disclaimer in the
0025 --     documentation and/or other materials provided with the distribution.
0026 --
0027 --  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
0028 --  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
0029 --  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
0030 --  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
0031 --  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
0032 --  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
0033 --  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
0034 --  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
0035 --  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
0036 --  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
0037 --  POSSIBILITY OF SUCH DAMAGE.
0038 --
0039 
0040 with INTERFACES; use INTERFACES;
0041 with TEXT_IO;
0042 with UNSIGNED32_IO;
0043 
0044 package body TIME_TEST_SUPPORT is
0045 
0046 --PAGE
0047 --
0048 --  PUT_TIME
0049 --
0050 
0051    procedure PUT_TIME (
0052       MESSAGE          : in     STRING;
0053       TOTAL_TIME       : in     RTEMS.UNSIGNED32;
0054       ITERATIONS       : in     RTEMS.UNSIGNED32;
0055       LOOP_OVERHEAD    : in     RTEMS.UNSIGNED32;
0056       CALLING_OVERHEAD : in     RTEMS.UNSIGNED32
0057    ) is
0058       PER_ITERATION : RTEMS.UNSIGNED32;
0059    begin
0060 
0061       PER_ITERATION := (TOTAL_TIME - LOOP_OVERHEAD) / ITERATIONS;
0062       PER_ITERATION := PER_ITERATION - CALLING_OVERHEAD;
0063 
0064       if PER_ITERATION = 0 then
0065 
0066          TEXT_IO.PUT( "TOTAL_TIME " );
0067          UNSIGNED32_IO.PUT( TOTAL_TIME );
0068          TEXT_IO.NEW_LINE; 
0069 
0070          TEXT_IO.PUT( "ITERATIONS " );
0071          UNSIGNED32_IO.PUT( ITERATIONS );
0072          TEXT_IO.NEW_LINE; 
0073 
0074          TEXT_IO.PUT( "LOOP_OVERHEAD " );
0075          UNSIGNED32_IO.PUT( LOOP_OVERHEAD );
0076          TEXT_IO.NEW_LINE; 
0077 
0078          TEXT_IO.PUT( "CALLING_OVERHEAD " );
0079          UNSIGNED32_IO.PUT( CALLING_OVERHEAD );
0080          TEXT_IO.NEW_LINE; 
0081 
0082       end if;
0083 
0084       TEXT_IO.PUT( MESSAGE );
0085       TEXT_IO.PUT( " " );
0086       UNSIGNED32_IO.PUT( PER_ITERATION );
0087       TEXT_IO.NEW_LINE; 
0088       TEXT_IO.FLUSH; 
0089 
0090    end PUT_TIME;
0091 
0092 end TIME_TEST_SUPPORT;