搜索
bottom↓
回复: 3

新手求助,Verilog编写SPI读取计数的问题

[复制链接]

出0入0汤圆

发表于 2010-6-9 12:22:29 | 显示全部楼层 |阅读模式
现在是ss为高电平时取计数数据,低电平时SPI发送,仿真通过但总觉得有点别扭
请教如何改?才能达到只在ss的下降沿才执行一次读取计数器的动作。

/* SPI SLAVE */
module Clock(clk,spsck,mosi,miso,ss);
  input clk,spsck,mosi,ss;       
  output miso;

  reg [15:0] counter;
  reg [15:0] out_data;
  reg miso;
       
  always@(posedge clk)
    begin
      counter = counter+1;
    end

  always@(posedge spsck or posedge ss)
    begin
      if (ss)
      begin
        out_data = counter;       // 如何改?才能使此句只在ss的下降沿才执行一次
      end
      else
      begin
        miso = out_data[0];
        out_data = out_data >> 1;
      end
    end
       
endmodule


仿真波形 (原文件名:simclock.JPG)


SPI时序 (原文件名:m8spi.JPG)

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2010-6-9 12:41:30 | 显示全部楼层
negedge ss

出0入0汤圆

 楼主| 发表于 2010-6-9 14:39:56 | 显示全部楼层
楼上可否写详细点

如果这样写always@(posedge spsck or negedge ss)
下面就不知要如何处理了,如再判断ss的话就变成低电平读取计数器而非下降沿读取了

出0入0汤圆

发表于 2010-6-9 22:54:41 | 显示全部楼层
count是基于高频clk时域,
always@(posedge spsck or posedge ss)
    begin
      if (ss)
      begin
        out_data = counter;       // 如何改?才能使此句只在ss的下降沿才执行一次
      end

你用低频的spsck处理out_data = counter; 这样out_data很有可能才空,或者采不到你实际需要的值。
对于采一次ss的下降沿可以这样处理:
always@(posedge spsck)
begin
   ss_buf1 <= ss;
   ss_buf2 <= ss_buf1;
end

assign ss_down = !ss_buf1 && ss_buf2;
//ss_down为ss信号的下降沿
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-6-15 03:31

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表