JP2014222528A - Memory system and method of controlling nonvolatile memory - Google Patents

Memory system and method of controlling nonvolatile memory Download PDF

Info

Publication number
JP2014222528A
JP2014222528A JP2014140953A JP2014140953A JP2014222528A JP 2014222528 A JP2014222528 A JP 2014222528A JP 2014140953 A JP2014140953 A JP 2014140953A JP 2014140953 A JP2014140953 A JP 2014140953A JP 2014222528 A JP2014222528 A JP 2014222528A
Authority
JP
Japan
Prior art keywords
area
management unit
logical
data
deletion
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.)
Pending
Application number
JP2014140953A
Other languages
Japanese (ja)
Inventor
隆二 西久保
Ryuji Nishikubo
隆二 西久保
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Toshiba Corp
Original Assignee
Toshiba Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Toshiba Corp filed Critical Toshiba Corp
Priority to JP2014140953A priority Critical patent/JP2014222528A/en
Publication of JP2014222528A publication Critical patent/JP2014222528A/en
Pending legal-status Critical Current

Links

Images

Landscapes

  • Memory System (AREA)

Abstract

PROBLEM TO BE SOLVED: To provide a memory system capable of holding information about whether or not a region that is indicated as being unnecessary in units of sectors by a trimming request is unnecessary without requiring an additional storage region for a flag.SOLUTION: A memory system includes: a nonvolatile memory 6; storage means 4 provided with a logical-physical conversion table that holds a correspondence between a logical address specified by a host 1 and a physical address on the nonvolatile memory 6, for each management unit; and a controller 3. When receiving from the host 1 a deletion notification in which a deletion region in the unit of the amount of data which is smaller than the management unit is specified, the controller 3 reads data in a second region on the nonvolatile memory 6, which corresponds to a first region corresponding to the deletion region in the logical-physical conversion table; overwrites a predetermined data pattern at a location corresponding to the deletion region of the read data; and writes the data to a third region on the nonvolatile memory 6 which is different from the second region.

Description

本発明の実施形態は、メモリシステムおよび不揮発性メモリの制御方法に関する。   Embodiments described herein relate generally to a memory system and a non-volatile memory control method.

二次記憶装置としてのメモリシステムでは、ホストからセクタ単位でデータの読み書き
指示がされるが、ホストから書き込まれるデータは、通常はセクタよりも大きなサイズを
持つ所定の管理単位でメモリシステム内部の不揮発性半導体メモリに記憶される。メモリ
システムは、各セクタが不揮発性半導体メモリ上のどこに格納されているかを管理するた
め、論理アドレスとしてのLBA(Logical Block Address)と不揮発性半導体メモリ上
の位置との管理単位での対応表である論物変換テーブルを保持している。
In a memory system as a secondary storage device, the host issues a data read / write instruction in units of sectors. However, data written from the host is usually a nonvolatile in the memory system in a predetermined management unit having a size larger than the sector. Stored in a conductive semiconductor memory. In order to manage where each sector is stored in the nonvolatile semiconductor memory, the memory system is a correspondence table in a management unit between a logical block address (LBA) as a logical address and a position on the nonvolatile semiconductor memory. A logical-physical conversion table is held.

特開2010−218290号公報JP 2010-218290 A

本発明が解決しようとする課題は、トリム要求によりセクタ単位で不要であることが通
知された領域について、フラグ用の追加記憶領域を要さずに不要か否かの情報を保持する
ことが可能なメモリシステムを提供することである。
The problem to be solved by the present invention is that it is possible to hold information about whether or not it is unnecessary without needing an additional storage area for a flag for an area that is notified that it is not required in units of sectors by a trim request. Is to provide a simple memory system.

上記課題を達成するために、実施形態のメモリシステムは、不揮発性メモリと、ホスト
が指定する論理アドレスと前記不揮発性メモリ上での物理アドレスとの対応を管理単位毎
に保持する論物変換テーブルを備えた記憶手段と、コントローラを備える。コントローラ
は、前記管理単位より小さいデータ量を単位として論理アドレスにより削除領域が指定さ
れた削除通知を前記ホストから受け取った場合に、前記削除領域のうち前記管理単位に満
たない第1削除領域を含み前記管理単位に対応する第1領域と前記論物変換テーブルにお
いて対応する前記不揮発性メモリ上の第2領域のデータを読み出し、前記読み出したデー
タの前記第1の削除領域に対応する箇所に所定のデータパターンを上書きし、前記上書き
されたデータを前記第2領域とは別であって前記不揮発性メモリ上の前記管理単位に対応
する第3領域に書き込む。
In order to achieve the above object, a memory system according to an embodiment includes a logical-physical conversion table that holds a correspondence between a nonvolatile memory, a logical address designated by a host, and a physical address on the nonvolatile memory for each management unit. And a controller. When the controller receives from the host a deletion notification in which a deletion area is designated by a logical address in units of data smaller than the management unit, the controller includes a first deletion area that is less than the management unit among the deletion areas. Read data in the first area corresponding to the management unit and the second area on the non-volatile memory corresponding in the logical-physical conversion table, and place a predetermined number in the location corresponding to the first deletion area of the read data A data pattern is overwritten, and the overwritten data is written to a third area corresponding to the management unit on the non-volatile memory separately from the second area.

図1は、実施形態にかかるメモリシステム(SSD)のシステム構成を示すブロック図である。FIG. 1 is a block diagram illustrating a system configuration of a memory system (SSD) according to the embodiment. 図2は、実施形態における管理単位にアラインされたLBAとNANDフラッシュメモリ上において管理単位に割り振られているデータ領域との対応関係を示す図である。FIG. 2 is a diagram illustrating a correspondence relationship between an LBA aligned with a management unit and a data area allocated to the management unit on the NAND flash memory in the embodiment. 図3は、実施形態における論物変換テーブルを示す図である。FIG. 3 is a diagram illustrating a logical-physical conversion table in the embodiment. 図4は、実施形態においてトリム要求を受け取ったときのメモリシステムの処理を示すフローチャートである。FIG. 4 is a flowchart illustrating processing of the memory system when a trim request is received in the embodiment. 図5は、実施形態においてトリム要求されたLBAに対応する領域に所定のデータパターンを書き込む処理を示すフローチャートである。FIG. 5 is a flowchart illustrating a process of writing a predetermined data pattern in an area corresponding to the LBA requested to be trimmed in the embodiment. 図6は、実施形態においてトリム要求されたLBAに対応する領域に所定のデータパターンを書き込む処理を示す概念図である。FIG. 6 is a conceptual diagram illustrating a process of writing a predetermined data pattern in an area corresponding to the LBA requested to be trimmed in the embodiment. 図7は、実施形態において管理単位の全てが所定のデータパターンとなった場合に当該管理単位が解放できることを示す概念図である。FIG. 7 is a conceptual diagram showing that the management unit can be released when all of the management units have a predetermined data pattern in the embodiment. 図8は、実施形態において管理単位のデータを移動するときに、解放可能な管理単位を解放する処理を示すフローチャートである。FIG. 8 is a flowchart illustrating a process of releasing a releasable management unit when data of the management unit is moved in the embodiment.

ある管理単位内の全てのセクタについて、一度もデータが書き込まれていない場合には
当該管理単位の論理アドレスに対応する不揮発性半導体メモリ上の位置は「未割り当て」
になっている。未割り当ての管理単位に含まれるセクタに対しホストからデータが書き込
まれると、該当する論理アドレスを含む管理単位は「割り当て済み」になり、実際のデー
タが存在する不揮発性半導体メモリ上の位置が物理アドレスとして保存される。メモリシ
ステムは、データの断片化を解消する目的などで不揮発性半導体メモリ上のデータを移動
することがある。ホストから不要になったデータ領域の通知を受けて、「割り当て済み」
の管理単位を「未割り当て」に戻すことで、不要なデータの移動を削減することができる
When data has not been written for all sectors in a certain management unit, the position on the nonvolatile semiconductor memory corresponding to the logical address of the management unit is “unallocated”.
It has become. When data is written from the host to a sector included in an unallocated management unit, the management unit including the corresponding logical address becomes “allocated”, and the location on the nonvolatile semiconductor memory where the actual data exists is physically Saved as an address. A memory system may move data on a nonvolatile semiconductor memory for the purpose of eliminating fragmentation of data. Received notification of the data area that is no longer needed from the host, and "allocated"
By returning the management unit to “unassigned”, unnecessary data movement can be reduced.

従来のメモリシステムでは、ホストから不要となった領域の通知、たとえば、INCI
TS ATA8−ACSで採用されたData Set Management Command(通称トリム要求)に
よる通知(以下、トリム要求と呼称する)をセクタ単位で受け取り、トリム要求で通知さ
れた領域のうち、管理単位にアラインされた領域(管理単位と同じ大きさの領域)につい
ては当該管理単位を「割り当て済み」から「未割り当て」に変更し、不要なデータの移動
が起こらないようにすることができる。一方、トリム要求のうちで管理単位にアラインさ
れていない領域、即ち管理単位未満のトリム要求をされた領域については「未割り当て」
にすることができず、トリム要求の情報を利用できない。
In a conventional memory system, notification of an area that is no longer necessary from the host, for example, INCI
Received notification (hereinafter referred to as trim request) by Data Set Management Command (commonly referred to as trim request) adopted by TS ATA8-ACS, and aligned to the management unit in the area notified by the trim request. For the area (area having the same size as the management unit), the management unit can be changed from “allocated” to “unallocated” to prevent unnecessary data movement. On the other hand, the area that is not aligned with the management unit among the trim requests, that is, the area for which the trim request is less than the management unit is “unallocated”.
The trim request information cannot be used.

セクタ単位で領域が不要かどうかを示すフラグを別途導入すれば、後続のトリム要求の
情報と組み合わせて管理単位の不要な領域ができた際に当該領域を未割り当てにすること
ができる。しかしながら、この場合はフラグの情報を記憶するための追加の記憶領域が必
要となり、また、フラグ書き込みのための特別な処理を導入する必要がある。
If a flag indicating whether or not an area is unnecessary for each sector is separately introduced, the area can be unassigned when an unnecessary area for the management unit is created in combination with information of subsequent trim requests. However, in this case, an additional storage area for storing the flag information is required, and a special process for writing the flag needs to be introduced.

以下に添付図面を参照して、実施形態にかかるメモリシステムおよびメモリシステムの
制御方法を詳細に説明する。なお、この実施形態により本発明が限定されるものではない
Exemplary embodiments of a memory system and a memory system control method will be explained below in detail with reference to the accompanying drawings. In addition, this invention is not limited by this embodiment.

(実施形態)
図1は、実施形態にかかるメモリシステムとしてのSSD(Solid State Drive)2の
構成の一例を示すブロック図である。半導体記憶装置であるSSD2は、管理情報記憶部
40を含むRAM4、以下に説明するデータパターン検出部5、実際にデータを記憶する
NANDフラッシュメモリ6、およびそれらを制御するコントローラ3を備える。SSD
2は、図示せぬインタフェースを介して、ホスト1からの読み書き指示を受ける。ホスト
1とSSD2とのインタフェースは、例えば、SATA(Serial ATA)規格に準拠するが
、これに限定されるものではない。データパターン検出部5はハードウェアとして実装し
ても良いし、コントローラ3が実行するファームウェアモジュールとして実装しても良い
(Embodiment)
FIG. 1 is a block diagram illustrating an example of a configuration of an SSD (Solid State Drive) 2 as a memory system according to the embodiment. The SSD 2 that is a semiconductor storage device includes a RAM 4 including a management information storage unit 40, a data pattern detection unit 5 described below, a NAND flash memory 6 that actually stores data, and a controller 3 that controls them. SSD
2 receives a read / write instruction from the host 1 via an interface (not shown). The interface between the host 1 and the SSD 2 conforms to, for example, the SATA (Serial ATA) standard, but is not limited to this. The data pattern detection unit 5 may be implemented as hardware, or may be implemented as a firmware module executed by the controller 3.

NANDフラッシュメモリ6は、複数の不揮発性メモリセルが行列上に配置されたメモ
リセルアレイ及び当該メモリセルアレイに対する書込み、読み出し、消去動作を制御する
ための周辺回路を含む。メモリセルアレイは、データ消去の最小単位であるブロックを複
数配列して構成されている。各々のブロックは、データ書込み及び読み出しの最小単位で
あるページを複数配列して構成されている。1ブロックの記憶容量は例えば1024KB
であり、1ページの記憶容量は例えば8KBである。各々のメモリセルは、1ビットを記
憶するように構成されていても良いし、2ビット以上を記憶するように構成されていても
良い。NANDフラッシュメモリ6では、ブロック内の同一ページに対する再書き込みは
、一度当該ページを含むブロック全体を消去した後でなければ許可されない。
The NAND flash memory 6 includes a memory cell array in which a plurality of nonvolatile memory cells are arranged in a matrix, and a peripheral circuit for controlling write, read, and erase operations for the memory cell array. The memory cell array is configured by arranging a plurality of blocks which are the minimum unit of data erasure. Each block is configured by arranging a plurality of pages which are the minimum units for data writing and reading. The storage capacity of one block is 1024KB, for example
For example, the storage capacity of one page is 8 KB. Each memory cell may be configured to store 1 bit, or may be configured to store 2 bits or more. In the NAND flash memory 6, rewriting to the same page in the block is permitted only after the entire block including the page is once erased.

ホストとメモリシステムの間でデータをやりとりするための規格であるATA規格のDa
ta Set Management Commandにおいて、Trimという属性が定義されている。これにより、
ホストは不要になった領域をセクタ単位でメモリシステムに通知することができる。これ
についてはATAコマンドの規格を参照することとし(http://www.t13.org/Documents/Up
loadedDocuments/docs2009/d2015r1a-ATAATAPI_Command_Set_-_2_ACS-2.pdf)、ここでは
その詳細は説明しない。このようなコマンドを、以降トリムコマンド(トリム要求)と呼
称する。このコマンドによれば、不要になった記憶領域は、先頭論理アドレス(LBA)
とセクタサイズとで指定される。本実施形態は、ATA規格のトリム要求だけでなく、A
TA以外の規格であっても同様の仕様を持つコマンドであれば適用できる。
Da of ATA standard, which is a standard for exchanging data between host and memory system
In ta Set Management Command, an attribute called Trim is defined. This
The host can notify the memory system of the area that has become unnecessary in units of sectors. For this, refer to the ATA command standard (http://www.t13.org/Documents/Up
loadedDocuments / docs2009 / d2015r1a-ATAATAPI_Command_Set _-_ 2_ACS-2.pdf), details of which are not described here. Such a command is hereinafter referred to as a trim command (trim request). According to this command, the storage area that is no longer needed is the first logical address (LBA).
And the sector size. In the present embodiment, not only the ATA standard trim request but also A
Even a standard other than TA can be applied as long as it has a similar specification.

図1に戻り説明を続ける。ホスト1から書き込まれたデータは所定の管理単位でNAN
Dフラッシュメモリ6に記憶される。論理アドレス空間上の連続したアドレスを論物変換
(論理アドレスと物理アドレスとの変換)の単位として、当該連続したアドレスをまとめ
てNANDフラッシュメモリ6上の物理的な領域に割り当てる。この管理単位は、上述し
たトリム要求が指定するセクタ単位よりも大きく、当該管理単位内においては、論理アド
レスが連続する複数のセクタが順に配置されている。管理単位の大きさは任意であるが、
例えば、NANDフラッシュメモリ6のページサイズやブロックサイズ、あるいはホスト
1が採用するファイルシステムのクラスタサイズ等に一致させることができる。
Returning to FIG. Data written from the host 1 is NAN in a predetermined management unit
It is stored in the D flash memory 6. Using consecutive addresses in the logical address space as units of logical-physical conversion (conversion between logical addresses and physical addresses), the continuous addresses are collectively assigned to a physical area on the NAND flash memory 6. This management unit is larger than the sector unit specified by the trim request described above, and a plurality of sectors with consecutive logical addresses are arranged in order within the management unit. The size of the management unit is arbitrary,
For example, the page size or block size of the NAND flash memory 6 or the cluster size of the file system adopted by the host 1 can be matched.

ホスト1から書き込まれた更新データが管理単位にアラインされていない場合には、N
ANDフラッシュメモリ6上の管理単位の大きさの領域に既に記憶されているデータと、
管理単位の大きさに満たない新たに書き込まれた更新データとをRAM4上でマージし、
管理単位のデータを作成した上でNANDフラッシュメモリ6の空き領域に書き込む(リ
ードモディファイライト)。ホスト1から書き込まれたデータがNANDフラッシュメモ
リ6上のどこに書き込まれるかは動的に変化するものであり、その対応関係が後述する論
物変換テーブルによって管理される。論理アドレスとしては、例えば、論理容量に対して
セクタ単位で0から通し番号が付されたLBA(Logical Block Address)が採用される
。セクタサイズは、例えば512Bである。
If the update data written from host 1 is not aligned to the management unit, N
Data already stored in the area of the size of the management unit on the AND flash memory 6;
The newly written update data that is less than the size of the management unit is merged on the RAM 4,
After the management unit data is created, it is written in the empty area of the NAND flash memory 6 (read-modify-write). Where the data written from the host 1 is written on the NAND flash memory 6 changes dynamically, and the corresponding relationship is managed by a logical-physical conversion table described later. As the logical address, for example, an LBA (Logical Block Address) in which a serial number from 0 to the sector is assigned to the logical capacity is employed. The sector size is, for example, 512B.

図2は、管理単位でアラインされたLBAとNANDフラッシュメモリ上において管理
単位に割り振られているデータ領域との対応関係を示す図である。図2のように、ホスト
1が書き込み要求で指定するLBAはセクタ単位であるが、SSD2内部では当該LBA
は管理単位の大きさ(例えば、ページサイズ)でアラインされ、当該管理単位内の連続す
るLBAに対応するセクタが、NANDフラッシュ6の管理単位の領域にまとめて記憶さ
れる。例えば、管理単位の大きさがページサイズに等しい場合、ページサイズでアライン
されたLBAに対応する複数のセクタが、NANDフラッシュメモリ6のページサイズ分
の領域に書き込まれる。
FIG. 2 is a diagram showing a correspondence relationship between LBAs aligned in management units and data areas allocated to management units in the NAND flash memory. As shown in FIG. 2, the LBA specified by the host 1 in the write request is in units of sectors.
Are aligned in the size of the management unit (for example, page size), and sectors corresponding to consecutive LBAs in the management unit are collectively stored in the management unit area of the NAND flash 6. For example, when the size of the management unit is equal to the page size, a plurality of sectors corresponding to the LBAs aligned with the page size are written in an area corresponding to the page size of the NAND flash memory 6.

図3は、実施形態における論物変換テーブルを示す図である。管理情報記憶部40は、
LBAで指定されるデータがNANDフラッシュメモリ6のどこに書き込まれているかと
いう対応関係を示す論物変換テーブルを記憶している。図3の論物変換テーブルは、論理
アドレスとしてホスト1が指定するLBAを管理単位でアラインした値と、また物理アド
レスとしてNANDフラッシュメモリ6の物理アドレスを管理単位でアラインした値とを
含んでいる。例えば、管理単位がページサイズに等しければ、物理アドレスとして物理ペ
ージ番号が登録される。また例えば、管理単位がブロックサイズに等しければ、物理アド
レスとして物理ブロック番号が登録される。
FIG. 3 is a diagram illustrating a logical-physical conversion table in the embodiment. The management information storage unit 40
A logical-physical conversion table is stored that indicates a correspondence relationship where the data specified by the LBA is written in the NAND flash memory 6. The logical-physical conversion table of FIG. 3 includes a value obtained by aligning the LBA specified by the host 1 as a logical address in a management unit, and a value obtained by aligning the physical address of the NAND flash memory 6 in a management unit as a physical address. . For example, if the management unit is equal to the page size, a physical page number is registered as a physical address. For example, if the management unit is equal to the block size, a physical block number is registered as a physical address.

管理単位でアラインされたあるLBAについて、ホスト1から一度もデータが書き込ま
れていないとき、論物変換テーブルの当該LBAに対応する物理アドレスの位置には、無
効値が書き込まれるなどして「未割り当て」状態となっている。管理単位内のセクタにデ
ータが書き込まれると、当該管理単位は「割り当て済み」となりNANDフラッシュメモ
リ6上の位置が論物変換テーブルに記録される。SSD2は、データの断片化を解消する
目的などで、「割り当て済み」となっている管理単位のデータを移動することがある。ホ
スト1から不要になった領域の通知を受けとり、使わないことになった管理単位を「未割
り当て」にすることで、不要なデータの移動を削減することができる。
When no data has been written from the host 1 for a certain LBA aligned in the management unit, an invalid value is written at the position of the physical address corresponding to the LBA in the logical-physical conversion table. "Assigned" status. When data is written to a sector in the management unit, the management unit becomes “allocated”, and the position on the NAND flash memory 6 is recorded in the logical-physical conversion table. The SSD 2 may move management unit data that has been “assigned” for the purpose of eliminating data fragmentation. By receiving a notification of an unnecessary area from the host 1 and setting a management unit that is no longer used to “unassigned”, it is possible to reduce unnecessary data movement.

図4は、トリム要求を受け取ったときのメモリシステムの処理を示すフローチャートで
ある。コントローラ3は、ホスト1からトリム要求を受け取る(ステップS11)。トリ
ム要求は上述した通り、トリム対象領域の先頭LBA及びセクタサイズを含む。なお、1
つのトリム要求で複数のトリム対象領域を設定しても良い。
FIG. 4 is a flowchart showing processing of the memory system when a trim request is received. The controller 3 receives a trim request from the host 1 (step S11). As described above, the trim request includes the head LBA and the sector size of the trim target area. 1
A plurality of trim target areas may be set by one trim request.

コントローラ3は、トリム対象領域として指定されたLBA範囲が、少なくとも1つの
管理単位の領域全体を含むか否かを判定する。管理単位の領域を複数含む場合は、それら
全てに対して以下ステップ13の処理を適用する。(ステップS12)。管理単位の領域
を含む場合(ステップS12:Yes)、コントローラ3は論物変換テーブルを操作し、
当該管理単位のLBAを「未割り当て」に変更し、当該管理単位のLBAに割り当てられ
ていたNANDフラッシュメモリ6上の領域を解放する(ステップS13)。
The controller 3 determines whether or not the LBA range designated as the trim target area includes the entire area of at least one management unit. When a plurality of management unit areas are included, the processing in step 13 is applied to all of them. (Step S12). When the management unit area is included (step S12: Yes), the controller 3 operates the logical-physical conversion table,
The LBA of the management unit is changed to “unallocated”, and the area on the NAND flash memory 6 allocated to the LBA of the management unit is released (step S13).

コントローラ3は、トリム対象領域として指定されたLBA範囲が、管理単位未満の領
域を含むか否かを判定する(ステップS14)。管理単位未満のトリム対象領域が存在す
る場合(ステップS14:Yes)、コントローラ3は当該管理単位未満のトリム対象領
域に対して「所定のデータパターン」を書き込む(ステップS15)。本実施形態におい
ては「所定のデータパターン」が書き込まれていることを、当該領域が不要であることの
フラグとして利用する。
The controller 3 determines whether or not the LBA range designated as the trim target area includes an area less than the management unit (step S14). If there is a trim target area less than the management unit (step S14: Yes), the controller 3 writes “predetermined data pattern” to the trim target area less than the management unit (step S15). In the present embodiment, the fact that “predetermined data pattern” is written is used as a flag indicating that the area is unnecessary.

ここで、上記ステップS15の処理の詳細について説明する。なお、ここで説明する処
理はトリム要求で「所定のデータパターン」を書き込む場合に限ったものではなく、図1
のホスト1から通常のデータが書き込まれた場合でも、同様の処理でNANDフラッシュ
メモリ6に書き込みがなされる。
Here, the details of the process of step S15 will be described. The processing described here is not limited to the case where “predetermined data pattern” is written in the trim request.
Even when normal data is written from the host 1, data is written to the NAND flash memory 6 by the same processing.

SSD2がNANDフラッシュメモリ6にデータを書き込む際には以下のような制約が
ある。コントローラ3は、論物変換テーブルの解像度、即ちセクタ単位よりも大きい所定
の管理単位でしかデータを管理することができない。即ち、セクタ単位でばらばらの位置
にデータを書き込むことはできない。さらに、NANDフラッシュメモリ6はデータの上
書きができない。これらの制約の下での、管理単位未満の(管理単位にアラインされてい
ない)データを書き込むステップS15の処理手順(リードモディファイライト)の詳細
を、図1、図5のフローチャート、および図6に示した概念図を用いて説明する。
When the SSD 2 writes data to the NAND flash memory 6, there are the following restrictions. The controller 3 can manage data only in a predetermined management unit larger than the resolution of the logical-physical conversion table, that is, the sector unit. That is, data cannot be written at different positions in units of sectors. Further, the NAND flash memory 6 cannot overwrite data. Details of the processing procedure (read modify write) of step S15 for writing data less than the management unit (not aligned with the management unit) under these restrictions are shown in the flowcharts of FIGS. 1 and 5 and FIG. This will be described with reference to the conceptual diagram shown.

図5は、トリム要求されたLBAに対応する領域に所定のデータパターンを書き込む処
理を示すフローチャートである。また、図6は、トリム要求されたLBAに対応する領域
に所定のデータパターンを書き込む処理を示す概念図である。ホスト1から管理単位より
も小さい領域50に対してトリム要求があると、コントローラ3は、トリム要求されたセ
クタを含む管理単位61全体のデータをNANDフラッシュメモリ6から読み出して、R
AM4に保持する(図5、ステップS21)。管理単位61は、論物変換テーブルにおい
て、トリム要求されたLBAを管理単位でアラインした値に関連付けられたNANDフラ
ッシュメモリ6上の領域を示しており、以前にホスト1から書き込まれたデータを記憶し
ている。
FIG. 5 is a flowchart showing a process of writing a predetermined data pattern in an area corresponding to the LBA requested to be trimmed. FIG. 6 is a conceptual diagram showing a process of writing a predetermined data pattern in an area corresponding to the LBA requested to be trimmed. When there is a trim request from the host 1 to the area 50 smaller than the management unit, the controller 3 reads the data of the entire management unit 61 including the sector requested to be trimmed from the NAND flash memory 6, and R
It holds in AM4 (FIG. 5, step S21). The management unit 61 indicates an area on the NAND flash memory 6 associated with a value obtained by aligning the LBA requested for trimming in the management unit in the logical-physical conversion table, and stores data previously written from the host 1. doing.

コントローラ3は、RAM4において、管理単位61から読み出されたデータのトリム
要求された領域に「所定のデータパターン」77を上書きすることにより、管理単位61
に書き込まれていたトリム対象領域以外のデータと「所定のデータパターン」77とをマ
ージする(ステップS22)。ここでのマージ作業は、一般にホスト1から書き込まれた
更新データを管理単位61に書き込まれていたデータに上書きする場合も同様である。こ
こでは、管理単位61の大きさに満たないトリム要求に対して、管理単位61に書き込ま
れていたデータの中でトリム要求があった範囲のセクタに対して「所定のデータパターン
」77を上書きする。
The controller 3 overwrites the “predetermined data pattern” 77 in the RAM 4 in the area requested to trim the data read from the management unit 61.
The data other than the trimming target area written in the “merging data” and the “predetermined data pattern” 77 are merged (step S22). The merge operation here is also the same when overwriting update data written from the host 1 with data written in the management unit 61 in general. Here, in response to a trim request that is less than the size of the management unit 61, the “predetermined data pattern” 77 is overwritten on the sector in the range in which the trim request has been written in the data written to the management unit 61. To do.

コントローラ3は、このようにしてRAM4上でマージされた新しいデータを、NAN
Dフラッシュメモリ6の空き領域(消去済みの新しい管理単位68)に書き込む(ステッ
プS23)。コントローラ3は、図3の論物変換テーブルを操作して、トリム対象領域を
含む管理単位でアラインされたLBAに対して、管理単位68に対応する物理アドレスを
記録する。以前にホスト1から書き込まれた古いデータが記憶されている管理単位61は
、LBAとの関連付けから解放されて無効化され、データ消去後には空き領域として取り
扱われる(ステップS24)。
The controller 3 transfers the new data merged in the RAM 4 in this way to the NAN.
The data is written into an empty area (new erased management unit 68) in the D flash memory 6 (step S23). The controller 3 records the physical address corresponding to the management unit 68 for the LBA aligned in the management unit including the trim target area by operating the logical-physical conversion table of FIG. The management unit 61 in which old data previously written from the host 1 is stored is released from the association with the LBA and invalidated, and is treated as a free area after data erasure (step S24).

図7は、管理単位の全てが所定のデータパターンとなった場合に当該管理単位が解放で
きることを示す概念図である。上記したように、トリム対象領域に対応する「所定のデー
タパターン」77は、通常のホスト1からの書き込みと同様に、NANDフラッシュメモ
リ6上の管理単位のデータとマージされ、NANDフラッシュメモリ6に書き込まれる。
コントローラ3は、マージの結果、図7に示すように、管理単位内の全てのセクタが「所
定のデータパターン」になった場合に、当該管理単位の論理アドレスを「未割り当て」に
変更して解放することができる。
FIG. 7 is a conceptual diagram showing that the management unit can be released when all the management units have a predetermined data pattern. As described above, the “predetermined data pattern” 77 corresponding to the trim target area is merged with the data of the management unit on the NAND flash memory 6 and written to the NAND flash memory 6 in the same manner as the normal writing from the host 1. Written.
As a result of the merge, the controller 3 changes the logical address of the management unit to “unassigned” when all sectors in the management unit become “predetermined data pattern” as shown in FIG. Can be released.

図8は、管理単位のデータを移動するときに、解放可能な管理単位の領域を解放する処
理を示すフローチャートである。コントローラ3がNANDフラッシュメモリ6上のデー
タを移動する際などに、移動対象のデータから管理単位分のデータを読み込んだとき(ス
テップS31)、データパターン検出部5は、管理単位内のセクタ全てに「所定のデータ
パターン」が書き込まれているかどうかを判定する(ステップS32)。
FIG. 8 is a flowchart showing processing for releasing a releasable management unit area when moving management unit data. When the controller 3 moves data on the NAND flash memory 6 or the like, when data for the management unit is read from the data to be moved (step S31), the data pattern detection unit 5 applies to all sectors in the management unit. It is determined whether or not “predetermined data pattern” has been written (step S32).

データ移動は、例えば、無効化された古いデータが増えて新たにデータを書き込むこと
ができる領域が減少した場合に、「割り当て済み」の領域に記憶されている管理単位のデ
ータを特定のブロックに集め、古いデータだけになったブロックを消去して空き領域を増
加させる際に行われる(コンパクション、またはガベージコレクションと呼ばれる)。あ
るいは、メモリセルに書き込みが行われた後に長時間経過してデータが劣化したときに、
別の空き領域にデータを書き直すことで信頼性を向上させるために行われる(リフレッシ
ュと呼ばれる)。
For example, if the old data that has been invalidated increases and the area where new data can be written decreases, the data in the management unit stored in the “allocated” area is transferred to a specific block. This is done when collecting and erasing blocks that contain only old data to increase free space (called compaction or garbage collection). Alternatively, when the data deteriorates after a long time after writing to the memory cell,
This is performed in order to improve reliability by rewriting data in another free area (referred to as refresh).

データパターン検出部5は、管理単位内のセクタ全てが「所定のデータパターン」にな
っていると検出した場合(ステップS32:Yes)、その旨をコントローラ3に通知す
る。コントローラ3は、データパターン検出部5からの通知を受けて、当該管理単位を「
未割り当て」に変更し、当該管理単位のLBAに割り当てられていたNANDフラッシュ
メモリ6上の領域を解放する(ステップS33)。
When the data pattern detection unit 5 detects that all the sectors in the management unit are “predetermined data pattern” (step S32: Yes), the data pattern detection unit 5 notifies the controller 3 accordingly. The controller 3 receives the notification from the data pattern detection unit 5 and sets the management unit to “
The area is changed to “unallocated” and the area on the NAND flash memory 6 allocated to the LBA of the management unit is released (step S33).

データパターン検出部5は、管理単位内のセクタ全てが「所定のデータパターン」とな
っているわけではない場合(ステップS32:No)、その旨をコントローラ3に通知す
る。コントローラ3は、データパターン検出部5からの通知を受けて、読み出したデータ
をNANDフラッシュメモリ6上の移動先にそのまま書き込む(ステップS34)。
If all the sectors in the management unit are not “predetermined data pattern” (step S32: No), the data pattern detection unit 5 notifies the controller 3 accordingly. The controller 3 receives the notification from the data pattern detection unit 5 and writes the read data as it is to the movement destination on the NAND flash memory 6 (step S34).

ステップS33およびS34の後、コントローラ3は移動対象のデータを全て読み出し
たか否か判定する(ステップS35)。全て読み出していない場合は(ステップS35:
No)はステップS31にもどる。移動対象のデータを全て読み出したら(ステップS3
5:Yes)、データ移動処理を終了する。
After steps S33 and S34, the controller 3 determines whether all the movement target data has been read (step S35). If not all have been read (step S35:
No) returns to step S31. When all the data to be moved is read (step S3
5: Yes), the data movement process is terminated.

また、本実施形態のメモリシステムが上記のような動作を実行した場合にメモリシステ
ムとして円滑に機能させるために、さらに以下の動作を実行することが好ましい。即ち、
ホスト1からトリム要求としてではなく「所定のデータパターン」がNANDフラッシュ
メモリ6に書き込まれた場合に対してもデータの不一致が発生しないようにする。
In addition, when the memory system of the present embodiment performs the above-described operation, it is preferable to further execute the following operation in order to function smoothly as a memory system. That is,
Data mismatch does not occur even when a “predetermined data pattern” is written in the NAND flash memory 6 instead of as a trim request from the host 1.

具体的には、図3の論物変換テーブルの物理アドレスの位置に無効値が書き込まれた「
未割り当て」のLBAに対しホスト1から読み出し要求があった場合には、「所定のデー
タパターン」をホスト1に返すようにする。これにより、半導体記憶装置であるSSD2
はトリム要求により「所定のデータパターン」が書き込まれた場合と、ホスト1から実際
に「所定のデータパターン」の書き込み要求が来た場合とを区別しないで済む。
Specifically, an invalid value is written at the physical address position in the logical-physical conversion table of FIG.
When there is a read request from the host 1 for an “unallocated” LBA, a “predetermined data pattern” is returned to the host 1. As a result, the semiconductor memory device SSD2
Therefore, it is not necessary to distinguish between the case where the “predetermined data pattern” is written by the trim request and the case where the host 1 actually receives the “predetermined data pattern” write request.

従って、トリム要求ではなくホスト1から管理単位にアラインされたサイズの「所定の
データパターン」が書き込まれた場合に、図8のフローに従いステップS33にて当該管
理単位を解放しても矛盾は生じない。当該解放された領域に対応するLBAに読み出し要
求があった場合は、現実のデータは無効化されて存在しないものの、「所定のデータパタ
ーン」を返すことで書き込みデータを保証することが可能だからである。
Therefore, when a “predetermined data pattern” of a size aligned from the host 1 to the management unit is written instead of the trim request, a contradiction occurs even if the management unit is released in step S33 according to the flow of FIG. Absent. If there is a read request to the LBA corresponding to the released area, the actual data is invalidated and does not exist, but it is possible to guarantee the write data by returning “predetermined data pattern”. is there.

以上説明してきたように本実施形態にかかるメモリシステムは、ホストからトリム要求
を受け取ると、トリム要求されて不要となった領域のうちメモリシステムのデータ管理単
位にアラインされた領域を即座に解放する。不要となった領域がデータの管理単位にアラ
インされていない場合には不要となった領域に「所定のデータパターン」を書き込むこと
で当該領域が不要であるという情報を保持しておく。その後、後続のトリム要求と組み合
わせて管理単位が全て「所定のデータパターン」である解放可能な領域ができたときに当
該領域を解放する。即ち、その後データを読み込んだ際にデータの管理単位にアラインさ
れた「所定のデータパターン」を検出したら、当該領域を解放する。これにより、トリム
要求の情報を最大限に活用することができる。
As described above, when the memory system according to the present embodiment receives a trim request from the host, the memory system immediately releases the area aligned with the data management unit of the memory system among the areas that are unnecessary due to the trim request. . When an unnecessary area is not aligned with a data management unit, information indicating that the area is unnecessary is held by writing a “predetermined data pattern” in the unnecessary area. After that, in combination with the subsequent trim request, when a releasable area having all management units of “predetermined data pattern” is created, the area is released. That is, when a “predetermined data pattern” aligned with the data management unit is detected when the data is subsequently read, the area is released. As a result, the trim request information can be fully utilized.

また、本実施形態により「所定のデータパターン」が書き込まれた管理単位を不要であ
るとみなして解放することで、メモリシステムが利用できる領域を増やすことができる。
ホストが偶然「所定のデータパターン」を書き込んだ場合でも、トリム要求を受けたこと
によりコントローラが書き込んだ場合でも、特に区別する必要はない。「所定のデータパ
ターン」をトリム対象領域のフラグとして利用するので、各セクタが不要かどうかを示す
フラグを保存する追加の記憶領域を必要としない。
Further, according to the present embodiment, it is possible to increase the area that can be used by the memory system by releasing the management unit in which the “predetermined data pattern” is written as unnecessary.
Even if the host accidentally writes a “predetermined data pattern” or the controller writes due to receiving a trim request, there is no particular need to distinguish. Since the “predetermined data pattern” is used as a trim target area flag, an additional storage area for storing a flag indicating whether each sector is unnecessary is not required.

また、トリム要求のうち、従来は破棄、或いは記憶領域を追加して記憶していた管理単
位にアラインされていない領域の情報を、追加の記憶領域を必要とせずに記憶し、トリム
要求の全ての情報を活用できるようになる。管理単位にアラインされていないトリム要求
を複数個組み合わせて管理単位を解放し、利用できる不揮発性半導体メモリの領域を増や
すことができる。
Also, among trim requests, information on the area that is not aligned with the management unit that was previously discarded or added to the storage area is stored without the need for an additional storage area. It becomes possible to utilize information of. It is possible to release a management unit by combining a plurality of trim requests not aligned with the management unit, and to increase the area of the nonvolatile semiconductor memory that can be used.

なお、上記実施形態においてはセクタよりも大きな管理単位が1種類であるとして説明
したが、例えばクラスタ(例えば、セクタの2以上の自然数倍)およびトラック(例えば
、クラスタの2以上の自然数倍)などとセクタよりも大きな管理単位が複数種類ある場合
において、小さな管理単位から大きな管理単位にデフラグする場合などには、そのときに
上述した無効化処理を実行するようにしてもかまわない。具体的には、ある上位の管理単
位を構成する下位の管理単位が全て「所定のデータパターン」となった場合に、当該上位
の管理単位を解放することなどが考えられる。
In the above embodiment, the management unit larger than the sector is described as one type. However, for example, a cluster (for example, two or more natural number times of the sector) and a track (for example, two or more natural number times of the cluster). In the case where there are a plurality of types of management units larger than a sector, for example, when the defragmentation is performed from a small management unit to a large management unit, the invalidation process described above may be executed at that time. Specifically, when all of the lower management units constituting a certain upper management unit become “predetermined data pattern”, the upper management unit may be released.

また、上記実施形態では「所定のデータパターン」を書き込むコマンドとしてトリムコ
マンドを例に挙げて説明したが、これに限定されるものではない。例えば、不良セクタの
位置を示す情報がホストから送られた場合に、当該不良セクタに対応するLBAに「所定
のデータパターン」を書き込むことにしても良い。
In the above embodiment, the trim command has been described as an example of the command for writing the “predetermined data pattern”. However, the present invention is not limited to this. For example, when information indicating the position of the defective sector is sent from the host, a “predetermined data pattern” may be written in the LBA corresponding to the defective sector.

本発明のいくつかの実施形態を説明したが、これらの実施形態は、例として提示したも
のであり、発明の範囲を限定することは意図していない。これら新規な実施形態は、その
他の様々な形態で実施されることが可能であり、発明の要旨を逸脱しない範囲で、種々の
省略、置き換え、変更を行うことができる。これら実施形態やその変形は、発明の範囲や
要旨に含まれるとともに、特許請求の範囲に記載された発明とその均等の範囲に含まれる
Although several embodiments of the present invention have been described, these embodiments are presented by way of example and are not intended to limit the scope of the invention. These novel embodiments can be implemented in various other forms, and various omissions, replacements, and changes can be made without departing from the scope of the invention. These embodiments and modifications thereof are included in the scope and gist of the invention, and are included in the invention described in the claims and the equivalents thereof.

1 ホスト、2 SSD、3 コントローラ、4 RAM、5 データパターン検出部
、6 NANDフラッシュメモリ、40 管理情報記憶部。
1 host, 2 SSD, 3 controller, 4 RAM, 5 data pattern detection unit, 6 NAND flash memory, 40 management information storage unit.

Claims (12)

不揮発性メモリと、
ホストが指定する論理アドレスと前記不揮発性メモリ上での物理アドレスとの対応を管
理単位毎に保持する論物変換テーブルを備えた記憶手段と、
前記管理単位より小さいデータ量を単位として論理アドレスにより削除領域が指定され
た削除通知を前記ホストから受け取った場合に、前記削除領域のうち前記管理単位に満た
ない第1削除領域を含み前記管理単位に対応する第1領域と前記論物変換テーブルにおい
て対応する前記不揮発性メモリ上の第2領域のデータを読み出し、前記読み出したデータ
の前記第1の削除領域に対応する箇所に所定のデータパターンを上書きし、前記上書きさ
れたデータを前記第2領域とは別であって前記不揮発性メモリ上の前記管理単位に対応す
る第3領域に書き込むコントローラとを
備えたメモリシステム。
Non-volatile memory;
A storage unit including a logical-physical conversion table that holds a correspondence between a logical address designated by a host and a physical address on the nonvolatile memory for each management unit;
The management unit including a first deletion area that is less than the management unit among the deletion areas when a deletion notification in which a deletion area is specified by a logical address is received from the host with a data amount smaller than the management unit as a unit The data in the second area on the nonvolatile memory corresponding to the first area corresponding to the logical-physical conversion table in the logical-physical conversion table is read, and a predetermined data pattern is applied to the location corresponding to the first deletion area of the read data A memory system comprising: a controller for overwriting and writing the overwritten data in a third area corresponding to the management unit on the non-volatile memory separately from the second area.
前記コントローラは、前記削除通知を受け取った場合に、前記削除領域のうち前記管理
単位に対応する第2削除領域と前記論物変換テーブルにおいて対応する物理アドレスが保
存されている前記論物変換テーブル内の領域に無効値を書き込む請求項1に記載のメモリ
システム。
When the controller receives the deletion notification, the controller deletes a second deletion area corresponding to the management unit in the deletion area and a physical address corresponding to the logical-physical conversion table in the logical-physical conversion table. The memory system according to claim 1, wherein an invalid value is written in the area.
前記コントローラは、前記不揮発性メモリ上の前記管理単位に対応する第4領域から読
み出したデータが前記所定のデータパターンである場合、前記第4領域に対応する物理ア
ドレスが保存されている前記論物変換テーブル内の領域に無効値を書き込む請求項1乃至
請求項2の何れか1項に記載のメモリシステム。
When the data read from the fourth area corresponding to the management unit on the nonvolatile memory is the predetermined data pattern, the controller stores the physical address corresponding to the fourth area. The memory system according to claim 1, wherein an invalid value is written in an area in the conversion table.
前記コントローラは、前記論物変換テーブルにおいて対応する物理アドレスが保存され
る領域に無効値が書き込まれた論理アドレスを指定した読み出し要求を前記ホストから受
信した場合、前記所定のデータパターンを読み出しデータとして前記ホストに送信する請
求項1乃至請求項3の何れか1項に記載のメモリシステム。
When the controller receives a read request designating a logical address in which an invalid value is written in an area in which the corresponding physical address is stored in the logical-physical conversion table, the predetermined data pattern is used as read data. The memory system according to any one of claims 1 to 3, wherein the memory system is transmitted to the host.
前記管理単位はページ単位である請求項1乃至請求項4の何れか1項に記載のメモリシ
ステム。
The memory system according to any one of claims 1 to 4, wherein the management unit is a page unit.
前記削除通知はセクタ単位の論理アドレスにより削除領域が指定されている請求項1乃
至請求項5の何れか1項に記載のメモリシステム。
The memory system according to any one of claims 1 to 5, wherein a deletion area is designated in the deletion notification by a logical address in a sector unit.
不揮発性メモリの制御方法であって、
ホストが指定する論理アドレスと前記不揮発性メモリ上での物理アドレスとの対応を保
持する論物変換テーブルを管理単位毎に管理し、
前記管理単位より小さいデータ量を単位として論理アドレスにより削除領域が指定され
た削除通知を前記ホストから受け取った場合に、
前記削除領域のうち前記管理単位に満たない第1削除領域を含み前記管理単位に対応す
る第1領域と前記論物変換テーブルにおいて対応する前記不揮発性メモリ上の第2領域の
データを読み出し、
前記読み出したデータの前記第1削除領域に対応する箇所に所定のデータパターンを上
書きし、前記上書きされたデータを前記第2領域とは別であって前記不揮発性メモリ上の
前記管理単位に対応する第3領域に書き込む
制御方法。
A non-volatile memory control method comprising:
Manage the logical-physical conversion table that holds the correspondence between the logical address specified by the host and the physical address on the nonvolatile memory for each management unit,
When a deletion notification in which a deletion area is designated by a logical address with a data amount smaller than the management unit as a unit is received from the host,
Read the data of the first area corresponding to the management unit and the second area on the nonvolatile memory corresponding to the logical-physical conversion table including the first deletion area that is less than the management unit among the deletion areas,
A predetermined data pattern is overwritten at a location corresponding to the first deletion area of the read data, and the overwritten data is different from the second area and corresponds to the management unit on the nonvolatile memory. Control method for writing to the third area.
前記削除通知を受け取った場合に、前記削除領域のうち前記管理単位に対応する第2削
除領域と前記論物変換テーブルにおいて対応する物理アドレスが保存されている前記論物
変換テーブル内の領域に無効値を書き込む請求項7に記載の不揮発性メモリの制御方法。
When the deletion notification is received, the second deletion area corresponding to the management unit in the deletion area and the area in the logical-physical conversion table in which the physical address corresponding to the logical-physical conversion table is stored are invalid. The method for controlling a nonvolatile memory according to claim 7, wherein a value is written.
前記不揮発性メモリ上の前記管理単位に対応する第4領域から読み出したデータが前記
所定のデータパターンである場合、前記第4領域に対応する物理アドレスが保存されてい
る前記論物変換テーブル内の領域に無効値を書き込む請求項7乃至請求項8の何れか1項
に記載の不揮発性メモリの制御方法。
When the data read from the fourth area corresponding to the management unit on the nonvolatile memory is the predetermined data pattern, the physical address corresponding to the fourth area is stored in the logical-physical conversion table. The non-volatile memory control method according to claim 7, wherein an invalid value is written in the area.
前記論物変換テーブルにおいて対応する物理アドレスが保存される領域に無効値が書き
込まれた論理アドレスを指定した読み出し要求を前記ホストから受信した場合、前記所定
のデータパターンを読み出しデータとして前記ホストに送信する請求項7乃至請求項9の
何れか1項に記載の不揮発性メモリの制御方法。
When a read request specifying a logical address in which an invalid value is written in an area where the corresponding physical address is stored in the logical-physical conversion table is received from the host, the predetermined data pattern is transmitted to the host as read data The method for controlling a nonvolatile memory according to any one of claims 7 to 9.
前記管理単位はページ単位である請求項7乃至請求項10の何れか1項に記載の不揮発
性メモリの制御方法。
The method for controlling a nonvolatile memory according to claim 7, wherein the management unit is a page unit.
前記削除通知はセクタ単位の論理アドレスにより削除領域が指定されている請求項7乃
至請求項11の何れか1項に記載の不揮発性メモリの制御方法。
The non-volatile memory control method according to claim 7, wherein the deletion notification has a deletion area specified by a logical address in units of sectors.
JP2014140953A 2014-07-08 2014-07-08 Memory system and method of controlling nonvolatile memory Pending JP2014222528A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2014140953A JP2014222528A (en) 2014-07-08 2014-07-08 Memory system and method of controlling nonvolatile memory

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2014140953A JP2014222528A (en) 2014-07-08 2014-07-08 Memory system and method of controlling nonvolatile memory

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2011070852A Division JP5581256B2 (en) 2011-03-28 2011-03-28 Memory system, controller, and control method of memory system

Publications (1)

Publication Number Publication Date
JP2014222528A true JP2014222528A (en) 2014-11-27

Family

ID=52121983

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2014140953A Pending JP2014222528A (en) 2014-07-08 2014-07-08 Memory system and method of controlling nonvolatile memory

Country Status (1)

Country Link
JP (1) JP2014222528A (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109240938A (en) * 2017-07-11 2019-01-18 东芝存储器株式会社 Storage system and the control method for controlling nonvolatile memory
JP2019082817A (en) * 2017-10-30 2019-05-30 東芝メモリ株式会社 Computer system and control method

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070113029A1 (en) * 2005-11-14 2007-05-17 Sandisk Corporation Structures for the management of erase operations in non-volatile memories
JP2007140733A (en) * 2005-11-16 2007-06-07 Renesas Technology Corp Semiconductor processor and semiconductor integrated circuit
WO2010111694A2 (en) * 2009-03-27 2010-09-30 Sandforce Inc. Storage system logical block address de-allocation management and data hardening

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070113029A1 (en) * 2005-11-14 2007-05-17 Sandisk Corporation Structures for the management of erase operations in non-volatile memories
JP2007140733A (en) * 2005-11-16 2007-06-07 Renesas Technology Corp Semiconductor processor and semiconductor integrated circuit
WO2010111694A2 (en) * 2009-03-27 2010-09-30 Sandforce Inc. Storage system logical block address de-allocation management and data hardening

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109240938A (en) * 2017-07-11 2019-01-18 东芝存储器株式会社 Storage system and the control method for controlling nonvolatile memory
JP2019082817A (en) * 2017-10-30 2019-05-30 東芝メモリ株式会社 Computer system and control method
JP7074454B2 (en) 2017-10-30 2022-05-24 キオクシア株式会社 Computer system and control method
US11669444B2 (en) 2017-10-30 2023-06-06 Kioxia Corporation Computing system and method for controlling storage device

Similar Documents

Publication Publication Date Title
JP5581256B2 (en) Memory system, controller, and control method of memory system
US11593259B2 (en) Directed sanitization of memory
US9229876B2 (en) Method and system for dynamic compression of address tables in a memory
US9448919B1 (en) Data storage device accessing garbage collected memory segments
JP6016137B2 (en) Solid state drive and method of operation thereof
JP5418808B2 (en) Adaptive hybrid density memory storage control method and adaptive hybrid density memory storage
JP5550741B1 (en) Storage apparatus, storage controller and method for rearranging data in solid state drive
EP2955633B1 (en) Data erasing method and device for flash memory
US20120290779A1 (en) Data management in solid-state storage devices and tiered storage systems
US8516182B2 (en) Controller and memory system for managing data
US20190188130A1 (en) Data Storage Device and Non-Volatile Memory Control Method
US20100318726A1 (en) Memory system and memory system managing method
JP6142860B2 (en) Disk array device, disk control device, solid state drive, disk control method, and program therefor
US10235284B2 (en) Memory system
JP2015191336A (en) Memory controller, information processor, control method of information processor and program
KR20160139864A (en) Non-volatile memory system
US20100180072A1 (en) Memory controller, nonvolatile memory device, file system, nonvolatile memory system, data writing method and data writing program
JP4829202B2 (en) Storage device and memory control method
JP2014222528A (en) Memory system and method of controlling nonvolatile memory
JP2018185842A (en) Memory control device and information processing system
US8850160B2 (en) Adaptive write behavior for a system having non-volatile memory
JP2013200688A (en) Memory system and control method for the same
TW201624491A (en) Information processing device and non-transitory computer readable recording medium
KR20110089972A (en) Memory apparatus
JP2020119361A (en) Flash storage, computer, data erasure method for flash storage and flash storage control program

Legal Events

Date Code Title Description
RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7422

Effective date: 20150216

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20150218

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20150306

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20150410

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20151002