CN102541760B - 基于固态硬盘的计算机系统 - Google Patents
基于固态硬盘的计算机系统 Download PDFInfo
- Publication number
- CN102541760B CN102541760B CN201210000778.3A CN201210000778A CN102541760B CN 102541760 B CN102541760 B CN 102541760B CN 201210000778 A CN201210000778 A CN 201210000778A CN 102541760 B CN102541760 B CN 102541760B
- Authority
- CN
- China
- Prior art keywords
- state hard
- solid state
- module
- hard disc
- hard disk
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
- 238000013507 mapping Methods 0.000 claims abstract description 13
- 239000007787 solid Substances 0.000 claims description 59
- 230000003993 interaction Effects 0.000 claims description 8
- 230000005540 biological transmission Effects 0.000 claims description 3
- 238000004891 communication Methods 0.000 claims description 3
- 238000004321 preservation Methods 0.000 claims description 3
- 230000001360 synchronised effect Effects 0.000 claims description 3
- 238000013519 translation Methods 0.000 abstract description 3
- 238000005516 engineering process Methods 0.000 description 4
- 230000007547 defect Effects 0.000 description 3
- 238000000034 method Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 238000012545 processing Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
Landscapes
- Memory System Of A Hierarchy Structure (AREA)
Abstract
本发明提供了一种基于固态硬盘的计算机系统,包括相互连接的主机和固态硬盘,主机包括文件模块以及用于提供第一驱动程序的第一硬盘驱动模块,所述主机还包括用于提供第二驱动程序的第二硬盘驱动模块,第二硬盘驱动模块包括:FTL管理子模块,用于提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表;文件分析子模块,用于分析文件模块,并将文件模块内删除的文件对应的逻辑块地址通知FTL管理子模块,FTL管理子模块回收所述逻辑块地址对应的物理块;缓存子模块,用于建立缓冲区,暂存所述主机与固态硬盘之间交互的数据。借此,本发明的主机端也具有FTL管理功能,可大大提高系统的性能,减少固态硬盘的损耗。
Description
技术领域
本发明涉及计算机技术领域,尤其涉及一种基于固态硬盘的计算机系统。
背景技术
固态态硬盘是使用闪存作为存储介质的一类硬盘,相比较传统硬盘,其有更高速度,更低功耗,更低噪音等优点。由于固态硬盘使用的闪存有擦写次数限制,一旦某一闪存块擦除/写入到达一定次数,就可能造成无法写入新数据,或者数据损坏。为了避免这种情况发生,固态硬盘引入了闪存转换层(FlashTranslation Layer)算法技术,该技术通过将主机的逻辑块地址(LBA)映射为闪存的物理块地址(PBA),对闪存的每个物理块进行管理,做到每个物理块的擦写次数做到静态和动态均衡,延长了闪存的寿命,使得固态硬盘也有传统硬盘的使用寿命。
参见图1,现有的固态硬盘主要由三个模块组成:接口控制器模块,负责收发与主机交互的数据;FTL算法模块,负责管理闪存物理块和逻辑到物理地址映射;闪存控制器模块,负责根据FTL提供的物理地址从闪存读出数据或者写入数据到闪存。且所有控制器驱动程序和FTL算法模块,共用一个高性能嵌入式处理器或者两个嵌入式处理器来处理指令。这样就会存在以下缺陷:所有模块共用一个处理器,增加处理器的负担,降低系统响应速度;使用高性能处理器虽然会提高系统功耗,同时投入成本也相对较高;系统缓存有限,无法缓存更多数据,导致性能会有所损失。
综上可知,现有的固态硬盘系统,在实际使用上显然存在不便与缺陷,所以有必要加以改进。
发明内容
针对上述的缺陷,本发明的目的在于提供一种基于固态硬盘的计算机系统,其具有较高的系统性能,还可以减少固态硬盘的损耗。
为了实现上述目的,本发明提供一种基于固态硬盘的计算机系统,包括相互连接的主机和固态硬盘,所述主机包括文件模块以及用于提供第一驱动程序的第一硬盘驱动模块,其特征在于,所述主机还包括用于提供第二驱动程序的第二硬盘驱动模块,所述第二硬盘驱动模块包括:
FTL管理子模块,用于提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表;
文件分析子模块,用于分析所述文件模块,并将文件模块内删除的文件对应的逻辑块地址通知所述FTL管理子模块,所述FTL管理子模块回收所述逻辑块地址对应的物理块;
缓存子模块,用于建立缓冲区,暂存所述主机与固态硬盘之间交互的数据。
根据本发明的基于固态硬盘的计算机系统,所述固态硬盘包括:
接口模块,用于与所述主机交互数据;
FTL算法模块,用于当主机采用第一驱动程序时提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表;或者,用于当主机采用第二驱动程序时辅助所述FTL管理子模块运算管理;
闪存控制模块,用于将数据写入闪存或者从闪存中读出数据。
根据本发明的基于固态硬盘的计算机系统,当所述主机与所述固态硬盘交互数据时,所述缓存子模块将所述主机的内存作为缓冲区。
根据本发明的基于固态硬盘的计算机系统,所述接口模块与闪存控制模块可直接进行数据交互传输。
根据本发明的基于固态硬盘的计算机系统,所述主机加载第一驱动程序时,所述固态硬盘工作在第一工作模式;所述主机加载第二驱动程序时,所述固态硬盘工作在第二工作模式。
根据本发明的基于固态硬盘的计算机系统,所述固态硬盘的接口包括USB接口、SATA接口、SAS接口、PATA接口和PCIE接口。
根据本发明的基于固态硬盘的计算机系统,所述第二硬盘驱动模块还包括自定义命令子模块,用于处理所述固态硬盘的FTL算法模块的通信及同步;和/或保存映射表。
本发明通过在基于固态硬盘的系统的主机端内设置FTL管理子模块,其可以提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表其,该模块可提供FTL算法,并通过主机处理器控制运算,借此有效利用主机的处理器,且当运行该FTL管理子模块时,固态硬盘内的FTL算法模块无需再做大量的算法运算,借此提高系统的整体性能,并减少固态硬盘的损耗。
附图说明
图1是现有技术的基于固态硬盘的系统结构示意图;
图2是本发明的基于固态硬盘的系统结构示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
参见图2,本发明提供了一种基于固态硬盘的计算机系统,其包括相互连接的主机10和固态硬盘20。主机10内具有文件模块11以及用于提供第一驱动程序的第一硬盘驱动模块12,以及用于提供第二驱动程序的第二硬盘驱动模块13。
本发明的一实施例中,第二硬盘驱动模块13包括:
FTL管理子模块131,用于提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表。
文件分析子模块132,用于分析文件模块11,并将文件模块11内删除的文件对应的逻辑块地址通知FTL管理子模块131,FTL管理子模块131回收所述逻辑块地址对应的物理块。
缓存子模块133,用于建立缓冲区,暂存所述主机与固态硬盘之间交互的数据。
自定义命令子模块134,用于处理所述固态硬盘的FTL算法模块的通信及同步;和/或保存映射表。
需要说明的是,本发明所述的第一驱动程序是普通的硬盘驱动程序,第二驱动程序是通过上述第二硬盘驱动模块13实现的驱动程序,该第二驱动程序是加载了FTL算法的驱动。在本发明的系统启动时,可以加载普通的硬盘驱动程序进入第一工作模式,也可以加载第二驱动程序,进入第二工作模式,所述的第一工作模式为普通硬盘的正常工作模式,第二工作模式为本发明提供的高性工作模式。
具体应用中,固态硬盘20包括:
接口模块21,用于与主机10交互数据。本发明的固态硬盘20的接口可以为USB接口、SATA接口、SAS接口、PATA接口和PCIE接口等,接口模块21也与各类接口对应。
FTL算法模块22,用于当主机10加载第一驱动程序时提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表,当主机采用第二驱动程序时该FTL算法模块22辅助主10机的FTL管理子模块131运算管理。
闪存控制模块23,用于将数据写入闪存或者从闪存中读出数据。
下面结合图2具体描述本发明的一个工作过程。
系统上电初始化,主机10通过第二硬盘驱动模块13加载第二驱动程序,并发送自定义ATA命令通知固态硬盘20切换到第二工作模式。固态硬盘20将FTL相关数据传输给第二硬盘驱动模块13,FTL管理子模块131根据这些数据重建FTL管理所需的各映射表,且在之后的系统运行中FTL的运算管理主要由FTL管理子模块131完成,固态硬盘20的FTL算法模块22可协助其完成相应的计算管理任务,借此可减少固态硬盘20的损耗,提高其寿命。在主机10与固态硬盘20交互的过程中,缓存子模块133将主机10的内存建为缓冲区,可暂存交互的数据,同时,文件分析子模块132在系统空闲时分析文件模块11,将文件模块11内删除的文件对应的逻辑块地址通知FTL管理子模块131,FTL管理子模块131回收这些逻辑块对应的物理块,借此节省空间。需要说明的是,固态硬盘20的接口模块21和闪存控制模块23可以直接进行数据交互,且交互过程中,FTL算法模块22可以管理坏块表以及错误处理等辅助工作。
本发明通过在主机10和固态硬盘20内均设有用于提供FTL管理的模块,二者可以独立工作,也可以协同工作,方便灵活。同时,通过主机10的处理器进行计算处理减少了固态硬20的运算量。主机10的第二硬盘驱动模块13可分析主机文件模块11,便于Wear leveling和Garbage Collection,有利于改善性能,提高固态硬盘寿命。更好的,本发明可以将主机10的内存作为数据缓存,也可以对内存采取数据预读取技术,借此提升随机/顺序读写速度,同时可减小写入放大(Write Amplify)。
综上所述,本发明通过在基于固态硬盘的系统的主机端内设置FTL管理子模块,其可以提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表其,该模块可提供FTL算法,并通过主机处理器控制运算,借此有效利用主机的处理器,且当运行该FTL管理子模块时,固态硬盘内的FTL算法模块无需再做大量的算法运算,借此提高系统的整体性能,并减少固态硬盘的损耗。
当然,本发明还可有其它多种实施例,在不背离本发明精神及其实质的情况下,熟悉本领域的技术人员当可根据本发明作出各种相应的改变和变形,但这些相应的改变和变形都应属于本发明所附的权利要求的保护范围。
Claims (6)
1.一种基于固态硬盘的计算机系统,包括相互连接的主机和固态硬盘,所述主机包括文件模块以及用于提供第一驱动程序的第一硬盘驱动模块,其特征在于,所述主机还包括用于提供第二驱动程序的第二硬盘驱动模块,所述第二硬盘驱动模块包括:
FTL管理子模块,用于提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表;
文件分析子模块,用于分析所述文件模块,并将文件模块内删除的文件对应的逻辑块地址通知所述FTL管理子模块,所述FTL管理子模块回收所述逻辑块地址对应的物理块;
缓存子模块,用于建立缓冲区,暂存所述主机与固态硬盘之间交互的数据;
所述固态硬盘包括:
接口模块,用于与所述主机交互数据;
FTL算法模块,用于当主机采用第一驱动程序时提供逻辑块地址到物理块地址的映射,并管理闪存读写/擦除的损耗均衡以及坏块表;或者,用于当主机采用第二驱动程序时辅助所述FTL管理子模块运算管理;
闪存控制模块,用于将数据写入闪存或者从闪存中读出数据。
2.根据权利要求1所述的基于固态硬盘的计算机系统,其特征在于,当所述主机与所述固态硬盘交互数据时,所述缓存子模块将所述主机的内存作为缓冲区。
3.根据权利要求1所述的基于固态硬盘的计算机系统,其特征在于,所述接口模块与闪存控制模块可直接进行数据交互传输。
4.根据权利要求1所述的基于固态硬盘的计算机系统,其特征在于,所述主机加载第一驱动程序时,所述固态硬盘工作在第一工作模式;所述主机加载第二驱动程序时,所述固态硬盘工作在第二工作模式。
5.根据权利要求1所述的基于固态硬盘的计算机系统,其特征在于,所述固态硬盘的接口包括USB接口、SATA接口、SAS接口、PATA接口和PCIE接口。
6.根据权利要求1所述的基于固态硬盘的计算机系统,其特征在于,所述第二硬盘驱动模块还包括自定义命令子模块,用于处理所述固态硬盘的FTL算法模块的通信及同步;和/或保存映射表。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201210000778.3A CN102541760B (zh) | 2012-01-04 | 2012-01-04 | 基于固态硬盘的计算机系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201210000778.3A CN102541760B (zh) | 2012-01-04 | 2012-01-04 | 基于固态硬盘的计算机系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102541760A CN102541760A (zh) | 2012-07-04 |
CN102541760B true CN102541760B (zh) | 2015-05-20 |
Family
ID=46348698
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201210000778.3A Expired - Fee Related CN102541760B (zh) | 2012-01-04 | 2012-01-04 | 基于固态硬盘的计算机系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN102541760B (zh) |
Families Citing this family (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140122774A1 (en) * | 2012-10-31 | 2014-05-01 | Hong Kong Applied Science and Technology Research Institute Company Limited | Method for Managing Data of Solid State Storage with Data Attributes |
US9575884B2 (en) * | 2013-05-13 | 2017-02-21 | Qualcomm Incorporated | System and method for high performance and low cost flash translation layer |
CN103455390A (zh) * | 2013-08-29 | 2013-12-18 | 上海铁路通信有限公司 | 适用于车辆使用环境的双介质冗余存储系统及其应用 |
CN103729187B (zh) * | 2013-12-31 | 2017-02-15 | 深圳信息职业技术学院 | 基于缓冲区的驱动程序架构设计的方法及系统 |
WO2016187801A1 (zh) * | 2015-05-26 | 2016-12-01 | 崔开平 | 一种用于储存介质的数据管理方法及固态硬盘与控制芯片 |
CN105005536B (zh) * | 2015-07-01 | 2019-08-06 | 忆正科技(武汉)有限公司 | 固态存储设备、主机的工作方法及固态存储设备、主机 |
WO2017088185A1 (zh) * | 2015-11-27 | 2017-06-01 | 华为技术有限公司 | 一种存储设备存储数据的方法及存储设备 |
CN105867850B (zh) * | 2016-03-29 | 2019-05-31 | 北京联想核芯科技有限公司 | 一种信息调整方法及电子设备 |
CN106020723B (zh) * | 2016-05-19 | 2019-10-25 | 记忆科技(深圳)有限公司 | 一种简化NVMe固态硬盘的方法 |
CN106354664A (zh) * | 2016-08-22 | 2017-01-25 | 浪潮(北京)电子信息产业有限公司 | 一种固态硬盘数据传输方法及装置 |
CN107273051B (zh) * | 2017-05-15 | 2018-07-03 | 北京华云网际科技有限公司 | Io数据的读写方法和装置 |
CN107168653B (zh) * | 2017-05-24 | 2020-09-01 | 记忆科技(深圳)有限公司 | 一种提高固态硬盘中只读性能的方法及固态硬盘 |
CN110658980B (zh) | 2018-06-29 | 2021-03-23 | 华为技术有限公司 | 数据处理方法及装置、存储系统 |
CN109144897B (zh) * | 2018-09-04 | 2023-07-14 | 杭州阿姆科技有限公司 | 一种实现大容量ssd磁盘的方法 |
CN109491593B (zh) * | 2018-09-28 | 2020-11-17 | 方一信息科技(上海)有限公司 | 一种数据存储管理系统及方法 |
CN110515547A (zh) * | 2019-08-09 | 2019-11-29 | 浪潮电子信息产业股份有限公司 | 一种固态硬盘及计算机设备 |
CN111176562A (zh) * | 2019-12-24 | 2020-05-19 | 河南文正电子数据处理有限公司 | 一种存储系统 |
CN111177033A (zh) * | 2019-12-24 | 2020-05-19 | 河南文正电子数据处理有限公司 | 一种固态硬盘的使用方法 |
CN113934447A (zh) * | 2021-09-13 | 2022-01-14 | 深圳市硅格半导体有限公司 | 硬盘管理方法、装置、设备及计算机程序产品 |
CN114327288B (zh) * | 2021-12-31 | 2024-02-20 | 深圳忆联信息系统有限公司 | Ssd剩余用户使用时间的预测方法、装置、计算机设备及存储介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101236483A (zh) * | 2007-02-01 | 2008-08-06 | 三星电子株式会社 | 合作存储器管理 |
CN101533335A (zh) * | 2009-04-09 | 2009-09-16 | 杭州华三通信技术有限公司 | 磁盘存储系统以及磁盘存储控制方法和装置 |
CN102073459A (zh) * | 2010-11-02 | 2011-05-25 | 记忆科技(深圳)有限公司 | 基于固态硬盘的计算机系统及固态硬盘 |
-
2012
- 2012-01-04 CN CN201210000778.3A patent/CN102541760B/zh not_active Expired - Fee Related
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101236483A (zh) * | 2007-02-01 | 2008-08-06 | 三星电子株式会社 | 合作存储器管理 |
CN101533335A (zh) * | 2009-04-09 | 2009-09-16 | 杭州华三通信技术有限公司 | 磁盘存储系统以及磁盘存储控制方法和装置 |
CN102073459A (zh) * | 2010-11-02 | 2011-05-25 | 记忆科技(深圳)有限公司 | 基于固态硬盘的计算机系统及固态硬盘 |
Also Published As
Publication number | Publication date |
---|---|
CN102541760A (zh) | 2012-07-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102541760B (zh) | 基于固态硬盘的计算机系统 | |
US9934151B2 (en) | System and method for dynamic optimization for burst and sustained performance in solid state drives | |
US10255177B2 (en) | System and method for adaptive optimization for performance in solid state drives based on read/write intensity | |
KR100823171B1 (ko) | 파티션된 플래시 변환 계층을 갖는 컴퓨터 시스템 및플래시 변환 계층의 파티션 방법 | |
Park et al. | A high performance controller for NAND flash-based solid state disk (NSSD) | |
TWI516924B (zh) | 邏輯區塊位址位元映射之使用 | |
CN104461397A (zh) | 一种固态硬盘及其读写方法 | |
US20140122781A1 (en) | Hierarchical flash translation layer | |
US20110138112A1 (en) | Virtualization of Storage Devices | |
TWI385667B (zh) | 用於快閃記憶體的資料管理方法、儲存系統與控制器 | |
US20130067137A1 (en) | Systems and methods for using reserved solid state nonvolatile memory storage capacity for system reduced power state | |
TWI385517B (zh) | Storage device and data management method | |
US9436267B2 (en) | Data storage device | |
CN104166634A (zh) | 一种固态盘系统中的映射表缓存管理方法 | |
CN103543955A (zh) | 利用固态硬盘作为设备读缓存的方法、系统及固态硬盘 | |
JP6713934B2 (ja) | 記憶装置及びその動作方法並びにシステム | |
CN105630405B (zh) | 一种存储系统及采用该存储系统的读写方法 | |
CN103150258A (zh) | 一种固态存储系统的写入、读取及垃圾收集方法 | |
KR20140006299A (ko) | 낸드 플래시 메모리 기반의 저장부에 데이터 기록을 제어하는 방법 및 장치 | |
US10754785B2 (en) | Checkpointing for DRAM-less SSD | |
US20180067854A1 (en) | Aggressive write-back cache cleaning policy optimized for non-volatile memory | |
TW201719415A (zh) | 緩衝記憶體管理方法、記憶體控制電路單元及記憶體儲存裝置 | |
CN103744611A (zh) | 基于固态硬盘为缓存的计算机系统及缓存加速方法 | |
CN101714065A (zh) | 一种闪存控制器的映射信息管理方法 | |
CN103744798A (zh) | 固态硬盘的垃圾回收方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
CF01 | Termination of patent right due to non-payment of annual fee | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20150520 |