KR102445057B1 - Method of destroying privacy data in a nand flash memory - Google Patents
Method of destroying privacy data in a nand flash memory Download PDFInfo
- Publication number
- KR102445057B1 KR102445057B1 KR1020200170824A KR20200170824A KR102445057B1 KR 102445057 B1 KR102445057 B1 KR 102445057B1 KR 1020200170824 A KR1020200170824 A KR 1020200170824A KR 20200170824 A KR20200170824 A KR 20200170824A KR 102445057 B1 KR102445057 B1 KR 102445057B1
- Authority
- KR
- South Korea
- Prior art keywords
- personal information
- memory
- destroy
- data
- program
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/70—Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer
- G06F21/78—Protecting specific internal or peripheral components, in which the protection of a component leads to protection of the entire computer to assure secure storage of data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
- G06F21/6245—Protecting personal data, e.g. for financial or medical purposes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2221/00—Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/21—Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F2221/2143—Clearing memory, e.g. to prevent the data from being stolen
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Software Systems (AREA)
- Health & Medical Sciences (AREA)
- Bioethics (AREA)
- General Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
- Databases & Information Systems (AREA)
- Read Only Memory (AREA)
- Storage Device Security (AREA)
Abstract
개인 정보 폐기 방법은 부분 덮어 쓰기, SLC 프로그램 작업, 및 삭제 작업 펄스 적용 중 적어도 하나를 포함한다. 개인 정보 폐기 방법은, 개인 정보를 포함하는 삭제할 메모리 블록의 데이터의 프로그램 상태를 획득하고, 상기 개인 정보에 해당하는 프로그램 상태와 같거나 높은 상태의 데이터가 생성되고, 상기 생성된 데이터를 이용하여 상기 개인 정보에 대하여 부분 덮어쓰기 동작을 수행하는 단계를 포함한다.The personal information destruction method includes at least one of a partial overwrite, an SLC program operation, and a delete operation pulse application. In the personal information disposal method, a program state of data of a memory block to be deleted including personal information is obtained, data having the same or higher program state corresponding to the personal information is generated, and the generated data is used to and performing a partial overwrite operation on personal information.
Description
본 발명은 낸드 플래시 메모리에서 개인 정보 폐기 방법에 관한 것이다.The present invention relates to a method of discarding personal information in a NAND flash memory.
비휘발성 메모리는 덮어 쓸 수 있는 메모리와 그렇지 않은 메모리로 나뉜다. NAND 플래시 메모리는 덮어 쓸 수 없는 메모리이다. NAND 플래시 메모리는 기본적으로 적용된 전압에 따라 트랩 전하를 이동하여 임계 전압을 조정한다. 조정된 임계 전압에 해당하는 데이터가 결정된다. 또한 관리 측면에서 NAND 플래시 메모리는 쓰기 단위와 삭제 단위가 다르기 때문에 삭제와 관련된 잔여 데이터에 대한 문제가 있다. 일반적으로 유효 데이터는 쓰레기 수집(garbage collection)을 통해 하나의 블록으로 수집되며, 내부적으로 특정 기준에 도달하면 나머지 유효 데이터는 블록 단위로 지워진다. 그러나 NAND 플래시 메모리의 특성상 NAND 플래시 메모리는 사용자가 데이터를 삭제하더라도 디지털 포렌식을 통해 의미 있는 정보를 쉽게 얻을 수 있다. 디지털 포렌식은 쉽기 때문에 누구나 디지털 포렌식을 통해 사용자와 관련된 정보를 불법적으로 얻을 수 있다. 이 정보가 개인 정보라면 문제는 분명하다.Non-volatile memory is divided into overwriteable memory and non-overwriteable memory. NAND flash memory is memory that cannot be overwritten. NAND flash memory adjusts the threshold voltage by basically shifting the trap charge according to the applied voltage. Data corresponding to the adjusted threshold voltage is determined. In addition, in terms of management, NAND flash memory has a problem with respect to the residual data related to deletion because the write unit and the erase unit are different. In general, valid data is collected in one block through garbage collection, and when a certain criterion is reached internally, the remaining valid data is erased in block units. However, due to the characteristics of NAND flash memory, even if a user deletes data, meaningful information can be easily obtained through digital forensics. Because digital forensics is easy, anyone can illegally obtain information related to users through digital forensics. If this information is personal information, the problem is obvious.
기존 NAND 플래시 메모리는 덮어 쓸 수 없다. 따라서 사용자가 NAND 플래시 메모리에 저장된 개인 정보를 삭제하더라도 원래 데이터 유형이 여전히 남아있을 가능성은 상당하다. 최근 데이터 센터는 NAND 플래시 메모리를 사용하는 SSD를 사용하고 있으며, 이는 데이터 센터의 SSD에 개인 정보 보호 데이터가 보호되지 않을 가능성이 높다. 당연히 개인 정보 삭제 의무는 NAND 플래시 메모리에도 적용된다.Existing NAND flash memory cannot be overwritten. Therefore, even if a user deletes personal information stored in NAND flash memory, the chances of the original data type still remaining are significant. Recently, data centers are using SSDs that use NAND flash memory, which is likely to not protect privacy data on SSDs in data centers. Naturally, the obligation to delete personal information also applies to NAND flash memory.
삭제 작업이 아닌 덮어 쓰기 가능한 프로그램 작업을 사용하여 개인 정보를 파기하는 방법을 도입했다. 기존에 원샷 프로그래밍으로 MLC(Multi Level Cell) 데이터를 삭제하는 간단한 방법을 제시했다. 그러나 원샷 프로그래밍 방식은 NAND 플래시 메모리의 저장 용량을 변경하는 문제가 있다. MLC 페이지 수에서 SLC(Single Level Cell) 페이지로 변경되기 때문에 한 메모리 블록의 페이지 수가 갑자기 감소한다. 이것은 저장 용량의 크기를 변경하는 것을 의미한다. 따라서 이 접근 방식은 관리 관점에서 사용되기 어렵다.Introduced methods of destroying personal information using overwriteable program operations rather than delete operations. Previously, a simple method of deleting MLC (Multi Level Cell) data with one-shot programming was presented. However, the one-shot programming method has a problem of changing the storage capacity of the NAND flash memory. Because the number of MLC pages is changed to SLC (Single Level Cell) pages, the number of pages in one memory block suddenly decreases. This means changing the size of the storage capacity. Therefore, this approach is difficult to use from a management point of view.
따라서, 셀 특성에 영향을 주지 않고, 빠르게 개인 정보를 폐기하는 기술이 요구되고 있다.Accordingly, there is a need for a technique for rapidly disposing of personal information without affecting cell characteristics.
본원 발명이 해결하고자 하는 과제는 셀 특성에 영향을 주지 않고 빠르게 개인 정보를 폐기하는 방법을 제공하는 것이다.The problem to be solved by the present invention is to provide a method of rapidly disposing of personal information without affecting cell characteristics.
해결하고자 하는 과제를 달성하기 위하여 본 발명의 실시예들에 따른 개인 정보 폐기 방법은, 개인 정보를 포함하는 삭제할 메모리 블록의 데이터의 프로그램 상태를 획득하는 단계, 상기 개인 정보에 해당하는 프로그램 상태와 같거나 높은 상태의 데이터가 생성되는 단계, 및 상기 생성된 데이터를 이용하여 상기 개인 정보에 대하여 부분 덮어쓰기 동작을 수행하는 단계를 포함한다.In order to achieve the object to be solved, a method of disposing of personal information according to embodiments of the present invention includes the steps of obtaining a program state of data of a memory block to be deleted including personal information, the same as the program state corresponding to the personal information or generating high-state data, and performing a partial overwrite operation on the personal information using the generated data.
해결하고자 하는 과제를 달성하기 위하여 본 발명의 실시예들에 따른 개인 정보 폐기 방법은, 개인 정보를 포함하는 삭제할 메모리 블록 내 포함된 유효하지 않은 페이지에 대하여, on-the-fly 무효 페이지 프로그램 작업을 수행하는 단계를 포함하되, 상기 on-the-fly 무효 페이지 프로그램 작업은 임의의 임계 전압을 기반으로 단일 레벨 셀(Single Level Cell: SLC) 프로그램 동작을 수행한다.In order to achieve the object to be solved, a personal information disposal method according to embodiments of the present invention performs an on-the-fly invalid page program operation for an invalid page included in a memory block to be deleted including personal information. and performing the on-the-fly invalid page program operation to perform a single level cell (SLC) program operation based on an arbitrary threshold voltage.
해결하고자 하는 과제를 달성하기 위하여 본 발명의 실시예들에 따른 개인 정보 폐기 방법은, 개인 정보를 포함하는 삭제할 메모리 블록 내 포함된 유효하지 않은 페이지에 해당하는 워드 라인에 삭제 작업 펄스(Deletion Duty Pulse)를 인가하는 단계를 포함하되, 상기 삭제 작업 펄스는 통과 전압(Vpass)보다 크며, 상기 삭제 작업 펄스의 수는 ECC(Error Correction Code) 기술의 오류 수정 수준을 초과하도록 결정된다.In order to achieve the object to be solved, a method for disposing personal information according to embodiments of the present invention includes a deletion duty pulse (Deletion Duty Pulse) in a word line corresponding to an invalid page included in a memory block to be deleted including personal information. ), wherein the erasing pulse is greater than a pass voltage (Vpass), and the number of erasing pulses is determined to exceed an error correction level of an Error Correction Code (ECC) technology.
본 발명의 실시예들에 따르면, 기존 NAND 플래시 메모리에 즉시 적용할 수 있으며, 셀 특성에 영향을 주지 않고 간단하고 빠른 개인 정보 폐기가 가능하다. According to embodiments of the present invention, it can be immediately applied to an existing NAND flash memory, and simple and fast personal information disposal is possible without affecting cell characteristics.
또한, 기존 삭제 작업에 비해 메모리 성능 저하를 크게 줄이고 시간과 비용 측면에서 상당한 효과를 기대한다.In addition, compared to the conventional delete operation, the memory performance degradation is greatly reduced, and a significant effect is expected in terms of time and cost.
본 발명의 상세한 설명에서 인용되는 도면을 보다 충분히 이해하기 위하여 각 도면의 상세한 설명이 제공된다.
도 1은 NAND 플래시 메모리의 개인 정보를 파기하는 지침을 설명하는 순서도이다.
도 2는 프리 블록을 형성하기 위한 쓰레기 수집을 나타내는 블록도이다.
도 3은 관리할 수 없는 개인 정보를 보여주는 블록도이다.
도 4는 NAND 플래시 메모리의 데이터 변조를 보여주는 블록도이다.
도 5는 3-레벨 셀 프로그램에서 상태 매핍을 보여주는 블록도이다.
도 6은 덮어쓰기 가능한 데이터를 보여주는 일 예에 따른 블록도이다.
도 7은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 모식도이다.
도 8은 on-the fly 무효 페이지 프로그램을 보여주는 모식도이다.
도 9는 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 모식도이다.
도 10은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 모식도이다.
도 11은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 수행하는 장치를 설명하기 위한 모식도이다.A detailed description of each drawing is provided in order to more fully understand the drawings recited in the Detailed Description of the Invention.
1 is a flowchart illustrating instructions for destroying personal information in a NAND flash memory.
2 is a block diagram illustrating garbage collection for forming a free block.
3 is a block diagram showing unmanageable personal information.
4 is a block diagram illustrating data modulation of a NAND flash memory.
Fig. 5 is a block diagram showing state poverty in a three-level cell program.
6 is a block diagram illustrating overwriteable data according to an example.
7 is a schematic diagram for explaining a method of discarding personal information according to an embodiment of the present invention.
8 is a schematic diagram showing an on-the fly invalid page program.
9 is a schematic diagram for explaining a method of discarding personal information according to an embodiment of the present invention.
10 is a schematic diagram for explaining a method of discarding personal information according to an embodiment of the present invention.
11 is a schematic diagram for explaining an apparatus for performing a method for discarding personal information according to an embodiment of the present invention.
본 명세서에 개시되어 있는 본 발명의 개념에 따른 실시예들에 대해서 특정한 구조적 또는 기능적 설명들은 단지 본 발명의 개념에 따른 실시예들을 설명하기 위한 목적으로 예시된 것으로서, 본 발명의 개념에 따른 실시예들은 다양한 형태들로 실시될 수 있으며 본 명세서에 설명된 실시예들에 한정되지 않는다.Specific structural or functional descriptions of the embodiments according to the concept of the present invention disclosed herein are only exemplified for the purpose of explaining the embodiments according to the concept of the present invention, and the embodiment according to the concept of the present invention These may be embodied in various forms and are not limited to the embodiments described herein.
본 발명의 개념에 따른 실시예들은 다양한 변경들을 가할 수 있고 여러 가지 형태들을 가질 수 있으므로 실시예들을 도면에 예시하고 본 명세서에서 상세하게 설명하고자 한다. 그러나, 이는 본 발명의 개념에 따른 실시예들을 특정한 개시 형태들에 대해 한정하려는 것이 아니며, 본 발명의 사상 및 기술 범위에 포함되는 모든 변경, 균등물, 또는 대체물을 포함한다.Since the embodiments according to the concept of the present invention may have various changes and may have various forms, the embodiments will be illustrated in the drawings and described in detail herein. However, this is not intended to limit the embodiments according to the concept of the present invention to specific disclosed forms, and includes all modifications, equivalents, or substitutes included in the spirit and scope of the present invention.
제1 또는 제2 등의 용어는 다양한 구성 요소들을 설명하는데 사용될 수 있지만, 상기 구성 요소들은 상기 용어들에 의해 한정되어서는 안 된다. 상기 용어들은 하나의 구성 요소를 다른 구성 요소로부터 구별하는 목적으로만, 예컨대 본 발명의 개념에 따른 권리 범위로부터 벗어나지 않은 채, 제1 구성 요소는 제2 구성 요소로 명명될 수 있고 유사하게 제2 구성 요소는 제1 구성 요소로도 명명될 수 있다.Terms such as first or second may be used to describe various elements, but the elements should not be limited by the terms. The above terms are used only for the purpose of distinguishing one component from another, for example without departing from the scope of the inventive concept, a first component may be termed a second component and similarly a second component A component may also be referred to as a first component.
어떤 구성 요소가 다른 구성 요소에 "연결되어" 있다거나 "접속되어" 있다고 언급된 때에는, 그 다른 구성 요소에 직접적으로 연결되어 있거나 또는 접속되어 있을 수도 있지만, 중간에 다른 구성 요소가 존재할 수도 있다고 이해되어야 할 것이다. 반면에, 어떤 구성 요소가 다른 구성 요소에 "직접 연결되어" 있다거나 "직접 접속되어" 있다고 언급된 때에는 중간에 다른 구성 요소가 존재하지 않는 것으로 이해되어야 할 것이다. 구성 요소들 간의 관계를 설명하는 다른 표현들, 즉 "~사이에"와 "바로 ~사이에" 또는 "~에 이웃하는"과 "~에 직접 이웃하는" 등도 마찬가지로 해석되어야 한다.When a component is referred to as being “connected” or “connected” to another component, it may be directly connected or connected to the other component, but it is understood that other components may exist in between. it should be On the other hand, when it is mentioned that a certain element is "directly connected" or "directly connected" to another element, it should be understood that the other element does not exist in the middle. Other expressions describing the relationship between elements, such as "between" and "immediately between" or "neighboring to" and "directly adjacent to", etc., should be interpreted similarly.
본 명세서에서 사용한 용어는 단지 특정한 실시예를 설명하기 위해 사용된 것으로서, 본 발명을 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 명세서에서, "포함하다" 또는 "가지다" 등의 용어는 본 명세서에 기재된 특징, 숫자, 단계, 동작, 구성 요소, 부분품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성 요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.The terms used herein are used only to describe specific embodiments, and are not intended to limit the present invention. The singular expression includes the plural expression unless the context clearly dictates otherwise. In this specification, terms such as “comprise” or “have” are intended to designate that a feature, number, step, operation, component, part, or combination thereof described herein is present, but one or more other features It is to be understood that it does not preclude the possibility of the presence or addition of numbers, steps, operations, components, parts, or combinations thereof.
다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 의미를 갖는 것으로 해석되어야 하며, 본 명세서에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.Unless defined otherwise, all terms used herein, including technical or scientific terms, have the same meaning as commonly understood by one of ordinary skill in the art to which this invention belongs. Terms such as those defined in a commonly used dictionary should be interpreted as having a meaning consistent with the meaning in the context of the related art, and should not be interpreted in an ideal or excessively formal meaning unless explicitly defined in the present specification. does not
이하, 본 명세서에 첨부된 도면들을 참조하여 본 발명의 실시예들을 상세히 설명한다. 그러나, 특허출원의 범위가 이러한 실시예들에 의해 제한되거나 한정되는 것은 아니다. 각 도면에 제시된 동일한 참조 부호는 동일한 부재를 나타낸다.Hereinafter, embodiments of the present invention will be described in detail with reference to the accompanying drawings. However, the scope of the patent application is not limited or limited by these embodiments. Like reference numerals in each figure indicate like elements.
본 발명에 따른 개인 정보 폐기 방법을 설명하기 이전에, 일반적인 개인 정보 폐기 방법에 대한 지침 및 기존의 개인 정보 폐기 방법에 대하여 설명하기로 한다.Before describing the method of disposing of personal information according to the present invention, guidelines for general methods of disposing of personal information and existing methods of disposing of personal information will be described.
일반적으로, 개인 정보 수명주기는 수집, 저장, 저장, 사용/제공, 파기로 구성된다. 개인 정보 폐기는 개인 정보 수명주기의 마지막 단계이다. 미디어 삭제는 크게 Clear/Purge/Destroy로 나눌 수 있다.In general, the personal information life cycle consists of collection, storage, storage, use/provision, and destruction. Disposal of personal data is the final stage of the personal data lifecycle. Media deletion can be divided into Clear/Purge/Destroy.
'Clear'는 소프트웨어나 하드웨어를 사용하여 중요하지 않은 데이터를 덮어 쓰는 기술이다. 이렇게 하면 일반 읽기 또는 쓰기 명령을 사용하여 저장 장치의 새 값을 덮어 쓴다. NAND 플래시 메모리와 같이 덮어 쓰기가 제공되지 않는 장치의 경우 clear는 공장 상태로 설정되었음을 의미한다. 'Purge'는 실험 계획을 사용하여 대상 데이터를 복구할 수 없도록 만드는 물리적 또는 논리적 기술이다. 'destroy'는 실험실 기술을 사용하여 대상 데이터를 복구 불가능하게 만드는 동시에 데이터 저장 매체 역할을 하지 않는 것을 의미한다.'Clear' is a technology that overwrites unimportant data using software or hardware. This overwrites the new values on the storage device using normal read or write commands. For devices that do not provide overwrite, such as NAND flash memory, clear means it is set to the factory state. A 'purge' is a physical or logical technique that uses a design of an experiment to make the target data unrecoverable. 'Destroy' means using laboratory techniques to make the subject data unrecoverable while not serving as a data storage medium.
일반적으로 NAND 플래시 메모리의 개인 정보를 파기하는 지침이 있다. 도 1은 NAND 플래시 메모리의 개인 정보를 파기하는 지침을 설명하는 순서도이다.In general, there are guidelines for destroying personal information in NAND flash memory. 1 is a flowchart illustrating instructions for destroying personal information in a NAND flash memory.
도 1에 도시된 바와 같이, NIST(National Institute of Standards and Technology) 표준에 따라 Clear / Purge에 따른 플래시 메모리에 대한 설명이 있다. NIST 표준의 Clear 설명에서 언급했듯이 플래시 메모리 기반 저장 장치는 예비 셀을 포함하고 웨어 레벨링(wear leveling)을 수행하더라도 오래된 데이터를 완전히 삭제하지 못할 수 있다. 이는 저장 장치가 중요한 데이터가 저장되는 모든 영역의 직접 주소 지정을 지정하지 않기 때문이다. 여기서 명확한 작업은 소프트웨어/하드웨어 제품을 사용하여 기존 읽기/쓰기 명령에 따라 민감하지 않은 데이터로 주소 지정 가능 공간을 덮어 쓰는 것이다.As shown in FIG. 1 , there is a description of a flash memory according to Clear / Purge according to the National Institute of Standards and Technology (NIST) standard. As mentioned in the clear description of the NIST standard, flash memory-based storage devices may not completely erase old data even if they include spare cells and wear leveling is performed. This is because storage devices do not directly address all areas where sensitive data is stored. The obvious task here is to use a software/hardware product to overwrite the addressable space with non-sensitive data based on existing read/write commands.
NIST 표준은 또한 'Purge'라고 하는 개인 정보 데이터의 폐기를 언급한다. 여기에서 제거 작업에는 덮어 쓰기, 블록 삭제 및 암호화 삭제가 포함된다. 그러나 NAND 플래시 메모리는 일반적으로 덮어 쓰기를 지원하지 않고 주소를 지정할 수 없는 공간에 개인 정보를 저장할 가능성이 높기 때문에 NIST 표준이 개인 정보 폐기를 적절하게 수행했다는 사실을 받아 들이기 어렵다. 주소가 매핑되지 않은 개인 정보는 여전히 NAND 플래시 메모리에 남아 있다.The NIST standard also refers to the destruction of personal information data referred to as a 'purge'. Erase operations here include overwrite, block erase, and cryptographic erase. However, it is difficult to accept the fact that the NIST standard has done a good job of disposing of personal information, as NAND flash memory does not generally support overwriting and most likely stores personal information in non-addressable spaces. Personal information that is not mapped to addresses still resides in NAND flash memory.
일반 플래시 메모리의 경우 불량 블록 등으로 인해 사용자 블록 영역의 여유 블록이 부족하면 여유 블록 영역의 여유 블록을 사용자 블록 영역으로 할당한다. 이때 할당되는 크기는 블록 단위(또는 두 개 이상의 블록)이므로 필요한 저장 공간보다 더 큰 공간이 할당된다. 또한, 여유 블록 영역의 여유 블록은 비교적 짧은 시간에 짧아지고, 플래시 변환 계층은 여유 블록을 확보하기 위해 쓰레기 수집(garbage collection)과 같은 백그라운드 동작을 수행한다.In the case of a general flash memory, if the free blocks in the user block area are insufficient due to bad blocks, etc., the free blocks in the free block area are allocated as the user block area. In this case, since the allocated size is in block units (or two or more blocks), a larger space than the required storage space is allocated. In addition, the free block in the free block area is shortened in a relatively short time, and the flash conversion layer performs a background operation such as garbage collection to secure the free block.
도 2는 프리 블록을 형성하기 위한 쓰레기 수집을 나타내는 블록도이다. 도 2를 참조하면, 쓰레기 수집은, 메모리 어레이에서 특정 블록을 선택하고, 특정 블록의 유효한 페이지를 프리 블록에 복사한 후 블록을 지워서 프리 블록으로 만드는 과정이다.2 is a block diagram illustrating garbage collection for forming a free block. Referring to FIG. 2 , garbage collection is a process in which a specific block is selected from a memory array, valid pages of the specific block are copied to the free block, and then the block is erased to make a free block.
삭제된 블록은 나중에 데이터를 기록하는데 사용할 수 있다. 그러나 내부 정책 상 이러한 블록에 대한 삭제 동작이 빠르게 진행되지 않는 문제가 있다. 이 경우 유효한 페이지에 개인 정보가 포함되어 있으면 유효하지 않은 페이지에 동일한 개인 정보가 포함될 수 있다. 개인 정보는 자유 블록의 유효한 페이지와 삭제할 블록의 유효하지 않은 페이지 모두에 포함된다. 결과적으로 개인 정보는 적어도 두 개의 블록에 포함될 가능성이 있으며, 그 중 하나만 매핑되고 다른 블록은 매핑되지 않은 상태로 유지된다. The erased blocks can be used to write data later. However, there is a problem that the delete operation for these blocks does not proceed quickly due to the internal policy. In this case, if a valid page contains personal information, an invalid page may contain the same personal information. Personal information is included in both valid pages of free blocks and invalid pages of blocks to be deleted. As a result, personal information is likely to be contained in at least two blocks, one of which is mapped and the other remains unmapped.
도 3은 관리할 수 없는 개인 정보를 보여주는 블록도이다. 도 3에 도시된 바와 같이, 기존 쓰레기 수집을 수행하면 관리할 수 없는 개인 정보가 적어도 두 블록에 존재한다. 매핑되지 않은 제1 블록 (BLK1) 및 제2 블록 (BLK2)은 소거 동작이 수행될 때까지 개인 정보를 보유한다.3 is a block diagram showing unmanageable personal information. As shown in FIG. 3 , if the existing garbage collection is performed, personal information that cannot be managed exists in at least two blocks. The unmapped first block BLK1 and the second block BLK2 retain personal information until an erase operation is performed.
우려는 삭제될 블록의 유효하지 않은 페이지에 포함된 개인 정보 데이터를 어떻게 파기하는가 이다. 개인 정보를 폐기하는 가장 간단한 방법 중 하나는 개인 정보가 포함된 유효하지 않은 페이지가 포함된 블록을 즉시 삭제하는 것이다. 그러나, 삭제 동작은 블록 단위로 수행되기 때문에 정책적으로 저장 장치를 관리하기 어렵다. 일반적으로 하나의 블록은 1,024 페이지로 구성된다. 1,024 페이지 중 개인 정보를 저장하는 유효하지 않은 페이지로 인해 한 블록에 대해 지우기 작업을 수행하면 관리 비용이 많이 든다.The concern is how to destroy personal data contained in invalid pages of blocks to be deleted. One of the simplest ways to destroy personal information is to immediately delete blocks containing invalid pages containing personal information. However, since the deletion operation is performed in units of blocks, it is difficult to policyally manage the storage device. In general, one block consists of 1,024 pages. Erasing one block is expensive due to invalid pages storing personal information among 1,024 pages.
기존 NAND 플래시 기술은 덮어 쓰기를 지원하지 않는다. 신뢰할 수 있는 데이터 무효화 방법은 BLK1 및 BLK2에 대해 지우기 작업을 수행하는 것이다. 그러나, 공지된 바와 같이, 소거 동작은 웨어 레벨링 측면에서 메모리 블록에 대한 소거주기의 수가 제한되기 때문에 가능한 한 피해야 할 관리 동작 중 하나이다. 또한, 소거 작업은 많은 양의 전력을 소비하고 소거 시간도 상당하다. 공급 업체의 관점에서는 이러한 지우기 작업이 가능한 한 빨리 발생하지 않도록 하는데 중점을 둔다.Existing NAND flash technology does not support overwriting. A reliable method of invalidating data is to perform erase operations on BLK1 and BLK2. However, as is known, the erase operation is one of the management operations to be avoided as much as possible because the number of erase cycles for the memory block is limited in terms of wear leveling. Also, the erase operation consumes a large amount of power and the erase time is significant. From the vendor's point of view, the focus is on ensuring that these wipes don't happen as quickly as possible.
이러한 공급 업체에 대해 걱정하고 플래시 메모리에서 완전한 개인 정보 데이터를 제거하려는 사용자의 요구를 충족하기 시작했다. 기존의 기술을 요약하면, 기존의 NAND 플래시 메모리 쓰기 방법은 덮어 쓰기를 지원하지 않지만 개인 정보 폐기의 관점에서 접근하기 때문에 유효하지 않은 페이지를 임의의 데이터로 덮어 쓰기 위한 것이다. 물론 여기에 있는 모든 데이터는 현재 저장된 유효하지 않은 페이지에 쓸 수 있는 데이터이어야 한다. 일반적으로 한 페이지 쓰기(프로그램) 작업과 한 블록에 대한 지우기 작업에 필요한 시간이 1,000회 이상 걸리기 때문에 이 방법은 개인 정보 파기 방법으로 매우 효과적이다.These vendors are worried about and are starting to meet the needs of users who want to completely remove their personal data from flash memory. To summarize the existing technology, the existing NAND flash memory writing method does not support overwriting, but it is approached from the point of view of discarding personal information, so that invalid pages are overwritten with random data. Of course, all data here must be writeable to the currently stored invalid page. In general, this method is very effective as a method of destroying personal information because the time required for one page write (program) operation and one block erase operation takes more than 1,000 times.
이하, 본 발명의 일 실시예에 따른 개인 정보 폐기 방법에 대하여 설명하기로 한다. 상기 개인 정보 폐기 방법은 낸드 플래시 메모리 장치의 동작 방법으로 명명될 수도 있다. 또한, 상기 개인 정보 폐기 방법은 낸드 플래시 메모리 장치의 컨트롤러에 의한 동작을 의미할 수 있다.Hereinafter, a method for discarding personal information according to an embodiment of the present invention will be described. The method of disposing of personal information may also be referred to as an operation method of a NAND flash memory device. Also, the personal information disposal method may refer to an operation by a controller of a NAND flash memory device.
데이터 변조(Data Modulation)Data Modulation
일반적으로 데이터는 NAND 플래시 메모리에 원본 데이터 형태로 저장되지 않는다. 프로그래밍할 데이터 간의 간섭으로 인한 데이터 수정 가능성을 최소화하기 위해 원본 데이터는 미리 정해진 규칙에 따라 랜덤화되고 랜덤화된 데이터는 물리적 영역에 저장된다. Generally, data is not stored in NAND flash memory in the form of original data. In order to minimize the possibility of data modification due to interference between the data to be programmed, the original data is randomized according to a predetermined rule, and the randomized data is stored in a physical area.
도 4는 NAND 플래시 메모리의 데이터 변조를 보여주는 블록도이다. 도 4에 도시된 바와 같이, 데이터를 변조하기 위한 인코더와 물리적 영역에서 읽혀진 데이터를 복조하기 위한 디코더가 필수적으로 포함된다.4 is a block diagram illustrating data modulation of a NAND flash memory. As shown in FIG. 4, an encoder for modulating data and a decoder for demodulating data read from the physical domain are essentially included.
프로그램 동작은 오류 널 데이터(error null data)를 변조한 후 변조된 데이터를 메모리 셀에 프로그래밍한다. 읽기 동작은 메모리 셀에서 읽은 데이터를 복조한 후 원본 데이터를 출력할 수 있다. 원본 데이터, 즉 개인 정보에 해당하는 이진 비트는 메모리 셀에 엄격하게 저장되지 않는다. 그러나 변조된 데이터는 메모리 셀에 저장되고 저장된 변조 데이터와 원본 데이터는 소정의 방법으로 상호 교환이 가능하기 때문에 변조된 데이터도 개인 정보로 간주된다.The program operation modulates error null data and then programs the modulated data into the memory cell. The read operation may output original data after demodulating data read from the memory cell. The original data, i.e. the binary bits corresponding to personal information, are not strictly stored in memory cells. However, since the modulated data is stored in a memory cell and the stored modulated data and the original data are interchangeable in a predetermined way, the modulated data is also considered personal information.
상태 situation 매핑mapping (State Mapping)(State Mapping)
데이터 변조 데이터는 메모리 셀의 문턱 전압(Vt)에 대응하는 프로그램 상태에 따라 매핑된다.The data modulated data is mapped according to a program state corresponding to the threshold voltage Vt of the memory cell.
도 5는 3-레벨 셀 프로그램에서 상태 매핑을 보여주는 블록도이다.5 is a block diagram showing state mapping in a three-level cell program.
도 5에 도시된 바와 같이 예를 들어, 3-레벨 셀의 경우 E 상태는 '111', P1 상태는 '011', P2 상태는 '001', P3 상태는 '000', P4 상태는 '010', P5 상태는 '110', P6 상태는 '100', 그리고, P7 상태는 '101'로 각각 매핑된다. 즉, 메모리 셀의 문턱 전압에 해당하는 MSB(Most Significant Bit), CSB(Center Significant Bit), 및 LSB (Least Significant Bit)을 가지고 프로그램 상태가 결정된다.5, for example, in the case of a 3-level cell, the E state is '111', the P1 state is '011', the P2 state is '001', the P3 state is '000', and the P4 state is '010'. ', the P5 state is mapped to '110', the P6 state is mapped to '100', and the P7 state is mapped to '101'. That is, the program state is determined using a Most Significant Bit (MSB), a Center Significant Bit (CSB), and a Least Significant Bit (LSB) corresponding to the threshold voltage of the memory cell.
NAND 플래시 메모리에서 쓰기 동작을 수행하는 것은 각 메모리 셀이 8 개의 임계 전압 중 하나를 갖도록 하는 것을 의미한다. NAND 플래시 메모리는 기본적으로 복수의 메모리 블록을 포함하고, 복수의 메모리 블록 각각은 복수의 페이지를 포함하고, 복수의 페이지 각각은 복수의 메모리 셀을 포함한다. 일반적으로 NAND 플래시 메모리는 페이지 단위로 쓰기 또는 읽기를 수행하고 블록 단위로 소거를 수행한다.Performing a write operation in NAND flash memory means that each memory cell has one of eight threshold voltages. A NAND flash memory basically includes a plurality of memory blocks, each of the plurality of memory blocks includes a plurality of pages, and each of the plurality of pages includes a plurality of memory cells. In general, NAND flash memory performs writing or reading in units of pages and erases in units of blocks.
NAND 플래시 메모리 NAND flash memory 덮어 쓰기overwrite
일반적으로 NAND 플래시 메모리는 덮어 쓸 수 없는 것으로 알려져 있다. 그러나, NAND 플래시 메모리를 부분적으로 덮어 쓸 수 있는 상태가 적어도 하나 있으며, 덮어 쓰기 가능 상태에 해당하는 데이터 비트가 존재한다. 3-레벨 프로그래밍에서는 프로그래밍된 상태가 모두 최상위 상태 P7이 될 가능성이 거의 없다. 랜덤화 기법이 적용되었기 때문에 가장 높은 상태에 해당하는 데이터가 기록될 확률은 1/8 이하이다. 이는 최상위 상태 아래의 상태 중 하나 이상을 덮어 쓸 수 있음을 의미한다.It is generally known that NAND flash memory cannot be overwritten. However, there is at least one state in which the NAND flash memory can be partially overwritten, and data bits corresponding to the overwriteable state exist. In three-level programming, it is unlikely that all of the programmed states will be the highest state P7. Since the randomization technique is applied, the probability that the data corresponding to the highest state will be recorded is less than 1/8. This means that one or more of the states below the top-level state can be overwritten.
덮어 쓸 수 있는 상태state that can be overwritten
상태 매핑에서 언급 한 바와 같이, 각 메모리 셀은 8개 상태 중 어느 하나의 임계전압을 갖는다. NAND 플래시 메모리의 쓰기 동작은 페이지에 해당하는 워드 라인에 순차적으로 전압을 인가하고 해당 비트와 관련된 문턱 전압이 초과되었는지 확인함으로써 반복된다. 이때, 프로그램이 완료된 메모리 셀의 문턱 전압은 최종 상태(P7)가 아닐 가능성이 높기 때문에 최종 상태 (P7)보다 낮은 상태(E 내지 P6)를 덮어 쓸 수 있다. 관심을 갖는 것은 덮어 쓸 수 있는 상태이다.As mentioned in state mapping, each memory cell has a threshold voltage in any one of eight states. The write operation of the NAND flash memory is repeated by sequentially applying a voltage to the word line corresponding to the page and checking whether a threshold voltage associated with the corresponding bit is exceeded. In this case, since it is highly likely that the threshold voltage of the memory cell on which the program is completed is not in the final state P7, states E to P6 lower than the final state P7 may be overwritten. Interesting is a state that can be overwritten.
덮어 쓸 수 있는 데이터data that can be overwritten
상술한 바와 같이 덮어 쓰기가 가능한 상태가 있음을 알 수 있다. 따라서 현재 메모리 셀에 기록된 데이터의 비트가 어느 비트인지 알면 쓰기 가능 상태가 결정되어 쓰기 가능 상태에 대한 덮어 쓰기 가능 데이터를 결정할 수 있다.It can be seen that there is a state in which overwriting is possible as described above. Accordingly, if the bit of data currently written in the memory cell is known, the writable state is determined, so that the overwriteable data for the writable state can be determined.
도 6은 덮어쓰기 가능한 데이터를 보여주는 일 예에 따른 블록도이다. 도 6을 참조하면, 예를 들어, 프로그램된 메모리 셀의 '010'에 해당하는 P4 상태인 경우 덮어 쓰기 가능 상태는 상위 상태, 즉 P5 내지 P7 상태이다. 따라서 메모리 셀에 덮어 쓸 수 있는 데이터는 '110', '100', '101'이다.6 is a block diagram illustrating overwriteable data according to an example. Referring to FIG. 6 , for example, in the case of a state P4 corresponding to '010' of a programmed memory cell, the overwriteable state is an upper state, that is, states P5 to P7. Therefore, the data that can be overwritten in the memory cell is '110', '100', and '101'.
MLC 프로그램 작업에서, 프로그램된 상태보다 높은 상태에 대해 덮어 쓰기가 가능하다는 것이 밝혀졌다. 그러나 이러한 덮어 쓰기는 기본적으로 프로그램 작동을 기반으로 하므로 프로그램 장애가 발생할 수 있다. 여기서, 프로그램 방해는 현재 프로그램 동작에 의해 인접 페이지의 유효한 데이터에 영향을 미친다. 본 발명의 일 실시예에 따른 삭제는 이러한 프로그램 방해의 영향을 최소화하면서 덮어 쓸 수 있도록 한다.In working with MLC programming, it has been found that overwriting is possible for states higher than the programmed state. However, these overwrites are fundamentally based on program behavior, which can lead to program failure. Here, the program interference affects valid data of an adjacent page by the current program operation. Deletion according to an embodiment of the present invention enables overwriting while minimizing the effect of such program interference.
또한, 페이지를 덮어 쓰기 위해서는, 현재 페이지의 데이터를 읽고 읽은 데이터에서 덮어 쓰기 가능 상태를 확인하고 덮어 쓸 데이터를 생성하는 것이 불가피하다. 그러나 위에서 설명한 모든 프로세스에 대한 비용이 NAND 플래시 메모리의 개인 정보를 즉시 파기하는 비용보다 크지 않으면 필연적으로 이 접근 방식을 사용해야 한다.In addition, in order to overwrite a page, it is inevitable to read the data of the current page, check the overwriteable state from the read data, and generate data to be overwritten. However, unless the cost of all the processes described above outweighs the cost of immediately destroying the private information in the NAND flash memory, you should inevitably use this approach.
본 발명의 일 실시예에 따른, 덮어 쓸 수 있는 상태를 사용하는 NAND 플래시 메모리의 개인 정보 데이터 폐기 방법을 설명하기로 한다. 본 발명의 실시예들에 따른 정보 폐기 방법은, 부분 덮어 쓰기 방식, SLC 프로그래밍 방식, 및 삭제 작업 펄스 적용 방식 중 적어도 하나를 포함한다.A method of discarding personal information data of a NAND flash memory using an overwrite state according to an embodiment of the present invention will be described. The method of discarding information according to embodiments of the present invention includes at least one of a partial overwrite method, an SLC programming method, and an erase operation pulse application method.
1. 부분 덮어쓰기(Partial Overwriting)1. Partial Overwriting
삭제할 메모리 블록의 유효하지 않은 데이터에 개인 정보가 포함되어 있다고 가정한다. 개인 정보에 해당하는 바이너리 데이터가 있고 이를 수정하는 데이터가 있을 것이다. 프로그램 상태에 대한 정보는 변조된 데이터의 각 상태 매퍼를 통해 얻을 수 있다. 개인 정보에 해당하는 프로그램 상태를 획득하면, 프로그램된 상태와 같거나 더 높은 상태에 해당하는 데이터가 생성될 수 있다. 그런 다음 이러한 데이터로 유효하지 않은 데이터가 프로그래밍된 페이지에서 쓰기 작업을 수행할 수 있다. 이러한 덮어 쓰기 작업에 의해 개인 정보가 폐기될 수 있다.Assume that the invalid data in the memory block to be deleted contains personal information. There will be binary data corresponding to personal information, and there will be data that corrects it. Information on the program state can be obtained through each state mapper of the modulated data. When a program state corresponding to personal information is obtained, data corresponding to a state equal to or higher than the programmed state may be generated. These data can then be used to write writes to pages that are programmed with invalid data. Personal information may be destroyed by this overwrite operation.
일반적으로 NAND 플래시 메모리의 프로그램 동작은 ISPP(Incremental Step Pulse Programming)에 의해 수행된다. 워드 라인에는 특정 펄스가 인가되고, 각 스텝마다 워드 라인에는 소정의 값만큼 증가된 펄스가 인가된다. 이 작업은 상태가 원하는 임계 전압에 해당할 때까지 반복된다. 초기 프로그램 펄스 (PGM_start) 후에 상태를 확인하기 위해 펄스가 적용되는지 확인한다. 이러한 프로그램 세트가 진행되면 미리 정해진 수의 프로그램 펄스가 인가된 후 펄스가 인가되었는지 확인한다.In general, a program operation of a NAND flash memory is performed by incremental step pulse programming (ISPP). A specific pulse is applied to the word line, and a pulse increased by a predetermined value is applied to the word line at each step. This operation is repeated until the state corresponds to the desired threshold voltage. After the initial program pulse (PGM_start), check whether the pulse is applied to check the status. When such a program set is performed, after a predetermined number of program pulses are applied, it is checked whether the pulses are applied.
도 7은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 모식도이다. 도 7을 참조하면, 위에서 설명한 ISPP를 사용하여 부분 덮어 쓰기를 수행할 수 있다. 초기 덮어 쓰기 펄스(PO_start)는 정상적인 프로그램 작동의 초기 프로그램 펄스(PGM_pulse)보다 높을 것이다. 또한 부분 덮어 쓰기 동작에서 확인 펄스는 정상 프로그램 동작의 확인 펄스 수보다 작게 설정할 수 있다. 이는 대부분의 경우 덮어 쓰기 동작이 수행되는 프로그램 상태가 상대적으로 높은 임계 전압을 가질 것으로 예상되기 때문이다.7 is a schematic diagram for explaining a method of discarding personal information according to an embodiment of the present invention. Referring to FIG. 7 , partial overwriting may be performed using the ISPP described above. The initial overwrite pulse (PO_start) will be higher than the initial program pulse (PGM_pulse) of normal program operation. In addition, the number of confirmation pulses in partial overwrite operation can be set to be smaller than the number of confirmation pulses in normal program operation. This is because, in most cases, the program state in which the overwrite operation is performed is expected to have a relatively high threshold voltage.
다음에서는 예를 들어 부분 덮어 쓰기를 사용하여 개인 식별 번호를 삭제하는 방법에 대해 설명한다. The following describes how to delete a personal identification number using partial overwrite as an example.
표 1은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 표이다.Table 1 is a table for explaining a method of discarding personal information according to an embodiment of the present invention.
States (16)Partial Overwritable
States (16)
P6
P7
P6
P7
P6
P7
P6
P7
P3
P4
P5
P6
P7
P3
P4
P5
P6
P7
P7
P7
P3
P4
P5
P6
P7P2
P3
P4
P5
P6
P7
P4
P5
P6
P7
P4
P5
P6
P7
P7
P7
P6
P7
P6
P7
P4
P5
P6
P7
P4
P5
P6
P7
P3
P4
P5
P6
P7
P3
P4
P5
P6
P7
P7
P7
P4
P5
P6
P7
P4
P5
P6
P7
P3
P4
P5
P6
P7P2
P3
P4
P5
P6
P7
P5
P6
P7
P5
P6
P7
P4
P5
P6
P7
P4
P5
P6
P7
설명의 편의를 위해 개인 식별 번호는 '661004'로 가정한다. 개인 식별 번호는 표 1에서와 같이 2 진수로 변경할 수 있다. 부분 덮어 쓰기 상태가 선택된 표 1의 상태 체인이 선택된다. '661004'에 해당하는 바이너리 비트는 '001101100011011000110001001100000011000000110100'이다. 랜덤 알고리즘을 통해 바이너리 비트를 랜덤화하면 랜덤화된 비트는 '110110001101100011000100110000001100000011010000'이 된다.For convenience of explanation, it is assumed that the personal identification number is '661004'. The personal identification number can be changed to binary as shown in Table 1. The state chain in Table 1 with the partial overwrite state selected is selected. The binary bit corresponding to '661004' is '001101100011011000110001001100000011000000110100'. When binary bits are randomized through a random algorithm, the randomized bits become '110110001101100011000100110000001100000011010000'.
랜덤화된 비트에 해당하는 상태가 선택된다. 선택한 상태는 P5-P5-P2-P7-P6-P1-P3-P6-P5-P3-P2-P6-P3-P1-P4-P3이다. 선택된 각 상태는 페이지의 해당 메모리 셀에 프로그래밍된다. 상술한 바와 같이, 개인 정보에 대응하는 상태에 대한 프로그램 동작은 메모리 셀에서 수행된다. 그 후, 프로그램된 메모리 셀들의 개인 정보 파기 요청에 따라 부분 덮어 쓰기가 다음과 같이 진행될 수 있다.A state corresponding to the randomized bit is selected. The selected state is P5-P5-P2-P7-P6-P1-P3-P6-P5-P3-P2-P6-P3-P1-P4-P3. Each selected state is programmed into the corresponding memory cell of the page. As described above, a program operation for a state corresponding to personal information is performed in the memory cell. Thereafter, partial overwriting may proceed as follows according to a request for destruction of personal information of programmed memory cells.
개인 식별 번호 661004에 대한 부분 덮어 쓰기 가능 상태는 표 1에 표시된 대로 다양한 덮어 쓰기 가능 상태로 구성할 수 있다. 최상위 프로그램 상태 P7에서는 아무 작업도 수행되지 않는다. 따라서 부분 덮어 쓰기를 위해 선택된 프로그램 상태 체인은 P6-P7-P3-P7-P7-P4-P5-P7-P6-P4-P5-P7-P5-P2-P5-P4이다. 따라서 선택된 상태 체인은 메모리 셀에 프로그래밍된다. 부분 덮어 쓰기에 사용할 상태는 무작위로 선택할 수 있다.The partial overwriteable status for personal identification number 661004 is configurable to various overwritable statuses as shown in Table 1. In the top-level program state P7, nothing is done. Therefore, the program state chain selected for partial overwrite is P6-P7-P3-P7-P7-P4-P5-P7-P6-P4-P5-P7-P5-P2-P5-P4. Thus, the selected state chain is programmed into the memory cell. The state to be used for partial overwriting can be randomly selected.
그러나 반드시 이에 한정되는 것은 아니며, 가장 높은 상태 P7로 선택되거나 바로 아래에 있는 상태 P6이 선택 될 수 있다. 부분 덮어 쓰기 상태로 최고 상태 P7이 선택되면 과도한 프로그램 동작으로 인해 메모리 셀이 물리적으로 파기될 가능성이 있음에 유의해야 한다.However, the present invention is not necessarily limited thereto, and the highest state P7 or a state P6 immediately below may be selected. It should be noted that if the highest state P7 is selected as the partial overwrite state, there is a possibility that the memory cell is physically destroyed due to excessive program operation.
부분 덮어 쓰기는 개인 정보 데이터가 성공적으로 삭제되었는지 확인할 수 있다. 부분적으로 덮어 쓴 메모리 셀에서 상태 읽기 작업을 수행할 때 PO 비트는 '100101000101101010110101100010110101110001110010'입니다. derandomized 비트는 '001100010011000000110000001100010011000000110001'이다. 따라서 derandomized 비트에 해당하는 ASCII 값은 '100101'이다. 따라서, 개인 정보 (661004)는 메모리 셀에서 완전히 파기된다.Partial overwrite can ensure that your personal data has been successfully deleted. When performing a read status operation on a partially overwritten memory cell, the PO bit is '100101000101101010110101100010110101110001110010'. The derandomized bit is '001100010011000000110000001100010011000000110001'. Therefore, the ASCII value corresponding to the derandomized bit is '100101'. Accordingly, the personal information 661004 is completely destroyed in the memory cell.
한편, 상기 덮어 쓰기 가능한 상태 중 어느 하나를 선택하는 부담을 줄이기 위해 부분 덮어 쓰기는 특정 프로그램 상태보다 낮은 프로그램 상태로만 진행할 수 있다. 예를 들어, 부분 덮어 쓰기는 제5 프로그램 상태 P5보다 낮은 상태 E, P1, P2, P3 및 P4에 대해 배치 프로그램 동작을 제5 프로그램 P5로 진행시킬 수 있다. 즉, 제5 프로그램 상태(P5)보다 낮은 상태를 갖는 메모리 셀들만이 제5 프로그램 상태(P5)로 프로그램되고, 제5 프로그램 상태(P5)보다 높은 상태를 갖는 메모리 셀들은 현재 상태를 유지한다.Meanwhile, in order to reduce the burden of selecting one of the overwritable states, partial overwriting may be performed only in a program state lower than a specific program state. For example, the partial overwrite may advance the batch program operation to the fifth program P5 for states E, P1, P2, P3, and P4 lower than the fifth program state P5. That is, only memory cells having a state lower than the fifth program state P5 are programmed into the fifth program state P5 , and memory cells having a state higher than the fifth program state P5 maintain their current state.
특정 프로그램 상태를 넘어 부분 덮어 쓰기 상태가 선택되는 표 2의 상태 체인이 선택된다. The state chain in Table 2 is selected where a partial overwrite state is selected beyond a specific program state.
States (16)Partial Overwritable
States (16)
P6
P7
P6
P7
P6
P7
P6
P7
P3
P4
P5
P6
P7
P3
P4
P5
P6
P7
P7
P7
P3
P4
P5
P6
P7P2
P3
P4
P5
P6
P7
P4
P5
P6
P7
P4
P5
P6
P7
P7
P7
P6
P7
P6
P7
P4
P5
P6
P7
P4
P5
P6
P7
P3
P4
P5
P6
P7
P3
P4
P5
P6
P7
P7
P7
P4
P5
P6
P7
P4
P5
P6
P7
P3
P4
P5
P6
P7P2
P3
P4
P5
P6
P7
P5
P6
P7
P5
P6
P7
P4
P5
P6
P7
P4
P5
P6
P7
이 방법에 따르면 부분 덮어 쓰기를 위해 선택된 프로그램 상태 체인은 P5-P7-P5-P5-P5-P5-P5-P6-P5-P5-P5-P6-P5-P6-P5-P5-P5-P5이다. 이러한 상태 체인에 해당하는 PO 비트는 '100101000101101010110101100010110101110001110010'이되며 메모리 셀에 프로그래밍된다. 이 바이너리 코드에 해당하는 ASCII 값은 ' ' '이다. 따라서 개인 정보 데이터는 완전히 파기된다.According to this method, the program state chain selected for partial overwrite is P5-P7-P5-P5-P5-P5-P5-P6-P5-P5-P5-P6-P5-P6-P5-P5-P5-P5 . The PO bit corresponding to this state chain becomes '100101000101101010110101100010110101110001110010' and is programmed into the memory cell. The ASCII value corresponding to this binary code is ' ''to be. Therefore, personal information data is completely destroyed.
상술한 방법은 프로그램될 비트 수를 균등화하기 위해 무작위화 기법을 적용하기 때문에 실질적으로 가능하다. 원본 데이터를 변조할 때 특정 상태(예: 중간 프로그램 상태)의 숫자는 무작위화되기 때문에 나머지 숫자와 유사하다. 따라서 공격자가 이 부분을 덮어 쓰는 역 분석 공격은 소스로 차단된다.The above-described method is practically possible because a randomization technique is applied to equalize the number of bits to be programmed. When tampering with the original data, the numbers in a particular state (such as an intermediate program state) are randomized so they are similar to the rest of the numbers. Therefore, the reverse analysis attack where the attacker overwrites this part is blocked as the source.
2. 2. SLCSLC 프로그램( program( SLCSLC Programming) programming)
일반적으로 NAND 플래시 메모리는 다중 레벨 셀 프로그램 작업을 수행한다. 쓰레기 수집과 같은 작업에 의해 대상 페이지가 무효화되면 해당 메모리 블록을 무효 블록으로 처리하기 전에 개인 정보를 파기하기 위한 즉석 무효 페이지 프로그램 작업이 수행된다. 여기서, 즉석 무효화 페이지 프로그램 동작은 다중 레벨 셀 프로그램 동작이 아닌 특정 참조 레벨을 기반으로 한 단일 레벨 셀 프로그램 동작을 구성한다.In general, NAND flash memory performs multi-level cell programming operations. When a target page is invalidated by an operation such as garbage collection, an on-the-fly invalid page program operation is performed to destroy personal information before treating the memory block as an invalid block. Here, the instant invalidation page program operation constitutes a single-level cell program operation based on a specific reference level rather than a multi-level cell program operation.
도 8은 on-the fly 무효 페이지 프로그램을 보여주는 모식도이고, 도 9는 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 모식도이다.8 is a schematic diagram illustrating an on-the-fly invalid page program, and FIG. 9 is a schematic diagram illustrating a method of discarding personal information according to an embodiment of the present invention.
on-the-fly 무효 페이지 프로그램은 도 8을 참조하여 특정 임계 전압에 기초하여 단일 레벨 셀 프로그램 동작을 수행할 것이다.The on-the-fly invalid page program will perform a single level cell program operation based on a specific threshold voltage with reference to FIG. 8 .
메모리 컨트롤러는 유효하지 않은 블록 처리 이전에 유효하지 않은 페이지에 유효하지 않은 페이지 프로그램을 즉시 강제할 수 있다. 이 즉시 유효하지 않은 페이지 프로그램 작업은 프로그래밍된 다중 수준 셀의 임의 데이터에 대해 단일 수준 셀 프로그램 작업을 수행하여 수행할 수 있다. 개념은 위에서 언급한 부분 덮어 쓰기 기술과 약간 다르다. 부분 덮어 쓰기 기술에서는 세 페이지의 데이터가 생성되고 개인 정보 폐기를 위해 프로그래밍되지만 즉시 유효하지 않은 페이지 프로그래밍 기술은 한 페이지의 데이터만 생성하고 프로그래밍하는데 충분하다. 또한 프로그램의 성공 여부를 확인할 필요가 없다.The memory controller can immediately force an invalid page program to an invalid page before invalid block processing. This immediate invalid page program operation can be accomplished by performing a single-level cell program operation on arbitrary data in the multi-level programmed cell. The concept is slightly different from the partial overwrite technique mentioned above. In partial overwrite techniques, three pages of data are generated and programmed for personal information destruction, whereas page programming techniques that are not immediately valid are sufficient to create and program only one page of data. Also, there is no need to check whether the program is successful or not.
도 9에 도시된 바와 같이, SLC 프로그램(MLC PGM → SLC PGM)을 사용한 즉석 무효 페이지 프로그램 조작이 표시된다. 예를 들어, 도 8에 도시된 바와 같이, 3 단계 셀 프로그램에 의해 저장된 개인 정보는 1 단계 셀 프로그램에 의해 파기된다. 따라서 SLC 프로그래밍 기법이라고 할 수 있다.As shown in Fig. 9, the instantaneous invalid page program operation using the SLC program (MLC PGM → SLC PGM) is displayed. For example, as shown in Fig. 8, personal information stored by the 3-stage cell program is destroyed by the 1-stage cell program. Therefore, it can be called an SLC programming technique.
3. 3. DDPDDP
일반적으로 메모리 셀의 바디 영역에 전원 전압이 인가되더라도 메모리 셀에 연결된 워드 라인에 일정 값 이상의 워드 라인 전압을 인가하면 FN 터널링에 의한 전하 전달이 발생할 수 있다. 이는 유효하지 않은 데이터 폐기 작업이 놀랍도록 쉽게 수행될 수 있음을 의미한다. 즉, 본체 측에 전원 전압을 인가하지 않고 개인 정보가 있는 무효 페이지에 해당하는 워드 라인에 워드 라인 펄스를 인가하면 개인 정보 전체가 쉽게 폐기될 수 있다. 이는 임계 전압이 완전히 알려지지 않은 상태로 변경될 수 있기 때문이다.In general, even when a power voltage is applied to the body region of a memory cell, when a word line voltage of a predetermined value or more is applied to a word line connected to the memory cell, charge transfer by FN tunneling may occur. This means that discarding invalid data can be performed surprisingly easily. That is, if a word line pulse is applied to a word line corresponding to an invalid page having personal information without applying a power voltage to the main body, the entire personal information can be easily discarded. This is because the threshold voltage can change to a completely unknown state.
도 10은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 설명하기 위한 모식도이다.10 is a schematic diagram for explaining a method of discarding personal information according to an embodiment of the present invention.
도 10을 참조하면, 이러한 워드 라인 펄스를 DDP(Deletion Duty Pulses)라고 부른다. 호스트의 요청이나 NAND 플래시 메모리의 자체 요청에 의해 DDP가 유효하지 않은 페이지에 적용될 수 있다. 이러한 DDP를 적용한 후 데이터 상태를 확인할 필요가 없기 때문에 검증 펄스가 필요하지 않다. DDP의 레벨은 통과 전압(Vpass)보다 높을 수 있다. 일반적으로 워드 라인에 통과 전압(Vpass)보다 낮은 전압이 인가되면 채널에서 전하가 전달되지 않는다. 또한 DDP의 수는 실험적으로 결정되어야 한다. 예를 들어, DDP의 수는 종래의 프로그램 펄스의 수 또는 레벨보다 작게 결정될 수 있다. 프로그램 방해를 최소화하기 위해 DDP의 수를 결정할 수 있다.Referring to FIG. 10 , these word line pulses are referred to as deletion duty pulses (DDPs). DDP may be applied to invalid pages either by the host's request or by the NAND flash memory's own request. After applying this DDP, there is no need to check the data state, so no verification pulse is required. The level of the DDP may be higher than the pass voltage Vpass. In general, when a voltage lower than the pass voltage Vpass is applied to the word line, no charge is transferred from the channel. Also, the number of DDPs should be determined experimentally. For example, the number of DDPs may be determined to be smaller than the number or level of conventional program pulses. The number of DDPs can be determined to minimize program interruption.
일반적으로 NAND 플래시 메모리는 데이터 열화로 인한 데이터 수정을 위해 ECC (Error Correction Code) 기술을 사용한다. 삭제 작업 펄스의 수는 이 ECC 기술의 오류 수정 수준을 초과하도록 결정되어야 한다. 이러한 실험적인 DDP의 수는 NAND 칩 제조업체의 셀 특성에 따라 달라진다.In general, NAND flash memory uses ECC (Error Correction Code) technology to correct data due to data degradation. The number of erase operation pulses should be determined to exceed the error correction level of this ECC technique. The number of these experimental DDPs depends on the NAND chip manufacturer's cell characteristics.
개인 정보 파기 요청Request to destroy personal information
호스트로부터 개인 정보 폐기 요청을 수신하면, 메모리 컨트롤러는 NAND 플래시 메모리에서 주소 지정되지 않은 영역(예: BLK1, BLK2)에 대해 유효하지 않은 페이지가 있는 블록을 우선적으로 식별한다. 이후 무효 페이지가 있는 블록에 대해 부분 덮어 쓰기(PO) 동작 또는 작업 펄스 삭제(DDP) 동작이 수행된다.Upon receiving a request to discard personal information from the host, the memory controller preferentially identifies blocks with invalid pages for unaddressed areas (eg BLK1, BLK2) in NAND flash memory. Thereafter, a partial overwrite (PO) operation or a work pulse deletion (DDP) operation is performed on a block with an invalid page.
도 11은 본 발명의 일 실시예에 따른 개인 정보 폐기 방법을 수행하는 저장 장치를 설명하기 위한 모식도이다. 도 11을 참조하면, 저장 장치는 적어도 하나의 비휘발성 메모리 장치(NVM(s))과 그것을 제어하는 메모리 제어기(CNTL)를 포함할 수 있다.11 is a schematic diagram for explaining a storage device for performing a method for discarding personal information according to an embodiment of the present invention. Referring to FIG. 11 , the storage device may include at least one nonvolatile memory device NVM(s) and a memory controller CNTL controlling the same.
또한, 비휘발성 메모리 장치(NVM)는 복수의 메모리 블록들(BLK1 ~ BLKz, z는 2 이상의 정수) 및 제어 로직을 포함하도록 구현될 수 있다. 복수의 메모리 블록들(BLK1 ~ BLKz)의 각각은, 복수의 페이지들(Page 1 ~ Page m, m은 2 이상의 정수)를 포함할 수 있다. 복수의 페이지들(Page 1 ~ Page m)의 각각은, 복수의 메모리 셀들을 포함할 수 있다. 복수의 메모리 셀들의 각각은 적어도 하나의 비트를 저장할 수 있다. Also, the non-volatile memory device NVM may be implemented to include a plurality of memory blocks BLK1 to BLKz, where z is an integer greater than or equal to 2, and control logic. Each of the plurality of memory blocks BLK1 to BLKz may include a plurality of pages (
제어기(CNTL)는 제어 신호들(예를 들어, CLE, ALE, CE(s), WE, RE, 등)을 전송하는 복수의 제어 핀들을 통하여 적어도 하나의 비휘발성 메모리 장치(NVM)에 연결될 수 있다. 또한, 제어 신호들(CLE, ALE, CE(s), WE, RE 등)을 이용하여 비휘발성 메모리 장치(NVM)를 제어하도록 구현될 수 있다. 예를 들어, 비휘발성 메모리 장치(NVM)는 CLE(command latch enable) 신호 및 ALE(address latch enable) 신호에 따라 WE(write enable) 신호의 엣지에서 커맨드(CMD) 혹은 어드레스(ADD)를 래치 함으로써, 프로그램 동작/리드 동작/이레이즈 동작을 수행할 수 있다.The controller CNTL may be connected to at least one non-volatile memory device NVM through a plurality of control pins that transmit control signals (eg, CLE, ALE, CE(s), WE, RE, etc.). have. Also, it may be implemented to control the nonvolatile memory device NVM using control signals CLE, ALE, CE(s), WE, RE, etc.). For example, a nonvolatile memory device (NVM) latches a command (CMD) or an address (ADD) at the edge of a write enable (WE) signal according to a command latch enable (CLE) signal and an address latch enable (ALE) signal. , program operation/read operation/erase operation can be performed.
제어기(CNTL)는 적어도 하나의 프로세서를 포함할 수 있다. 프로세서는 저장 장치의 전반적인 동작을 제어하도록 구현될 수 있다. 프로세서는 캐시/버퍼 관리, 펌웨어 관리, 가비지 컬렉션 관리, 웨어 레벨링 관리, 데이터 중복 제거 관리, 리드 리프레쉬/리클레임 관리, 배드 블록 관리, 멀티-스트림 관리, 호스트 데이터와 비휘발성 메모리의 맵핑 관리, QoS(quality of service) 관리, 시스템 리소스 할당 관리, 비휘발성 메모리 큐(queue) 관리, 리드 레벨 관리, 소거/프로그램 관리, 핫/콜드 데이터 관리, 전력 손실 보호 관리, 동적 열관리, 초기화 관리, RAID(redundant array of inexpensive disk) 관리 등과 같은 다양한 관리 동작들을 수행할 수 있다.The controller CNTL may include at least one processor. The processor may be implemented to control the overall operation of the storage device. The processor includes cache/buffer management, firmware management, garbage collection management, wear leveling management, data deduplication management, read refresh/reclaim management, bad block management, multi-stream management, host data and non-volatile memory mapping management, QoS (quality of service) management, system resource allocation management, non-volatile memory queue management, read level management, erase/program management, hot/cold data management, power loss protection management, dynamic thermal management, initialization management, RAID (redundant) management Various management operations such as managing an array of inexpensive disks can be performed.
또한, 비휘발성 메모리 장치(NVM)는 메모리 셀 어레이, 로우 디코더, 페이지 버퍼 회로, 입출력 버퍼 회로, 전압 발생기, 및 제어 로직을 포함할 수 있다. Also, the nonvolatile memory device NVM may include a memory cell array, a row decoder, a page buffer circuit, an input/output buffer circuit, a voltage generator, and control logic.
메모리 셀 어레이는 워드라인들 혹은 선택 라인들을 통해 로우 디코더에 연결될 수 있다. 메모리 셀 어레이는 비트라인들을 통해서 페이지 버퍼 회로에 연결될 수 있다. 메모리 셀 어레이는 복수의 셀 스트링들(cell strings)을 포함할 수 있다. 셀 스트링들의 각각의 채널은 수직 혹은 수평 방향으로 형성될 수 있다. 셀 스트링들의 각각은 복수의 메모리 셀들을 포함할 수 있다. 여기서, 복수의 메모리 셀들은 비트라인이나, 워드라인으로 제공되는 전압에 의해서 프로그램 되거나, 소거 되거나, 읽혀질 수 있다.The memory cell array may be connected to the row decoder through word lines or selection lines. The memory cell array may be connected to the page buffer circuit through bit lines. The memory cell array may include a plurality of cell strings. Each channel of the cell strings may be formed in a vertical or horizontal direction. Each of the cell strings may include a plurality of memory cells. Here, the plurality of memory cells may be programmed, erased, or read by a voltage applied to a bit line or a word line.
로우 디코더는 수신된 어드레스에 응답하여 메모리 셀 어레이의 메모리 블록들(BLK1 ~ BLKz) 중 어느 하나를 선택하도록 구현될 수 있다. 로우 디코더는 어드레스에 응답하여 선택된 메모리 블록의 워드라인들 중 어느 하나를 선택할 수 있다. 로우 디코더는 선택된 메모리 블록의 워드라인에 동작 모드에 대응하는 워드라인 전압을 전달할 수 있다. 프로그램 동작시 로우 디코더는 선택 워드라인에 프로그램 전압과 검증 전압을 인가하고, 비선택 워드라인에 패스 전압을 인가할 수 있다. 리드 동작시 로우 디코더는 선택 워드라인에 리드 전압을 인가하고, 비선택 워드라인에 리드 패스 전압을 인가할 수 있다.The row decoder may be implemented to select any one of the memory blocks BLK1 to BLKz of the memory cell array in response to the received address. The row decoder may select any one of the word lines of the selected memory block in response to the address. The row decoder may transfer the word line voltage corresponding to the operation mode to the word line of the selected memory block. During a program operation, the row decoder may apply a program voltage and a verify voltage to a selected word line and may apply a pass voltage to an unselected word line. During a read operation, the row decoder may apply a read voltage to a selected word line and may apply a read pass voltage to an unselected word line.
페이지 버퍼 회로는 쓰기 드라이버로 혹은 감지 증폭기로 동작하도록 구현될 수 있다. 프로그램 동작시, 페이지 버퍼 회로는 메모리 셀 어레이의 비트라인들로 프로그램 될 데이터에 대응하는 비트라인 전압을 인가할 수 있다. 리드 동작 혹은 검증 리드 동작시, 페이지 버퍼 회로는 선택된 메모리 셀에 저장된 데이터를 비트라인을 통해서 감지할 수 있다. 페이지 버퍼 회로에 포함되는 복수의 페이지 버퍼들의 각각은 적어도 하나의 비트라인에 연결될 수 있다. 복수의 페이지 버퍼들의 각각은, 리드 동작을 수행하기 위한 센싱 및 래치를 수행하도록 구현될 수 있다.The page buffer circuit may be implemented to operate as a write driver or as a sense amplifier. During a program operation, the page buffer circuit may apply a bit line voltage corresponding to data to be programmed to the bit lines of the memory cell array. During a read operation or a verify read operation, the page buffer circuit may sense data stored in the selected memory cell through a bit line. Each of the plurality of page buffers included in the page buffer circuit may be connected to at least one bit line. Each of the plurality of page buffers may be implemented to perform sensing and latching for performing a read operation.
입출력 버퍼 회로는 외부에서 제공되는 데이터를 페이지 버퍼 회로로 제공할 수 있다. 입출력 버퍼 회로는 외부에서 제공되는 커맨드/어드레스를 제어 로직에 제공할 수 있다. 더불어, 입출력 버퍼 회로는 페이지 버퍼 회로에 의해서 센싱 및 래치된 데이터를 외부로 출력할 수 있다. The input/output buffer circuit may provide externally provided data to the page buffer circuit. The input/output buffer circuit may provide an externally provided command/address to the control logic. In addition, the input/output buffer circuit may output data sensed and latched by the page buffer circuit to the outside.
제어 로직은 외부로부터 전달되는 커맨드에 응답하여 로우 디코더 및 페이지 버퍼 회로를 제어하도록 구현될 수 있다.The control logic may be implemented to control the row decoder and the page buffer circuit in response to a command transmitted from the outside.
전압 발생기는 제어 로직의 제어에 따라 각각의 워드라인들로 인가될 다양한 종류의 워드라인 전압들, 메모리 셀들이 형성된 벌크(예를 들어, 웰 영역)로 공급될 웰 전압을 생성하도록 구현될 수 있다. 각각의 워드라인들로 인가되는 워드라인 전압들은, 프로그램 전압, 패스 전압, 리드 전압, 리드 패스 전압들 등을 포함할 수 있다.The voltage generator may be implemented to generate various types of word line voltages to be applied to the respective word lines and a well voltage to be supplied to a bulk (eg, a well region) in which memory cells are formed according to the control of the control logic. . The word line voltages applied to the respective word lines may include a program voltage, a pass voltage, a read voltage, and read pass voltages.
메모리 블록들 중 어느 하나의 메모리 블록(BLK1)은 3차원 구조로 구현될 수 있다. 메모리 블록은 하나의 비트라인에 연결된 복수의 셀 스트링들을 포함할 수 있다. 복수의 셀 스트링들은 로우 방향(row direction) 및 컬럼 방향(column direction)을 따라 배치되어 로우들 및 컬럼들을 형성할 수 있다.Any one of the memory blocks BLK1 may be implemented in a three-dimensional structure. The memory block may include a plurality of cell strings connected to one bit line. The plurality of cell strings may be disposed along a row direction and a column direction to form rows and columns.
실시예에 있어서, 셀 스트링들은 스트링 선택 라인들와 연결되어, 제 1 로우를 형성할 수 있다. 셀 스트링들은 스트링 선택 라인들와 연결되어 제 2 행을 형성할 수 있다. 복수의 셀 스트링들의 각각은 복수의 셀 트랜지스터들을 포함할 수 있다. 예를 들어, 복수의 셀 스트링들의 각각은 스트링 선택 트랜지스터들, 복수의 메모리 셀들, 접지 선택 트랜지스터들, 및 더미 메모리 셀들을 포함할 수 있다. 복수의 메모리 셀들은 직렬 연결되며, 로우 방향 및 컬럼 방향에 의해 형성된 평명에 수직 방향인 높이 방향(height direction)으로 적층 될 수 있다. 스트링 선택 트랜지스터들은 직렬 연결되고, 직렬 연결된 스트링 선택 트랜지스터들은 복수의 메모리 셀들 및 비트라인 사이에 제공될 수 있다. 접지 선택 트랜지스터들은 직렬 연결되고, 직렬 연결된 접지 선택 트랜지스터들은 복수의 메모리 셀들 및 공통 소스 라인 사이에 제공될 수 있다. 실시예에 있어서, 복수의 메모리 셀들 및 접지 선택 트랜지스터들 사이에 제 1 더미 메모리 셀이 제공될 수 있다. 셀 스트링들의 접지 선택 트랜지스터들은 접지 선택 라인에 공통으로 연결될 수 있다. In an embodiment, the cell strings may be connected to the string selection lines to form a first row. The cell strings may be connected to the string selection lines to form a second row. Each of the plurality of cell strings may include a plurality of cell transistors. For example, each of the plurality of cell strings may include string select transistors, a plurality of memory cells, ground select transistors, and dummy memory cells. The plurality of memory cells are connected in series and may be stacked in a height direction perpendicular to a plane formed by a row direction and a column direction. The string select transistors may be connected in series, and the series connected string select transistors may be provided between the plurality of memory cells and the bit line. The ground select transistors may be connected in series, and the series connected ground select transistors may be provided between the plurality of memory cells and the common source line. In an embodiment, a first dummy memory cell may be provided between the plurality of memory cells and the ground select transistors. The ground select transistors of the cell strings may be commonly connected to the ground select line.
도 11에 도시된 바와 같이, 메모리 컨트롤러는 쓰레기 수집 유닛, 블록 관리 유닛 및 삭제 작업 실행 유닛(DDIB)을 포함할 수 있다. 블록 관리 유닛은 블록 관리 유닛과 비교하여 개인 정보가 저장된 무효 블록을 특별히 관리할 수 있다. 예를 들어, 블록 관리부는 무효 블록에 대한 무효화 페이지의 물리 주소를 저장할 수 있다. 삭제 의무 실행부는 무효화 페이지의 물리적 주소에 개인 정보 파기 기술(예: PO / DDP)을 적용할 수 있다.11 , the memory controller may include a garbage collection unit, a block management unit, and a delete operation execution unit (DDIB). The block management unit may specifically manage an invalid block in which personal information is stored as compared with the block management unit. For example, the block manager may store a physical address of an invalidation page for an invalid block. Deletion Obligation Enforcement Department may apply personal information destruction technology (eg PO / DDP) to the physical address of the invalidation page.
개인 정보 파기 확인Confirmation of personal information destruction
호스트의 개인 정보 삭제 요청에 대한 응답으로 NAND 플래시 메모리는 개인 정보 삭제 작업을 수행할 수 있다. 이후, NAND 플래시 메모리는 개인 정보 파기 요청에 대해 검증 동작을 수행할 수 있다. 개인 정보 파기 요청의 검증 동작은 파기 요청된 개인 정보의 복원할 정보 또는 복원할 정보가 NAND 플래시 메모리의 유효 페이지 또는 무효 페이지에 존재하는지 여부를 결정한다. 예를 들어, 개인 정보와 개인 정보가 변조된 데이터가 NAND 플래시 메모리의 무효화 영역 또는 유효성 검증 영역에 존재하는지 여부를 판단할 수 있다. NAND 플래시 메모리에 개인 정보 또는 개인 정보에 해당하는 데이터가 없으면 개인 정보 파기 요청이 성공한 것으로 판단된다. NAND 플래시 메모리가 호스트에 대한 응답으로 이 사실을 전송 한 후, 기본적으로 개인 정보 폐기를 확인하기 위해서는 매핑되지 않은 메모리 블록과 매핑된 메모리 블록에 대한 개인 정보 검색을 수행해야 한다.In response to the host's request to delete personal information, the NAND flash memory can perform the personal information deletion operation. Thereafter, the NAND flash memory may perform a verification operation on the personal information destruction request. The verification operation of the personal information destruction request determines whether the information to be restored or the information to be restored of the personal information requested to be destroyed exists in a valid page or an invalid page of the NAND flash memory. For example, it may be determined whether personal information and data whose personal information has been tampered with exist in an invalidation area or a validation area of the NAND flash memory. If there is no personal information or data corresponding to personal information in the NAND flash memory, the personal information destruction request is judged to be successful. After the NAND flash memory sends this fact in response to the host, it basically has to perform a private information retrieval for the unmapped and mapped memory blocks to confirm the destruction of personal information.
성능비교Performance Comparison
기존의 Block Erase 방식, 부분 덮어 쓰기, SLC 프로그래밍, DDP 방식의 성능을 비교했다. 여기서 성능에는 NAND 플래시 메모리에서 개인 정보가 폐기될 때까지 메모리 셀의 성능 저하 정도와 경과 시간이 포함된다. 편의를 위해 쓰레기 수집 상황을 비교했다.The performance of the existing Block Erase method, partial overwrite, SLC programming, and DDP method was compared. Here, performance includes the degree of degradation of memory cells and the amount of time that elapses before personal information is discarded from the NAND flash memory. For convenience, the garbage collection situation is compared.
표 3에서, 볼록 삭제 방식(제1 비교예), MLC 방식(Lin's, 제2 비교예), 부분 덮어 쓰기 방식(제1 실시예), SLC 프로그래밍 방식(제2 실시예), 및 DDP 방식(제3 실시예)의 쓰레기 수집 현황 및 개인 정보 파기 시기를 살펴본다.In Table 3, the convex erase method (Comparative Example 1), the MLC method (Lin's, Comparative Example 2), the partial overwrite method (Example 1), the SLC programming method (Example 2), and the DDP method ( Examine the garbage collection status and personal information destruction time of the third embodiment).
Destruction TimePrivacy data
Destruction Time
countPGM
count
countErase
count
SchemeBlock Erase
(until GG, >M*TPGM)x
(until GG, >M*T PGM )
Overwriting
SchemePartial
overwriting
Scheme
Programming
SchemeSLC
Programming
Scheme
두 개의 메모리 블록 사이에 M개의 유효한 페이지와 N개의 유효하지 않은 페이지가 있다고 가정한다. 여기서 M개의 유효한 페이지가 새 메모리 블록에 프로그래밍된다. 두 개의 메모리 블록에 완전히 N개의 유효하지 않은 페이지가 있다고 가정한다. 따라서, 모든 방식에서 M개의 프로그램 동작은 유효한 페이지를 읽기 위한 읽기 동작으로 수행되며, 성능 지수에는 삭제 동작이나 프로그램 동작보다 열화 정도가 떨어지기 때문에 언급되지 않는다. 여기서 a는 지우기 동작으로 인한 셀 저하 정도이고 b는 프로그램 동작으로 인한 셀 저하 정도이다. 일반적으로 a는 b보다 1000 배 더 높다. 즉, 프로그램 동작보다 소거 동작으로 인한 열화 정도가 더 심하다.Assume that there are M valid pages and N invalid pages between two memory blocks. Here, M valid pages are programmed into the new memory block. Assume that there are completely N invalid pages in two memory blocks. Therefore, in all schemes, M program operations are performed as read operations for reading valid pages, and the figure of merit is not mentioned because the degree of degradation is lower than that of an erase operation or a program operation. Here, a is the degree of cell degradation due to the erase operation and b is the degree of cell degradation due to the program operation. In general, a is 1000 times higher than b. That is, the degree of deterioration due to the erase operation is greater than that of the program operation.
블록 소거 방식의 경우 무효화될 두 개의 메모리 블록에 대해 프로그램 동작이 수행되지 않는다. 대신 새 메모리 블록에 대해 M개의 유효한 페이지에서 프로그램 작업이 수행된다. 따라서 무효화될 블록에서 개인 정보를 삭제하기 위해 삭제 동작을 한 번 수행한다. 일반적으로 쓰레기 수집의 블록 지우기 작업은 NAND 플래시 메모리의 내부 정책에 따라 수행된다. 이 내부 정책은 메모리 블록의 수명을 최대화하기 위해 관리된다. 따라서 표 3에서 볼 수 있듯이 다양한 운영 변수에 의해 개인 정보 파기 시간을 예측하는 것은 사실상 불가능하다.In the case of the block erase method, a program operation is not performed on two memory blocks to be invalidated. Instead, the program operation is performed on M valid pages for the new memory block. Therefore, the delete operation is performed once to delete personal information from the block to be invalidated. In general, the block erase operation of garbage collection is performed according to the internal policy of NAND flash memory. This internal policy is managed to maximize the lifetime of a memory block. Therefore, as shown in Table 3, it is virtually impossible to predict the personal information destruction time by various operating variables.
반면 본 발명에 따른 삭제 기법을 적용하여 개인 정보의 파기시기를 예측할 수 있다. 예를 들어 부분 덮어 쓰기 방식의 시간은 M * TPGM + N * TRDG + TPOW, SLC 프로그래밍 방식의 시간은 M * TPGM + N * TSDG + TSLCP, DDP 방식의 시간은 M * TPGM + N * TDDP이다. 여기서 TPGM은 프로그램 작동 시간, TRDG는 임의 데이터 생성 시간, TSDG는 SLC 데이터 생성 시간, T는 덮어 쓰기 시간, TPOW는 SLC 프로그래밍 시간, TDDP는 DDP 적용 시간이다.On the other hand, it is possible to predict the destruction time of personal information by applying the deletion technique according to the present invention. For example, the time of the partial overwrite method is M * TPGM + N * TRDG + TPOW, the time of the SLC programming method is M * TPGM + N * TSDG + TSLCP, and the time of the DDP method is M * TPGM + N * TDDP. where TPGM is the program run time, TRDG is the random data generation time, TSDG is the SLC data generation time, T is the overwrite time, TPOW is the SLC programming time, and TDDP is the DDP application time.
Destruction TimePrivacy data
Destruction Time
countPGM
count
countErase
count
SchemeBlock Erase
(until GG)x
(until GG)
Overwriting
SchemePartial
overwriting
Scheme
Programming
SchemeSLC
Programming
Scheme
요약하면, 본 발명에 따른 실시예에서는 개인 정보 데이터의 파기 시간을 예측할 수 있다. 또한, 하나의 메모리 블록에 대한 셀 열화 정도를 비교하면, 블록 소거 방식은 하나의 소거 동작에 대응하는 열화 정도를 갖는다.In summary, in the embodiment according to the present invention, the destruction time of personal information data can be predicted. Also, comparing the degree of cell degradation for one memory block, the block erase method has a degree of degradation corresponding to one erase operation.
MLC의 접근 방식은 쓰레기 수집 상황이 아닌 업데이트 상황만 고려한다. 이는 MLC의 접근 방식에 따르면 개인 정보가 쓰레기 수집 상황에서 여전히 무효화 블록에 있음을 의미한다.MLC's approach considers only the update situation, not the garbage collection situation. This means that, according to MLC's approach, personal information is still in the invalidation block in a garbage collection situation.
또한 하나의 메모리 블록에 있는 한 페이지의 개인 정보를 업데이트하는 경우를 가정하여 삭제의 성능을 비교했다. 반면 MLC의 방식과 본 발명의 실시예들에 따른 방식은 개인 정보 데이터가 파기될 때까지 삭제 작업을 수행할 필요가 없다. 따라서 개인 정보가 폐기될 때까지 N개 미만의 프로그래밍 작업을 수행한 정도이다.Also, the performance of deletion was compared under the assumption of updating the personal information of one page in one memory block. On the other hand, the MLC method and the method according to the embodiments of the present invention do not need to perform a deletion operation until the personal information data is destroyed. Therefore, it is less than N programming operations until the personal information is discarded.
단일 페이지 업데이트조차도 기존의 블록 지우기는 개인 정보 데이터의 폐기 시간을 예측할 수 없다. 반면에 MLC의 모든 계획과 우리의 계획은 폐기 시간을 예측할 수 있다. 그리고 본 발명의 실시예들에 따른 방식의 경우 개인 정보 폐기까지의 열화 특성도 기존의 삭제 방식보다 우수하다. 예를 들어 표 4에서 볼 수 있듯이 Lin의 방식 시간은 M * TPGM + TONESHOT, 부분 덮어 쓰기 방식의 시간은 M * TPGM + TRDG + TPOW, SLC 프로그래밍 방식의 시간은 M * TPGM + TSDG + TSLCP, DDP 방식의 시간은 M * TPGM + TDDP이다. 여기서 TONESHOT은 원샷 프로그래밍 시간이다.Even a single page update, conventional block erase cannot predict the discard time of personal information data. On the other hand, all of MLC's plans and our plans are predictable for retirement times. And, in the case of the method according to the embodiments of the present invention, the deterioration characteristic until the personal information is discarded is also superior to that of the existing deletion method. For example, as shown in Table 4, Lin's method time is M * TPGM + TONESHOT, partial overwrite method time is M * TPGM + TRDG + TPOW, SLC programming method time is M * TPGM + TSDG + TSLCP, DDP The time of the scheme is M * TPGM + TDDP. where TONESHOT is the one-shot programming time.
본 발명의 실시예들에 따른 방식은 기존의 블록 삭제 방식에 비해 개인 정보의 파기 시간을 크게 줄일 수 있음을 확인했다. 또한 본 발명의 실시예들에 따른 방식은 메모리 셀의 열화 특성 측면에서 많은 장점이 있음을 알 수 있다. 따라서 본 발명의 실시예들에 따른 개인 정보 파기 방법은 기존 NAND 플래시 메모리에 쉽게 적용할 수 있으며 관리 및 경제 측면에서 유용할 수 있다.It was confirmed that the method according to the embodiments of the present invention can significantly reduce the destruction time of personal information compared to the existing block deletion method. In addition, it can be seen that the method according to the embodiments of the present invention has many advantages in terms of deterioration characteristics of the memory cell. Therefore, the personal information destruction method according to the embodiments of the present invention can be easily applied to the existing NAND flash memory and can be useful in terms of management and economy.
본 발명의 일 실시예에 따른 NAND 플래시 메모리에 남아있는 개인 정보를 폐기하는 방법은, 프로그래밍 가능한 상태를 부분적으로 식별하고 부분 덮어 쓰기 방식을 사용하여 개인화된 정보를 식별하는 방법을 포함한다. 삭제 작업 펄스를 여러 번 적용하여 개인 정보를 폐기하는 방법도 제안된다. 또한 SLC 프로그래밍을 사용하여 개인 정보를 파기하는 방법도 있다. 이 NAND 플래시 메모리의 개인 데이터 폐기 방식은 기존 삭제 작업에 비해 메모리 성능 저하를 크게 줄이고 시간과 비용 측면에서 상당한 효과가 있다.A method of discarding personal information remaining in a NAND flash memory according to an embodiment of the present invention includes a method of partially identifying a programmable state and identifying personalized information using a partial overwrite method. A method of destroying personal information by applying a deletion action pulse multiple times is also proposed. There are also ways to destroy personal information using SLC programming. This NAND flash memory's personal data disposal method greatly reduces the degradation of memory performance compared to the conventional erase operation, and has a significant effect in terms of time and cost.
이상에서 설명된 장치는 하드웨어 구성 요소, 소프트웨어 구성 요소, 및/또는 하드웨어 구성 요소 및 소프트웨어 구성 요소의 집합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치 및 구성 요소는, 예를 들어, 프로세서, 콘트롤러, ALU(Arithmetic Logic Unit), 디지털 신호 프로세서(Digital Signal Processor), 마이크로컴퓨터, FPA(Field Programmable array), PLU(Programmable Logic Unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 하나 이상의 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(Operation System, OS) 및 상기 운영 체제 상에서 수행되는 하나 이상의 소프트웨어 애플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술 분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(Processing Element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 콘트롤러를 포함할 수 있다. 또한, 병렬 프로세서(Parallel Processor)와 같은, 다른 처리 구성(Processing Configuration)도 가능하다.The device described above may be implemented as a hardware component, a software component, and/or a set of hardware components and software components. For example, devices and components described in the embodiments may include, for example, a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable array (FPA), It may be implemented using one or more general purpose or special purpose computers, such as a Programmable Logic Unit (PLU), a microprocessor, or any other device capable of executing and responding to instructions. The processing device may execute an operating system (OS) and one or more software applications executed on the operating system. The processing device may also access, store, manipulate, process, and generate data in response to execution of the software. For convenience of understanding, although one processing device is sometimes described as being used, one of ordinary skill in the art will recognize that the processing device includes a plurality of processing elements and/or a plurality of types of processing elements. It can be seen that may include For example, the processing device may include a plurality of processors or one processor and one controller. Other Processing Configurations are also possible, such as a Parallel Processor.
소프트웨어는 컴퓨터 프로그램(Computer Program), 코드(Code), 명령(Instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(Collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성 요소(Component), 물리적 장치, 가상 장치(Virtual Equipment), 컴퓨터 저장 매체 또는 장치, 또는 전송되는 신호 파(Signal Wave)에 영구적으로, 또는 일시적으로 구체화(Embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 하나 이상의 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.The software may include a computer program, code, instructions, or a combination of one or more of these, and configure the processing device to operate as desired or process it independently or in combination (Collectively) You can command the device. The software and/or data may be any type of machine, component, physical device, virtual equipment, computer storage medium or device, to be interpreted by or provide instructions or data to the processing device. , or may be permanently or temporarily embodied in a transmitted signal wave (Signal Wave). The software may be distributed over networked computer systems and stored or executed in a distributed manner. Software and data may be stored in one or more computer-readable recording media.
실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 매체에 기록되는 프로그램 명령은 실시예를 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(Magnetic Media), CD-ROM, DVD와 같은 광기록 매체(Optical Media), 플롭티컬 디스크(Floptical Disk)와 같은 자기-광 매체(Magneto-optical Media), 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다. 상기된 하드웨어 장치는 실시예의 동작을 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.The method according to the embodiment may be implemented in the form of program instructions that can be executed through various computer means and recorded in a computer-readable medium. The computer-readable medium may include program instructions, data files, data structures, etc. alone or in combination. The program instructions recorded on the medium may be specially designed and configured for the embodiment, or may be known and available to those skilled in the art of computer software. Examples of the computer-readable recording medium include magnetic media such as hard disks, floppy disks and magnetic tapes, optical recording media such as CD-ROMs and DVDs, and magnetic media such as floppy disks. - Includes hardware devices specially configured to store and execute program instructions, such as Magneto-optical Media, ROM, RAM, Flash memory, and the like. Examples of program instructions include not only machine language codes such as those generated by a compiler, but also high-level language codes that can be executed by a computer using an interpreter or the like. The hardware devices described above may be configured to operate as one or more software modules to perform the operations of the embodiments, and vice versa.
본 발명은 도면에 도시된 실시예를 참고로 설명되었으나 이는 예시적인 것에 불과하며, 본 기술 분야의 통상의 지식을 가진 자라면 이로부터 다양한 변형 및 균등한 타 실시예가 가능하다는 점을 이해할 것이다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성 요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성 요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다. 따라서, 본 발명의 진정한 기술적 보호 범위는 첨부된 등록청구범위의 기술적 사상에 의해 정해져야 할 것이다.Although the present invention has been described with reference to the embodiment shown in the drawings, which is only exemplary, those skilled in the art will understand that various modifications and equivalent other embodiments are possible therefrom. For example, the described techniques are performed in an order different from the described method, and/or the described components of the system, structure, apparatus, circuit, etc. are combined or combined in a different form than the described method, or other components Or substituted or substituted by equivalents may achieve an appropriate result. Accordingly, the true technical protection scope of the present invention should be determined by the technical spirit of the appended claims.
Claims (19)
개인 정보 파기 요청에 응답하여 상기 복수의 메모리 블록들 중에서 개인 정보가 저장되어 있는 무효 페이지를 포함하는 적어도 하나의 메모리 블록을 식별하는 단계; 및
상기 무효 페이지에 대응하는 워드 라인으로 적어도 하나의 삭제 의무 펄스(Deletion Duty Pulse, DDP)를 인가하여 상기 개인 정보를 삭제하는 단계를 포함하고,
상기 적어도 하나의 삭제 의무 펄스의 개수는 ECC(Error Correction Code)의 오류 정정 수준을 초과하도록 결정되는,
개인 정보 파기 방법.a plurality of cell strings each connected between one bit line and a common source line and including at least one string select transistor, a plurality of memory cells corresponding to each of the word lines, and at least one ground select transistor A method for destroying personal information in a non-volatile memory device including a plurality of memory blocks, the method comprising:
identifying at least one memory block including an invalid page in which personal information is stored from among the plurality of memory blocks in response to a personal information destruction request; and
applying at least one deletion duty pulse (DDP) to a word line corresponding to the invalid page to delete the personal information;
The number of the at least one deletion duty pulse is determined to exceed an error correction level of an Error Correction Code (ECC),
How we destroy your personal information.
상기 개인 정보 파기 요청은 외부의 장치로부터 수신되는,
개인 정보 파기 방법.According to claim 1,
The personal information destruction request is received from an external device,
How we destroy your personal information.
상기 복수의 메모리 셀들 각각은 멀티 레벨 셀이고,
상기 적어도 하나의 삭제 의무 펄스의 개수는 프로그램 동작에서 발생하는 프로그램 펄스의 개수 보다 작은,
개인 정보 파기 방법.According to claim 1,
Each of the plurality of memory cells is a multi-level cell,
The number of the at least one deletion duty pulse is smaller than the number of program pulses generated in the program operation;
How we destroy your personal information.
상기 적어도 하나의 삭제 의무 펄스의 레벨은 프로그램 패스 전압(Vpass)의 레벨보다 큰,
개인 정보 파기 방법.According to claim 1,
The level of the at least one erase duty pulse is greater than the level of the program pass voltage (V pass ),
How we destroy your personal information.
상기 비휘발성 메모리 장치는 낸드 플래시 메모리 장치이고,
상기 개인 정보 파기 요청은 상기 낸드 플래시 메모리 장치 내부적으로 발생되는,
개인 정보 파기 방법.According to claim 1,
The non-volatile memory device is a NAND flash memory device,
The personal information destruction request is generated internally in the NAND flash memory device,
How we destroy your personal information.
상기 개인 정보의 파기 완료에 대한 검증 동작을 수행하는 단계를 더 포함하는,
개인 정보 파기 방법.According to claim 1,
Further comprising the step of performing a verification operation on the completion of the destruction of the personal information,
How we destroy your personal information.
상기 검증 동작을 수행하는 단계는,
상기 개인 정보 또는 상기 개인 정보가 변조된 데이터가 상기 복수의 메모리 블록들 중에서 맵핑된 메모리 블록의 상기 무효 페이지에 존재하는지 여부를 판단하는 단계를 포함하는,
개인 정보 파기 방법.7. The method of claim 6,
The step of performing the verification operation is
Determining whether the personal information or data in which the personal information is modulated exists in the invalid page of a mapped memory block among the plurality of memory blocks;
How we destroy your personal information.
상기 검증 동작을 수행하는 단계는,
상기 개인 정보 또는 상기 개인 정보가 변조된 데이터가 상기 복수의 메모리 블록들 중에서 맵핑된 유효 페이지들에 존재하는지 여부를 판단하는 단계를 포함하는,
개인 정보 파기 방법.7. The method of claim 6,
The step of performing the verification operation is
Comprising the step of determining whether the personal information or the data modulated by the personal information exists in valid pages mapped among the plurality of memory blocks,
How we destroy your personal information.
상기 검증 동작을 수행하는 단계는,
상기 개인 정보 또는 상기 개인 정보가 변조된 데이터가 상기 복수의 메모리 블록들 중에서 맵핑되지 않은 메모리 블록의 상기 무효 페이지에 존재하는지 여부를 판단하는 단계를 포함하는,
개인 정보 파기 방법.7. The method of claim 6,
The step of performing the verification operation is
Determining whether the personal information or data in which the personal information is modulated exists in the invalid page of an unmapped memory block among the plurality of memory blocks,
How we destroy your personal information.
상기 검증 동작을 수행하는 단계는,
상기 개인 정보 또는 상기 개인 정보가 변조된 데이터가 상기 복수의 메모리 블록들 중에서 맵핑되지 않은 유효 페이지들에 존재하는지 여부를 판단하는 단계를 포함하는,
개인 정보 파기 방법.7. The method of claim 6,
The step of performing the verification operation is
Comprising the step of determining whether the personal information or the data modulated by the personal information exists in unmapped valid pages among the plurality of memory blocks,
How we destroy your personal information.
상기 적어도 하나의 비휘발성 메모리 장치를 제어하고, 외부의 호스트 장치로부터 개인 정보 파기 요청을 수신하고, 상기 개인 정보 파기 요청에 응답하여 개인 정보 파기 커맨드를 생성하는 제어기를 포함하고,
상기 제어기는 복수의 메모리 블록들 중에서 개인 정보가 저장되어 있는 무효 페이지를 포함하는 적어도 하나의 메모리 블록을 식별하고,
상기 제어 로직은, 상기 개인 정보 파기 커맨드에 응답하여,
상기 무효 페이지에 대응하는 워드 라인으로 적어도 하나의 삭제 의무 펄스를 인가하여 상기 개인 정보를 삭제하고,
상기 적어도 하나의 삭제 의무 펄스의 개수는 ECC(Error Correction Code)의 오류 정정 수준을 초과하도록 결정되는,
저장 장치.a plurality of cell strings each connected between one bit line and a common source line and including at least one string select transistor, a plurality of memory cells corresponding to each of the word lines, and at least one ground select transistor A memory cell array including a plurality of memory blocks, a row decoder that selects any one of the plurality of memory blocks in response to an address and selects any one of the word lines, is connected to bit lines and is connected to the word line a page buffer circuit including a plurality of page buffers connected to a memory cell connected to each of the above, a voltage generator generating word line voltages applied to the word lines, and the row decoder, the page buffer circuit, and the voltage generator. at least one non-volatile memory device including control logic for controlling; and
a controller for controlling the at least one non-volatile memory device, receiving a personal information destruction request from an external host device, and generating a personal information destruction command in response to the personal information destruction request;
The controller identifies at least one memory block including an invalid page in which personal information is stored from among the plurality of memory blocks,
The control logic, in response to the personal information destruction command,
applying at least one deletion duty pulse to a word line corresponding to the invalid page to delete the personal information;
The number of the at least one deletion duty pulse is determined to exceed an error correction level of an Error Correction Code (ECC),
storage device.
상기 복수의 메모리 셀들 각각은 멀티 레벨 셀이고,
상기 적어도 하나의 삭제 의무 펄스의 개수는 프로그램 동작에서 발생하는 프로그램 펄스의 개수 보다 작은,
저장 장치.12. The method of claim 11,
Each of the plurality of memory cells is a multi-level cell,
The number of the at least one deletion duty pulse is smaller than the number of program pulses generated in the program operation;
storage device.
상기 적어도 하나의 삭제 의무 펄스의 레벨은 프로그램 패스 전압(Vpass)의 레벨보다 큰,
저장 장치.12. The method of claim 11,
The level of the at least one erase duty pulse is greater than the level of the program pass voltage (V pass ),
storage device.
상기 적어도 하나의 비휘발성 메모리 장치는 맵핑된 메모리 블록 및 맵핑되지 않은 메모리 블록에서 상기 개인 정보의 파기 완료에 대한 검증 동작을 수행하는,
저장 장치.12. The method of claim 11,
the at least one non-volatile memory device performs a verification operation on completion of destruction of the personal information in a mapped memory block and an unmapped memory block;
storage device.
상기 제어기가 호스트 장치로부터 개인 정보 파기 요청을 수신하는 단계;
상기 제어기가 상기 개인 정보가 포함되어 있는 삭제 대상 페이지를 식별하는 단계; 및
상기 적어도 하나의 비휘발성 메모리 장치가 상기 대상 페이지에 대응하는 워드 라인에 적어도 하나의 삭제 의무 펄스를 인가하는 단계를 포함하고,
상기 적어도 하나의 삭제 의무 펄스의 개수는 ECC의 오류 정정 수준을 초과하도록 결정되는,
개인 정보 파기 방법.A personal information destruction method performed by a storage device comprising at least one non-volatile memory device and a controller for controlling the at least one non-volatile memory device, the method comprising:
receiving, by the controller, a personal information destruction request from the host device;
identifying, by the controller, a page to be deleted including the personal information; and
applying, by the at least one nonvolatile memory device, at least one erase duty pulse to a word line corresponding to the target page;
the number of the at least one erasure duty pulse is determined to exceed an error correction level of the ECC;
How we destroy your personal information.
상기 제어기가 맵핑된 메모리 블록 또는 맵핑되지 않은 메모리 블록에서 상기 개인 정보의 존재 여부를 판단하는 단계를 더 포함하는,
개인 정보 파기 방법.16. The method of claim 15,
Further comprising the step of determining, by the controller, whether the personal information exists in a mapped memory block or an unmapped memory block,
How we destroy your personal information.
상기 적어도 하나의 삭제 의무 펄스의 레벨은 프로그램 패스 전압의 레벨보다 높고, 프로그램 전압의 레벨보다 낮은,
개인 정보 파기 방법.16. The method of claim 15,
a level of the at least one erase duty pulse is higher than a level of a program pass voltage and lower than a level of a program voltage;
How we destroy your personal information.
상기 개인 정보의 파기 완료 이후에, 상기 제어기가 개인 정보 파기 성공 메시지를 상기 호스트로 전송하는 단계를 더 포함하는,
개인 정보 파기 방법.16. The method of claim 15,
After the destruction of the personal information is completed, the controller further comprising the step of transmitting a personal information destruction success message to the host,
How we destroy your personal information.
상기 제어기는 무효화 페이지의 물리 주소에 개인 정보를 파기하는 동작을 수행하는 삭제 의무 실행부를 포함하는,
개인 정보 파기 방법.16. The method of claim 15,
The controller includes a deletion duty execution unit that performs an operation to destroy personal information in the physical address of the invalidation page,
How we destroy your personal information.
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/KR2020/017965 WO2021118232A1 (en) | 2019-12-09 | 2020-12-09 | Method for discarding personal information in nand flash memory |
US17/783,792 US11899958B2 (en) | 2019-12-09 | 2020-12-09 | Method for discarding personal information in NAND flash memory |
US18/410,095 US20240143217A1 (en) | 2019-12-09 | 2024-01-11 | Method for discarding personal information in nand flash memory |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020190162829 | 2019-12-09 | ||
KR20190162829 | 2019-12-09 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20210072730A KR20210072730A (en) | 2021-06-17 |
KR102445057B1 true KR102445057B1 (en) | 2022-09-21 |
Family
ID=76603920
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020200170824A KR102445057B1 (en) | 2019-12-09 | 2020-12-08 | Method of destroying privacy data in a nand flash memory |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR102445057B1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20240003750A (en) | 2022-07-02 | 2024-01-09 | 안나영 | Storage device hving real-time secure deletion function and operating method thereof |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100226178A1 (en) * | 2009-03-05 | 2010-09-09 | Infineon Technologies Ag | Apparatus and methods for correcting over-erased flash memory cells |
US20110153919A1 (en) * | 2009-12-22 | 2011-06-23 | Erez Sabbag | Device, system, and method for reducing program/read disturb in flash arrays |
JP5659178B2 (en) * | 2012-03-16 | 2015-01-28 | 株式会社東芝 | NONVOLATILE MEMORY DEVICE AND NONVOLATILE MEMORY CONTROL METHOD |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7782674B2 (en) | 2007-10-18 | 2010-08-24 | Micron Technology, Inc. | Sensing of memory cells in NAND flash |
KR102144124B1 (en) * | 2019-04-22 | 2020-08-13 | 고려대학교 산학협력단 | Method and apparatus for managing data of non-volatile memory in hybrid main memory system |
-
2020
- 2020-12-08 KR KR1020200170824A patent/KR102445057B1/en active IP Right Grant
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100226178A1 (en) * | 2009-03-05 | 2010-09-09 | Infineon Technologies Ag | Apparatus and methods for correcting over-erased flash memory cells |
US20110153919A1 (en) * | 2009-12-22 | 2011-06-23 | Erez Sabbag | Device, system, and method for reducing program/read disturb in flash arrays |
JP5659178B2 (en) * | 2012-03-16 | 2015-01-28 | 株式会社東芝 | NONVOLATILE MEMORY DEVICE AND NONVOLATILE MEMORY CONTROL METHOD |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20240003750A (en) | 2022-07-02 | 2024-01-09 | 안나영 | Storage device hving real-time secure deletion function and operating method thereof |
Also Published As
Publication number | Publication date |
---|---|
KR20210072730A (en) | 2021-06-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10936252B2 (en) | Storage system capable of invalidating data stored in a storage device thereof | |
JP4362534B2 (en) | Scheduling housekeeping operations in flash memory systems | |
US9645896B2 (en) | Data storage device and flash memory control method | |
US8127200B2 (en) | Flash memory device and system with randomizing for suppressing errors | |
JP4787266B2 (en) | Scratch pad block | |
US8296498B2 (en) | Method and system for virtual fast access non-volatile RAM | |
US8370561B2 (en) | Randomizing for suppressing errors in a flash memory | |
KR100568115B1 (en) | Incremental merge method and memory system using the same | |
US9558128B2 (en) | Selective management of security data | |
US20190179569A1 (en) | Data storage device and data storage method | |
KR101468432B1 (en) | Flash memory refresh techniques triggered by controlled scrub data reads | |
US20120303865A1 (en) | Write Operation with Immediate Local Destruction of Old Content in Non-Volatile Memory | |
US10445008B2 (en) | Data management method for memory and memory apparatus | |
Ahn et al. | Schemes for privacy data destruction in a NAND flash memory | |
KR102445057B1 (en) | Method of destroying privacy data in a nand flash memory | |
US11101009B1 (en) | Systems and methods to convert memory to one-time programmable memory | |
US20200201788A1 (en) | Data Integrity Protection for Relocating Data in a Memory System | |
US11782782B2 (en) | Memory system and data processing system | |
US11899958B2 (en) | Method for discarding personal information in NAND flash memory | |
CN114625323A (en) | Safe NAND flash memory device | |
KR100932801B1 (en) | Memory management methods, memory devices, and computer readable storage media | |
KR20220118004A (en) | Memory system and operating method of memory system | |
TWI661300B (en) | Data management method for memory and memory apparatus | |
JP4551938B2 (en) | Memory system | |
KR20220068535A (en) | Memory system and operating method of memory system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right |