存取单元和管理片段存储器操作
1.分案申请的相关信息
2.本技术是申请号为201980064685.7、申请日为2019年10月1日、发明名称为“存取单元和管理片段存储器操作”的中国发明专利申请的分案申请。
技术领域
3.本公开的实施例大体上涉及存储器子系统,且更具体来说,涉及存取单元和管理片段存储器操作。
背景技术:
4.存储器子系统可以是存储系统,如固态驱动器(ssd)或硬盘驱动器(hdd)。存储器组件可以例如是非易失性存储器组件和易失性存储器组件。存储器子系统可为存储器模块,例如双列直插式存储器模块(dimm)、小型dimm(so-dimm)或非易失性双列直插式存储器模块(nvdimm)。存储器子系统可包含一或多个存储器组件。存储器组件可以例如是非易失性存储器组件和易失性存储器组件。一般来说,主机系统可以利用存储器子系统以在存储器组件处存储数据且从存储器组件检索数据。
技术实现要素:
5.本公开的实施例提供一种系统,其包括:第一存储器组件,其具有与逻辑存取单元对应的特定存取大小,所述逻辑存取单元具有与耦合到所述第一存储器组件的处理装置的与存储器操作的执行相关联的高速缓存行大小相同的大小;第二存储器组件,其存储逻辑到物理数据结构,所述数据结构的管理条目将管理片段映射到所述存储器组件中的相应物理位置,其中每一管理片段对应于具有所述特定存取大小的经聚合的多个逻辑存取单元,且其中所述管理条目包括管理片段地址、时间戳或存取计数或其组合中的至少一个;优先级排序器电路,其被配置成协调与所述第一存储器组件相关联的被动干扰管理操作的执行;和处理装置,其可操作地耦合到所述第一存储器组件,所述处理装置被配置成:通过控制具有与所述逻辑存取单元对应的所述特定存取大小的数据到所述第一存储器组件的传送,致使所述被动干扰管理操作的执行;和在每管理片段基础上通过以下操作来执行存储器管理操作:对于每一相应管理片段,跟踪对与所述相应管理片段对应的组员存取单元的存取请求;和基于所述跟踪和来自所述优先级排序器电路的输入确定是否对所述相应管理片段执行特定存储器管理操作。
6.本公开的另一实施例提供一种系统,其包括:存储器组件,其具有与逻辑存取单元对应的特定存取大小,所述逻辑存取单元具有与耦合到所述存储器组件的处理装置的与存储器操作相关联的高速缓存行大小相同的大小;逻辑到物理数据结构,其条目将管理片段映射到所述存储器组件中的相应物理位置,其中每一管理片段对应于具有所述特定存取大小的经聚合的多个逻辑存取单元;优先级排序器电路,其被配置成协调与所述存储器组件相关联的被动干扰管理操作的执行;和处理装置,其被配置成:通过控制具有与所述逻辑存
取单元对应的所述特定存取大小的数据到所述存储器组件的传送,致使所述被动干扰管理操作的执行;和响应于接收到的对具有所述特定存取大小的特定存取单元执行存储器操作的请求:确定与所述特定存取单元对应的管理条目,其中所述管理条目包括管理片段地址、时间戳或存取计数或其组合中的至少一个;更新所述管理条目的属性数据;和基于所述经更新属性数据确定是否对与所述管理条目对应的所述管理片段执行媒体管理操作。
7.本公开的又一实施例提供一种方法,其包括:使用将管理片段映射到存储器组件的相应物理位置的管理条目执行存储器管理操作,其中每一管理片段对应于具有特定存取大小的经聚合的多个逻辑存取单元,所述特定存取大小对应于具有与处理装置的高速缓存行大小相同的大小的逻辑存取单元,且其中所述管理条目包括管理片段地址、时间戳或存取计数或其组合中的至少一个;跟踪对应于每一管理片段的存取请求;基于从优先级排序器电路接收到的输入,通过控制具有对应于所述逻辑存取单元的所述特定存取大小的数据到所述存储器组件的传送来执行被动干扰管理操作;和至少部分地基于所述跟踪,确定是否对相应管理片段执行特定存储器管理操作。
附图说明
8.根据下文提供的具体实施方式和本公开的各种实施例的附图将更加充分地理解本公开。
9.图1说明根据本公开的一些实施例的包含存储器子系统的实例计算环境。
10.图2说明根据本公开的一些实施例的包含存储器子系统的另一实例计算环境。
11.图3说明根据本公开的一些实施例的存储器组件的一部分的实例。
12.图4是根据本公开的一些实施例的对应于存取单元和管理片段存储器操作的实例方法的流程图。
13.图5是其中可操作本公开的实施例的实例计算机系统的框图。
具体实施方式
14.本公开的方面针对于存取单元和管理片段存储器操作。存储器子系统在下文也称为“存储器装置”。存储器子系统的实例是通过外围互连件(例如,输入/输出总线、存储区域网络)耦合到中央处理单元(cpu)的存储装置。存储装置的实例包含固态驱动器(ssd)、快闪驱动器、通用串行总线(usb)快闪驱动器和硬盘驱动器(hdd)。存储器子系统的另一实例是经由存储器总线联接到cpu的存储器模块。.存储器模块的实例包含双列直插式存储器模块(dimm)、小型dimm(so-dimm)、非易失性双列直插式存储器模块(nvdimm)等。在一些实施例中,存储器子系统是混合式存储器/存储子系统。一般来说,主机系统可利用包含一或多个存储器组件的存储器子系统。主机系统可提供数据以存储于存储器子系统处,且可请求从存储器子系统检索数据。
15.存储器子系统(例如,ssd)可包含媒体管理组件,其可用以对提供管理操作的处置以维持存储器子系统健康。一些新兴的存储器子系统(例如三维交叉点(3-dxp)存储器子系统)可要求超出“与非”(nand)类型存储器的常规动态随机存取(dram)的管理处置的特殊管理处置。举例来说,一些存储器子系统可要求对例如以下特性的管理:对读取和/或写入循环的数目的耐久性限制、读取分界电压的漂移、对写入操作的近接干扰效应和/或对读取操
作的自干扰效应。
16.处置对以上特性的管理的一些常规方法可包含耗损均衡、干扰管理和/或漂移管理。然而,在一些常规方法中,这些技术同时实施于数据页(例如,大约4千字节(kb)的数据)上。一般来说,随着在执行耗损均衡、干扰管理和/或漂移管理技术时使用的数据量增加,对存储器子系统的有害影响也可增加。举例来说,使用大约存储器子系统的一个页大小(例如,4kb)的单元执行干扰管理的一些方法可对写入或读取的整个页产生近接干扰和/或自干扰效应。
17.相比之下,本文中所描述的实施例允许小于存储器子系统的页大小的存取单元大小。在一些实施例中,举例来说,存取单元大小可为64字节(例如,页大小的1/64大小)或128字节(例如,页大小的1/32大小)。相较于使用与页大小相当的存取单元大小的方法,通过提供小于页大小的存取单元大小,可实现改进的写入放大。另外,在一些实施例中,存取单元大小可与供与存储器子系统相关联的处理资源的高速缓存行使用的码字大小相当,这与使用与页大小相当的存取单元大小的方法相比可精简码字处理量。处理资源是对外部数据源执行操作的硬件装置。码字是代码或协议元素,例如与计算机代码或计算协议相关联的连续位串。高速缓存行是在计算机存储器和计算装置的各个高速缓存器之间传送的固定大小的数据单元。
18.另外,本公开描述具有小于页大小的大小的存取单元的利用,这与利用与页大小相当的存取单元大小的方法相比可减少错误校正需求。举例来说,归因于与较小存取单元相关联的写入干扰的效应减小,可需要较少错误校正来确保数据完整性。
19.在一些实施例中,可使用与页大小相当的管理片段执行耗损均衡。举例来说,64字节存取单元可组合成具有大约4kb的大小的单个管理片段。通过对更大管理片段执行耗损均衡,可优化耗损均衡操作,同时通过使用较小存取单元大小来降低干扰效应。以组合方式,归因于上文所提及的降低的干扰效应结合优化的耗损均衡,这些可允许改进写入放大。
20.图1说明根据本公开的一些实施例的包含存储器子系统110的实例计算环境100。存储器子系统110可包含媒体,如存储器组件112a到112n。存储器组件112a到112n可以是易失性存储器组件、非易失性存储器组件或这类组件的组合。在一些实施例中,存储器子系统是存储系统。存储系统的实例是ssd。在一些实施例中,存储器子系统110是混合式存储器/存储装置子系统。一般来说,计算环境100可包含使用存储器子系统110的主机系统120。举例来说,主机系统120可将数据写入到存储器子系统110以及从存储器子系统110读取数据。
21.主机系统120可为计算装置,例如台式计算机、手提式计算机、网络服务器、移动装置、支持物联网的装置,或包含存储器和处理装置的此类计算装置。主机系统120可包含或耦合到存储器子系统110,使得主机系统120可从存储器子系统110读取数据或将数据写入到存储器子系统110。主机系统120可经由物理主机接口耦合到存储器子系统110。如本文所使用,“耦合到”通常是指组件之间的连接,其可以是间接通信连接或直接通信连接(例如,没有中间组件),无论是有线还是无线的,包含例如电连接、光学连接、磁连接等的连接。物理主机接口的实例包含但不限于串行高级技术附件(sata)接口、外围组件互连高速(pcie)接口、通用串行总线(usb)接口、光纤通道、串行连接的scsi(sas)等。物理主机接口可用于在主机系统120与存储器子系统110之间发射数据。当存储器子系统110通过pcie接口与主机系统120耦合时,主机系统120还可利用nvm高速(nvme)接口来存取存储器组件112a到
112n。物理主机接口可提供用于在存储器子系统110与主机系统120之间传送控制、地址、数据和其它信号的接口。
22.存储器组件112a到112n可以包含不同类型的非易失性存储器组件和/或易失性存储器组件的任何组合。非易失性存储器组件的实例包含“与非”(nand)类型快闪存储器。存储器组件112a到112n中的每一个可包含一或多个存储器单元阵列,如单层级单元(slc)或多层级单元(mlc)(例如,三层级单元(tlc)或四层级单元(qlc))。在一些实施例中,特定存储器组件可以包含存储器单元的slc部分和mlc部分两者。存储器单元中的每一个可存储供主机系统120使用的一或多个数据位(例如,数据块)。虽然描述如nand类型快闪存储器的非易失性存储器组件,但存储器组件112a到112n可基于任何其它类型的存储器,例如易失性存储器。在一些实施例中,存储器组件112a到112n可以是(但不限于)随机存取存储器(ram)、只读存储器(rom)、动态随机存取存储器(dram)、同步动态随机存取存储器(sdram)、相变存储器(pcm)、磁随机存取存储器(mram)、“或非”(nor)快闪存储器、电可擦除可编程只读存储器(eeprom)以及非易失性存储器单元的交叉点阵列。非易失性存储器的交叉点阵列可结合可堆叠交叉网格化数据存取阵列而基于体电阻的改变来进行位存储。另外,与许多基于闪存的存储器对比,交叉点非易失性存储器可执行就地写入操作,其中可在不预先擦除非易失性存储器单元的情况下对非易失性存储器单元进行编程。此外,存储器组件112a到112n的存储器单元可分组为存储器页或数据块,其可指代用于存储数据的存储器组件的单元。
23.存储器系统控制器115(下文称为“控制器”)可与存储器组件112a到112n通信以执行操作,例如在存储器组件112a到112n处读取数据、写入数据或擦除数据,以及其它此类操作。控制器115可包含硬件,如一或多个集成电路和/或离散组件、缓冲存储器或其组合。控制器115可以是微控制器、专用逻辑电路(例如,现场可编程门阵列(fpga)、专用集成电路(asic)等)或其它合适的处理器。控制器115可包含处理装置(例如,处理器117),其被配置成执行存储于本地存储器119中的指令。在所说明的实例中,控制器115的本地存储器119包含被配置成存储指令以用于执行控制存储器子系统110的操作(包含处置存储器子系统110与主机系统120之间的通信)的各种过程、操作、逻辑流程以及例程的嵌入式存储器。在一些实施例中,本地存储器119可以包含存储器寄存器,其存储存储器指针、提取的数据等。本地存储器119还可以包含用于存储微码的只读存储器(rom)。虽然图1中的实例存储器子系统110已说明为包含控制器115,但在本公开的另一实施例中,存储器子系统110可能不包含控制器115,且可改为依靠(例如由外部主机或由与存储器子系统分离的处理器或控制器提供的)外部控制。
24.在一些实施例中,控制器115包含媒体管理组件113的至少一部分。举例来说,控制器115可包含处理器117(处理装置),其被配置成执行存储在本地存储器119中的指令以用于执行本文中所描述的操作。在一些实施例中,媒体管理组件113是主机系统120、应用程序或操作系统的部分。然而,实施例不限于此,且媒体管理组件113可部署在控制器115外部。
25.一般来说,控制器115可从主机系统120接收命令或操作且可将所述命令或操作转换成指令或适合的命令以实现对存储器组件112a到112n的所需存取。控制器115可负责其它操作,例如耗损均衡操作、垃圾收集操作、错误检测和错误校正码(ecc)操作、加密操作、高速缓存操作和在与存储器组件112a到112n相关联的逻辑块地址与物理块地址之间的地
址转译。控制器115可另外包含主机接口电路系统以经由物理主机接口与主机系统120通信。主机接口电路系统可将从主机系统接收到的命令转换成命令指令以存取存储器组件112a到112n,以及将与存储器组件112a到112n相关联的响应转换成用于主机系统120的信息。
26.存储器子系统110还可包含未说明的额外电路或组件。举例来说,存储器组件112a到112n可包含控制电路系统、地址电路系统(例如,行和列解码电路系统)和/或所述存储器组件可与控制器115和/或主机120通信所借助的输入/输出(i/o)电路系统。作为实例,在一些实施例中,地址电路系统(可从控制器115接收地址且解码所述地址以存取存储器组件112a到112n)。
27.存储器子系统110包含媒体管理组件113(例如,如本文中所描述的被配置成执行用于存储器子系统110的管理操作的电路系统和/或逻辑)。媒体管理组件113可在本文中替代地被称为“处理装置”。媒体管理组件113可被配置成致使产生各自包含特定量的数据的存取单元。在一些实施例中,媒体管理组件113可被配置成产生对应于处理器117的高速缓存行大小的存取单元。举例来说,媒体管理组件113可被配置成产生含有64字节数据、128字节的数据等的存取单元。在一些实施例中,存取单元可包括可被存储器组件112a到112n存取(例如,写入到存储器组件112a到112n、从存储器组件112a到112n读取、由存储器组件112a到112n存储、传送到存储器组件112a到112n或从存储器组件112a到112n传送等)的码字。举例来说,媒体管理组件113可接收和/或发射用以产生存取单元(例如,本文中结合图3描述的存取单元330)和/或管理片段(例如,本文中结合图3描述的管理片段332)的信号。
28.媒体管理组件113可被进一步配置成产生包含多个存取单元的管理片段。在一些实施例中,管理片段可具有对应于存储器组件112a到112n的页大小的大小(例如,4kb)。在此实例中,管理单元可包含六十四个64字节存取单元、三十二个128字节存取片段等。
29.在一些实施例中,媒体管理组件113可被配置成致使使用管理片段执行存储器管理操作。作为实例,媒体管理组件113可被配置成致使对管理片段执行耗损均衡操作。然而,实施例不限于此,且在一些实施例中,媒体管理组件113可被配置成致使对存储器组件112a到112n的其中存储有存取单元的部分执行被动干扰管理操作。如本文中所使用,举例来说,“被动干扰管理操作”可指管理或降低当数据写入到存储器组件112a到112n时可出现的干扰效应的影响的操作。举例来说,如本文中更详细地描述,可通过限制存取单元的大小和/或写入跨存储器组件112a到112n的通道的存取单元,执行被动写入干扰管理操作。然而,实施例不限于耗损均衡操作或一干扰管理操作中的任一个的性能,且在一些实施例中,媒体管理组件113可执行耗损均衡操作和被动干扰管理操作两者。
30.媒体管理组件113可被配置成产生和/或附加存取计数计数器121到管理片段。举例来说,媒体管理组件113可致使存取计数计数器121对应于使用管理片段执行存储器管理操作的次数和/或已对存储器组件112a到112n的特定页执行存储器管理操作的次数。另外,或在替代方案中,如下文更详细地描述,存取计数计数器121可被配置成跟踪对存储器组件112a到112n的部分的存取频率。在一些实施例中,与跟踪存储器组件112a到112n的特定位置参与执行存储器管理操作的次数的一些先前方法相比,存取计数器121可用于为存储器组件112a到112n提供改进的写入放大特性。另外,媒体管理组件113可使用存取计数计数器121采取例如以下动作来减少对存储器组件112a到112n的某些部分的写入放大:致使对存
储器组件112a到112n的与存储器组件112a到112n的其它部分相比较不频繁被使用的部分执行存储器管理操作。
31.图2说明根据本公开的一些实施例的包含存储器子系统110的另一实例计算环境100。存储器子系统110可包含媒体,例如存储器组件112a到112n和/或主存储器,例如dram 209。存储器组件112a到112n可以是易失性存储器组件、非易失性存储器组件或这类组件的组合。在一些实施例中,存储器子系统是存储系统。存储系统的实例是ssd。在一些实施例中,存储器子系统110是混合式存储器/存储子系统(例如,包含3d xpoint存储器部分和主存储器部分(例如dram部分)的存储器子系统)。图2中所说明的计算环境100可类似于图1中所说明的计算环境100。
32.在本文中,存储器子系统110可耦合到接口207,所述接口207可耦合到主机系统,例如图1中所说明的主机系统120。在一些实施例中,接口207可为双倍数据速率接口,例如ddr4、ddr5、ddr-t等接口,或非易失性双列直插式存储器(nvdimm)接口,例如nvdimm-n、nvdimm-p等接口。然而,实施例不限于列举的这些实例,且接口207可为如下任何类别的接口:将命令(例如,cmd)提供到存储器子系统110和/或提供进出存储器子系统100的双向数据路径(例如,data)。另外,在一些实施例中,存储器子系统110可包括ddr dimm,其包含主存储器部分,例如动态随机存取存储器(dram)部分,以及三维非易失性存储器部分,例如3d交叉点(3d xpoint)存储器部分。在一些实施例中,主机系统120可经由事务ddr接口存取非易失性存储器部分。举例来说,可经由来自主机系统120的ddr存取请求存取非易失性存储器部分。
33.存储器子系统110可包含媒体管理组件113(本文中结合图1更详细地描述),其可包含逻辑到物理(l2p)表216。存储器子系统110可另外包含管理子组件214和/或优先级排序器218。管理子组件214可包含被配置成与媒体管理组件113协同执行媒体管理操作的电路系统和/或逻辑。举例来说,管理子组件214可包含如下子组件:被配置成执行对存取媒体112a到112n的监测以例如协调响应于干扰效应、耗损均衡、写入到读取和/或写入到写入时序管理、漂移管理和/或后台媒体监测而执行的校正性读取和/或刷新操作。
34.l2p表216可在管理片段层级上执行逻辑到物理地址转译。举例来说,l2p表216可被配置成为存储器子系统110所使用的管理片段提供逻辑到物理地址转译。在一些实施例中,l2p表216可在本文中被称作管理片段表。如本文中所使用,管理片段表可包含对应于片段地址(例如,对应于存取单元和/或管理片段的地址)、与存取单元和/或管理片段相关联的时间戳和/或管理片段存取计数值(例如,存取计数计数器值)的信息。
35.优先级排序器218可包含如下电路系统和/或逻辑:被配置成协调管理子组件214所执行的操作和/或为管理子组件214所执行的操作指配优先级等级以协调管理子组件214所执行的操作。举例来说,优先级排序器218可被配置成确定执行上文所描述的与管理子组件214相关联的操作的次序。虽然在图2中示出为控制器115的部分,但管理子组件214和/或优先级排序器218无需物理上安置于控制器上或内。举例来说,在一些实施例中,管理子组件214和/或优先级排序器可位于存储器子系统110上或内和/或管理子组件214和/或优先级排序器218的部分可部分地位于控制器115上或内。
36.在一些实施例中,计算环境100可包括用于存取单元和管理片段存储器操作的系统。举例来说,媒体管理组件113可维持逻辑到物理数据结构216,其条目将管理片段映射到
存储器组件113中的相应物理位置。管理片段可对应于具有特定存取大小的经聚合的多个逻辑存取单元。媒体管理组件113可被配置成对具有特定存取大小的特定存取单元执行存储器操作,确定特定存取单元对应的管理条目,更新管理条目的属性数据,以及基于经更新属性数据确定是否在对应于管理条目的管理片段上执行媒体管理操作。所述属性数据可包含管理条目内的计数值(例如,存取计数器121所存储的值)、旗标、阈值计数值等。在一些实施例中,管理条目可包含管理片段地址、时间戳和/或存取计数。
37.存储器组件112a到112n可具有与其相关联的特定存取大小。所述特定存取大小可对应于存储器组件的输入/输出(i/o)传送大小并且与主机(例如,本文中在图1中所说明的主机系统120)的传送大小对准。举例来说,所述特定存取大小可对应于主机的与用于计算环境100的存储器操作的执行相关联的高速缓存行大小。
38.如上文所描述,存储器组件112a到112n可包括非易失性存储器。举例来说,存储器组件112a到112n可包括具有非易失性就地写入能力的非易失性存储器和/或响应于存储器操作的执行受到耗损的存储器。在一些实施例中,除了非易失性存储器组件112a到112n之外,dram存储器部分209也可提供给计算环境。应注意,在一些实施例中,如上文所描述,存储器组件112a到112n可经由ddr接口与主机通信。
39.图3说明根据本公开的一些实施例的存储器组件112的一部分的实例。存储器组件112的部分可包含多个存储器通道,所述存储器通道可包含存储器页和/或存储器分区。举例来说,如图3中所示,每一存储器通道(c)可包含存储器页(n、n 1、n 2、
……
、n 5)和/或存储器分区(0到31)。
40.可跨存储器组件113的一部分的多个通道存储存取单元330(其可由在本文中结合图1论述的媒体管理组件113产生)。在一些实施例中,存取单元330具有对应于耦合到存储器组件112的处理器(例如,本文中在图1中所说明的处理器117)的高速缓存行大小的大小。举例来说,存取单元330可具有大约64字节、128字节等的大小。如图3中所示,跨延伸到存储器组件112的含有存储器组件112的页n和/或n 1和分区31的部分的页中的通道c(例如,通道c=0到通道c-1,如图3的右下角所示)存储存取单元330。如将了解,此特定实例并非限制性,且可跨存储器组件112的不同页和/或分区的不同通道存储存取单元330。
41.在一些实施例中,与一些先前方法相比,通过跨存储器组件112的多个通道存储存取单元330,可减轻写入干扰效应。另外,在一些实施例中,与一些先前方法相比,通过将存取单元330的大小限制为对应于耦合到存储器组件112的处理器(例如,本文中在图1中所说明的处理器117)的高速缓存行的大小,可将写入干扰效应降到最低。这可引起随后可对存取单元330执行的错误校正操作的减少。
42.可跨多个存储器页(例如,页n 2和/或n 3)和/或分区(例如,分区0到31)存储管理片段332(可由本文中结合图1论述的媒体管理组件113)产生。如将了解,此特定实例并非限制性,且可跨存储器组件112的不同页和/或分区存储管理片段332。在一些实施例中,与一些先前方法相比,通过跨存储器组件113的多个页和/或分区存储管理片段332,可使用对应于存储器组件112的页大小的数量的数据执行存储器管理操作,例如耗损均衡操作,这可允许在将写入放大效应降到最低的同时有效管理耗损均衡操作。
43.在一些实施例中,管理片段332可具有对应于存储器组件112的页大小的大小。举例来说,管理片段332可具有大约4kb的大小,所述大小可对应于存储器组件112的页大小。
因此,在其中存取单元330大小是64字节且管理片段332大小是大约4kb的实例中,管理片段332可包含六十四个存取单元330。换句话说,在一些实例中,管理片段332可通过组合多个存取单元330产生。在一些实施例中,可使用上文结合图1和图2描述的媒体管理组件组合存取单元330以形成管理片段332。换句话说,管理片段332可包括存取单元330的聚合。这可降低独立跟踪存取单元330的复杂性。
44.在一些实施例中,管理片段332可包含片段元数据333。片段元数据333可为具有与其相关联的特定位量或字节量的码字。片段元数据332可包含与存储器组件112和/或管理片段332相关联的各种管理数据。在一些实施例中,片段元数据333可为包含存取计数计数器的码字。存取计数计数器可响应于存储器管理操作的执行而递增。举例来说,上文结合图1和图2描述的媒体管理组件可被配置成致使存取计数计数器响应于管理片段332和/或存取单元330进行的存取而递增。另外,在一些实施例中,与一些先前方法相比,片段元数据可跟踪存储器管理操作的执行频率以提供改进的写入放大。
45.作为改进存储器组件112的写入放大的过程的部分,可监测存取计数计数器(例如,本文中在图1和图2中所说明的存取计数器121)。举例来说,一旦存取计数计数器已达到阈值计数量,媒体管理组件便可采取校正性动作以减少用于存储器组件112的写入放大。在一些实施例中,可在存储器组件112的寿命内维持存取计数计数器。
46.如图3中所示,管理片段332可具有物理上位于管理片段332上方的北相邻者片段336和物理上位于管理片段332下方的南相邻者片段338。一般来说,当从存储器组件112的读取数据或将数据写入到存储器组件112的部分时,相邻区可经历干扰效应。举例来说,当管理片段332写入到对其进行存储的分区或从所述分区进行读取时,北相邻者片段336和/或南相邻者片段338可经历干扰(例如,写入干扰和/或近接干扰)效应,这可给存储于北相邻者片段336和/或南相邻者片段338中的数据带来非所要结果。
47.然而,在一些实施例中,可缓解给存储于北相邻者片段336和/或南相邻者片段338中的数据带来非所要结果。举例来说,如上文所描述,与一些先前方法相比,通过使用存取单元330和管理片段332,可降低可给北管理片段336和/或南管理片段338带来的非所要效应。也就是说,在一些实施例中,相较于先前方法,通过组合利用大小类似于处理器的高速缓存行大小的存取单元330对存储器组件的被动干扰管理操作的执行与由选择大于存取单元330大小的管理片段332大小引起的干扰管理操作的执行,可实现写入放大的改进。
48.图4是根据本公开的一些实施例的对应于存取单元和管理片段存储器操作的实例方法的流程图。方法400可由处理逻辑执行,所述处理逻辑可包含硬件(例如,处理装置、电路系统、专用逻辑、可编程逻辑、微码、装置的硬件、集成电路等)、软件(例如,在处理装置上运行或执行的指令),或其组合。在一些实施例中,方法400由图1的媒体管理组件113执行。虽然以特定顺序或次序来展示,但是除非另有指定,否则可修改过程的次序。因此,应理解,所说明实施例仅为实例,且所说明过程可以不同次序进行,且一些过程可并行地进行。另外,在各个实施例中可以省略一或多个过程。因此,在每个实施例中并不需要所有过程。其它过程流程也是可能的。
49.在一些实施例中,处理装置可维持逻辑到物理数据结构,其条目将管理片段映射到存储器组件中的相应物理位置,其中每一管理片段对应于具有特定存取大小的经聚合的多个逻辑存取单元。在一些实施例中,存取单元包括第一数量的数据。处理装置可类似于本
文中结合图1和图2描述的媒体管理组件113,或包含所述媒体管理组件113的一部分。存取单元可类似于本文中结合图3描述的存取单元330。在一些实施例中,存取单元可包括具有与其相关联的数量的数据的码字,所述数量对应于处理装置的高速缓存行大小(例如,对应于存储器组件的输入/输出(i/o)传送大小并且与主机的传送大小对准)。举例来说,第一数量的数据可为64字节、128字节等。
50.在框443处,处理装置使用管理片段执行存储器管理操作,其中每一管理片段对应于具有特定存取大小的经聚合的多个逻辑存取单元。存储器管理操作可包含耗损均衡操作、干扰管理操作(例如,被动干扰管理操作)等。在一些实施例中,存储器管理操作的执行可包含同时执行耗损均衡操作和干扰管理操作。
51.在框445处,处理装置跟踪对应于每一管理片段的存取请求。可借助于存取计数器(例如,本文中在图1和图2中所说明的存取计数器121)执行所述跟踪。举例来说,存取计数器可响应于存储器管理操作的执行而递增直到达到阈值计数值。在一些实施例中,可提供多个存取计数器。举例来说,可为每一管理片段提供存取计数器。在一些实施例中,作为根据本公开的一些实施例改进写入放大的部分,存取计数计数器可响应于存储器操作的执行而递增。
52.在一些实施例中,处理装置可监测存取计数计数器以确定已使用管理片段执行了多少个存储器操作和/或已对存储器组件的特定部分(例如,特定页)执行了多少个存储器操作。一旦存取计数计数器已递增到阈值,处理装置可致使使用管理片段对存储器组件的不同部分执行后续存储器操作。另外(或在替代方案中),一旦存取计数计数器已递增到阈值,处理装置便可致使使用不同管理片段执行后续存储器操作,所述不同管理片段可使用相同存取单元或不同存取单元形成。
53.在框447处,处理装置至少部分地基于跟踪,确定是否对相应管理片段执行特定存储器管理操作。举例来说,如果存取计数器已递增到阈值,那么处理装置可确定不执行特定存储器操作。相比之下,如果处理装置确定存取计数器尚未递增到阈值,那么处理装置可确定可使用管理片段执行另一存储器管理操作。
54.在一些实施例中,处理装置将存取单元传送到存储器组件的多个通道。在一些实施例中,存储器组件可类似于本文中结合图1论述的存储器组件112a到112n。如本文中结合图3所描述,存取单元可传送到存储器组件的多个通道。举例来说,存取单元可传送到存储器组件的c通道。在一些实施例中,将存取单元传送到存储器组件的多个通道可包含对存储器组件执行被动干扰管理操作。举例来说,与一些先前方法相比,通过传送大小与处理装置的高速缓存行相当的存取单元,可同时写入到存储器组件的较少部分,这继而可引起存储器组件经历的写入干扰效应减少。
55.处理装置可进一步从存取单元产生管理片段。管理片段可包含阈值数量的存取单元。举例来说,管理片段可为聚合数量的存取单元。存取单元可类似于本文中结合图3描述的管理片段332。在一些实施例中,产生管理片段可包含将一定数量的存取单元组合成管理片段。因此,管理片段可具有与其相关联的数量的数据,所述数量大于与存取单元相关联的数据数量。举例来说,管理片段可包含存储器组件的大约页大小(例如,大约4kb)的数据。
56.处理装置可将管理片段存储于存储器组件的页中。如本文中结合图3所描述,管理片段可存储于存储器组件的多个页中和/或多个分区上。如上文所描述,管理片段可包含元
数据片段(例如,本文中在图3中所说明的元数据片段333),其可包含存取计数计数器和/或管理元数据。
57.在一些实施例中,处理装置可对管理片段执行存储器管理操作。存储器管理操作可为如上文所描述的耗损均衡操作。举例来说,处理装置可致使对管理片段执行耗损均衡操作。可执行耗损均衡操作以确保存储器组件的特定部分不被过度使用且因此不会比存储器组件的其它部分更快速劣化。
58.在一些实施例中,处理装置可致使产生存取单元,其各自包括具有第一数量的数据的码字。在一些实施例中,所述第一数量的数据可对应于处理装置的高速缓存行大小(例如,64字节、128字节等)。在一些实施例中,处理装置可执行指令以致使基于存储于存储器组件的逻辑到物理映射表中的数据产生存取单元。
59.处理装置可进一步致使跨存储器组件的c通道存储存取单元。举例来说,如上文结合图3所描述,处理装置可执行指令以致使存取单元跨存储器组件的多个通道分布。在一些实施例中,通过跨存储器组件的多个通道分布存取单元,可对存储器组件执行被动干扰管理操作。举例来说,与一些先前方法相比,通过以此方式存储存取单元,可写入到存储器组件的较少存储器位置,这可引起写入干扰效应减少。
60.处理装置可进一步致使产生具有第二数量的数据的管理片段。所述第二数量的数据可大于所述第一数量的数据。在一些实施例中,管理片段包含阈值数量的存取单元。举例来说,如果管理片段的大小是大约4kb且存取单元各自包含64字节,那么管理单元可包含六十四个64字节存取单元。
61.在一些实施例中,处理装置可进一步致使元数据码字包含在管理片段中。所述元数据码字可包含对应于将存取单元和管理片段存储于存储器组件中的频率的信息。举例来说,元数据码字可包含允许做出关于将存取单元和/或管理片段存储于存储器组件中的频率的确定的信息。此信息可用作执行耗损均衡操作以与一些先前方法相比改进存储器组件的写入放大的部分。
62.处理装置可进一步致使管理片段存储于存储器组件的特定页中。举例来说,如上文结合图3所描述,管理片段可存储于存储器组件的一或多个页和/或分区中。在其中管理片段的大小对应于存储器组件的页大小的实施例中,管理片段可存储于存储器组件的单个页中。然而,实施例不限于此,且取决于存储器装置的页大小和/或管理片段的大小,可跨存储器组件的多个页和/或分区存储管理片段。
63.处理装置可进一步致使对存储器组件的上面存储有管理片段的特定页执行耗损均衡操作。如上文所描述,可执行耗损均衡操作以确保存储器组件的特定部分不被过度使用且因此不会比存储器组件的其它部分更快速劣化。
64.处理装置可进一步致使对存储器组件的上面存储有管理片段的特定页执行耗损均衡操作。如上文所描述,可执行耗损均衡操作以确保存储器组件的特定部分不被过度使用且因此不会比存储器组件的其它部分更快速劣化。
65.在一些实施例中,处理装置可进一步致使元数据码字包含在管理片段中。元数据码字可包含对应于与管理片段相关联的存取计数量的信息。如上文所描述,存取计数计数器可响应于与管理片段相关联的存取计数量而递增。举例来说,存取计数计数器可响应于使用管理片段执行存储器操作和/或在存储器组件的上面存储有管理片段的位置处执行存
储器操作而递增。在一些实施例中,存取计数器可在不考虑存取管理片段内的哪个存取单元的情况下递增。这可允许准确跟踪存取单元被存取的次数,进而与无法跟踪对存取单元的每次存取的方法相比改进对管理特性的处置。
66.处理装置可进一步致使做出已达到与管理片段相关联的存取计数的数量的确定,致使管理片段存储于存储器组件的不同页上,和/或致使对管理片段传送到的存储器组件的不同页执行后续耗损均衡操作。举例来说,一旦存取计数计数器已递增到阈值,处理装置便可致使使用管理片段对存储器组件的不同部分执行后续存储器操作。另外,一旦存取计数计数器已递增到阈值,处理装置便可致使使用不同管理片段执行后续存储器操作。
67.图5说明计算机系统500的实例机器,可执行所述计算机系统500内的用于致使所述机器执行本文中所论述的方法中的任一种或多种方法的指令集。在一些实施例中,计算机系统500可对应于包含、耦合到或使用存储器子系统(例如,图1的存储器子系统110)或可用以执行控制器的操作(例如,以执行操作系统来执行对应于图1的媒体管理组件113的操作)的主机系统(例如,图1的主机系统120)。在替代性实施例中,机器可连接(例如联网)到lan、内联网、外联网和/或因特网中的其它机器。机器可作为对等(或分布式)网络环境中的对等机器或作为云计算基础设施或环境中的服务器或客户端机器而以客户端-服务器网络环境中的服务器或客户端机器的容量进行操作。
68.机器可以是个人计算机(pc)、平板pc、机顶盒(stb)、个人数字助理(pda)、蜂巢式电话、网络器具、服务器、网络路由器、交换机或桥接器,或能够(依序或以其它方式)执行指定将由所述机器采取的动作的指令集的任何机器。另外,尽管说明单个机器,但还应认为术语“机器”包含机器的任何集合,所述集合单独地或共同地执行一(或多)个指令集以进行本文中所论述的方法中的任何一或多种。
69.实例计算机系统500包含处理装置502、主存储器504(例如,只读存储器(rom)、闪存存储器、动态随机存取存储器(dram)例如同步dram(sdram)或rambus dram(rdram)等)、静态存储器506(例如,闪存存储器、静态随机存取存储器(sram)等),以及数据存储系统518,其经由总线530彼此通信。
70.处理装置502表示一或多个通用处理装置,例如微处理器、中央处理单元等。更特定来说,处理装置可以是复杂指令集计算(cisc)微处理器、精简指令集计算(risc)微处理器、超长指令字(vliw)微处理器或实施其它指令集的处理器,或实施指令集的组合的处理器。处理装置502也可以是一或多个专用处理装置,例如专用集成电路(asic)、现场可编程门阵列(fpga)、数字信号处理器(dsp)、网络处理器等。处理装置502被配置成执行指令526以用于执行本文中所论述的操作和步骤。计算机系统500可另外包含网络接口装置508以在网络520上通信。
71.数据存储系统518可包含机器可读存储媒体524(也称为计算机可读媒体),其上存储有一或多个指令集526或体现本文中所描述的方法或功能中的任一或多种的软件。指令526还可在由计算机系统500执行期间完全或至少部分地驻存在主存储器504内和/或处理装置502内,主存储器504和处理装置502也构成机器可读存储媒体。机器可读存储媒体524、数据存储系统518和/或主存储器504可对应于图1的存储器子系统110。
72.在一个实施例中,指令526包含实施对应于电力管理组件(例如,图1的媒体管理组件113)的功能性的指令。尽管在实例实施例中将机器可读存储媒体524展示为单个媒体,但
应认为术语“机器可读存储媒体”包含存储一或多个指令集的单个媒体或多个媒体。术语“机器可读存储媒体”还应被认为包含能够存储或编码供机器执行的指令集合且致使机器执行本公开的方法中的任何一种或多种的任何媒体。术语“机器可读存储媒体”因此应被视为包含但不限于固态存储器、光学媒体和磁性媒体。
73.已在针对计算机存储器内的数据位的操作的算法和符号表示方面呈现了先前详细描述的一些部分。这些算法描述和表示是数据处理领域的技术人员用以将其工作的主旨最有效地传达给所属领域的其他技术人员的方式。在本文中,且一般将算法构想为产生所要结果的操作的自洽序列。操作是要求对物理量进行物理操纵的操作。通常(但未必),这些量采用能够存储、组合、比较以及以其它方式操纵的电或磁信号的形式。已经证实,主要出于常用的原因,将这些信号称为位、值、元素、符号、字符、项、编号等等有时是便利的。
74.然而,应牢记,所有这些和类似术语将与适当物理量相关联,且仅仅为应用于这些量的便利标记。本公开可以指操控和变换计算机系统的寄存器和存储器内的表示为物理(电子)数量的数据为计算机系统存储器或寄存器或其它这类信息存储系统内的类似地表示为物理量的其它数据的计算机系统或类似电子计算装置的动作和过程。
75.本公开还涉及用于执行本文中的操作的设备。这一设备可以出于所需目的而专门构造,或其可包含通过存储在计算机中的计算机程序选择性地激活或重新配置的通用计算机。这种计算机程序可存储在计算机可读存储媒体中,例如但不限于任何类型的盘,包含软盘、光盘、cd-rom以及磁性光盘、只读存储器(rom)、随机存取存储器(ram)、eprom、eeprom、磁卡或光卡,或适合于存储电子指令的任何类型的媒体,其各自连接到计算机系统总线。
76.本文中呈现的算法和显示器在本质上并不与任何特定计算机或其它设备相关。各种通用系统可以与根据本文中的教示的程序一起使用,或可以证明构造用以执行所述方法更加专用的设备是方便的。将如下文描述中所阐述的那样来呈现各种这些系统的结构。另外,未参考任何特定编程语言来描述本公开。应了解,可使用各种编程语言来实施如本文中所描述的本公开的教示内容。
77.本公开可提供为计算机程序产品或软件,其可包含在其上存储有可用于编程计算机系统(或其它电子装置)以进行根据本公开的过程的指令的机器可读媒体。机器可读媒体包含用于以机器(例如,计算机)可读的形式存储信息的任何机构。在一些实施例中,机器可读(例如计算机可读)媒体包含机器(例如计算机)可读存储媒体,例如只读存储器(“rom”)、随机存取存储器(“ram”)、磁盘存储媒体、光学存储媒体、闪存存储器组件等。
78.在前述说明书中,本公开的实施例已经参照其特定实例实施例进行描述。将显而易见的是,可在不脱离如所附权利要求书中阐述的本公开的实施例的更广精神和范围的情况下对本公开进行各种修改。因此,应在说明性意义上而非限制性意义上看待说明书及图式。
技术特征:
1.一种系统,其包括:第一存储器组件,其具有与存储器操作的执行相关联的特定存取大小;第二存储器组件,其存储逻辑到物理数据结构,所述物理数据结构的管理条目将管理片段映射到所述存储器组件中的相应物理位置,其中每一管理片段对应于具有所述特定存取大小的经聚合的多个逻辑存取单元,且其中所述管理条目包括管理片段地址或存取计数或两者中的至少一个;处理装置,其耦合到所述第一存储器组件和所述第二存储器组件,所述处理装置:通过以下操作在每管理片段基础上执行存储器管理操作:对于每一相应管理片段,跟踪对与所述相应管理片段对应的组员存取单元的存取请求;和基于所述跟踪确定是否对所述相应管理片段执行特定存储器管理操作。2.根据权利要求1所述的系统,其中与相应存取单元相关联的数据数量小于与所述相应管理片段相关联的数据数量。3.根据权利要求1所述的系统,其中所述处理装置被配置成作为执行所述存储器管理操作的部分,对所述管理片段执行耗损均衡操作。4.根据权利要求1所述的系统,其中所述存取单元的每一者包括码字,所述码字具有对应于所述处理装置的高速缓存行大小的大小。5.根据权利要求1所述的系统,其中所述管理片段包括存取计数器,且其中所述存取计数器可响应于每一存储器管理操作的执行而递增。6.根据权利要求1所述的系统,其中所述处理装置被配置成致使跨所述第一存储器组件或所述第二存储器组件或两者的第一部分的c通道写入所述存取单元。7.根据权利要求1所述的系统,其中所述第一存储器组件或所述第二存储器组件或两者包括多个存储器组件,且其中至少一个存储器组件包括易失性存储器组件且至少一个存储器组件包括三维交叉点存储器组件。8.一种系统,其包括:存储器组件,其具有与存储器操作相关联的特定存取大小;逻辑到物理数据结构,其条目将管理片段映射到所述存储器组件中的相应物理位置,其中每一管理片段对应于具有所述特定存取大小的经聚合的多个逻辑存取单元;以及处理装置,其被配置成响应于接收到的对具有所述特定存取大小的特定存取单元执行存储器操作的请求:确定与所述特定存取单元对应的管理条目,其中所述管理条目包括管理片段地址或时间戳或两者中的至少一个;更新所述管理条目的属性数据;和基于所述经更新属性数据,确定是否对与所述管理条目对应的所述管理片段执行媒体管理操作。9.根据权利要求8所述的系统,其中所述特定存取大小是所述存储器组件的输入/输出i/o传送大小并且与主机的传送大小对准。10.根据权利要求8所述的系统,其中所述存储器组件包括第一存储器部分和第二存储器部分,所述第一存储器部分包括易失性存储器,所述第二存储器部分包括具有就地写入
能力的非易失性存储器。11.根据权利要求8所述的系统,其中所述存储器组件包括第一存储器部分和第二存储器部分,所述第一存储器部分包括易失性存储器,所述第二存储器部分包括响应于存储器操作的执行受到耗损的非易失性存储器。12.根据权利要求8所述的系统,其中所述媒体管理操作包括耗损均衡操作。13.根据权利要求8所述的系统,其中所述媒体管理操作包括干扰管理操作。14.根据权利要求8所述的系统,其中所述处理装置被进一步配置成响应于所述存储器操作的执行而使存取计数器递增。15.一种方法,其包括:使用将管理片段映射到存储器组件的相应物理位置的管理条目执行存储器管理操作,其中每一管理片段对应于具有特定存取大小的经聚合的多个逻辑存取单元,且其中所述管理条目包括时间戳或存取计数或两者中的至少一个;跟踪对应于每一管理片段的存取请求;以及至少部分地基于所述跟踪,确定是否对相应管理片段执行特定存储器管理操作。16.根据权利要求15所述的方法,其中执行所述存储器管理操作包括执行耗损均衡操作。17.根据权利要求15所述的方法,其中执行所述存储器管理操作包括执行被动干扰管理操作。18.根据权利要求15所述的方法,其中所述跟踪包括响应于每一存储器管理操作的执行而使存取计数器递增。19.根据权利要求18所述的方法,其另外包括:确定所述存取计数器已递增到阈值;和响应于所述确定,使用所述存储器组件的不同页对不同管理片段执行后续存储器管理操作。20.根据权利要求15所述的方法,其中所述存储器组件包括第一存储器部分和第二存储器部分,所述第一存储器部分包括易失性存储器,所述第二存储器部分包括响应于存储器操作的执行受到耗损的非易失性存储器。
技术总结
本发明涉及存取单元和管理片段存储器操作。本发明提供一种系统,其包含第一存储器组件,其具有与执行存储器操作相关联的特定存取大小;第二存储器组件,其存储逻辑到物理数据结构,所述数据结构的条目将管理片段映射到所述存储器组件中的相应物理位置,其中每一管理片段对应于具有所述特定存取大小的经聚合的多个逻辑存取单元;和处理装置,其可操作地耦合到所述存储器组件。所述处理装置可通过以下操作在每管理片段基础上执行存储器管理操作:对于每一相应管理片段,跟踪对与所述相应管理片段对应的组员存取单元的存取请求;和基于所述跟踪确定是否对所述相应管理片段执行特定存储器管理操作。存储器管理操作。存储器管理操作。
技术研发人员:E
受保护的技术使用者:美光科技公司
技术研发日:2019.10.01
技术公布日:2022/5/25
转载请注明原文地址:https://tc.8miu.com/read-5384.html