Saturday, 5 March 2016

hdl - Verilog: Check for two negedges in always block


i try to do something like this:


always @ (negedge speed_dec or negedge speed_inc)
begin
do something
end


This doesn't work as checking for 2 negative edges is to demanding and results in only checking for the clock.


I tried do do the check manually:


    reg old_key0;
always @ (KEY[0])
begin
if(KEY[0] == 1 & old_key0 == 0)
do something
old_key0 = KEY[0];
end


But now it completely stops working. Can anyone spot the error?



Answer



The always@ is a sensitivity list and generally not a checking list i.e. it doesn't work as an if-else block.


Instead, it indicates when the register/latch specified in the block needs to change states, typically on a clock edge (register) or level change (latch).


If you're trying to detect an edge on an input, such as for an interrupt detection, the recommended way is to synchronise the edge to an internal shift register.


It could be as simple as this:


reg [1:0] det_edge;
wire sig_edge;
assign sig_edge = (det_edge == 2'b10);

always @(posedge clk)
begin
det_edge <= {det_edge[0], input};
end

Then, you can do whatever you want with the edge signal, possibly as an enable signal to a state machine or other block that does something with your device (such as flagging the interrupt).


So, for your application, you may want to do the above twice and then use the two edge detect signals to control some other device/block.


The key point to remember with all HDL work is that HDL stands for Hardware Description Language. It is a replacement for schematics, not software.


For starters, I would recommend starting with the hardware and then translate that into code i.e. draw the schematic and then write the HDL that describes that circuit schematic.


No comments:

Post a Comment

arduino - Can I use TI&#39;s cc2541 BLE as micro controller to perform operations/ processing instead of ATmega328P AU to save cost?

I am using arduino pro mini (which contains Atmega328p AU ) along with cc2541(HM-10) to process and transfer data over BLE to smartphone. I...