找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 405|回复: 0
打印 上一主题 下一主题
收起左侧

一个单片机与其他芯片通信的时序图,求大神解答

[复制链接]
跳转到指定楼层
楼主

如上图,目的是通过图中的时序读出DATAOUT的数据,DATAOUT是并行的,有8个IO,代表bit0---biy7单片机用的  stm32f1
AdrIn对应芯片4个并行IO,接到单片机四个IO,分别代表bit0---bit4,表示地址0-15


片选CS拉低保持时间t1:  大于20ns
地址提前准备时间t2 :  大于5ns
片选CS拉高保持时间t3:大于20ns
输入地址保持时间t4:  大于20ns
数据输出准备时间t5:  最大20ns
数据输出延时td:最大200ns
以下是数据手册的说明:
“在CLK-IN信号的每一个上升边缘后,数据被采样并保存。数据在CS下降边缘后的最新200ns(数据输出延迟)时可在数据总线上提供。地址数据的提供通过ClkOut和AdrOut相应地表示

伪代码:
void  readAllData(void)
{
    for(i = 0; i<16;  i++)  //从地址0开始读
    {
        CLKIN = 0;
        CS = 1;
        CLKIN  =1;
        AddrInSet(i);  //根据地址更改AdrIn的四个IO电平
        delay-ns(10);
        CS = 0;   
        delay-ns(300);
        readDataout();   //读取8个IO电平组成一个字节
        CS = 1;
        CLK = 1;
    }
}

这样一番操作数据始终不对,大神能帮忙看看这个代码对应这个时序哪里有问题


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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