DRAM Command Unit(DCU)

2023-11-06 08:50
文章标签 dcu dram command unit

本文主要是介绍DRAM Command Unit(DCU),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

4.7.1 DCU功能


DCU模块提供了一种通过配置总线执行DRAM命令的方式。以下是DCU的主要目的:
1. 通过配置端口执行DRAN初始化流程
2. 提供统一的硅片测试与PHY特性测试,且不需要控制器支持
3. 提供软件可执行的DRAM命令
注意:DCU提供有限的功能,且不能替代功能模式。

4.7.2 DCU命令


用户可通过配置端口(APB或JTAG)来实现DRAM的命令,下面列表为可支持的命令

命令操作码命令命令描述
0000NOPPUB无操作
0001LOAD_MODE写模式寄存器
0010SELF_REFRESH使DRAM进入自刷新模式
0011REFRESH向DRAM发出一个自动刷新命令
0100PRECHARGE关闭DRAM中的某一页
0101PRECHARGE_ALL关闭DRAM中的所有页
0110ACTIVATE激活DRAM中的某一页
0111SPECIAL_CMD特殊命令,详见PUB文档第240页
1000WRITE向DRAM发出burst写命令
1001WRITE_PRECHG向DRAM发出burst写命令,并在写完成后关闭该页
1010READ向DRAM发出burst读命令
1011READ_PRECHG向DRAM发出burst读命令,并在写完成后关闭该页
1100ZQCAL_SHORT仅DDR3,向DRAM发出长ZQ校准命令
1101ZQCAL_LONG仅DDR3,向DRAM发出短ZQ校准命令
1110POWER_DOWN进入DRAM低功耗模式
1111SDRAM_NOP向DRAM发出NOP操作

PUB不会对输入到DCU的命令进行自动时序检查,也不会自动生成activate和precharge命令。所以当用户使用配置端口输入命令时,必须确认正确的NOP操作数量以保证命令之间的时序。或者使用DCU时序特性来保证DRAM的时序要求。同时用户需要生成activate与precharge名来来保证正确的页打开与关闭。

4.7.3 DCU Caches


DCU共包含三种Cache,分别是:
1. 命令Cache
2. 读数据Cache
3. 期望数据Cache

命令Cache按照顺序来存储将要执行的DRAM命令。读数据Cache捕获来自DRAM的读数据。期望数据Cache存储用来与读数据进行比较的数据。每个Cache的深度可独立的配置为4、8、16(默认16),且此深度在编译时就确定了。

每个Cache可被写或者读,通过DCUAR(DCU地址寄存器)以及DCRDR(DCU数据寄存器)。Cache中每一行的地址与Cache的整体深度相关,例如若Cache深度为16,每一行的地址为0-15。Cache中每一行被分为32位,0位是最低位。Cache中每一行的位数与PHY中bytelane的个数以及Cache的类型相关。读数据Cache与期望数据Cache仅仅存储数据,而命令Cache除了存储所有命令的编码之外,还额外存储了3位,这三位表示此条命令的重复次数。每个条目的数据部分拥有四个节拍的数据(不是很确定是不是这么翻译的)

下图中展示了Cache字的格式。由于面积的限制,为了减小设计中Cache的尺寸,PUB中可以配置数据为32bit字与4bit掩码。在此配置下,32bit数据将被复制到每个bytelane。
这里写图片描述

在配置DCU命令Cache时,每一个组成部分都是必要的。下面列表中包含了相关信息。需要注意的是,命令Cache的宽度没有必要分割为32bit的部分,此时,在写DCUDR时最高有效低位需要被置为0已凑齐一个完整的32bit。

NameWidth CalculationDescription
DATA32*DWC_NO_OF_BYTES
MASK4*DWC_NO_OF_BYTES
ADDRDWC_ADDR_WIDTH
BANKDWC_BANK_WIDTH
RANKSingle Rank System = 0
CMD4DRAM命令
TAG2
DTP5DRAM时序参数
RPT3重复次数

DTP参数要求是当前命令与下一个命令之间确切的最小的DRAM时序参数,PUB会根据DTP参数自动的在当前命令执行完毕之后添加SDRAM NOP操作。为了简化配置DRAM命令的时序参数配置,DTP域被简化成可选择的DRAM命令时序参数项,这些时序参数项来自于DTPR0-2,PTR1-2以及RDIMMGCR1,还有已经预先计算好的参数。此域配置为0,则表示当前命令执行完毕之后没有任何延时。
下面列表表示了DTP可选择的参数

DTPVALUESOURCE REGISTER
00Fixed
1tRPDPTR0
2tRASDPTR0
3tRRDDPTR0
4tRCDPTR0
5tMRDDPTR1
6tMODDPTR1
7tFAWDPTR1
8tRFCDPTR1
9tWLMRDDPTR1
10tWLODPTR1
11tXSDPTR2
12tXPDPTR2
13tCKEDPTR2
14tDLLKDPTR2
15tDINITRSTPTR4
16tDINITCKELOPTR3
17tDINICKEHIPTR3
18tDINITZQPTR4
19tRPAComputed by PUB
20tPRE2ACTComputed by PUB
21tACT2RWComputed by PUB
22tRD2PREComputed by PUB
23tWR2PREComputed by PUB
24tRD2WRComputed by PUB
25tWR2RDComputed by PUB
26tRDA2ACTComputed by PUB
27tWRA2ACTComputed by PUB
28tDCUT0DCUTR
29tDCUT1DCUTR
30tDCUT2DCUTR
31tDCUT3DCUTR

当对命令Cache进行编程时,每一行含有一个3bit的RPT域。此域的含义为将当前命令执行x+1次。下表表示了RPT域的含义。

RPTValueSource RegisterDescription
00Fixed执行1次
11Fixed执行2次
27Fixed执行8次
3tBLComputed by PUB执行一次完整的DDR Burst
4tDCUT0DCUTR执行tDCUT0+1次
5tDCUT1DCUTR执行tDCUT1+1次
6tDCUT2DCUTR执行tDCUT2+1次
7tDCUT3DCUTR执行tDCUT3+1次

当使用tBL时,PUB将重复执行命令的次数与配置的Burst长度想匹配。尤其是在DDR3中,固定每次都是BL8时,比较有用。比如说,我配置的Burst长度为4,那么我在发送了4拍数据之后会发送NOP命令,来消耗BL8中的后四拍数据。

4.7.4 Writing or Reading DCU Caches

有两种方式可以读取或写入DCU的Cache。第一种为,先写DCUAR确定行地址与片段地址,然后再写入DCUDR。这是一种比较笨的方法,非常的耗时,所以PUB提供了一种自动增加地址的机制。通过配置DCUAR的INCA域,用户仅需要配置起始地址,随后每一次写入DCUDR的32位数据,都会写增加一次片段地址,直到当前行已经写满,然后自动跳入下一行,且片段地址变回0。
下面例子为第一种方式写入Cache,共包含4行,每行4个片段。
这里写图片描述

下面例子为第二种方式,通过自动增加地址的方式写入Cache。
这里写图片描述

4.7.5 Command Execution

一旦命令被载入命令Cache,可以通过配置DCURR里面的DINST域来触发运行Cache中的命令。在执行命令时,会从DCURR中配置的SADDR地址开始,结束于EADDR地址。命令执行可以通过配置DCURR的DINST为STOP来暂停,或者在指针到达命令cache的末端时也会自动暂停命令执行。命令执行还可以通过检查错误数量来停止,首先需要配置DCURR的SONF为1,同时配置NFAIL为你期望的错误数量,那么当你开始执行命令后,在比较读返回数据时,累计错误数量到达NFAIL时,也会自动暂停命令执行。

通过配置DCULR寄存器,可以设定SADDR至EADDR之间的命令循环执行的次数。LSADDR为循环起始地址,此地址必须大于或等于执行命令的起始地址。LEADDR为循环结束地址,次地址必须小于或等于执行命令的结束地址。DCULR寄存器中的LCNT域可配置循环的次数,而LINT可设定循环次数是否是无限次。已执行的循环次数可在DCUSR1寄存器中的LPCNT域进行查看。DCURR寄存器的DINST配置为STOP_LOOP可停止无限循环,此停止可跳出循环并继续向下执行命令,如果还有任何命令没有运行完毕。

DCULR寄存器中的IDA与XLEADDR域是没有必要配置的。IDA控制DRAM地址自动增加,XLEADDR配置期望数据的最后有效地址。

4.7.5.1 Command Cache Instructions for BL8 Reads and Writes

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

需要注意的是,Cache中单独一行读或者写都是不合法的,加入用户仅写入一行写,那么由于DDR3是固定BL8的,那么PUB会将下一行的数据作为后四拍数据发送出去,此时下一行的命令将会丢失。

4.7.6 Read Data Capture and Compare


用户可通过配置DCURR寄存器中的RCEN位来使能DRAM返回的读数据是否进入读数据Cache。需要注意的是,一旦读数据Cache的指针到达了Cache的最后一行,则会直接转向读数据Cache的第一行。可通过配置DCURR寄存器中的SCOF位来防止此问题出现,一旦此位设置为1,那么当指针到达最后一行时,抓取读数据将会停止。无论SCOF为设置与否,当指针到达最末你,DCUSR0的CFULL位都将被置1。

DCUGCR寄存器中的RCSW为可选择PUB开始抓取读数据的序号。例如此位设置为12,那么PUB将会从第13个读数据开始抓取。

DCURR寄存器中的XCEN可配置是否比较期望数据Cache和返回的读数据。首先,用户将期望的数据写入期望数据Cache。如果没有配置XLEADDR,那么期望数据Cache也会循环的将Cache中的数据与读数据进行比较,若配置了XLEADDR,则对比数据从XLEADDR+1位置开始绕回起始位置。若后续程序清零了XCEN,那么期望数据的指针也会随之清零。

4.7.7 DCU Status

一旦执行命令完成或者停止,DCUSR0寄存器的RDONE位会被置为1,这仅仅表示命令的执行已经完成了。用户在读取其他DCU状态寄存器时,首先要确保此位已经变为1。为了避免上一次运行的配置影响下一次,DCURR中的reset可复位一部分状态寄存器。如下图所示。
这里写图片描述

DCU Examples Single Load Command Execution

CADDRRPTDTPTAGCMDRANKBANKADDRMASKDATA
00tACT2RW00ACTIVATE00000
1tBLtWR2RD00WRITE00000xABCD_1234
20tWR2RD00SDRAM_NOP00000
3tBLtRE2PRE00READ00000
40tRP00PRECHARGE00000

注释:
1. DCURR[SADDR]=0=start address
2. DCURR[EADDR]=4=end address
3. DCULR[LEADDR] = 4 = loop end address.
4. DCULR[LINF] = 1 = loop infinite around the write command.
5. DCULR[IDA] = 1 = increment the address for each iteration of the loop.
6. Accessed DRAM location: rank = 0, bank = 0, row = 0, column = 0
更多例子请参考PUB手册

这篇关于DRAM Command Unit(DCU)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/355625

相关文章

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

编译时出现错误 -- clang: error: linker command failed with exit code 1 (use -v to see invocation)

出现这个错误的原因有多种,常见的是因为某些文件的缺失或者是文件的重复导致的。 这类错误查看的关键在于其上一行的文字。 对于文件缺少而导致错误的情况: 例如上图中的示例,其上一行文字为 ld:library not found for -lrxl,可以看出是缺失了某一文件而导致的错误,这行文字中的最后“ -lrxl ”:-l 代表着其前缀是“lib”,连着后面的 rxl,其名称为 libr

ON_COMMAND_RANGE 和 ON_UPDATE_COMMAND_UI_RANGE

 ON_COMMAND_RANGE 和 ON_UPDATE_COMMAND_UI_RANGE 可以影射ID连续的Toolbar/Menu ID。 ON_COMMAND_RANGE影射的消息响应函数需要一个参数UINT表明是哪一个消息, afx_msg void OnZoom(UINT nID); 而ON_UPDATE_COMMAND_UI_RANGE的消息响应函数则无此ID,与ON

on command range

 ON_COMMAND_RANGEON_COMMAND_RANGE( id1, id2, memberFxn )参数: id1一个连续范围的命令ID的起始值。id2一个连续范围的命令ID的结束值。memberFxn该命令被映射到的消息处理函数的名字。 说明:使用这个宏把一个连续范围的命令ID映射到单个命令处理函数。ID的范围从id1开始,到id2结束。用ON_COMMAND_RAN

ON_COMMAND_RANGE的用法

 今天主要介绍一下ON_COMMAND_RANGE的用法 第一次用这个方法还是刚毕业那会,那时写过一个控制程序,界面上有很多电器的控制按钮,这些按钮的响应函数基本一致,只是相应的ID值不一样,要是一一写响应函数那不累死人,于是就东找西找,找到ON_COMMAND_RANGE。 最近一个偶然机会也要用到它,三下五除二,CODE写完了, 1.在要添加的工程上添加函数afx_msg vo

seleniumIDE command 命令类型

command命令 三大类型:(action、Accessor、assertion) 操作 存储 断言 操作类型——Action 浏览器操作 open(https://www.sogou.com/) 打开url。 goBack() 无参数,后退。 refresh() 无参数,刷新。 windowFocus() 无参数,激活选中的浏览器窗口。 windowMaximize() 无参数,使浏览器窗口

【POJ】3164 Command Network 最小树形图——朱刘算法

传送门:【POJ】3164 Command Network 题目大意:平面上n个点,分别编号1~n。有m条有向边(u,v),边权为两点间的笛卡尔距离,表达为(u,v,cost)。现在问你能否选择一些边使得编号为1的点能到达其他所有点并且花费最小。 题目分析:最小树形图入门题。 什么是最小树形图?其实就是有向最小生成树。 那么算法是怎么实现的呢? 首先,我们从根做一次dfs,判

python执行command, 并获取command的执行结果

import subprocess   # 方法1:使用subprocess模块的run函数 def run_cmd_1(command):     """     运行CMD命令并返回输出结果          参数:     command (str): 要执行的CMD命令          返回:     output (str): 命令执行的输出结果     """     try:

Unknown command: “create-react-app“

在创建react项目时出现报错" Unknown command: "create-react-app" " 解决方法: 配置变量,在要创建的目录下打开控制栏,输入下列命令,回车等待结束即可: npx create-react-app 项目名称   可能遇见的错误: 1. npm error network 'proxy' config is set properly.  S

关于GDB运行时No symbol table is loaded. Use the “file“ command.的解决方法

最近有同学问GDB使用的问题,对此做一个整理。 首先,GDB已经报错file找不到了,那可以运行file test检测一下 (gdb) file testReading symbols from test...(no debugging symbols found)...done. 发现找不到可执行文件,所以问题应该在于编译时候没有加上ggdb3,重新编译一下 ty@ubuntu: