打印
[技术讨论]

单片机与芯片的通信时序图,求解答

[复制链接]
907|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;
        CLKIN = 1;
    }
}

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

未标题-1.jpg (114.81 KB )

未标题-1.jpg

使用特权

评论回复

相关帖子

发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1

主题

1

帖子

0

粉丝