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

Subversion Repositories mips_enhanced

[/] [mips_enhanced/] [trunk/] [grlib-gpl-1.0.19-b3188/] [lib/] [gleichmann/] [dac/] [adc_sigdelt_ea.vhd] - Blame information for rev 2

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 dimamali
 
2
library ieee;
3
use ieee.std_logic_1164.all;
4
use ieee.numeric_std.all;
5
 
6
 
7
entity adc_sigdelt is
8
  generic(c_adcin_length : positive := 8);  -- length of binary input vector adc_in
9
  port(
10
    rstn    : in  std_ulogic;           -- resets integrator, high-active
11
    clk     : in  std_ulogic;           -- sampling clock
12
    valid   : out std_ulogic;
13
    adc_fb  : out std_ulogic;           -- feedback
14
    adc_out : out std_logic_vector(c_adcin_length-1 downto 0);  -- output vector
15
    adc_in  : in  std_ulogic            -- input bit stream
16
    );
17
end adc_sigdelt;
18
 
19
architecture rtl of adc_sigdelt is
20
  signal ff            : std_ulogic;    -- registered input flipflop
21
  signal width_counter : integer range 0 to 2**c_adcin_length - 1;
22
  signal one_counter   : integer range 0 to 2**c_adcin_length - 1;
23
begin
24
 
25
  parallelize : process (clk, rstn) is
26
  begin
27
    if rstn = '0' then
28
      ff            <= '0';
29
      width_counter <= 0;
30
      one_counter   <= 0;
31
      valid         <= '0';
32
      adc_out       <= (others => '0');
33
    elsif rising_edge(clk) then
34
      ff <= adc_in;
35
 
36
      if width_counter < 2**c_adcin_length-1 then
37
        width_counter <= width_counter + 1;
38
        valid         <= '0';
39
        if ff = '1' then
40
          one_counter <= one_counter + 1;
41
        end if;
42
      else -- counter overflow
43
        -- reset counters
44
        width_counter <= 0;
45
        one_counter   <= 0;
46
        -- output parallelized value and signal that it is valid
47
        adc_out       <= std_logic_vector(to_unsigned(one_counter, c_adcin_length));
48
        valid         <= '1';
49
      end if;
50
 
51
    end if;
52
  end process parallelize;
53
 
54
  -- feed back read value to comparator
55
  adc_fb <= ff;
56
 
57
end rtl;
58
 

powered by: WebSVN 2.1.0

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