aboutsummaryrefslogtreecommitdiffstats
path: root/src/synth/types_utils.adb
blob: 861827520b41b2cb8772052e6dbe56dd747ca632 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
--  Utils for common types.
--  Copyright (C) 2019 Tristan Gingold
--
--  GHDL is free software; you can redistribute it and/or modify it under
--  the terms of the GNU General Public License as published by the Free
--  Software Foundation; either version 2, or (at your option) any later
--  version.
--
--  GHDL is distributed in the hope that it will be useful, but WITHOUT 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
--  along with GHDL; see the file COPYING.  If not, write to the Free
--  Software Foundation, 59 Temple Place - Suite 330, Boston, MA
--  02111-1307, USA.

package body Types_Utils is
   function Sext (V : Uns64; Sz : Natural) return Uns64
   is
      Sh : constant Natural range 0 .. 64 := 64 - Sz;
   begin
      return Shift_Right_Arithmetic (Shift_Left (V, Sh), Sh);
   end Sext;

   function Sext (V : Uns32; Sz : Natural) return Uns32
   is
      Sh : constant Natural range 0 .. 32 := 32 - Sz;
   begin
      return Shift_Right_Arithmetic (Shift_Left (V, Sh), Sh);
   end Sext;
end Types_Utils;