OpenCores
URL https://opencores.org/ocsvn/distributed_intelligence/distributed_intelligence/trunk

Subversion Repositories distributed_intelligence

[/] [distributed_intelligence/] [trunk/] [SRC/] [rdecal_x16.vhd] - Blame information for rev 5

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 4 leoel
----------------------------------------------------------------------------------
2
-- Company: 
3
-- Engineer: Léo Germond
4
-- 
5
-- Create Date:    19:21:58 11/04/2009 
6
-- Design Name: 
7
-- Module Name:    rdecal_x16 - Behavioral 
8
-- Project Name: 
9
-- Target Devices: 
10
-- Tool versions: 
11
-- Description: 
12
--
13
-- Dependencies: 
14
--
15
-- Revision: 
16
-- Revision 0.01 - File Created
17
-- Additional Comments: 
18
--
19
----------------------------------------------------------------------------------
20
library IEEE;
21
use IEEE.STD_LOGIC_1164.ALL;
22
use IEEE.STD_LOGIC_ARITH.ALL;
23
use IEEE.STD_LOGIC_UNSIGNED.ALL;
24
 
25
---- Uncomment the following library declaration if instantiating
26
---- any Xilinx primitives in this code.
27
--library UNISIM;
28
--use UNISIM.VComponents.all;
29
 
30
entity rdecal_x16 is
31
    Port ( data : in  STD_LOGIC_VECTOR (15 downto 0);
32
           decal_lvl : in  STD_LOGIC_VECTOR (3 downto 0);
33
           decal : out  STD_LOGIC_VECTOR (15 downto 0));
34
end rdecal_x16;
35
 
36
 
37
architecture BarrelShifter of rdecal_x16 is
38
 
39
        signal din: STD_LOGIC_VECTOR (15 downto 0);
40
        signal dout: STD_LOGIC_VECTOR (15 downto 0);
41
 
42
        signal dec1: STD_LOGIC_VECTOR (15 downto 0);
43
        signal dec2: STD_LOGIC_VECTOR (15 downto 0);
44
        signal dec3: STD_LOGIC_VECTOR (15 downto 0);
45
 
46
        component generic_const_rdecal_x16
47
                generic ( BIT_DECAL : natural range 0 to 15 );
48
                Port ( data : in  STD_LOGIC_VECTOR (15 downto 0);
49
           en : in  STD_LOGIC;
50
           decal : out  STD_LOGIC_VECTOR (15 downto 0));
51
        end component;
52
begin
53
        d1 : generic_const_rdecal_x16
54
                generic map(BIT_DECAL => 1)
55
                port map( data => din, en => decal_lvl(0), decal => dec1);
56
 
57
        d2 : generic_const_rdecal_x16
58
                generic map(BIT_DECAL => 2)
59
                port map( data => dec1, en => decal_lvl(1), decal => dec2);
60
 
61
        d3 : generic_const_rdecal_x16
62
                generic map(BIT_DECAL => 4)
63
                port map( data => dec2, en => decal_lvl(2), decal => dec3);
64
 
65
        d4 : generic_const_rdecal_x16
66
                generic map(BIT_DECAL => 8)
67
                port map( data => dec3, en => decal_lvl(3), decal => dout);
68
 
69
                din <= data;
70
                decal <= dout;
71
end BarrelShifter;

powered by: WebSVN 2.1.0

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