老SDRAM和DDR SDRAM时序图与信号完整性仿真结合运用(2) -版本博客图片丢失,增加图片后又不能上传,shit.

本文主要是介绍老SDRAM和DDR SDRAM时序图与信号完整性仿真结合运用(2) -版本博客图片丢失,增加图片后又不能上传,shit.,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

前一段时间只是以2410和6410时序图简单归纳了一下,现在将时序基础概念和详细计算过程彻底理一遍。    

   传播延迟

     信号从缓冲器出来之后,就要经过传输线到接收终端,信号在传输线上的传输的延时我们称为传播延迟(propagation delay),属于器件外部的延迟,它只和信号的传播速度和线长有关。

     最大/最小飞行时间

     飞行时间(Flight Time)参数,包括最大飞行时间(Max Flight Time)和最小飞行时间(Min Flight Time)。飞行时间包含了传播延迟和信号上升沿变化这两部分因素。在较轻的负载(如单负载)情况下,驱动端的上升沿几乎和接收端的信号的上升沿平行(如上图),所以这时候平均飞行时间和传播延迟时间大体相等;但如果在重负载(如多负载)的情况下,接收信号的上升沿明显变缓,这时候平均飞行时间就会远远大于信号的传播延迟。这里说的平均飞行时间是指Buffer波形的Vms到接收端波形Vms之间的延时,这个参数只能用于时序的估算,准确的时序分析一定要通过仿真测量最大/最小飞行时间来计算。上面只是对信号上升沿的分析,对于下降沿来说,同样存在着最大/最小飞行时间的参数,如下图。在时序计算时我们实际取的最大飞行时间是在上升沿和下降沿中取最长的那个飞行时间,而最小飞行时间则是取上升和下降沿中最短的那个飞行时间。也有些时候,人们对信号的最大/最小飞行时间还有其它称谓,比如在Cadence软件中,就将最大飞行时间称为最终稳定延时(Final Settle Delay),而将最小飞行时间称为最早开关延时(First Switch Delay)。

 

如下进行详细计算:

CPU范例

 

假设MCU的时钟频率为66MHz,时钟周期为15.15ns,其SDRAM的接口参数见下表:

明:MCU 在读SDRAM数据时,对输入数据的最小保持时间要求为3ns;对输入数据的最小setup时间       Tsetup_MCUin_min=Tclk-Taccess_time_max=15.15ns-10ns=5.15ns。MCU在对SDRAM写数据时,MCU的数据输出的Tsetup_MCUout =3ns,Thold_MCUout =7.5ns

SDRAM(例)

 

 说明:以133MHz为例,在对SDRAM读数据时,SDRAM的数据输出内部延迟时间

Tco_data_SDRAMout= Tacs_SDRAMout= Tclk-Tsetup_SDRAMout,其最大值为6ns(也即SDRAM的数据输出的setup时间最小为15.15-6=9.15ns),其最小值由data-out hold time_min(2ns)决定。在对SDRAM写数据时,SDRAM对输入的数据的最小保持时间Thold_SDRAMin=0.8ns,最小建立时间Tsetup_SDRAMin =1.5ns。

SDRAM的读时序

时序说明

MCU_CLK输出 一 SDRAM_CLK输入 一 经过 Tacs _ sdram之后数据送到SDRAM数据口一 数据传到MCU数据口一 SDRAM的后续时钟源数据保留Toh_sdram一 同时MCU侧进行数据采样。

由于SDRAM在输出数据时,其选取时钟来自于MCU,因此属于变型的共同时钟系统的通讯结构。

时序约束公式

由于MCU内部包含clock buffer,此时可忽略Tflt clka,也暂不考jitter,则时序约束公式简化为:

Tsetup_marin_SDRAM_read = Tcycle- Tflt_clkb- Tflt_data- Tco_data Tsetup

                        = Tclk- Tclk_delay Tdata_delay Tco_data Tsetup

                        = Tsetup_SDRAMout_max - Tclk_delay Tdata_delay Tsetup

Thold_ margin_SDRAM_read = Tco_data + Tdata_delay + Tclk_delay Thold

                         = Thold_SDRAMout_min + Tdata_delay + Tclk_delay Thold

(备注:Tdata_delay 和Tclk_delay均为走线延迟时间,并忽略和Flight的差异)

读时序的约束条件

计算时间裕量:

Tsetup_margin_SDRAM_read = Tsetup_SDRAMout_max - Tclk_delay Tdata_delay Tsetup

                     = 9.15ns - Tclk_delay Tdata_delay-5.15ns

                     = 4ns - Tclk_delay Tdata_delay > 0ns

                     Tdata_delay + Tclk_delay < 4ns

(备注:因为SDRAM输出的setup时间较长,相对于MCU的读要求,有4ns的裕量,因此,数据线和时钟线 的延迟之和,不能超过这个裕量。)

Thold_ margin_SDRAM_read = Thold_SDRAMout_min + Tdata_delay + Tclk_delay Thold_MCUin_min

                     = 2ns + Tdata_delay + Tclk_delay 3ns > 0ns

                     Tdata_delay + Tclk_delay > 1ns

(备注:如果SDRAM输出的hold时间大于MCU的hold要求,则上述约束条件自动满足;但SDRAM器件输出的hold时间趋于缩短,因此,需要通过走线延迟的方式来“缩短”setup时间,从而补偿和加长在MCU接收端的数据hold时间。)

SDRAM的写时序

 

时序说明

    由于MCU在发送数据的同时,也负责发送数据选通时钟,因此属于源同步系统。

时序约束公式

    Tsetup_margin_SDRAM_write= Tclk_delay + Tsetup_MCUout - Tdata_delay – Tsetup_SDRAMin

                                    = Tclk_delay + 3ns- Tdata_delay1.5ns

                                        Tclk_delay - Tdata_delay>-1.5ns

Thold_margin_SDRAM_write = Tdata_delay + Thold_MCUout –Tclk_delay– Thold_SDRAMin

           = Tdata_delay +7.5ns –Tclk_delay0.8ns

                          Tclk_delay - Tdata_delay<6.7ns

约束条件总结

读时序的约束条件

    1ns < Tdata_delay + Tclk_delay < 4ns

    考虑SDRAM各品牌的差异性,进一步加严约束,以提高设计的兼容性:

    即 1.5ns < Tdata_delay + Tclk_delay < 3ns

写时序的约束条件

    -1.5ns <Tclk_delay - Tdata_delay <6.7ns

    实际布线时,时钟线通常比数据线、地址线等线路的长度要长些或等长,因此

    0ns <Tclk_delay - Tdata_delay<6.7ns

综合的约束条件

    0ns <Tclk_delay - Tdata_delay<3ns

    1.5ns < Tdata_delay + Tclk_delay < 3ns (读数据的约束条件,相对较困难实现)

    按表面微带线150ps/in的计算,则数据线(时钟线)的长度不应超过10in 即250mm。

    按内层带状线180ps/in的计算,则数据线(时钟线)的长度不应超过8.3in 即210mm。

 

DDR的时序约束条件

 

 

 

说明(以DDR266为例)

        Tclk=7.5ns,Tch = Tcl=0.45*Tclk=3.38ns

        Tsetup_DDRin_min = 0.5ns

        Thold_DDRin_min = 0.5ns

        Tdv_SDRAMout= Tsetup_DDRout + Thold_DDRout

                            =tQH-tDQSQ=tHP tQHS tDQSQ=0.45*Tch-0.75ns-0.5ns=2.12ns

DDR的写约束条件

上图为某ARM11内核的MCU 的写DDR时序和参数(133MHz)分析,典型的源同步时序系统,在时钟的上下沿读取数据。

时序约束公式

    同SDRAM

Tsetup_margin_DDR_write= Tclk_delay + Tsetup_MCUout - Tdata_delay – Tsetup_SDRAMin

                                           = Tclk_delay + 0.95ns- Tdata_delay0.5ns

                                           Tclk_delay - Tdata_delay>-0.45ns

Thold_margin_DDR_write = Tdata_delay + Thold_MCUout –Tclk_delay– Thold_SDRAMin

                   = Tdata_delay +0.95ns –Tclk_delay0.5ns

                                          Tclk_delay - Tdata_delay<0.45ns

DDR的读约束条件

    上图为某ARM11内核的MCU 的读DDR时序和参数(133MHz)

    由于是在DQS的高(低)电平中间读取数据,因此需要按数据窗口的概念来修改约束条件:

    DDR 的理想数据窗口周期为0.45*Tclk=0.45*7.5ns=3.38ns(按最小值计算)

    DDR输出的实际数据窗口为Tdv_SDRAMout=2.12ns

    DDR输出数据和DQS的SKEW时间为0.5ns

    则Tdata_delay-Tclk_delay<tDQSQ_MCU – tDQSQ_DDR=0.85ns-0.5ns=0.35ns

       及 0.5ns+2.12ns +(Tdata_delay-Tclk_delay) >tQH_MCU=2.3ns

       (Tdata_delay-Tclk_delay)>-0.32ns

-0.32ns<Tdata_delay-Tclk_delay<0.35ns

DDR约束条件总结

读时序约束

-0.32ns<Tdata_delay -Tclk_delay<0.35ns

写时序约束

    -0.45ns<Tdata_delay -Tclk_delay<0.45ns

综合约束条件

    -0.32ns<Tdata_delay-Tclk_delay<0.35ns

即数据线和DQS线的传输延迟SKEW要严格控制在+/-0.3ns以内,此要求比SDRAM严格得多。

按表面微带线150ps/in的计算,则数据线和DQS线的长度偏差不应超过2in 即50mm。

按内层带状线180ps/in的计算,则数据线(时钟线)的长度不应超过1.6in 即40mm。

由于这个时间很短,信号的上升沿(下降沿)时间的影响不能忽略,也即度量延迟SKEW时,需要以信号的飞行时间(Flight)来取代delay时间,因此上述的长度偏差只是做参考,实际走线时要尽可能做到等长。

DDR对数据线的长度未做要求。

这篇关于老SDRAM和DDR SDRAM时序图与信号完整性仿真结合运用(2) -版本博客图片丢失,增加图片后又不能上传,shit.的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/yd4330152763132/article/details/6620872
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/704360

相关文章

在macOS上安装jenv管理JDK版本的详细步骤

《在macOS上安装jenv管理JDK版本的详细步骤》jEnv是一个命令行工具,正如它的官网所宣称的那样,它是来让你忘记怎么配置JAVA_HOME环境变量的神队友,:本文主要介绍在macOS上安装... 目录前言安装 jenv添加 JDK 版本到 jenv切换 JDK 版本总结前言China编程在开发 Java

电脑提示d3dx11_43.dll缺失怎么办? DLL文件丢失的多种修复教程

《电脑提示d3dx11_43.dll缺失怎么办?DLL文件丢失的多种修复教程》在使用电脑玩游戏或运行某些图形处理软件时,有时会遇到系统提示“d3dx11_43.dll缺失”的错误,下面我们就来分享超... 在计算机使用过程中,我们可能会遇到一些错误提示,其中之一就是缺失某个dll文件。其中,d3dx11_4

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统