dual-edge sensitivity

Joined
May 10, 2007
Messages
1
Reaction score
0
I'm trying to use both edges of my clock signal to count for a clock divider using VHDL. Behaviorally, the simulation works, but it won't synthesize. I'm using a Xilinx Spartan-3e FPGA. I tried it in Verilog and I'm getting the same results. Is this something that VHDL is not allowing me to do or is it my FPGA? Here's an example:


----------------------------------------------------------------------
count : process (clk)
begin

if ( rising_edge(clk) or falling_edge(clk) )then
if num = 20 then
new_clk <= not new_clk;
num <= 0;
else
num <= num + 1;
end if;
clk_slow <= new_clk;
end if;
end process count;
---------------------------------------------------------------------


this didn't work.. so I tried this:


---------------------------------------------------------------------
count : process (clk)
begin

if rising_edge(clk) then
if num = 0 then
new_clk <= not new_clk;
num <= 0;
else
num <= num + 1;
end if;
elsif falling_edge(clk) then
if num = 0 then
new_clk <= not new_clk;
num <= 0;
else
num <= num + 1;
end if;
end if;
clk_slow <= new_clk;
end process count;
---------------------------------------------------------------------

And that gave me errors because of the way I'm synchronizing my signal "num". Any ideas?

Travis
 
Joined
May 22, 2007
Messages
2
Reaction score
0
You are trying to clock a flip flop on both edges, I don´t think that is possible with any Xilinx FPGA.
Spartan 3 has a DCM (Digital Clock Manager) that can divide the clock for you. Search the home page for application notes.
 
Joined
May 4, 2007
Messages
49
Reaction score
0
You can never use both edges of a clock in the same process for a synthesizable design. You must create 2 seperate processes with one using a rising_edge and the other the falling_edge. I'm not sure why you would ever need to count both edges since if you count one you essentially double it to indicate that you have counted both. You might want to explain a little better what you're tying to accomplish.

It is possible to use the high & low levels of the clock to possibly mux different data onto the same line to double throughput speeds. I would recommend simply doubling the clock speed in this case though for a more precise design.

Scott
 
Last edited:

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
474,164
Messages
2,570,897
Members
47,439
Latest member
shasuze

Latest Threads

Top