一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

IODSSD的独立集数据通道的制作方法

2022-05-08 10:09:41 来源:中国专利 TAG:

iod ssd的独立集数据通道
1.相关申请案的交叉参考
2.本技术案主张2019年7月26日提出申请的美国申请案第16/523,925号的优先权,所述美国申请案的内容以全文引用的方式并入本文中。
技术领域
3.本公开一般来说一般来说涉及用于提供输入/输出(i/o)确定性(iod)固态驱动器(ssd)的系统及方法。


背景技术:

4.ssd包含若干个非易失性存储器装置,例如但不限于,nand快闪存储器装置,nand快闪存储器装置由控制器控制使得nand快闪存储器装置行为上像单个驱动器。nand快闪存储器装置经受起源于主机的i/o操作,例如读取及写入存储于nand快闪存储器装置中的数据,所述i/o操作可起源于在一或多个主机上运行的多个相异应用程序。nand快闪存储器装置可仅在任一时间处理单个i/o操作,且将多个nand快闪装置连接到存储器控制器的存储器总线/信道可仅在任一时间传送针对单个存储器装置的数据。传统上,尝试从ssd读取数据或向ssd写入数据的主机应用程序因此通常由于必须与其它应用程序共享对存储器装置的存取而经历不同等级的等待时间。此外,由于不同应用程序的i/o活动通常不同步或相关,因此单个应用程序所经历的等待时间是不可预测的。在其中一主机驻存于具有大量ssd及运行多个相异应用程序来存储及检索数据的主机的数据中心内的实例中,所述主机在请求ssd针对一应用程序执行i/o操作时由于其它主机及应用程序的同时且无关联的活动而无法控制ssd的不可预测的等待时间。在其中主机对ssd运行时间敏感应用程序(例如,实时数据收集、实时数据分配等)的情境中,主机体验可进一步恶化。
5.在尝试限制对另一应用程序所经历的i/o等待时间具有有害效应的一个应用程序的效应的过程中,非易失性存储器存储装置的nvm express
tm v1.4基本协议规范引入了“非易失性存储器(nvm)集”的概念,其中将非易失性存储装置划分成若干可单独寻址的区域。这些区域是存储器的逻辑上及/或物理上单独的区,这使得单独主机应用程序能够排他地存取存储器的单独区而不必彼此共享存储器资源。然而,仍需要使ssd中的nand快闪存储器控制器具有针对主机应用程序以确定且可预测的i/o等待时间(也称为i/o确定性,iod)处置多个相异主机应用程序对多个nvm集的i/o的能力及关于对ssd的i/o操作改进主机应用程序的体验。


技术实现要素:

6.在某些方面中,ssd装置的本发明实施方案针对于用于提供独立数据通道来支持ssd装置的iod特征的系统及方法。
附图说明
7.图1a展示根据一些实施方案的实例ssd的框图;
8.图1b是根据一些实施方案支持低等待时间操作的ssd架构的框图;
9.图2是根据一些实施方案包含多个独立数据通道的ssd架构的框图;
10.图3是图解说明根据一些实施方案的过程间流程的框图;
11.图4是图解说明根据一些实施方案用于启用一或多个数据通道的实例过程的流程图;及
12.图5是图解说明根据一些实施方案操作地耦合到两个处理器的ipc的长度的框图。
具体实施方式
13.在其它方面当中,iod驱动器是指实施本文中所描述的iod特征的ssd。iod驱动器的物理空间物理上分割成各种区域或存储空间的隔离区域(“岛”),称为nvm集。物理分割可由iod驱动器的nand快闪存储器装置的物理块及/或裸片执行。每一nvm集是逻辑上独立于iod驱动器的其它nvm集的逻辑来管理。即,iod驱动器的每一物理请求均映射到iod驱动器的逻辑请求。iod驱动器可独立地管理对每一nvm集执行的逻辑且为每一nvm集分配适当存储空间及带宽。相对于nvm集的i/o操作被保障以来自所述nvm集的独立于其它nvm集的特定带宽水平,因此允许主机可预测等待时间,因为主机知晓受保障带宽。主机可因此在预期受保障带宽的情况下使用iod驱动器执行存储及计算功能,所述预期可总是由于iod驱动器的特性而得以满足。可在2017年11月1日提出申请的标题为“支持低等待时间操作的ssd架构(ssd architecture supporting low latency operation)”的美国专利公开案第us 2019/0042150号中找到iod驱动器的实例架构,所述美国专利公开案特此以全文引用的方式并入。
14.在常规的非iod ssd的所谓的“嘈杂邻居”情境中,第一应用程序的i/o操作可影响第二应用程序所经历的操作及等待时间。利用iod驱动器,即使由主机执行的第一应用程序与对第一nvm集而非第二nvm集的i/o操作有关,仍可因iod驱动器的物理上不恰当的请求而导致“嘈杂邻居”现象。另外,尽管iod驱动器是物理上及逻辑上分成多个nvm集来请求,但由于执行且控制逻辑功能的控制器在nvm集之间对计算及/或硬件资源的共享,所述控制器可由于iod驱动器的一个nvm集的i/o操作而导致iod驱动器的另一nvm集的i/o操作的延迟。如此,逻辑上管理iod驱动器的多个nvm集的控制器可变成所述多个nvm集的i/o操作的瓶颈,因此尽管有分配给iod驱动器中的nvm集的非易失性存储装置的物理分割仍导致“嘈杂邻居”现象。
15.用于执行iod驱动器的i/o操作的控制器内的过程流称为i/o路径。在一些情形中,i/o路径包含多个控制流且通常在多个处理器及/或控制器上在多个过程之间通信。i/o路径包含i/o路径的一端上的主机、i/o路径的另一端上的nand快闪存储器装置,及主机与nand快闪存储器装置之间的多个过程及/或处理器。过程间通信(ipc)可帮助过程及/或处理器之间的通信,所述ipc中的每一者对应于彼此通信的两个过程/处理器之间的通信链路。可在过程之间在ipc上传送多个消息类型。针对iod驱动器,在将数据写入到iod驱动器的nand快闪存储器装置或从所述nand快闪存储器装置读取数据之前,ipc在i/o路径中载运每一nvm集的消息。虽然处理器及过程的数目可在控制器上保持不变,但ipc基础设施及传
统固件的调度会导致在iod驱动器的多个nvm集之间发生冲突及资源瓶颈。
16.在非iod驱动器中使用的传统ipc方案不适合对iod驱动器的实施方案,因为那些ipc方案缺乏避免在同一类型的ipc消息之间发生资源竞争及颠倒的优先级的能力,其中所述ipc消息属于多个nvm集。在其中处理器当前正处置集0的ipc s0-a且所述处理器在所述处理器正处置ipc s0-a时接收到来自集1的ipc s1-a并在接收到s1-a之后接收到来自集2的ipc s2-a的实例中,根据传统ipc方案,s0-a、s1-a及s2-a将在所述处理器上以所述次序被处置。s0-a、s1-a及s2-a属于同一消息类型且由同一处理器处置。如果nand快闪存储器装置正忙于集0或集0的控制器资源不可用,那么处理s0-a将花费更长时间。s0-a的长处理时间可使s1-a及s2-a的处理进一步延迟,这是因为s0-a、s1-a及s2-a是以所述次序顺序地处理。因此,传统ipc方案由于集0上的业务状况而增加集1及集2的ipc消息上的等待时间,因此导致“嘈杂邻居”现象。此问题因控制器内用于i/o操作的大量过程及控制路径而加剧。
17.本文中所公开的实施例涉及用于提供在具有iod特征的驱动器的控制器上实施的低等待时间ipc方案的系统、设备、方法及非暂时性计算机可读媒体。所述ipc方案经实施以连接过程、处理器、硬件、控制器、主机及所述驱动器的nand快闪存储器装置。固件经配置以建立且管理iod驱动器的每一nvm集的独立数据通道。每一独立数据通道包含一或多个ipc及相关联处理程序。
18.在一些实施方案中,iod驱动器可例如通过避免在iod驱动器的不同nvm集当中发生i/o冲突及开销而为ssd提供可预测的等待时间。在一些实施例中,iod驱动器可确保一个nvm集上的业务分布及负载不影响同一驱动器(例如,同一ssd)内的其它nvm集上的等待时间。即,iod驱动器经配置以通过在控制器中隔离每一经配置nvm集而防止“嘈杂邻居”现象。即,除形成经隔离区域(为了隔离每一nvm集的nand操作)的物理nand分区外,ssd固件还可经配置以通过能够为ssd的每一nvm集提供独立数据通道而确保控制器内的i/o处置针对每一iod nvm集是隔离开的。
19.图1a是根据一些实施方案的ssd 100的结构的框图。如图1a中所展示,控制器120通过主机接口110与主机101通信。主机101可为一或多个一或多个主机装置或主机应用程序。主机101可包含任何适合装置,例如但不限于,计算装置、存储器具等。在一些实例中,主机101可为由用户操作的用户装置。在一些实施方案中,主机101及ssd 100驻存于数据中心(未展示)中。数据中心包含多个平台,所述多个平台中的每一者可支持多个主机(例如但不限于,主机101)及ssd装置(例如但不限于,ssd 100)。
20.ssd 100包含易失性存储器130及非易失性存储器140。易失性存储器装置130及非易失性存储器140与控制器120通信。
21.在一些实施方案中,非易失性存储器140可为非易失性存储器裸片阵列,如所展示。非易失性存储器140包含可布置于连接到控制器120的一或多个存储器通信信道中的非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d。举例来说,裸片142a到d可配置于一个存储器信道上,裸片144a到d可配置于另一存储器信道上,以此类推。虽然图1a中展示16个非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d,但ssd 100的非易失性存储器140可包含布置于与控制器120通信的一或多个信道中的任何适合数目个非易失性存储器裸片。
22.在一个实施方案中,非易失性存储器裸片142a到142d、144a到144d、146a到146d及
148a到148d包含nand快闪存储器。nand快闪存储器包含快闪存储器。举例来说,每一nand快闪存储器装置包含一或多个个别nand快闪裸片,所述一或多个个别nand快闪裸片是能够在无电力的情况下保留数据的非易失性存储器装置。非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d中的每一者具有一或多个平面。每一平面具有多个块,且每一块具有多个页。数据可以连续次序写入到块中的页,一旦所有页均被写入便不再写入数据直到块被擦除,在块被擦除后可即刻再次以连续次序向页写入新数据,以此类推。
23.在一些实施方案中,易失性存储器装置130包含易失性存储器dram缓冲器。易失性存储器装置130可为单一类型的单个装置或能够为ssd 100提供易失性存储器缓冲器的不同类型的多个装置。
24.控制器120可组合非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d中的原始数据存储,使得那些非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d像单个存储装置一样起作用。控制器120可包含微控制器、缓冲器、错误校正功能性、快闪翻译层(ftl)、快闪接口层(ftl)、快闪控制器、快闪管理层软件、地址映射表及用于实施此类功能的固件,如本文中进一步描述。在一些布置中,软件/固件可存储于非易失性存储器140中或任何其它适合计算机可读存储媒体中。
25.控制器120包含用于执行本文中所描述的功能以及其它功能的适合处理及存储器能力。举例来说,控制器120包含用于实施ssd 100的各种功能的一或多个处理器(例如,中央处理单元(cpu))。如所描述,控制器120管理非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d的各种特征,包含但不限于,i/o处置、读取、写入、擦除、监视、日志记录、错误处置、垃圾收集、损耗均衡、逻辑到物理(l2p)地址映射等。
26.图1b是根据一些实施方案支持低等待时间操作的ssd架构150的框图。参考图1a及1b,ssd架构150可由ssd的非易失性存储器(例如但不限于,非易失性存储器140)配置而成。如图1b中所展示,ssd架构150包含跨越8个信道(ch0到ch7)布置的32个非易失性存储器裸片的阵列,其中有4个非易失性存储器裸片耦合到每一信道。换句话说,ssd架构150包含nand快闪存储器装置阵列。非易失性存储器裸片中的每一者具有一或多个平面。所属领域的普通技术人员可了解,任何适合数目个裸片可操作地耦合到任何适合数目个信道。ssd架构150中的非易失性存储器裸片中的每一者可为非易失性存储器裸片142a到142d、144a到144d、146a到146d及148a到148d中的一者。信道ch0到ch7可为物理信道或逻辑信道。
27.ssd架构150包含通过从同一信道及邻近信道(由相同阴影表示)上的非易失性存储器裸片中的每一者选择所有物理块而形成的超级块,而不是通过从跨越所有8个信道的非易失性存储器裸片中的每一者选择物理块而形成的超级块。这些超级块中的每一者在ssd内形成隔离区域(例如,与其它区域隔离的区域),所述隔离区域不受对ssd的其它区域的信道i/o活动影响,这是因为每一区域是经由不与其它区域共享的信道来存取。每一隔离区域可称为nvm集。因此,在ssd架构150中,隔离区域102包含两个信道ch0及ch1上的非易失性存储器裸片的物理块。隔离区域104包含两个信道ch2及ch3上的非易失性存储器裸片的物理块。隔离区域106包含两个信道ch4及ch5上的非易失性存储器裸片的物理块。隔离区域108包含两个信道ch6及ch7上的非易失性存储器裸片的物理块。
28.通过仅使用来自固定数目个单独信道中的非易失性存储器裸片的物理块配置超级块以形成隔离区域(例如图1b中所展示),可最小化或完全避免在非易失性存储器裸片及
信道控制器处发生i/o操作冲突,从而允许ssd的较低等待时间、较大可预测性及较一致i/o性能。如所展示,隔离区域102到108中的每一者包含耦合到多个(例如,两个)信道的非易失性存储器裸片,因此每隔离区域利用多个信道控制器来处置主机i/o操作以提高每隔离区域的吞吐量。替代地,隔离区域可包含耦合到一个信道的非易失性存储器裸片。因此,ssd架构150的裸片可经选择及布置以形成隔离区域102到108,但原理上可使用任何数目个信道来形成隔离区域,其中单独隔离区域不共享信道。
29.虽然图1b图解说明操作地耦合到同一信道的所有裸片位于同一隔离区域中,但用于形成隔离区域的其它方法允许耦合到同一信道的裸片位于单独隔离区域中。举例来说,来自信道ch0到ch3中的每一者的两个裸片可形成第一隔离区域,而来自信道ch0到ch3中的每一者的另两个裸片可形成第二隔离区域。每隔离区域的大量信道提高了隔离区域的吞吐量,然而当在区域之间共享信道时,做出了关于隔离能力的折衷,这是因为具有独有裸片但共享信道的两个区域的隔离程度将不像具有完全单独的信道的区域那样大。
30.图2是根据一些实施方案包含多个独立数据通道的ssd架构200的框图。参考图1a到2,ssd架构200包含控制器220及非易失性存储装置240。控制器220可为控制器120的实例实施方案。控制器220包含易失性存储器230,易失性存储器230可为例如但不限于易失性存储器130的易失性存储器。非易失性存储装置240可为非易失性存储器,例如但不限于,非易失性存储器140或具有架构150的非易失性存储器。
31.非易失性存储装置240包含跨越8个信道(例如,ch0到ch7)布置的非易失性存储器裸片的阵列,其中有三个非易失性存储器裸片耦合到每一信道。换句话说,非易失性存储装置240包含nand快闪存储器装置阵列。为了清晰起见,未展示到个别裸片的信道连接。非易失性存储器裸片中的每一者具有多个平面。所属领域的普通技术人员可了解,任何适合数目个裸片可操作地耦合到任何适合数目个信道。信道ch0到ch7可为物理信道或逻辑信道。
32.非易失性存储装置240的非易失性存储器裸片形成隔离区域(物理上隔离的区域)或nvm集260到263。属于同一nvm集的裸片由相同阴影表示。举例来说,操作地耦合到信道ch0及ch1的裸片形成nvm集260。操作地耦合到信道ch2及ch3的裸片形成nvm集261。操作地耦合到信道ch4及ch5的裸片形成nvm集262。操作地耦合到信道ch6及ch7的裸片形成nvm集263。
33.控制器220包含经配置以执行控制器220的各种过程的各种处理器。举例来说,ftl处理器242(例如,ftl接口模块)可处理地址映射表248(例如,l2p映射表)。地址映射表248是保持逻辑地址与物理地址之间的对应性记录的映射表。举例来说,地址映射表248可将关于逻辑块的读取及写入命令(从主机接收)翻译成参考物理块的低级命令。在一些实例中,从主机接收的读取或写入命令至少包含逻辑块地址(lba)。lba是识别可为扇区中的区域的逻辑块的逻辑地址。在一些实例中,写入命令还可包含数据将被写入到的区域/扇区的数目。地址映射表248存储每一逻辑地址与所述逻辑地址的数据被存储在的一或多个物理地址(例如,存储器裸片的页)之间的映射。
34.ftl处理器242可基于地址映射表248执行l2p操作。举例来说,ftl处理器242可将lba翻译成物理地址,因此分辨对应于lba的物理地址。响应于接收到来自主机的写入或读取命令(其中含有lba),ftl处理器242可通过使用地址映射表248查找对应于lba的物理地址以便向所述物理地址写入或从所述物理地址读取。地址映射表248可存储于非易失性存
储装置240、易失性存储器230或控制器220的适合存储器中的一或多者中。
35.在一些实施方案中,控制器220包含快闪管理层(fml)处理器246。fml处理器242管理快闪存储器裸片,将裸片内的存储器块布置成称作逻辑块的若干最优群组,确定要为用户数据分配的下一逻辑块、要为垃圾收集及元数据(例如映射查找表)选择的下一逻辑块。fml还监视写入命令的进展且提前准备下一块进行写入并管理用于检查先前存储的数据的保留可靠性的触发器。
36.在一些实施方案中,控制器220包含快闪接口层(fil)处理器250a及250b。fil处理器250a及250b提供ftl与快闪控制器(分别地,fc 255a/b及255c/d)之间的接口。fil处理命令队列(为了清晰起见未展示)中来自ftl的传入快闪命令,以最优方式将其调度到所述命令的目的地物理存储器组(裸片)的适当快闪控制器。来自命令的响应是从fc处置且存储于响应队列(为了清晰起见未展示)中,从而向ftl指示命令的成功或失败。如所展示,fil处理器250a及250b中的每一者位于nvm集260到263中的两者的i/o路径中。举例来说,fil处理器250a位于nvm集260到261的i/o路径中。fil处理器250b位于nvm集262到263的i/o路径中。
37.在一些实施方案中,控制器220进一步包含快闪控制器(fc)255a到255d。fc 255a到255d从fil获取存储器命令且在个别存储器信道上调度所述命令,执行必要存储器总线控制信令及向存储器裸片的数据传送,并针对命令成功还是失败检查存储器裸片状态。如所展示,nvm集260到263中的每一者具有fc 255a到255d中的一个不同fc。例如,fc255a位于nvm集260的i/o路径中。fc 255b位于nvm集261的i/o路径中。fc 255c位于nvm集262的i/o路径中。fc 255d位于nvm集263的i/o路径中。
38.在一些实施方案中,处理器242、246、250a到250b及255a到255d中的每一者可为单独处理器(例如,cpu)、处理电路或微控制器。换句话说,处理器242、246、250a到250b及255a到255d中的每一者是指可在制造后保持不变的单独硬件组件。在替代实施方案中,处理器242、246、250a到250b及255a到255d中的两者或更多者可实施于同一处理器、处理电路或微控制器上。控制器220(包含处理器242、246、250a到250b及255a到255d、易失性存储器230及地址映射表248(如果存储于控制器的存储器中))可使用例如但不限于系统单芯片(soc)的硬件实施。如本文中进一步详细地描述,处理器242、246、250a到250b及255a到255d、易失性存储器230及地址映射表248在其上运行的固件可用于配置给定数目个数据通道。固件处置且管理非易失性存储装置240、i/o操作及ssd架构200的后台操作。
39.ipc用于ssd架构200的两个组件(例如,在处理器上运行的两个过程)之间的通信。ipc对应于经由从发送方处理器或过程到接收方处理器或过程的通信链路的信令。例如,ipc可提供允许在发送方处理器或过程与接收方处理器或过程之间传递指令、消息及任务的通信协议。指令、消息及任务中的每一者载运将由接收方处理器或过程执行的任务的指示及上下文识别符或对在任务中使用的数据的参考。在一些实施方案中,每一ipc对应于经配置软件/固件,例如但不限于,软件队列、消息队列、共享存储器或使用发送方过程与接收方过程之间的适合协议配置的邮箱。在一些实施方案中,每一ipc对应于由控制器220建立以用于发送方过程与接收方过程之间的通信的通信端口,例如但不限于,因特网协议(ip)端口或插口。替代地,每一ipc是物理通信链路,例如但不限于,总线(例如,外围组件互连(pci))、串行通信链路、物理ipc端口、信道等。
40.控制器220的固件可配置来自非易失性存储装置240中的裸片的任何适合数目个
nvm集且可配置相同数目个独立数据通道。换句话说,控制器220的固件可针对每一经配置nvm集配置独立数据通道,使得所述nvm集的所有指令、消息及任务可使用对应独立数据通道来载运,且对应独立数据通道不载运另一nvm集的任何指令、消息或任务。
41.如所展示,沿着nvm集260的i/o路径提供第一独立数据通道。第一独立数据通道包含多个ipc/链路212a、212b、212c、212d及212e。ipc 212a用于将指令、消息及任务从易失性存储器230载运到ftl处理器242。ipc 212b用于在ftl处理器242与fil处理器250a之间载运指令、消息及任务。ipc 212c用于在fil处理器250a与fc 255a之间载运指令、消息及任务。链路212d是用于在fc 255a与nvm集260的操作地耦合到信道ch0的裸片之间载运命令/操作、数据及消息的快闪存储器信道。链路212e是用于在fc 255a与nvm集260的操作地耦合到信道ch1的裸片之间载运命令/操作、数据及消息的快闪存储器信道。鉴于fc 255a到非易失性存储装置240中的nvm集260之间的链路是信道特定的,第一独立数据通道从fc 255a到nvm集260包含两个链路212d及212e。第一独立数据通道仅针对nvm集260且不针对另一nvm集载运命令/操作、数据及消息。
42.沿着nvm集261的i/o路径提供第二独立数据通道。第一独立数据通道包含多个ipc/链路214a、214b、214c、214d及214e。ipc 214a用于将指令、消息及任务从易失性存储器230载运到ftl处理器242。ipc 214b用于在ftl处理器242与fil处理器250a之间载运指令、消息及任务。ipc 214c用于在fil处理器250a与fc 255b之间载运指令、消息及任务。链路214d是用于在fc 255b与nvm集261的操作地耦合到信道ch2的裸片之间载运命令/操作、数据及消息的快闪存储器信道。链路214e是用于在fc 255b与nvm集260的操作地耦合到信道ch3的裸片之间载运命令/操作、数据及消息的快闪存储器信道。鉴于fc 255b到非易失性存储装置240中的nvm集261之间的链路是信道特定的,第一独立数据通道从fc 255b到nvm集261包含两个链路214d及214e。第二独立数据通道仅针对nvm集261且不针对另一nvm集载运命令/操作、数据及消息。
43.沿着nvm集262的i/o路径提供第三独立数据通道。第三独立数据通道包含多个ipc/链路216a、216b、216c、216d及216e。ipc 216a用于将指令、消息及任务从易失性存储器230载运到ftl处理器242。ipc 216b用于在ftl处理器242与fil处理器250b之间载运指令、消息及任务。ipc 216c用于在fil处理器250b与fc 255c之间载运指令、消息及任务。链路216d是用于在fc 255c与nvm集262的操作地耦合到信道ch4的裸片之间载运命令/操作、数据及消息的快闪存储器信道。链路216e是用于在fc 255c与nvm集262的操作地耦合到信道ch5的裸片之间载运命令/操作、数据及消息的快闪存储器信道。鉴于fc 255c到非易失性存储装置240中的nvm集262之间的链路是信道特定的,第三独立数据通道从fc 255c到nvm集262包含链路ipc 216d及216e。第三独立数据通道仅针对nvm集262且不针对另一nvm集载运命令/操作及消息。
44.沿着nvm集263的i/o路径提供第四独立数据通道。第四独立数据通道包含多个ipc/链路218a、218b、218c、218d及218e。ipc 218a用于将指令、消息及任务从易失性存储器230载运到ftl处理器242。ipc 218b用于在ftl处理器242与fil处理器250b之间载运指令、消息及任务。ipc 218c用于在fil处理器250b与fc 255d之间载运指令、消息及任务。链路218d是用于在fc 255d与nvm集263的操作地耦合到信道ch6的裸片之间载运命令/操作、数据及消息的快闪存储器信道。链路218e是用于在fc 255d与nvm集263的操作地耦合到信道
ch7的裸片之间载运命令/操作、数据及消息的快闪存储器信道。鉴于fc 255d到非易失性存储装置240中的nvm集263之间的链路是信道特定的,第四独立数据通道从fc 255d到nvm集263包含两个链路218d及218e。第四独立数据通道仅针对nvm集263且不针对另一nvm集载运命令/操作及消息。
45.沿着ipc 212a到212c、214a到214c、216a到216c及218a到218c或在其中展示的方框是指在ipc 212a到212c、214a到214c、216a到216c及218a到218c中的对应者中载运的指令、消息及任务。具有与nvm集260到263中的对应一者的阴影相同的阴影的方框是指与对应nvm集且不与另一nvm集相关的指令、消息及任务。
46.虽然处理器242、246、250a到250b及255a到255d以及存储装置230及240被展示为实体的实例使得可针对每一nvm集建立那些实体中的两者之间的ipc及快闪信道,但每nvm集的ipc及快闪信道方案可同样地针对额外处理器(例如,主机接口110)及存储装置来实施。
47.如图2中所展示,可在发送方过程与接收方过程之间经由固件建立各自用于nvm集260到263中的不同一者的多个ipc,而不是用于所有nvm集260到263的一个ipc。鉴于每一处理器执行一或多个专用功能(或“工作”或“任务”),针对相同功能建立各自用于nvm集260到263中的不同一者的多个ipc。如此,ssd架构200及特定来说控制器220的布置减少或防止控制器220处因同一ipc中多个nvm集的消息、指令及任务的夹压导致的瓶颈。因此,在所公开实施方案中,当关于nvm集260到263中的一者发生延迟时,仅对应于被延迟nvm集的数据通道受影响。
48.图3是图解说明根据一些实施方案的过程间流程300的框图。参考图1a到3,过程间流程300可使用系统及架构100、150及200实施。p1 302、p2 304及p3 306各自是指例如但不限于控制器120及220的控制器的任何处理器。在一些实例中,p1 302、p2 304及p3 306中的每一者可为处理器242、246、250a到250b及255a到255d中的一者。
49.在过程间流程300中,建立三个独立数据通道。每一独立数据通道对应于在非易失性存储装置(例如但不限于,非易失性存储器140、架构150及非易失性存储装置240)中建立的三个nvm集(未展示)中的不同一者。举例来说,用于第一nvm集的第一独立数据通道包含ipc 321a、ipc 321b,及一或多个额外ipc(未展示)。用于第二nvm集的第二独立数据通道包含ipc 323a、ipc 323b,及一或多个额外ipc(未展示)。用于第三nvm集的第三独立数据通道包含ipc 325a、ipc 325b,及一或多个额外ipc(未展示)。ipc 321a、323a及325a在p1 302与p2 304之间传达指令、消息及任务。ipc 321b、323b及325b在p2 304与p3 306之间传达指令、消息及任务。
50.p1 302是可由控制器的固件配置以经由专用于第一nvm集的ipc 321a将第一nvm集的指令、消息及任务322a及322b推送到p2 304的发送方处理器或过程。p1 302可由控制器的固件配置以经由专用于第二nvm集的ipc 323a将第二nvm集的指令、消息及任务324a及324b推送到p2 304。p1 302可由控制器的固件配置以经由专用于第三nvm集的ipc 325a将第三nvm集的指令、消息及任务326a及326b推送到p2 304。p2 304是可处理指令、消息及任务322a、322b、324a、324b、326a及326b的处理器。在一些实例中,鉴于使用同一处理器p2 304来处理指令、消息及任务322a、322b、324a、324b、326a及326b,那些指令、消息及任务322a、322b、324a、324b、326a及326b属于同一类型。
51.p2 304是可由控制器的固件配置以经由ipc 321b将第一nvm集的指令、消息及任务322a及322b推送到p3 306的发送方处理器或过程。p2 304可由控制器的固件配置以经由ipc 323b将第二nvm集的指令、消息及任务324a及324b推送到p3 306。p2 304可由控制器的固件配置以经由ipc 325b将第三nvm集的指令、消息及任务326a及326b推送到p3306。
52.p2 304可基于独立数据通道顺序地处理指令、消息及任务322a、322b、324a、324b、326a及326b,例如,处理第一nvm集在ipc 321a中(例如,在软件队列中)的任务中的一者,接着处理第二nvm集在ipc 323a中(例如,在软件队列中)的任务中的一者,接着处理第三nvm集在ipc 325a中(例如,在软件队列中)的任务中的一者,且当已处理来自ipc 321a、323a及325a中的每一者的一个任务时,p2 304开始处理第一nvm集在ipc 321a中的下一任务,以此类推。替代地,可由p2 304同时处理独立数据通道中的两个或更多个或所有独立数据通道的指令、消息及任务。指令、消息及任务322a、322b、324a、324b、326a及326b可具有统一大小,如标题为“iod ssd的ipc上的最优传送与处理单位(optimal transfer and processing unit on ipc for iod ssd)”的代理人案卷第117441-0127号中进一步详细地论述,所述代理人案卷特此以全文引用的方式并入。标题为“用于固态驱动器中的输入输出确定性的两层确定性过程间通信调度器(two-layered deterministic inter-process communication scheduler for input output determinism in solid state drives)”的代理人案卷第117441-0128号中论述关于处理指令、消息及任务的方式的其它细节,所述代理人案卷特此以全文引用的方式并入。
53.在一些实例中,指令、消息及任务322a、322b、324a、324b、326a及326b可为i/o操作(例如,读取及写入)、后台操作(例如,垃圾收集、压缩、损耗均衡、断电保护及数据刷新)、开始/停止i/o等的部分。
54.过程间流程300图解说明针对在两个过程之间传递的每一nvm集的所有指令、消息及任务建立独立ipc,且用于每一nvm集的此类ipc中的两者或更多者可形成用于每一nvm集的独立数据通道。用于i/o操作(以及后台操作)的此类独立数据通道最小化或消除由于一个nvm集上的拥塞影响其它nvm集。举例来说,如果nand正忙于第一nvm集或用于第一nvm集的控制器资源不可用,那么p2 304可在处理指令、消息及任务322a及322b中的一者或两者之前处置其它nvm集的指令、消息及任务324a、324b、326a及326b。如此,第二及第三nvm集上的等待时间保持不受第一nvm集上的拥塞影响。
55.图4是图解说明根据一些实施方案用于启用一或多个数据通道的实例过程400的流程图。参考图1a到4,过程400可由系统及架构100、150或200上的控制器120或220的固件实施。不管数目还是功能,硬件(例如,设置于soc上的处理器/存储装置230、242、246、248、250a、250b、255a到255d及302到306)一旦被制造便保持不变。控制硬件的固件可配置硬件以取决于ssd的客户针对同一硬件期望非iod ssd配置还是iod ssd解决方案而建立任何数目个数据通道。在一个实例中,固件可在非iod配置中在控制器中针对非易失性存储装置(例如,非易失性存储器140)建立一个数据通道(非易失性存储器的区域不被隔离以形成隔离区域或nvm集)。在另一实例中,固件可在iod配置中在控制器中针对非易失性存储装置(例如,非易失性存储装置240或使用架构150的非易失性存储装置)的所有nvm集建立一个数据通道。在又一实例中,固件可在iod配置中在控制器中针对非易失性存储装置的nvm集中的每一者建立一个数据通道,例如参考图2及3所描述。如此,鉴于ssd产品可需要iod及非
iod解决方案两者,同一硬件是可在制造后通过固件配置的,以基于客户偏好实现每nvm集一个独立数据通道或另一其它数据通道配置。
56.在410处,ssd(例如,其控制器)执行第一通电序列。第一通电序列是ssd制造后的第一个通电序列,且在第一通电序列之前未执行其它通电序列。在一些实施方案中,在第一通电序列期间执行数据通道配置。在其它实施方案中,在另一时间执行数据通道配置(例如,框420及430)。
57.在420处,控制器确定待配置的至少一个数据通道的数目。举例来说,所述数目可为用于针对未隔离的非易失性存储装置(常规非iod ssd)或隔离成多个nvm集的非易失性存储装置(iod ssd)传递数据的一个数据通道,或用于每一nvm集(iod ssd)的一个独立数据通道。数据通道的数目可为高达数据通道的最大配置数目的数目。所述数目是单个参数。数据通道的数目还等于隔离以配置ssd的iod特征的nvm集的数目。
58.可基于主机或客户偏好而确定所述数目。在一些实例中,如果主机操作地耦合到控制器,那么可在第一通电序列期间从主机接收数据通道的数目。在一些实例中,通过检查ssd的装置配置文件而确定数据通道的数目。在第一通电序列期间检查装置配置文件或简档以设置ssd,包含数据通道。数据通道的数目的主机或客户偏好可含于装置配置文件中。装置配置文件可存储于控制器的任何适合存储器装置中或可从另一装置接收。
59.在430处,控制器启用至少一个数据通道中的所述数目个数据通道。每一数据通道包含用于沿着所述数据通道的每一对发送方/接收方处理器或过程的ipc。这意味着可基于所要nvm集的数目按比例增加ipc。在其中数据通道的数目是1的实例中,启用一个数据通道来在非iod情形中操作地耦合到非易失性存储装置或在iod情形中操作地耦合到非易失性存储装置的nvm集。在其中数据通道的数目是多于一个且等于nvm集的数目(例如,每nvm集一个独立数据通道)的实例中,启用一个数据通道来在iod情形中操作地耦合到非易失性存储装置的多个nvm集中的每一者。
60.每一ipc可经由软件定义为软件队列、消息队列或邮箱。在一些实施方案中,当固件在过程中使用先进先出(fifo)创建nvm集时,每一ipc可由于缺少物理端口而为纯软件ipc。例如,在于共同队列上接收到ipc消息后,即刻基于ipc消息中的nvm集识别符重新组织ipc消息且按fifo将ipc消息排队。此外,每一ipc可经由硬件定义,使得每一ipc可为物理总线、物理ipc端口、物理信道等。控制器可具有给定数目个可用物理总线、ipc端口及/或物理信道。可使用所有可用物理总线、ipc端口及/或物理信道中的在420处确定的数目个物理总线、ipc端口及/或物理信道。如此,每一ipc可通过连接两个处理器上的两个物理端口来界定。此外,针对每一nvm集相同的共享存储器旗标、共享存储器位图或共享存储器结构可经实施使得发送方过程设定由另一过程轮询的值以触发独立于其它nvm集的共享存储器内容的任务。
61.在一些实施方案中,可识别等待时间关键ipc消息,使得可针对每一nvm集建立单独ipc来载运等待时间关键ipc消息。在一些实施方案中,执行i/o相关操作(例如但不限于,读取及写入(例如,确定要从其读取或向其写入的逻辑地址、基于逻辑地址确定要从其读取或向其写入的物理地址等))的处理器/存储装置是等待时间关键的,而后台操作(例如,垃圾收集、压缩、损耗均衡、断电保护及数据刷新)是非等待时间关键的。在一些实施方案中,非等待时间关键ipc消息可针对所有nvm集经由同一ipc路由。
62.在其中易失性存储器230与ftl 242之间的ipc消息预定为等待时间关键的一个实例中,建立ipc 212a、214a、216a及218a来分别针对nvm集260到263载运消息。在其中ftl242与fil 250a及250b之间的ipc消息预定为等待时间关键的另一实例中,建立ipc 212b、214b、216b及218b来分别针对nvm集260到263载运消息。
63.在一些实例中,nvm集识别符可包含于经由独立数据通道或独立ipc发送的每一指令、消息或任务(例如,指令、消息或任务322a、322b、324a、324b、326a及326b中的每一者)中。集识别符可为指令、消息或任务的元数据的一部分。发送方处理器或过程及接收方处理器或过程可使用nvm集识别符来识别对应于指令、消息及任务的nvm集。举例来说,发送方处理器或过程可通过读取nvm集识别符而确定应通过哪一ipc发送或推送指令、消息及任务。接收方处理器或过程可出于处理指令、消息及任务的目的而识别对应于指令、消息及任务的nvm集。接收方处理器或过程可将不同算法应用于且将不同带宽分配给不同nvm集的指令、消息及任务。因此,nvm集识别符用于发送方处理器或过程与接收方处理器或过程之间的握手。
64.在440处,控制器经由在430处配置的数据通道传递指令、消息及任务。在其中启用一个总数据通道的实例中,经由所述一个数据通道传递针对非易失性存储装置(在非iod情形中)或针对非易失性存储装置的nvm集(在iod情形中)的指令、消息及任务。在其中针对每一nvm集启用一个独立数据通道的实例中,经由所建立的多个独立数据通道中的对应一者传递针对多个nvm集中的每一者的所有指令、消息及任务。
65.在涉及具有多个经隔离nvm集的iod ssd的一些实例中,在430处启用至少一个数据通道中的所述数目个数据通道(其包含一或多个ipc)进一步包含基于接收方处理器的最大处理能力或带宽及总nvm集的数目确定及调整每一独立ipc的深度。图5是图解说明根据一些实施方案操作地耦合到处理器p1 501及p2 502的ipc 510到517的长度的框图。
66.参考图1a到5,p1 501及p2 502各自是指例如但不限于控制器120及220的控制器的任何处理器或过程。在一些实例中,p1 501及p2 502中的每一者可为处理器242、246、250a到250b及255a到255d、易失性存储器230及地址映射表248中的一者。可以本文中所描述的方式针对八个nvm集中的相应一者建立ipc 510到517中的每一者。ipc 510到517中的每一者可为用于八个nvm集中的相应一者的独立数据通道的一部分。
67.常规ipc可为软件队列,例如但不限于布局发布请求队列。如本文中所描述,针对非易失性存储器的所有指令、消息及任务是经由同一常规ipc传递。常规ipc的深度基于接收方处理器或过程(p2 502)的处理能力、存储器要求及带宽。常规ipc越深(例如,可排队的指令、消息及任务越多),接收方处理器或过程具有的处理能力、存储器及带宽越大。举例来说,常规布局发布请求队列的深度(例如,链接发送方处理器/存储装置与接收方处理器/存储装置的仅一个布局发布请求队列)等于查找表(lut)更新完成队列。常规布局发布请求队列的实例深度是48,这意味着p2 502可在1ms内处理且完成48个任务。
68.在启用多个ipc来将指令、消息及任务从发送方处理器或过程p1 501载运到接收方处理器或过程p2 502(例如,ipc被按比例增加)时,鉴于增加p2 502的处理能力、存储器要求及带宽可为高成本的,维持p2 502的处理能力、存储器要求及带宽可为优选的。如此,当在430处启用所述数目个数据通道时,可通过将p1 501与p2 502之间的常规ipc的深度(例如,48)除以nvm集的总数目(例如,8)而确定p1 501与p2 502之间的ipc 510到517中的
每一者的深度。如所展示,ipc 510到517中的每一者具有深度6,这意味着6个指令、消息或任务可在用于p2 502的ipc 510到517n中的每一者中排队来处理。如此,p2 502仍可使用ipc 510到517在1ms内执行48个任务。
69.8个ipc 510到517n中的每一方框是指指令、消息或任务在队列中的位置或定位。所述位置/定位可使用索引(例如ipc布局发布索引ipc_lyt_rel)来确定。nvm集n(其中0《n《8)中的指令m(其中0《m《ipc_depth-1)(例如,对应于指令520ipc 513的m=2、n=3)的ipc布局发布索引可使用以下表达式确定:
70.ipc_lyt_rel[insm,setn]=m ipc[set0] (n
×
ipc
depth
);
[0071]
其中ipc[set0]是指用于集0的ipc 510中的第一指令的索引,且ipc_depth是指ipc510到517n中的每一者中的项目(例如,指令、消息或任务)的深度,其是6。
[0072]
因此,本文中所描述的实施方案涉及控制器内的固件管理的独立nvm集数据通道,其用以实现低等待时间过程间通信方案以避免iod驱动器中的“嘈杂邻居”效应、解决导致多个nvm集的i/o之间的冲突的控制器问题,多个nvm集的i/o之间的冲突又导致i/o等待时间,即使nand被分割成经隔离nvm集。
[0073]
同一固件可提供iod ssd的各种不同配置及对针对通用非iod ssd设计的控制器内用于每一iod nvm集的i/o路径的管理。此类实施方案允许针对每一nvm集独立地按比例扩展固件的设计,以避免竞争的方式划分控制器资源(例如但不限于,cpu、硬件组件、存储器等),这将nvm集中的任一者上的i/o工作负载的等待时间与性能折衷。
[0074]
本文中所描述的独立数据通道可用于流及非流隔离以避免由于对非流的后台操作对多个流造成性能影响。独立ipc方案可扩展到许多解决方案,例如但不限于对四电平单元(qlc)nand及任何未来nand产品的iod解决方案、具有混合iod与流的主机管理的方案的驱动器、在nand上具有多个隔离分区并要求隔离分区之间的等待时间改进的任何驱动器等。
[0075]
提供先前说明以使得所属领域的技术人员能够实践本文中所描述的各种方面。所属领域的技术人员将容易明了对这些方面的各种修改,且本文中所定义的通用原理可应用于其它方面。因此,权利要求书并不打算限于本文中所展示的方面,而是应被赋予与语言权利要求相一致的全部范围,其中以单数形式对元素的参考并不打算意指“一个且仅一个”(除非具体如此陈述),而是意指“一或多个”。除非另有具体陈述,否则术语“一些”是指一或多个。所属领域的普通技术人员已知的或后来知晓的在先前说明通篇描述的各种方面的元素的所有结构及功能等效物明确地以引用的方式并入本文中且打算由权利要求书涵盖。此外,本文中所公开的任何内容均不打算致力于公共的,而不管此公开是否明确地叙述于权利要求书中。任何权利要求元素均不应被视为构件加功能,除非使用短语“用于

的构件”明确地表达所述元素。
[0076]
应理解,所公开的过程中的步骤的特定次序或层次是说明性方法的实例。基于设计偏好,应理解,可在保持于先前说明的范围内的同时重新布置过程中的步骤的特定次序或层次。所附方法权利要求以样品次序呈现各种步骤的元素,且并不意在限于所呈现的特定次序或层次。
[0077]
提供所公开实施方案的先前说明以使得所属领域的技术人员能够制作或使用所公开的标的物。所属领域的技术人员将易于明了对这些实施方案的各种修改,且在本文中
所定义的通用原理可在不背离先前说明的精神或范围的情况下应用于其它实施方案。因此,先前说明不打算限于本文中所展示的实施方案,而是应被赋予与本文中所公开的原理及新颖特征一致的最宽广范围。
[0078]
所图解说明及描述的各种实例仅提供为实例以图解说明权利要求书的各种特征。然而,关于任一给定实例所展示及描述的特征不必限于相关联实例且可与所展示及描述的其它实例一起使用或与其组合。此外,权利要求书不打算受任一实例限制。
[0079]
前述方法说明及过程流程图仅提供为说明性实例且不打算要求或暗示各种实例的步骤必须以所呈现的次序执行。所属领域的技术人员将了解,前述实例中步骤的次序可以任何次序执行。例如“此后”、“接着”、“接下来”等词语不打算限制步骤的次序;这些词语仅用于引导读者贯穿对方法的说明。此外,以单数形式(例如,使用冠词“一(a)”、“一(an)”或“所述(the)”)对权利要求元素的任何参考不应解释为将所述元素限制为单数。
[0080]
结合本文中所公开的实例描述的各种说明性逻辑块、模块、电路及算法步骤可实施为电子硬件、计算机软件或两者的组合。为了清楚地图解说明硬件与软件的此可互换性,上文大体就各种说明性组件、块、模块、电路及步骤的功能性对其进行了描述。此功能性是实施为硬件还是软件取决于特定应用及对总体系统强加的设计约束。所属领域的技术人员可针对每一特定应用以各种方式实施所描述功能性,但此类实施方案决策不应解释为导致背离本公开的范围。
[0081]
用于结合本文中所公开的实例实施所描述的各种说明性逻辑、逻辑块、模块及电路的硬件可利用以下各项来实施或执行:经设计以执行本文中所描述的功能的通用处理器、dsp、asic、fpga或其它可编程逻辑装置、离散门或晶体管逻辑、离散硬件组件或其任一组合。通用处理器可为微处理器,但在替代方案中,处理器可为任何常规处理器、控制器、微控制器或状态机。处理器也可实施为计算装置的组合,例如,dsp与微处理器的组合、多个微处理器的组合、一或多个微处理器联合dsp核心的组合,或任何其它此类配置。替代地,一些步骤或方法可由特定于给定功能的电路系统执行。
[0082]
在一些示范性实例中,所描述的功能可以硬件、软件、固件或其任一组合实施。如果以软件实施,那么所述功能可作为一或多个指令或代码存储在非暂时性计算机可读存储媒体或非暂时性处理器可读存储媒体上。本文中所公开的方法或算法的步骤可以可驻存于非暂时性计算机可读或处理器可读存储媒体上的处理器可执行软件模块体现。非暂时性计算机可读或处理器可读存储媒体可为可由计算机或处理器存取的任何存储媒体。通过实例但非限制的方式,此类非暂时性计算机可读或处理器可读存储媒体可包含ram、rom、eeprom、快闪存储器、cd-rom或其它光盘存储装置、磁盘存储装置或其它磁性存储装置或者可用于以指令或数据结构的形式存储所要程序代码且可由计算机存取的任何其它媒体。如本文中所使用,磁盘及光盘包含压缩光盘(cd)、激光光盘、光学光盘、数字通用光盘(dvd)、软磁盘及蓝光光盘,其中磁盘通常以磁性方式再现数据,而光盘借助激光以光学方式再现数据。以上各项的组合也包含于非暂时性计算机可读及处理器可读媒体的范围内。另外,方法或算法的操作可作为代码及/或指令中的一者或任一组合或者集驻存于可并入到计算机程序产品中的非暂时性处理器可读存储媒体及/或计算机可读存储媒体上。
[0083]
对所公开实例的前述说明经提供以使得所属领域的技术人员能够制作或使用本公开。所属领域的技术人员将容易地明了对这些实例的各种修改,且本文中所定义的通用
原理可在不背离本公开的精神或范围的情况下应用于一些实例。因此,本公开不打算限于本文中所展示的实例,而是应被赋予与所附权利要求书以及本文中所公开的原理及新颖特征一致的最宽广范围。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献