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;
|