[问答] iic eeprom verilog 仿真

[复制链接]

实习生

发表于 2018-1-13 20:07:33   189 查看 5 回复 显示全部楼层 倒序浏览
分享
我正在做iic eeprom的仿真,需要一个eeprom 的behavior module,希望大神们指点指点
标签:仿真

实习生

发表于 2018-1-14 10:43:24    楼主|
在写行为级模型时,我看的夏文宇老师的,有一点不明白,每写完一个数据在stop状态里state都清零,所以state一直是 00 01 10循环啊 感觉state加不到11(read状态)
回复

点赞 举报

实习生

发表于 2018-1-14 10:43:30    楼主|
always @(negedge sda)
                if(scl==1)
                        begin
                                state <= state +1;
                                if(state == 2'b11)
                                        disable write_to_eeprom;
                        end
       
        //always@(posedge sda)
       
       
        always@(posedge sda)  //这里是因为写入的第一位数是1(器件地址状态字为10100010)
                if(scl == 1)
                        begin
                                stop_w_r;  //每写完一个字节的数据都产生停止,清零
                                //n = n + 1;
                        end
                else //if(n <= 32'd19)
                        begin
                         casex(state)
                                2'b01:
                                        begin       
                                                read_in;
                                                        if(ctrl_byte == 8'b1010_0010)
                                                                begin
                                                                        state = 2'b10;  
                                                                        write_to_eeprom;
                                                                       
                                                                end
                                                        else
                                                                state = 2'b00;
                                        end
                               
                                2'b11:
                                        read_from_eeprom;
                                default:
                                        state = 2'b00;
                         endcase
                        end
       
        task stop_w_r;
                begin
                        state = 2'b00;
                        addr_byte = 0;
                        ctrl_byte = 0;
                        out_flag = 0;
                        sda_buf = 0;
                end
        endtask
回复

点赞 举报

实习生

发表于 2018-1-14 10:43:56    楼主|
上面是这一部分的程序
回复

点赞 举报

实习生

发表于 2018-1-14 22:29:18    楼主|
已解决
回复

点赞 举报

技术员

发表于 4 天前  
。。。。楼主自给自足啊,厉害了!
回复

点赞 举报

高级模式
您需要登录后才可以回帖 登录 | 注册

关闭

站长推荐 上一条 /7 下一条

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

推荐专区

技术干货集中营

专家问答

用户帮助┃咨询与建议┃版主议事

工程师杂谈

工程师创意

工程师职场

论坛电子赛事

社区活动专版

发烧友活动

-

嵌入式论坛

ARM技术论坛

Android论坛

Linux论坛

单片机/MCU论坛

FPGA|CPLD|ASIC论坛

DSP论坛

嵌入式系统论坛

-

电源技术论坛

电源技术论坛

无线充电技术

-

硬件设计论坛

PCB设计论坛

电路设计论坛

电子元器件论坛

控制|传感

总线技术|接口技术

-

测试测量论坛

LabVIEW论坛

Matlab论坛

测试测量技术专区

仪器仪表技术专区

-

EDA设计论坛

multisim论坛

PADS技术论坛

Protel|AD|DXP论坛

Allegro论坛

proteus论坛|仿真论坛

EasyEDA-中国人自已的EDA工具

Orcad论坛

-

综合技术与应用

电机控制

智能电网

光电及显示

参考设计中心

汽车电子技术论坛

医疗电子论坛

-

开源硬件

-

无线通信论坛

无线通信技术专区

天线|RF射频|微波|雷达技术

-

IC设计论坛

芯片测试与失效分析

Mixed Signal/SOC[数模混合芯片设计]

Analog/RF IC设计

设计与制造封装测试

-

厂商专区

TI论坛

TI Deyisupport社区

-

检测技术与质量

电磁兼容(EMC)设计与整改

安规知识论坛

检测与认证

-

消费电子论坛

手机技术论坛

平板电脑/mid论坛

音视/视频/机顶盒论坛

-

电子论坛综合区

聚丰众筹官方社区

新人报道区

聚丰供应链

-

论坛服务区

-

供求信息发布

供需广告

招聘┃求职发布区

电子展览展会专区