I found this code in how to make a clock divider. I have a general understanding on how to make a divider using counters but i not sure what this code is doing and why its doing it.
entity clkdiv is
Port ( mclk : in STD_LOGIC;
clr : in STD_LOGIC;
clk190 : out STD_LOGIC;
clk48 : out STD_LOGIC);
end clkdiv;
architecture clkdiv of clkdiv is
signal q: std_logic_vector(23 downto 0);
begin
--clock divider
process(mclk,clr)
begin
if clr ='1' then
q <= X"000000";
elsif mclk'event and mclk = '1' then
q <= q+1;
end if;
end process;
clk48 <= q(19);
clk190 <= q(17);
end clkdiv;
I know that the example is on the basis 2 board, the input clock is 50MHz. This code is supposed to create a 48hz clock signal and 190hz clock signal.
50MHz/48Hz = 104166.7, so you can't get there exactly.
If you use a counter which counts up to 104167 at 50MHz, you'll get a single pulse at close to 48 Hz (47.9999846 Hz - which is probably good enough for most purposes).
Don't use the output of the counter as a clock, use a single pulse when it wraps around as a clock enable - you get much better results that way. A single clock throughout the design with enabled sections is the way to do it.
What the above code does is simply that it creates a VHDL module containing a 24 bit counter
q
, which is counted up on each rising edge from the master clockmclk
. It then derivesclk190
andclk48
by using different bits of this counter directly as clock signals.For instance, with
mclk
at 50 MHz, the lsb (q(0)
), would effectively run at 25 MHz. Each rising edge ofmclk
gives you one edge onq(0)
- similarly upwards, so that each subsequent bit runs at half the frequency of the previous bit.For instance:
Your derived clocks will thus be depend on your master clock, and be:
However - generating clocks like this is often the wrong way to do it!
It may seem as if you get nice synchronized clocks, but in reality, they'll be slightly skewed compared to each other, since you're generating what is known as a gated clock (many tools will even warn you about this).
More info on that here, including a way of doing the same thing (but better) with clock enables: VHDL: creating a very slow clock pulse based on a very fast clock