用于异构存储器系统的信令
背景技术:1.计算机系统通常将廉价且高密度的动态随机存取存储器(dram)芯片用于主存储器。现今销售的大部分dram芯片与由电子装置工程联合委员会(jedec)颁布的各种双倍数据速率(ddr)dram标准兼容。ddr存储器控制器用于根据已发布的ddr标准管理各种存储器访问代理与ddr dram之间的接口。
2.具有持久性存储装置的非易失性双列直插式存储器模块(“nvdimm-p”)是可以用于代替标准ddr dimm但是包括持久性存储器的一种存储类存储器。然而,这些存储器具有非确定性访问延时,并且可能具有可能会暂时延迟对非易失性存储器的访问的板载介质管理活动,因此这些存储器需要握手协议来就来自nvdimm-p的数据的可用性通知主机控制器。jedec正在开发一种事务协议以减轻这种非确定性对性能的影响,以提供启用乱序事务和堆栈命令的能力。
附图说明
3.图1以框图形式示出了现有技术中已知的加速处理单元(apu)和存储器系统;
4.图2以框图形式示出了根据一些实施方案的适用于在类似于图1的apu中使用的存储器控制器;
5.图3以框图形式示出了根据一些实施方案的一对存储器通道和一个apu;
6.图4以图形形式示出了根据一些实施方案的处置存储器访问命令的过程;
7.图5以图形形式示出了图4的过程的其他部分;
8.图6以图形形式示出了图4和图5的过程的又其他部分;
9.图7是根据一些实施方案的用于处置存储器访问请求的过程的流程图。
10.在以下描述中,不同附图中使用的相同的附图标记来指示类似或相同的项目。除非另外指出,否则词语“耦合”及其相关动词形式包括直接连接和通过本领域中已知的装置进行的间接电气连接这两者,并且除非另外指出,否则对直接连接的任何描述也意味着使用适当形式的间接电气连接的替代实施方案。
具体实施方式
11.存储器控制器与至少一个非易失性存储类存储器(scm)模块对接。存储器控制器包括命令队列、存储器接口队列、非易失性命令队列(nv队列)、仲裁器和控制电路。命令队列具有用于接收包括易失性存储器读取、易失性存储器写入、非易失性存储器读取和非易失性存储器写入的存储器访问命令的第一输入以及输出,并且具有多个条目。存储器接口队列具有耦合到命令队列的输出的输入,以及用于耦合到异构存储器通道的输出,所述异构存储器通道耦合到至少一个非易失性scm模块。nv队列耦合到命令队列的输出以用于存储置于存储器接口队列中的非易失性读取命令。仲裁器耦合到命令队列以用于从命令队列中选择条目,并将它们置于存储器接口队列中从而使它们在异构存储器通道上传输。控制电路适于耦合到异构存储器通道以用于从非易失性scm模块接收就绪响应,所述就绪响应
指示响应数据可用于非易失性读取命令中的相关联非易失性读取命令,并且作为响应,导致发送命令被置于存储器接口队列中以用于命令非易失性scm模块发送响应数据。
12.一种方法包括接收多个存储器访问请求,所述多个存储器访问请求包括易失性存储器读取、易失性存储器写入、非易失性存储器读取和非易失性存储器写入。将用于执行存储器访问请求的存储器访问命令置于存储器接口队列中,并将存储器访问命令从存储器接口队列传输到连接到非易失性存储类存储器(scm)模块的异构存储器通道。所述方法包括将置于存储器接口队列中的非易失性读取命令存储在nv队列中。从非易失性scm模块接收到就绪响应,所述就绪响应指示响应数据可用于非易失性读取命令中的相关联非易失性读取命令。作为响应,所述方法包括将用于命令非易失性scm模块发送响应数据的发送命令置于存储器接口队列中。
13.一种数据处理系统包括:中央处理单元;数据结构,所述数据结构耦合到中央处理单元;以及存储器控制器,所述存储器控制器耦合到数据结构以用于执行来自中央处理单元的存储器请求。存储器控制器包括命令队列、存储器接口队列、nv队列、仲裁器和控制电路。命令队列具有用于接收包括易失性存储器读取、易失性存储器写入、非易失性存储器读取和非易失性存储器写入的存储器访问命令的第一输入以及输出,并且具有多个条目。存储器接口队列具有耦合到命令队列的输出的输入,以及用于耦合到异构存储器通道的输出,所述异构存储器通道耦合到至少一个非易失性scm模块。nv队列耦合到命令队列的输出以用于存储置于存储器接口队列中的非易失性读取命令。仲裁器耦合到命令队列以用于从命令队列中选择条目,并将它们置于存储器接口队列中从而使它们在异构存储器通道上传输。控制逻辑耦合到所述异构存储器通道以用于从非易失性scm模块接收就绪响应,所述就绪响应指示响应数据可用于非易失性读取命令中的相关联非易失性读取命令,并且响应于接收到就绪响应,导致发送命令被置于存储器接口队列中以用于命令非易失性scm模块发送响应数据。
14.图1以框图形式示出了现有技术中已知的加速处理单元(apu)100和存储器系统130。apu 100是适合于用作主机数据处理系统中的处理器的集成电路,并且大致上包括中央处理单元(cpu)核心联合体110、图形核心120、一组显示引擎122、存储器管理集线器140、数据结构125、一组外围控制器160、一组外围总线控制器170以及系统管理单元(smu)180。
15.cpu核心联合体110包括cpu核心112和cpu核心114。在该示例中,cpu核心联合体110包括两个cpu核心,但是在其他实施方案中,cpu核心联合体110可以包括任意数量的cpu核心。cpu核心112和114中的每一者双向地连接到系统管理网络(smn),这形成了控制结构;并连接到数据结构125,并且能够向数据结构125提供存储器访问请求。cpu核心112和114中的每一者可以为单一核心,或者还可以是带共享诸如缓存等某些资源的两个或更多个单一核心的核心联合体。
16.图形核心120是高性能图形处理单元(gpu),其能够以高度集成且并行的方式执行图形操作,诸如顶点处理、片段处理、明暗处理、纹理混合等。图形核心120双向地连接到smn和数据结构125,并且能够向数据结构125提供存储器访问请求。就此而言,apu 100可以支持其中cpu核心联合体110和图形核心120共享同一存储器空间的统一存储器架构,或其中cpu核心联合体110和图形核心120共享存储器空间的一部分同时图形核心120还使用cpu核心联合体110不可访问的专用图形存储器的存储器架构。
17.显示引擎122渲染并光栅化通过图形核心120生成的对象以便显示在监视器上。图形核心120和显示引擎122双向地连接到公共的存储器管理集线器140以便统一转变成存储器系统130中的适当地址,而存储器管理集线器140双向地连接到数据结构125以用于生成此类存储器访问并接收从存储器系统返回的读取数据。
18.数据结构125包括交叉交换机以用于在任何存储器访问代理与存储器管理集线器140之间路由存储器访问请求和存储器响应。该数据结构还包括通过基本输入/输出系统(bios)定义的系统存储器映射以用于基于系统配置来确定存储器访问的目的地,以及用于每一虚拟连接的缓冲器。
19.外围控制器160包括通用串行总线(usb)控制器162和串行高级技术附件(sata)接口控制器164,它们中的每一者双向连接到系统集线器166和smn总线。这两个控制器仅举例示出可以在apu 100中使用的外围控制器。
20.外围总线控制器170包括系统控制器或“南桥”(sb)172和外围组件互连高速(pcie)控制器174,这些控制器中的每一者双向地连接到输入/输出(i/o)集线器176和smn总线。i/o集线器176还双向地连接到系统集线器166并连接到数据结构125。因此,例如cpu核心可以通过访问对usb控制器162、sata接口控制器164、sb 172或pcie控制器174中的寄存器进行编程,所述数据结构125通过i/o集线器176来路由这些访问。用于apu 100的软件和固件存储在系统数据驱动器或系统bios存储器(未示出)中,所述系统数据驱动器或系统bios存储器可以是各种非易失性存储器类型中的任何一种,诸如只读存储器(rom)、闪存电可擦除可编程rom(eeprom)等。通常情况下,bios存储器通过pcie总线访问,并且系统数据驱动器通过sata接口访问。
21.smu 180是本地控制器,其控制在apu 100上的资源的操作并同步这些资源之间的通信。smu 180管理apu 100上的各种处理器的加电定序,并经由重置、启用和其他信号来控制多个芯片外装置。smu 180包括一个或多个时钟源(未示出)(诸如锁相环(pll))以对apu 100的组件中的每一者提供时钟信号。smu 180还管理各种处理器和其他功能块的电源,并且可以从cpu核心112和114以及图形核心120接收所测量的功耗值以确定适当的电源状态。
22.在该实施方案中,存储器管理集线器140及其相关联的物理接口(phy)151和152与apu 100集成。存储器管理集线器140包括存储器通道141和142以及电源引擎149。存储器通道141包括主机接口145、存储器通道控制器143和物理接口147。主机接口145通过串行存在检测链路(sdp)将存储器通道控制器143双向地连接到数据结构125。物理接口147将存储器通道控制器143双向地连接到phy 151并遵守ddr phy接口(dfi)规范。存储器通道142包括主机接口146、存储器通道控制器144和物理接口148。主机接口146通过另一sdp将存储器通道控制器144双向地连接到数据结构125。物理接口148将存储器通道控制器144双向地连接到phy 152并遵守dfi规范。电源引擎149通过smn总线双向地连接到smu 180,通过apb双向地连接到phy 151和152,并且还双向地连接到存储器通道控制器143和144。phy 151与存储器通道131进行双向连接。phy 152与存储器通道133进行双向连接。
23.存储器管理集线器140是具有两个存储器通道控制器的存储器控制器的实例化,并使用共享的电源引擎149来以下文将进一步描述的方式控制存储器通道控制器143和存储器通道控制器144这两者的操作。存储器通道141和142中的每一者可以连接到现有技术ddr存储器,诸如ddr第四版(ddr4)、低功率ddr4(lpddr4)、图形ddr第五版(gddr5)以及高带
宽存储器(hbm),并可以适于未来的存储器技术。这些存储器提供高总线带宽和高速操作。同时,这些存储器还提供低功率模式以节省诸如膝上型计算机等电池供电应用的功率,并且还提供内置热监视。
24.存储器系统130包括存储器通道131和存储器通道133。存储器通道131包括连接到ddrx总线132的一组双列直插式存储器模块(dimm),其包括在该示例中对应于单独的存储排的代表性dimm 134、136和138。同样地,存储器通道133包括连接到ddrx总线129的一组dimm,其包括代表性dimm 135、137和139。
25.apu 100用作主机数据处理系统的中央处理单元(cpu),并提供在现代计算机系统中有用的各种总线和接口。这些接口包括两个双倍数据速率(ddrx)存储器通道、用于连接到pcie链路的pcie根联合体、用于连接到usb网络的usb控制器以及与sata大容量存储装置的接口。
26.apu 100还实施各种系统监视和节电功能。具体地,一个系统监视功能是热监视。例如,如果apu 100变热,则smu 180可以减小cpu核心112和114和/或图形核心120的频率和电压。如果apu 100变得过热,则可以完全关闭该apu。热事件还可以通过smu 180经由smn总线从外部传感器接收,并且作为响应,smu 180可以减小时钟频率和/或电源电压。
27.图2以框图形式示出了适合于在与图1类似的apu中使用的存储器控制器200。存储器控制器200包括存储器通道控制器210和电源控制器250。存储器通道控制器210通常包括接口212、存储器接口队列214、命令队列220、地址生成器222、内容可寻址存储器(cam)224、包括重放队列230的重放控制逻辑231、刷新逻辑块232、定时块234、页表236、仲裁器238、纠错码(ecc)校验电路242、ecc生成块244、数据缓冲器246、非易失性(nv)缓冲器247和nv队列248。
28.接口212具有通过外部总线到数据结构125的第一双向连接,并具有输出。在存储器控制器200中,该外部总线与由英国剑桥的armholdings,plc指定的高级可扩展接口第四版(被称为“axi4”)兼容,但在其他实施方案中可以为其他类型的接口。接口212将存储器访问请求从被称为fclk(或memclk)域的第一时钟域转变到被称为uclk域的在存储器控制器200内部的第二时钟域。类似地,存储器接口队列214将存储器访问从uclk域提供到与dfi接口相关联的dficlk域。
29.地址生成器222对通过axi4总线从数据结构125接收到的存储器访问请求的地址进行解码。存储器访问请求包括以规范化格式表示的物理地址空间中的访问地址。地址生成器222将规范化地址转换成可以用于对存储器系统130中的实际存储器装置进行寻址以及用于高效地调度相关访问的格式。该格式包括区域标识符,其使存储器访问请求与特定存储排、行地址、列地址、存储体地址以及存储体群组相关联。在启动时,系统bios查询存储器系统130中的存储器装置以确定所述存储器装置的地址长度和配置,并对与地址生成器222相关联的一组配置寄存器进行编程。地址生成器222使用存储在配置寄存器中的配置来将规范化地址转变成适当格式。地址生成器222对存储器(包括nvdimm-p存储器)的地址范围进行解码,并将指示存储器访问请求是否是对nvdimm-p的请求的解码信号存储在命令队列220中。然后,仲裁器238可以相对于其他请求以适当的优先级对nvdimm-p请求进行优先级排序。命令队列220是从apu 100中的存储器访问代理(诸如cpu核心112和114以及图形核心120)接收到的存储器访问请求的队列。命令队列220存储通过地址生成器222解码的地址
字段,以及允许仲裁器238高效地选择存储器访问的其他地址信息,其包括访问类型和服务质量(qos)标识符。cam 224包括用于执行排序规则的信息,诸如写后写(waw)和写后读(raw)排序规则。
30.纠错码(ecc)生成块244确定要发送到nvdimm-p的写入数据的ecc。ecc检查电路242对照导入ecc检查接收的ecc。
31.重放队列230是用于存储由仲裁器238挑选的等待响应(诸如地址和命令奇偶校验响应)的选定存储器访问的临时队列。重放控制逻辑231访问ecc校验电路242以确定返回的ecc是正确的还是指示错误。重放控制逻辑231发起并控制重放序列,其中在这些周期中的一者的奇偶校验或ecc错误的情况下重放访问。重放的命令被置于存储器接口队列214中。
32.刷新逻辑232包括用于各种掉电、刷新和终结电阻(zq)校准周期的状态机,这些周期与从存储器访问代理接收到的正常的读和写存储器访问请求分开生成。例如,如果存储排处于预充电掉电,则它必须定期被唤醒以运行刷新周期。刷新逻辑232定期地生成刷新命令以防止通过dram芯片中的存储器单元的存储电容器的电荷的泄漏造成的数据错误。另外,刷新逻辑232定期地校准zq以防止由于系统中的热变化导致的片内终结电阻(on-die termination resistance)中的失配。
33.仲裁器238双向地连接到命令队列220,并且是存储器通道控制器210的心脏。所述仲裁器通过智能地调度访问以提高存储器总线的使用率来提高效率。仲裁器238使用定时块234以通过基于dram定时参数来确定命令队列220中的某些访问是否有资格发出而执行正确的定时关系。例如,每个dram在激活命令之间都有最小指定时间,称为“t
rc”。定时块234维护一组计数器,该组计数器基于此和在jedec规范中规定的其他定时参数来确定资格,并且所述定时块双向连接到重放队列230。页表236维持关于仲裁器238的存储器通道的每一存储体和存储排中的活动页的状态信息,并且双向地连接到重放队列230。
34.nv缓冲器247将用于重放序列并且用于管理nv读取响应的nv读取命令存储在nv队列248中。nv缓冲器247双向连接到存储器接口队列214以用于处置rd_rdy和send命令,如下文进一步描述。
35.响应于从接口212接收到的写存储器访问请求,ecc生成块244根据写数据来计算ecc。数据缓冲器246针对接收到的存储器访问请求存储写数据和ecc。当仲裁器238选取对应的写入访问以供调度到存储器通道时,所述数据缓冲器将组合的写入数据/ecc输出到存储器接口队列214。
36.电源控制器250大体上包括与高级可扩展接口第一版一(axi)的接口252、高级外围总线(apb)接口254以及电源引擎260。接口252具有到smn的第一双向连接,其包括用于接收在图2中单独地示出的标记为“event_n”的事件信号的输入,以及输出。apb接口254具有连接到接口252的输出的输入,和用于通过apb连接到phy的输出。电源引擎260具有连接到接口252的输出的输入,和连接到存储器接口队列214的输入的输出。电源引擎260包括一组配置寄存器262、微控制器(μc)264、自刷新控制器(slfref/pe)266以及可靠的读/写定时引擎(rrw/te)268。配置寄存器262通过axi总线来编程,并存储配置信息以控制存储器控制器200中的各种块的操作。因此,配置寄存器262具有连接到图2中未详细示出的这些块的输出。自刷新控制器266是除通过刷新逻辑232自动地生成刷新外还允许手动地生成刷新的引擎。可靠的读/写定时引擎268向存储器或i/o装置提供连续的存储器访问流以用于诸如ddr
接口最大读取延时(mrl)训练和回送测试(loopback testing)等目的。
37.存储器通道控制器210包括允许它选取存储器访问以调度到相关存储器通道的电路。为了做出期望的仲裁决定,地址生成器222将地址信息解码成预解码信息,其包括存储器系统中的存储排、行地址、列地址、存储体地址以及存储体群组,而命令队列220存储预解码信息。配置寄存器262存储配置信息以确定地址生成器222如何对接收到的地址信息进行解码。仲裁器238使用解码的地址信息、由定时块234指示的定时合格性信息以及由页表236指示的活动页信息来高效地调度存储器访问,同时观察其他标准,诸如服务质量(qos)要求。例如,仲裁器238实施对打开页进行访问的偏好以避免改变存储器页所需的预充电和激活命令的开销,并通过将对一个存储体的开销访问与对另一个存储体的读取和写入访问进行交错来隐藏开销访问。具体地,在正常操作期间,仲裁器238通常在选择不同的页之前在不同存储体中保持页打开,直到需要对这些页进行预充电。
38.图3以框图形式示出了根据一些实施方案的数据处理系统300。数据处理系统300包括存储器系统330和apu 310。apu 310包括存储器控制器,如存储器控制器200(图2),其支持异构存储器通道与存储器系统330对接。除了正常的ddrx存储器通道之外,apu 310还在具有正常注册的dimm或rdimm 334和336以及nvdimm-p338两者的异构存储器通道330上支持nvdimm-p 338,所述异构存储器通道作为仅具有通过总线342连接的rdimm 344、346和348的同构存储器通道340的补充。尽管在该实施方案中异构存储器通道330连接到nvdimm-p和rdimm两者,但是在一些实施方案中,异构存储器通道具有与所有nvdimm-p类型dimm对接的能力。
39.根据nvdimm-p标准草案,apu 310和nvdimm-p 338上的存储器控制器之间的事务受“链接”ecc保护。链路ecc确保存储器控制器与nvdimm之间通过总线332的数据传递的数据完整性。根据已知的ecc机制,它可以防止链路上由随机或瞬时错误引起的数据损坏。所述保护因使用的ecc代码而异。ecc可以允许例如具有多位错误检测的单位校正。响应于检测到不可纠正的错误,存储器控制器可以重放事务,使得暂时或随机错误不会持续存在,并且还可以向操作系统报告可纠正和不可纠正的错误。
40.尽管在该实施方案中描述了nvdimm-p类型的dimm,但是其他实施方案采用本文的技术以通过异构存储器通道与其他类型的存储类存储器(scm)模块对接。如本文所使用,scm指示具有可在系统存储器空间中寻址的非易失性存储器的存储器模块。scm模块中的非易失性存储器可以通过ram缓冲和/或与scm模块上的ram配对。从操作系统(os)的角度来看,scm存储器地址映射与常规的dram填充一起出现。操作系统通常知道scm定义的地址范围是与常规存储器“不同”的存储器类型。这种区别是为了通知os:该存储器可能更隐蔽并且具有持久的质量。os可以将scm存储器映射为直接访问存储器或文件系统访问存储器。直接访问意味着os将scm地址范围作为物理可寻址存储器进行访问。文件系统访问意味着os将持久存储器作为文件系统的一部分进行管理,并经由基于文件的api管理对scm的访问。最终,请求到达scm地址范围内的存储器控制器,这与更高级别的os如何管理访问无关。
41.图4至图6是示出根据一些实施方案的处置非易失性读取命令的过程700(图7)的一系列图。所描绘的过程包括使用nv队列248来保存nv读取命令,诸如xread命令,完成对命令的执行,并在发生需要重放命令的错误时使命令可供重放过程使用。将参考图7描述图4至图6。
42.图7是根据一些实施方案的用于处置存储器访问命令的过程700的流程图。过程700适合于用图2的存储器控制器200或其他存储器控制器布置来实施。过程700开始于框702,其中所述过程接收多个存储器访问请求,所述多个存储器访问请求包括易失性存储器读取、易失性存储器写入、非易失性存储器读取和非易失性存储器写入。在框704处对用于执行请求的存储器访问命令进行解码并将其置于诸如命令队列220(图2)等命令队列中。
43.在框706处,选择来自命令队列的存储器访问命令用于通过异构存储器通道传输。所述选择通常由诸如仲裁器238(图2)等仲裁器来执行。选定的存储器访问命令被置于要传输的存储器接口队列中。图4的图中示出了这种情况的示例,其中箭头401描绘了被置于存储器接口队列中的命令。在框708处,过程700将置于存储器接口队列中的非易失性读取命令存储在非易失性命令队列(nv队列)(诸如nv队列248(图2))中。这种情况的示例在箭头402处示出,其中被发送到存储器接口队列的xread命令存储在nv队列中。来自存储器接口队列的存储器访问命令被传输到耦合到易失性双列直插式存储器模块(dimm)和非易失性dimm的异构存储器通道。来自存储器接口队列的存储器访问命令的传输由箭头403描绘,所述箭头示出了通过异构存储器通道传递到非易失性dimm的xread命令,在这种情况下,nvdimm-p包括介质控制器、非易失性介质和dram。
44.对于通过异构存储器通道传输的非易失性读取命令,由于读取请求数据的过程不可预测,非易失性dimm通常在非确定性时间段后做出响应,所述请求数据可以在非易失性dimm处的非易失性存储器中、在非易失性dimm的dram中或在介质控制器处的缓存中。在非确定性时间段期间,通常执行其他存储器访问命令并将其从存储器接口队列中移除。当非易失性dimm处的介质控制器完成读取请求数据的过程时,它向存储器控制器发送就绪响应信号“rd_rdy”。通常,在异构存储器通道的子通道上而非在存储器接口队列在其上接收对存储器访问命令的响应的子通道上发送和接收rd_rdy信号。例如,对于nvdimm-p存储器通道,rd_rdy信号通常在存储器通道的与在其上传输命令和数据的“cmd”和“dq”线分开的“rsp_r”线上发送。
45.在框712处,从非易失性dimm接收rd_rdy,所述rd_rdy指示响应数据可用于非易失性读取命令中的相关联非易失性读取命令。控制电路(在该示例中为nv缓冲器控制电路)接收rd_rdy信号。图5中的箭头404描绘了从非易失性dimm传递到nv缓冲器控制电路的rd_rdy信号。作为响应,在框714处,控制电路将send命令置于存储器接口队列中,如箭头405所描绘。send命令由此被调度或排队以传输到非易失性dimm,如图6中的箭头406所描绘。send命令具有确定性响应时间,因为响应数据在send命令到达时已准备好从非易失性dimm发送,因此send命令不会给存储器接口队列操作增加非确定性延迟。如果非易失性读取命令被保存在存储器接口队列而非nv队列中,直到命令被执行,则它会“阻塞”存储器接口队列,延迟对其他命令的处理并增加整体命令处理的延迟。
46.在接收到send命令时,非易失性dimm介质控制器将针对非易失性读取命令读取的响应数据(包括所述命令的相关联标识符)传输回存储器控制器。该实施方案中的相关联标识符是用于读取命令的读取标识符“rid”,如图6中的箭头407所描绘,示出了传输到存储器控制器的数据和rid。
47.在框716处,存储器控制器从非易失性dimm接收响应数据和相关联标识符。作为响应,存储器控制器的nv缓冲器使用相关联标识符来标识nv队列中具有同一相关联标识符的
非易失性读取命令。在框718处,提供响应数据以执行为其产生非易失性就绪命令的相关联的非易失性读取请求。这执行所述请求,并且如箭头408所描绘将相关联的非易失性读取命令从nv队列中移除,然后在nv队列中划掉xread命令。
48.在一些实施方案中,过程700包括利用诸如仲裁器238(图2)等仲裁器来调度存储器访问命令。在一个示例中,在将存储器访问命令置于存储器接口队列中之前,所述过程将非易失性读取命令与其他非易失性读取命令或易失性读取命令分组。这种分组在图4中进行描绘,其中箭头401示出以新顺序置于存储器接口队列中的存储器访问命令,其中read(易失性读取命令)和xread(一种非易失性读取命令)命令被分组在一起,并且write(易失性写入命令)和xwrite(一种非易失性写入命令)命令被分组在一起。
49.在一些实施方案中,过程700在框714处还包括在将send命令置于存储器接口队列之前,在将发送命令置于存储器接口队列之前,将send命令与一组非易失性或易失性读取命令分组。这在图5的箭头405处进行描绘,其中send命令被置于一组read命令中。
50.因此,如本文所述的存储器控制器和数据处理系统提高了存储器控制器与异构存储器通道上的非易失性dimm对接的能力。此外,本文的存储器控制器通过消除存储器接口队列长时间保持非易失性读取命令直到它们被执行的需要来减少存储器接口队列所需的长度。
51.图2的存储器控制器200或其任何部分(诸如仲裁器238)可以由数据库或其他数据结构形式的计算机可访问数据结构来描述或表示,所述数据库或其他数据结构可以由程序读取并直接或间接用于制造集成电路。例如,该数据结构可以是用诸如verilog或vhdl等高级设计语言(hdl)对硬件功能性的行为级描述或寄存器传输级(rtl)描述。所述描述可以通过合成工具来读取,所述合成工具可以对描述进行合成以从合成库中产生包括一系列门的网表。所述网表包括门的集合,这些门还表示包括集成电路的硬件的功能性。所述网表然后可以被放置和路由以产生描述要应用于掩模的几何形状的数据集。然后可以在各种半导体制造步骤中使用掩模来产生集成电路。替代地,计算机可访问存储介质上的数据库根据需要可以为网表(具有或不具有合成库)或数据集或者图形数据系统(gds)ii数据。
52.尽管已经描述了特定实施方案,但是对这些实施方案的各种修改对于本领域技术人员来说将是显而易见的。例如,存储器通道控制器210和/或功率引擎250的内部架构可以在不同实施方案中变化。存储器控制器200可以对接到除了nvdimm-p和ddrx之外的其他类型的存储器,诸如高带宽存储器(hbm)、rambus dram(rdram)等。尽管所示实施方案示出了与单独dimm相对应的每个存储排,但是在其他实施方案中,每个dimm可以支持多个存储排。此外,尽管通常支持异构存储器通道,但是异构通道可以被完全填充有非易失性dimm。此外,尽管本文讨论的非易失性读取命令的示例类型是xread命令,但是也支持其他类型的非易失性读取命令。例如,nvdimm-p规范提供了推测性读取(sread)命令,如果在非易失性dimm上的dram中找到请求的存储器,则所述sread命令具有确定性响应时间,但是如果非易失性dimm确定所请求的数据在dram中不可用,而是必须从非易失性存储器介质中读取,则所述sread命令被解释为具有非确定性响应时间的非易失性读取。在一些实施方案中,如果发生这种“未命中”,则sread命令也被添加到nv队列中,然后类似于xread进行处理。
53.因此,所附权利要求意图涵盖落入所公开实施方案的范围内的对所公开实施方案的所有修改。