搜索
bottom↓
回复: 2

altera的CPLD MAX3000A 接收i2c数据,混乱

[复制链接]

出0入0汤圆

发表于 2015-3-4 22:53:05 | 显示全部楼层 |阅读模式
本帖最后由 atom100 于 2015-3-4 23:07 编辑

用altera的CPLD  MAX3000A  系列的EPM3128ATC100-10接收i2c数据,cpld 不需要回应,只检测接收数据,
功能:按i2c时序 接收led_data上的数据,cpld不需要 发送ACK信号,led_clk是i2c的时钟
时序如下




下面代码 有什么问题?  我用modelsim仿真没有问题,但放到MAX3000A系列的EPM3128ATC100-10上运行,接收到的  数据总是混乱的 ?我刚用CPLD ,搞不懂
哪位  给指教下 ,cpld_clk的输入时钟是25Mhz
module led(

                        input cpld_clk,
                        input rst_n,
                       
                        input led_data,
                        input led_clk,
                       
                        output [23:0]PANA_LINK,
                        output [23:0]PANA_SPEED,
                       
                        output [5:0]PANB_LINK,
                        output [5:0]PANB_SPEED
                        );
//
reg [1:0]led_data_r;
reg [1:0]led_clk_r;
reg [6:0]data_cnt;
//
reg [23:0]PANA_LINK_r;
reg [23:0]PANA_SPEED_r;
                       
reg [6:0]PANB_LINK_r;
reg [6:0]PANB_SPEED_r;
//
always @(posedge cpld_clk )
        begin               
                led_data_r[1] <= led_data_r[0];
                led_data_r[0] <= led_data;
               
                led_clk_r[1] <= led_clk_r[0];
                led_clk_r[0] <= led_clk;
        end
//

always @(posedge cpld_clk or negedge rst_n)                       
                if(!rst_n)
                                data_cnt <= 7'd0;
                else if(led_clk & led_data_r[1] & ~led_data_r[0])
                                data_cnt <= 7'd0;
                else if(~led_clk_r[1] & led_clk_r[0])
                           data_cnt <= data_cnt + 7'd1;
                       
always @(posedge cpld_clk or negedge rst_n)       
                if(!rst_n)
                        PANA_LINK_r <= 24'hffffff;
                else
                 begin
                        case(data_cnt)
                        7'd0: PANA_LINK_r[0] <= led_data_r[0];
                        7'd1: PANB_LINK_r[0] <= led_data_r[0];
                                .
                                .
                                .
                                .  
                                .
                                .
                               
                        default:;
                        endcase                  
                 end


assign PANA_LINK[0] <= PANA_LINK_r[0] ;
assign PANB_LINK[0] <= PANB_LINK_r[0] ;
                                .
                                .
                                .
  
endmodule

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

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

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出20入186汤圆

发表于 2015-3-5 08:24:20 | 显示全部楼层
你需要对CLK,DATA时钟都要做下降沿处理,I2C开始是CLK高电平,DAT下降沿,看上边代码你没有对DAT引脚做下降沿检测处理

出0入0汤圆

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

本版积分规则

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

GMT+8, 2024-8-27 00:13

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

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