OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [c3/] [c3a0006.a] - Diff between revs 294 and 338

Only display areas with differences | Details | Blame | View Log

Rev 294 Rev 338
-- C3A0006.A
-- C3A0006.A
--
--
--                             Grant of Unlimited Rights
--                             Grant of Unlimited Rights
--
--
--     Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
--     Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
--     F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
--     F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
--     unlimited rights in the software and documentation contained herein.
--     unlimited rights in the software and documentation contained herein.
--     Unlimited rights are defined in DFAR 252.227-7013(a)(19).  By making
--     Unlimited rights are defined in DFAR 252.227-7013(a)(19).  By making
--     this public release, the Government intends to confer upon all
--     this public release, the Government intends to confer upon all
--     recipients unlimited rights  equal to those held by the Government.
--     recipients unlimited rights  equal to those held by the Government.
--     These rights include rights to use, duplicate, release or disclose the
--     These rights include rights to use, duplicate, release or disclose the
--     released technical data and computer software in whole or in part, in
--     released technical data and computer software in whole or in part, in
--     any manner and for any purpose whatsoever, and to have or permit others
--     any manner and for any purpose whatsoever, and to have or permit others
--     to do so.
--     to do so.
--
--
--                                    DISCLAIMER
--                                    DISCLAIMER
--
--
--     ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
--     ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
--     DISCLOSED ARE AS IS.  THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
--     DISCLOSED ARE AS IS.  THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
--     WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
--     WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
--     SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
--     SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
--     OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
--     OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
--     PARTICULAR PURPOSE OF SAID MATERIAL.
--     PARTICULAR PURPOSE OF SAID MATERIAL.
--*
--*
--
--
-- OBJECTIVE:
-- OBJECTIVE:
--      Check that access to subprogram may be stored within data
--      Check that access to subprogram may be stored within data
--      structures, and that the access to subprogram can subsequently
--      structures, and that the access to subprogram can subsequently
--      be called.
--      be called.
--
--
-- TEST DESCRIPTION:
-- TEST DESCRIPTION:
--      Declare an access to function type in a package specification.
--      Declare an access to function type in a package specification.
--      Declare an array of the access type.  Declare three different
--      Declare an array of the access type.  Declare three different
--      functions that can be referred to by the access to function type.
--      functions that can be referred to by the access to function type.
--
--
--      In the main program, declare a key function that builds the array
--      In the main program, declare a key function that builds the array
--      by calling each function indirectly through the access value.
--      by calling each function indirectly through the access value.
--
--
--
--
-- CHANGE HISTORY:
-- CHANGE HISTORY:
--      06 Dec 94   SAIC    ACVC 2.0
--      06 Dec 94   SAIC    ACVC 2.0
--
--
--!
--!
package C3A0006_0 is
package C3A0006_0 is
   TC_Sine_Call  : Integer := 0;
   TC_Sine_Call  : Integer := 0;
   TC_Cos_Call   : Integer := 0;
   TC_Cos_Call   : Integer := 0;
   TC_Tan_Call   : Integer := 0;
   TC_Tan_Call   : Integer := 0;
   Sine_Value    : Float :=  4.0;
   Sine_Value    : Float :=  4.0;
   Cos_Value     : Float :=  8.0;
   Cos_Value     : Float :=  8.0;
   Tan_Value     : Float := 10.0;
   Tan_Value     : Float := 10.0;
   -- Type accesses to any function
   -- Type accesses to any function
   type Trig_Function_Ptr is access function
   type Trig_Function_Ptr is access function
      (Angle : in Float) return Float;
      (Angle : in Float) return Float;
   function Sine (Angle : in Float) return Float;
   function Sine (Angle : in Float) return Float;
   function Cos  (Angle : in Float) return Float;
   function Cos  (Angle : in Float) return Float;
   function Tan  (Angle : in Float) return Float;
   function Tan  (Angle : in Float) return Float;
end C3A0006_0;
end C3A0006_0;
-----------------------------------------------------------------------------
-----------------------------------------------------------------------------
package body C3A0006_0 is
package body C3A0006_0 is
   function Sine (Angle : in Float) return Float is
   function Sine (Angle : in Float) return Float is
   begin
   begin
     TC_Sine_Call := TC_Sine_Call + 1;
     TC_Sine_Call := TC_Sine_Call + 1;
     Sine_Value := Sine_Value + Angle;
     Sine_Value := Sine_Value + Angle;
     return Sine_Value;
     return Sine_Value;
   end Sine;
   end Sine;
   function Cos  (Angle: in Float) return Float is
   function Cos  (Angle: in Float) return Float is
   begin
   begin
     TC_Cos_Call := TC_Cos_Call + 1;
     TC_Cos_Call := TC_Cos_Call + 1;
     Cos_Value := Cos_Value - Angle;
     Cos_Value := Cos_Value - Angle;
     return Cos_Value;
     return Cos_Value;
   end Cos;
   end Cos;
   function Tan (Angle : in Float) return Float is
   function Tan (Angle : in Float) return Float is
   begin
   begin
     TC_Tan_Call := TC_Tan_Call + 1;
     TC_Tan_Call := TC_Tan_Call + 1;
     Tan_Value := (Tan_Value + (Tan_Value * Angle));
     Tan_Value := (Tan_Value + (Tan_Value * Angle));
     return Tan_Value;
     return Tan_Value;
   end Tan;
   end Tan;
end C3A0006_0;
end C3A0006_0;
-----------------------------------------------------------------------------
-----------------------------------------------------------------------------
with Report;
with Report;
with C3A0006_0;
with C3A0006_0;
procedure C3A0006 is
procedure C3A0006 is
   Trig_Value, Theta  : Float := 0.0;
   Trig_Value, Theta  : Float := 0.0;
   Total_Routines     : constant := 3;
   Total_Routines     : constant := 3;
   Sine_Total         : constant := 7.0;
   Sine_Total         : constant := 7.0;
   Cos_Total          : constant := 5.0;
   Cos_Total          : constant := 5.0;
   Tan_Total          : constant := 75.0;
   Tan_Total          : constant := 75.0;
   Trig_Table : array (1 .. Total_Routines) of C3A0006_0.Trig_Function_Ptr;
   Trig_Table : array (1 .. Total_Routines) of C3A0006_0.Trig_Function_Ptr;
   -- Key function to build the table
   -- Key function to build the table
   function Call_Trig_Func (Func : C3A0006_0.Trig_Function_Ptr;
   function Call_Trig_Func (Func : C3A0006_0.Trig_Function_Ptr;
                            Operand : Float) return Float is
                            Operand : Float) return Float is
   begin
   begin
      return (Func(Operand));
      return (Func(Operand));
   end Call_Trig_Func;
   end Call_Trig_Func;
begin
begin
   Report.Test ("C3A0006", "Check that access to subprogram may be " &
   Report.Test ("C3A0006", "Check that access to subprogram may be " &
                "stored within data structures, and that the access " &
                "stored within data structures, and that the access " &
                "to subprogram can subsequently be called");
                "to subprogram can subsequently be called");
   Trig_Table := (C3A0006_0.Sine'Access, C3A0006_0.Cos'Access,
   Trig_Table := (C3A0006_0.Sine'Access, C3A0006_0.Cos'Access,
                  C3A0006_0.Tan'Access);
                  C3A0006_0.Tan'Access);
   -- increase the value of Theta to build the table
   -- increase the value of Theta to build the table
   for I in 1 .. Total_Routines loop
   for I in 1 .. Total_Routines loop
      Theta := Theta + 0.5;
      Theta := Theta + 0.5;
      for J in 1 .. Total_Routines loop
      for J in 1 .. Total_Routines loop
         Trig_Value     := Call_Trig_Func (Trig_Table(J), Theta);
         Trig_Value     := Call_Trig_Func (Trig_Table(J), Theta);
      end loop;
      end loop;
   end loop;
   end loop;
   if C3A0006_0.TC_Sine_Call /= Total_Routines
   if C3A0006_0.TC_Sine_Call /= Total_Routines
     or C3A0006_0.TC_Cos_Call /= Total_Routines
     or C3A0006_0.TC_Cos_Call /= Total_Routines
     or C3A0006_0.TC_Tan_Call /= Total_Routines then
     or C3A0006_0.TC_Tan_Call /= Total_Routines then
        Report.Failed ("Incorrect subprograms result");
        Report.Failed ("Incorrect subprograms result");
   end if;
   end if;
   if C3A0006_0.Sine_Value /= Sine_Total
   if C3A0006_0.Sine_Value /= Sine_Total
     or C3A0006_0.Cos_Value /= Cos_Total
     or C3A0006_0.Cos_Value /= Cos_Total
     or C3A0006_0.Tan_Value /= Tan_Total then
     or C3A0006_0.Tan_Value /= Tan_Total then
        Report.Failed ("Incorrect values returned from subprograms");
        Report.Failed ("Incorrect values returned from subprograms");
   end if;
   end if;
   if Trig_Value /= Tan_Total then
   if Trig_Value /= Tan_Total then
        Report.Failed ("Incorrect call order.");
        Report.Failed ("Incorrect call order.");
   end if;
   end if;
   Report.Result;
   Report.Result;
end C3A0006;
end C3A0006;
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.