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

一种设置于固态硬盘主控芯片内的坏块扫描电路

2022-09-14 20:27:52 来源:中国专利 TAG:


1.本实用新型涉及固态硬盘技术领域,尤其涉及一种设置于固态硬盘主控芯片内的坏块扫描电路。


背景技术:

2.在ssd固态硬盘的生产中,现有技术都有专门的坏块扫描的步骤,要么是一个单独的扫描出厂坏块的步骤,要么是作为“开卡”工序的一个子步骤,待扫出坏块后,再写入进ssd内部的存储空间。
3.这些步骤需要消耗相应的生产时间或测试时间,相应地也降低了ssd固态硬盘的生产效率/测试效率。


技术实现要素:

4.本实用新型的目的在于提供一种设置于固态硬盘主控芯片内的坏块扫描电路,以提高生产效率。
5.为解决上述技术问题,本实用新型采用如下技术方案:
6.本实用新型实施例的第一方面提供了一种设置于固态硬盘主控芯片内的坏块扫描电路,所述固态硬盘内包括闪存模块和主控芯片,所述主控芯片包括扫描电路和cpu,所述闪存模块包括多个出厂块,所述出厂块中含有出厂坏块,所述扫描电路包括:接口模块,所述接口模块与所述闪存模块连接,以用于读取所述闪存模块中的出厂块;nhost模块,所述nhost模块分别连接所述接口模块和所述cpu,以用于从所述接口模块读取的出厂块中识别出厂坏块,并将所述出厂坏块信息传送至cpu;用于控制所述扫描电路工作流程的msm模块,所述cpu与所述msm模块连接,所述msm模块分别连接所述nhost模块和所述接口模块。
7.在一些实施例中,所述扫描电路还包括用于与cpu通信的uartc模块和串口总线,所述cpu通过所述串口总线与所述uartc模块连接,所述uartc模块分别连接所述nhost模块和所述msm模块。
8.在一些实施例中,所述扫描电路还包括用于缓存数据的ram模块,所述ram模块设置于所述nhost模块和所述uartc模块之间。
9.在一些实施例中,所述主控芯片还包括用于与所述接口模块切换使用的nandc模块,所述nandc模块分别连接所述闪存模块和所述串口总线。
10.在一些实施例中,所述扫描电路还包括用于切换所述接口模块和所述nandc模块的mux模块,所述mux模块分别连接所述接口模块、所述nandc模块和所述闪存模块。
11.在一些实施例中,所述msm模块连接控制所述mux模块。
12.在一些实施例中,所述接口模块包括多个phy接口。
13.在一些实施例中,所述扫描电路还包括用于与cpu通信的spic模块和spi总线,所述cpu通过所述spi总线与所述spic模块连接,所述spic模块分别连接所述nhost模块和所述msm模块。
14.根据本实用新型实施例的一种设置于固态硬盘主控芯片内的坏块扫描电路,至少具有如下有益效果:在ssd固态硬盘首次装机使用时,首次上电后,ssd固态硬盘内部即自动进行出厂坏块的扫描,并将出厂坏块写入ssd固态硬盘内部的保留区。这一扫描用时只需几秒至十几秒,对于用户体验没有影响。这样,在ssd固态硬盘的开卡量产步骤中,就可以省掉扫描出厂坏块的步骤,提高ssd固态硬盘的生产效率,节省宝贵的产线占用的时间。
15.应当理解的是,以上的一般描述和后文的细节描述仅是示例性的,并不能限制本公开。
附图说明
16.为了更清楚地说明本实用新型实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本实用新型的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
17.图1为根据实施例的扫描电路连接结构示意图;
18.图2为根据实施例的扫描方法流程图。
19.附图标记说明如下:1、固态硬盘;2、闪存模块;3、主控芯片;4、扫描电路;5、cpu;6、接口模块;7、nhost模块;8、msm模块;9、uartc模块;10、串口总线;11、ram模块;12、nandc模块;13、mux模块。
具体实施方式
20.下面将结合本实用新型实施例中的附图,对本实用新型实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本实用新型一部分实施例,而不是全部的实施例。基于本实用新型中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本实用新型保护的范围。
21.在本实用新型的描述中,需要理解的是,术语“中心”、“上”、“下”、“前”、“后”、“左”、“右”、“竖直”、“水平”、“顶”、“底”、“内”、“外”等指示的方位或位置关系为基于附图所示的方位或位置关系,仅是为了便于描述本实用新型和简化描述,而不是指示或暗示所指的装置或元件必须具有特定的方位、以特定的方位构造和操作,因此不能理解为对本实用新型的限制。
22.术语“第一”、“第二”、“第三”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”、“第三”的特征可以明示或者隐含地包括一个或者更多个该特征。
23.在本实用新型的描述中,除非另有说明,“多个”的含义是两个或两个以上。
24.在本实用新型的描述中,需要说明的是,除非另有明确的规定和限定,术语“连通”、“安装”、“相连”、“连接”应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或一体地连接;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通。对于本领域的普通技术人员而言,可以具体情况理解上述术语在本实用新型中的具体含义。
25.现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形
式实施,且不应被理解为限于在此阐述的范例;相反,提供这些示例实施方式使得本公开的描述将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。附图仅为本公开的示意性图解,并非一定是按比例绘制。图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。
26.以下结合本说明书的附图1至图2,对本公开的较佳实施方式予以进一步地详尽阐述。
27.请参阅图1。
28.根据一些实施例,本技术提供一种固态硬盘主控芯片坏块的扫描电路,所述固态硬盘1内包括闪存模块2和主控芯片3,所述主控芯片3包括扫描电路4和cpu5,所述闪存模块2包括多个出厂块,所述出厂块中含有出厂坏块,所述扫描电路4包括:接口模块6,所述接口模块6与所述闪存模块2连接,以用于读取所述闪存模块2中的出厂块;nhost模块7,所述nhost模块7分别连接所述接口模块6和所述cpu5,以用于从所述接口模块6读取的出厂块中识别出厂坏块,并将所述出厂坏块信息传送至cpu5;用于控制所述扫描电路4工作流程的msm模块8,所述cpu5与所述msm模块8连接,所述msm模块8分别连接所述nhost模块7和所述接口模块6。
29.基于上述实施例,固态硬盘1是传统机械式硬盘的替代品。一个典型的固态硬盘1,其内部电路包括主控芯片3、ddr内存颗粒、闪存模块2、spi flash颗粒等。
30.闪存模块2包括多个nand flash闪存阵列,nand flash闪存阵列是固态硬盘1内部用于承载存储数据的主体;nand flash中的数据在系统掉电后不会丢失,重新上电后,其中的数据仍在,拥有这一特性的存储器,业内将之称作“非易失存储器”。
31.一颗典型的nand flash存储器芯片,其内部的存储空间是按照下列方式来进行组织的:
32.1颗nand flash存储器封装体内,包含1个或多个lun;
33.1个lun内,包含1个或多个plane;
34.1个plane内,包含多个block;
35.1个block内,包含有许多page;
36.1个page内,包含有多个byte。
37.其中,block即“块”,page即“页”,byte即“字节”。
38.nand flash的常用操作有3种:读、写(即编程)、擦(即擦除)。一般而言,读、写操作都以page即页为单位,而擦除操作则以block即块为单位。
39.nand flash内部总是会有少量的一些块,在出厂时,这些块内带有固有的、无法修复的缺陷、错误,无法正常进行读/写/擦操作。这些块被称作“出厂坏块”,即factory bad block,用户不能使用这些块进行数据的存储。
40.每颗nand flash的出厂坏块地址都是随机的,在典型的情况下,每1000个block中,可能有十个以内的出厂坏块。
41.固态硬盘1之所以能够存储大量用户数据,靠的就是电路板上的nand flash存储器颗粒阵列。因此,固态硬盘1的一个重要功能,就是坏块处理。
42.在现有的固态硬盘1的生产中,现有技术都有专门的坏块扫描的步骤,要么是一个单独的扫描出厂坏块的步骤,要么是作为“开卡”工序的一个子步骤,待扫出坏块后,再写入
进固态硬盘1内部的存储空间。
43.这些步骤需要消耗相应的生产时间或测试时间,相应地,这降低了固态硬盘1的生产效率/测试效率。
44.因此本技术提供了一种固态硬盘1主控芯片3坏块的扫描电路4,如图1所示,其包括主控芯片3,主控芯片3设置于固态硬盘1内,主控芯片3内包括扫描电路4和cpu5,扫描电路4包括:接口模块6,接口模块6包括多个phy接口,闪存模块2中包括多个nand flash闪存阵列,phy接口与nand flash闪存阵列可以是1对1的关系,也可以是1对多的关系,接口模块6与闪存模块2连接,以用于读取闪存模块2中的出厂块。其中,接口模块6为:nand flash模块的物理层(即phy层)控制逻辑,用于实现nand芯片手册中所要求的command cycle、address cycle、data input cycle、data output cycle这四种基本cycle。
45.进一步的,nhost模块7分别连接接口模块6和cpu5,以用于从接口模块6读取的出厂块中识别出厂坏块,并将出厂坏块信息传送至cpu5,cpu5将出厂坏块信息存储至非易失存储器内。其中,nhost模块7为:闪存模块2的主控端,它对接口模块6进行调度,用四种基本cycle,拼接出读、写、擦、读id、读unique id、读status等各种操作流程。例如,一个典型的页读(page read)操作,由command cycle、address cycle、data output cycle拼接而成。
46.进一步的,cpu5与msm模块8连接,msm模块8分别连接所述nhost模块7和所述接口模块6,所述cpu5对所述出厂块进行读写擦操作时,当遇到与非易失存储器内坏块信息一致的出厂坏块时,则不进行读写擦操作。
47.进一步的,在长期使用固态硬盘1后会出现新增坏块,当识别到新增坏块后,cpu5将新增坏块存储至非易失存储器内。防止下次再次访问到新增坏块。
48.通过将扫描电路4设置于固态硬盘1主控芯片3内后,在固态硬盘1首次装机使用时,首次上电后,固态硬盘1内部即自动进行出厂坏块的扫描,并将出厂坏块写入固态硬盘1内部的保留区。这一扫描用时只需几秒至十几秒,对于用户体验没有影响。这样,在固态硬盘1的开卡量产步骤中,就可以省掉扫描出厂坏块的步骤,提高固态硬盘1的生产效率,节省宝贵的产线占用的时间。
49.根据一些实施例,所述扫描电路4还包括用于与cpu5通信的uartc模块9和串口总线10,所述cpu5通过所述串口总线10与所述uartc模块9连接,所述uartc模块9分别连接所述nhost模块7和所述msm模块8。其中,uartc模块9为串口通信,通过soc内部的总线,与cpu5通信。
50.基于上述实施例,使用uartc模块9,可以挂接至cpu5的串口总线10;串口是一种常用的简单的总线。除了串口之外,还可以使用spi总线、iic总线、apb总线、ahb总线、axi总线等,相应地,uartc模块9需要替换为名为spic、iicc、apbc、ahbc、axic等的模块。
51.根据一些实施例,所述扫描电路4还包括用于缓存数据的ram模块11,所述ram模块11设置于所述nhost模块7和所述uartc模块9之间,ram模块11接收nhost模块7的信息后,暂时缓存数据,再通过uartc模块9发送至cpu5。
52.根据一些实施例,所述主控芯片3还包括用于与所述接口模块6切换使用的nandc模块12,所述nandc模块12分别连接所述闪存模块2和所述串口总线10。
53.根据一些实施例,所述扫描电路4还包括用于切换所述接口模块6和所述nandc模块12的mux模块13,所述mux模块13分别连接所述接口模块6、所述nandc模块12和所述闪存
模块2,所述msm模块8连接控制所述mux模块13。
54.基于上述实施例,在用户的正常使用期间,做新增坏块扫描时,由nandc模块12对闪存模块2进行控制,但接口模块6对nandc模块12与闪存模块2之间的接口信号进行监测。对闪存模块2的访问控制接口,由mux模块13来进行切换控制,mux模块13受msm模块8的控制。
55.请参阅图2。
56.为了使本领域技术人员更清晰的理解本技术,本技术提供一种扫描方法,用于固态硬盘1坏块的扫描方法,所述方法应用于如上所述的固态硬盘1主控芯片3坏块的扫描电路4,所述出厂坏块包括第一类出厂坏块和第二类出厂坏块,所述扫描方法包括:步骤101,所述接口模块6读取所述闪存模块2中的出厂块,并识别出第二类出厂坏块;步骤102,所述nhost模块7从所述出厂块中识别出所述第一类出厂坏块,并将所述第一类出厂坏块和第二类出厂坏块的信息传送至所述cpu5;步骤103,所述cpu5将所述第一类出厂坏块和第二类出厂坏块的信息录入存储器;步骤104,所述cpu5在对所述出厂块进行读写擦操作时,避开与所述存储器中信息一致的坏块。
57.根据一些实施例,在步骤101,所述接口模块6读取所述闪存模块2中的出厂块,并识别出第二类出厂坏块之前,所述方法还包括:所述固态硬盘1装机并首次上电开机后,所述固态硬盘1自动进行如上所述的扫描方法进行固态硬盘1坏块的扫描。
58.根据一些实施例,在所述固态硬盘1装机并首次上电开机后,所述固态硬盘1自动进行如上所述的扫描方法进行固态硬盘1坏块的扫描之前,所述方法还包括:分别对所述第一类出厂坏块和所述第二类出厂坏块做不同的坏块标记,以便于所述nhost模块7和所述接口模块6识别所述第一类出厂坏块和所述第二类出厂坏块。
59.基于上述实施例,闪存模块2包括多个nand flash阵列,一颗典型的nand flash存储器芯片,其内部的存储空间是按照下列方式来进行组织的:
60.1颗nand flash存储器封装体内,包含1个或多个lun;
61.1个lun内,包含1个或多个plane;
62.1个plane内,包含多个block;
63.1个block内,包含有许多page;
64.1个page内,包含有多个byte。
65.其中,block即“块”,page即“页”,byte即“字节”。
66.nand flash的常用操作有3种:读、写(即编程)、擦(即擦除)。一般而言,读、写操作都以page即页为单位,而擦除操作则以block即块为单位。nand flash内部总是会有少量的一些块,在出厂时,这些块内带有固有的、无法修复的缺陷、错误,无法正常进行读/写/擦操作。这些块被称作“出厂坏块”,即factory bad block,用户不能使用这些块进行数据的存储。
67.每颗nand flash的出厂坏块地址都是随机的,在典型的情况下,每1000个block中,可能有十个以内的出厂坏块。
68.为方便查询,常用的标记方法有两种:
69.第一类出厂坏块:
70.在spare area的第六个byte,写入特殊字符,作为坏块标记。用户希望查询出厂坏
块时,需要依次读取每个物理块的第六个byte,看是否标记为出厂坏块,就可以判定。
71.如果采用这种方法,则出厂坏块的标记其实是可以被用户擦掉的;如果进行过全片擦除,则所有出厂坏块的标记会全部丢失。
72.生产过程中,是在严苛的环境条件下对芯片进行测试、以对出厂坏块进行识别确认;其所标记的“出厂坏块”,其实很多是处在“好”和“坏”之间的临界状态,如果芯片工作于较为舒适的环境条件下,很可能表现为好块。交付用户后,用户很难复现如此严苛的环境,因此,用户将出厂坏块标记擦除后,若对“出厂坏块”作读写擦访问,则这些地址很可能表现为正常的好块。
73.因而,对于这种闪存颗粒,用户在拿到nand flash颗粒后,必须先读取出厂坏块、将之另行保存,再进行其他的读写擦操作;否则,一旦将出厂坏块标志擦除,就再无手段获取出厂坏块信息了。
74.第二类出厂坏块:
75.以非易失的方式,对各block进行标记,用户以特定的指令序列,对全片各block逐一进行指令操作,并读取相应的status标志,即可知道各block是不是出厂坏块,进而构建一个出厂坏块列表录入存储器。
76.如果采用这种方法,一般而言,坏块标志无法被用户擦掉,即便进行全片擦除,出厂坏块的标志也不会丢失。对于这种nand flash颗粒,即便没有事先读出厂坏块,也可以在稍后的时间,再重新读取出厂坏块信息。
77.扫描出厂坏块:
78.在固态硬盘1交付用户并装机完成后,首次上电开机后,此时全盘为空白状态,此时进行出厂坏块的扫描。
79.对于第一类出厂坏块,由接口模块6读取全片各block中的坏块标志符所在的地址,由nhost模块7判断是不是出厂坏块,如果是,则将坏块的地址写入ram模块11缓存,之后通过uartc模块9回传给cpu5。
80.对于第二类出厂坏块,由接口模块6直接循环读取全片的各block状态,即可知道是不是出厂坏块,将坏块信息(即坏块的地址)写入ram模块,之后由uartc模块9将其回传给cpu5。
81.第一类出厂坏块和第二类出厂坏块一般不会同时出现在同一块nand flash芯片中。一般而言,nand flash芯片中,要么使用第一类出厂坏块的标记方法检测,要么使用第二类出厂坏块的标记方法检测。为了检测的更全面,本技术检测时,将第一类出厂坏块和第二类出厂坏块一起检测,如果没有第一类出厂坏块就跳过检测第一类出厂坏块的步骤,如果没有第二类出厂坏块就跳过检测第二类出厂坏块的步骤。
82.根据一些实施例,在所述cpu5对所述出厂块进行读写擦操作时,避开与所述存储器中信息一致的坏块之后,所述方法还包括:在对所述闪存模块2进行读写擦操作时,如果编写或擦除操作失败,则判定为新增坏块,并将所述新增坏块信息传送至所述cpu5;所述cpu5将所述新增坏块信息录入存储器,防止再次访问所述新增坏块。
83.基于上述实施例,闪存模块2的寿命不是无限的,其有自己的使用寿命,寿命有两种:1,endurance,即各个block可以经受住多少次program/erase cycle,即p/e寿命;2,retention,即存入flash的数据可以留存保持多少年。
84.在固态硬盘1使用过程中,随着读写擦操作次数的增加,各block会逐渐接近其p/e寿命的上限。在此过程中,某些block可能会产生较严重的退化,进而,导致无法编程(program写失败)、无法擦除(erase失败)、或者读取出错(读数据的错误率较高,超出ecc纠错能力范围)。当遇到这一情况时,相应的块也称之为“坏块”即bad block。为与芯片出厂时自带的“出厂坏块”相区分,这些在使用过程中出现的坏块,称为“新增坏块”或“使用坏块”。
85.一般而言,需要控制在闪存模块2的使用寿命范围内,新增坏块的数量不超过芯片总容量的一个比例,例如,最多不超过2%;在此前提下,配合以适当的坏块管理算法,闪存模块2仍可正常使用。
86.固态硬盘1之所以能够存储大量用户数据,靠的就是电路板上的nand flash存储器颗粒阵列。因此,固态硬盘1的一个重要功能,就是坏块处理,包括:
87.扫描闪存模块2、获得其出厂坏块列表,并录入存储器。
88.在固态硬盘1的使用过程中,建立、维护、更新一个新增坏块列表,并录入存储器。
89.在实际的固态硬盘1设计方案中,“出厂坏块列表”和“新增坏块列表”,可能合并为同一个,也可能分别维护和管理。
90.在正常对闪存模块2进行访问期间,接口模块6对闪存模块2接口进行实时监测,如果发现编程或擦除操作返回的status为fail,则判定为新增坏块,此时则将其block地址写入ram模块,稍后由uartc回传给cpu5。
91.根据一些实施例,在所述在对所述闪存模块2进行读写擦操作时,如果编写或擦除操作失败,则判定为新增坏块,并将所述新增坏块信息传送至所述cpu5中,所述方法还包括:在对所述闪存模块2进行读写擦操作时,所述cpu5通过所述nandc来访问闪存,并通过所述nandc进行所述新增坏块的扫描。
92.基于上述实施例,另一种电路形式如下,闪存模块2由主控芯片3内的nandc模块12和接口模块6交替控制:
93.进行正常数据访问(普通读写擦)时,由nandc模块12来访问闪存模块2;
94.做出厂坏块扫描时,由接口模块6来控制闪存模块2;
95.在用户的正常使用期间,做新增坏块扫描时,仍由nandc模块12对闪存模块2进行控制,但由接口模块6对nandc模块12与闪存模块2之间的接口信号进行监测;
96.对闪存模块2的访问控制接口,由mux模块13来进行切换控制,mux模块13受msm模块8的控制。
97.在上述实施方式的描述中,具体特征、结构、材料或者特点可以在任何的一个或多个实施例或示例中以合适的方式结合。
98.虽然已参照几个典型实施方式描述了本公开,但应当理解,所用的术语是说明和示例性、而非限制性的术语。由于本公开能够以多种形式具体实施而不脱离实用新型的精神或实质,所以应当理解,上述实施方式不限于任何前述的细节,而应在随附权利要求所限定的精神和范围内广泛地解释,因此落入权利要求或其等效范围内的全部变化和改型都应为随附权利要求所涵盖。
再多了解一些

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

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

相关文献