|
本帖最后由 Ian11122840 于 2012-3-27 14:52 编辑
如题,CPLD时钟是40M,需要测量Sain这个脉冲信号宽度,先对Sain滤波,同步Sain的上升沿,再对时钟clk计数:
问题是这些都有了,如何计算2个上升沿的计数值之差呢?
C语言里很简单的事儿,用CPLD好像没有思路,求大虾指点下,谢谢!!
//////////////////////////////////////////////////////////////////////////////////////
//Ain 信号滤波
always @(posedge clk)
begin
Sain_buf <= {Sain_buf[6:0],Sain};
end
assign safilter = (Sain_buf == 8'hFF)? 1'b1 : 1'b0; //
always@(negedge rst or posedge clk) //RST为低时,全部寄存器清零
begin
if(!rst)
begin
Sa_buf <= 0;
end
else Sa_buf <= {Sa_buf[0],safilter};
end
assign SysRsa = (Sa_buf == 2'b01)? 1'b1 : 1'b0; //同步A的上升沿
再来个时钟的计数
///TIMER
always @(posedge clk)
begin
clkcnt = clkcnt+1;
end
|
阿莫论坛20周年了!感谢大家的支持与爱护!!
知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)
|