g-altcon.adb   [plain text]


------------------------------------------------------------------------------
--                                                                          --
--                         GNAT COMPILER COMPONENTS                         --
--                                                                          --
--             G N A T . A L T I V E C . C O N V E R S I O N S              --
--                                                                          --
--                                 B o d y                                  --
--                                                                          --
--            Copyright (C) 2005, Free Software Foundation, Inc.            --
--                                                                          --
-- GNAT is free software;  you can  redistribute it  and/or modify it under --
-- terms of the  GNU General Public License as published  by the Free Soft- --
-- ware  Foundation;  either version 2,  or (at your option) any later ver- --
-- sion.  GNAT is distributed in the hope that it will be useful, but WITH- --
-- OUT ANY WARRANTY;  without even the  implied warranty of MERCHANTABILITY --
-- or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License --
-- for  more details.  You should have  received  a copy of the GNU General --
-- Public License  distributed with GNAT;  see file COPYING.  If not, write --
-- to  the Free Software Foundation,  59 Temple Place - Suite 330,  Boston, --
-- MA 02111-1307, USA.                                                      --
--                                                                          --
-- As a special exception,  if other files  instantiate  generics from this --
-- unit, or you link  this unit with other files  to produce an executable, --
-- this  unit  does not  by itself cause  the resulting  executable  to  be --
-- covered  by the  GNU  General  Public  License.  This exception does not --
-- however invalidate  any other reasons why  the executable file  might be --
-- covered by the  GNU Public License.                                      --
--                                                                          --
-- GNAT was originally developed  by the GNAT team at  New York University. --
-- Extensive contributions were provided by Ada Core Technologies Inc.      --
--                                                                          --
------------------------------------------------------------------------------

with Ada.Unchecked_Conversion;

with System; use System;

with GNAT.Altivec.Low_Level_Interface; use GNAT.Altivec.Low_Level_Interface;
with GNAT.Altivec.Low_Level_Vectors;   use GNAT.Altivec.Low_Level_Vectors;

package body GNAT.Altivec.Conversions is

   function To_Varray_unsigned_char is
     new Ada.Unchecked_Conversion (Varray_signed_char,
                                   Varray_unsigned_char);

   function To_Varray_unsigned_char is
     new Ada.Unchecked_Conversion (Varray_bool_char,
                                   Varray_unsigned_char);

   function To_Varray_unsigned_short is
     new Ada.Unchecked_Conversion (Varray_signed_short,
                                   Varray_unsigned_short);

   function To_Varray_unsigned_short is
     new Ada.Unchecked_Conversion (Varray_bool_short,
                                   Varray_unsigned_short);

   function To_Varray_unsigned_short is
      new Ada.Unchecked_Conversion (Varray_pixel,
                                    Varray_unsigned_short);

   function To_Varray_unsigned_int is
     new Ada.Unchecked_Conversion (Varray_signed_int,
                                   Varray_unsigned_int);

   function To_Varray_unsigned_int is
     new Ada.Unchecked_Conversion (Varray_bool_int,
                                   Varray_unsigned_int);

   function To_Varray_unsigned_int is
      new Ada.Unchecked_Conversion (Varray_float,
                                    Varray_unsigned_int);

   function To_Varray_signed_char is
     new Ada.Unchecked_Conversion (Varray_unsigned_char,
                                   Varray_signed_char);

   function To_Varray_bool_char is
     new Ada.Unchecked_Conversion (Varray_unsigned_char,
                                   Varray_bool_char);

   function To_Varray_signed_short is
     new Ada.Unchecked_Conversion (Varray_unsigned_short,
                                   Varray_signed_short);

   function To_Varray_bool_short is
     new Ada.Unchecked_Conversion (Varray_unsigned_short,
                                   Varray_bool_short);

   function To_Varray_pixel is
     new Ada.Unchecked_Conversion (Varray_unsigned_short,
                                   Varray_pixel);

   function To_Varray_signed_int is
     new Ada.Unchecked_Conversion (Varray_unsigned_int,
                                   Varray_signed_int);

   function To_Varray_bool_int is
     new Ada.Unchecked_Conversion (Varray_unsigned_int,
                                   Varray_bool_int);

   function To_Varray_float is
     new Ada.Unchecked_Conversion (Varray_unsigned_int,
                                   Varray_float);

   function To_VUC is new Ada.Unchecked_Conversion (VUC_View, VUC);
   function To_VSC is new Ada.Unchecked_Conversion (VSC_View, VSC);
   function To_VBC is new Ada.Unchecked_Conversion (VBC_View, VBC);
   function To_VUS is new Ada.Unchecked_Conversion (VUS_View, VUS);
   function To_VSS is new Ada.Unchecked_Conversion (VSS_View, VSS);
   function To_VBS is new Ada.Unchecked_Conversion (VBS_View, VBS);
   function To_VUI is new Ada.Unchecked_Conversion (VUI_View, VUI);
   function To_VSI is new Ada.Unchecked_Conversion (VSI_View, VSI);
   function To_VBI is new Ada.Unchecked_Conversion (VBI_View, VBI);
   function To_VF  is new Ada.Unchecked_Conversion (VF_View,  VF);
   function To_VP  is new Ada.Unchecked_Conversion (VP_View,  VP);

   function To_VUC_View is new Ada.Unchecked_Conversion (VUC, VUC_View);
   function To_VSC_View is new Ada.Unchecked_Conversion (VSC, VSC_View);
   function To_VBC_View is new Ada.Unchecked_Conversion (VBC, VBC_View);
   function To_VUS_View is new Ada.Unchecked_Conversion (VUS, VUS_View);
   function To_VSS_View is new Ada.Unchecked_Conversion (VSS, VSS_View);
   function To_VBS_View is new Ada.Unchecked_Conversion (VBS, VBS_View);
   function To_VUI_View is new Ada.Unchecked_Conversion (VUI, VUI_View);
   function To_VSI_View is new Ada.Unchecked_Conversion (VSI, VSI_View);
   function To_VBI_View is new Ada.Unchecked_Conversion (VBI, VBI_View);
   function To_VF_View  is new Ada.Unchecked_Conversion (VF,  VF_View);
   function To_VP_View  is new Ada.Unchecked_Conversion (VP,  VP_View);

   pragma Warnings (Off, Default_Bit_Order);

   ---------------
   -- To_Vector --
   ---------------

   function To_Vector (S : VSC_View) return VSC is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VSC (S);
      else
         declare
            Result : LL_VUC;
            VS     : constant VUC_View :=
                       (Values => To_Varray_unsigned_char (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VSC (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VBC_View) return VBC is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VBC (S);
      else
         declare
            Result : LL_VUC;
            VS     : constant VUC_View :=
                       (Values => To_Varray_unsigned_char (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VBC (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VSS_View) return VSS is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VSS (S);
      else
         declare
            Result : LL_VUS;
            VS     : constant VUS_View :=
                       (Values => To_Varray_unsigned_short (S.Values));
         begin
            Result := To_Vector (VS);
            return VSS (To_LL_VSS (Result));
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VBS_View) return VBS is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VBS (S);
      else
         declare
            Result : LL_VUS;
            VS     : constant VUS_View :=
                       (Values => To_Varray_unsigned_short (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VBS (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VP_View) return VP is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VP (S);
      else
         declare
            Result : LL_VUS;
            VS     : constant VUS_View :=
                       (Values => To_Varray_unsigned_short (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VP (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VSI_View) return VSI is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VSI (S);
      else
         declare
            Result : LL_VUI;
            VS     : constant VUI_View :=
                       (Values => To_Varray_unsigned_int (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VSI (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VBI_View) return VBI is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VBI (S);
      else
         declare
            Result : LL_VUI;
            VS     : constant VUI_View :=
                       (Values => To_Varray_unsigned_int (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VBI (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VF_View) return VF is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VF (S);
      else
         declare
            Result : LL_VUI;
            VS     : constant VUI_View :=
                       (Values => To_Varray_unsigned_int (S.Values));
         begin
            Result := To_Vector (VS);
            return To_LL_VF (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VUC_View) return VUC is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VUC (S);
      else
         declare
            Result : VUC_View;
         begin
            for J in Vchar_Range'Range loop
               Result.Values (J) :=
                 S.Values (Vchar_Range'Last - J + Vchar_Range'First);
            end loop;
            return To_VUC (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VUS_View) return VUS is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VUS (S);
      else
         declare
            Result : VUS_View;
         begin
            for J in Vshort_Range'Range loop
               Result.Values (J) :=
                 S.Values (Vshort_Range'Last - J + Vshort_Range'First);
            end loop;
            return To_VUS (Result);
         end;
      end if;
   end To_Vector;

   function To_Vector (S : VUI_View) return VUI is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VUI (S);
      else
         declare
            Result : VUI_View;
         begin
            for J in Vint_Range'Range loop
               Result.Values (J) :=
                 S.Values (Vint_Range'Last - J + Vint_Range'First);
            end loop;
            return To_VUI (Result);
         end;
      end if;
   end To_Vector;

   --------------
   -- To_View --
   --------------

   function To_View (S : VSC) return VSC_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VSC_View (S);
      else
         declare
            Result : VUC_View;
         begin
            Result := To_View (To_LL_VUC (S));
            return (Values => To_Varray_signed_char (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VBC) return VBC_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VBC_View (S);
      else
         declare
            Result : VUC_View;
         begin
            Result := To_View (To_LL_VUC (S));
            return (Values => To_Varray_bool_char (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VSS) return VSS_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VSS_View (S);
      else
         declare
            Result : VUS_View;
         begin
            Result := To_View (To_LL_VUS (S));
            return (Values => To_Varray_signed_short (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VBS) return VBS_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VBS_View (S);
      else
         declare
            Result : VUS_View;
         begin
            Result := To_View (To_LL_VUS (S));
            return (Values => To_Varray_bool_short (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VP) return VP_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VP_View (S);
      else
         declare
            Result : VUS_View;
         begin
            Result := To_View (To_LL_VUS (S));
            return (Values => To_Varray_pixel (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VSI) return VSI_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VSI_View (S);
      else
         declare
            Result : VUI_View;
         begin
            Result := To_View (To_LL_VUI (S));
            return (Values => To_Varray_signed_int (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VBI) return VBI_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VBI_View (S);
      else
         declare
            Result : VUI_View;
         begin
            Result := To_View (To_LL_VUI (S));
            return (Values => To_Varray_bool_int (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VF) return VF_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VF_View (S);
      else
         declare
            Result : VUI_View;
         begin
            Result := To_View (To_LL_VUI (S));
            return (Values => To_Varray_float (Result.Values));
         end;
      end if;
   end To_View;

   function To_View (S : VUC) return VUC_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VUC_View (S);
      else
         declare
            VS     : constant VUC_View := To_VUC_View (S);
            Result : VUC_View;
         begin
            for J in Vchar_Range'Range loop
               Result.Values (J) :=
                 VS.Values (Vchar_Range'Last - J + Vchar_Range'First);
            end loop;
            return Result;
         end;
      end if;
   end To_View;

   function To_View (S : VUS) return VUS_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VUS_View (S);
      else
         declare
            VS     : constant VUS_View := To_VUS_View (S);
            Result : VUS_View;
         begin
            for J in Vshort_Range'Range loop
               Result.Values (J) :=
                 VS.Values (Vshort_Range'Last - J + Vshort_Range'First);
            end loop;
            return Result;
         end;
      end if;
   end To_View;

   function To_View (S : VUI) return VUI_View is
   begin
      if Default_Bit_Order = High_Order_First then
         return To_VUI_View (S);
      else
         declare
            VS     : constant VUI_View := To_VUI_View (S);
            Result : VUI_View;
         begin
            for J in Vint_Range'Range loop
               Result.Values (J) :=
                 VS.Values (Vint_Range'Last - J + Vint_Range'First);
            end loop;
            return Result;
         end;
      end if;
   end To_View;

end GNAT.Altivec.Conversions;