KR101532951B1 - 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 - Google Patents
고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 Download PDFInfo
- Publication number
- KR101532951B1 KR101532951B1 KR1020147028326A KR20147028326A KR101532951B1 KR 101532951 B1 KR101532951 B1 KR 101532951B1 KR 1020147028326 A KR1020147028326 A KR 1020147028326A KR 20147028326 A KR20147028326 A KR 20147028326A KR 101532951 B1 KR101532951 B1 KR 101532951B1
- Authority
- KR
- South Korea
- Prior art keywords
- storage
- data
- solid
- storage device
- module
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/16—Constructional details or arrangements
- G06F1/18—Packaging or power distribution
- G06F1/183—Internal mounting support structures, e.g. for printed circuit boards, internal connecting means
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1076—Parity data used in redundant arrays of independent storages, e.g. in RAID systems
- G06F11/108—Parity data distribution in semiconductor storages, e.g. in SSD
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0804—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with main memory updating
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0866—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches for peripheral storage systems, e.g. disk cache
- G06F12/0868—Data transfer between cache memory and other subsystems, e.g. storage devices or host systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
- G06F12/123—Replacement control using replacement algorithms with age lists, e.g. queue, most recently used [MRU] list or least recently used [LRU] list
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/20—Handling requests for interconnection or transfer for access to input/output bus
- G06F13/28—Handling requests for interconnection or transfer for access to input/output bus using burst mode transfer, e.g. direct memory access DMA, cycle steal
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4004—Coupling between buses
- G06F13/4022—Coupling between buses using switching circuits, e.g. switching matrix, connection or expansion network
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4247—Bus transfer protocol, e.g. handshake; Synchronisation on a daisy chain bus
- G06F13/426—Bus transfer protocol, e.g. handshake; Synchronisation on a daisy chain bus using an embedded synchronisation, e.g. Firewire bus, Fibre Channel bus, SSA bus
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
- G06F15/163—Interprocessor communication
- G06F15/173—Interprocessor communication using an interconnection network, e.g. matrix, shuffle, pyramid, star, snowflake
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0604—Improving or facilitating administration, e.g. storage management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0608—Saving storage space on storage systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
- G06F3/0613—Improving I/O performance in relation to throughput
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0614—Improving the reliability of storage systems
- G06F3/0619—Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/0643—Management of files
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/065—Replication mechanisms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/0652—Erasing, e.g. deleting, data cleaning, moving of data to a wastebasket
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0656—Data buffering arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0659—Command handling arrangements, e.g. command buffers, queues, command scheduling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0685—Hybrid storage combining heterogeneous device types, e.g. hierarchical storage, hybrid arrays
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0683—Plurality of storage devices
- G06F3/0688—Non-volatile semiconductor memory arrays
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/52—Program synchronisation; Mutual exclusion, e.g. by means of semaphores
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H05—ELECTRIC TECHNIQUES NOT OTHERWISE PROVIDED FOR
- H05K—PRINTED CIRCUITS; CASINGS OR CONSTRUCTIONAL DETAILS OF ELECTRIC APPARATUS; MANUFACTURE OF ASSEMBLAGES OF ELECTRICAL COMPONENTS
- H05K7/00—Constructional details common to different types of electric apparatus
- H05K7/14—Mounting supporting structure in casing or on frame or rack
- H05K7/1438—Back panels or connecting means therefor; Terminals; Coding means to avoid wrong insertion
- H05K7/1439—Back panel mother boards
- H05K7/1444—Complex or three-dimensional-arrangements; Stepped or dual mother boards
-
- H—ELECTRICITY
- H05—ELECTRIC TECHNIQUES NOT OTHERWISE PROVIDED FOR
- H05K—PRINTED CIRCUITS; CASINGS OR CONSTRUCTIONAL DETAILS OF ELECTRIC APPARATUS; MANUFACTURE OF ASSEMBLAGES OF ELECTRICAL COMPONENTS
- H05K7/00—Constructional details common to different types of electric apparatus
- H05K7/14—Mounting supporting structure in casing or on frame or rack
- H05K7/1485—Servers; Data center rooms, e.g. 19-inch computer racks
- H05K7/1487—Blade assemblies, e.g. blade cases or inner arrangements within a blade
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2211/00—Indexing scheme relating to details of data-processing equipment not covered by groups G06F3/00 - G06F13/00
- G06F2211/002—Bus
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2211/00—Indexing scheme relating to details of data-processing equipment not covered by groups G06F3/00 - G06F13/00
- G06F2211/10—Indexing scheme relating to G06F11/10
- G06F2211/1002—Indexing scheme relating to G06F11/1076
- G06F2211/103—Hybrid, i.e. RAID systems with parity comprising a mix of RAID types
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1032—Reliability improvement, data loss prevention, degraded operation etc
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1041—Resource optimization
- G06F2212/1044—Space efficiency improvement
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/20—Employing a main memory using a specific memory technology
- G06F2212/202—Non-volatile memory
- G06F2212/2022—Flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/22—Employing cache memory using specific memory technology
- G06F2212/222—Non-volatile memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/70—Details relating to dynamic memory management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7203—Temporary buffering, e.g. using volatile buffer or dedicated buffer blocks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7205—Cleaning, compaction, garbage collection, erase control
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7208—Multiple device management, e.g. distributing data over multiple flash devices
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1097—Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- Microelectronics & Electronic Packaging (AREA)
- Mathematical Physics (AREA)
- Quality & Reliability (AREA)
- Power Engineering (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
- Multi Processors (AREA)
- Debugging And Monitoring (AREA)
- Stored Programmes (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Storage Device Security (AREA)
- Information Transfer Between Computers (AREA)
- Bus Control (AREA)
- Signal Processing For Digital Recording And Reproducing (AREA)
- Cooling Or The Like Of Electrical Apparatus (AREA)
- Turbine Rotor Nozzle Sealing (AREA)
- Information Transfer Systems (AREA)
Abstract
장치, 시스템 및 방법이 고-용량, 비-휘발성(HCNV, High-Capacity, Non-Volatile) 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지에 대해 개시된다. 상기 장치, 시스템, 및 방법은 캐시 전단 모듈 및 캐시 후단 모듈을 포함한 다수의 모듈이 제공된다. 캐시 전단 모듈은 스토리지 요청과 결합된 데이터 전송을 관리한다. 데이터 전송은 요청 장치 및 하나 또는 그 이상의 HCNV 저장 장치를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지 간에 수행되고, 데이터 전송은 데이터, 메타데이터, 및 메타데이터 인덱스 중 하나 또는 그 이상을 포함할 수 있다. 솔리드-스테이트 스토리지는 비-휘발성, 솔리드-스테이트 데이터 스토리지 엘리먼트의 어레이를 포함할 수 있다. 캐시 후단 모듈은 솔리드-스테이트 스토리지 및 하나 또는 그 이상의 HCNV 저장 장치 간의 데이터 전송을 관리한다.
Description
본원은 "요소 블레이드 시스템(ElementalBlade System)"으로 명명되고 David Flynn 등에 의해 2006년 12월 6일에 출원된 미국 가출원 번호 60/873,111과 "객체-지향 솔리드-스테이트 스토리지에 대한 장치, 시스템 및 방법(Apparatus, System, and Method for Object-Oriented Solid-State Storage)"으로 명명되고 David Flynn 등에 의해 2007년 9월 22일에 출원된 미국 가출원 번호 60/974,470로부터 우선권을 주장하며, 이는 이하 참조로 포함된다.
본 발명은 데이터 관리에 관한 것으로, 보다 구체적으로 고-용량(high-capacity), 비-휘발성(non-volatile) 스토리지 장치를 위한 캐시(cache)로서 솔리드-스테이트 스토리지를 사용하는 것에 관한 것이다.
일반적으로, 자주 액세스되거나 애플리케이션 또는 운영체제의 일부로서 로딩되는 데이터가 캐시에 저장됨으로써, 데이터가 고-용량, 비-휘발성(HCNV, High-Capacity Non-Volatile) 저장 장치, 예컨대 HDD(Hard Disk Drive), 광학 드라이브, 테잎 스토리지 등을 통해 액세스되는 경우보다 후속 액세스가 훨씬 빠르게 수행되기 때문에 캐시(cache)는 유익하다. 캐시는 일반적으로 컴퓨터 내에 포함된다.
일부 저장 장치 및 시스템은 HCNV 저장 장치 내에 캐시를 포함한다. 일부 HCNV 저장 장치는 비-휘발성 솔리드 스테이트 캐시를 포함하며; 이는 액세스 시간을 감소시키는 장점을 제공하지만, 통상 HCNV 저장 장치 인터페이스의 제한된 용량에 따라서만 성능을 제공할 수 있다. 일부 비-휘발성 솔리드-스테이트 캐시 저장 장치는 일반적으로 마더보드에 위치되며; 이러한 장치는 캐시 코히어런스(cache coherence)가 제공되지 않기 때문에 멀티-클라이언트 환경에서는 사용될 수 없다. HCNV 장치의 일부 컨트롤러는 또한 캐시를 포함한다. 리던던트(redundant) HCNV 캐시 컨트롤러가 다수의 클라이언트 간에 공유되는 경우, 복잡한 캐시 코히어런스 알고리즘은 데이터에 오류가 발생하지 않음을 보증하기 위해 요구된다.
일반적으로, 캐시는 DRAM에 구현되며, 이는 캐시 용량을 우수하게 만들고, 상대적으로 성능 당 높은 파워를 요구한다. 휘발성 캐시를 지원하는 파워가 손실되면, 캐시에 저장된 데이터는 손실된다. 일반적으로, 일부 배터리 백업이 파워 실패(power failure)의 경우 데이터 손실을 방지하도록 사용되며, 이는 배터리 백업의 실패가 발생하기 전에 캐시를 비-휘발성 메모리로 플러시(flush)하기에 충분한 용량을 구비한다. 또한, 배터리 백업 시스템은 파워를 소비하며, 리던던시(redundancy)를 요구하며, 신뢰성에 부정적으로 영향을 미치고 공간을 차지한다. 배터리는 또한 표준 기준에 서비스되어야하고, 배터리 백업은 상대적으로 고가이다.
전술한 바와 같이, 솔리드-스테이트 스토리지를 사용하여 데이터를 관리하는 장치, 시스템, 및 방법에 대한 요구가 존재하는 것은 분명하다. 유리하게, 그러한 장치, 시스템 및 방법은 적은 파워를 소비하는 비-휘발성 캐시를 제공하고, 두드러지게 큰 용량을 제공하고 캐시에 저장된 데이터를 유지하기 위해 배터리 백업을 요구하지 않는다.
본 발명은 기술분야의 현재 상태에 응답하여 개발되었으며, 구체적으로, 현재 사용가능한 데이터 스토리지 관리 시스템에 의해 아직 완전히 해결되지 않은 기술분야의 문제점 및 요구에 부응하여 개발되었다. 따라서, 본 발명은 기술분야 내의 상술한 단점의 대다수 또는 전부를 극복하는 하나 또는 그 이상의 고-용량, 비-휘발성(HCNV, High-Capacity Non-Volatile) 저장 장치의 데이터 저장을 관리하는 장치, 시스템 및 방법을 제공하도록 개발되었다.
일 실시예에서, 상기 장치는 캐시 전단(cache front-end) 모듈 및 캐시 후단(cache back-end) 모듈을 포함하는 다수의 모듈을 제공한다. 캐시 전단 모듈은 스토리지 요청과 결합된 데이터 전송을 관리한다. 데이터 전송은 요청 장치와 하나 또는 그 이상의 HCNV 저장 장치를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지 간에 이루어지고, 데이터 전송은 데이터, 메타데이터, 및 메타데이터 인덱스 중 하나 또는 그 이상을 포함한다. 솔리드-스테이트 스토리지는 비-휘발성, 솔리드 스테이트 데이터 스토리지 엘리먼트의 어레이를 포함할 수 있다. 캐시 후단 모듈은 솔리드-스테이트 스토리지와 하나 또는 그 이상의 HCNV 저장 장치 간의 데이터 전송을 관리한다.
상기 장치의 일 실시예에서, 캐시 전단 모듈 및 캐시 후단 모듈은 솔리드-스테이트 스토리지를 관리하는 솔리드-스테이트 스토리지 컨트롤러와 함께 공존한다. 더한 실시예에서, 캐시 전단 모듈, 캐시 후단 모듈, 및 솔리드-스테이트 스토리지 컨트롤러는 요청 장치로부터 자발적으로 동작한다.
일 실시예에서, 상기 장치는 RAID 레벨에 일관된 독립 드라이브(RAID)의 리던던트 어레이 내의 둘 또는 그 이상의 HCNV 저장 장치 내의 솔리드-스테이트 스토리지 내에 캐시된(cached) 데이터를 저장하는 HCNV RAID 모듈을 포함한다. 데이터는 전체로서 요청 장치에 드러날 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 및 하나 또는 그 이상의 HCNV 저장 장치 는 RAID 그룹으로 구성된 하이브리드 저장 장치 세트 내의 하이브리드 저장 장치를 포함할 수 있다. 솔리드-스테이트 스토리지에 캐시되고 HCNV 장치에 추후 저장된 데이터 세그먼트는 스트라이프의 N 개의 데이터 세그먼트 또는 스트라이프의 패리티 데이터 세그먼트 중 하나를 포함할 수 있다. 하이브리드 저장 장치는 일반적으로 RAID 스트라이프의 데이터 세그먼트에 독립적인 하나 또는 그 이상의 클라이언트로부터 스토리지 요청을 수신한다. 더한 실시예에서, 하이브리드 저장 장치는 둘 또는 그 이상의 클라이언트로부터 둘 또는 그 이상의 동시적인(simultaneous) 스토리지 요청을 수신하는 공유되고(shared), 전단 분산된(front-end distributed) RAID 그룹의 저장 장치일 수 있다.
상기 장치의 추가적인 실시예에서, HCNV 저장 장치는 HDD(Hard Disk Drive), 광학 드라이브, 또는 테잎 스토리지일 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 및 하나 또는 그 이상의 HCNV 저장 장치는 하이브리드 저장 장치일 수 있다. 일 실시예에서, 상기 장치는 또한 하나 또는 그 이상의 요청 장치를 로딩하기 전에, 하이브리드 저장 장치의 동작에 특화된 코드로 하나 또는 그 이상의 요청 장치에 부착된 표준 장치(standard device)를 에뮬레이팅(emulating)함으로써 하이브리드 저장 장치로의 액세스를 제공하는 표준 장치 에뮬레이션 모듈을 포함할 수 있다. 표준 장치는 일반적으로 산업 표준 BIOS에 의해 지원될 수 있다.
다른 실시예에서, 솔리드-스테이트 스토리지 장치는 둘 또는 그 이상의 영역으로 파티션될 수 있으며, 하나 또는 그 이상의 파티션은 HCNV 저장 장치를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지에 독립적인 솔리드-스테이트 스토리지로서 사용될 수 있다. 여전히 다른 실시예에서, 하나 또는 그 이상의 클라이언트는 캐시 제어 메시지를 캐시 전단 모듈 및 캐시 후단 모듈로 전송하여 솔리드-스테이트 스토리지 장치 및 하나 또는 그 이상의 HCNV 저장 장치에 저장된 파일 또는 객체의 하나 또는 그 이상의 상태를 관리한다.
상기 장치의 일 실시예에서, 캐시 제어 메시지는 하나 또는 그 이상의 제어 메시지를 포함할 수 있다. 제어 메시지의 다양한 실시예는 캐시 후단 모듈이 솔리드-스테이트 스토리지내의 객체 또는 파일의 일부를 피닝(pin)하도록 야기하는 제어 메시지 또는 캐시 후단 모듈이 솔리드-스테이트 스토리지 내의 객체 또는 파일의 일부를 언피닝(unpin)하도록 야기하는 제어 메시지를 포함할 수 있다. 제어 메시지의 다른 실시예는 캐시 후단 모듈이 객체 또는 파일의 일부를 솔리드-스테이트 스토리지로부터 하나 또는 그 이상의 HCNV 저장 장치로 플러시(flush)하도록 야기하는 제어 메시지 또는 캐시 후단 모듈이 객체 또는 파일의 일부를하나 또는 그 이상의 HCNV 저장 장치로부터 솔리드-스테이트 스토리지로 프리로드(preload)하도록 야기하는 제어 메시지를 포함할 수 있다. 제어 메시지의 여전히 다른 실시예는 캐시 후단 모듈이 하나 또는 그 이상의 객체 또는 파일을 솔리드-스테이트 스토리지에서 하나 또는 그 이상의 HCNV 저장 장치로 오프로드(offload)하도록 야기하여 솔리드-스테이트 스토리지내의 결정된 양의 저장 공간을 자유롭게하도록 야기하는 제어 메시지일 수 있다. 일 실시예에서, 캐시 제어 메시지는 객체 또는 파일을 위한 메타데이터(캐시 제어 메타데이터)를 통해 통신될 수 있다. 더한 실시예에서, 캐시 제어 메타데이터는 영속적(persistent)일 수 있다. 다른 실시예에서, 캐시 제어 메타데이터는 파일 또는 객체의 생성 시 속성 세트(attribute set)를 통해 구축될 수 있다. 여전히 다른 실시예에서, 캐시 제어 메타데이터는 파일 또는 객체 관리 시스템으로부터 획득될 수 있다.
상기 장치의 일 실시예에서, 상기 장치는 휘발성 캐시 스토리지 엘리먼트를 포함할 수 있으며, 캐시 전단 모듈 및 캐시 후단 모듈은 휘발성 캐시 스토리지 엘리먼트 내에 데이터를 저장하고 솔리드-스테이트 스토리지 및 휘발성 캐시 스토리지 엘리먼트 내에 저장된 데이터를 관리한다. 후단 스토리지 모듈은 휘발성 캐시 스토리지 엘리먼트, 솔리드-스테이트 스토리지 및 HCNV 저장 장치 간의 데이터 전송을 더 관리할 수 있다. 더한 실시예에서, HCNV 저장 장치에 저장된 객체 및 파일에 대한 메타데이터 및/또는 인덱스 메타데이터는 솔리드-스테이트 스토리지 장치 및 휘발성 캐시 스토리지 엘리먼트 내에서 유지될 수 있다.
상기 장치의 추가적인 실시예에서, HCNV 저장 장치 내에 저장된 객체 및 파일에 대한 메타데이터 및/또는 인덱스 메타데이터는 솔리드-스테이트 스토리지 장치 내에서 유지될 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 및 하나 또는 그 이상의 HCNV 저장 장치는 저장 장치를 포함할 수 있어, HCNV 저장 장치는 저장 장치에 연결된 클라이언트의 시야로부터 숨겨질 수 있다.
본 발명의 시스템이 또한 제시된다. 상기 시스템은 실질적으로 상기 장치에 관련하여 상술된 모듈 및 실시예를 포함한다. 일 실시예에서, 상기 시스템은 비-휘발성, 솔리드-스테이트 데이터 스토리지 엘리먼트의 어레이를 포함하는 솔리드-스테이트 스토리지를 포함한다. 상기 시스템은 또한 하나 또는 그 이상의 HCNV 저장 장치 및 스토리지 컨트롤러를 포함한다. 일 실시예에서, 스토리지 컨트롤러는 솔리드-스테이트 스토리지 컨트롤러 및 HCNV 저장 장치 컨트롤러를 포함할 수 있다. 스토리지 컨트롤러는 또한 캐시 전단 모듈 및 캐시 후단 모듈을 포함할 수 있다. 캐시 전단 모듈은 스토리지 요청과 결합된 데이터 전송을 관리한다. 데이터 전송은 일반적으로 요청 장치 및 하나 또는 그 이상의 HCNV 저장 장치를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지 간에 수행된다. 데이터 전송은 데이터, 메타데이터, 및 메타데이터 인덱스 중 하나 또는 그 이상을 포함할 수 있다. 캐시 후단 모듈은 솔리드-스테이트 스토리지 및 하나 또는 그 이상의 HCNV 저장 장치 간의 데이터 전송을 관리한다.
일 실시예에서, 상기 시스템은 스토리지 컨트롤러에 연결된 네트워크 인터페이스를 포함하며, 네트워크 인터페이스는 컴퓨터 네트워크를 통한 요청 장치 및 솔리드-스테이트 스토리지 컨트롤러 간의 데이터 전송을 구현한다. 다른 실시예에서, 상기 시스템은 솔리드-스테이트 스토리지, 하나 또는 그 이상의 HCNV 저장 장치, 및 스토리지 컨트롤러를 포함하는 서버를 포함한다. 여전히 다른 실시예에서, 하나 또는 그 이상의 HCNV 저장 장치는 SAN(Storage Area Network)를 통해 스토리지 컨트롤러에 연결된다.
본 발명의 방법이 또한 다수의 호스트 간에 장치를 공유하기 위해 제시된다. 개싯된 실시예의 상기 방법은 실질적으로 상술한 장치 및 시스템의 동작에 관하여 제시된 기능을 수행하기 위해 필수적인 단계들을 포함한다. 일 실시예에서, 상기 방법은 스토리지 요청과 결합된 데이터 전송을 관리하는 단계를 포함하며, 데이터 전송은 요청 장치 및 하나 또는 그 이상의 HCNV 저장 장치를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지 간에 수행된다. 데이터 전송은 데이터, 메타데이터, 및 메타데이터 인덱스 중 하나 또는 그 이상을 포함할 수 있다. 솔리드-스테이트 스토리지는 비-휘발성, 솔리드-스테이트 데이터 스토리지 엘리먼트의 어레이를 포함할 수 있다. 상기 방법은 또한 솔리드-스테이트 스토리지 및 하HCNV 저장 장치 간의 데이터 전송을 관리하는 단계를 포함할 수 있다.
본 발명의 상세한 설명에 걸쳐 기재된 특징, 이점, 또는 그와 유사한 용어는 본 발명으로 구현될 수 있는 모든 특징 및 이점이 본 발명의 임의의 단일 실시예이어야만 하거나 단일 실시예임을 의미하지 않는다. 오히려, 특징 및 이점을 언급하는 용어는 실시예와 결합되어 기술된 특별한 특징, 이점, 또는 특성은 본 발명의 적어도 하나의 실시예에 포함됨을 의미하는 것으로 이해된다. 따라서, 본 발명의 상세한 설명에 걸쳐 사용되는 특징, 이점, 및 이와 유사한 용어에 대한 논의는 동일한 실시예를 언급할 수도 있지만, 이는 필수적이지 않다.
또한, 본 발명의 기술된 특징, 이점 및 특성은 하나 또는 그 이상의 실시예에서 임의의 적절한 방식으로 결합될 수 있다. 당업자는 본 발명이 특별한 실시예의 하나 또는 그 이상의 특별한 특징 또는 이점 없이 구현될 수 있음을 인식할 것이다. 다른 예에서, 추가적인 특징 및 이점은 본 발명의 모든 실시예에서 제시되지 않을 수 있는 특정 실시예에서 인식될 수 있다.
본 발명의 이러한 특징 및 이점은 다음의 기술 및 부가된 청구범위로부터 보다 완전히 명확해질 것이며, 또는 이하 기술되는 본 발명의 구현예에 의해 학습될 수 있다.
본 발명의 이점이 용이하게 이해되어지도록 하기 위해, 위에서 간략하게 기술된 본 발명의 보다 구체적인 기술이 첨부된 도면에 도시된 특정 실시예를 참조로 하여 기술될 것이다. 이들 도면은 오직 본 발명의 전형적인 실시예만을 도시함을 이해할 것이며, 본 발명의 권리범위를 제한하도록 고려되지 않으며, 본 발명은 첨부한 도면을 사용하여 부가적인 특징 및 세부사항이 기술되고 설명될 것이다.
도 1a는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 1b는 본 발명에 따른 스토리지 장치 내의 객체 관리를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 1c는 본 발명에 따른 인-서버 스토리지 영역 네트워크(in-server storage area network)를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 2a는 본 발명에 따른 스토리지 장치 내의 객체 관리를 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 2b는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 솔리드-스테이트 스토리지 장치 컨트롤러의 일 실시예를 설명하는 개략적인 블록도이다.
도 3은 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 데이터 기록 파이프라인 및 데이터 독출 파이프라인과 함께 구비된 솔리드-스테이트 스토리지 컨트롤러의 일 실시예를 설명하는 개략적인 블록도이다.
도 4a는 본 발명에 따른 솔리드-스테이트 스토리지 컨트롤러 내의 뱅크 인터리브 컨트롤러의 일 실시예를 설명하는 개략적인 블록도이다.
도 5a는 본 발명에 따른 데이터 파이프라인을 이용한 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 5b는 본 발명에 따른 인-서버 SAN을 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 6은 본 발명에 따른 데이터 파이프라인을 이용한 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 방법의 다른 실시예를 설명하는 개략적인 흐름도이다.
도 7은 본 발명에 따른 뱅크 인터리브를 사용한 솔리드-스테이트 스토리지 장치 내의 데이터 관리 방법의 실시예를 설명하는 개략적인 흐름도이다.
도 8은 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 가비지 컬렉션을 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 9는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 가비지 컬렉션을 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 10은 본 발명에 따른 프로그레시브(progressive) RAID, 전단 분산된(front-end distributed) RAID, 및 공유되고 전단 분산된 RAID를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 11은 본 발명에 따른 전단 분산된 RAID를 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 12는 본 발명에 따른 전단 분산된 RAID를 위한 방법의 실시예를 설명하는 개략적인 흐름도이다.
도 13은 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 14는 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 방법의 실시예를 설명하는 개략적인 흐름도이다.
도 15는 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 구비한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 16은 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 구비한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 17은 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 사용하는 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 1a는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 1b는 본 발명에 따른 스토리지 장치 내의 객체 관리를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 1c는 본 발명에 따른 인-서버 스토리지 영역 네트워크(in-server storage area network)를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 2a는 본 발명에 따른 스토리지 장치 내의 객체 관리를 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 2b는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 솔리드-스테이트 스토리지 장치 컨트롤러의 일 실시예를 설명하는 개략적인 블록도이다.
도 3은 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 데이터 기록 파이프라인 및 데이터 독출 파이프라인과 함께 구비된 솔리드-스테이트 스토리지 컨트롤러의 일 실시예를 설명하는 개략적인 블록도이다.
도 4a는 본 발명에 따른 솔리드-스테이트 스토리지 컨트롤러 내의 뱅크 인터리브 컨트롤러의 일 실시예를 설명하는 개략적인 블록도이다.
도 5a는 본 발명에 따른 데이터 파이프라인을 이용한 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 5b는 본 발명에 따른 인-서버 SAN을 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 6은 본 발명에 따른 데이터 파이프라인을 이용한 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 방법의 다른 실시예를 설명하는 개략적인 흐름도이다.
도 7은 본 발명에 따른 뱅크 인터리브를 사용한 솔리드-스테이트 스토리지 장치 내의 데이터 관리 방법의 실시예를 설명하는 개략적인 흐름도이다.
도 8은 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 가비지 컬렉션을 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 9는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 가비지 컬렉션을 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
도 10은 본 발명에 따른 프로그레시브(progressive) RAID, 전단 분산된(front-end distributed) RAID, 및 공유되고 전단 분산된 RAID를 위한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 11은 본 발명에 따른 전단 분산된 RAID를 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 12는 본 발명에 따른 전단 분산된 RAID를 위한 방법의 실시예를 설명하는 개략적인 흐름도이다.
도 13은 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 14는 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 방법의 실시예를 설명하는 개략적인 흐름도이다.
도 15는 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 구비한 시스템의 일 실시예를 설명하는 개략적인 블록도이다.
도 16은 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 구비한 장치의 일 실시예를 설명하는 개략적인 블록도이다.
도 17은 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 사용하는 방법의 일 실시예를 설명하는 개략적인 흐름도이다.
본 발명의 상세한 설명에 기술된 많은 기능적 유닛(functional units)은 보다 구체적으로 그들의 구현 독립성(implementation independence)를 강조하기 위해 모듈로서 분류된다. 예를 들어, 모듈은 커스텀 VLSI 회로 또는 게이트 어레이, 논리 칩, 트랜지스터, 또는 다른 디스크릿 컴포넌트와 같은 기성 반도체를 포함하는 하드웨어 회로로서 구현될 수 있다. 모듈은 또한 프로그램 가능한 하드웨어 장치, 예컨대 필드 프로그램 가능한 게이트 어레이, 프로그램 가능한 어레이 로직, 프로그램 가능한 로직 장치 등으로 구현될 수도 있다.
모듈은 다양한 타입의 프로세서에 의해 실행을 위한 소프트웨어로 구현될 수도 있다. 예를 들어, 실행가능한 코드의 식별된 모듈은 예를 들어, 객체(object), 과정(procedure), 또는 함수(function)로서 구성될 수 있는 하나 또는 그 이상의 컴퓨터 명령의 물리적 또는 논리적 블록을 포함할 수 있다. 그럼에도 불구하고, 식별된 모듈의 실행가능함(executables)은 물리적으로 함께 위치할 필요는 없으며, 단지 상이한 장소에 저장된 다른 명령을 포함할 수 있으며, 이들이 논리적으로 함께 결합되는 경우, 모듈을 포함할 수 있으며 모듈에 대한 언급된 목적을 달성할 수 있다.
실제로, 실행가능한 코드의 모듈은 단일의 명령, 또는 다수의 명령일 수 있으며, 상이한 프로그램 중에서 그리고 다수 개의 메모리 장치에 걸쳐 다수의 상이한 코드 세그먼트로 분배될 수도 있다. 유사하게, 운영 데이터(operational data)는 여기에서 모듈 내에서 식별되고 설명되고, 임의의 적절한 형태로 구현될 수 있고 데이터 구조의 임의의 적절한 타입 내에서 구성될 수 있다. 운영 데이터는 단일의 데이터 세트로서 수집될 수 있거나, 또는 상이한 스토리지 장치에 걸쳐 포함되는 상이한 장소에 걸쳐 분배될 수 있고, 적어도 부분적으로, 시스템 또는 네트워크에서 전기적 신호로서만 존재할 수도 있다. 모듈 또는 모듈의 일부가 소프트웨어로 구현되는 경우, 상기 소프트웨어 부분은 하나 또는 그 이상의 컴퓨터로 읽을 수 있는 미디어에 저장된다.
본 발명의 상세한 설명에 걸쳐 사용되는 "일 실시예", "실시예", 또는 이와 유사한 용어는 실시예와 결합되어 기술되는 특별한 특징, 구조, 또는 특성이 본 발명의 적어도 일 실시예 포함되는 것을 의미한다. 따라서, 본 발명의 상세한 설명에 걸쳐 사용되는 문구 "일 실시에에서", "실시에에서", 및 그와 유사한 용어의 출현은 모두 동일한 실시예를 언급할 수 있으나, 이는 필수적이지 않다.
신호 포함 매체(signal bearing medium)에 대한 언급은 신호를 생성하거나, 생성될 신호를 야기하거나, 또는 디지털 처리 장치에 장치가 읽을 수 있는 명령의 프로그램의 실행을 야기함을 가능하게 하는 임의의 형태를 취할 수 있다. 신호 포함 매체는 전송 라인, 컴팩트 디스크, 디지털-비디오 디스크, 자기 테잎, 베르누이 드라이브, 자기 디스크, 펀치 카드, 플래시 메모리, 직접 회로, 또는 다른 디지털 처리 장치 메모리 장치에 의해 구현될 수 있다.
또한, 본 발명의 기술된 특징, 구조, 또는 특성은 하나 또는 그 이상의 실시예에서 임의의 적절한 방식으로 결합될 수 있다. 후술될 상세한 설명에서, 다수의 구체적인 세부 사항이 제공되며, 예컨대 프로그래밍, 소프트웨어 모듈, 사용자 선택, 네트워크 트랜잭션(transactions), 데이터베이스 조회, 데이터베이스 구조, 하드웨어 모듈, 하드웨어 회로, 하드웨어 칩 등의 예가 제공되어, 본 발명의 실시예의 직접적인 이해를 제공한다. 그러나, 당업자는 본 발명이 하나 또는 그 이상의 특정 세부 사항이 없이 구현될 수 있으며, 또는 다른 방법, 컴포넌트, 물질 등을 사용하여 구현될 수 있음을 인지할 것이다. 다른 예에서, 잘 알려진 구조, 물질, 또는 동작은 상세하게 도시되거나 기술되지 않아 본 발명의 양상을 불명확하게 하는 것을 방지한다.
여기에 포함된 개략적인 흐름도는 논리적인 흐름도로서 일반적으로 설명된다. 그러한 것으로, 도시된 순서 및 라벨링된 단계는 본 발명의 방법의 일 실시예를 나타낸다. 다른 단계 및 방법은 설명된 방법의 하나 또는 그 이상의 단계 또는 그 일부에 기능적, 논리적, 또는 효과적으로 균등한 것으로 이해된다. 추가적으로, 사용된 형태 및 기호는 본 발명의 논리적 단계를 설명하기 위해 제공되고 본 발명의 범위를 제한하지 않도록 이해된다. 비록 다양한 화살표 타입 및 라인 타입이 흐름도에 도입될 수 있지만, 이들은 해당 방법의 범위를 제한하지 않도록 이해된다. 실제로, 일부 화살표 또는 다른 연결자는 본 발명의 논리적 흐름만을 지시하도록 사용될 수 있다. 예를 들어, 화살표는 도시된 방법의 열거된 단계들 간의 특정되지 않은 지속의 기간을 기다리거나 감시하는 것을 지시할 수 있다. 추가적으로, 특정 방법이 발생한 순서는 도시된 해당 단계들의 순서에 엄격하게 고수될 수 있거나 고수되지 않을 수 있다.
솔리드-스테이트 스토리지 시스템
도 1a는 본 발명에 따른 솔리드-스테이트 스토리지 장치 내의 데이터 관리를 위한 시스템(100)의 일 실시예를 설명하는 개략적인 블록도이다. 시스템(100)은 솔리드-스테이트 스토리지 장치(102), 솔리드-스테이트 스토리지 컨트롤러(104), 데이터 기록 파이프라인(106), 데이터 독출 파이프라인(108), 솔리드-스테이트 스토리지(110), 컴퓨터(112), 클라이언트(114) 및 컴퓨터 네트워크(116)을 포함하며, 이는 이하 기술된다.
상기 시스템(100)은 적어도 하나의 솔리드-스테이트 스토리지 장치(102)를 포함한다. 다른 실시예에서, 상기 시스템(100)은 둘 또는 그 이상의 솔리드-스테이트 스토리지 장치(102)를 포함한다. 각각의 솔리드-스테이트 스토리지 장치(102)는 비-휘발성, 솔리드-스테이트 스토리지(110), 예컨대 플래시 메모리, 나노 RAM 또는 NRAM(Nano Random Access Memory), MRAM(Magneto-resistive RAM), DRAM(Dynamic RAM), PRAM(Phase change RAM) 등을 포함할 수 있다. 솔리드-스테이트 스토리지 장치(102)는 도 2 및 도 3을 참조하여 보다 상세하게 기술된다. 솔리드-스테이트 스토리지 장치(102)는 컴퓨터 네트워크(116)을 통해 클라이언트(114)에 연결된 컴퓨터(112) 내에 구현된다. 일 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 컴퓨터(112) 내부에 구비되고 시스템 버스, 예컨대 PCI-e(Peripheral Component Interconnect express) 버스, 직렬 ATA(Serial Advanced Technology Attachment) 버스 등을 이용하여 연결된다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 컴퓨터 외부에 구비되고, USB(Universal Serial Bus) 연결, 및 IEEE(Institute of Electrical and Electronics Engineers) 1394 버스 ("FireWire") 등을 통해 연결된다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 외부 전기 또는 광학 버스 확장(extension) 또는 인피니밴드(Infiniband) 또는 PCIe-AS(PCI Express Advanced Switching) 등과 같은 버스 네트워킹 솔루션을 이용한 PCI(Peripheral Component Interconnect) 고속 버스를 이용하여 연결된다.
다양한 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 DIMM(Dual Inline Memory Module), 도터 카드(daughter card) 또는 마이크로-모듈의 형태로 구성될 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 랙-장착 블레이드(rack-mounted blade) 내의 엘리먼트이다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 보다 높은 레벨의 어셈블리(예컨대, 마더보드, 랩탑, 그래픽 프로세서)와 직접적으로 통합된 패키지 내에 포함된다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)를 포함한 개별 컴포넌트(individual components)는 중간 패키징(intermediate packaging)을 사용하지 않고 보다 높은 레벨의 어셈블리에 직접적으로 통합된다.
솔리드-스테이트 스토리지 장치(102)는 하나 또는 그 이상의 솔리드-스테이트 스토리지 컨트롤러(104)를 포함하며, 각각은 데이터 기록 파이프라인(106) 및 데이터 독출 파이프라인(108)을 포함할 수 있고, 각각은 솔리드-스테이트 스토리지(110)를 포함하며, 이는 도 2 및 도 3을 참조로 보다 상세하게 이하 기술된다.
상기 시스템(100)은 솔리드-스테이트 스토리지 장치(102)에 연결된 하나 또는 그 이상의 컴퓨터(112)를 포함한다. 컴퓨터(112)는 호스트, 서버, SAN(Storage Area Network)의 스토리지 컨트롤러, 워크스테이션, 퍼스널 컴퓨터, 랩탑 컴퓨터, 소형 컴퓨터, 수퍼컴퓨터, 컴퓨터 클러스터, 네트워크 스위치, 라우터, 또는 어플라이언스(appliance), 데이터베이스 또는 스토리지 어플라이언스, 데이터 획득(data acquisition) 또는 데이터 캡쳐 시스템, 진단 시스템(diagnostic system), 테스트 시스템, 로봇, 휴대용 전자 장치, 무선 장치 등일 수 있다. 다른 실시예에서, 컴퓨터(112)는 클라이언트 및 컴퓨터(112)로부터 전송된 서비스 데이터 요청에 자발적으로(autonomously) 동작하는 솔리드-스테이트 스토리지 장치(102)일 수 있다. 이러한 실시예에서, 컴퓨터(112) 및 솔리드-스테이트 스토리지 장치(102)는 컴퓨터 네트워크, 시스템 버스, 또는 컴퓨터(112)와 자발적 솔리드-스테이트 스토리지 장치(102) 간의 연결에 적합한 다른 통신 수단을 이용하여 연결될 수 있다.
일 실시예에서, 상기 시스템(100)은 하나 또는 그 이상의 컴퓨터 네트워크(116)를 통해 하나 또는 그 이상의 컴퓨터(112)와 연결된 하나 또는 그 이상의 클라이언트(114)를 포함한다. 클라이언트(114)는 호스트, 서버, SAN의 스토리지 컨트롤러, 워크스테이션, 퍼스널 컴퓨터, 랩탑 컴퓨터, 소형 컴퓨터, 수퍼컴퓨터, 컴퓨터 클러스터, 네트워크 스위치, 라우터, 또는 어플라이언스(appliance), 데이터베이스 또는 스토리지 어플라이언스, 데이터 획득(data acquisition) 또는 데이터 캡쳐 시스템, 진단 시스템(diagnostic system), 테스트 시스템, 로봇, 휴대용 전자 장치, 무선 장치 등일 수 있다. 컴퓨터 네트워크(116)는 인터넷, WAN(Wide Area Network), MAN(Metropolitan Area Network), LAN(Local Area Network), 토큰 링, 무선 네트워크, 파이버 채널(fiber channel) 네트워크, SAN, NAS(Network Attached Storage), ESCON 등 또는 네트워크들의 임의의 조합을 포함할 수 있다. 컴퓨터 네트워크(116)는 또한 네트워크 기술의 IEEE 802 패밀리로부터의 네트워크, 예컨대 이더넷, 토큰 링, WiFi, WiMax 등을 포함할 수 있다.
컴퓨터 네트워크(116)는 서버, 스위치, 라우터, 케이블링(cabling). 라디오, 및 컴퓨터(112)와 클라이언트(114)의 네트워킹을 구현하도록 사용되는 다른 장비를 포함할 수 있다. 일 실시예에서, 상기 시스템(100)은 컴퓨터 네트워크(116)를 통해 피어(peer)로서 통신하는 다수의 컴퓨터들(112)을 포함한다. 다른 실시예에서, 상기 시스템(100)은 컴퓨터 네트워크(116)를 통해 피어로서 통신하는 다수의 솔리드-스테이트 스토리지 장치(102)를 포함한다. 당업자는 다른 컴퓨터 네트워크(116)가 하나 또는 그 이상의 컴퓨터 네트워크(116), 및 하나 또는 그 이상의 클라이언트(114) 또는 하나 또는 그 이상의 솔리드-스테이트 스토리지 장치(102) 또는 하나 또는 그 이상의 컴퓨터(112)와 연결된 하나 또는 그 이상의 솔리드-스테이트 스토리지 장치(102)를 사용한 다른 컴퓨터 간의 단일 또는 리던던트(redundant) 연결을 사용한 관련된 장비를 사용하는 것을 파악할 것이다. 일 실시예에서, 상기 시스템(100)은 컴퓨터(112)를 사용하지 않고 컴퓨터 네트워크(118)를 통해 클라이언트(116)로 연결된 둘 또는 그 이상의 솔리드-스테이트 스토리지 장치(102)를 포함한다.
스토리지 컨트롤러-관리 객체(Storage Controller-Managed Objects)
도 1b는 본 발명에 따른 스토리지 장치 내의 객체 관리를 위한 시스템(101)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 시스템(101)은 하나 또는 그 이상의 스토리지 장치(150)를 포함하며, 각각은 스토리지 컨트롤러(152) 및 하나 또는 그 이상의 데이터 스토리지 장치(154), 및 하나 또는 그 이상의 요청 장치(requesting devices)(155)를 구비한다. 스토리지 장치(150)는 함께 네트워크로 구성되고, 하나 또는 그 이상의 요청 장치(155)와 연결된다. 요청 장치(155)는 스토리지 장치(150a)로 객체 요청(object requests)을 송신한다. 객체 요청은 객체 생성을 위한 요청, 데이터를 객체에 기록하기 위한 요청, 데이터를 객체로부터 독출하기 위한 요청, 객체를 삭제하기 위한 요청, 객체를 체크포인트(checkpoint)하기 위한 요청, 객체를 카피하기 위한 요청 등일 수 있다. 당업자는 다른 객체 요청을 파악할 것이다.
일 실시예에서, 스토리지 컨트롤러(152) 및 데이터 스토리지 장치(154)는 분리된 장치이다. 다른 실시예에서, 스토리지 컨트롤러(152) 및 데이터 스토리지 장치(154)는 하나의 스토리지 장치(150)으로 통합된다. 다른 실시예에서, 데이터 스토리지 장치(154)는 솔리드-스테이트 스토리지(110)이며, 스토리지 컨트롤러는 솔리드-스테이트 스토리지 장치 컨트롤러(202)이다. 다른 실시예에서, 데이터 스토리지 장치(154)는 하드 디스크 드라이브, 광학 드라이브, 테잎 스토리지 등일 수 있다. 다른 실시예에서, 스토리지 장치(150)는 다른 타입의 둘 또는 그 이상의 데이터 스토리지 장치(154)를 포함할 수 있다.
일 실시예에서, 데이터 스토리지 장치(154)는 솔리드-스테이트 스토리지(110)이며 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 어레이로 배열된다. 다른 실시예에서, 솔리드-스테이트 스토리지(110)는 둘 또는 그 이상의 뱅크(214a-n)으로 배열된다. 솔리드-스테이트 스토리지(110)은 도 2b를 참조로 이하 보다 상세하게 기술된다.
스토리지 장치(150a-n)는 함께 네트워크를 구성하고 분산된(distributed) 스토리지 장치로서 동작할 수 있다. 요청 장치(155)와 결합된 스토리지 장치(150a)는 객체 요청을 분산된 스토리지 장치로 제어한다. 일 실시예에서, 스토리지 장치(150) 및 결합된 스토리지 컨트롤러(152)는 객체를 관리하고, 분산된 객체 파일 시스템으로서 요청 장치(들)(155)에게 드러난다. 여기서, 병렬 객체 파일 시스템(parallel object file system)은 분산된 객체 파일 시스템의 일 타입의 예이다. 다른 실시예에서, 스토리지 장치(150) 및 결합된 스토리지 컨트롤러(152)는 객체를 관리하고, 분산된 객체 파일 서버로서 요청 장치(들)(155)에게 드러난다. 여기서, 병렬 객체 파일 서버는 분산된 객체 파일 서버의 일 타입의 예이다. 이들 그리고 다른 실시예에서, 요청 장치(155)는 배타적으로 객체를 관리할 수 있거나 또는 스토리지 장치(150)와 함께 객체 관리에 참여할 수 있으며; 이는 일반적으로 다른 클라이언트(114)에 대한 완전한 객체 관리를 위한 스토리지 장치(150)의 기능을 제한하지 않는다. 퇴보된 경우에서, 각각의 분산된 스토리지 장치, 분산된 객체 파일 시스템 및 분산된 객체 파일 서버는 단일 장치로서 독립적으로 동작할 수 있다. 네트워크로 구성된 스토리지 장치(150a-n)는 분산된 스토리지 장치, 분산된 객체 파일 시스템, 분산된 객체 파일 서버, 및 하나 또는 그 이상의 요청 장치(155)를 위해 구성된 하나 또는 그 이상의 능력(capabilities)의 이미지를 가지는 그 임의의 조합으로서 동작할 수 있다. 예를 들어, 스토리지 장치(150)는 제 1 요청 장치(155a)를 위해 분산된 스토리지 장치로서 동작하도록 구성될 수 있으나, 요청 장치(155b)를 위한 분산된 스토리지 장치 및 분산된 객체 파일 시스템으로서 동작할 수도 있다. 상기 시스템(101)이 하나의 스토리지 장치(150a)를 포함하면, 객체를 관리하는 스토리지 장치(150a)의 스토리지 컨트롤러(152a)는 요청 장치(들)(155)에게 객체 파일 시스템 또는 객체 파일 서버로서 나타날 수 있다.
일 실시예에서, 스토리지 장치들(150)이 분산된 스토리지 장치로서 함께 네트워크로 구성되면, 스토리지 장치(150)는 하나 또는 그 이상의 분산된 스토리지 컨트롤러(152)에 의해 관리되는 RAID(Redundant Array of Independent Drives)로서 동작한다. 예를 들어, 객체의 데이터 세그먼트를 기록하도록 하는 요청은 데이터 세그먼트가 패러티 스트라이프(parity stripe)를 사용하여 데이터 스토리지 장치(154a-n)에 걸쳐 스트립(stripped)되도록 하며, 이는 RAID 레벨에 의존한다. 이러한 배열의 일 이득은 단일의 스토리지 장치(150)가 스토리지 컨트롤러(152), 데이터 스토리지 장치(154) 또는 스토리지 장치(150)의 다른 컴포넌트의 실패(failure)의 경우에도 그러한 객체 관리 시스템이 지속적으로 사용가능(available)할 수 있는 것이다.
리던던트 네트워크(redundant network)가 스토리지 장치(150)과 요청 장치(155)를 상호연결하도록 사용되는 경우, 객체 관리 시스템은 네트워크 중 하나가 동작하도록 유지되는 한 네트워크 실패가 존재하여도 지속적으로 사용가능할 수 있다. 단일 스토리지 장치(150a)를 포함한 시스템(101)은 또한 다수의 데이터 스토리지 장치(154a)를 포함할 수 있으며, 스토리지 장치(150a)의 스토리지 컨트롤러(152a)는 RAID 컨트롤러로서 동작할 수 있고 스토리지 장치(150a)의 데이터 스토리지 장치(154a)에 걸쳐 데이터 세그먼트를 스트라입(stripe)할 수 있고, 패러티 스트라이프를 포함하며, RAID 레벨에 의존할 수 있다.
일 실시예에서, 하나 또는 그 이상의 스토리지 장치(150a-n)가 솔리드-스테이트 스토리지 장치 컨트롤러(202) 및 솔리드-스테이트 스토리지(110)를 포함한 솔리드-스테이트 스토리지 장치(102)이면, 솔리드-스테이트 스토리지 장치(들)(102)는 DIMM 구성, 도터 카드, 마이크로-모듈 등으로 구성될 수 있으며, 컴퓨터(112) 내에 구비될 수 있다. 컴퓨터(112)는 서버 또는 함께 네트워크로 구성되고 분산된 RAID 컨트롤러로서 구동하는 솔리드-스테이트 스토리지 장치(102)를 포함한 유사한 장치일 수 있다. 유익하게, 스토리지 장치(102)는 PCI-e, PCIe-AS, 이피니밴드 또는 다른 고성능 버스, 스위치된 버스(switched bus), 네트워크로 구성된 버스(networked bus), 또는 네트워크를 이용하여 연결될 수 있고, 솔리드-스테이트 스토리지(110a-n)을 걸쳐 데이터 세그먼트를 자발적으로 스트라이핑하는 단일 또는 분산된 솔리드-스테이트 스토리지 컨트롤러(202)를 포함한 매우 컴팩트하고 높은 성능의 RAID 스토리지 시스템을 제공할 수 있다.
일 실시예에서, 스토리지 장치(150)와 통신하도록 요청 장치(155)에 의해 사용된 동일한 네트워크는 피어 스토리지 장치(150b-n)와 통신하도록 피어 스토리지 장치(150a)에 의해 사용되어 RAID 기능성을 달성할 수 있다. 다른 실시예에서, 분리된 네트워크는 RAID를 위해 스토리지 장치들(150) 간에 사용될 수 있다. 다른 실시예에서, 요청 장치(155)는 리던던트 요청을 스토리지 장치(150)로 전송함으로써 RAID 프로세스에 참여할 수 있다. 예를 들어, 요청 장치(155)는 제 1 객체 기록 요청을 제 1 스토리지 장치(150a)로 전송하고, 동일한 데이터 세그먼트와 함께 제 2 객체 기록 요청을 제 2 스토리지 장치(150b)로 송신하여 단순한 미러링(mirroring)을 달성할 수 있다.
스토리지 장치(들)(102) 내의 객체 조작을 위한 기능을 위해, 스토리지 컨트롤러(들)(152)은 고유하게 하나의 RAID 레벨을 이용하여 하나의 데이터 세그먼트 또는 객체를 저장하는 반면, 다른 데이터 세그먼트 또는 객체는 다른 RAID 레벨을 이용하거나 또는 RAID 스트리핑을 사용하지 않고 저장되는 기능을 가진다. 이러한 다중 RAID 그룹핑은 스토리지 장치(150) 내의 다중 파티션과 결합될 수 있다. RAID 0, RAID 1, RAID 5, RAID 6 및 혼합 RAID 타입 10, 50, 60은 데이터 스토리지 장치(154a-n)를 포함하는 다양한 RAID 그룹에 걸쳐 동시에 지원될 수 있다. 당업자는 다른 RAID 타입 및 구성도 또한 동시에 지원될 수 있음을 인지할 것이다.
또한, 스토리지 컨트롤러(들)(152)이 자발적으로 RAID 컨트롤러로서 동작하므로, RAID 컨트롤러는 프로그레시브(progressive) RAID를 수행할 수 있고, 요청 장치(155)가 영향받거나, 참여하거나 심지어 RAID 레벨의 변화를 검출함 없이 임의의 RAID 레벨에서 다른 RAID 레벨까지 데이터 스토리지 장치(154)에 걸쳐 스트라이프된 객체 또는 객체의 일부를 변환할 수 있다. 바람직한 실시예에서, RAID 구성을 임의의 레벨에서 다른 레벨로 진행시키는 것은 객체 또는 심지어 패킷 베이스로 자발적으로 달성될 수 있으며, 스토리지 장치(150) 또는 스토리지 컨트롤러(152) 중 하나에서 동작하는 분산된 RAID 컨트롤 모듈에 의해 개시될 수 있다. 일반적으로, RAID 진행(progression)은 RAID 1과 같은 높은 성능 및 낮은 효율의 스토리지 구성으로부터 RAID 5와 같은 낮은 성능 및 높은 스토리지 효율 구성으로 진행되며, 여기서 변환은 액세스의 빈도(frequency)를 기반으로 동적으로 개시된다. 그러나, RAID 5에서 RAID 1으로의 구성의 진행 또한 가능하다. RAID 진행의 개시를 위한 다른 프로세스는 클라이언트 또는 스토리지 시스템 관리 서버 요청과 같은 외부 에이전트로부터 구성되거나 요청될 수 있다. 당업자는 객체를 자발적으로 관리하는 스토리지 컨트롤러(152)를 포함하는 스토리지 장치(102)의 다른 특징 및 이점을 파악할 것이다.
인-서버 SAN을 구비한 솔리드-스테이트 스토리지 장치(Solid-State Storage Device with IN-Server SAN)
도 1c는 본 발명에 따른 인-서버 SAN(Storage Area NEtwork)를 위한 시스템(103)의 일 실시예를 설명하는 개략적인 블록도이다.
상기 시스템(103)은 일반적으로 서버("서버(112)")로 구성되는 컴퓨터(112)를 포함한다. 각각의 서버(112)는 하나 또는 그 이상의 저장 장치(150)를 포함하며, 여기서 서버(112) 및 저장 장치(150)는 각각 공유된 네트워크 인터페이스(156)에 연결된다. 각각의 저장 장치(150)는 스토리지 컨트롤러(152) 및 해당 데이터 저(154)를 포함한다. 상기 시스템(103)은 서버(112)의 내부 또는 외부에 구비되는 클라이언트(114,114a,114b)를 포함한다. 클라이언트(114,114a,114b)는 각각의 서버(112) 및 각각의 저장 장치(150)와 하나 또는 그 이상의 컴퓨터 네트워크(116)를 통해 통신할 수 있으며, 이는 상술한 바와 실질적으로 유사하다.
저장 장치(150)는 DAS 모듈(158), NAS 모듈(160), 스토리지 통신 모듈(162), 인-서버 SAN 모듈(164), 공통 인터페이스 모듈(166), 프록시 모듈(170), 가상 버스 모듈(172), 전단(front-end) RAID 모듈(174), 및 후단(back-end) RAID 모듈(176)을 포함하며, 이는 이하 기술된다. 모듈(158-176)이 저장 장치(150)에 도시되지만, 각각의 모듈(158-176)의 전부 또는 일부는 저장 장치(150), 서버(112), 스토리지 컨트롤러(152), 또는 다른 장소에 위치될 수 있다.
인-서버 SAN과 함께 사용되는 서버(112)는 서버로 기능하는 컴퓨터이다. 서버(112)는 파일 서버 기능과 같은 적어도 하나의 서버 기능을 포함하지만, 또한 다른 서버 기능을 포함할 수도 있다. 서버(112)는 서버 팜(server farm)의 일부일 수 있고 다른 클라이언트(114)에게 서비스할 수 있다. 다른 실시예에서, 서버(112)는 또한 퍼스널 컴퓨터, 워크스테이션, 또는 저장 장치(150)를 구비하는 다른 컴퓨터일 수 있다. 서버(112)는 DAS(Direct Attached Storage), 스토리지 또는 NAS(Network Attached Storage)가 부착된 SAN으로서, 서버(112) 내의 하나 또는 그 이상의 저장 장치(150)에 액세스할 수 있다. 인-서버 SAN 또는 NAS에 구비되는 스토리지 컨트롤러(150)는 서버(112)의 내부 도는 외부에 구비될 수 있다.
일 실시예에서, 인-서버 SAN 장치는 적어도 하나의 클라이언트(114)에서 서버(112)로의 스토리지 요청을 서비스하기 위한 서버(112)로 부착되는 DAS 장치로서, 서버(112) 내의 스토리지 컨트롤러(152)에 의해 제어되는 적어도 하나의 데이터 저장 장치(154)의 적어도 일부를 구성하는 DAS 모듈(158)을 포함한다. 일 실시예에서, 제 1 데이터 저장 장치(154a)는 DAS로서 제 1 서버(112a)에 구성되며, 또한 인-서버 SAN 저장 장치로서 제 1 서버(112a)에 구성된다. 다른 실시예에서, 제 1 데이터 저장 장치(154a)는 분할되어, 하나의 파티션은 DAS이고 다른 파티션은 인-서버 SAN이다. 다른 실시예에서, 제 1 데이터 저장 장치(154a) 내의 저장 공간의 적어도 일부는 제 1 서버(112a)로의 DAS로서 구성되고, 제 1 데이터 저장 장치(154a) 상의 저장 공간의 동일한 부분은 제 1 서버(112a)로의 인-서버 SAN으로 구성된다.
다른 실시예에서, 인-서버 SAN 장치는 적어도 하나의 클라이언트(114)를 위한 NAS 장치로서 스토리지 컨트롤러(152)를 구성하고, 클라이언트(114)로부터의 파일 요청을 서비스하는 NAS 모듈(160)을 포함한다. 스토리지 컨트롤러(152)는 또한 제 1 서버(112)를 위한 인-서버 SAN 장치로서 구성될 수도 있다. 저장 장치(150)는 저장 장치(150)를 구비한 서버(112)로부터 독립적으로, 공유된 네트워크 인터페이스(156)을 통해 컴퓨터 네트워크(116)로 직접 연결할 수 있다.
하나의 구성 요소로, 인-서버 SAN을 위한 장치는 제 1 서버(112a) 내에 제 1 스토리지 컨트롤러(152a)를 포함하며, 여기서 제 1 스토리지 컨트롤러(152a)는 적어도 하나의 저장 장치(154a)를 포함한다. 제 1 서버(112a)는 제 1 서버(112a) 및제 1 스토리지 컨트롤러(152a)에 의해 공유되는 네트워크 인터페이스(156)을 포함한다. 인-서버 SAN 장치는 제 1 스토리지 컨트롤러(152a)와 제 1 서버(112a)의 외부에 구비된 적어도 하나의 장치 간의 통신을 구현하는 스토리지 통신 모듈(162)을 포함하여, 제 1 스토리지 컨트롤러(152a)와 외부 장치 간의 통신은 제 1 서버(112a)로부터 독립적이다. 스토리지 통신 모듈(162)은 제 1 스토리지 컨트롤러(152a)가 외부 통신을 위해 네트워크 인터페이스(156a)에 독립적으로 액세스하도록 허용할 수 있다. 일 실시예에서, 스토리지 통신 모듈(162)은 네트워크 인터페이스(156a) 내의 스위치에 액세스하여, 제 1 스토리지 컨트롤러(152a)와 외부 장치 간의 네트워크 트래픽을 지시한다.
인-서버 SAN 장치는 네트워크 프로토콜 및 버스 프로토콜 중 하나 또는 둘 모두를 사용하여 스토리지 요청을 서비스하는 인-서버 SAN 모듈(164)을 포함한다. 인-서버 SAN 모듈(164)은 제 1 서버(112a)로부터 독립적인 스토리지 요청을 서비스하고, 서비스 요청은 내부 또는 외부 클라이언트(114,114a)로부터 수신된다.
일 실시예에서, 제 1 서버(112)의 외부에 구비된 장치는 제 2 스토리지 컨트롤러(152b)이다. 제 2 스토리지 컨트롤러(152b)는 적어도 하나의 데이터 저장 장치(154b)를 제어한다. 인-서버 SAN 모듈(164)은 네트워크 인터페이스(156a)를 통한 통신을 사용하여 제 1 서버(112a)와 독립적인 제 1 , 제 2 스토리지 컨트롤러(152a,152b) 간의 스토리지 요청을 서비스한다. 제 2 스토리지 컨트롤러(152b)는 제 2 서버(112b)의 내부 또는 다른 장치의 내부에 구비될 수 있다.
다른 실시예에서, 제 1 서버(112a)의 외부에 구비된 장치는 클라이언트(114)이고, 스토리지 요청은 외부 클라이언트(114)로부터 발생하며, 여기서 제 1 스토리지 컨트롤러는 SAN의 적어도 일부로서 구성되고, 인-서버 SAN 모듈(164)은 제 1 서버(112a)와 독립적인 네트워크 인터페이스(156a)를 통해 스토리지 요청을 서비스한다. 외부 클라이언트(114)는 제 2 서버(112b) 내에 구비될 수 있거나 또는 제 2 서버(112b)의 외부에 구비될 수 있다. 일 실시예에서, 인-서버 SAN 모듈(164)은 비록 제 1 서버(112a)가 사용 불가능한 경우라도 외부 클라이언트(114)로부터 스토리지 요청을 서비스할 수 있다.
다른 실시예에서, 스토리지 요청을 발생시키는 클라이언트(114a)는 제 1 서버(112a)의 내부에 구비되며, 여기서 제 1 스토리지 컨트롤러(152a)는 SAN의 적어도 일부로서 구성되고, 인-서버 SAN 모듈(164)은 스토리지 요청을 하나 또는 그 이상의 네트워크 인터페이스(156a) 및 시스템 버스를 통해 서비스한다.
종래의 SAN 구성은 서버(112)로부터 원격에 위치한 저장 장치가 DAS(Direct Attached Storage)로서, 서버(112) 내에 구비된 저장 장치와 같이 액세스되도록 하여, 그 결과 저장 장치는 블록 저장 장치(block storage device)로서 나타난다. 일반적으로, SAN으로서 연결된 저장 장치는 SAN 프로토콜, 예컨대 파이버 채널, iSCSI(Internet Small Computer System Interface), 하이퍼SCSI, FICON(Fiber Connectivity), 이더넷을 통한 ATA(Advanced Technology Attachment) 등을 요구한다. 인-서버 SAN은 서버(112) 내부에 스토리지 컨트롤러(152)를 포함하며, 이는 여전히 네트워크 프로토콜 및/또는 버스 프로토콜을 사용하여 스토리지 컨트롤러(152a)와 원격 스토리지 컨트롤러(152b) 또는 외부 클라이언트(114) 간의 네트워크 연결을 허용한다.
일반적으로, SAN 프로토콜은 네트워크 프로토콜의 형태이며, 더 많은 네트워크 프로토콜, 예컨대 스토리지 컨트롤러(150a)와 SAN으로 구성되는 결합된 데이터 저장 장치(154a)를 허용하고 외부 클라이언트(114) 또는 제 2 스토리지 컨트롤러(152b)와 통신하는 인피니밴드가 떠오른다. 다른 예에서, 제 1 스토리지 컨트롤러(152a)는 이더넷을 사용하여 외부 클라이언트(114) 또는 제 2 스토리지 컨트롤러(152b)와 통신할 수 있다.
스토리지 컨트롤러(152)는 버스를 통해 내부 스토리지 컨트롤러(152) 또는 클라이언트(114a)와 통신할 수 있다. 예를 들어, 스토리지 컨트롤러(152)는PCIe-IOV(PCI Express Input/Output Virtualization)를지원할 수 있는 PCI-e를 사용하여 버스를 통해 통신할 수 있다. 다른 떠오르는 버스 프로토콜은 시스템 버스가 컴퓨터 또는 서버(112)의 외부로 확장되도록 허용하고, 스토리지 컨트롤러(152a)가 SAN으로서 구성되도록 허용한다. 이러한 버스 프로토콜 중 하나는 PCIe-AS이다. 본 발명은 단순히 SAN 프로토콜로 제한되지 않고, 또한 스토리지 요청을 서비스하는 떠오르는 네트워크 및 버스 프로토콜을 이용할 수 있다. 클라이언트(114) 또는 외부 스토리지 컨트롤러(152b) 중 어느 하나의 형태인 외부 장치는 확장된 시스템 버스 또는 컴퓨터 네트워크(116)을 통해 통신할 수 있다. 여기에 사용된 바와 같이, 스토리지 요청은 데이터를 기록하거나, 데이터를 독출하거나, 데이터를 소거하거나, 데이터를 조회하는 등의 요청을 포함하고, 블록 데이터 요청뿐만 아니라 객체 데이터, 메타데이터, 및 관리 요청을 포함할 수 있다.
종래의 서버(112)는 일반적으로 서버(112) 내의 장치로의 액세스를 제어하는 루트 컴플렉스(root complex)를 구비한다. 일반적으로, 서버(112)의 루트 컴플렉스는 네트워크 인터페이스(156)를 구비하여, 네트워크 인터페이스(156)를 통한 임의의 통신은 서버(112)에 의해 제어된다. 그러나, 인-서버 SAN 장치의 바람직한 실시예에서, 스토리지 컨트롤러(152)는 독립적으로 네트워크 인터페이스(156)를 액세스할 수 있어, 클라이언트(114)는 SAN을 형성하는 제 1 서버(112a) 내의 하나 또는 그 이상의 스토리지 컨트롤러(152a)와 직접 통신할 수 있거나, 또는 하나 또는 그 이상의 제 1 스토리지 컨트롤러(152a)는 SAN을 형성하기 위해 제 2 스토리지 컨트롤러(152b) 또는 다른 원격 스토리지 컨트롤러(152)와 함께 네트워크를 구성할 수 있다. 바람직한 실시예에서, 제 1 서버(112a)로부터 원격인 장치는 단일의 공유된 네트워크 어드레스를 통해 제 1 서버(112a) 또는 제 1 스토리지 컨트롤러(152a)에 액세스할 수 있다. 일 실시예에서, 인-서버 SAN 장치는 네트워크 인터페이스(156), 스토리지 컨트롤러(152), 및 서버(112)를 구성하는 공통 인터페이스 모듈(166)을 포함하여, 서버(112) 및 스토리지 컨트롤러(152)는 공유된 네트워크 어드레스를 사용하여 액세스 가능하게 된다.
다른 실시예에서, 서버(112)는 둘 또는 그 이상의 네트워크 인터페이스(156)를 포함한다. 예를 들어, 서버(112)는 하나의 네트워크 인터페이스(156)를 통해 통신할 수 있는 반면, 저장 장치(150)는 다른 인터페이스를 통해 통신할 수 있다. 다른 예에서, 서버(112)는 다수의 저장 장치(150)를 포함하고, 각각은 네트워크 인터페이스(156)를 구비한다. 당업자는 하나 또는 그 이상의 저장 장치(150) 및 하나 또는 그 이상의 네트워크 인터페이스(156)를 구비하는 서버(112)의 다른 구성을 파악할 것이며, 여기서, 하나 또는 그 이상의 저장 장치(150)는 서버(112)로부터 독립적인 네트워크 인터페이스(156)에 액세스한다. 당업자는 또한 이러한 다양한 구성이 네트워크 리던던시(redundancy)를 지원하고 유효성(avaiability)를 향상시키기 위해 확장될 수 있는 방법을 파악할 것이다.
유리하게, 인-서버 SAN 장치는 종래의 SAN의 복잡성 및 고비용을 상당 수 제거한다. 예를 들어, 일반적인 SAN은 외부 스토리지 컨트롤러(152)를 구비하고 데이터 저장 장치(154)와 결합된 서버(112)를 요구한다. 이는 랙에 추가적인 공간을 차지하고 케이블, 스위치 등을 요구한다. 케이블 연결, 스위칭, 종래의 SAN을 구성하기 위해 요구되는 다른 오버헤드는 공간을 차지하고, 대역폭을 감소시키며, 가격이 높다. 인-서버 SAN 장치는 스토리지 컨트롤러(152) 및 결합된 스토리지(154)가 서버(112)에 들어 맞도록 하고, 그 결과 요구되는 공간 및 비용을 감소시킨다. 인-서버 SAN은 또한 내부 및 외부 고속 데이터 버스를 통해 상대적으로 빠른 통신을 사용하는 연결을 허용한다.
일 실시예에서, 저장 장치(150)는 솔리드-스테이트 스토리지 장치(102)이며, 스토리지 컨트롤러(152)는 솔리드-스테이트 스토리지 컨트롤러(104)이며, 데이터 저장 장치(154)는 솔리드-스테이트 스토리지(110)이다. 이 실시예는 여기에 기술된 솔리드-스테이트 스토리지 장치(102)의 속도 때문에 유리하다. 또한, 솔리드-스테이트 스토리지 장치(102)는 서버(112)에 편리하게 들어맞고 적은 공간을 요구하는 DIMM으로 구성될 수 있다.
서버(112) 내의 하나 또는 그 이상의 내부 클라이언트(114a)는 또한 서버의 네트워크 인터페이스(156)를 통해 컴퓨터 네트워크(116)에 연결될 수 있으며, 클라이언트의 연결은 일반적으로 서버(112)에 의해 제어된다. 이는 다수의 장점을 가진다. 클라이언트(114a)는 직접적으로 저장 장치(150)에 국부적이고(locally) 원격적으로 액세스할 수 있고, 클라이언트(114a)와 저장 장치(150)의 메모리 간의 로컬 DMA(DMA) 또는 원격 DMA(RDMA) 데이터 전송을 개시할 수 있다.
다른 실시예에서, 서버(112)의 내부 또는 외부에 구비되는 클라이언트(114,114a)는 하나 또는 그 이상의 네트워크(116)를 통해 클라이언트(114)로의 파일 서버로서 구동할 수 있는 반면, 국부적으로(locally) 부착된 저장 장치(150)를 DAS 장치, 네트워크가 부착된 저장 장치(150), 인-서버 SAN의 일부로서 참여하는 네트워크가 부착된 솔리드-스테이트 스토리지(102) 장치, 외부 SAN, 및 하이브리드 SASN으로서 사용할 수 있다. 저장 장치(150)는 DAS, 인-서버-SAN, SAN, NAS, 및 그 임의의 조합 등에 동시에 참여할 수 있다. 추가적으로, 각각의 저장 장치(150)는 제 1 파티션이 저장 장치(150)를 DAS로서 사용 가능하도록 하고, 제 2 파티션이 저장 장치(150)를 인-서버-SAN의 엘리먼트로서 사용 가능하도록 하고, 제 3 파티션이 저장 장치(150)를 NAS로서 사용 가능하도록 하고, 제 4 파티션이 저장 장치(150)를 SAN의 엘리먼트로서 사용 가능하도록 하는 등의 방법으로 분할될 수 있다. 유사하게, 저장 장치(150)는 안전 및 액세스 제어 요구사항에 일치하도록 분할될 수 있다. 당업자는 저장 장치, 가상 저장 장치, 스토리지 네트워크, 가상 스토리지 네트워크, 개인 스토리지, 공유된 스토리지, 패러렐(parallel) 파일 시스템, 패러렐 객체 파일 시스템, 블록 저장 장치, 객체 저장 장치, 스토리지 어플라이언스, 네트워크 어플라이언스 등의 임의의 조합 및 순열이 구성되고 지원될 수 있는 방법을 파악할 것이다.
또한, 컴퓨터 네트워크(116)로의 직접적인 연결에 의해, 저장 장치(150)는 서로 간에 통신할 수 있고 인-서버 SAN으로서 동작할 수 있다. 서버(112) 내의 클라이언트(114a) 및 컴퓨터 네트워크(116)를 통해 연결된 클라이언트(114)는 SAN으로서 저장 장치(150)에 액세스할 수 있다. 저장 장치(150)를 서버(112)로 이동시키고 저장 장치(150)를 SAN으로 구성하는 기능을 구비함으로써, 서버(112)/저장 장치(150)의 조합은 전용 스토리지 컨트롤러, 파이버 채널 네트워크, 및 다른 장비를 위한 종래의 SAN의 필요를 제거한다. 인-서버 SAN 시스템(103)은 저장 장치(150)가 파워, 쿨링, 관리, 및 물리적 공간과 같은 공통 리소스를 클라이언트(114) 및 컴퓨터(112)와 공유하도록 하는 장점이 있다. 예를 들어, 저장 장치(150)는 서버(112)의 빈 슬랏을 채우고 SAN 또는 NAS의 모든 성능, 신뢰성 및 유효성을 제공할 수 있다. 당업자는 인-서버 SAN 시스템(103)의 다른 특징 및 장점을 파악할 것이다.
다른 구성에서, 다수의 인-서버-SAN 저장 장치(150a)는 단일의 서버(112a) 인프라구조 내에 함께 배치된다. 일 실시예에서, 서버(112a)는 외부 네트워크 인터페이스(156), 외부 클라이언트(114,114b), 또는 외부 저장 장치(150b)를 구비하지 않고 PCI-e IOV를 사용하여 상호연결된 하나 또는 그 이상의 내부 블레이드된(bladed) 서버 클라이언트(114a)를 포함한다.
또한, 인-서버 SAN 저장 장치(150)는 하나 또는 그 이상의 컴퓨터 네트워크(116)를 통해 컴퓨터(112)에 위치되거나(도 1a 참조), 또는 SAN 및 인-서버 SAN 둘 모두의 모든 기능을 구비한 하이브리드 SAN을 형성하도록 컴퓨터(112)를 사용하지 않고 컴퓨터 네트워크(116)에 직접 연결된 피어(peer) 저장 장치(150)와 통신할 수 있다. 이러한 유연성은 다양한 가능한 솔리드-스테이트 스토리지 네트워크 구현들 사이에 확장성(extensibility) 및 이주성(migration)을 단순화시키는 장점을 구비한다. 당업자는 솔리드-스테이트 컨트롤러(104)를 위치시키고 상호연결시키기 위한 다른 조합, 구성, 구현, 및 구조를 파악할 것이다.
네트워크 인터페이스(156a)가 서버(112a) 내에서 동작하는 오직 하나의 에이전트에 의해서만 제어될 수 있는 경우, 그 에이전트 내에서 동작하는 링크 설정 모듈(168)은 내부 클라이언트(114a)와 저장 장치(150a)/제 1 스토리지 컨트롤러(152a) 간의 통신 경로를 네트워크 인터페이스(156a)를 통해 외부 저장 장치(150b) 및 클라이언트(114,114b)로 설정할 수 있다. 바람직한 실시예에서, 통신 경로가 구축된 경우, 개별적인 내부 저장 장치(150a) 및 내부 클라이언트(114a)는 그들의 고유한 명령 큐를 구축하고 관리하고, 명령 및 데이터를 네트워크 인터페이스(156a)를 통해 외부 저장 장치(150b) 및 클라이언트(114,114b)로 어느 방향으로든, 직접 및 네트워크 인터페이스(156a)를 제어하는 프록시(proxy) 또는 에이전트에 독립적인 RDMA를 통해 전송할 수 있다. 일 실시예에서, 링크 설정 모듈(168)은 초기화 프로세스(initiallization process), 예컨대 하드웨어의 스타트업 또는 초기화 도중 통신 링크를 구축한다.
다른 실시예에서, 프록시 모듈(170)은 스토리지 요청을 서비스하도록 사용되는 명령의 적어도 일부를 제 1 서버(112a)를 통해 지시하는 반면, 스토리지 요청과 결합된 적어도 데이터, 및 다른 명령은 제 1 서버에 독립적으로 제 1 스토리지 컨트롤러 및 외부 저장 장치 간에 통신된다. 다른 실시예에서, 프록시 모듈(170)은 내부 저장 장치(150a) 및 클라이언트(114a)를 위해 명령 또는 데이터를 전달한다.
일 실시예에서, 제 1 서버(112a)는 제 1 서버(!12a) 내부에 하나 또는 그 이상의 서버를 포함하고, 제 1 서버(112a) 내의 하나 또는 그 이상의 서버가 분리된 가상 버스를 통해 하나 또는 그 이상의 스토리지 컨트롤러(152a)에 독립적으로 액세스하도록 허용하는 가상 버스 모듈(172)을 포함한다. 가상 버스는 PCIe-IOV와 같은 개선된 버스 프로토콜을 사용하여 구축될 수 있다. IOV를 지원하는 네트워크 인터페이스(156a)는 하나 또는 그 이상의 서버 및 하나 또는 그 이상의 스토리지 컨트롤러가 하나 또는 그 이상의 네트워크 인터페이스(156a)를 독립적으로 제어하도록 허용할 수 있다.
다양한 실시예에서, 인-서버 SAN 장치는 둘 또는 그 이상의 저장 장치(150)가 RAID로 구성되도록 허용한다. 일 실시예에서, 인-서버 SAN 장치는 둘 또는 그 이상의 스토리지 컨트롤러(152)를 RAID로서 구성하는 전단(front-end) RAID 모듈(174)을 포함한다. 클라이언트(114,114a)로부터의 스토리지 요청이 데이터를 저장시키는 요청을 포함하는 경우, 전단 RAID 모듈(174)은 특별히 구현된 RAID 레벨에 일치하여 RAID로 데이터를 기록함으로써 스토리지 요청을 서비스한다. 제 2 스토리지 컨트롤러(152)는 제 1 서버(112a) 또는 제 1 서버(112a)의 외부 중 어느 하나에 위치될 수 있다. 전단 RAID 모듈(174)은 스토리지 컨트롤러(152)의 RAID를 허용하여, 스토리지 컨트롤러(152)가 스토리지 요청을 전송하는 클라이언트(114,114a)에 보여지도록 한다. 이는 스트라이핑 및 패리티 정보가 마스터로 지정된 스토리지 컨트롤러(152)에 의해 또는 클라이언트(114,114a)에 의해 관리되도록 한다.
다른 실시예에서, 인-서버 SAN 장치는 스토리지 컨트롤러에 의해 제어되는 둘 또는 그 이상의 데이터 저장 장치(154)를 RAID로서 구성하는 후단(back-end) RAID 모듈(176)을 포함한다. 클라이언트로부터의 스토리지 요청이 데이터를 저장시키는 요청을 포함한 경우, 후단 RAID 모듈(176)은 구현된 RAID 레벨에 맞춰 RAID로 데이터를 기록함으로써 스토리지 요청을 서비스하여, RAID로서 구성된 저장 장치(154)가 제 1 스토리지 컨트롤러(152)에 의해 제어되는 단일의 데이터 저장 장치(154)로서 클라이언트(114,114a)에 의해 액세스되도록 한다. 이러한 RAID 구성은 RAID화(RAIDing)가 데이터 저장 장치(154)에 액세스하는 임의의 클라이언트(114,114a)에 대해 투명(transparent)하게 되는 방법으로 스토리지 컨트롤러(152)에 의해 제어되는 데이터 저장 장치(154)의 RAID화(RAIDing)를 허용한다. 다른 실시예에서, 전단 RAID 및 후단 RAID 둘 모두는 다중-레벨 RAID를 구비하도록 구현된다. 당업자는 여기에 기술된 솔리드-스테이트 스토리지 컨트롤러(104) 및 결합된 솔리드-스테이트 스토리지(110)에 맞게 저장 장치(152)를 RAID 시키는 다른 방법을 파악할 것이다.
스토리지 컨트롤러-관리 객체 장치(Apparatus For Storage Controller-Managed Objects)
도 2a는 본 발명에 따른 스토리지 장치 내의 객체 관리를 위한 장치(200)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 장치(200)는 객체 요청 리시버 모듈(260), 파싱 모듈(262), 명령 실행 모듈(264), 객체 인덱스 모듈(266), 객체 요청 큐잉(queing) 모듈(268), 메시지 모듈(270)을 포함한 패킷타이저(302), 및 객체 인덱스 재구성 모듈(272)을 포함한 스토리지 컨트롤러(152)를 포함하며, 이들은 이하 기술된다.
스토리지 컨트롤러(152)는 도 1b의 시스템(102)와 관련되어 기술된 스토리지 컨트롤러(152)와 실질적으로 유사하며, 도 2와 관련되어 기술된 솔리드-스테이트 스토리지 장치 컨트롤러(202)일 수 있다. 상기 장치(200)는 하나 또는 그 이상의 요청 장치(155)로부터 객체 요청을 수신하는 객체 요청 리시버 모듈(260)을 포함한다. 예를 들어, 객체 데이터 요청의 저장을 위해, 스토리지 컨트롤러(152)는 데이터 세그먼트를 데이터 패킷으로서 스토리지 컨트롤러(152)와 결합된 데이터 스토리지 장치(154)에 저장한다. 객체 요청은 일반적으로 스토리지 컨트롤러에 의해 관리되는 객체를 위해 하나 또는 그 이상의 객체 데이터 패킷 내에 저장된 또는 저장될 데이터 세그먼트에 보내진다. 객체 요청은 스토리지 컨트롤러(152)가 데이터로 추후 채워질 객체에서 로컬 또는 원격 DMA(Direct Memory Access) 또는 RDMA(Remote DMA) 전송을 사용할 수 있는 추후 객체 요청(later object 요청)을 생성하도록 요청할 수 있다.
일 실시예에서, 객체 요청은 객체의 전부 또는 일부를 이전에 생성된 객체에 기록하도록 하는 기록 요청이다. 일 예에서, 기록 요청은 객체의 데이터 세그먼트를 위한 것이다. 객체의 다른 데이터 세그먼트는 스토리지 장치(150) 또는 다른 스토리지 장치(152)에 기록될 수 있다. 다른 예에서, 기록 요청은 모든 객체를 위한 것이다. 다른 예에서, 객체 요청은 스토리지 컨트롤러(152)에 의해 관리된 데이터 세그먼트로부터 데이터를 독출하도록 한다. 다른 실시예에서, 객체 요청은 데이터 세그먼트 또는 객체를 삭제하도록 하는 삭제 요청이다.
유익하게, 스토리지 컨트롤러(152)는 새로운 객체를 기록하거나 기존의 객체에 데이터를 추가하는 것보다 더 하도록 하는 기록 요청을 받아들일 수 있다. 예를 들어, 객체 요청 리시버 모듈(260)에 의해 수신된 기록 요청은 스토리지 컨트롤러(152)에 의해 저장된 데이터의 앞에 데이터를 더하도록 하는 요청을 포함하여, 저장된 데이터에 데이터를 삽입하거나, 또는 데이터의 세그먼트를 교체할 수 있다. 스토리지 컨트롤러(152)에 의해 유지되는 객체 인덱스(object index)는 다른 스토리지 컨트롤러에서는 유효하지 않지만, 현재 서버 및 다른 컴퓨터의 파일 시스템 내의 스토리지 컨트롤러의 외부에서만 유효한 복합(complex) 기록 동작을 위해 요구되는 유연성(flexibility)을 제공한다.
상기 장치(200)는 객체 요청을 하나 또는 그 이상의 명령으로 파싱하는 파싱 모듈(262)을 포함한다. 일반적으로, 파싱 모듈(262)은 객체 요청을 하나 또는 그 이상의 버퍼로 파싱한다. 예를 들어, 객체 요청 내의 하나 또는 그 이상의 명령은 명령 버퍼(command buffer)로 파싱될 수 있다. 일반적으로, 파싱 모듈(262)은 객체 요청을 준비하여, 객체 요청 내의 정보가 스토리지 컨트롤러(152)에 의해 이해되고 실행될 수 있도록 한다. 당업자는 객체 요청을 하나 또는 다른 명령으로 파싱하는 파싱 모듈(262)의 다른 기능을 인지할 것이다.
상기 장치(200)는 객체 요청으로부터 파싱된 명령(들)을 실행하는 명령 실행 모듈(264)을 포함한다. 일 실시예에서, 명령 실행 모듈(264)은 하나의 명령을 실행한다. 다른 실시예에서, 명령 실행 모듈(264)은 다중 명령을 실행한다. 일반적으로, 명령 실행 모듈(264)은 객체 요청으로부터 파싱된 명령, 예컨대 기록 명령을 번역하고, 그리고 나서 서브명령(subcommands)을 생성, 큐잉(queue) 및 실행한다. 예를 들어, 객체 요청으로부터 파싱된 기록 명령은 스토리지 컨트롤러(152)로 보내져 다수의 데이터 세그먼트를 저장한다. 객체 요청은 또한 암호화, 압축 등과 같은 요구되는 속성(attributes)을 포함한다. 명령 실행 모듈(264)은 스토리지 컨트롤러(152)로 전달되어 데이터 세그먼트를 압축하고, 데이터 세그먼트를 암호화하고, 하나 또는 그 이상의 데이터 패킷 및 각각의 데이터 패킷에 대해 결합된 헤더를 생성하고, 미디어 암호화 키를 사용하여 데이터 패킷을 암호화하고, 에러 정정 코드를 추가하고, 그리고 데이터 패킷을 특정 장소에 저장하도록 할 수 있다. 데이터 패킷의 특정 장소로의 저장 및 서브명령은 다른 낮은 레벨의 서브명령으로 분할될 수도 있다. 당업자는 명령 실행 모듈(264)이 객체 요청으로부터 파싱된 하나 또는 그 이상의 명령을 실행할 수 있는 다른 방법을 인지할 것이다.
상기 장치(200)는 객체를 생성하거나 또는 객체의 데이터 세그먼트를 저장하는 스토리지 컨트롤러(152)에 응답하여 객체 인덱스 내의 객체 엔트리(object entry)를생성하는 객체 인덱스 모듈(266)을 포함한다. 일반적으로, 스토리지 컨트롤러(152)는 데이터 세그먼트로부터 데이터 패킷을 생성하고, 데이터 패킷이 저장된 장소는 데이터 세그먼트가 저장된 시점에 할당된다. 데이터 세그먼트와 함께 수신되거나 또는 객체 요청의 일부로서의 객체 메타데이터(object metadata)는 유사한 방법으로 저장될 수 있다.
객체 인덱스 모듈(266)은 데이터 패킷이 저장되고 데이터 패킷의 물리적 어드레스가 할당된 시점에 객체 엔트리를 객체 인덱스로 생성한다. 객체 엔트리는 객체의 논리적 식별자(logical identifier)와 스토리지 컨트롤러(152)가 하나 또는 그 이상의 데이터 패킷 및 임의의 객체 메타데이터 패킷을 저장한 하나 또는 그 이상의 해당 물리적 어드레스 간의 매핑(mapping)을 포함한다. 다른 실시예에서, 객체 인덱스 내의 엔트리는 객체의 데이터 패킷이 저장되기 전에 생성된다. 예를 들어, 스토리지 컨트롤러(152)가 미리 데이터 패킷이 저장될 물리적 어드레스를 결정한 경우, 객체 인덱스 모듈(266)은 객체 인덱스 내에 엔트리를 미리 생성할 수 있다.
일반적으로, 독출-변경-기록(read-modify-write) 동작 도중 발생할 수 있는, 객체 요청 또는 객체 요청의 그룹이 객체 또는 데이터 세그먼트가 변경되는 것을 야기한 경우, 객체 인덱스 모듈(266)은 변경된 객체에 대응하는 객체 인덱스 내의 엔트리를 업데이트한다. 일 실시예에서, 객체 인덱스는 새로운 객체 및 변경된 객체에 대한 객체 인덱스 내에 새로운 엔트리를 생성한다. 일반적으로, 객체의 일부만이 변경된 경우, 객체는 변경된 데이터 패킷과 변경되지 않은 채 유지된 일부 데이터 패킷을 포함한다. 이 경우, 새로운 엔트리는 처음부터 기록된 대로의 변하지 않은 데이터 패킷에 대한 매핑과 새로운 장소에 기록된 변경된 객체로의 매핑을 포함한다.
다른 실시예에서, 객체 요청 리시버 모듈(260)이 데이터 블록 또는 다른 객체 엘리먼트를 삭제하는 명령을 포함한 객체 요청을 수신하면, 스토리지 컨트롤러(152)는 객체에 대한 참조(reference), 객체와의 관계, 및 삭제된 데이터 블록의 사이즈를 포함하는 정보를 포함한 삭제 패킷(erase packet)과 같은 적어도 하나의 패킷을 저장할 수 있다. 또한, 삭제된 객체 엘리먼트가 영으로 채워지도록 더 지시할 수 있다. 따라서, 삭제 객체 요청은 삭제된 실제 메모리 또는 스토리지를 에뮬레이트(emulate)하도록 사용될 수 있고, 메모리/스토리지의 셀에 실제로 영이 저장된 적절한 메모리/스토리지의 일부를 실제로 구비할 수 있다.
유리하게, 데이터 세그먼트와 객체의 메타데이터 간의 매핑을 지시하는 엔트리를 구비한 객체 인덱스를 생성하는 것은 스토리지 컨트롤러(152)가 자발적으로 객체를 조작하고 관리하도록 한다. 이러한 기능은 스토리지 장치(150)에 데이터를 저장함에 있어서 매우 많은 유연성을 제공한다. 객체에 대한 인덱스 엔트리가 생성되면, 객체에 대한 수반되는 객체 요청은 스토리지 컨트롤러(152)에 의해 효율적으로 서비스된다.
일 실시예에서, 스토리지 컨트롤러(152)는 파싱 모듈(262)에 의해 파싱하기 전에 객체 요청 리시버 모듈(260)에 의해 수신된 하나 또는 그 이상의 객체 요청을 큐잉하는 객체 요청 큐잉 모듈을 포함한다. 객체 요청 큐잉 모듈(268)은 객체 요청이 수신된 시기와 실행된 시기 간의 유연성을 제공한다.
다른 실시예에서, 스토리지 컨트롤러(152)는 하나 또는 그 이상의 데이터 세그먼트로부터 하나 또는 그 이상의 데이터 패킷을 생성하는 패킷타이저(302)를 포함하며, 여기서 데이터 패킷은 데이터 스토리지 장치(154) 내의 스토리지를 위한 사이즈로 구성된다. 패킷타이저(302)는 도 3을 참조로 이하 보다 상세하게 기술된다. 일 실시예에서, 패킷타이저(302)는 각각의 패킷에 대해 헤더를 생성하는 메시지 모듈(270)을 포함한다. 헤더는 패킷 식별자 및 패킷 길이를 포함한다. 패킷 식별자는 패킷을 패킷이 형성된 객체에 연관시킨다.
일 실시예에서, 각각의 패킷은 자급식(self-contained)인 패킷 식별자를 포함하며, 패킷 식별자는 패킷 내에 포함된 객체 엘리먼트의 객체 내에 객체 및 관계를 식별하기에 충분한 정보를 포함한다. 그러나, 보다 효율적인 바람직한 실시예는 패킷을 컨테이너(contyainers)에 저장한다.
컨테이너는 패킷의 보다 효율적인 저장을 구현하는 데이터 구조이며, 객체와 데이터 패킷, 메타데이터 패킷, 및 컨테이너에 저장된 객체와 연관된 다른 패킷 간의 관계를 구축하는데 도움을 준다. 스토리지 컨트롤러(152)는 일반적으로 객체의 일부로서 수신된 객체 메타데이터와 데이터 세그먼트를 유사한 방식으로 취급한다. 일반적으로 "패킷"은 데이터, 메타데이터를 포함한 메타데이터 패킷, 또는 다른 패킷 타입의 다른 패킷을 포함한 데이터 패킷을 언급할 수 있다. 객체는 하나 또는 그 이상의 컨테이너에 저장될 수 있으며, 컨테이너는 일반적으로 하나의 고유한 객체만을 위해 패킷을 포함한다. 객체는 다수의 컨테이너 사이에 분산될 수 있다. 일반적으로 컨테이너는 단일 논리적 소거 블록(single logical erase block)(저장 단위(storage division) 내에 저장되고, 일반적으로 논리적 소거 블록들 간에 분할되지는 않는다.
일 예에서, 컨테이너는 둘 또는 그 이상의 논리적/가상 페이지 사이에 분할될 수 있다. 컨테이너는 객체를 구비한 컨테이너와 결합된 컨테이너 라벨에 의해 식별된다. 컨테이너는 많은 패킷에 영을 포함할 수 있고, 컨테이너 내의 패킷은 일반적으로 하나의 객체로부터 올 수 있다. 패킷은 많은 객체 엘리먼트 타입으로 구성될 수 있으며, 이는 객체 속성 엘리먼트, 객체 데이터 엘리먼트, 객체 인덱스 엘리먼트 등을 포함한다. 하이브리드 패킷(hybrid packets)은 하나의 객체 엘리먼트 타입보다 많은 것을 포함할 수 있다. 컨테이너 내 각각의 패킷은 일반적으로 객체와의 관계를 식별하는 고유한 식별자를 포함한다.
각각의 패킷은 하나의 컨테이너와 결합된다. 바람직한 실시예에서, 컨테이너는 소거 블록으로 제한되어, 각각의 소거 블록의 시작(beginning)에서 또는 그 근처에서 컨테이너 패킷이 발견될 수 있다. 이는 오류가 발생된(corrupted) 패킷 헤더를 포함한 소거 블록에 대한 데이터 손실을 제한하는 것을 도운다. 이 실시예에서, 객체 인덱스가 유효하지 않고 소거 블록 내의 패킷 헤더가 오류를 일으킨 경우, 오류를 일으킨 패킷 헤더로부터 소거 블록의 끝까지의 컨텐츠는 손실될 것이며, 이는 수반하는(subsequent) 패킷의 위치를 결정하는 신뢰성 있는 메커니즘이 존재하지 않기 때문이다. 다른 실시예에서, 보다 신뢰성 있는 접근은 페이지 경계(page boundary)로 제한된 컨테이너를 구비하는 것이다. 이 실시예는 오버헤드된 더 많은 헤더를 요구한다. 다른 실시예에서, 컨테이너는 페이지를 걸쳐 흐를 수 있으며, 블록 경계를 삭제할 수 있다. 이는 오버헤드된 헤더를 더 적게 요구하나, 패킷에 오류가 발생된 경우, 데이터의 보다 많은 부분이 손실될 수 있다. 이러한 다수의 실시예에서, RAID의 일부 타입은 데이터 보전(data integrity)을 더 보증하도록 사용되는 것이 예상된다.
일 실시예에서, 상기 장치(200)는 데이터 스토리지 장치(154)에 저장된 패킷 헤더로부터의 정보를 사용하여 객체 인덱스 내의 엔트리를 재구성하는 객체 인덱스 재구성 모듈(272)을 포함한다. 일 실시예에서, 객체 인덱스 재구성 모듈(272)은 각각의 패킷이 속한 객체를 결정하기 위해 헤더를 독출함으로써 그리고 객체 내에서 데이터 또는 메타데이터가 속하는 장소를 결정하기 위해 시퀀스 정보를 독출함으로써 객체 인덱스의 엔트리를 재구성한다. 객체 인덱스 재구성 모듈(272)은 각각의 패킷에 대한 물리적 어드레스 정보 및 패킷의 물리적 위치와 객체 식별자 및 데이터 세그먼트 시퀀스 간의 매핑을 생성하는 타임스탬프 또는 시퀀스 정보를 사용한다. 타임스탬프 또는 시퀀스 정보는 객체 인덱스 재구성 모듈(272)에 의해 사용되어, 인덱스에 만들어진 변화의 시퀀스를 재생하여, 그에 의해 일반적으로 가장 최근의 상태를 재구축한다.
다른 실시예에서, 객체 인덱스 재구성 모듈(272)은 컨테이너 패킷 정보와 함께 패킷 헤더 정보를 사용하여 패킷을 위치시켜, 패킷의 물리적 위치, 객체 식별자, 및 각각의 패킷의 시퀀스 번호를 식별하여, 객체 인덱스 내의 엔트리를 재구성한다. 일 실시예에서, 소거 블록은 타임 스탬프되거나 또는 패킷이 기록된대로 시퀀스 번호가 주어지고, 소거 블록의 타임스탬프 또는 시퀀스 정보는 컨테이너 헤더 및 패킷 헤더로부터 수집된 정보와 함께 사용되어 객체 인덱스를 재구성한다. 다른 실시예에서, 소거 블록이 복구된 경우 타임스탬프 또는 시퀀스 정보는 소거 블록으로 기록된다.
객체 인덱스가 휘발성 메모리에 저장된 경우, 에러, 전원 손실, 또는 객체 인덱스의 저장 없이 스토리지 컨트롤러(152)가 셧 다운되도록 유발시키는 다른 문제는 객체 인덱스가 재구성될 수 없는 경우 문제가 될 수 있다. 객체 인덱스 재구성 모듈(272)은 객체 인덱스가 휘발성 메모리의 장점, 예컨대 빠른 액세스를 허용하는 휘발성 메모리 내에 저장되도록 한다. 객체 인덱스 재구성 모듈(272)은 스토리지 장치(150)의 외부에 구비된 장치에 의존하지 않고 자발적으로 객체 인덱스의 빠른 재구성을 허용한다.
일 실시예에서, 휘발성 메모리의 객체 인덱스는 주기적으로 데이터 스토리지 장치(154)에 저장된다. 특정 예에서, 객체 인덱스 또는 "인덱스 메타데이터"는 솔리드-스테이트 스토리지(110)에 주기적으로 저장된다. 다른 실시예에서, 인덱스 메타데이터는 패킷을 저장하는 솔리드-스테이트 스토리지(110a-110n-1)로부터 분리된 솔리드-스테이트 스토리지(110n)에 저장된다. 인덱스 메타데이터는 데이터 및 요청 장치(155)로부터 전송된 객체 메타데이터로부터 독립적으로 관리되고, 스토리지 컨트롤러(152)/솔리드-스테이트 스토리지 장치 컨트롤러(202)에 의해 관리된다. 다른 데이터 및 객체로부터의 메타데이터로부터 분리된 인덱스 메타데이터를 관리하고 저장하는 것은 스토리지 컨트롤러(152)/솔리드-스테이트 스토리지 장치 컨트롤러(202)가 불필요하게 객체 메타데이터를 처리도록 하지 않고 효율적인 데이터 플로우를 허용한다.
일 실시예에서, 객체 요청 리시버 모듈(260)에 의해 수신된 객체 요청이 기록 요청을 포함한 경우, 스토리지 컨트롤러(152)는 로컬 DMA(Direct Memory Access) 또는 RDMA(Remote DMA) 동작으로서 요청 장치(155)의 메모리로부터 객체의 하나 또는 그 이상의 데이터 세그먼트를 수신한다. 바람직한 실시예에서, 스토리지 컨트롤러(152)는 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 요청 장치(155)의 메모리로부터 데이터를 끌어온다. 다른 실시예에서, 요청 장치(155)는 데이터 세그먼트(들)를 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 스토리지 컨트롤러(152)로 밀어낸다. 다른 실시예에서, 객체 요청이 독출 요청을 포함하는 경우, 스토리지 컨트롤러(152)는 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 요청 장치(155)의 메모리로 객체의 하나 또는 그 이상의 데이터 세그먼트를 전송한다. 바람직한 예에서, 스토리지 컨트롤러(152)는 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 데이터를 요청 장치(155)의 메모리로 밀어낸다. 다른 예에서, 요청 장치(155)는 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 스토리지 컨트롤러(152)로부터 데이터를 끌어온다. 다른 예에서, 스토리지 컨트롤러(152)는 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 요청 장치(155)의 메모리로부터 객체 명령 요청 세트를 끌어온다. 다른 예에서, 요청 장치(155)는 하나 또는 그 이상의 DMA 또는 RDMA 동작으로 스토리지 컨트롤러(152)로 객체 명령 요청 세트를 밀어낸다.
일 실시예에서, 스토리지 컨트롤러(152)는 블록 스토리지를 에뮬레이트하고 요청 장치(155)와 스토리지 컨트롤러(152) 간에 통신되는 객체는 하나 또는 그 이상의 데이터 블록을 포함한다. 일 실시예에서, 요청 장치(155)는 드라이버를 포함하여, 스토리지 장치(150)은 블록 스토리지 장치로 구현된다. 예를 들어, 요청 장치(152)는 특정 사이즈의 데이터의 블록을 요청 장치(155)가 데이터 블록을 저장하기 원하는 장소의 물리적 어드레스와 함께 전송할 수 있다. 스토리지 컨트롤러(152)는 데이터 블록을 수신하고, 데이터 블록과 함께 전송된 물리적 블록 어드레스 또는 물리적 블록 어드레스의 변환을 객체 식별자로서 사용한다. 그리고 나서 스토리지 컨트롤러(152)는 데이터 블록의 패킷타이징 및 의도한대로 데이터 블록을 저장함으로써 데이터 블록을 객체 또는 객체의 데이터 세그먼트로 저장한다. 그리고 나서, 객체 인덱스 모듈(266)은 물리적 블록-기반 객체 식별자 및 스토리지 컨트롤러(156)가 데이터 블록으로부터의 데이터를 포함한 데이터 패킷을 저장한 장소의 실제 물리적 위치를 이용하여 객체 인덱스 내에 엔트리를 생성한다.
다른 실시예에서, 스토리지 컨트롤러(152)는 블록 객체를 승인함으로써 블록 스토리지를 에뮬레이트한다. 블록 객체는 블록 구조 내의 하나 또는 그 이상의 데이터 블록을 포함할 수 있다. 일 실시예에서, 스토리지 컨트롤러(152)는 블록 객체를 임의의 다른 객체로서 취급한다. 다른 실시예에서, 객체는 전체 블록 장치, 블록 장치의 파티션, 또는 트랙, 섹터, 채널 등을 포함한 블록 장치의 다른 논리적 또는 물리적 서브-엘리먼트를 나타낼 수 있다. 구체적으로는 블록 장치 RAID 그룹을 프로그레시브 RAID와 같이 상이한 RAID를 지원하는 객체로 리매핑하는 기능이다. 당업자는 전통적인 또는 미래의 블록 장치를 객체로 매핑하는 다른 방법을 인지할 것이다.
솔리드-스테이트 스토리지 장치
도 2b는 본 발명에 따른 솔리드-스테이트 스토리지 장치(102) 내의 데이터 기록 파이프라인(106) 및 데이터 독출 파이프라인(108)을 포함하는 솔리드-스테이트 스토리지 장치 컨트롤러(202)의 일 실시예(201)를 설명하는 개략적인 블록도이다. 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 다수의 솔리드-스테이트 스토리지 컨트롤러 0 내지 N(104a-n)을 포함할 수 있으며, 각각은 솔리드-스테이트 스토리지(110)을 제어한다. 도시된 실시예에서, 두 개의 솔리드-스테이트 컨트롤러가 도시된다: 솔리드-스테이트 컨트롤러 0(104a) 및 솔리드-스테이트 스토리지 컨트롤러 N(104n)이며, 각각은 솔리드-스테이트 스토리지(110a-n)을 제어한다. 도시된 실시예에서, 솔리드-스테이트 스토리지 컨트롤러 0(104a)는 데이터 채널을 제어하여, 부착된 솔리드-스테이트 스토리지(110a)는 데이터를 제어한다. 솔리드-스테이트 스토리지 컨트롤러 N(104n)은 저장된 데이터와 결합된 인덱스 메타데이터 채널을 제어하고 결합된 솔리드-스테이트 스토리지(110n)은 인덱스 메타데이터를 저장한다. 대체적인 실시예에서, 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 단일 솔리드-스테이트 스토리지(110a)를 구비하는 단일 솔리드-스테이트 컨트롤러(104a)를 포함한다. 다른 실시예에서, 다수의 솔리드-스테이트 스토리지 컨트롤러(104a-n) 및 결합된 솔리드-스테이트 스토리지(110a-n)가 구비된다. 일 실시예에서, 결합된 솔리드-스테이트 스토리지(110a-110n-1)와 결합된 하나 또는 그 이상의 솔리드-스테이트 컨트롤러(104a-104n-1)는 데이터를 제어하는 반면, 그 결합된 솔리드-스테이트 스토리지(110n)와 결합된 적어도 하나의 솔리드-스테이트 스토리지 컨트롤러(104n)는 인덱스 메타데이터를 제어한다.
일 실시예에서, 적어도 하나의 솔리드-스테이트 컨트롤러(104)는 FPGA(Field-Programmable Gate Array)이며, 컨트롤러 기능은 FPGA에 프로그램된다. 구체적인 실시예에서, FPGA는 Xilinx® FPGA이다. 다른 실시예에서, 솔리드-스테이트 스토리지 컨트롤러(104)는 솔리드-스테이트 스토리지 컨트롤러(104)로서 구체적으로 디자인된 컴포넌트, 예컨대 ASIC(Application-Specific Integrated Circuit) 또는 커스텀 논리 솔루션을 포함한다. 각각의 솔리드-스테이트 스토리지 컨트롤러(104)는 일반적으로 데이터 기록 파이프라인(106) 및 데이터 독출 파이프라인(108)을 포함하며, 이는 도 3과 관련하여 더 기술된다. 다른 실시예에서, 적어도 하나의 솔리드-스테이트 스토리지 컨트롤러(104)는 FPGA, ASIC 및 커스텀 논리 컴포넌트의 조합으로 만들어진다.
솔리드-스테이트 스토리지
솔리드-스테이트 스토리지
솔리드-스테이트 스토리지(110)는 비-휘발성 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 어레이로 구성되며, 이는 뱅크(214) 내에 배열되고, 양방향 스토리지 I/O(Input/Output) 버스(210)를 통해 병렬로(in parallel) 액세스된다. 일 실시예에서, 스토리지 I/O 버스(210)는 어느 때라도 단방향 통신이 가능하다. 예를 들어, 데이터가 솔리드-스테이트 스토리지(110)에 기록되는 경우, 데이터는 솔리드-스테이트 스토리지(110)으로부터 독출될 수 없다. 다른 실시예에서, 데이터는 두 방향으로 동시에 흐를 수 있다. 그러나, 여기서 데이터 버스에 관하여 사용된 바와 같이, 양방향은 한 번에 오직 한 방향으로만 흐르는 데이터를 가지는 데이터 경로를 의미하지만, 양방향 데이터 버스에서 일 방향으로 흐르는 데이터가 정지된 경우, 데이터는 양방향 데이터 버스에서 반대 방향으로 흐를 수 있다.
솔리드-스테이트 스토리지 엘리먼트(예컨대, SSS 0.0(216a))는 일반적으로 칩(하나 또는 그 이상의 다이의 패키지) 또는 회로기판 상의 다이(die)로 구성된다. 도시된 바와 같이, 이들 다수의 엘리먼트가 칩 패키지, 칩 패키지의 스택, 또는 다른 패키지 엘리먼트에서 함께 패키지로 구성될지라도, 솔리드-스테이트 스토리지 엘리먼트(예컨대 216a)는 다른 솔리드-스테이트 스토리지 엘리먼트(예컨대 218a)와 독립적으로 또는 반-독립적으로(semi-independently) 동작한다. 도시된 바와 같이, 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 컬럼은 뱅크(214)로 지시된다. 도시된 바와 같이, "n" 개의 뱅크(214a-n) 및 솔리드-스테이트 스토리지(110) 내의 n×m 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 어레이 내의 뱅크 당 "m" 개의 솔리드-스테이트 스토리지 엘리먼트(216a-m,218a-m,220a-m)가 구비된다. 일 실시예에서, 솔리드-스테이트 스토리지(110a)는 여덟 개의 뱅크(214)와 함께 뱅크(214) 당 스무 개의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)를 포함하고, 솔리드-스테이트 스토리지(110n)은 한 개의 뱅크(214)와 함께 뱅크(214) 당 두 개의 솔리드-스테이트 스토리지 엘리먼트(216,218)을 포함한다. 일 실시예에서, 각각의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)은 SLC(Single-Level Cell) 장치를 포함한다. 다른 실시예에서, 각각의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)은 MLC(Multi-Level Cell) 장치를 포함한다.
일 실시예에서, 공통 스토리지 I/O 버스(210a) 열(예컨대, 216b,218b,220b)을 공유하는 다수의 뱅크에 대한 솔리드-스테이트 스토리지 엘리먼트는 함께 패키지로 구성된다. 일 실시예에서, 솔리드-스테이트 스토리지 엘리먼트(216,218,220)은 하나 또는 그 이상의 칩이 수직으로 적층되고 칩 당 하나 또는 그 이상의 다이를 구비할 수 있고, 각각의 다이는 독립적으로 액세스될 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 엘리먼트(예컨대 SSS 0.0(216a))는 다이 당 하나 또는 그 이상의 가상 다이를 구비하고, 칩 당 하나 또는 그 이상의 다이를 구비하고, 하나 또는 그 이상의 칩이 수직으로 적층되고, 각각의 가상 다이(virtual die)는 독립적으로 액세스될 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 엘리먼트(SSS 0.0(216a))는 다이 당 하나 또는 그 이상의 가상 다이를 구비할 수 있고, 수직으로 적층된 하나 또는 그 이상의 다이의 일부 또는 전부와 함께 칩 당 하나 또는 그 이상의 다이를 구비할 수 있고, 각각의 가상 다이는 독립적으로 액세스될 수 있다.
일 실시예에서, 두 개의 다이는 그룹 당 네 개의 스택을 포함하여 수직으로 적층되어 여덟 개의 스토리지 엘리먼트(예컨대 SSS0.0-SSS 0.8)(216a-220a)를 형성하며, 각각은 별개의 뱅크(214a-n)에 구비된다. 다른 실시예에서, 20 개의 스토리지 엘리먼트(예컨대 SSS 0.0-SSS 20.0)(216)는 가상 뱅크(214a)를형성하여, 여덟 개의 가상 뱅크 각각은 20 개의 스토리지 엘리먼트(예컨대 SSS 0.0-SSS 20.8)(216,218,220)을 구비한다. 데이터는 스토리지 I/O 버스(210)을 통해 솔리드-스테이트 스토리지(110)으로 전송되고 스토리지 엘리먼트(SSS 0.0-SSS 0.8)(216a,218a,220a)의 특정 그룹의 모든 스토리지 엘리먼트로 전송된다. 스토리지 컨트롤 버스(212a)는 특정 뱅크(예컨대 뱅크-0(214a))를 선택하도록 사용되어, 모든 뱅크(214)로 연결된 스토리지 I/O 버스(210)를 통해 수신된 데이터가 선택된 뱅크(214a)로 기록된다.
바람직한 실시예에서, 스토리지 I/O 버스(210)는 하나 또는 그 이상의 독립적인 I/O 버스들(210 a.a-m, 210 n.1-m을 포함하는 IIOBa-m)로 구성되며, 각각의 열(row) 내의 솔리드-스테이트 스토리지 엘리먼트는 각각의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)에 병렬로 액세스하는 독립적인 I/O 버스들 중 하나를 공유하여, 모든 뱅크(214)는 동시에 액세스된다. 예를 들어, 스토리지 I/O 버스(210)의 하나의 채널은 각각의 뱅크(214a-n)의 제 1 솔리드-스테이트 스토리지 엘리먼트(216a,218a,220a)에 동시에 액세스할 수 있다. 스토리지 I/O 버스(210)의 제 2 채널은 각각의 뱅크(214a-n)의 제 2 솔리드-스테이트 스토리지 엘리먼트(216b,218b,220b)에 동시에 액세스할 수 있다. 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 각각의 열은 동시에 액세스된다. 일 실시예에서, 솔리드-스테이트 스토리지 엘리먼트(216,218,220)가 멀티-레벨(물리적으로 적층됨)이면, 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 모든 물리적 레벨들은 동시에 액세스된다. 여기에 사용된 "동시(simultaneously)"는 또한 장치가 스위칭 노이즈를 방지하기 위해 다소 상이한 인터벌을 두고 액세스되는 거의 동시 접속을 포함한다. 용어 "동시"는 본 발명의 명세서에서 명령 및/또는 데이터가 개별적으로 하나가 전송되고 그 다음에 다른 하나가 전송되는 순차적(sequential) 또는 직렬(serial) 액세스와 구별하도록 사용된다.
일반적으로, 뱅크(214a-n)는 스토리지 컨트롤 버스(212)를 사용하여 독립적으로 선택된다. 일 실시예에서, 뱅크(214)는 칩 인에이블(chip enable) 또는 칩 선택(chip select)를 사용하여 선택된다. 챕 선택 및 칩 인에이블 둘 모두가 유효한 경우, 스토리지 컨트롤 버스(212)는 멀티-레벨의 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 중 하나의 레벨을 선택할 수 있다. 다른 실시예에서, 다른 명령은 스토리지 컨트롤 버스(212)에 의해 사용되어 멀티-레벨의 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 중 하나의 레벨을 개별적으로 선택한다. 솔리드-스테이트 스토리지 엘리먼트(216,218,220)는 또한 스토리지 I/O 버스(210) 및 스토리지 컨트롤 버스(212)에 전송된 제어 및 어드레스 정보의 조합을 통해 선택될 수 있다.
일 실시예에서, 각각의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)는 소거 블록(erase blocks)으로 분할되며, 각각의 소거 블록은 페이지(pages)로 분할된다. 일반적인 페이지는 2000 byte("2kB")이다. 일 예에서, 솔리드-스테이트 스토리지 엘리먼트(예컨대 SSS 0.0)는 두 개의 레지스터를 포함하고 두 개의 페이지를 프로그램할 수 있어, 두 개의 레지스터 솔리드-스테이트 스토리지 엘리먼트(216,218,220)는 4 kB의 용량(capacity)을 가진다. 따라서, 20 개의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 뱅크(214)는 스토리지 I/O 버스(210)의 채널을 나가는 동일한 어드레스로 액세스되는 80kB 용량의 페이지를 가질 수 있다.
이러한 80kB의 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 뱅크(214) 내의 페이지 그룹은 가상 페이지(virtual page)로 언급될 수 있다. 유사하게, 뱅크(214a)의 각각의 스토리지 엘리먼트(216a-m)의 소거 블록은 가상 소거 블록을 형성하도록 그룹으로 구성될 수 있다. 바람직한 실시예에서, 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 내의 페이지의 소거 블록은 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 내에 삭제 명령이 수신된 경우 삭제된다. 반면 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 내의 소거 블록, 페이지, 플랜(planes) 또는 다른 논리적 및 물리적 디비젼(division)의 사이즈 및 개수는 기술 발전에 의해 시간에 따라 변경될 것이 예상되며, 새로운 구성에 일관된 많은 실시예가 가능하고 명세서의 일반적인 기술에 일관되도록 예상될 것이다.
일반적으로, 패킷이 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 내의 특정 장소에 기록되고, 패킷이 특정 뱅크의 특정 엘리먼트의 특정 소거 블록의 특정 페이지 내의 장소에 기록되도록 의도된 경우, 물리적 어드레스는 스토리지 I/O 버스(210)에 전송되고 그 다음으로 패킷이 전송된다. 물리적 어드레스는 솔리드-스테이트 스토리지 엘리먼트(216,218,220)에 대한 충분한 정보를 포함하여 패킷을 페이지 내의 지정된 장소로 보낸다. 스토리지 엘리먼트의 열(row) 내의 모든 스토리지 엘리먼트(예컨대 SSS 0.0-SSS 0.N(216a,218a,220a))가 스토리지 I/O 버스(210 a.a) 내의 적절한 버스에 의해 동시에 액세스되어, 적절한 페이지에 도달하고 데이터 패킷을 스토리지 엘리먼트(SSS 0.0-SSS 0.N(216a,218a,220a))의 열 내의 유사하게 어드레스된 페이지로 기록하는 것을 방지하므로, 데이터 패킷이 기록될 올바른 페이지를 구비한 솔리드-스테이트 스토리지 엘리먼트(SSS 0.0(216a))를 포함한 뱅크(214a)는 스토리지 컨트롤 버스(212)에 의해 동시에 선택된다.
유사하게, 스토리지 I/O 버스(212) 상의 독출 명령 트래블링(traveling)은 스토리지 컨트롤 버스(212) 상의 동시 명령을 요구하여 단일 뱅크(214a) 및그 뱅크(214a) 내의 적절한 페이지를 선택한다. 바람직한 실시예에서, 독출 명령은 전체 페이지를 독출하고, 이는 뱅크(214) 내에 병렬로 다수의(multiple) 솔리드-스테이트 스토리지 엘리먼트(216,218,220)가 구비되기 때문이며, 전체 가상 페이지는 독출 명령으로 독출된다. 그러나, 독출 명령은 서브명령으로 분할될 수 있으며, 이는 뱅크 인터리브(bank interleave)에 관하여 이하 설명될 것이다. 가상 페이지는 기록 동작으로도 액세스될 수 있다.
소거 블록 소거 명령은 특정 소거 블록을 소거하기 위한 특정 소거 블록 어드레스를 사용하여 스토리지 I/O 버스(210)을 통해 소거 블록을 소거하도록 전송될 수 있다. 일반적으로, 소거 블록 소거 명령은 스토리지 I/O 버스(210)의 병렬 경로(parallel paths)를 통해 전송되어 가상 소거 블록을 소거할 수 있으며, 각각은 특정 소거 블록을 소거하기 위한 특정 소거 블록 어드레스를 포함한다. 동시에 특정 뱅크(예컨대 뱅크-0(214a))는 스토리지 컨트롤 버스(212)를 통해 선택되어 모든 뱅크(뱅크 1-N(214b-n)) 내의 유사하게 어드레스된 소거 블록의 소거를 방지한다. 다른 명령은 또한 스토리지 I/O 버스(210) 및 스토리지 컨트롤 버스(212)의 조합을 이용하여 특정 장소로 전송될 수 있다. 당업자는 양방향 스토리지 I/O 버스(210) 및 스토리지 컨트롤 버스(212)를 이용한 특정 스토리지 장소를 선택하는 다른 방법을 인식할 것이다.
일 실시예에서, 패킷은 솔리드-스테이트 스토리지(110)으로 순차적으로 기록된다. 예를 들어, 패킷은 스토리지 엘리먼트(216)의 뱅크(214a)의 스토리지 기록 버퍼로 스트리밍되고, 버퍼가 가득 찬 경우, 패킷은 지정된 가상 페이지로 프로그래밍된다. 그리고 나서 패킷은 스토리지 기록 버퍼를 다시 채우고, 가득 찬 경우, 패킷은 다음 가상 페이지로 기록된다. 다음 가상 페이지는 동일한 뱅크(214a) 또는 다른 뱅크(예컨대 214b)에 구비될 수 있다. 가상 페이지 후에 가상 페이지로 넘어가는 이러한 프로세스는 일반적으로 가상 소거 블록이 가득찰 때까지 지속된다. 다른 실시예에서, 스트리밍은 프로세스가 지속되면서 가상 소거 블록 경계에 걸쳐, 가상 소거 블록 후에 가상 소거 블록으로 넘어가도록 지속될 수 있다.
독출, 변경, 기록 동작에서, 객체와 결합된 데이터 패킷은 장소에 지정되고 독출 동작으로 독출된다. 변경되어온 변경된 객체의 데이터 세그먼트는 그들이 독출되어온 장소로 기록되지 않는다. 대신, 변경된 데이터 세그먼트는 데이터 패킷으로 다시 변환되고 그리고 나서 현재 기록되고 있는 가상 페이지 내의 다음 유효한 장소로 기록된다. 각각의 데이터 패킷에 대한 객체 인덱스 엔트리는 변경된 데이터 세그먼트를 포함하는 패킷으로 지시된다. 변경되지 않은 동일한 객체와 결합된 데이터 패킷에 대한 객체 인덱스 내의 엔트리 또는 엔트리들은 변경되지 않은 데이터 패킷의 원래 장소로의 포인터(pointers)를 포함할 것이다. 따라서, 원래 객체가 유지되는 경우, 예를 들어 객체의 이전 버전이 유지되는 경우, 원래 객체는 원래 기록된 대로의 모든 데이터 패킷으로의 포인터를 객체 인덱스 내에 구비할 것이다. 새로운 객체는 객체 인덱스 내에 원래 데이터 패킷의 일부로의 포인터 및 현재 기록되고 있는 가상 페이지 내의 변경된 데이터 패킷으로의 포인터를 구비할 것이다.
카피 동작에서, 객체 인덱스는 솔리드-스테이트 스토리지(110) 내에 저장된 다수의 패킷으로 매핑된 원래 객체에 대한 엔트리를 포함한다. 카피가 만들어지면, 새로운 객체가 생성되고, 새로운 엔트리가 원래의 패킷으로 새로운 객체를 매핑한 객체 인덱스 내에서 생성된다. 새로운 객체는 또한 객체 인덱스 내의 새로운 엔트리로 매핑된 장소와 함께 솔리드-스테이트 스토리지(110)으로 기록된다. 새로운 객체 패킷은 카피로 전해지지 않은 원래 객체에 변화가 가해지고 객체 인덱스가 손실되거나 요류발생된(corrupted) 경우를 참조한 원래 객체 내의 패킷을 식별하도록 사용될 수 있다.
유리하게, 순차적 패킷 기록은 솔리드-스테이트 스토리지(110)의 보다 고른 사용을 용이하게 하고, 솔리드-스토리지 장치 컨트롤러(202)가 스토리지 핫 스팟(hot spot) 및 솔리드-스테이트 스토리지(110) 내의 다양한 가상 페이지의 레벨 사용을 감시하도록 허용한다. 순차적 패킷 기록은 또한 강력하고, 효율적인 가비지 컬렉션 시스템(garbage collection system)을 구현하며, 이는 이하 기술된다. 당업자는 데이터 패킷의 순차 저장의 다른 장점을 인식할 것이다.
솔리드-스테이트 스토리지 장치 컨트롤러
다양한 실시예에서, 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 또한 데이터 버스(204), 로컬 버스(206), 버퍼 컨트롤러(208), 버퍼 0-N(222a-n), 마스터 컨트롤러(224), DMA(Direct Memory Access) 컨트롤러(226), 메모리 컨트롤러(228), 동적 메모리 어레이(230), 정적 랜덤 메모리 어레이(232), 관리 컨트롤러(234), 관리 버스(236), 시스템 버스(240)로의 브리지(238), 및 다양한(miscellaneous) 로직(242)을 포함하며, 이는 이하 기술된다. 다른 실시예에서, 시스템 버스(240)는 하나 또는 그 이상의 NIC(Network Interface Card)(244), RDMA(Remote DMA) 컨트롤러(246)를 포함할 수 있는 장치, 하나 또는 그 이상의 CPU(Central Processing Unit)(248), 하나 또는 그 이상의 외부 메모리 컨트롤러(250) 및 결합된 외부 메모리 어레이(252), 하나 또는 그 이상의 스토리지 컨트롤러(254), 피어(peer) 컨트롤러(256), 및 애플리케이션 특정 프로세서(258)와 결합되며, 이는 이하 기술된다. 시스템 버스(240)에 연결된 컴포넌트(244-258)는 컴퓨터(112)에 위치할 수 있거나 또는 다른 장치일 수 있다.
일반적으로, 솔리드-스테이트 스토리지 컨트롤러(들)(104)은 데이터를 스토리지 I/O 버스(210)을 통해 솔리드-스테이트 스토리지(110)로 통신한다. 솔리드-스테이트 스토리지가 뱅크(214)에 배열되고 각각의 뱅크(214)가 병렬로 액세스되는 다수의 스토리지 엘리먼트(216,218,220)를 포함하는 일반적인 실시예에서, 스토리지 I/O 버스(210)는 버스의 어레이이며, 스토리지 엘리먼트(216,218,220)의 각각의 열에 대한 버스는 뱅크(214)로 연결된다. 여기에 사용되는 바와 같이, 용어 "스토리지 I/O 버스"는 하나의 스토리지 I/O 버스(210) 또는 데이터 독립 버스들(204)의 어레이를 의미할 수 있다. 바람직한 실시예에서, 스토리지 엘리먼트(예컨대 216a,218a,220a)의 열에 액세싱하는 각각의 스토리지 I/O 버스(210)는 스토리지 엘리먼트(216a,218a,220a)의 열에 액세스되는 스토리지 디비젼(예컨대 소거 블록)에 대한 논리적-물리적 매핑(logical-tophysical mapping)을 포함할 수 있다. 이러한 매핑은 첫 번째 스토리지 디비젼이 실패하거나, 부분적으로 실패하거나, 액세스 불가능하거나, 또는 다른 문제를 가지는 경우, 스토리지 디비젼의 물리적 어드레스로 매핑되는 논리적 어드레스가 다른 스토리지 디비젼으로 리매핑되도록 한다. 리매핑은 도 3의 리매핑 모듈(314)와 연관되어 더 설명된다.
데이터는 또한 시스템 버스(240), 브리지(238), 로컬 버스(206), 버퍼(들)(22), 및 마지막으로 데이터 버스(204)를 통해 요청 장치(144)로부터 솔리드-스테이트 스토리지 컨트롤러(들)(104)로 통신될 수 있다. 데이터 버스(204)는 일반적으로 버퍼 컨트롤러(208)를 사용하여 제어되는 하나 또는 그 이상의 버퍼(222a-n)에 연결된다. 버퍼 컨트롤러(208)는 일반적으로 로컬 버스(206)에서 버퍼(222)로의 데이터 전송 및 데이터 버스(204)를 통한 파이프라인 입력 버퍼(306) 및 출력 버퍼(330)로의 데이터 전송을 제어한다. 버퍼 컨트롤러(222)는 일반적으로 요청 장치로부터 출발한 데이터가 버퍼(222)에 임시로 저장되는 방법 및 그리고 나서 데이터 버스(204)로 전송되는 방법, 또는 그 역의 전송 방법을 제어하여, 다른 클럭 도메인을 설명하여, 데이터 충돌 등을 방지한다. 버퍼 컨트롤러(208)는 일반적으로 데이터 흐름을 조정하기 위해 마스터 컨트롤러(224)와 결합하여 동작한다. 데이터가 도달하면, 데이터는 시스템 버스(240)에 도달할 것이며, 브리지(238)을 통해 로컬 버스(206)로 전송될 것이다.
일반적으로 데이터는 마스터 컨트롤러(2224) 및 버퍼 컨트롤러(208)에 의해 지시된 대로 로컬 버스(206)로부터 하나 또는 그 이상의 데이터 버퍼(222)로 전송된다. 그리고 나서 데이터는 버퍼(들)(222)로부터 데이터 버스(204)로 흘러가며, 솔리드-스테이트 컨트롤러(104)를 통해, NAND 플래시 또는 다른 저장 매체와 같은 솔리드-스테이트 스토리지(110)으로 전송된다. 바람직한 실시예에서, 데이터 및 데이터와 함께 도달한 결합된 대역외(out-of-band) 메타데이터("객체 메타데이터")는 하나 또는 그 이상의 솔리드-스테이트 스토리지 컨트롤러(104a-104n-1) 및 결합된 솔리드-스테이트 스토리지(110a-110n-1)를 포함하는 하나 또는 그 이상의 데이터 채널을 이용하여 통신되며, 반면 적어도 하나의 채널(솔리드-스테이트 스토리지 컨트롤러(104n), 솔리드-스테이트 스토리지(110n))은 인덱스 정보 및 솔리드-스테이트 스토리지 장치(102)에서 내부적으로 생성된 다른 메타데이터와 같은 대역내(in-band) 메타데이터에 사용된다.
로컬 버스(206)는 일반적으로 양방향 버스 또는 솔리드-스테이트 스토리지 장치 컨트롤러(202) 내부의 장치들간 그리고 솔리드-스테이트 스토리지 장치(102) 내부의 장치 및 시스템 버스(240)에 연결된 장치(244-258) 간의 데이터 및 명령의 통신을 허용하는 버스들의 세트이다. 브리지(238)는 로컬 버스(206) 및 시스템 버스(240) 간의 통신을 구현한다. 당업자는 링 구조 또는 교환된(switched) 별 구조와 같은 다른 실시예 및 버스(240,206,204,210) 및 브리지(238)의 기능을 인식할 것이다.
시스템 버스(240)는 일반적으로 컴퓨터(112)의 버스 또는 솔리드-스테이트 스토리지 장치(102)가 설치되거나 연결된 다른 장치이다. 일 실시예에서, 시스템 버스(240)은 PCI-e 버스, 직렬 ATA(Serial Advanced Technology Attachment) 버스, 병렬 버스 등일 수 있다. 다른 실시예에서, 시스템 버스(240)는 SCSI(Small Computer System Interface), 파이어와이어(Firewire), 섬유 채널(Fiber Channel), ISB, PCIe-AS 등과 같은 외부 버스이다. 솔리드-스테이트 스토리지 장치(102)는 외부적으로 연결된 장치로서 또는 장치에 내부적으로 구비되도록 패키지로 구성될 수 있다.
솔리드-스테이트 스토리지 장치 컨트롤러(202)는 솔리드-스테이트 스토리지 장치(102) 내에서 보다 높은 레벨의 기능을 제어하는 마스터 컨트롤러(224)를 포함한다. 다양한 실시예에서, 마스터 컨트롤러(224)는 객체 요청 및 다른 요청을 해석함으로써 데이터 플로우를 제어하며, DMA 요청 등과 조정하여(coordinating), 데이터와 결합된 객체 식별자를 결합된 데이터의 물리적 위치에 매핑하는 인덱스의 생성을 지시한다. 여기에 기술된 많은 기능은 마스터 컨트롤러(224)가 전부 제어하거나 또는 부분적으로 제어한다.
일 실시예에서, 마스터 컨트롤러(224)는 임베디드(embeded) 컨트롤러(들)을 사용한다. 다른 실시예에서, 마스터 컨트롤러(224)는 동적 메모리 어레이(230)(DRAM), 정적 메모리 어레이(323)(SRAM) 등과 같은 로컬 메모리를 사용한다. 일 실시예에서, 로컬 메모리는 마스터 컨트롤러(224)를 사용하여 제어된다. 다른 실시예에서, 마스터 컨트롤러는 메모리 컨트롤러(228)을 통해 액세스한다. 다른 실시예에서, 마스터 컨트롤러는 리눅스 서버를 구동하고 WWW(World Wide Web), HTML(Hyper-Text Markup Languate) 등과 같은 다양한 공통 서버 인터페이스를 지원할 수 있다. 다른 실시예에서, 마스터 컨트롤러(224)는 나노 프로세서를 사용한다. 마스터 컨트롤러(224)는 프로그래밍 가능하거나 표준 로직, 또는 상술한 컨트롤러 타입의 임의의 조합을 이용하여 구성될 수 있다. 당업자는 마스터 컨트롤러에 대한 많은 실시예를 인지할 것이다.
일 실시예에서, 스토리지 장치(152)/솔리드-스테이트 스토리지 장치 컨트롤러(202)가 다수의 데이터 스토리지 장치/솔리드-스테이트 스토리지(110a-n)를 관리하는 경우, 마스터 컨트롤러(224)는 솔리드-스테이트 스토리지 컨트롤러(104a-n)과 같은 내부 컨트롤러의 작업 로드를 분배한다. 예를 들어, 마스터 컨트롤러(224)는 데이터 스토리지 장치(예컨대 솔리드-스테이트 스토리지(110a-n)로 기록될 객체를 분할하여, 객체의 일부가 부착된 데이터 스토리지 장치의 각각에 저장되도록 할 수 있다. 이러한 특징은 신속한 저장 및 객체로의 액세스를 가능하게 하는 성능 향상이다. 일 실시예에서, 마스터 컨트롤러(224)는 FPGA를 이용하여 구현된다. 다른 실시예에서, 마스터 컨트롤러(224) 내의 펌웨어는 관리 버스(236), NIC(244) 또는 시스템 버스(240)에 연결된 다른 장치로 연결된 네트워크를 통한 시스템 버스(240)를 통해 업데이트될 수 있다.
일 실시예에서, 객체를 관리하는 마스터 컨트롤러(224)는 블록 스토리지를 에뮬레이트(emulate)하여, 컴퓨터(102) 또는 스토리지 장치(152)/솔리드-스테이트 스토리지 장치(102)에 연결된 다른 장치는 스토리지 장치(152)/솔리드-스테이트 스토리지 장치(102)를 블록 스토리지 장치로 바라보고, 데이터를 스토리지 장치(152)/솔리드-스테이트 스토리지 장치(102) 내의 특정한 물리적 어드레스로 전송한다. 그리고 나서 마스터 컨트롤러(224)는 블록 및 블록과 함께 전송된 물리적 어드레스를 마스터 컨트롤러(224)에 의해 결정된 실제 장소로 매핑한다. 매핑은 객체 인덱스에 저장된다. 일반적으로, 블록 에뮬레이션에서, 블록 장치 API(Application Program Interface)는 컴퓨터(112), 클라이언트(114), 또는 스토리지 장치(152)/솔리드-스테이트 스토리지 장치(102)를 블록 스토리지 장치로 사용하기를 원하는 다른 장치 내의 드라이버에 제공된다.
다른 실시예에서, 마스터 컨트롤러(224)는 NIC 컨트롤러(244) 및 임베디드 RDMA 컨트롤러(246)와 함께 구동되어 데이터 및 명령 세트의 RDMA 전송을 제 시간에 전달한다. NIC 컨트롤러(244)는 불-투명 포트의 뒤에 숨겨져 커스텀 드라이버의 사용을 가능하게 할 수 있다. 또한, 클라이언트(114) 상의 드라이버는 표준 스택 API를 사용하고 NIC(244)와 함께 구동하여 I/O 메모리 드라이버를 통해 컴퓨터 네트워크(118)로의 액세스를 구비할 수 있다.
일 실시예에서, 마스터 컨트롤러(224)는 또한 RAID(Redundant Array of Independent Driver) 컨트롤러이다. 데이터 스토리지 장치/솔리드-스테이트 스토리지(102)가 하나 또는 그 이상의 다른 데이터 스토리지 장치/솔리드-스테이트 스토리지(102)로 네트워크로 구성된 경우, 마스터 컨트롤러(224)는 단일 층(tier) RAID, 다중 층 RAID, 프로그레시브 RAID 등을 위한 RAID 컨트롤러일 수 있다. 마스터 컨트롤러(224)는 또한 일부 객체가 RAID 어레이에 저장되도록 하고 다른 객체가 RAID를 사용하지 않고 저장되도록 한다. 다른 실시예에서, 마스터 컨트롤러(224)는 분산된 RAID 컨트롤러 엘리먼트일 수 있다. 다른 실시예에서, 마스터 컨트롤러(224)는 많은 RAID, 분산된 RAID, 및 명세서 다른 곳에 기술된 다른 기능을 포함할 수 있다.
일 실시예에서, 마스터 컨트롤러(224)는 단일 또는 리던던트 네트워크 관리자(예컨대 스위치(switches))와 함께 동작하여 라우팅을 구축하고, 대역폭 사용, 장애극복(failover) 등의 균형을 맞춘다. 다른 실시예에서, 마스터 컨트롤러(224)는 (로컬 버스(206)을 통해) 집적된 애플리케이션 특정 로직(application specific logic) 및 결합된 드라이버 소프트웨어와 함께 동작한다. 다른 실시예에서, 마스터 컨트롤러(224)는 (외부 시스템 버스(240)을 통해)부착된 애플리케이션 특정 프로세서(application specific processor)(258) 또는 로직 및 결합된 드라이버 소프트웨어와 함께 동작한다. 다른 실시예에서, 마스터 컨트롤러(224)는 (컴퓨터 네트워크(118)을 통해)원격 애플리케이션 특정 로직(application specific logic) 및 결합된 드라이버 소프트웨어와 함께 동작한다. 다른 실시예에서, 마스터 컨트롤러(224)는 로컬 버스(206) 또는 HDD(Hard Disk Drive) 스토리지 컨트롤러에 부착된 외부 버스와 함께 동작한다.
일 실시예에서, 마스터 컨트롤러(224)는 하나 또는 그 이상의 스토리지 컨트롤러(254)와 통신하며, 여기서 스토리지 장치/솔리드-스테이트 스토리지(102)는 SCSI 버스, iSCSI(Internet SCSI), 파이버 채널 등을 통해 연결된 스토리지 장치로서 나타날 수 있다. 반면 스토리지 장치/솔리드-스테이트 스토리지(102)는 자발적으로 객체를 관리하고 객체 파일 시스템 또는 분산된 객체 파일 시스템으로 나타날 수 있다. 마스터 컨트롤러(224)는 또한 피어 컨트롤러(256) 및/또는 애플리케이션 특정 프로세서(258)에 의해 액세스될 수도 있다.
다른 실시예에서, 마스터 컨트롤러(224)는 자발적인 직접된 관리 컨트롤러와 함께 동작하여 FPGA 코드 및/또는 컨트롤러 소프트웨어를 주기적으로 검증하며(validate), 구동(리셋)도중 FPGA 코드를 검증하고 및/또는 전원 공급(리셋) 도중 컨트롤러 소프트웨어를 검증하고, 외부 리셋 요청을 지원하고, 워치독 타임아웃(watchdog timeouts)에 기인한 리셋 요청을 지원하고, 전압, 전류, 전원, 온도, 및 다른 환경적 측정 및 임계 인터럽트(threshold interrupts)의 세팅을 지원한다. 다른 실시예에서, 마스터 컨트롤러(224)는 소거 블록의 재사용을 자유롭게 하기 위해 가비지 컬렉션을 관리한다. 다른 실시예에서, 마스터 컨트롤러(224)는 웨어 레벨링(wear leveling)을 관리한다. 다른 실시예에서, 마스터 컨트롤러(224)는 데이터 스토리지 장치/솔리드-스테이트 스토리지 장치(102)가 다수의 가상 장치로 파티션되도록 하고, 파티션-기반 미디어 암호화를 허용한다. 다른 실시예에서, 마스터 컨트롤러(224)는 솔리드-스테이트 스토리지 컨트롤러(104)가 진보되고, 멀티-비트(multi-bit) ECC 정정을 사용하도록 지원한다. 당업자는 스토리지 컨트롤러(152), 또는 보다 구체적으로 솔리드-스테이트 스토리지 장치(102) 내의 마스터 컨트롤러(224)의 다른 특징 및 기능을 인지할 것이다.
일 실시예에서, 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 동적 랜덤 메모리 어레이(230) 및/또는 정적 랜덤 메모리 어레이(232)를 제어하는 메모리 컨트롤러(228)를 포함한다. 상술한 바와 같이, 메모리 컨트롤러(228)는 일반적으로 임의의 타입의 휘발성 메모리, 예컨대 DRAM(동적 랜덤 메모리 어레이(230)) 및 SRAM(정적 랜덤 메모리 어레이(232)를 제어한다. 다른 예에서, 메모리 컨트롤러(228)는 또한 EEPROM(Electrically Erasable Programmable REad Only Memory) 등과 같은 다른 메모리 타입을 제어한다. 다른 실시예에서, 메모리 컨트롤러(228)는 둘 또는 그 이상의 메모리 타입을 제어하며 메모리 컨트롤러(228)는 하나의 컨트롤러보다 많은 컨트롤러를 포함할 수 있다. 일반적으로, 메모리 컨트롤러(228)는 가능한한 많은 SRAM(232)이 실행가능하도록(feasible) 제어하고 DRAM(230)에 의해 SRAM(2332)을 보충하도록 한다.
일 실시예에서, 객체 인덱스는 메모리(230,232)에 저장되고 그리고 나서 솔리드-스테이트 스토리지(110n) 또는 다른 비-휘발성 메모리의 채널로 주기적으로 오프-로드된다. 당업자는 메모리 컨트롤러(228), 동적 메모리 어레이(230), 및 정적 메모리 어레이(232)의 다른 사용 및 구성을 인식할 것이다.
일 실시예에서, 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 스토리지 장치/솔리드-스테이트 스토리지 장치(102)와 하나 또는 그 이상의 외부 메모리 컨트롤러(250)와 결합된 외부 메모리 어레이(252) 및 CPU(248) 간의 DMA 동작을 제어하는 DMA 컨트롤러(226)을 포함한다. 외부 메모리 컨트롤러(250) 및 외부 메모리 어레이(252)는 외부적(external)이라고 언급되며, 이는 이들이 스토리지 장치/솔리드-스테이트 스토리지 장치(102)의 외부에 위치하기 때문이다. 또한, DMA 컨트롤러(226)는 NIC(244) 및 결합된 RDMA 컨트롤러(246)을 통해 장치를 요청하면서 RDMA 동작을 제어할 수도 있다. DMA 및 RDMA는 이하 보다 상세하게 설명된다.
일 실시예에서, 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 관리 버스(236)에 연결된 관리 컨트롤러(234)를 포함한다. 일반적으로 관리 컨트롤러(234)는 스토리지 장치/솔리드-스테이트 스토리지 장치(102)의 환경적 계량(metric) 및상태를 관리한다. 관리 컨트롤러(234)는 장치 온도, 팬 속도, 전원 공급 세팅 등을 관리 버스(236)를 통해 감시할 수 있다. 관리 컨트롤러는 FPGA 코드 ㅁ미및OM 컨ㅌ트트롤러 소프트웨어의 저장을 위한 sable Programmable Read Only Memory)의 독출 및 프로그래밍을 지원할 수 있다. 일반적으로 관리 버스(236)는 스토리지 장치/솔리드-스테이트 스토리지 장치(102) 내의 다양한 컴포넌트에 연결된다. 관리 컨트롤러(234)는 로컬 버스(206)을 통해 경고, 인터럽트 등을 통신할 수 있거나 또는 시스템 버스(240) 또는 다른 버스로의 분리된 통신을 포함할 수 있다. 일 실시예에서, 관리 버스(236)는 I2C(Inter-Integrated Circuit) 버스이다. 당업자는 관리 버스(236)에 의한 스토리지 장치/솔리드-스테이트 스토리지 장치(102)의 컴포넌트에 연결된 관리 컨트롤러(234)의 다른 관련된 기능 및 사용을 인지할 것이다.
일 실시예에서, 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 특정 애플리케이션을 위해 주문제작될 수 있는 다양한 로직(miscellaneous logic)(242)을 포함한다. 일반적으로 솔리드-스테이트 스토리지 장치 컨트롤러(202) 또는 마스터 컨트롤러(224)가 FPGA 또는 다른 구성가능한 컨트롤러를 사용하여 구성된 경우, 커스텀 로직은 특정 애플리케이션, 사용자 요구사항, 스토리지 요구사항 등을 기반으로 포함될 수 있다.
데이터 파이프라인(Data Pipeline)
도 3은 본 발명에 따른 솔리드-스테이트 스토리지 장치(102) 내의 데이터 기록 파이프라인(106) 및 데이터 독출 파이프라인(108)의 일 실시예(300)를 설명하는 개략적인 블록도이다. 상기 실시예(300)는 데이터 버스(204), 로컬 버스(206), 및 버퍼 컨트롤(208)을 포함하며, 이는 도 2의 솔리드-스테이트 스토리지 장치 컨트롤러(202)에 관하여 기술된 바와 실질적으로 유사하다. 데이터 기록 파이프라인은 패킷타이저(302) 및 ECC(Error-Correcting Code) 생성기(304)를 포함한다. 다른 실시예에서, 데이터 기록 파이프라인은 입력 버퍼(306), 기록 동기 버퍼(write synchronization buffer)(308), 기록 프로그램 모듈(310), 압축 모듈(312), 암호화 모듈(314), 가비지 컬렉터 바이패스(garbage collector bypass)(316)(데이터 독출 파이프라인에 일부 포함됨), 미디어 암호화 모듈(318), 및 기록 버퍼(320)를 포함한다. 데이터 독출 파이프라인(108)은 독출 동기 버퍼(328), ECC 정정 모듈(322), 디패킷타이저(324), 조정 모듈(326), 및 출력 버퍼(330)를 포함한다. 다른 실시예에서, 데이터 독출 파이프라인(108)은 미디어 복호화 모듈(332), 가비지 컬렉터 바이패스(316)의 일부, 복호화 모듈(334), 복원 모듈(336), 및 독출 프로그램 모듈(338)을 포함할 수 있다. 솔리드-스테이트 스토리지 컨트롤러(104)는 또한 제어 및 상태 레지스터(340) 및 컨트롤 큐(control queues)(342), 뱅크 인터리브 컨트롤러(344), 동기 버퍼(346), 스토리지 버스 컨트롤러(348), 및 멀티플렉서("MUX")(350)를 포함할 수 있다. 솔리드-스테이트 컨트롤러(104) 및 결합된 데이터 기록 파이프라인(106) 및 데이터 독출 파이프라인(108)의 컴포넌트는 이하 기술된다. 다른 실시예에서, 동기식(synchronous) 솔리드-스테이트 스토리지(110)가 사용될 수 있고 동기 버퍼(308,328)는 제거될 수 있다.
데이터 기록 파이프라인(Write Data Pipeline)
데이터 기록 파이프라인(106)은 직접 또는 간접적으로 다른 데이터 기록 파이프라인(106) 스테이지를 통해, 솔리드-스테이트 스토리지에 기록될 데이터 또는 메타데이터 세그먼트를 수신하는 패킷타이저(302)를 포함하고, 솔리드-스테이트 스토리지(110)를 위해 사이즈가 조정된 하나 또는 그 이상의 패킷을 생성한다. 데이터 또는 메타데이터 세그먼트는 일반적으로 객체의 일부이지만, 전체 객체를 포함할 수도 있다. 다른 실시예에서, 데이터 세그먼트는 데이터의 블록 일부이지만, 데이터의 전체 블록을 포함할 수도 있다. 일반적으로, 객체는 컴퓨터(112), 클라이언트(114), 또는 다른 컴퓨터 또는 장치로부터 수신되고 솔리드-스테이트 스토리지 장치(102) 또는 컴퓨터(112)로 스트리밍된 데이터 세그먼트로서 솔리드-스테이트 스토리지 장치(102)로 전송된다. 데이터 세그먼트는 또한 다른 이름, 예컨대 데이터 파슬(data parcel)로도 알려지지만, 여기에서는 객체 또는 데이터 블록의 전부 또는 일부를 포함한다.
각각의 객체는 하나 또는 그 이상의 패킷으로 저장된다. 각각의 객체는 하나 또는 그 이상의 컨테이너 패킷을 포함한다. 각각의 패킷은 헤더를 포함한다. 헤더는 헤더 타입 필드를 포함할 수 있다. 타입 필드는 데이터, 객체 속성(object attrbute), 메타데이터, 데이터 세그먼트 구분자(delimiters)(다중-패킷), 객체 구조, 객체 링키지 등을 포함할 수 있다. 헤더는 또한 패킷의 사이즈에 관한 정보, 예컨대 패킷 내에 포함된 데이터의 바이트 수를 포함할 수도 있다. 패킷의 길이는 패킷 타입에 의해 구축될 수 있다. 헤더는 객체에 대한 패킷의 관계를 구축하는 정보를 포함할 수 있다. 일 예는 객체 내의 데이터 세그먼트의 위치를 식별하기 위해 데이터 패킷 헤더 내에서 오프셋을 사용하는 것일 수 있다. 당업자는 패킷타이저(302)에 의해 데이터에 추가된 헤더 내 포함된 다른 정보 및 데이터 패킷에 추가될 수 있는 다른 정보를 인지할 것이다.
각각의 패킷은 헤더 및 데이터 또는 메타데이터 세그먼트로부터의 데이터를 포함할 수 있다. 각각의 패킷의 헤더는 패킷을 패킷이 속한 객체에 관련시키기 위한 적절한 정보를 포함한다. 예를 들어, 헤더는 객체 식별자 및 데이터 세그먼트, 객체, 또는 데이터 패킷이 형성된 데이터 블록을 지시하는 오프셋을 포함할 수 있다. 헤더는 또한 패킷을 저장하기 위해 스토리지 버스 컨트롤러(348)에 의해 사용된 논리적 어드레스를 포함할 수도 있다. 헤더는 또한 패킷 내에 포함된 바이트의 수와 같은 패킷의 사이즈에 관한 정보를 포함할 수도 있다. 헤더는 또한 데이터 세그먼트 또는 객체를 재구성할 때 객체 내의 다른 패킷에 관하여 데이터 세그먼트가 속한 곳을 식별하는 시퀀스 넘버를 포함할 수도 있다. 헤더는 헤더 타입 필드를 포함할 수 있다. 타입 필드는 데이터, 객체 속성, 메타데이터, 데이터 세그먼트 구분자(다중-패킷), 객체 구조, 객체 링키지 등을 포함할 수 있다. 당업자는 패킷타이저(302)에 의해 데이터 또는 메타데이터에 추가된 헤더 내 포함될 수 있는 다른 정보 및 패킷에 추가될 수 있는 다른 정보를 인지할 것이다.
데이터 기록 파이프라인(106)은 패킷타이저(302)로부터 수신된 하나 또는 그 이상의 패킷에 대한 하나 또는 그 이상의 ECC(Error-Correcting Codes)를 생성하는 ECC 생성기(304)를 포함한다. ECC 생성기(304)는 일반적으로 에러 정정 알고리즘을 사용하여 패킷과 함께 저장되는 ECC를 생성한다. 패킷과 함께 저장된 ECC는 일반적으로 전송 및 저장 도중 데이터에 발생된 에러를 검출하고 정정하도록 사용된다. 일 실시예에서, 패킷은 길이 N의 인코딩되지 않은(un-encoded) 블록으로서 ECC생성기(304)로 스트리밍된다. 길이 S의 신드롬(syndrome)이 계산되고, 추가되고 길이 N+S의 인코딩된 블록으로 출력된다. N 및 S 값은 특정 성능, 효율, 및 내성(robustness) 수치를 달성하기 위해 선택된 알고리즘의 특성에 종속된다. 바람직한 실시예에서, ECC 블록과 패킷 간에 고정된 관계는 존재하지 않으며; 패킷은 하나의 ECC 블록 이상을 포함할 수 있으며; ECC 블록은 하나의 패킷 이상을 포함할 수 있으며; 제 1 패킷은 ECC 블록 내의 임의의 장소에서 종료되고 제 2 패킷은 동일한 ECC 블록 내에서 제 1 패킷의 종료 후에 시작될 수 있다. 바람직한 실시예에서, ECC 알고리즘은 동적으로 변경되지 않는다. 바람직한 실시예에서, 데이터 패킷과 함께 저장된 ECC는 두 비트 이상으로 에러를 정정하기에 충분히 강하다.
유리하게, 단일 비트 정정 또는 심지어 더블 비트 정정 이상을 허용하는 강인한 ECC 알고리즘을 사용하는 것은 솔리드-스테이트 스토리지(110)의 수명을 연장시킬 수 있다. 예를 들어, 플래시 메모리가 솔리드-스테이트 스토리지(110)에서 저장 매체로 사용되는 경우, 플래시 메모리는 소거 사이클 당 에러(error per erase cycle) 없이 대략 100,000 번 기록될 수 있다. 이러한 사용 제한은 강인한(robust) ECC 알고리즘을 사용하여 연장될 수 있다. ECC 생성기(304) 및 솔리드-스테이트 스토리지 장치(102)에 온보드로 해당 ECC 정정 모듈(322)을 구비하여, 솔리드-스테이트 스토리지 장치(102)는 내부적으로 에러를 정정할 수 있으며, 보다 덜 강인한 ECC 알고리즘이 사용된 경우, 예컨대 단일(single) 비트 정정을 사용한 경우보다 더 길게 사용할 수 있다. 그러나, 다른 실시예에서, ECC 생성기(304)는 보다 덜 강인한 알고리즘을 사용할 수 있고, 단일-비트 또는 더블-비트 에러를 정정할 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(110)는 MLC(Multi-Level Cell) 플래시와 같은 보다 신뢰성이 낮은 스토리지를 포함하여 용량을 늘릴 수 있으며, 스토리지가 보다 강인한 ECC 알고리즘을 사용하지 않으면 충분히 신뢰성을 구비할 수 없다.
일 실시예에서, 기록 파이프라인(106)은 솔리드-스테이트 스토리지(110)에 기록될 데이터 세그먼트를 수신하는 입력 버퍼(306)를 포함하고 패킷타이저(302)와 같은 데이터 기록 파이프라인(106)의 다음 스테이지가 다음 데이터 세그먼트를 처리할 준비가 될 때까지 유입된 데이터 세그먼트를 저장한다. 입력 버퍼(306)는 일반적으로 데이터 세그먼트가 수신되는 레이트(rate)와 데이터 기록 파이프라인(106)에 의해 처리되는 레이트 간의 불일치를 적절한 사이즈의 데이터 버퍼를 이용하여 보완한다. 입력 버퍼(306)는 또한 데이터 버스(204)가 데이터 기록 파이프라인(106)에 의해 유지될 수 있는 정도보다 큰 레이트로 데이터를 전송하도록 하여 데이터 버스(204)의 동작 효율을 향상시킨다. 일반적으로, 데이터 기록 파이프라인(106)이 입력 버퍼(306)를 포함하지 않는 경우, 버퍼링 기능은 예컨대 솔리드-스테이트 스토리지 장치(102) 내의 임의의 장소, 그러나 데이터 기록 파이프라인(106)의 외부, 또는 컴퓨터(112) 내의 NIC(Network Interface Card) 내부와 같은 곳, 또는 다른 장치, 예를 들어 RDMA(Remote Direct Memory Access)를 사용한 경우다른 장치에서 수행된다.
다른 실시예에서, 데이터 기록 파이프라인(106)은 또한 패킷을 솔리드-스테이트 스토리지(110)로 기록하기 전에 ECC 생성기(304)로부터 수신된 패킷을 버퍼링하는 기록 동기 버퍼(308)를 포함한다. 기록 동기 버퍼(308)는 로컬 클럭 도메인과 솔리드-스테이트 스토리지 클럭 도메인 사이의 경계(boundary)에 위치되고 클럭 도메인의 차이를 보완하도록 버퍼링을 제공한다. 다른 실시예에서, 동기식 솔리드-스테이트 스토리지(110)가 사용될 수 있고 동기 버퍼(308,328)는 제거될 수 있다.
일 실시예에서, 데이터 기록 파이프라인(106)은 또한 직접 또는 간접적으로 패킷타이저(302)로부터 하나 또는 그 이상의 패킷을 수신하는 미디어 암호화 모듈(318)을 포함하고 패킷을 ECC 생성기(304)로 전송하기 전에 솔리드-스테이트 스토리지 장치(102)에 고유한 암호화 키를 이용하여 하나 또는 그 이상의 패킷을 암호화한다. 일반적으로, 전체 패킷이 암호화되고 이는 헤더를 포함한다. 다른 실시예에서, 헤더는 암호화되지 않는다. 본 발명의 명세서에서, 암호화 키는 솔리드-스테이트 스토리지(110)를 구비하는 실시예로부터 외부적으로 관리되는 비밀 암호화 키를 의미하도록 이해되며, 여기서 상기 실시예는 암호화 보호(encryption protection)을 요구한다. 미디어 암호화 모듈(318) 및 해당 미디어 복호화 모듈(332)은 솔리드-스테이트 스토리지(110)에 저장되는 데이터를 위한 보안 레벨을 제공한다. 예를 들어, 데이터가 미디어 암호화 모듈(318)을 사용하여 암호화되고, 솔리드-스테이트 스토리지(110)가 다른 솔리드-스테이트 스토리지 컨트롤러(104), 솔리드-스테이트 스토리지 장치(102), 또는 컴퓨터(112)에 연결된 경우, 솔리드-스테이트 스토리지(110)의 컨텐츠는 일반적으로 솔리드-스테이트 스토리지(110)로의 데이터 기록 도중 사용된 동일한 암호화 키의 사용 없이는 중대한 노력 없이 독출될 수 없다.
일반적인 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 비-휘발성 스토리지에 암호화 키를 저장하지 않고, 암호화 키로의 외부 액세스를 허용하지 않는다. 암호화 키는 초기화(initialization) 도중 솔리드-스테이트 스토리지 컨트롤러(104)로 제공된다. 솔리드-스테이트 스토리지 장치(102)는 암호화 키와 함께 사용되는 비-기밀 암호적 논스(non-secret cryptographic nonce)를 사용하고 저장할 수 있다. 상이한 논스가 모든 패킷마다 저장될 수 있다. 데이터 세그먼트는 보안을 향상시킬 목적으로 암호화 알고리즘에 의해 고유한 논스를 사용한 다중 패킷들로 분할될 수 있다. 암호화 키는 클라이언트(114), 컴퓨터(112), 키 매니저, 또는 솔리드-스테이트 스토리지 컨트롤러(104)에 의해 사용될 암호화 키를 관리하는 다른 장치로부터 수신될 수 있다. 다른 실시예에서, 솔리드-스테이트 스토리지(110)는 둘 또는 그 이상의 파티션을 가질 수 있고 솔리드-스테이트 스토리지 컨트롤러(104)는 둘 또는 그 이상의 솔리드-스테이트 스토리지 컨트롤러(104)처럼 동작할 수 있으며, 각각은 솔리드-스테이트 스토리지(110) 내의 단일 파티션에서 동작한다. 이 실시예에서, 고유한 미디어 암호화 키는 각각의 파티션과 함께 사용될 수 있다.
다른 실시예에서, 데이터 기록 파이프라인(106)은 또한 데이터 세그먼트를 패킷타이저(302)로 전송하기 전에, 직접 또는 간접적으로 입력 버퍼(306)으로부터 수신된 데이터 또는 메타데이터 세그먼트를 암호화하는 암호화 모듈(314)을 포함하며, 데이터 세그먼트는 데이터 세그먼트와 함께 수신된 암호화 키를 사용하여 암호화된다. 암호화 모듈(314)은 데이터를 암호화하기 위해 암호화 모듈(318)에 의해 사용되는 암호화 키가 솔리드-스테이트 스토리지 장치(102) 내에 저장된 모든 데이터에 공통되지 않고, 객체 기반으로 변화할 수 있으며 아래 기술된 바와 같이 데이터 세그먼트의 수신과 함께 수신되는 점에서 미디어 암호화 모듈(318)과 다르다. 예를 들어, 암호화 모듈(318)에 의해 암호화될 데이터 세그먼트를 위한 암호화 키는 데이터 세그먼트와 함께 수신될 수 있거나, 또는 데이터 세그먼트가 속하는 객체를 쓰기 위한 명령의 일부로서 수신될 수 있다. 솔리드-스테이트 스토리지 장치(102)는 비-기밀 암호적 논스를 사용하고, 암호화 키와 함께 사용되는 각각의 객체 패킷 내에 저장할 수 있다. 모든 패킷마다 상이한 논스가 저장될 수 있다. 데이터 세그먼트는 암호화 알고리즘에 의해 보안을 향상할 목적으로 고유한 논스를 구비한 다중 패킷들로 분할될 수 있다. 일 실시예에서, 미디어 암호화 모듈(318)에 의해 사용되는 논스는 암호화 모듈(314)에 의해 사용되는 논스와 동일하다.
암호화 키는 클라이언트(114), 컴퓨터(112), 키 매니저, 또는 데이터 세그먼트를 암호화하도록 사용될 암호화 키를 보유하는 다른 장치로부터 수신될 수 있다. 일 실시예에서, 암호화 키는 솔리드-스테이트 스토리지 장치(102), 컴퓨터(112), 클라이언트(114), 또는 사적인 키 및 공적인 키를 안전하게 전송하고 보호하도록 산업 표준 방법을 실행하는 기능을 가진 다른 외부 에이전트 중 하나로부터 솔리드-스테이트 스토리지 컨트롤러(104)로 전송된다.
일 실시예에서, 암호화 모듈(318)은 제 1 패킷을 패킷과 함껙 수신된 제 1 암호화 키를 사용하여 암호화하고, 제 2 패킷을 제 2 패킷과 함께 수신된 제 2 암호화 키를 사용하여 암호화한다. 다른 실시예에서, 암호화 모듈(318)은 제 1 패킷을 패킷과 함께 수신된 제 1 암호화 키를 사용하여 암호화하고, 제 2 데이터 패킷을 암호화를 하지 않고 다음 스테이지로 전달한다. 유리하게, 솔리드-스테이트 스토리지 장치(102)의 데이터 기록 파이프라인(106) 내에 포함된 암호화 모듈(318)은 단일 파일 시스템 또는 해당 객체 또는 데이터 세그먼트를 저장하기 위해 사용되는 상이한 암호화 키를 지속적으로 추적할 수 있는 다른 외부 시스템을 사용하지 않고 객체 대 객체(object-by-object) 또는 세그먼트 대 세그먼트(segment-by-segment) 데이터 암호화를 허용한다. 각각의 요청 장치(155) 또는 관련된 키 관리자는 독립적으로 요청 장치(155)에 의해 전송된 객체 또는 데이터 세그먼트만을 암호화하도록 사용된 암호화 키를 관리한다.
다른 실시예에서, 데이터 기록 파이프라인(106)은 데이터 세그먼트를 패킷타이저(302)로 전송하기 전에 메타데이터 세그먼트에 대한 데이터를 압축하는 압축 모듈(312)을 포함한다. 압축 모듈(312)은 일반적으로 당업자에게 알려진 압축 루틴을 이용하여 데이터 또는 메타데이터 세금건트를 압축하여 세그먼트의 저장 사이즈를 줄인다. 예를 들어, 데이터 세그먼트가 512 개의 영(zeros)의 스트링(string)을 포함한 경우, 압축 모듈(312)은 512 개의 영을 512 개의 영을 지시하는 코드 또는 토큰으로 교체하며, 여기서 상기 코드는 512 개의 영에 의해 차지하는 공간보다 훨씬 컴팩트하다.
일 실시예에서, 압축 모듈(312)은 제 1 세그먼트를 제 1 압축 루틴을 사용하여 압축하고 제 2 세그먼트를 압축 없이 전달한다. 다른 실시예에서, 압축 모듈(312)은 제 1 세그먼트를 제 1 압축 루틴을 사용하여 압축하고 제 2 세그먼트를 제 2 압축 루틴을 사용하여 압축한다. 솔리드-스테이트 스토리지 장치(102) 내에서 이와 같은 유연성(flexibility)을 구비하는 것은 유리하며, 그 결과 클라이언트(114) 또는 데이터를 솔리드-스테이트 스토리지 장치(102)로 기록하는 다른 장치는 압축 루틴을 각각 지정할 수 있거나, 또는 일부는 압축 루틴을 지정하는 반면 다른 일부는 압축을 지정하지 않을 수 있다. 압축 루틴의 선택은 또한 객체 타입 또는 객체 클래스 기반 상의 초기 세팅(defualt setting)에 따라 선택될 수도 있다. 예를 들어, 특정 객체의 제 1 객체는 초기 압축 루틴 세팅을 무시할 수 있고 동일 객체 클래스 및 객체 타입의 제 2 객체는 초기 압축 루틴을 사용할 수 있고, 동일한 객체 클래스 및 객체 타입의 제 3 객체는 압축을 사용하지 않을 수 있다.
일 실시예에서, 데이터 기록 파이프라인(106)은 가비지 컬렉션 시스템의 데이터 바이패스의 일부로서 데이터 독출 파이프라인(108)으로부터 데이터 세그먼트를 수신하는 가비지 컬렉터 바이패스(316)를 포함한다. 가비지 컬렉션 시스템은 일반적으로 더 이상 유효하지 않은 패킷을 마크하며, 일반적으로 이는 패킷이 삭제를 위해 마크되거나 변경되고 변경된 데이터는 다른 장소에 저장되기 때문이다. 일부 관점에서, 가비지 컬렉션 시스템은 스토리지의 특정 섹션이 복원됨을 결정한다. 이러한 결정은 유효한 저장 용량의 부족, 무효하다고 마크된 데이터의 퍼센티지가 임계치에 도달하거나, 유효한 데이터의 통합(consolidation), 스토리지의 이러한 섹션에 대한 에러 검출 레이트의 임계값 도달, 또는 데이터 분산을 기반으로 한 성능 향상 등에 기인할 수 있다. 많은 팩터(factors)가 스토리지의 섹션이 복원될 시점을 결정하기 위해 가비지 컬렉션 알고리즘에 의해 고려될 수 있다.
스토리지의 섹션이 복원을 위해 마크된 경우, 섹션 내 유효한 패킷은 일반적으로 재배치되어야 한다. 가비지 컬렉터 바이패스(316)는 패킷이 데이터 독출 파이프라인(108)으로 독출되도록 하고, 그리고 나서 솔리드-스테이트 스토리지 컨트롤러(104) 밖으로 라우팅되지 않고 직접적으로 데이터 기록 파이프라인(106)으로 전송될 수 있도록 한다. 바람직한 실시예에서, 가비지 컬렉터 바이패스(316)는 솔리드-스테이트 스토리지 장치(102) 내에서 작동하는 자발적인 가비지 컬렉터 시스템의 일부이다. 이는 솔리드-스테이트 스토리지 장치(102)가 데이터를 관리하여, 데이터가 솔리드-스테이트 스토리지(110)에 걸쳐 시스템적으로 퍼지도록(spread) 하여, 성능, 데이터 신뢰성을 향상시키고, 솔리드-스테이트 스토리지(110)의 임의의 한 장소 또는 영역의 과용 및 미달을 방지하고, 솔리드-스테이트 스토리지(110)의 유용한 수명을 연장시킨다.
가비지 컬렉터 바이패스(316)는 다른 세그먼트를 클라이언트(116) 또는 다른 장치에 의해 기록하면서 데이터 기록 파이프라인(106)으로의 세그먼트의 삽입을 수행한다. 도시된 실시예에서, 가비지 컬렉터 바이패스(316)는 데이터 기록 파이프라인(106) 내에서 패킷타이저(302) 전에 위치하고 데이터 독출 파이프라인(108) 내에서 디패킷타이저(324) 후에 위치하지만, 데이터 독출 및 기록 파이프라인(106,108) 내에서 임의의 위치에 위치할 수도 있다. 가비지 컬렉터 바이패스(316)는 기록 파이프라인(106)의 플러쉬(flush) 도중 사용되어 가상 페이지의 나머지(remainder)를 채워 솔리드-스테이트 스토리지(110) 내의 저장 효율을 향상시키고 그에 의해 가비지 컬렉션의 빈도수를 줄인다.
일 실시예에서, 데이터 기록 파이프라인(106)은 기록 동작의 효율을 위해 데이터를 버퍼링하는 기록 버퍼(320)를 포함한다. 일반적으로, 기록 버퍼(320)는 패킷이 솔리드-스테이트 스토리지(110) 내의 적어도 하나의 가상 페이지를 채우기 위한 충분한 용량을 포함한다. 이는 기록 동작이 데이터의 전체 페이지를 솔리드-스테이트 스토리지(110)으로 인터럽션 없이 전송하도록 한다. 데이터 기록 파이프라인(106)의 기록 버퍼(320) 및 데이터 독출 파이프라인(108) 내의 버퍼의 사이즈를 조절하여 솔리드-스테이트 스토리지(110) 내의 스토리지 기록 버퍼와 동일하거나 보다 큰 용량을 구비하도록 함으로써, 다중 명령 대신 단일 기록 명령이 데이터의 가득 찬(full) 가상 페이지를 솔리드-스테이트 스토리지(110)으로 전송하도록 만들어질 수 있으므로 데이터의 기록 및 독출이 보다 효율적으로 될 수 있다.
기록 버퍼(320)이 가득 차는 동안, 솔리드-스테이트 스토리지(110)는 다른 독출 동작을 위해 사용될 수 있다. 이는 데이터가 스토리지 기록 버퍼에 기록되고 스토리지 기록 버퍼로의 데이터 유입이 지연된 경우, 보다 작은 기록 버퍼 또는 기록 버퍼가 구비되지 않은 다른 솔리드-스테이트 장치는 솔리드-스테이트 스토리지를 정체시킬 수 있기 때문이다. 독출 동작은 전체 스토리지 기록 버퍼가 채워지고 프로그램될 때까지 차단될 것이다(blocked). 기록 버퍼를 구비하지 않거나 작은 기록 버퍼를 구비한 시스템을 위한 다른 접근 방법은 독출을 가능하게 하기 위해 가득 차지 않은 스토리지 기록 버퍼를 플러쉬하는 것이다. 하지만 다중 기록/프로그램 사이클은 페이지를 채우도록 요구되므로 이 방법은 비효율적이다.
가상 페이지보다 더 큰 사이즈를 구비한 기록 버퍼(320)를 포함한 도시된 실시예에 대해, 많은 서브명령을 포함한 단일 기록 명령은 각각의 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 내의 스토리지 기록 버퍼로부터 각각의 솔리드-스테이트 스토리지 엘리먼트(216,218,220) 내의 지정된 페이지로 데이터의 페이지를 전송하도록 하는 단일 프로그램 명령이 수반될 수 있다. 이러한 기술은 부분적인 페이지 프로그래밍을 제거하는 장점이 있지만, 데이터의 신뢰성 및 지속성(durability)을 감소시키고 버퍼가 채워진 반면 독출 및 다른 명령에 대해 목적지 뱅크(destination bank)를 자유롭게 하는 것으로 알려져 있다.
일 실시예에서, 기록 버퍼(320)는 핑-퐁 버퍼(ping-pong buffer)이며, 이는 버퍼의 일측이 채워지고 그리고 나서 적절한 시점에서 전송을 위해 지정되는 반면 핑퐁 버퍼의 타측이 채워진다. 다른 실시예에서, 기록 버퍼(320)는 데이터 세그먼트의 가상 페이지보다 큰 용량을 가진 FIFO(First-In First-Out) 레지스터를 포함한다. 당업자는 솔리드-스테이트 스토리지(110)로 데이터를 기록하기 전에 데이터의 가상 페이지가 저장되도록 하는 다른 기록 버퍼(320) 구성을 인식할 것이다.
다른 실시예에서, 기록 버퍼(320)는 가상 페이지보다 작도록 사이즈가 구성되어, 페이지보다 작은 정보가 솔리드-스테이트 스토리지(110) 내의 스토리지 기록 버퍼에 기록될 수 있다. 실시예에서, 데이터 기록 파이프라인(106) 내의 정체가 독출 동작을 억제하는 것을 방지하기 위해, 데이터는 가비지 컬렉션 프로세스의 일부로서 한 장소에서 다른 장소로 이동될 필요가 있는 가비지 컬렉션 시스템을 이용하여 대기행렬에 대기시킨다(queue). 데이터 기록 파이프라인(106) 내의 데이터 정체의 경우, 데이터는 가비지 컬렉터 바이패스(316)를 통해 기록 버퍼(320)으로 공급될 수 있으며 그리고 나서 솔리드-스테이트 스토리지(110) 내의 스토리지 기록 버퍼로 공급되어 데이터를 프로그래밍하기 전에 가상 페이지의 페이지를 채울 수 있다. 이러한 방법으로, 데이터 기록 파이프라인(106) 내의 데이터 정체는 솔리드-스테이트 스토리지 장치(106)로부터의 독출로 정체되지 않을 것이다.
다른 실시예에서, 데이터 기록 파이프라인(106)은 데이터 기록 파이프라인(106) 내의 하나 또는 그 이상의 사용자-정의가능한 기능을 구비한 기록 프로그램 모듈(310)을 포함한다. 기록 프로그램 모듈(310)은 사용자가 데이터 기록 파이프라인(106)을 맞춤 구성(customize)할 수 있도록 한다. 사용자는 특정 데이터 요구사항 또는 애플리케이션을 기반으로 데이터 기록 파이프라인(106)을 맞춤 구성할 수 있다. 솔리드-스테이트 스토리지 컨트롤러(104)가 FPGA인 경우, 사용자는 커스텀 명령 및 기능을 사용하여 상대적으로 용이하게 데이터 기록 파이프라인(106)을 프로그램할 수 있다. 사용자는 또한 ASIC를 구비한 커스텀 기능을 포함하도록 기록 프로그램 모듈(310)을 사용할 수도 있으나, 그러나 ASIC를 맞춤 구성하는 것응ㄴ FPGA를 이용하는 것보다 더 어렵다. 기록 프로그램 모듈(310)은 버퍼 및 바이패스 메커니즘을 포함할 수 있어 제 1 데이터 세그먼트가 기록 프로그램 모듈(310) 내에서 실행되도록 하는 반면 제 2 데이터 세그먼트는 데이터 기록 파이프라인(106)을 통해 지속될 수 있다. 다른 실시예에서, 기록 프로그램 모듈(310)은 소프트웨어를 통해 프로그램될 수 있는 프로세서 코어를 포함할 수 있다.
기록 프로그램 모듈(310)은 입력 버퍼(306) 및 압축 모듈(312) 사이에 도시되지만, 기록 프로그램 모듈(310)은 데이터 기록 파이프라인(106) 내 어느 곳에도 위치될 수 있으며 다양한 스테이지(302-320)로 분산될 수 있다. 또한, 프로그래밍되고 독립적으로 동작하는 다양한 스테이트(302-320)에 분산된 다중 기록 프로그램 모듈(310)이 구비될 수 있다. 또한, 스테이지(302-320)의 순서는 변경될 수 있다. 당업자는 특정 사용자 요구사항을 기반으로 스테이지(302-320)의 순서에 대한 작업가능한 변경을 인식할 것이다.
데이터 독출 파이프라인(Read Data Pipeline)
데이터 독출 파이프라인(108)은 요청된 패킷의 각각의 ECC 블록과 함께 저장된 ECC를 사용함으로써 솔리드-스테이트 스토리지(110)로부터 수신된 요청된 패킷의 ECC블록 내에 데이터 에러가 존재하는지 여부를 결정하는 ECC 정정 모듈(322)을 포함한다. 그리고 나서, 임의의 에러가 존재하고 에러가 ECC를 이용하여 정정가능한 경우, ECC 정정 모듈(322)은 요청된 패킷 내의 임의의 에러를 정정한다. 예를 들어, ECC가 6 비트의 에러를 검출할 수 있으나 오직 3 비트의 에러만을 정정할 수 있는 경우, ECC 정정 모듈(322)은 에러 중 3 비트까지 요청된 패킷의 ECC 블록을 정정한다. ECC 정정 모듈(322)은 에러가 발생된 비트를 에러가 없는 비트 또는 영 상태(zero state)로 변경함으로써 에러가 발생된 비트를 정정하여, 그 결과 요청된 데이터 패킷은 솔리드-스테이트 스토리지(110)으로 기록된 때와 동일해지고 ECC는 패킷에 대해 생성된다.
요청된 패킷이 ECC가 정정할 수 있는 것보다 더 많은 에러 발생 비트를 포함하는 것으로 ECC 정정 모듈(322)이 결정한 경우, ECC 정정 모듈(322)은 요청된 패킷의 오류가 발생한 ECC 블록 내의 에러를 정정할 수 없으며, 인터럽트(interrupt)를 전송한다. 일 실시예에서, ECC 정정 모듈(322)은 요청된 패킷에 에러가 발생됨을 지시하는 메시지와 함께 인터럽트를 전송한다. 메시지는 ECC 정정 모듈(322)이 에러 또는 에러를 정정하도록 하는 ECC 정정 모듈(322)의 구동불능을 정정할 수 없다는 정보를 포함할 수 있다. 다른 실시예에서, ECC 정정 모듈(322)은 요청된 패킷의 오류가 발생된 ECC 블록을 인터럽트 및/또는 메시지와 함께 전송한다.
바람직한 실시예에서, ECC 정정 모듈(322)에 의해 정정될 수 없는 요청된 패킷의 오류가 발생된 ECC 블록 또는 오류가 발생된 ECC 블록의 일부는 마스터 컨트롤러(224)에 의해 독출되고, 정정되고, 그리고 데이터 독출 파이프라인(108)에 의한 추후 처리를 위해 ECC 정정 모듈(322)로 반환된다. 일 실시예에서, 요청된 패킷의 오류가 발생된 ECC 블록 또는 오류가 발생된 ECC 블록의 일부는 데이터를 요청한 장치로 전송된다. 요청 장치(155)는 ECC 블록을 정정하거나 다른 카피, 예컨대 백업 또는 미러 카피를 사용하여 데이터를 교체할 수 있으며, 그리고 나서 요청된 데이터 패킷의 교체 데이터를 사용하거나 데이터 독출 파이프라인(108)으로 반환할 수 있다. 요청 장치(155)는 에러가 발생된 요청된 패킷 내의 헤더 정보를 사용하여 오류가 발생된 요청된 패킷을 교체할 필요가 있는 데이터를 식별하거나 또는 그러한 패킷이 속한 객체를 교체할 수 있다. 다른 바람직한 실시예에서, 솔리드-스테이트 스토리지 컨트롤러(104)는 일부 타입의 RAID를 사용하여 데이터를 저장하고 오류가 발생된 데이터를 복구할 수 있다. 다른 실시예에서, ECC 정정 모듈(322)은 인터럽트 및/또는 메시지를 전송하고 수신 장치는 요청된 데이터 패킷과 결합된 독출 동작을 실패한다. 당업자는 요청된 패킷의 하나 또는 그 이상의 ECC 블록이 오류가 발생되고 ECC 정정 모듈(322)이에러를 정정할 수 없는 것을 결정하는 ECC 정정 모듈(322)의 결과로서 취할 다른 옵션 및 동작을 인식할 것이다.
데이터 독출 파이프라인(108)은 ECC 정정 모듈(322)로부터 요청된 패킷의 ECC 블록을 직접 또는 간접적으로 수신하는 디패킷타이저(324)를 포함하고, 하나 또는 그 이상의 패킷 헤더를 확인하고 제거한다. 디패킷타이저(324)는 헤더 내의 패킷 식별자, 데이터 길이, 데이터 위치 등을 확인함으로써 패킷 헤더를 검증할 수 있다. 일 실시예에서, 데이터 독출 파이프라인(108)으로 전달된 패킷이 요청된 패킷인지 검증하도록 사용될 수 있는 해쉬 코드(hash code)를포함한다. 디패킷타이저(324)는 또한 패킷타이저(302)에 의해 추가된 요청된 패킷으로부터 헤더를 제거한다. 디패킷타이저(324)는 특정 패킷이 동작하지 않고 변경 없이 전달하도록 지시할 수 있다. 일 예는 재구성 프로세스의 코스(course) 도중 요청된 컨테이너 라벨일 수 있으며, 여기서 헤더 정보는 객체 인덱스 재구성 모듈(272)에 의해 요구된다. 또 다른 예는 솔리드-스테이트 스토리지 장치(102) 내에 사용을 위해 정해진 다양한 타입의 패킷의 전송을 포함한다. 다른 실시예에서, 디패킷타이저(324) 동작은 패킷 타입에 종속할 수 있다.
데이터 독출 파이프라인(108)은 디패킷타이저(324)로부터 데이터를 수신하고 원치않은 데이터를 삭제하는 조정 모듈(alignment module)(326)을 포함한다. 일 실시예에서, 솔리드-스테이트 스토리지(110)으로 전송된 독출 명령은 데이터의 패킷을 검색한다. 데이터를 요청하는 장치는 검색된 패킷 내의 모든 데이터를 요구하지 않을 수 있으며 조정 모듈(326)은 원치않은 데이터를 삭제한다. 검색된 페이지 내의 모든 데이터가 요청된 데이터인 경우, 조정 모듈(326)은 어떤 데이터도 삭제하지 않는다.
조정 모듈(326)은 데이터 세그먼트를 다음 스테이지로 전달하기 전에 데이터 세그먼트를 요청한 장치와 호환성 있는 형태로 데이터를 객체의 데이터 세그먼트로서 재구성한다(reformat). 일반적으로, 데이터가 데이터 독출 파이프라인(108)에 의해 처리되므로, 데이터 세그먼트 또는 패킷의 사이즈는 다양한 스테이지에서 변경된다. 조정 모듈(326)은 데이터를 요청 장치(155)로 전송되기에 적절한 데이터 세그먼트로 데이터를 구성하도록 수신된 데이터를 사용하고 응답(response)를 형성하도록 참가한다. 예를 들어, 제 1 데이터 패킷의 일부로부터의 데이터는 제 2 데이터 패킷의 일부로부터의 데이터와 결합될 수 있다. 데이터 세그먼트가 요청 장치에 의해 요청된 데이터보다 큰 경우, 조정 모듈(326)은 원치않은 데이터를 폐기할 수 있다.
일 실시예에서, 데이터 독출 파이프라인(108)은 데이터 독출 파이프라인(108)에 의해 처리하기 전에 솔리드-스테이트 스토리지(110)로부터 독출된 하나 또는 그 이상의 요청된 패킷을 버퍼링하는 독출 동기 버퍼(328)를 포함한다. 독출 동기 버퍼(328)는 솔리드-스테이트 스토리지 클럭 도메인과 로컬 버스 클럭 도메인 사이의 경계에 위치하고 클럭 도메인의 차이를 보완하기 위해 버퍼링을 제공한다.
다른 실시예에서, 데이터 독출 파이프라인(108)은 요청 장치로 전송하기 전에 조정 모듈(326)로부터 요청된 패킷을 수신하고 패킷을 저장하는 출력 버퍼(330)을 포함한다. 출력 버퍼(330)는 데이터 세그먼트가 데이터 독출 파이프라인(108)의 스테이지로부터 수신된 시기와 데이터 세그먼트가 솔리드-스테이트 스토리지 컨트롤러(104) 또는 요청 장치의 다른 부분으로 전송되는 시기 간의 차이를 보완한다. 출력 버퍼(330)는 또한 데이터 버스(204)가 데이터 독출 파이프라인(108)에 의해 유지될 수 있는 것보다 더 큰 레이트로 데이터 독출 파이프라인(108)으로부터 데이터를 수신하도록 하여, 데이터 버스(204)의 동작의 효율을 향상시킨다.
일 실시예에서, 데이터 독출 파이프라인(108)은 하나 또는 그 이상의 요청된 패킷을 디패킷타이저(324)로 전송하기 전에, ECC 정정 모듈(322)로부터 하나 또는 그 이상의 암호화되고 요청된 패킷을 수신하고 솔리드-스테이트 스토리지 장치(102)에 고유한 암호화 키를 사용하여 하나 또는 그 이상의 요청된 패킷을 복호화하는 미디어 복호화 모듈(332)을 포함한다. 일반적으로 미디어 복호화 모듈(332)에 의해 데이터를 복호화하도록 사용되는 암호화 키는 미디어 암호화 모듈(318)에 의해 사용된 암호화 키와 일치한다. 다른 실시예에서, 솔리드-스테이트 스토리지(110)는 둘 또는 그 이상의 파티션을 가질 수 있으며 솔리드-스테이트 스토리지 컨트롤러(104)는 둘 또느 그 이상의 솔리드-스테이트 스토리지 컨트롤러(104)처럼 동작할 수 있으며, 각각은 솔리드-스테이트 스토리지(110) 내의 단일 파티션상에서 동작한다. 이 실시예에서, 고유한 미디어 암호화 키는 각각의 파티션과 함께 사용될 수 있다.
다른 실시예에서, 데이터 독출 파이프라인(108)은 데이터 세그먼트를 출력 버퍼(330)로 전송하기 전에 디패킷타이저(324)에 의해 구성된 데이터 세그먼트를 복호화하는 복호화 모듈(334)을 포함한다. 독출 요청과 함께 수신된 암호화 키를 사용하여 복호화된 데이터 세그먼트는 독출 동기 버퍼(328)에 의해 수신된 요청된 패킷의 검색을 개시한다. 복호화 모듈(334)은 제 1 패킷을 제 1 패킷에 대한 독출 요청과 함께 수신된 암호화 키를 사용하여 복호화할 수 있고, 그리고 나서 제 2 패킷을 상이한 암호화 키를 사용하여 복호화할 수 있거나 또는 제 2 패킷을 복호화 없이 데이터 독출 파이프라인(108)의 다음 스테이지로 전달할 수 있다. 일반적으로, 복호화 모듈(334)은 상이한 암호화 키를 사용하여 데이터 세그먼트를 복호화하는 반면 미디어 복호화 모듈(332)은 요청된 패킷을 복호화한다. 패킷이 비-기빌 암호적 논스(non-secret cryptographic nonce)를 사용하여 저장된 경우, 논스는 암호화 키와 함께 사용되어 데이터 패킷을 복호화한다. 암호화 키는 클라이언트(114), 컴퓨터(112), 키 관리자, 또는 솔리드-스테이트 스토리지 컨트롤러(104)에 의해 사용될 암호화 키를 관리하는 다른 장치로부터 수신될 수 있다.
다른 실시예에서, 데이터 독출 파이프라인(108)은 디패킷타이저(324)에 의해 구성된 데이터 세그먼트를 복원하는 복원(decompression) 모듈(336)을 포함한다. 바람직한 실시예에서, 복원 모듈(336)은 패킷 헤더 및 컨테이너 라벨 중 하나 또는 둘 모두에 저장된 압축 정보를 사용하여 압축 모듈(312)에 의해 데이터를 압축하기 위해 사용된 루틴과 상보되는 루틴(complementary routine)을 선택한다. 다른 실시예에서, 복원 모듈(336)에 의해 사용되는 복원 루틴은 복원되는 데이터 세그먼트를 요청하는 장치에 의해 지시된다. 다른 실시예에서, 복원 모듈(336)은 객체 타입 또는 객체 클래스 기반 상의 초기 세팅에 따라 복원 루틴을 선택한다. 제 1 객체의 제 1 패킷은 초기 복원 루틴을 무시할 수 있고 동일한 객체 클래스 및 객체 타입의 제 2 객체의 제 2 패킷은 초기 복원 루틴을 사용할 수 있고 동일한 객체 클래스 및 객체 타입의 제 3 객체의 제 3 패킷은 복원을 사용하지 않을 수 있다.
다른 실시예에서, 데이터 독출 파이프라인(108)은 데이터 독출 파이프라인(108) 내의 하나 또는 그 이상의 사용자-정의가능한(user-definable) 기능을 포함하는 독출 프로그램 모듈(338)을 포함한다. 독출 프로그램 모듈(338)은 기록 프로그램 모듈(310)과 유사한 특성을 가지고 사용자가 데이터 독출 파이프라인(108)으로 커스텀 기능을 제공할 수 있도록 한다. 독출 프로그램 모듈(338)은 도 3에 도시된 바와 같이 위치될 수 있거나, 데이터 독출 파이프라인(108) 내의 다른 지점에 위치될 수 있거나, 또는 데이터 독출 파이프라인(108) 내의 다수 지점 내에 다수 부분을 포함할 수 있다. 추가적으로, 데이터 독출 파이프라인(108) 내의 다수 지점 내의 다수의 독출 프로그램 모듈(338)은 독립적으로 동작할 수 있다. 당업자는 데이터 독출 파이프라인(108) 내의 독출 프로그램 모듈(338)의 다른 형태를 인식할 것이다. 데이터 기록 파이프라인(106)과 같이, 데이터 독출 파이프라인(108)의 스테이지는 재배열될 수 있으며 당업자는 데이터 독출 파이프라인(108) 내의 스테이지의 다른 순서를 인식할 것이다.
솔리드-스테이트 스토리지 컨트롤러(104)는 컨트롤 및 상태 레지스터(340) 및 해당 컨트롤 큐(342)를 포함한다. 컨트롤 및 상태 레지스터(340) 및 컨트롤 큐(342)는 데이터 기록 및 독출 파이프라인(106,108) 내에서 처리되는 데이터와 결합되는 시퀀싱 명령 및 서브명령을 구현한다. 예를 들어, 패킷타이저(302) 내의 데이터 세그먼트는 ECC 생성기와 결합된 컨트롤 큐(342) 내의 하나 또는 그 이상의 해당 컨트롤 명령 또는 지시를 구비할 수 있다. 데이터 세그먼트가 패킷화됨에 따라, 지시 또는 명령 중 일부는 패킷타이저(302) 내에서 실행될 수 있다. 다른 명령 또는 지시는 컨트롤 및 상태 레지스터(340)를 통해 새로 형성된 데이터 패킷으로서 다음 컨트롤 큐(342)로 전달될 수 있다.
각각의 패킷이 스테이지에 의해 실행됨에 따라 각각의 파이프라인 스테이지는 적절한 명령 또는 지시를 끌어오면서, 명령 또는 지시는 데이터 기록 파이프라인(106)으로 전달되는 패킷을 위한 컨트롤 큐(342)로 동시에 로드(loaded)될 수 있다. 유사하게, 각각의 패킷이 스테이지에 의해 실행됨에 따라 각각의 파이프라인 스테이지는 적절한 명령 또는 지시를 끌어오면서, 명령 또는 지시는 데이터 독출 파이프라인(108)으로부터 요청되는 패킷을 위한 컨트롤 큐(342)로 동시에 로드될 수 있다. 당업자는 컨트롤 및 상태 레지스터(340) 및 컨트롤 큐(342)의 다른 특징 및 기능을 인식할 것이다.
솔리드-스테이트 스토리지 컨트롤러(104) 및/또는 솔리드-스테이트 스토리지 장치(102)는 또한 뱅크 인터리브 컨트롤러(344), 동기 버퍼(346), 스토리지 버스 컨트롤러(348), 및 멀티플렉서(MUX)(350)을 포함하며, 이는 도 4a 및 도 4b와 관련하여 기술된다.
뱅크 인터리브(Bank Interleave)
도 4a는 본 발명에 따른 솔리드-스테이트 스토리지 컨트롤러(104) 내의 뱅크 인터리브 컨트롤러(344)의 일 실시예(400)를 설명하는 개략적인 블록도이다. 뱅크 인터리브 컨트롤러(344)는 컨트롤 및 상태 레지스터(340)에 연결되고, MUX(350), 스토리지 버스 컨트롤러(348), 및 동기 버퍼(346)를 통해 스토리지 I/O 버스(210) 및 스토리지 컨트롤 버스(212)에 연결되며, 이는 이하 기술된다. 뱅크 인터리브 컨트롤러는 독출 에이전트(402), 기록 에이전트(404), 소거 에이전트(406), 관리 에이전트(408), 독출 큐(410a-n), 기록 큐(412a-n), 소거 큐(414a-n) 및 솔리드-스테이트 스토리지(110) 내의 뱅크(214)를 위한 관리 큐(416a-n), 뱅크 컨트롤러(418a-n), 버스 아비터(bus arbiter)(420), 및 상태 MUX(status MUX)(422)를 포함하며, 이는 이하 기술된다.
뱅크 인터리브 컨트롤러(344)는 하나 또는 그 이상의 명령을 뱅크 인터리브 컨트롤러(344) 내의 둘 또는 그 이상의 큐로 지시하고 큐 내에 저장된 명령의 솔리드-스테이트 스토리지(110) 실행의 뱅크(214) 사이에서 조정하여, 제 1 타입의 명령은 하나의 뱅크(214a)에서 실행되는 반면 제 2 타입의 명령은 제 2 뱅크(214b)에서 실행된다. 하나 또는 그 이상의 명령은 명령 타입에 의해 큐로 분리된다. 솔리드-스테이트 스토리지(110)의 각각의 뱅크(214)는 뱅크 인터리브 컨트롤러(344) 내의 큐의 해당 세트를 구비하고 큐의 각각의 세트는 각각의 명령 타입을 위한 큐를 포함한다.
뱅크 인터리브 컨트롤러(344)는 큐 내에 저장된 명령의 솔리드-스테이트 스토리지(110) 실행의 뱅크(214) 사이에서 조정된다. 예를 들어, 제 1 타입의 명령은 하나의 뱅크(214a)에서 실행되는 반면 제 2 타입의 명령은 제 2 뱅크(214b)에서 실행된다. 일반적으로 명령 타입 및 큐 타입은 독출 및 기록 명령 및 큐(410,412)를 포함하지만, 또한 저장 매체에 특정한 다른 명령 및 큐를 포함할 수도 있다. 예를 들어, 도 4a에 도시된 실시예에서, 소거 및 관리 큐(414,416)는 포함되고 플래시 메모리, NRAM, MRAM, DRAM, PRAM 등에 적절할 것이다.
솔리드-스테이트 스토리지(110)의 다른 타입에 대해, 명령 및 해당 큐의 다른 타입은 본 발명의 범위로부터 벗어나지 않으면서 포함될 수 있다. FPGA 솔리드-스테이트 스토리지 컨트롤러(104)의 유연한 속성(flexible nature)은 저장 매체 내에 유연성을 허용한다. 플래시 메모리가 다른 솔리드-스테이트 스토리지 타입으로 변경된 경우, 뱅크 인터리브 컨트롤러(344), 스토리지 버스 컨트롤러(348), 및 MUX(350)는 데이터 파이프라인(106,108) 및 다른 솔리드-스테이트 스토리지 컨트롤러(104) 기능에 중대하게 영향을 미치지 않으면서 미디어 타입에 적합하게 변경될 수 있다.
도 4a에 도시된 실시예에서, 뱅크 인터리브 컨트롤러(344)는 각각의 뱅크(214), 솔리드-스테이트 스토리지(110)으로부터 데이터 독출을 위한 독출 큐(410), 솔리드-스테이트 스토리지(110)로 명령을 기록하기 위한 기록 큐(412), 솔리드-스테이트 스토리지 내의 소거 블록을 소거하기 위한 소거 큐(414), 관리 명령을 위한 관리 큐(416)를 포함한다. 뱅크 인터리브 컨트롤러(344)는 또한 해당 독출, 기록, 소거, 및 관리 에이전트(402,404,406,408)을 포함한다. 다른 실시예에서, 컨트롤 및 상태 레지스터(340) 및 컨트롤 큐(342) 또는 유사한 컴포넌트는 솔리드-스테이트 스토리지(110)의 뱅크(214)로 전송되는 데이터를 위한 명령을 뱅크 인터리브 컨트롤러(344)를 사용하지 않고 대기행렬에 대기시킨다(queue).
일 실시예에서, 에이전트(402,404,406,408)는 특정 뱅크(214a)를 위해 정해진 적절한 타입의 명령을 뱅크(214a)를 위한 정정 큐(correct queue)로 보낸다. 예를 들어, 독출 에이전트(402)는 뱅크-1(214b)를 위한 독출 명령을 수신하고 상기 독출 명령을 뱅크-1 독출 큐(410b)로 보낼 수 있다. 기록 에이전트(404)는 데이터를 솔리드-스테이트 스토리지(110)의 뱅크-0(214a) 내의 한 장소로 기록하도록 하는 기록 명령을 수신할 수 있고, 그리고 나서 상기 기록 명령을 뱅크-0 기록 큐(412a)로 전송할 것이다. 유사하게, 소거 에이전트(406)는 뱅크-1(214b) 내의 소거 블록을 소거하는 소거 명령을 수신할 수 있고, 그리고 나서 상기 소거 명령을 뱅크-1 소거 큐(414b)로 전달할 것이다. 관리 에이전트(408)는 일반적으로 리셋 명령 또는 뱅크-0(214a)와 같은 뱅크(214)의 구성 레지스터(configuration register)를독출하는 요청과 같은 관리 명령, 상태 요청(status requests) 등을 수신한다. 관리 에이전트(408)는 관리 명령을 뱅크-0 관리 큐(416a)로 전송한다.
또한, 에이전트(402,404,406,408)는 일반적으로 큐(410,412,414,416)의 상태를 감시하고 큐(410,412,414,416)가 가득 차거나, 거의 가득 차거나, 동작하지 않는 등의 경우 상태, 인터럽트, 또는 다른 메시지를 전송한다. 일 실시예에서, 에이전트(402,404,406,408)는 명령을 수신하고 해당 서브명령을 생성한다. 일 실시예에서, 에이전트(402,404,406,408)는 컨트롤 및 상태 레지스터(340)을 통해 명령을 수신하고 큐(410,412,414,416)로 전달되는 해당 서브명령을 생성한다. 당업자는 에이전트(402,404,406,408)의 다른 기능을 인식할 것이다.
큐(410,412,414,416)는 일반적으로 명령을 수신하고 솔리드-스테이트 스토리지 뱅크(214)로 전송이 요구될 때까지 상기 명령을 저장한다. 일반적인 실시예에서, 큐(410,412,414,416)는 FIFO(First-In, First-Out) 레지스터 또는 FIFO로서 동작하는 유사한 컴포넌트이다. 다른 실시예에서, 큐(410,412,414,416)는 데이터를 매치하는(match) 오더, 중요 순서, 다른 분류에 따라 명령을 저장ㅎ나다.
뱅크 컨트롤러(418)는 일반적으로 큐(410,412,414,416)로부터 명령을 수신하고 적절한 서브명령을 생성한다. 예를 들어, 뱅크-0 기록 큐(412a)는 데이터 패킷의 페이지를 뱅크-0(214a)로 기록하는 명령을 수신할 수 있다. 뱅크-0 컨트롤러(418a)는 적절한 시기에 기록 명령을 수신할 수 있고 뱅크-0(214a) 내의 페이지로 기록될 기록 버퍼(320) 내에 저장된 각각의 데이터 패킷에 대한 하나 또는 그 이상의 기록 서브명령을 생성한다. 예를 들어, 뱅크-0 컨트롤러(418a)는 뱅크 0(214a) 및솔리드-스테이트 스토리지 어레이(216)의 상태를 검증하기 위한 명령을 생성하고, 하나 또는 그 이상의 데이터 패킷을 기록하기 위한 적절한 장소를 선택하고, 솔리드-스테이트 스토리지 메모리 어레이(216) 내의 입력 버퍼를 비우고(clear), 하나 또는 그 이상의 데이터 패킷을 입력 버퍼로 전송하고, 입력 버퍼를 상기 선택된 장소로 프로그램하고, 데이터가 올바르게 프로그래밍 되었는지 검증하고, 프로그램 실패가 발생하면 하나 또는 그 이상의 마스터 컨트롤러 인터럽트를 수행하고, 동일한 물리적 장소로 기록을 재시도하고 상이한 물리적 장소로 기록을 재시도한다. 추가적으로, 기록 명령의 예와 함께, 스토리지 버스 컨트롤러(348)는 스토리지 I/O 버스(210a)에 대한 제 1 물리적 어드레스로 매핑되고 스토리지 I/O 버스(210b)에 대한 제 2 물리적 어드레스로 매핑되는 등의 명령의 논리적 어드레스를 사용하여 각각의 스토리지 I/O 버스(210a-n)로 다중시키는 하나 또는 그 이상의 명령을 야기시킬 것이다.
일반적으로, 버스 아비터(420)는 뱅크 컨트롤러(418) 중에서 선택하고 뱅크 컨트롤러(418) 내의 출력 큐로부터 서브명령을 끌어내고 뱅크(214)의 성능을 최적화하는 순서로 이들 출력 큐를 스토리지 버스 컨트롤러(348)로 전달한다. 다른 실시예에서, 버스 아비터(420)는 하이 레벨 인터럽트에 응답하고 일반적인 선택 기준을 변경할 수 있다. 다른 실시예에서, 마스터 컨트롤러(224)는 컨트롤 및 상태 레지스터(340)를 통해 버스 아비터(420)를 제어할 수 있다. 당업자는 버스 아비터(420)가 명령의 시퀀스를 뱅크 컨트롤러(418)로부터 솔리드-스테이트 스토리지(110)로 제어하고 인터리브할 수 있는 다른 수단을 인식할 것이다.
버스 아비터(420)는 일반적으로 적절한 명령의 선택, 및 명령 타입에 따라 요구되는 경우 뱅크 컨트롤러(418)로부터 해당 데이터를 불러와 명령 및 데이터를 스토리지 버스 컨트롤러(348)로 전송한다. 버스 아비터(420)는 또한 일반적으로 명령을 스토리지 컨트롤 버스(212)로 전송하여 적절한 뱅크(214)를 선택한다. 플래시 메모리 또는 비동기식, 양방향 직렬 스토리지 I/O 버스(210)의 다른 솔리드-스테이트 스토리지(110)의 경우에 대해, 오직 하나의 명령(제어 정보) 또는 데이터 세트만이 한 번에 전송될 수 있다. 예를 들어, 기록 명령 또는 데이터가 스토리지 I/O 버스(210) 상에서 솔리드-스테이트 스토리지(110)으로 전송되는 경우, 독출 명령, 독출되는 데이터, 소거 명령, 관리 명령, 또는 다른 상태 명령은 스토리지 I/O 버스(210) 상으로 전송될 수 없다. 예를 들어, 데이터가 스토리지 I/O 버스(210)으로부터 독출되는 경우, 데이터는 솔리드-스테이트 스토리지(110)으로 기록될 수 없다.
예를 들어, 뱅크-0으로의 기록 동작 도중, 버스 아비터(420)는 스토리지 버스 컨트롤러(348)이 다음과 같은 시퀀스를 실행하도록 야기하는 큐의 상부에 있는 기록 명령 또는 일련의 기록 서브-명령들을 구비할 수 있는 뱅크-0 컨트롤러(418a)를선택한다. 버스 아비터(420)는 기록 명령을 스토리지 버스 컨트롤러(348)로 전달하며, 이는 스토리지 컨트롤 버스(212)를 통해 뱅크-0(214a)를 선택함으로써 기록 명령을 설치하며, 뱅크-0(214a)와 결합된 솔리드-스테이트 스토리지 엘리먼트(110)의 입력 버퍼를 비우는 명령을 전송하고, 뱅크-0(214a)와 결합된 솔리드-스테이트 스토리지 엘리먼트(216,218,220)의 의 상태를 검증하는 명령을 전송한다. 그리고 나서, 스토리지 버스 컨트롤러(348)는 스토리지 I/O 버스(210) 상으로 기록 서브명령을 전송하며, 이는 논리적 소거 블록 어드레스로부터 매핑된 바와 같이 각각의 개별적인 물리적 소거 솔리드-스테이트 스토리지 엘리먼트(216a-m)에 대한 논리적 소거 블록의 어드레스를 포함하는 물리적 어드레스를 포함한다. 그리고 나서, 스토리지 버스 컨트롤러(348)는 기록 동기 버퍼(308)를 통한 기록 버퍼(320)를 MUX(350)를통해 스토리지 I/O 버스(210)로 다중화한다(mux). 페이지가 가득 찬 경우, 스토리지 버스 컨트롤러(348)는 뱅크-0(214a)와 결합된 솔리드-스테이트 스토리지 엘리먼트(216a-m)가 입력 버퍼를 솔리드-스테이트 스토리지 엘리먼트(216a-m) 내의 메모리 셀로 프로그램하도록 야기한다. 최종적으로, 스토리지 버스 컨트롤러(348)는 페이지가 올바르게 프로그래밍 되었는지 보증하도록 상태를 검증한다.
독출 동작은 상술한 기록의 예와 유사하다. 독출 동작 도중, 일반적으로 버스 아비터(420) 또는 뱅크 인터리브 컨트롤러(344)의 다른 컴포넌트는 데이터 및 해당 상태 정보를 수신하고, 상태 정보를 컨트롤 및 상태 레지스터(340)로 전송하는 반면 데이터를 데이터 독출 파이프라인(108)으로 전송한다. 일반적으로, 버스 아비터(420)로부터 스토리지 버스 컨트롤러(348)로 전달된 독출 데이터 명령은 MUX(350)가 스토리지 I/O 버스(210) 상의 독출 데이터를 데이터 독출 파이프라인(108)으로 제어하도록(gate) 야기하고, 상태 정보를 상태 MUX(422)를통해 적절한 컨트롤 및 상태 레지스터(340)로 전송한다.
버스 아비터(420)는 다양한 명령 타입 및 데이터 액세스 모드를 제어하여, 오직 적절한 명령 타입 또는 해당 데이터만이 임의의 주어진 시간에 버스에 위치하도록 한다. 버스 아비터(420)가 기록 명령을 선택하고, 기록 서브명령 및 해당 데이터가 솔리드-스테이트 스토리지(110)로 기록되는 경우, 버스 아비터(420)는 다른 명령 타입이 스토리지 I/O 버스(210) 상에 위치하도록 허용하지 않을 것이다. 유리하게, 버스 아비터(420)는 뱅크(214) 상태에 관해 수신된 상태 정보와 함께, 예견된 명령 실행 시간과 같은 타이밍 정보를 사용하여, 버스의 유휴 시간(idle time)을 최소화하거나 제거하는 목적으로 버스 상의 다양한 명령의 실행을 조정한다.
버스 아비터(420)를 통한 마스터 컨트롤러(224)는 일반적으로 상태 정보와 함께, 큐(410,412,414,416)에 저장된 명령의 기대되는 완료 시간을 사용하여, 명령과 결합된 서브명령이 하나의 뱅크(214a) 상에서 실행되고 있는 경우, 다른 명령의 다른 서브명령은 다른 뱅크(214b-n) 상에서 실행되도록 한다. 하나의 명령이 뱅크(214a)에서 완전히 실행되는 경우, 버스 아비터(420)는 다른 명령을 뱅크(214a)로 지시한다. 버스 아비터(420)는 또한 큐(410,412,414,416)에 저장되지 않은 다른 명령과 함께 큐(410,412,414,416)에 저장된 명령을 조정한다.
예를 들어, 소거 명령은 솔리드-스테이트 스토리지(110) 내의 소거 블록의 그룹을 소거하도록 전송될 수 있다. 소거 명령은 실행하기 위해 기록 또는 독출 명령보다 10에서 1000 배 많은 시간이 걸리거나, 실행하기 위해 프로그램 명령보다 10에서 100 배 많은 시간이 걸릴 수 있다. N 개의 뱅크(214)에 대해, 뱅크 인터리브 컨트롤러(344)는 소거 명령을 N 개의 명령으로 분할할 수 있고, 각각은 뱅크(214a)의 가상 소거 블록을 소거한다. 뱅크-0(214a)가 소거 명령을 실행하는 동안, 버스 아비터(420)는 다른 뱅크(214b-n) 상의 실행을 위한 다른 명령을 선택할 수 있다. 버스 아비터(420)는 또한 스토리지 버스 컨트롤러(348), 마스터 컨트롤러(224) 등과 같은 다른 컴포넌트와 함께 동작하여, 버스 사이에서 명령 실행을 조정할 수 있다. 버스 아비터(420), 뱅크 컨트롤러(418), 큐(410,412,414,416) 및 뱅의 에이전트(402,404,406,408)를 사용한 명령의 실행 조정은 뱅크 인터리브 기능이 없는 다른 솔리드-스테이트 스토리지 시스템보다 성능이 월등하게 증가한다.
일 실시예에서, 솔리드-스테이트 컨트롤러(104)는 솔리드-스테이트 스토리지(110)의 모든 스토리지 엘리먼트(216,218,220)를 제어하는 하나의 뱅크 인터리브 컨트롤러(344)를 포함한다. 다른 실시예에서, 솔리드-스테이트 컨트롤러(104)는 스토리지 엘리먼트(216a-m,218a-m,220a-m)의 각각의 열을 위한 뱅크 인터리브 컨트롤러(344)를 포함한다. 예를 들어, 하나의 뱅크 인터리브 컨트롤러(344)는 스토리지 엘리먼트의 일 열 SSS 0.0-SSS 0.N(216a,218a,220a)을 제어하고, 제 2 뱅크 인터리브 컨트롤러(344)는 스토리지 엘리먼트의 제 2 열 SSS 1.0-SSS1.N(216b,218b,220b)를 제어하는 식으로 동작할 수 있다.
도 4b는 본 발명에 따른 솔리드-스테이트 스토리지 컨트롤러 내의 뱅크 인터리브 컨트롤러의 대체적인 실시예(401)를 설명하는 개략적인 블록도이다. 도 4b에도시된 실시예에 나타난 컴포넌트(210,212,340,346,350,402-430)는 각각의 뱅크(214)가 단일의 큐(432a-n)를 포함하고 뱅크(예컨대 뱅크-0(214a))에 대한 독출 명령, 기록 명령, 소거 명령, 관리 명령 등은 뱅크(214a)에 대한 단일 큐(432a)로 보내지는 점을 제외하고 도 4a에 관하여 기술된 뱅크 인터리브 장치(400)과 실질적으로 유사하다. 일 실시예에서, 큐(432)는 FIFO이다. 다른 실시예에서, 큐(432)는 저장된 순서가 아닌 다른 순서로 큐(432)로부터 끌어온 명령을 구비할 수 있다. 다른 대체적인 실시예에서(미도시), 독출 에이전트(402), 기록 에이전트(404), 소거 에이전트(406), 및 관리 에이전트(408)는 적절한 큐(432a-n)로 명령을 할당하는 단일 에이전트로 결합될 수 있다.
다른 대체적인 실시예에서(미도시), 명령은 단일 큐에 저장되며, 여기서 명령은 그들이 저장된 순서가 아닌 다른 순서로 큐로부터 불려올 수 있으며, 뱅크 인터리브 컨트롤러(344)는 하나의 뱅크(214a) 상의 명령을 실행하는 반면 다른 명령은 다른 뱅크(214b-n) 상에서 실행되도록 할 수 있다. 당업자는 하나의 뱅크(214a) 상에서 명령이 실행되는 반면 다른 명령이 다른 뱅크(214b-n) 상에서 실행되도록 하는 다른 큐 구성 및 타입을 용이하게 인식할 것이다.
스토리지-특정 컴포넌트(Storage-Specific Components)
솔리드-스테이트 스토리지 컨트롤러(104)는 전송되고 솔리드-스테이트 스토리지(110)으로부터 수신된 명령 및 상태 메시지를 버퍼링하는 동기 버퍼(346)를 포함한다. 동기 버퍼(346)는 솔리드-스테이트 스토리지 클럭 도메인과 로컬 버스 클럭 도메인 사이의 경계에 위치하고 클럭 도메인의 차이를 보완하기 위해 버퍼링을 제공한다. 동기 버퍼(346), 기록 동기 버퍼(308), 및 독출 동기 버퍼(328)는 독립적일 수 있거나, 또는 데이터, 명령, 상태 메시지 등을 버퍼링하도록 함께 동작할 수 있다. 바람직한 실시예에서, 동기 버퍼(346)는 클럭 도메인을 가로지르는 신호의 수가 가장 적은 장소에 위치한다. 당업자는 클럭 도메인 간의 동기가 솔리드-스테이트 스토리지 장치(102) 내의 다른 장소로 임의적으로 이동되어 디장니 구현의 일부 양상을 최적화하는 방식을 인식할 것이다.
솔리드-스테이트 스토리지 컨트롤러(104)는 솔리드-스테이트 스토리지로 전송되고 그로부터 독출되는 데이터를 위한 명령 및 솔리드-스테이트 스토리지(110)의 타입을 기반으로 솔리드-스테이트 스토리지(110)으로부터 수신된 상태 메시지를 해석하고 번역하는 스토리지 버스 컨트롤러(348)를 포함한다. 예를 들어, 스토리지 버스 컨트롤러(348)는 스토리지의 상이한 타입, 상이한 성능 특성의 스토리지, 상이한 제조자로부터의 스토리지 등을 위한 상이한 타이밍 요건을 구비할 수 있다. 스토리지 버스 컨트롤러(348)는 또한 제어 명령을 스토리지 컨트롤 버스(212)로 전송한다.
바람직한 실시예에서, 솔리드-스테이트 스토리지 컨트롤러(104)는 멀티플렉서(350a-n)의 어레이를 포함하는 MUX(350)를 포함하며, 여기서 각각의 멀티플렉서는 솔리드-스테이트 스토리지 어레이(110)의 열을 위해 사용된다. 예를 들어, 멀티플렉서(350a)는 솔리드-스테이트 스토리지 엘리먼트(216a,218a,220a)와 결합된다. MUX(350)는 데이터 기록 파이프라인(106)으로부터의 데이터 및 스토리지 버스 컨트롤러(348)로부터의 명령을 스토리지 I/O 버스(210)을 통해 솔리드-스테이트 스토리지(110)로 라우팅하고, 스토리지 I/O 버스(210)를 통한 솔리드-스테이트 스토리지(220)으로부터의 데이터 및 상태 메시지를 스토리지 버스 컨트롤러(348), 동기 버퍼(346), 및 뱅크 인터리브 컨트롤러(344)를 통해 데이터 독출 파이프라인(106) 및 컨트롤 및 상태 레지스터(340)로 라우팅한다.
바람직한 실시예에서, 솔리드-스테이트 스토리지 컨트롤러(104)는 솔리드-스테이트 스토리지 엘리먼트(예컨대 SSS 0.1(216a), SSS 0.2(218a), SSS 0.N(220a))를 위한 MUX(350)를 포함한다. MUX(350)는 데이터 기록 파이프라인(106)으로부터의 데이터와 스토리지 I/O 버스(210)를 통해 솔리드-스테이트 스토리지(110)로 전송된 명령을 결합하고, 명령으로부터 데이터 독출 파이프라인(106)에 의해 처리될 데이터를 분리한다. 기록 버퍼(320) 내에 저장된 패킷은 기록 버퍼(320)를 벗어나 버스로 보내져, 솔리드-스테이트 스토리지 엘리먼트(SSS x.0 내지 SSS x.N(216,218,220)의 각각의 열에 대한 기록 동기 버퍼(308)를 통해 솔리드-스테이트 스토리지 엘리먼트(SSS x.0 내지 SSS x.N(216,218,220)의 각각의 열에 대한 MUX(350)로 보내진다. 명령 및 독출 데이터는 MUX(350)에 의해 스토리지 I/O 버스(210)으로부터 수신된다. MUX(350)는 또한 상태 메시지를 스토리지 버스 컨트롤러(348)로 보낸다.
스토리지 버스 컨트롤러(348)는 매핑 모듈(424)를 포함한다. 매핑 모듈(424)은 소거 블록의 논리적 어드레스를 소거 블록의 하나 또는 그 이상의 물리적 어드레스로 매핑한다. 예를 들어, 블록(214a) 당 20 개의 스토리지 엘리먼트의 어레이(예컨대 SSS 0.0 내지 SSS M.0(216))를 구비한 솔리드-스테이트 스토리지(110)는 소거 블록의 20 개의 물리적 어드레스로 매핑된 특정 소거 블록에 대한 논리적 어드레스를 구비하고, 스토리지 엘리먼트 당 하나의 물리적 어드레스를 구비할 수 있다. 스토리지 엘리먼트가 병렬로 액세스되기 때문에, 스토리지 엘리먼트(216a,218a,220a)의 열 내의 각각의 스토리지 엘리먼트 내의 동일한 지점에서의 소거 블록은 물리적 어드레스를 공유할 것이다. 열 내의 (예컨대, 스토리지 엘리먼트 SSS 0.0,0.1,...0.N(216a,218a,220a) 내의) 모든 소거 블록 대신 하나의 소거 블록(예컨대 스토리지 엘리먼트 SSS 0.0(216a))를 선택하기 위해, 하나의 뱅크(이 경우 뱅크-0(214a)가 선택된다.
하나의 소거 블록이 손상되거나 액세스가 불가능한 경우, 매핑은 다른 소거 블록을 매핑하도록 변경될 수 있으므로, 이러한 소거 블록에 대한 논리적-물리적 매핑은 유리하다. 이는 하나의 엘리먼트의 소거 블록에 결함이 있는 경우 전체 가상 소거 블록의 손실에 의한 손실을 완화시킨다. 리매핑 모듈(430)은 소거 블록의 논리적 어드레스의 매핑을 가상 소거 블록(스토리지 엘리먼트의 어레이 전반에 걸쳐 분포됨)의 하나 또는 그 이상의 물리적 어드레스로 변경한다. 예를 들어, 가상 소거 블록 1은 스토리지 엘리먼트 SSS0.0(216a)의 소거 블록 1, 스토리지 엘리먼트 SSS 1.0(216b)의 소거 블록 1,..., 및 스토리지 엘리먼트 M.0(216m)으로 매핑될 수 있으며, 가상 소거 블록 2는 스토리지 엘리먼트 SSS 0.1(218a)의 소거 블록 2, 스토리지 엘리먼트 SSS 1.1(218b)의 소거 블록 2,..., 및 스토리지 엘리먼트 M.1(218m) 등으로 매핑될 수 있다.
오랜 사용으로 인한 에러의 발생 등, 또는 다른 이유에 의해 사용할 수 없는 경우와 같이, 스토리지 엘리먼트 SSS 0.0(216a)의 소거 블록 1이 손상된 경우, 리매핑 모듈은 가상 소거 블록 1의 소거 블록 1로 지시된 논리적 어드레스에 대한 논리적-물리적 매핑을 변경할 수 있다. 스토리지 엘리먼트 SSS 0.0(216a)의 예비(spare) 소거 블록(이를 소거 블록 221로 언급함)이 유효하고 현재 매핑되지 않은 상태인 경우, 스토리지 엘리먼트 SSS 1.0(216b)의 소거 블록 1, 스토리지 엘리먼트 SSS 2.0의 소거 블록 1(미도시),..., 및 스토리지 엘리먼트 M.0(216m)으로의 지시를 지속하면서, 리매핑 모듈은 스토리지 엘리먼트 SSS 0.0(216a)의 소거 블록 221을 지시하도록 가상 소거 블록 1의 매핑을 변경할 수 있다.
매핑 모듈(424) 또는 리매핑 모듈(430)은 기설정된 순서(가상 소거 블록 1을 스토리지 엘리먼트의 소거 블록 1로, 가상 소거 블록 2를 스토리지 엘리먼트의 소거 블록 2로 등과 같음)로 소거 블록들을 매핑하거나, 또는 다른 기준을 기반으로 다른 순서로 스토리지 엘리먼트(216,218,220)의 소거 블록을 매핑할 수 있다.
일 실시예에서, 소거 블록은 액세스 타임에 의해 그룹으로 구성될 수 있다. 명령을 실행하는 시간, 예컨대 특정 소거 블록의 페이지로 데이터를 프로그래밍(기록)하는 시간을 의미하는 액세스 타임에 의한 그룹화는 명령 완료를 고르게 할 수 있어, 가상 소거 블록의 소거 블록에 걸쳐 실행된 명령이 가장 느린 소거 블록에 의해 제한되지 않도록 한다. 다른 실시예에서, 소거 블록은 마모 레벨(wear level), 양호 정도(health) 등에 의해 그룹화될 수 있다. 당업자는 소거 블록의 매핑 또는 리매핑에 고려할 다른 팩터를 인식할 것이다.
일 실시예에서, 스토리지 버스 컨트롤러(348)는 솔리드-스테이트 스토리지(110)로부터 상태 메시지를 수신하고 상태 메시지를 상태 MUX(422)로 전송하는 상태 캡쳐 모듈(426)을 포함한다. 다른 실시예에서, 솔리드-스테이트 스토리지(110)가 플래시 메모리인 경우, 스토리지 버스 컨트롤러(348)는 NAND 버스 컨트롤러(428)를 포함한다. NAND 버스 컨트롤러(428)는 명령을 데이터 독출 및 기록 파이프라인(106,108)로부터 솔리드-스테이트 스토리지(110) 내의 올바른 장소로 지시하며, 플래시 메모리 등의 특성을 기반으로 명령 실행의 타이밍을 조정한다. 솔리드-스테이트 스토리지(110)가 다른 솔리드-스테이트 스토리지 타입인 경우, NAND 버스 컨트롤러(428)는 스토리지 타입에 특정한 버스 컨트롤러로 교체될 것이다. 당업자는 NAND 버스 컨트롤러(428)의 다른 기능을 인식할 것이다.
흐름도
도 5a는 본 발명에 따른 데이터 파이프라인을 사용한 솔리드-스테이트 스토리지 장치(102) 내의 데이터를 관리하는 방법(500)의 일 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(500)은 개시되고(502), 입력 버퍼(306)가 솔리드-스테이트 스토리지(110)에 기록될 하나 또는 그 이상의 데이터 세그먼트를 수신한다(504). 하나 또는 그 이상의 데이터 세그먼트는 일반적으로 객체의 적어도 일부를 포함하지만 전체 객체일 수도 있다. 패킷타이저(302)는 객체와 결합하여 하나 또는 그 이상의 객체 특정 패킷을 생성할 수 있다. 패킷타이저(302)는 헤더를 각각의 패킷에 추가하며, 헤더는 일반적으로 패킷의 길이 및 객체 내의 패킷에 대한 시퀀스 번호를 포함한다. 패킷타이저(302)는 입력 버퍼(306)에 저장된 하나 또는 그 이상의 데이터 또는 메타데이터 세그먼트를 수신하고(504), 솔리드-스테이트 스토리지(110)을 위한 사이즈로 구성된 하나 또는 그 이상의 패킷을 생성함으로써 하나 또는 그 이상의 데이터 또는 메타데이터 세그먼트를 패킷타이즈하며(506), 여기서 각각의 패킷은 하나의 헤더 및 하나 또는 그 이상의 세그먼트로부터의 데이터를 포함한다.
일반적으로, 제 1 패킷은 패킷이 생성된 객체를 식별하는 객체 식별자를 포함한다. 제 2 패킷은 제 2 패킷을 제 1 패킷에서 식별된 객체로 결합시키기 위해 솔리드-스테이트 스토리지 장치(102)에 의해 사용된 정보 및 객체 내의 제 2 패킷을 위치시키는 오프셋 정보를 구비한 헤더, 및 데이터를 포함할 수 있다. 솔리드-스테이트 스토리지 장치 컨트롤러(202)는 뱅크(214) 및 패킷이 스트리밍되는 물리적 영역을 관리한다.
ECC 생성기(304)는 패킷타이저(302)로부터 패킷을 수신하고 데이터 패킷을 위한 ECC를 생성한다(508). 일반적으로, 패킷과 ECC 블록 간에는 고정된 관계는 없다. ECC 블록은 하나 또는 그 이상의 패킷을 포함할 수 있다. 패킷은 하나 또는 그 이상의 ECC 블록을 포함할 수 있다. 패킷은 ECC 블록 내의 어느 곳에서도 시작하고 종료될 수 있다. 패킷은 제 1 ECC 블록 내의 임의의 곳에서 시작하고 수반하는 ECC 블록 내의 임의의 곳에서 종료될 수 있다.
기록 동기 버퍼(308)는 ECC 블록을 솔리드-스테이트 스토리지(110)로 기록하기 전에 해당 ECC 블록 내에 분산된 패킷을 버퍼링하고(510), 그리고 나서 솔리드-스테이트 스토리지 컨트롤러(104)는 클럭 도메인 차이를 고려한 적절한 시간에 데이터를 기록하고(512), 상기 방법(500)은 종료한다(514). 기록 동기 버퍼(308)는 로컬 클럭 도메인 및 솔리드-스테이트 스토리지(220) 클럭 도메인 사이의 경계에 위치된다. 상기 방법(500)은 하나 또는 그 이상의 데이터 세그먼트를 수신하고 편의를 위해 하나 또는 그 이상의 데이터 패킷을 기록하는 단계를 기술하지만, 일반적으로 데이터 세그먼트의 스트림은 그룹으로 수신된다. 일반적으로 솔리드-스테이트 스토리지(110)의 완전한(complete) 가상 페이지를 포함한 많은 ECC 블록이 솔리드-스테이트 스토리지(110)에 기록된다. 일반적으로 패킷타이저(302)는 한 사이즈의 데이터 세그먼트를 수신하고 다른 사이즈의 패킷을 생성한다. 이는 필수적으로 데이터 또는 메타데이터 세그먼트 또는 데이터 또는 메타데이터 세그먼트의 일부가 데이터 패킷을 형성하도록 결합되어 세그먼트의 모든 데이터를 패킷으로 캡쳐하는 것을 요구한다.
도 5b는 본 발명에 따른 인-서버 SAN을 위한 방법의 일 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(500)은 개시하여(522), 스토리지 통신 모듈(162)이 제 1 스토리지 컨트롤러(152a)와 제 1 서버(112a)의 외부에 구비된 적어도 하나의 장치 간의 통신을 구현한다(554). 제 1 스토리지 컨트롤러(152a)와 외부 장치 간의 통신은 제 1 서버(112a)로부터 독립적이다. 제 1 스토리지 컨트롤러(112a)는 제 1 서버(112a) 내에 구비되고, 제 1 스토리지 컨트롤러(152a)는 적어도 하나의 저장 장치(154a)를 제어한다. 제 1 서버(112a)는 제 1 서버(112a)와 함께 배치된 네트워크 인터페이스(156a) 및 제 1 스토리지 컨트롤러(152a)를 포함한다. 인-서버 SAN 모듈(164)는 스토리지 요청을 서비스하고(556), 상기 방법(501)은 종료한다(558). 인-서버 SAN 모듈은 네트워크 프로토콜 및/또는 버스 프로토콜을 사용하여 스토리지 요청을 서비스한다(556). 인-서버 SAN 모듈(164)은 제 1 서버(112a)로부터 독립적으로 스토리지 요청을 서비스하고(556), 서비스 요청은 클라이언트(114,114a)로부터 수신된다.
*도 6은 본 발명에 따른 데이터 파이프라인을 이용한 솔리드-스테이트 스토리지 장치(102) 내의 데이터 관리를 위한 방법(600)의 다른 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(600)은 개시되고(602), 입력 버퍼(306)가 솔리드-스테이트 스토리지(110)에 기록될 하나 또는 그 이상의 데이터 및 메타데이터 세그먼트를 수신한다(604). 패킷타이저(302)는 헤더를 각각의 패킷에 추가하고, 상기 헤더는 일반적으로 객체 내의 패킷의 길이를 포함한다. 패킷타이저(302)는 입력 버퍼(306)에 저장된 하나 또는 그 이상의 세그먼트를 수신하고(604), 솔리드-스테이트 스토리지(110)을 위한 사이즈로 구성된 하나 또는 그 이상의 패킷을 생성함으로써 하나 또는 그 이상의 세그먼트를 패킷타이즈(606)하며, 여기서 각각의 패킷은 헤더 및 하나 또는 그 이상의 세그먼트로부터의 데이터를 포함한다.
ECC 생성기(304)는 패킷타이저(302)로부터 패킷을 수신하고, 패킷에 대한 하나 또는 그 이상의 ECC 블록을 생성한다(608). 기록 동기 버퍼(308)는 ECC 블록을 솔리드-스테이트 스토리지(110)로 기록하기 전에 해당 ECC 블록 내에 분산된 패킷을 버퍼링하고(610), 그리고 나서 솔리드-스테이트 스토리지 컨트롤러(104)는 클럭 도메인 차이를 고려한 적절한 시간에 데이터를 기록한다(612). 데이터가 솔리드-스테이트 스토리지(110)로부터 요청되는 경우, 하나 또는 그 이상의 데이터 패킷을 포함하는 ECC 블록은 독출 동기 버퍼(328)로 독출되고 버퍼링된다(614). 패킷의 ECC 블록은 스토리지 I/O 버스(210)을 통해 수신된다. 스토리지 I/O 버스(210)이 양방향성이므로, 데이터가 독출되면, 기록 동작, 명령 동작 등은 정지된다.
ECC 정정 모듈(322)은 독출 동기 버퍼(328)에 보류된 요청된 패킷의 ECC 블록을 수신하고 각각의 ECC 블록 내의 에러를 필요한대로 정정한다(616). ECC 정정 모듈(322)이 ECC 블록 내에 하나 또는 그 이상의 에러가 존재하고 상기 에러가 ECC 신드롬을 이용하여 정정가능하다고 결정하는 경우, ECC 정정 모듈(322)은 ECC 블록 내의 에러를 정정한다(616). ECC 정정 모듈(322)이 검출된 에러가 ECC를 사용하여 정정가능하지 않다고 결정하는 경우, ECC 정정 모듈(322)은 인터럽트를 전송한다.
디패킷타이저(324)는 ECC 정정 모듈(322)이 임의의 에러를 정정한 후 요청된 패킷을 수신하고(618), 각각의 패킷의 패킷 헤더를 확인하고 제거함으로써 패킷을 디패킷타이즈한다(618). 조정 모듈(326)은 디패킷타이징 후에 패킷을 수신하고, 원치않은 데이터를 제거하고, 데이터 패킷을 세그먼트 또는 객체를 요청하는 장치와 양립가능한 형태로 객체의 데이터 또는 메타데이터 세그먼트로서 재구성한다(620).출력 버퍼(330)는 디패킷타이징 후에 요청된 패킷을 수신하고 요청 장치로 전송하기 전에 패킷을 버퍼링하고(622), 상기 방법(600)은 종료한다(624).
도 7은 본 발명에 따른 뱅크 인터리브를 사용한 솔리드-스테이트 스토리지 장치(102) 내의 데이터를 관리하는 방법(700)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(600)은 개시되어(602), 뱅크 인터리브 컨트롤러(344)가 하나 또는 그 이상의 명령을 둘 또는 그 이상의 큐(410,412,414,416)로 전달한다(604). 일반적으로, 에이전트(402,404,406,408)는 명령 타입에 의해 명령을 큐(410,412,414,416)로 전달한다(604). 각각의 큐(410,412,414,416)의 세트는 각각의 명령 타입을 위한 큐를 포함한다. 뱅크 인터리브 컨트롤러(344)는 뱅크(214) 사이에서 큐(410,412,414,416)에 저장된 명령의 실행을 조정하여, 제 1 타입의 명령이 하나의 뱅크(214a)에서 실행되는 반면 제 2 타입의 명령이 제 2 뱅크(214b)에서 실행되도록 하고, 상기 방법(600)은 종료한다(608).
저장 공간 복구(Storage Space Recovery)
도 8은 본 발명에 따른 솔리드-스테이트 스토리지 장치(102) 내의 가비지 컬렉션을 위한 장치(800)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 장치(800)는 순차적(sequential) 저장 모듈(802), 스토리지 디비전(division) 선택 모듈(804), 데이터 복구 모듈(806), 및 스토리지 디비전 복구 모듈(808)을 포함하며, 이는 이하 기술된다. 다른 실시예에서, 상기 장치(800)는 가비지 마킹 모듈(810) 및 소거 모듈(812)를 포함한다.
상기 장치(800)는 데이터를 스토리지 디비전 내의 페이지에 순차적으로 기록하는 순차적 저장 모듈(802)을 포함한다. 패킷은 이들이 새로운 패킷 또는 변경된 패킷인지 여부에 따라 순차적으로 저장된다. 이 실시예의 변경된 패킷은 일반적으로 이들이 이전에 저장된 장소로 다시 기록되지 않는다. 일 실시예에서, 그리고 나서 순차적 저장 모듈(802)은 스토리지 디비전의 다음 페이지를 채우기 시작한다. 이는 스토리지 디비전이 가득 찰 때까지 지속된다.
바람직한 실시예에서, 순차적 저장 모듈(802)은 뱅크(뱅크-0(214a))의 스토리지 엘리먼트(예컨대 SSS 0.0 내지SSS M.0(216)) 내의 스토리지 기록 버퍼로의 패킷 기록을 시작한다. 스토리지 기록 버퍼가 가득찬 경우, 솔리드-스테이트 스토리지 컨트롤러(104)는 스토리지 기록 버퍼 내의 데이터가 뱅크(214a)의 스토리지 엘리먼트(216) 내의 지정된 페이지로 프로그램되도록 야기한다. 그리고 나서, 다른 뱅크(예컨대 뱅크-1(214b))가 선택되고 순차적 저장 모듈(802)은 뱅크(214b)의 스토리지 엘리먼트(218)의 스토리지 기록 버퍼로의 패킷 기록을 시작하며, 반면 상기 제 1 뱅크-0는 지정된 페이지를 프로그래밍한다. 뱅크(214b)의 스토리지 기록 버퍼가 가득 찬 경우, 스토리지 기록 버퍼의 컨텐츠는 각각의 스토리지 엘리먼트(218) 내의 다른 지정된 페이지로 프로그램된다. 이러한 프로세스는 하나의 뱅크(214a)가 페이지를 프로그래밍하는 동안, 다른 뱅크(214b)의 스토리지 기록 버퍼가 채워질 수 있으므로 효율적이다.
스토리지 디비전은 솔리드-스테이트 스토리지 장치(102) 내의 솔리드-스테이트 스토리지(110)의 일부를 포함한다. 일반적으로 스토리지 디비전은 소거 블록이다. 플래시 메모리의 경우, 소거 블록으로의 소거 동작은 각각의 셀을 충전함으로써 일(one)을 소거 블록 내의 모든 비트에 기록한다. 이는 장소가 모두 영(zero)으로 시작하는 프로그램 동작과 비교하여 긴 프로세스이고, 데이터가 기록되면서, 일부 비트는 영으로 기록된 셀을 방전함으로써 영으로 변경된다. 그러나, 솔리드-스테이트 스토리지(110)가 플래시 메모리가 아니거나 또는 소거 사이클이 독출 또는 프로그램과 같은 다른 동작과 유사한 시간이 걸리는 플래시 메모리를 구비하는 경우, 스토리지 디비전은 소거되도록 요구되지 않을 수 있다.
이하 사용된 바와 같이, 스토리지 디비전은 면적에서 소거 블록과 동등하지만, 소거될 수 있거나 소거되지 않을 수 있다. 여기서 소거 블록이 사용된 경우, 소거 블록은 스토리지 엘리먼트(예컨대 SSS 0.0(216a)) 내의 지정된 사이즈의 특정 영역을 언급할 수 있고, 일반적으로 특정 양의 페이지를 포함한다. "소거 블록"이 플래시 메모리와 함께 사용된 경우, 이는 일반적으로 기록되기 전에 소거되는 스토리지 디비전이다. "소거 블록"이 "솔리드-스테이트 스토리지"와 사용된 경우, 이는 소거될 수 있거나 또는 소거되지 않을 수 있다. 여기에 사용된 바와 같이, 소거 블록은 하나의 소거 블록 또는 스토리지 엘리먼트(예컨대 SSS 0.0 내지 SSS M.0(216a-n))의 각각의 열에 하나의 소거 블록이 구비된 소거 블록의 그룹을 포함할 수 있으며, 이는 또한 여기서 가상 소거 블록으로 언급될 수 있다. 가상 소거 블록과 결합된 논리적 구조를 언급하는 경우, 소거 블록은 여기서 LEB(Logical Erase Block)로서 언급될 수 있다.
일반적으로, 패킷은 프로세싱의 순서에 의해 순차적으로 저장된다. 일 실시예에서, 데이터 기록 파이프라인(106)이 사용된 경우, 순차적 저장 모듈(802)은 패킷이 데이터 기록 파이프라인(106)으로부터 나오는 순서로 저장된다. 이러한 순서는 유효한 데이터가 이하 설명되는 복구 동작 도중 스토리지 디비전으로부터 복구되어진 대로, 다른 스토리지 디비전으로부터 독출되어온 유효한 데이터의 패킷과 함께 혼합된 요청 장치(155)로부터 도달한 데이터 세그먼트 결과일 수 있다. 복구되고, 유효한 데이터 패킷을 데이터 기록 파이프라인(106)으로 리-라우팅(re-routing)하는 것은 도 3의 솔리드-스테이트 스토리지 컨트롤러(104)와 연관되어 상술된 가비지 컬렉터 바이패스(316)을 포함할 수 있다.
상기 장치(800)는 복구를 위한 스토리지 디비전을 선택하는 스토리지 디비전 선택 모듈(804)를 포함한다. 복구를 위한 스토리지 디비전의 선택은 데이터 기록, 복구된 스토리지 디비전을 스토리지 풀(pool)로 추가하는 것을 위해 순차적 저장 모듈(802)에 의한 스토리지 디비전의 재사용일 수 있으며, 또는 스토리지 디비전이 실패하거나, 신뢰성이 없거나, 리프레쉬되어야 하거나, 또는 스토리지 디비전이 스토리지 풀로부터 일시적으로 또는 영구적으로 꺼내는 다른 이유를 결정한 후 스토리지 디비전으로부터 유효한 데이터를 회복하는 것일 수 있다. 다른 실시예에서, 스토리지 디비전 선택 모듈(804)은 많은 양의 유효하지 않은 데이터를 구비한 스토리지 디비전 또는 소거 블록을 식별함으로써 복구를 위한 스토리지 디비전을 선택한다.
다른 실시예에서, 스토리지 디비전 선택 모듈(804)은 적은 양의 웨어(a low amount of wear)를 구비한 스토리지 디비전 또는 소거 블록을 식별함으로써 복구를 위한 스토리지 디비전을 선택한다. 예를 들어, 적은 양의 웨어를 구비한 스토리지 디비전 도는 소거 블록을 식별하는 것은 적은 양의 유효하지 않은 데이터, 적은 수의 소거 사이클, 낮은 비트 에러 레이트(bit error rate), 또는 낮은 프로그램 카운트(적은회수로 버퍼 내의 데이터의 페이지가 스토리지 디비전 내의 페이지로 기록되거나; 프로그램 카운트는 장치가 제조될 때로부터 측정되고, 스토리지 디비전이 마지막으로 소거된 때로부터 측정되고, 이들의 조합으로부터 측정될 수 있다)를 구비한 스토리지 디비전을 식별하는 것을 포함할 수 있다. 스토리지 디비전 선택 모듈(804)은 또한 상술한 또는 다른 파라미터의 임의의 조합을 사용하여, 적은 양의 웨어를 구비한 스토리지 디비전을 결정할 수 있다. 적은 양의 웨어를 구비한 스토리지 디비전을 결정함으로써 복구할 스토리지 디비전을 선택하는 것은 부족하게 사용된 스토리지 디비전을 발견하기 위해 요구될 수 있고, 웨어 레벨링(wear leveling) 등을 위해 복구될 수 있다.
다른 실시예에서, 스토리지 디비전 선택 모듈(804)은 많은 양의 웨어를 구비한 스토리지 디비전 또는 소거 블록을 식별함으로써 복구할 스토리지 디비전을 선택한다. 예를 들어, 많은 양의 웨어를 구비한 스토리지 디비전 또는 소거 블록을 식별하는 것은 많은 수의 소거 사이클, 높은 비트 에러 레이트, 복구 불가능한 ECC블록을 구비한 스토리지 디비전, 또는 높은 프로그램 카운트를 구비한 스토리지 디비전을 식별하는 것일 수 있다. 스토리지 디비전 선택 모듈(804)은 또한 상술한 또는 다른 파라미터의 임의의 조합을 사용하여 많은 양의 웨어를 구비한 스토리지 디비전을 결정할 수 있다. 높은 양의 웨어를 구비한 스토리지 디비전을 결정함으로써 복구할 스토리지 디비전을 선택하는 것은 과용된 스토리지 디비전을 발견하기 위해 요구될 수 있고, 소거 사이클 등을 사용하여 스토리지 디비전을 리프레쉬함으로써 복구될 수 있거나, 또는 서비스로부터 쓸모없는 스토리지 디비전을 회수하기 위해 요구될 수 있다.
상기 장치(800)는 복구를 위한 스토리지 디비전으로부터 유효한 데이터 패킷을 독출하고, 순차적 저장 모듈(802)에 의해 순차적으로 기록될 다른 데이터 패킷과 함께 유효한 데이터 패킷을 큐하고(queue), 인덱스를 순차적 저장 모듈(802)에 의해 기록된 유효한 데이터의 새로운 물리적 어드레스로 업데이트하는 데이터 복구 모듈(806)을 포함한다. 일반적으로, 인덱스는 객체의 데이터 객체 식별자를 데이터 객체로부터 도출된 패킷이 솔리드-스테이트 스토리지(110) 내에 저장되는 물리적 어드레스로 매핑하는 객체 인덱스이다.
일 실시예에서, 상기 장치(800)는 사용 또는 재사용을 위한 스토리지 디비전을 준비하고, 데이터 복구 모듈(806)이 스토리지 디비전으로부터 유효한 데이터를 카피하는 것을 완료한 후 순차적으로 데이터 패킷을 기록하기 위해, 순차적 저장 모듈(802)로 스토리지 디비전을 유효한 것으로 마크하는 스토리지 디비전 복구 모듈(808)을 포함한다. 다른 실시예에서, 상기 장치(800)는 복구를 위해 선택된 스토리지 디비전을 데이터 저장을 위해 무효로 마크하는 스토리지 디비전 복구 모듈(808)을 포함한다. 일반적으로 이는 많은 양의 웨어를 구비한 스토리지 디비전 또는 소거 블록을 식별하는 스토리지 디비전 선택 모듈(804)에 기인하며, 스토리지 디비전 또는 소거 블록이 신뢰성 있는 데이터 저장을 위해 사용될 상태가 아니기 때문이다.
일 실시예에서, 상기 장치(800)는 솔리드-스테이트 스토리지 장치(102)의 솔리드-스테이트 스토리지 장치 컨트롤러(202)에 구비된다. 다른 실시예에서, 상기 장치(800)는 솔리드-스테이트 스토리지 장치 컨트롤러(202)를 제어한다. 다른 실시예에서, 상기 장치(800)의 일부는 솔리드-스테이트 스토리지 장치 컨트롤러(202)에 구비된다. 다른 실시예에서, 데이터 복구 모듈(806)에 의해 업데이트되는 객체 인덱스는 또한 솔리드-스테이트 스토리지 장치 컨트롤러(202) 내에 위치된다.
일 실시예에서, 스토리지 디비전은 소거 블록이고, 상기 장치(800)는 데이터 복구 모듈(806)이 선택된 소거 블록으로부터 유효한 데이터 패킷을 카피한 후 그리고 스토리지 디비전 복구 모듈(808)이 소거 블록을 유효한 것으로 마크하기 전에, 복구를 위해 선택된 소거 블록을 소거하는 소거 모듈(810)을 포함한다. 플래시 메모리 및 독출 또는 기록 동작보다 더 긴 시간이 소요되는 소거 동작을 구비하는 다른 솔리드-스테이트 스토리지에서, 새로운 데이터를 기록하기 위해 데이터 블록을 유효한 것으로 마킹하기 전에 데이터 블록을 소거하는 것은 효율적인 동작을 위해 요구된다. 솔리드-스테이트 스토리지(110)가 뱅크(214)에 배열된 경우, 소거 모듈(810)에 의한 소거 동작은 하나의 뱅크에 실행될 수 있는 반면 다른 뱅크는 독출, 기록, 또는 다른 동작을 실행할 수 있다.
일 실시예에서, 상기 장치(800)는 데이터 패킷이 더 이상 유효하지 않음을 지시하는 동작에 응답하여 스토리지 디비전 내의 데이터 패킷을 무효로 식별하는 가비지 마킹 모듈(812)을 포함한다. 예를 들어, 데이터 패킷이 삭제되는 경우, 가비지 마킹 모듈(812)은 데이터 패킷을 무효로 식별할 수 있다. 독출-변경-기록 동작은 무효로 식별될 데이터 패킷을 위한 다른 방법이다. 일 실시예에서, 가비지 마킹 모듈(812)은 인덱스를 업데이트함으로써 데이터 패킷을 무효로 식별할 수 있다. 다른 실시예에서, 가비지 마킹 모듈(812)은 무효한 데이터 패킷이 삭제됨을 지시하는 다른 데이터 패킷을 저장함으로써 데이터 패킷을 무효로 식별할 수 있다. 이는 솔리드-스테이트 스토리지(110)에서, 데이터 패킷이 삭제된 정보를 저장하는 것은 객체 인덱스 재구성 모듈(262) 또는 유사한 모듈이 객체 인덱스를 무효한 데이터 패킷이 삭제됨을 지시하는 엔트리로 재구성하는 것을 허용하기 때문에 유리하다.
일 실시예에서, 상기 장치(800)는 전반적인 성능을 향상시키기 위한 플러쉬(flush) 명령 다음의 데이터의 가상 페이지의 리메인더(remainder)를재우기 위해 사용될 수 있으며, 여기서 플러쉬 명령은 기록 파이프라인(106)으로 흐르는 데이터를 기록 파이프라인(106)이 비워지고 모든 패킷이 영구적으로 비-휘발성 솔리드-스테이트 스토리지(110)으로 기록될 때까지 보류한다. 이는 요구되는 가비지 컬렉션의 양, 스토리지 디비전을 소거하기 위해 사용되는 시간, 및 가상 페이지를 프로그램하기 위해 요구되는 시간을 감소시키는 장점이 있다. 예를 들어, 플러쉬 명령은 오직 하나의 작은 패킷이 솔리드-스테이트 스토리지(100)의 가상 페이지로 기록되기 위해 준비되는 경우 수신될 수 있다. 이러한 거의 비어 있는 가상 페이지를 프로그래밍하는 것은 낭비된 공간을 즉시 복구시키는 필요를 야기할 수 있으며, 스토리지 디비전 내의 유효한 데이터가 불필요하게 가비지 수집되는 것을 야기하고, 순차적 저장 모듈(802)에 의한 기록을 위해 스토리지 디비전이 소거되고, 복구되고, 그리고 유효한 공간의 풀(pool)로 반환될 수 있다.
실제로 무효한 데이터 패킷을 소거하는 것보다 데이터 패킷을 무효로 마크하는 것은 상술한 바와 같이, 플래시 메모리 및 다른 유사한 저장장치에 대해 소거 동작이 많은 시간을 소요하기 때문에 보다 효율적이다. 상기 장치(800)에 기술된 바와 같이, 가비지 컬렉션 시스템이 솔리드-스테이트 스토리지(110) 내에서 자발적으로 동작하도록 허용하는 것은 소거 동작을 독출, 기록, 및 다른 빠른 동작으로부터 분리시키는 방법을 제공하여, 솔리드-스테이트 스토리지 장치(102)가 다른 많은 솔리드-스테이트 스토리지 시스템 또는 데이터 저장 장치보다 빠르게 동작할 수 있도록 한다.
도 9는 본 발명에 따른 스토리지 복구를 위한 방법(900)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(900)은 시작되고(902), 순차적 저장 모듈(802)이 순차적으로 데이터 패킷을 스토리지 디비전에 기록한다(904). 스토리지 디비전은 솔리드-스테이트 스토리지 장치(102) 내의 솔리드-스테이트 스토리지(110)의 일부이다. 일반적으로 스토리지 디비전은 소거 블록이다. 데이터 패킷은 객체로부터 도출되고, 데이터 패킷은 처리 순서에 의해 순차적으로 저장된다.
스토리지 디비전 선택 모듈(804)은 복구를 위한 스토리지 디비전을 선택하고(906), 데이터 복구 모듈(806)은 복구를 위해 선택된 스토리지 디비전으로부터 유효한 데이터 패킷을 독출한다(908). 일반적으로 유효한 데이터 패킷은 소거 또는 삭제를 위해 마크되지 않은 데이터 패킷 또는 유효하거나 "우수한" 데이터로 마킹되고 고려되는 다른 일부 무효한 데이터이다. 데이터 복구 모듈(806)은 순차적 저장 모듈(802)에 의해 순차적으로 기록되도록 스케쥴된 다른 데이터 패킷과 함게 유효한 데이터 패킷을 큐한다(910). 데이터 복구 모듈(806)은 인덱스를 순차적 저장 모듈(802)에 의해 기록된 유효한 데이터의 새로운 물리적 어드레스로 업데이트한다(912). 인덱스는 데이터 패킷의 물리적 어드레스의 객체 식별자로의 매핑을 포함한다. 데이터 패킷은 솔리드-스테이트 스토리지(110)에 저장된 것들이며, 객체 식별자는 데이터 패킷에 대응한다.
데이터 복구 모듈(806)이 유효한 데이터를 스토리지 디비전으로부터 카피하는 것을 완료한 후, 스토리지 디비전 복구 모듈(808)은 복구를 위해 선택된 스토리지 디비전을 순차적으로 데이터 패킷을 기록하기 위해 순차적 저장 모듈(802)로 유효한 것으로 마크하고(914) 상기 방법(900)은 종료한다(916).
빈 데이터 세그먼트 지시어(Empty Data Segment Directive)
일반적으로, 데이터가 더 이상 유효하지 않으면 이는 소거될 수 있다. 많은 파일 시스템에서, 소거 명령은 파일 시스템 내의 디렉토리 엔트리를 삭제하는 반면 데이터를 포함하는 저장 장치 내의 장소에 데이터를 남긴다. 일반적으로, 데이터 저장 장치는 이러한 타입의 소거 동작에 관여하지 않는다. 소거 데이터의 다른 방법은 데이터 저장 장치에 영, 일, 또는 다른 널 데이터 문자를 기록하여, 실제로 소거된 파일을 교체하는 것이다. 그러나, 이는 오버라이트되는 데이터가 전송되면서 유용한 대역폭이 사용되기 때문에 비효율적이다. 또한, 저장 장치 내의 저장 공간은 무효한 데이터를 오버라이트하기 위해 사용되는 데이터에 의해 사용된다.
여기에 기술되는 솔리드-스테이트 스토리지 장치(102)와 같은 일부 저장 장치는 랜덤 액세스 저장 장치가 아니므로, 이전에 저장된 데이터의 업데이트는 기존의 데이터를 오버라이트하지 않는다. 데이터를 이러한 장치에 일의 스트링 또는 영의 스트링으로 오버라이트하도록 시도하는 것은 기존 데이터를 오버라이트하는 요구되는 목적을 만족하지 못한 채 유용한 저장 공간을 차지하게 된다. 솔리드-스테이트 스토리지 장치(102)와 같은 이러한 비-랜덤 액세스 장치에 대해, 클라이언트(114)는 일반적으로 데이터를 오버라이트하여 소거하는 기능을 구비하지 않는다.
반복된 문자의 스트링 또는 문자 스트링을 수신하는 경우, 수신된 데이터는 매우 압축적이지만, 일반적으로 압축은 저장 장치로의 전송 전에 파일 시스템에 의해 수행된다. 일반적인 저장 장치는 압축된 데이터 및 압축되지 않은 데이터를 구별할 수 없다. 저장 장치는 또한 소거된 파일을 독출하는 명령을수신할 수 있어, 저장 장치는 영, 일, 또는 널 문자의 스트림을 요청 장치로 전송할 수 있다. 또 다시, 대역폭은 소거된 파일을 나타내는 데이터를 전송하도록 요구된다.
전술한 바와 같이, 데이터가 소거되는 지시어(directive)를 수신하여, 저장 장치가 빈 데이터 세그먼트(empty data segment) 또는 반복된 문자 또는 문자 스트링을 구비한 데이터를 나타내는 데이터 세그먼트 토큰을 저장할 수 있는 장치, 시스템, 및 방법에 대한 요구가 존재하는 것은 분명하다. 상기 장치, 시스템 및 방법은 또한 기존 데이터를 소거하여, 그 결과 사용된 저장 장치는 작은 데이터 세그먼트 토큰을 포함할 수 있다. 장치, 시스템 및 방법은 종래의 문제점의 일부 또는 모두를 해결하는 방안을 제시한다.
도 10은 본 발명에 따른 토큰 지시어(token directive)를 생성하는 장치를 구비하는 시스템(1000)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 장치는 토큰 지시어 생성 모듈(1002), 토큰 지시어 전송 모듈(1004), 독출 리시버 모듈(1006), 독출 요청 전송 모듈(1008), 독출 토큰 지시어 리시버 모듈(1010), 요청 클라이언트 응답 모듈(1012), 및 데이터 세그먼트 재생성 모듈(1014)을 포함하며, 이는 이하 기술된다. 일 실시예에서, 상기 장치는 스토리지 컨트롤러(152) 및 데이터 저장 장치(154)를 구비한 저장 장치(150)에 연결된 서버(112) 내에 구비되며, 이는 실질적으로 상술한 바와 유사하다.
일 실시예에서, 상기 장치는 토큰 지시어로 스토리지 요청(storage request)을 생성하는 토큰 지시어 생성 모듈(1002)을 포함한다. 토큰 지시어는 데이터 세그먼트 토큰을 저장 장치(150)에 저장시키는 요청을 포함한다. 토큰 지시어는 저장 장치(150)로 전송되고 데이터 세그먼트 토큰이 제 자리에 전송되지 않은 경우, 데이터 세그먼트로서 저장되는 반복되고, 동일한 문자의 연속 또는 반복되고, 동일한 문자 스트링의 연속을 대체하도록 의도된다. 일 실시예에서, 반복되고 동일한 문자의 연속은 데이터 세그먼트가 비어 있음을 지시한다. 예를 들어, 반복되고 동일한 문자의 연속은 영 또는 일일 수 있고, 영 또는 일로 채워지는 데이터 세그먼트는 비어있는 것으로 해석될 수 있다.
토큰 지시어는 적어도 데이터 세그먼트 식별자 및 데이터 세그먼트 길이를 포함한다. 데이터 세그먼트 식별자는 일반적으로 객체 ID, 파일 이름, 또는 저장 장치 상에 반복되고 동일한 문자 또는 문자 스트링을 저장하도록 탐색하는(seeking) 파일 시스템, 애플리케이션, 서버(112) 등에 알려진 다른 식별자이다. 데이터 세그먼트 길이는 일반적으로 반복되고, 동일한 문자 또는 문자 스트링의 연속에 의해 요구되는 저장 공간이다. 데이터 세그먼트 토큰 및 토큰 지시어는 일반적으로 데이터 세그먼트의 데이터, 예컨대 반복되고 동일한 문자의 연속을 포함하지 않는다.
그러나, 토큰 지시어는 반복되고 동일한 문자 또는 문자 스트링의 적어도 하나의 예와 같은 데이터 세그먼트 토큰을 형성하는 다른 적절한 정보를 포함할 수 있다. 토큰 지시어는 또한 메타데이터, 예컨대 데이터 세그먼트 위치, 파일 시스템으로부터의 어드레스, 데이터 세그먼트에 대응하는 데이터 저장 장치 상의 장소 등을 포함할 수 있다. 당업자는 토큰 지시어에 포함될 수 있는 다른 정보를 파악할 것이다. 일 실시예에서, 지시어 생성 모듈(1002)은 토와 함께 데이터 세그먼트 토큰을 생성한다.
일 실시예에서, 토큰 지시어 생성 모듈(1002)는 기존 데이터를 저장 장치(150)에 오버라이트하는 요청에 응답하여 토큰 지시어 및 안전 소거 명령(secure erase command) 둘 모두를 생성한다. 기존 데이터는 토큰 지시어 내의 데이터 세그먼트 식별자로서 동일한 데이터 세그먼트 식별자로 저장 장치 상에 식별된 데이터를 포함한다. 일반적으로, 데이터를 오버라이트하는 요청은 단지 데이터를 무효 또는 가비지로 마크하는 것으로 불충분하도록 전송되어, 데이터로의 포인터(pointer)를 삭제하거나 다른 일반적인 삭제 동작을 하지만, 데이터가 복구될 수 없는 방법으로 오버라이트되도록 요청된다. 예를 들어, 데이터를 오버라이트하는 요청은 데이터가 민감한 정보이고 보안적 이유를 위해 파괴되어야하는 것이 요구될 수 있다.
안전 소거 명령은 저장 장치(150)가 기존 데이터를 오버라이트하도록 지시하여, 기존 데이터가 복구 불가능하도록 한다. 그리고 나서 저장 장치(150)는 오버라이트, 복구, 소거 등 뿐만 아니라 데이터 세그먼트 토큰의 생성도 한다. 그 결과, 기존 데이터는 복구 불가능하고 데이터 세그먼트 토큰은 저장 장치(150)에 저장되며, 이는 일반적으로 기존 데이터보다 더 적은 저장 공간을 차지한다.
더한 실시예에서, 상기 장치는 저장 장치 상의 기존 데이터가 문자로 오버라이트되어 기존 데이터가 복구 불가능하다는 확인을 수신하는 소거 확인 모듈(1016)을 포함한다. 확인은 요청 장치 또는 클라이언트(114)로 전달될 수 있고, 기존 데이터가 복구 불가능한 상태에 있음을 검증하도록 사용될 수 있다. 다른 실시예에서, 안전 소거 명령은 저장 장치(150)가 기존 데이터를 특정 문자 또는 문자 스트링으로 오버라이트하도록 지시할 수 있거나 또는 실행 명령은 다수 번 실행될 수 있다. 당업자는 기존 데이터가 복구 불가능함을 보증하는 하나 또는 그 이상의 안전 소거 명령을 구성하는 다른 방법을 파악할 것이다.
데이터는 암호화될 수 있고, 그리고 나서 저장 장치(150)에 저장될 수 있으며, 여기서 암호화는 데이터 저장과 함께 저장 장치(150)에 의해 수신된 암호화 키를 사용하여 달성된다. 기존 데이터가 저장되기 전에 이러한 수신된 암호화 키를 사용하여 암호화되는 경우, 다른 실시예에서, 토큰 지시어 생성 모듈(1002)은 기존 데이터를 오버라이트하는 요청을 수신함에 응답하여 토큰 지시어의 생성과 함께 암호화 소거 명령을 생성한다. 암호화 소거 명령은 기존 데이터의 저장에 사용된 암호화 키를 소거하여, 암호화 키는 복구 불가능하게 된다.
일 실시예에서, 암호화 키의 소거는 요청 장치로부터 암호화 키를 소거하는 단계를 포함한다. 다른 실시예에서, 암호화 키의 소거는 서버, 키 볼트(key vault), 또는 암호화 키가 저장된 다른 장소로부터 암호화 키를 소거하는 단계를 포함한다. 암호화 키의 소거는 암호화 키를 다른 데이터 또는 문자의 연속으로 대체하는 단계를 포함할 수 있어, 암호화 키는 어떠한 방법으로도 복구될 수 없다. 암호화 키의 소거는 일반적으로 저장 장치(150) 상의 기존 데이터를 복구 불가능하도록 만들며, 여기서 암호화 루틴은 기존 데이터를 복호화하는 시도를 방지하기에 충분히 강건한 기존 데이터를 암호화하도록 사용된다. 기존 데이터를 오버라이트하는 요청은 안전상의 이유로 데이터가 오버라이트되는 안전 소거 지시어, 데이터를 오버라이트하여 데이터를 소거하도록 하는 요청, 기존 데이터를 반복되고 동일한 문자 또는 문자 스트링으로 교체하도록 추구하는 요청 등일 수 있다. 일 실시예에서, 안전 소거 지시어는 장치가 암호화 키를 안전하게 소거하고 기존 데이터를 안전하게 소거하도록 한다. 일 실시예에서, 암호화 키의 소거는 저장 장치의 데이터의 안전한 소거가 가비지 컬렉션 프로세스가 저장 공간 복구 프로세스의 일부로서 데이터를 소거할 때까지 연기되도록 허용할 수 있다. 당업자는 암호화 키를 소거하는 다른 방법 및 기존 데이터를 오버라이트하는 요청을 수신하는 다른 방법을 파악할 것이다.
일 실시예에서, 토큰 지시어는 데이터 세그먼트 토큰을 포함하고, 토큰 지시어 전송 모듈(1004)은 데이터 세그먼트 토큰을 토큰 지시어와 함께 전송한다. 다른 실시예에서, 토는 데이터 세그먼트 토큰을 포함하지 않고, 데이터 세그먼트 토큰을 생성하기 위한 저장 장치(150)에 대한 명령을 포함한다. 이 실시예에서, 토큰 지시어 전송 모듈(1004)은 토큰 지시어를 데이터 세그먼트 토큰를 생성하기 위한 명령과 함께 전송하지만, 데이터 세그먼트 토큰을 전송하지는 않는다.
상기 장치는 토큰 지시어를 저장 장치(150)로 전송하는 토큰 지시어 전송 모듈(1004)을 포함한다. 일반적으로, 토큰 지시어 전송 모듈(1004)은 토큰 지시어를 스토리지 요청의 일부로서 전송한다. 스토리지 요청은 객체 요청, 데이터 요청, 또는 당업자에게 알려진 다른 형태로 구성될 수 있다. 토큰 지시어 생성 모듈(1002)이 안전 소거 지시어를 생성한 경우, 토큰 지시어 전송 모듈(1004)은 안전 소거 지시어를 저장 장치(150)로 전송한다. 토큰 지시어 생성 모듈(1002)이 암호화 키 소거 명령을 생성하는 경우, 암호화 키 소거 명령은 필요하게 명령을 실행할 다른 장치로 전송된다.
일 실시예에서, 토큰 지시어 전송 모듈(1004)은 토큰 지시어를 데이터 세그먼트 토큰을 포함하지 않고 전송한다. 이 실시예에서, 토큰 지시어는 저장 장치(150)가 데이터 세그먼트 토큰을 생성하도록 하는 지시 및 정보를 포함한다. 다른 실시예에서, 토큰 지시어 전송 모듈(1004)은 데이터 세그먼트 토큰을 포함하는 토큰 지시어를 전송한다. 이 실시예에서, 저장 장치(150)는 토큰 지시어와 함께 수신된 데이터 세그먼트 토큰이 데이터 세그먼트를 나타내고 데이터 세그먼트 토큰를 저장하도록 적절한 동작을 취해, 단지 데이터 세그먼트 토큰이 원본 데이터로서 저장되는 것보다 데이터 세그먼트 토큰이 데이터 세그먼트를 나타내는 것을 인식할 수 있다.
특정 실시예에서, 상기 장치는 저장 장치(150)로부터 데이터 세그먼트를 독출하는 스토리지 요청을 수신하는 독출 리시버 모듈(1006) 및 스토리지 요청을 저장 장치(150)로 전송하는 독출 요청 전송 모듈(1008)을 포함한다. 일반적으로, 스토리지 요청은 요청 클라이언트(114), 예컨대 외부 클라이언트(114), 서버(112)에서 구동되는 애플리케이션 또는 파일 서버와 같은 서버(112) 내부에 구비된 클라이언트(114) 등으로부터 수신된다. 당업자는 독출 리시버 모듈(1006)이 스토리지 요청을 수신할 수 있는 요청 클라이언트(114)로서의 다른 장치 및 소프트웨어 기능을 파악할 것이다.
스토리지 요청은 토큰 지시어 전송 모듈(1004)에 의해 저장 장치(150)로 전송되는 토큰 지시어에 저장되도록 요청되는 데이터 세그먼트 토큰에 대응하는 데이터 세그먼트를 독출하는 요청을 포함한다. 일 실시예에서, 요청 클라이언트(114)는 데이터 세그먼트가 데이터 세그먼트 토큰의 형태로 저장된 것을 인식하지 못한다. 다른 실시예에서, 요청 장치는 데이터 세그먼트가 데이터 세그먼트 토큰로서 저장된 것을 인식하지만, 데이터 세그먼트 토큰에 저장된 정보에 대해서는 인식하지 못한다.
특정 실시예에서, 상기 장치는 또한 저장 장치로부터 요청된 데이터 세그먼트 토큰에 대응하는 메시지를 수신하는 독출 토큰 지시어 리시버 모듈(1010)을 포함하며, 여기서 메시지는 적어도 데이터 세그먼트 식별자 및 데이터 세그먼트 길이를 포함한다. 메시지는 일반적으로 데이터 세그먼트의 데이터를 포함하지 않는다. 메시지는 또한 데이터 세그먼트 토큰에 저장된 다른 정보, 예컨대 데이터 세그먼트 위치 또는 반복되고 동일한 문자 또는 문자 스트링을 더 포함할 수 있다. 특정 실시예에서, 상기 장치는 저장 장치(150)로부터 수신된 메시지로부터 형성된 응답을 요청 클라이언트(113)으로 전송하는 요청 클라이언트 응답 모듈(1012)을 포함한다.
일 실시예에서, 독출 토큰 지시어 리시버 모듈(1010)은 또한 메시지 내에서, 기존 데이터가 문자로 오버라이트되어 기존 데이터가 복구 불가능하다는 확인을 수신하며, 여기서 기존 데이터는 기존에 저장 장치에 저장되었고 메시지 내에 수신된 데이터 세그먼트 토큰으로부터 동일한 데이터 세금너트 식별자로 참조된다. 상기 확인은 또한 데이터 세그먼트를 독출하는 임의의 스토리지 요청으로부터 독립적으로 저장 장치(150)로부터 수신될 수 있다.
다른 실시예에서, 요청 클라이언트(114)가 데이터 세그먼트를 요구하는 경우, 상기 장치는 메시지에 포함된 정보를 사용하여 데이터 세그먼트의 데이터를 재구성하는 데이터 세그먼트 재구성 모듈(1014)을 포함한다. 이 경우, 요청 장치로 전송된 응답은 재구성된 데이터 세그먼트를 포함한다. 다른 실시예에서, 요청 클라이언트로 전송된 응답은 저장 장치(150)로부터 수신된 메시지에 포함된 정보를 포함한다. 그리고 나서 요청 클라이언트(114)는 데이터 세그먼트를 재구성하거나 또는 다른 방법으로 정보를 사용할 수 있다. 다른 실시예에서, 메시지는 데이터 세그먼트 토큰를 포함한다. 데이터 세그먼트 토큰은 요청 클라이언트(114)로 전달하기 전에 데이터 세그먼트를 재구성하도록 데이터 세그먼트 재구성 모듈(1014)에 의해 사용되거나, 또는 요청 클라이언트 응답 모듈(1012)은 단순히 데이터 세그먼트 토큰을 전달할 수 있다.
일 실시예에서, 토큰 지시어를 구비한 스토리지 요청은 또한 저장 장치(150) 상의 저장 공간을 보존하는 요청을 포함하며, 여기서 요청되고 보유된 저장 공간은 데이터 세그먼트 길이와 거의 동일한 양의 저장 공간이다. 다른 실시예에서, 저장 공간 보존 요청은 데이터 세그먼트 길이와 다른 양의 저장 공간이다. 예를 들어, 저장 장치(150)가 솔리드-스테이트 스토리지 장치(102)인 경우, 솔리드-스테이트 스토리지 장치(102)는 하드 드라이브 또는 다른 롱-텀(long-term), 비싸지 않은 스토리지와 연결될 수 있는 반면, 솔리드-스테이트 스토리지(110)는 롱-텀 스토리지를 위한 캐시(cache)로 구성된다. 스토리지를 보존하는 요청은 데이터를 솔리드-스테이트 스토리지 장치(102)로 기록하는 것에 대비하여 솔리드-스테이트 스토리지 장치(102)가 캐시의 일부를 롱-텀 스토리지로 플러시(flush)하는 것을 야기할 수 있다. 당업자는 저장 공간을 보존하는 요청이 요구되는 다른 상황을 파악할 것이다.
일 실시예에서, 장치는 독출 리시버 모듈(1006), 독출 요청 전송 모듈(1008), 토큰 지시어 독출 리시버 모듈(1010), 및 요청 클라이언트 응답 모듈(1012)을 제공할 수 있으며, 이는 상술한 바와 실질적으로 유사하다. 실시예에서, 모듈(1006-1012)은 토큰 생성 모듈(1002) 또는 토큰 지시어 전송 모듈(1004)을 포함하는 장치로부터 독립적일 수 있다. 일 실시예에서, 상기 장치는 데이터 세그먼트 재생성 모듈(1014)를 포함하며, 이는 상술한 데이터 세그먼트 재생성 모듈(1014)와 실질적으로 유사하다.
도 11은 본 발명에 따른 토큰 지시어를 생성하고 전송하는 방법(1100)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(1100)은 개시하여(1102) 토큰 지시어 생성 모듈(1002)가 토큰 지시어를 사용하여 스토리지 요청을 생성하고(1104), 여기서 토큰 지시어는 데이터 세그먼트 토큰을 저장 장치(150)로 저장하는 요청을 포함한다. 토큰 지시어 전송 모듈(1004)은 토큰 지시어를 저장 장치(150)으로 전송하고(1106), 상기 방법(1100)은 종료한다(1108). 일 실시예에서, 스토리지 요청은 데이터 세그먼트 토큰를 저장하는 토큰 지시어를 포함하며, 여기서 스토리지 요청은 데이터 세그먼트의 데이터를 필수적으로 갖지 않는다. 다른 실시예에서, 스토리지 요청은 데이터 세그먼트로부터의 데이터를 포함한다. 바람직한 실시예에서, 소프트웨어 애플리케이션은 토큰 지시어를 사용하여 스토리지 요청을 생성하여, 데이터 세그먼트의 생성을 방지한다. 다른 실시예에서, 소프트웨어 애플리케이션은 토큰 지시어의 생성을 요청한다.
도 12는 본 발명에 따른 데이터 세그먼트 토큰을 독출하는 방법(1200)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(1200)은 개시하여(1202), 독출 리시버 모듈(1006)이 저장 장치(150)로부터의 데이터 세그먼트를 요청 클라이언트(114)로부터 독출하는 스토리지 요청을 수신한다(1204). 독출 요청 전송 모듈(1008)은 스토리지 요청을 저장 장치(150)로 전송한다(1206).
독출 토큰 지시어 리시버 모듈(1008)은 요청된 데이터 세그먼트 토큰에 대응하는 메시지를 저장 장치(150)로부터 수신하며, 여기서 메시지는 적어도 데이터 세그먼트 식별자 및 데이터 세그먼트 길이를 포함한다. 메시지는 실질적으로 데이터 세그먼트의 데이터를 갖지 않는다. 요청 클라이언트 응답 모듈(1012)은 저장 장치(150)로부터 수신된 메시지로부터 형성된 응답을 요청 장치로 전송하고(1210), 상기 방법(1200)은 종료한다(1212).
도 13은 본 발명에 따른 데이터 세그먼트 토큰를 관리하는 장치를 구비하는 시스템(1300)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 시스템(1300)은 기록 요청 리시버 모듈(1302) 및 데이터 세그먼트 토큰 저장 모듈(1304)을 구비하는 장치를 포함하고, 다양한 실시예에서 토큰 지시어 생성 모듈(1306), 독출 요청 리시버 모듈(1308), 데이터 세그먼트 토큰 독출 모듈(1310), 데이터 세그먼트 토큰 전송 모듈(1314) 및 데이터 세그먼트 전송 모듈(1316)을 구비한 독출 요청 응답 모듈(1312), 데이터 세그먼트 재구성 모듈(1318), 소거 확인 모듈(1322)을 구비한 안전 소거 모듈(1320), 및 저장 공간 보존 모듈(1324)를 포함하며, 이는 이하 기술된다. 상기 시스템(1300)은 스토리지 컨트롤러(152) 및 데이터 저장 장치(154)를 구비한 저장 장치(150)를 포함하며, 이는 상술한 바와 실질적으로 유사하다. 상기 시스템(1300)은 저장 장치(150)와 통신하는 요청 장치(1326)를 포함하며, 이는 이하 기술된다.
도시된 실시예에서, 모듈(1302-1324)은 저장 장치(150) 또는 스토리지 컨트롤러(152) 내에 포함된다. 다른 실시예에서, 하나 또는 그 이상의 모듈(1302-1324)의 적어도 일부는 저장 장치(150)의 외부에 위치된다. 더한 실시예에서, 요청 장치(1326)는 모듈(1302-1324)의 일부를 드라이버, 소프트웨어, 또는 하나 또는 그 이상의 모듈(1302-1324)의 다른 기능을 포함한다. 예를 들어, 토큰 생성 모듈(1306) 및 데이터 세그먼트 재구성 모듈(1318)은 요청 장치(1326)에 도시된다. 당업자는 모듈(1302-1324)의 기능성을 분산시키고 구현하는 다른 방법을 파악할 것이다.
상기 장치는 요청 장치(1326)으로부터 스토리지 요청을 수신하며, 여기서 스토리지 요청은 데이터 세그먼트를 저장 장치(150) 내에 저장하는 요청을 포함한다. 데이터 세그먼트는 반복되고, 동일한 문자 또는 문자 스트링의 연속을 포함한다. 일반적으로, 반복되고, 동일한 문자의 연속은 데이터 세그먼트가 비어 있음을 의미한다. 이는 특히 반복되고 동일한 문자의 연속이 일 또는 영인 경우 사실이다. 상기 장치는 데이터 세그먼트 토큰을 저장 장치(150)에 저장하는 데이터 세그먼트 토큰 저장 모듈(1304)을 포함한다. 데이터 세그먼트 토큰은 적어도 데이터 세그먼트 식별자 및 데이터 시그멘트 길이를 포함한다. 데이터 세그먼트 토큰은 실질적으로 데이터 세그먼트의 데이터를 갖지 않는다.
데이터 세그먼트 토큰은 많은 형태로 저장될 수 있다. 일 실시예에서, 데이터 세그먼트 토큰은 인덱스 내의 엔트리를 포함하며, 여기서 인덱스는 저장 장치(150)에 저장된 정보 및 데이터에 대응한다. 예를 들어, 인덱스는 도 2에 도시된 장치(200)과 관련하여 기술된 객체 인덱스일 수 있다. 인덱스는 또한 파일 시스템 인덱스, 블록 저장 인덱스, 또는 당업자에게 알려진 다른 인덱스일 수 있다. 다른 실시예에서, 데이터 세그먼트 토큰은 저장 장치(150)에 저장된 메타데이터 또는 그러한 형태이다. 다른 실시예에서, 데이터 세그먼트 토큰은 저장 장치에 메타데이터로서 저장되고 인덱스 내의 엔트리를 포함한다. 당업자는 데이터 세그먼트 토큰을 저장하는 다른 방법을 파악할 것이다.
일 실시예에서, 스토리지 요청은 데이터 세그먼트 토큰을 저장하는 토큰 지시어를 포함하며, 여기서 스토리지 요청은 데이터 세그먼트의 데이터를 갖지 않는다. 토큰 지시어는 데이터 세그먼트 토큰 또는 데이터 세그먼트 토큰을 생성하는 명령을 포함할 수 있다. 토큰 지시어가 데이터 세그먼트 토큰을 포함하지 않으면, 데이터 세그먼트 토큰 저장 모듈(1304)은 토큰 지시어 내의 정보로부터 데이터 세그먼트 토큰을 생성한다. 토큰 지시어가 데이터 세그먼트 토큰을 포함하는 경우, 데 저장 모듈(1304)은 데이터 세그먼트 토큰을 토큰 지시어 내의 데이터 세그먼트 식별자에 의해 식별되는 데이터 세그먼트를 나타내는 데이터 구조로서 인식하고, 데이터 세그먼트 토큰을 적절하게 저장한다.
일반적으로, 데이터 세그먼트 토큰 저장 모듈(1304)이 데이터 세그먼트 토큰을 인식하면, 데이터 세그먼트 토큰은 저장 장치(150)에 저장된 다른 데이터로부터 임의의 방법을 사용하여 구별된다. 예를 들어, 요청 장치(1326)는 단지 데이터를 압축하고 압축된 객체, 파일 또는 데이터 세그먼트를 전송하여, 저장 장치(150)는 압축된 데이터 세그먼트를 다른 스토리지 요청의 방식에 의해 수신된 다른 데이터로부터 구별하지 않도록 한다.
데이터 세그먼트 토큰 저장 모듈(1304)이 수신된 데이터 세그먼트 토큰이 데이터 세그먼트 토큰임을 인식한 경우, 데이터 세그먼트 토큰 저장 모듈(1304)은 독출된 경우, 데이터 세그먼트 토큰보다는 데이터 세그먼트로서 나타날 수 있는 방법으로 데이터 세그먼트 토큰를 저장할 수 있다. 당업자는 수신된 데이터 세그먼트 토큰이 데이터 세그먼트가 아닌 데이터 세그먼트 토큰임을 인식한 후, 데이터 세그먼트 토큰 저장 모듈(1304)이 데이터 세그먼트 토큰을 저장할 수 있는 다른 방법을 파악할 것이다.
다른 실시예에서, 스토리지 요청은 데이터 세그먼트로부터의 데이터를 포함한다. 이 실시예에서, 상기 장치는 데이터 세그먼트로부터 데이터 세그먼트 토큰을 생성하는 토큰 생성 모듈(1306)을 포함하며, 여기서 데이터 세그먼트 토큰은 데이터 세그먼트를 저장하는 스토리지 요청에 응답하여 생성된다. 더한 실시예에서, 토큰 생성 모듈(1306)은 요청 장치(1326)에 구비되며, 드라이버의 형태로 구비될 수 있다.
일 실시예에서, 상기 장치는 기존 데이터를 문자로 오버라이트하여, 기존 데이터를 복구 불가능하도록 하는 안전 소거 모듈(1320)을 포함하며, 여기서 기존 데이터는 스토리지 요청에서 식별된 데이터 세그먼트로서 동일한 데이터 세그먼트 식별자로 식별된 저장 장치 상에 기존에 저장된 데이터 세그먼트의 데이터를 포함한다. 이 실시예에서, 데이터 세그먼트 토큰은 데이터 세그먼트 식별자 및 데이터 세그먼트 길이와 함께 저장되고, 데이터 세그먼트 토큰에 저장된 동일한 데이터 세그먼트 식별자에 의해 식별된 기존 데이터는 기존 데이터를 오버라이트함으로써 소거된다. 일반적으로 기존 문자는 영, 일, 또는 다른 문자 스트링에 의해 오버라이트되어 기존 데이터는 파괴되고 복구 불가능하게 된다.
더한 실시예에서, 안전 소거 모듈은 또한 기존 데이터가 오버라이트됨을 지시하는 메시지를 전송하는 소거 확인 모듈(1322)를 포함한다. 일반적으로 메시지는 요청 장치(1326)로 전송된다. 소거 확인 메시지는 안전 소거 모듈(1320)이 기존 데이터를 오버라이트한 후에 전송된다. 메시지는 스토리지 요청과 동일한 트랜잭션(transaction) 또는 상이한 트랜잭션으로 전송될 수 있다.
다른 실시예에서, 안전 소거 모듈(1320)은 기존 데이터를 저장 공간 복구 동작 도중 오버라이트한다. 예를 들어, 저장 장치(150)가 상술한 바와 같이, 솔리드-스테이트 스토리지 장치(102)인 경우, 저장 공간 복구 동작은 도 8에 도시된 장치(800)과 관련하여 기술된 가비지 컬렉션과 관련될 수 있다. 그러나, 기존 데이터를 오버라이트하는 요청과 연관된 저장 공간 복구 동작은 일반적으로 촉진시켜서, 임의의 확인 메시지가 소거 확인 모듈(1322)에 의해 전송되기 전에, 기존 데이터가 저장된 저장 장소가 필수적으로 복구되도록 한다. 일 실시예에서, 기존 데이터는 마크되거나 또는 안전 소거가 요청되었음을 지시하도록 식별된다. 확인 메시지는 일반적으로 소거를 위해 마크된 기존 데이터가 오버라이트되고 복구 불가능하게 될 때까지 전송되지 않는다. 다른 실시예에서, 안전 소거 모듈(1320)은 추후 저장 공간 복구를 위해 기존 데이터를 무효로 마크한다. 다른 실시예에서, 안전 소거는 기존 데이터가 무효임을 지시하고 데이터가 추후 저장 공간 복구 도중 오버라이트될 때까지 이 데이터로의 액세스를 방지하도록 인덱스를 업데이트한다.
일 실시예에서, 보안 소거 모듈(1320)은 데이터 세그먼트 토큰이 저장된 각각의 시간마다 기존 데이터를 오버라이트한다. 다른 실시예에서, 스토리지 요청은 구체적으로 기존 데이터를 오버라이트하는 요청을 포함하고, 안전 소거 모듈(1320)은 기존 데이터를 오버라이트하는 요청에 응답하여 기존 데이터를 오버라이트한다. 다른 실시예에서, 안전 소거 모듈(1320)은 기존 데이터가 소거되어 수반하는 독출이 소거를 지시하도록 하는 확인에 관한 메타데이터 정보를 저장한다.
다른 실시예에서, 안전 소거가 수신되지 않은 경우, 기존 데이터는 삭제된다. 일 실시예에서, 데이터의 삭제는 인덱스 엔트리, 어드레스 등의 삭제를 포함한다. 바람직한 실시예에서, 데이터 세그먼트 토큰이 저장된 경우, 해당 기존의 데이터는 무효로 마크되거나 스토리지 복구를 위해 준비된다. 데이터는 추후 스토리지 복구 동작, 가비지 컬렉션 동작 등에서 복구될 수 있다.
특정 실시예에서, 상기 장치는 데이터 세그먼트를 독출하는 스토리지 요청을 수신하는 독출 요청 리시버 모듈(1308), 스토리지 요청에 의해 요청된 데이터 세그먼트에 대응하는 데이터 세그먼트 토큰을 독출하는 데이터 세그먼트 토큰 독출 모듈(1310), 및 응답을 요청 장치(1326)로 전송하는 독출 요청 응답 모듈(1312)를 포함한다. 응답은 요청된 데이터 세그먼트에 대응하는 데이터 세그먼트 토큰을 사용하여 생성된다.
일 실시예에서, 데이터 세그먼트를 독출하는 스토리지 요청은 스토리지 요청과 결합되고, 스토리지 요청이 성공적임을 확인하도록 한다. 다른 실시예에서, 데이터 세그먼트를 독출하는 요청은 스토리지 요청으로부터 독립적이고, 스토리지 요청을 만드는 요청 장치(1326) 또는 다른 분리된 요청 장치(1326)에 의해 개시될 수 있다.
일 실시예에서, 요청 장치는 실제 데이터의 장소에서 데이터 세그먼트 토큰로부터 정보를 수신할 수 있고, 독출 요청 응답 모듈(1312)은 요청 장치(1326)로의 메시지에 응답하여 전송하는 데이터 세그먼트 토큰 전송 모듈(1314)을 포함한다. 메시지는 적어도 데이터 세그먼트 식별자 및 데이터 세그먼트 길이를 포함하지만, 또한 데이터 세그먼트 장소, 반복되고 동일한 문자 또는 문자 스트링의 적어도 하나의 예, 또는 다른 적절한 정보를 포함할 수 있다. 일반적으로, 메시지는 데이터 세그먼트 토큰에 포함된 것이 아닌, 데이터 세그먼트의 실제 데이터를 포함하지 않는다.
다른 실시예에서, 요청 장치(1326)가 데이터 세그먼트를 수신하는 것을 기대한 경우, 상기 장치는 데이터 세그먼트 토큰을 사용하여 데이터 세그먼트의 데이터를 재구성하는 데이터 세그먼트 재구성 모듈(1318)을 포함한다. 독출 요청 응답 모듈(1312)은 또한 재구성된 요청된 데이터 세그먼트를 요청 장치(1326)로 전송하는 데이터 세그먼트 전송 모듈(1316)을 포함한다. 다른 실시예에서, 데이터 세그먼트 재구성 모듈(1318)은 요청 장치(1326)에 구비되며, 드라이버의 형태로 구비될 수 있으며, 데이터 세그먼트 토큰 전송 모듈(1314)은 메시지를 데이터 세그먼트 토큰 정보와 함께 요청 장치(1326)로 전송한다. 요청 장치(1326) 내의 데이터 세그먼트 재구성 모듈(1318)은 요청된 데이터 세그먼트를 메시지로부터 재구성한다.
일 실시예에서, 상기 시스템(1300)은 독출 요청 리시버 모듈(1308), 데이터 세그먼트 토큰 독출 모듈(1310), 독출 요청 응답 모듈(1312)을 포함하는 분리된 장치를 포함하며, 이는 상술한 바와 실질적으로 유사하다. 상기 장치는 기록 요청 리시버 모듈(1302) 및 데이터 세그먼트 토큰 저장 모듈(1304)를 포함한 장치로부터 독립적이다. 일 실시예에서, 독출 요청 응답 모듈(1312)은 데이터 세그먼트 토큰 전송 모듈(1314) 및/또는 데이터 세그먼트 전송 모듈(1316)을 포함하고, 상기 장치는 데이터 세그먼트 재구성 모듈(1318)을 포함할 수 있으며, 여기서 모듈(1314,1316,1318)은 상술한 바와 실질적으로 유사하다.
도 14는 본 발명에 따른 데이터 세그먼트 토큰을 저장하는 방법(1400)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(1400)은 개시되어(1402), 기록 요청 리시버 모듈(1302)이 스토리지 요청을 요청 장치(1326)로부터 수신하고(1404), 여기서 스토리지 요청은 데이터 세그먼트를 저장 장치(150)에 저장하는 요청을 포함한다. 데이터 세그먼트는 반복되고 동일한 문자 또는 문자 스트링의 연속을 포함한다. 데이터 세그먼트 토큰 저장 모듈(1304)은 저장 장치(150) 내에 데이터 세그먼트 토큰을 저장하고(1406), 상기 방법(1400)은 종료한다(1408). 데이터 세그먼트 토큰은 적어도 데이터 세그먼트 식별자 식별자 및 데이터 세금너트 길이를 포함하고, 데이터 세그먼트 토큰은 대부분에서 데이트 세그먼트로부터의 데이터를 포함하지 않는다.
도 15는 본 발명에 따른 데이터 세그먼트 토큰을 독출하는 방법(1500)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(1500)은 개시하여(1502), 기록 요청 리시버 모듈(1308)이 데이터 세그먼트를 저장 장치(150)로부터 독출하는 스토리지 요청을 수신한다(1504). 데이터 세그먼트는 데이터 세그먼트 토큰에 의해 저장 장치에 표시되고, 데이터 세그먼트는 반복되고 동일한 문자 또는 문자 스트링의 연속을 포함한다. 데이터 세그먼트 토큰은 적어도 데이터 세그먼트 식별자 및 데이터 세그먼트 길이를 포함하고, 데이터 세그먼트 토큰은 데이터 세그먼트로부터의 데이터를 포함하지 않는다. 데이터 세그먼트 토큰 독출 모듈(1310)은 스토리지 요청 내에 요청된 데이터 세그먼트에 대응하는 데이터 세그먼트 토큰를 독출하고(1506), 독출 요청 응답 모듈(1312)은 응답을 요청 장치(150)으로 전송하고(1508), 상기 방법(1500)은 종료한다(1510). 응답은 요청된 데이터 세그먼트에 대응하는 데이터 세그먼트 토큰을 사용하여 생성된다.
프로그레시브 RAID{Progressive RAID}
RAID(Redundant Array of Independent Drives)는 다양한 목적을 달성하기 위해 많은 방법으로 구성될 수 있다. 여기에 기술되는 바와 같이, 드라이브는 데이터를 위한 대용량 저장 장치(mass storage device)이다. 드라이브, 또는 저장 장치는 솔리드-스테이트 장치(110), HDD(Hard Disk Drive), 테잎 드라이브, 광학 드라이브, 또는 당업자에게 알려진 임의의 다른 대용량 저장 장치일 수 있다. 일 실시예에서, 드라이브는 가상 볼륨(virtual volume)으로서 액세스되는 대용량 저장 장치의 일부를 포함한다. 다른 실시예에서, 드라이브는 가상 볼륨으로서 함께 액세스 가능하고, SAN(Storage Area Network) 내에 RAID로서, 단지 다수의 디스크/드라이브(JBOD) 등으로서 구성된다. 일반적으로, 드라이브는 스토리지 컨트롤러(152)를 통해 단일 유닛 또는 가상 볼륨으로서 액세스된다. 바람직한 실시예에서, 스토리지 컨트롤러(152)는 솔리드-스테이트 장치 컨트롤러(104)를 포함한다. 당업자는 RAID 내에 구성될 수 있는 대용량 저장 장치의 형태의 드라이브의 다른 형태를 파악할 것이다. 여기에 기술된 실시예에서, 드라이브 및 저장 장치(150)는 호환성 있게 사용된다.
종래에, 다양한 RAID 구성은 RAID 레벨(level)로 언급되었다. 하나의 기본 RAID 구성은 저장 장치(150)의 미러 카피(mirror copy)를 생성하는 RAID 레벨 0이다. RAID 0의 장점은 하나 또는 그 이상의 저장 장치(150)로의 데이터의 완전한 카피가 또한 하나 또는 그 이상의 저장 장치(150)의 미러 카피 상에 사용가능하여, 프라이머리 드라이브로의 데이터 독출 또는 반사된(mirrored) 드라이브는 상대적으로 빠르다. RAID 0은 또한 프라이머리 저장 장치(150)내의 실패의 경우에 대비하여 데이터의 백업 카피를 제공한다. RAID 0의 단점은 기록이 상대적으로 느린 것이며, 이는 기록된 데이터는 두 번 기록되어야 하기 때문이다.
다른 종래의 RAID 구성은 RAID 레벨 1이다. RAID 1에서, RAID로 기록되는 데이터는 저장 장치(150)의 세트 내의 N 개의 저장 장치(150)에 대응하는 N 개의 데이터 세그먼트로 분할된다. N 개의 데이터 세그먼트는 "스트라이프(stripe)"를 구성한다. 다수의 저장 장치(150)에 걸쳐 데이터를 스트라이프 함으로써, 성능은 향상되며, 이는 단일 저장 장치(150)가 N 개의 데이터 세그먼트를 포함하는 데이터를 저장할 수 있는 것에 비해 저장 장치(150)가 N 개의 데이터 세그먼트를 보다 빠르게 저장하도록 병렬로(in parallel) 작동할 수 있기 때문이다. 데이터 독출은 상대적으로 느리지만, 이는 데이터가 다수의 저장 장치(150)에 걸쳐 분포될 수 있기 때문이며, 다수의 저장 장치(150)의 액세스 시간은 일반적으로 모든 요구되는 데이터를 포함하는 하나의 저장 장치(150)로부터 데이터를 독출하는 것에 비해 더 느리다. 또한, RAID 1은 실패 보호(failure protection)을 제공하지 않는다.
인기 있는 RAID 구성은 N 개의 저장 장치(150)에 걸쳐 N 개의 데이터 세그먼트의 스트리핑(striping) 및 N+1 저장 장치(150)에 패리티(parity) 데이터 세그먼트를저장하는 것을 포함하는 RAID 레벨 5이다. RAID 5는 실패 내성(failure tolerance)을 제공하며 이는 RAID가 저장 장치(150)의 단일 실패(single failure)를 견딜 수 있기 때문이다. 예를 들어, 저장 장치(150)가 실패한 경우, 스트라이프의 데이터 세그먼트의 손실은 다른 사용 가능한 데이터 세그먼트 및 스트라이프를 위해 특별히 계산된 패리티 데이터 세그먼트를 사용하여 생성될 수 있다. RAID 5는 또한 일반적으로 RAID 0에 비해 보다 적은 저장 공간을 사용하며 이는 RAID된 저장 장치(150)의 세트의 각각의 저장 장치(150)는 데이터의 완전한 카피를 저장하도록 요구되지 않고, 스트라이프 또는 패리티 데이터 세그먼트의 데이터 세그먼트만을 저장하기 때문이다. RAID 1과 같이 RAID 5는 데이터 기록이 빠르지만, 상대적으로 데이터 독출은 느리다. 일반적인 종래의 RAID 5의 데이터 기록은 RAID 1보다 더 느리지만, 이는 패리티 데이터 세그먼트가 스트라이프의 N 개의 데이터 세그먼트로부터 각각의 스트라이프에 대해 계산되어야 하기 때문이다.
다른 인기 있는 RAID 구성은 듀얼 분산 패리티(dualdistributed parity)를포함하는 RAID 6이다. RAID 6에서, 두 개의 저장장치는 패리티-미러(parity-mirror) 장치(예컨대 1602a,1602b)로서 할당된다. 스트라이프에 대한 각각의 패리티 데이터 세그먼트는 분리되어 계산되며 그 결과 저장 장치(150) 내의 두 개의 저장 장치(150) 중 어느 하나의 손실은 남아있는 사용 가능한 데이터 세그먼트 및/또는 패리티 데이터 세그먼트를 사용하여 복구 가능하다. RAID 6는 RAID 5와 유사한 성능적 장점 및 단점을 가진다.
네스팅된(nested) RAID는 또한 높은 신뢰성을 요구하는 폴트 내성(fault tolerance)을 증가시키기 위해 사용된다. 예를 들어, 각각은 RAID 5로 구성된 두 개의 저장 장치 세트는 RAID 0 구성으로 미러링(mirrored)될 수 있다. 도출되는 구성은 RAID 50으로 언급될 수 있다. RAID 6이 각각의 미러링된 세트를 위해 사용되는 경우, 상기 구성은 RAID 60으로 언급될 수 있다. 네스팅된 RAID 구성은 일반적으로 근원적인 RAID 그룹과 같은 유사한 성능 이슈를 가진다.
전술한 바와 같이, 폴트 내성, RAID 0, RAID 5, RAID 6 등과 같은 종래의 RAID 레벨의 폴트-내성보다 빠른 데이터 기록의 장점을 제공하면서 또한 RAID 0, RAID 5, RAID 6 등과 같은 종래의 스트라이프된 RAID 레벨보다 더 빠른 데이터 독출을 제공하는 프로그레시브 RAID에 대한 장치, 시스템, 및 방법에 대한 요구가 존재하는 것은 분명하다. 유리하게, 그러한 장치, 시스템, 및 방법은 패리티 데이터 세그먼트가 계산되도록 요구될 때까지, 예컨대 스토리지 통합 동작(storage consolidation operation) 전까지 또는 그 일부까지, N 개의 데이터 세그먼트를 패리티-미러 저장 장치(1602)에 기록하며, RAID 0 시스템의 장점을 제공한다.
도 10은 본 발명에 따른 프로그레시브 RAID를 위한 시스템(1600)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 시스템(1600)은 하나 또는 그 이상의 클라이언트(114)에 의해 컴퓨터 네트워크(116)를 통해 액세스 가능한 N 개의 저장 장치(150) 및 M 개의 패리티-미러 저장 장치(1602)를 포함한다. N 개의 저장 장치(150) 및 패리티-미러 저장 장치(1602)는 하나 또는 그 이상의 서버(112)에 위치될 수 있다. 저장 장치(150), 서버(112), 컴퓨터 네트워크(116), 및 클라이언트(114)는 실질적으로 상술한 바와 유사하다. 패리티-미러 장치(1602)는 일반적으로 N 개의 저장 장치(150)과 유사하거나 동일하고, 일반적으로 스트라이프를 위한 패리티-미러 저장 장치(1602)로서 지정된다.
일 실시예에서, N 개의 저장 장치(150) 및 M 개의 패리티-미러 저장 장치(1602)는 하나의 서버(112)에 포함되거나 이를 통해 액세스 가능하고, 시스템 버스 SAN, 또는 다른 컴퓨터 네트워크(116)를 사용하여 함께 네트워크로 구성될 수 있다. 다른 실시예에서, N 개의 저장 장치(150) 및 M 개의 패리티-미러 저장 장치(1602)는 다수의 서버(112a-n+m) 내에 위치되거나 또는 이를 통해 액세스 가능하다. 예를 들어, 저장 장치(150) 및 패리티-미러 저장 장치(1602)는 도 1c의 시스템(103) 및 도 5b의 방법(105)와 연관되어 상술된 인-서버 SAN의 일부일 수 있다.
일 실시예에서, 패리티-미러 저장 장치(1602)는 프로그레시브 RAID에 저장된 스트라이프의 모든 패리티 데이터 세그먼트를 저장한다. 다른 바람직한 실시예에서, 프로그레시브 RAID에 할당된 저장 장치 세트(1604)의 저장 장치(150)는 특정 스트라이프를 위한 패리티-미러 저장 장치(1602)가 되도록 할당되고, 할당은 순환되어 패리티 데이터 세그먼트는 각각의 스트라이프에 대해 N+M 개의 저장 장치(150) 사이에서 순환된다. 이 실시예는 각각의 스트라이프를 위한 패리티-미러 저장 장치(1602)로 사용될 단일의 저장 장치(150)의 할당을 통해 성능적 장점을 제공한다. 패리티-미러 저장 장치(1602)를 순환함으로써(rotate), 패리티 데이터 세그먼트의 계산 및 저장과 연관된 오버헤드가 분산될 수 있다.
일 실시예에서, 저장 장치(150)는 솔리드-스테이트 스토리지 장치(102)이며, 각각은 솔리드-스테이트 스토리지(110) 및 솔리드-스테이트 스토리지 컨트롤러(104)와 결합된다. 다른 실시예에서, 각각의 저장 장치(150)는 솔리드-스테이트 스토리지 컨트롤러(104)를 포함하고, 결합된 솔리드-스테이트 스토리지(110)는 테잎 스토리지 또는 하드 디스크 드라이브와 같은 다른 덜 비싸고 낮은 성능의 스토리지를 위한 캐시(cache)로서 작동하낟. 다른 실시예에서, 하나 또는 그 이상의 서버(112)는 스토리지 요청을 프로그레시브 RAID로 전송하는 하나 또는 그 이상의 클라이언트(114)를 포함한다. 당업자는 N 개의 저장 장치(150) 및 하나 또는 그 이상의 패리티-미러 저장 장치(1602)를 구비한 프로그레시브 RAID로 구성될 수 있는 다른 시스템 구성을 파악할 것이다.
도 17은 본 발명에 따른 프로그레시브 RAID를 위한 장치(1700)의 일 실시예를 설명하는 개략적인 블록도이다. 다양한 실시예에서, 상기 장치(1700)는 스토리지 요청 리시버 모듈(1702), 스트라이핑 모듈(1704), 패리티-미러 모듈(1706), 및 패리티 프로그레션 모듈(1708), 패리티 교대(alternation) 모듈(1710), 미러링 세트(mirrored set) 모듈(1712), 업데이트 모듈(1714), 다이렉트 클라이언트 응답 모듈(1718)을 구비한 미러 복구 모듈(1716), 이전-통합(pre-consolidation) 모듈(1720), 후-통합 모듈(1722), 데이터 재건(rebuild) 모듈(1724), 및 패리티 재건 모듈(1726)을 포함하며, 이는 이하 기술된다. 모듈(1702-1726)은 서버(112)에 도시되지만, 모듈(1702-1726)의 기능 중 일부 또는 모두는 또한 다수의 서버(112), 스토리지 컨트롤러(152), 저장 장치(150), 클라이언트(114) 등에 분산될 수 있다.
상기 장치(1700)는 데이터를 저장시키는 요청을 수신하는 스토리지 요청 리시버 모듈(1702)을 포함하며, 여기서 데이터는 파일 또는 객체의 데이터이다. 일 실시예에서, 스토리지 요청은 객체 요청이다. 다른 실시예에서, 스토리지 요청은 블록 스토리지 요청이다. 일 실시예에서, 스토리지 요청은 데이터를 포함하지 않으며, 저장 장치(150) 및 패리티-미러 저장 장치(1602)에 의해 사용될 수 있는 명령에서 클라이언트(114) 또는 다른 소스로부터의 DMA 또는 RDMA 데이터를 포함한다. 다른 실시예에서, 스토리지 요청은 스토리지 요청의 결과로서 저장될 데이터를 포함한다. 다른 실시예에서, 스토리지 요청은 저장 장치 세트(1604)에 저장된 데이터를 구비할 수 있는 하나의 명령을 포함한다. 다른 실시예에서, 스토리지 요청은 다수의 명령을 포함한다. 당업자는 프로그레시브 RAID를 위해 적절한 데이터를 저장하는 다른 스토리지 요청을 파악할 것이다.
데이터는 상기 장치(1700)에 액세스 가능한 장소에 저장된다. 일 실시예에서, 데이터는 클라이언트(114) 또는 서버에 의해 사용되는 RAM과 같은 RAM(Random Access Memory) 내에서 사용 가능하다. 다른 실시예에서, 데이터는 하드 디스크 드라이브, 테잎 스토리지, 또는 다른 대용량 저장 장치에 저장된다. 일 실시예에서, 데이터는 객체 또는 파일로서 구성된다. 다른 실시예에서, 데이터는 객체 또는 파일의 일부인 데이터 블록으로서 구성된다. 당업자는 스토리지 요청의 영향을 받는 데이터에 대한 다른 형태 및 장소를 파악할 것이다.
상기 장치(1700)는 데이터를 위한 스트라이프 패턴을 계산하는 스트라이핑 모듈(1704)을 포함한다. 스트라이프 패턴은 하나 또는 그 이상의 스트라이프를 포함하며, 여기서 각각의 스트라이프는 N 개의 데이터 세그먼트의 세트를 포함한다. 일반적으로 스트라이프 내의 데이터 세그먼트의 수는 RAID 그룹에 얼마나 많은 저장 장치(150)가 할당되었는지에 따라 결정된다. 예를 들어, RAID 5가 사용된 경우, 하나의 저장 장치(150)가 패리티-미러 저장 장치(1602a)로 할당되어 특정 스트라이프를 위한 패리티 데이터를 저장한다. 네 개의 다른 저장 장치(150a,150b,150c,150d)가 RAID 그룹으로 할당된 경우, 스트라이프는 패리티 데이터 세그먼트에 추가하여 네 개의 데이터 세그먼트를 구비할 것이다. 스트라이핑 모듈(1704)은 N 개의 스트라이프의 N 개의 데이터 세그먼트를 N 개의 저장 장치(150a-n)에 기록하여, 각각의 N 개의 데이터 세그먼트는 스트라이프에 할당된 저장 장치(150)의 세트(1604) 내의 분리된 저장 장치(150a,150b,...150n)으로 기록된다. 당업자는 특정 RAID 레벨을 위하여 RAID 그룹에 할당될 수 있는 저장 장치(150)의 다양한 조합 및 스트라이핑 패턴을 생성하고 스트라이프 당 N 개의 데로 데이터를 분할하는 방법을 파악할 것이다.
상기 장치(1700)는 스트라이프의 N 개의 데이터 세그먼트의 세트를 저장 장치 세트(1604) 내의 하나 또는 그 이상의 패리티-미러 저장 장치(1602)에 기록하는 패리티-미러 모듈(1706)을 포함하며, 여기서 패리티-미러 저장 장치(1602)는 N 개의 저장 장치(150)에 추가된다. 그리고 나서, N 개의 데이터 세그먼트는 패리티 데이터 세그먼트의 추후 계산을 위해 사용 가능하다. 패리티 데이터 세그먼트를 즉시 계산하기 보다는, 패리티-미러 모듈(1706)이 N 개의 데이터 세그먼트의 세트를 패리티-미러 저장 장치(1602)로 카피하며, 이는 일반적으로 N 개의 데이터 세그먼트를 저장하는 것보다 적은 시간을 요구한다. N 개의 데이터 세그먼트가 패리티-미러 저장 장치(1602)에 저장되면, N 개의 데이터 세그먼트는 N 개의 저장 장치(150) 중 하나가 사용 불가능하게 되는 경우 데이터를 독출하거나 복구하기 위해 사용되도록 사용 가능해진다. 데이터 독출은 또한 RAID 0 구성의 장점을 가지며, 이는 N 개의 데이터 세그먼트 모두는 하나의 저장 장치(예컨대 1602a)로부터 함께 사용 가능하기 때문이다. 하나의 패리티-미러 저장 장치(예컨대 1602a,1602b)보다 많은 것에 대해, 패리티-미러 모듈(1706)은 N 개의 데이터 세그먼트를 각각의 패리티-미러 저장 장치(1602a,1602b)로 카피한다.
상기 장치(1700)는 스토리지 통합 동작에 응답하여 스트라이프를 위해 하나 또는 그 이상의 패리티 데이터 세그먼트를 계산하는 패리티 프로그레션 모듈(1708)을 포함한다. N 개의 데이터 세그먼트로부터 계산된 하나 또는 그 이상의 패리티 데이터 세그먼트는 패리티-미러 저장 장치(1602)에 저장된다. 패리티 프로그레션 모듈(1708)은 패리티 데이터 세그먼트를 하나 또는 그 이상의 패리티-미러 저장 장치(1602)의 각각에 저장한다. 스토리지 통합 동작은 적어도 저장 공간 또는 데이터, 또는 하나 또는 그 이상의 패리티-미러 저장 장치(1602) 중 적어도 하나의 저장 공간 및 데이터를 복구하도록 구동된다. 예를 들어, 스토리지 통합 동작은 도 8 및 도 9의 장치(800) 및 방법(900)과 관련하여 상술한 솔리드-스테이트 스토리지 장치(102) 상의 데이터 가비지 컬렉션일 수 있다. 스토리지 통합 동작은 또한 하드 디스크 드라이브를 위한 조각 처리(defragmentation) 동작, 또는 저장 공간을 증가시키기 위해 데이터를 통합하는 다른 유사한 동작을 포함한다. 여기에 사용된 바와 같이, 스토리지 통합 동작은 또한 데이터를 복구하는 동작을 포함할 수 있으며, 예를 들어, 저장 장치(150)가 사용 불가능한 경우, 에러로부터 복구하거나, 또는 패리티-미러 저장 장치(1602)로부터 데이터를 독출하기 위한 다른 원인일 수 있다. 다른 실시예에서, 패리티 생성 모듈(1708)은 패리티-미러 저장 장치(1602)가 덜 바쁜(busy) 경우, 단순히 패리티 데이터 세그먼트를 계산한다.
유리하게, 스트라이프의 패리티 데이터 세그먼트의 계산 및 저장을 지연시킴으로써, 패리티-미러 저장 장치(1602)에 더 많은 저장 공간이 필요해지거나 또는 스토리지 통합 동작을 위한 다른 이유가 있을 때까지, 패리티-미러 저장 장치(1602) 상의 N 개의 데이터 세그먼트는 데이터 세그먼트의 독출, 데이터의 복구, 저장 장치(150) 상의 데이터 재건을 위해 사용 가능하다. 그리고 나서, 패리티 프로그레션 모듈(1708)은 스토리지 요청 리시버 모듈(1702), 스트라이핑 모듈(1704), 또는 패리티-미러 모듈(1706)으로부터 자발적으로, 백그라운드 동작으로서 구동될 수 있다. 당업자는 프로그레시브 RAID 동작의 일부로서 패리티 데이터 세그먼트의 계산을 지연시킬 다른 이유를 용이하게 파악할 것이다.
일 실시예에서, 모듈(1702-1708)의 기능 일부 또는 전부, 예컨대 데이터를 저장시키는 요청을 수신하고, 스트라이프 패턴을 계산하고 N 개의 데이터 세그먼트를 N 개의 저장 장치에 기록하고, N 개의 데이터 세그먼트의 세트를 패리티-미러 저장 장치에 기록하고, 그리고 패리티 데이터 세그먼트를 계산하는 기능은 저장 장치 세트(1604), 클라이언트(114), 및 제 3 RAID 관리 장치의 저장 장치(150)에서 발생한다. 제 3 RAID 관리 장치(third-party RAID management device)는 서버(114) 또는 다른 컴퓨터일 수 있다.
일 실시예에서, 상기 장치(1700)는 각각의 스트라이프에 대해 교대하는 패리티 교대 모듈(1710)을 포함하며, 여기서 저장 장치 세트(1604) 내의 저장 장치(150)는 스트라이프를 위한 하나 또는 그 이상의 패리티-미러 저장 장치(1602)가 되도록 할당된다. 도 10의 시스템(1600)과 관련하여 상술한 바와 같이, 어떠한 저장 장치(150)가 스트라이프를 위한 패리티-미러 저장 장치를 위해 사용될지 순환시킴으로써, 다양한 패리티 데이터 세그먼트의 계산 동작은 저장 장치 세트(1604)의 저장 장치(150) 사이로 분포된다.
다른 실시예에서, 저장 장치 세트(1604)는 제 1 저장 장치 세트이며, 상기 장치(1700)는 제 1 저장 장치 세트(1604)에 추가하여 하나 또는 그 이상의 저장 장치 세트를 생성하여, 그 결과 하나 또는 그 이상의 추가적인 저장 장치 세트의 각각이 N 개의 데이터 세그먼트를 하나 또는 그 이상의 추가적인 저장 장치 세트의 각각의 N 개의 저장 장치(150)로 기록하는 적어도 결합된 스트라이핑 모듈(1704)을 포함하도록 하는 미러링 세트(mirrored set) 모듈(1712)을 포함한다. 관련된 실시예에서, 하나 또는 그 이상의 추가적인 저장 장치 세트의 각각은 N 개의 데이터 세그먼트의 세트를 저장하기 위한 결합된 패리티-미러 모듈(1706) 및 하나 또는 그 이상의 패리티 데이터 세그먼트를 계산하기 위한 패리티 프로그레션 모듈(1708)을 포함한다. 미러링 세트 모듈(1702)이 하나 또는 그 이상의 미러링된(mirrored) 저장 장치 세트를 생성하는 경우, RAID는 RAID50과 같은 네스팅된(nested) RAID일 수 있다. 이 실시예에서, RAID 레벨은 데이터가 스트라이프되고 미러링되는 RAID 10으로부터 RAID 50 또는 RAID 60으로 발전될 수 있으며, 여기서 패리티 데는 각각의 저장 장치 세트(1604)를 위해 계산되고 저장된다.
일 실시예에서, 상기 장치(1700)는 업데이트 모듈(1714)을 포함한다. 업데이트 모듈(1714)은 일반적으로 패리티-미러 저장 장치(1602) 상의 N 개의 데이터 세그먼트가 패리티 데이터 세그먼트로 진행되지 않은 경우 사용된다. 업데이트 모듈(1714)은 업데이트된 데이터 세그먼트를 수신하며, 여기서 업데이트된 데이터 세그먼트는 N 개의 저장 장치(150)에 저장된 N 개의 데의 기존 데이터 세그먼트에 대응한다. 업데이트 모듈(1714)은 업데이트된 데이터 세그먼트를 기존 데이터 세그먼트가 저장된 스트라이프의 저장 장치(150)로 그리고 스트라이프의 하나 또는 그 이상의 패리티-미러 저장 장치(1602)로 카피한다. 업데이트 모듈(1714)은 N 개의 저장 장치(150a-n)의 저 상에 저장된 기존 데이터 세그먼트를 업데이트된 데이터 세그먼트로 교체하고, 하나 또는 그 이상의 패리티-미러 저장 장치(1602)에 저장된 해당 기존 데이터 세그먼트를 업데이트된 데이터 세그먼트로 교체한다.
일 실시예에서, 데이터 세그먼트의 교체는 저장 장치(150)로의 데이터 세그먼트의 기록 및 그리고 나서 해당 데이터 세그먼트를 수반되는 가비지 컬렉션을 위해 무효로 마킹하는 것을 포함한다. 이 실시예의 일 예는 도 8 및 도 9와 관련하여 상술된 솔리드-스테이트 스토리지(110) 및 가비지 컬렉션 장치를 위해 기술된다. 다른 실시예에서, 데이터 세그먼트의 교체는 기존 데이터 세그먼트를 업데이트된 데이터 세그먼트로 오버라이트(overwrite)하는 것을 포함한다.
일 실시예에서, 저장 장치의 세트(1604)는 제 1 저장 장치 세트이고, 상기 장치(1700)는 제 1 저장 장치 세트(1604)의 저장 장치(150)에 저장된 데이터 세그먼트를 복구하는 미러 복구 모듈(1716)을 포함하며, 여기서 제 1 저장 장치 세트(1604)의 저장 장치(150)는 사용 불가능하다. 데이터 세그먼트는 데이터 세그먼트의 카피를 포함하는 미러 저장 장치로부터 복구된다. 미러 저장 장치는 N 개의 데이터 세그먼트의 카피를 저장하는 하나 또는 그 이상의 저장 장치(150)의 세트 중 하나를 포함한다.
더한 실시예에서, 미러 복구 모듈(1716)은 데이터 세그먼트를 독출하기 위한 클라이언트(114)로부터의 독출 요청에 응답하여 데이터 세그먼트를 복구한다. 다른 연관된 실시예에서, 미러 복구 모듈(1716)은 또한 요청된 데이터 세그먼트를 미러 저장 장치로부터 클라이언트(114)로 전송하는 다이렉트 클라이언트 응답 모듈(1718)을 포함한다. 이 실시예에서, 요청된 데이터 세그먼트는 클라이언트(114)로 카피되어, 클라이언트(114) 상의 데이터 세그먼트가 전송되기 전 데이터 세그먼트가 복구될 때까지 클라이언트(114)는 대기할 필요가 없다.
일 실시예에서, 상기 장치(1700)는 데이터 세그먼트를 독출하는 요청에 응답하여 저장 장치 세트(1604)의 저장 장치(150)에 저장된 데이터 세그먼트를 복구하는 이전-통합 복구 모듈(1702)을 포함한다. 실시예에서, 저장 장치(150)는 사용 불가능하고, 패리티 프로그레션 모듈(1708)이 하나 또는 그 이상의 패리티-미러 저장 장치(1602)에 하나 또는 그 이상의 패리티 데이터 세그먼트를 생성하기 전에 데이터 세그먼트가 패리티-미러 저장 장치(1602)로부터 복구된다.
다른 실시예에서, 상기 장치(1700)는 저장 장치 세트의 저장 장치(150)에 저장된 데이터 세그먼트를 복구하는 후-통합 복구 모듈(1724)을 포함한다. 실시예에서, 저장 장치(150)는 사용 불가능하고, 패리티 프로그레션 모듈(1708)이 하나 또는 그 이상의 패리티 데이터 세그먼트를 생성한 후에 데이터 세그먼트가 하나 또는 그 이상의 패리티-미러 저장 장치(150)에 저장된 하나 또는 그 이상의 패리티 데이터 세그먼트를 사용하여 복구된다. 예를 들어, 후-통합 복구 모듈(1724)은 패리티 데이터 세그먼트 및 사용 가능한 N 개의 저장 장치(150) 상의 사용 가능한 데이터 세그먼트를 사용하여 손실된 데이터 세그먼트를 재생성한다.
일 실시예에서, 상기 장치(1700)는 복구된 데이터 세그먼트를 재건 동작으로 대체 저장 장치에 저장하는 데이터 재건 모듈(1724)을 포함하며, 여기서 복구된 데이터 세그먼트는 사용 불가능한 저장 장치(150)에 저장된 삿용 불가능한 데이터 세그먼트에 매칭된다. 사용 불가능한 저장 장치(150)는 저장 장치 세트(1602)의 N 개의 저장 장치(150) 중 하나이다. 일반적으로, 재건 동작은 사용 불가능한 데이터 세그먼트를 저장한 저장 장치(150)의 실패(failure) 후에 발생한다. 재건 동작은 데이터 세그먼트를 대체 저장 장치로 복구하여 사용 불가능한 저장 장치(150)에 이전에 저장된 데이터 세그먼트를 매칭시킨다.
데이터 세그먼트는 다수의 소스(source)로부터 재건 동작을 위해 복구될 수 있다. 예를 들어, 매칭된 데이터 세그먼트가 패리티-미러 저장 장치(1602)에 구비된 경우, 데이터 세그먼트는 프로그레션 전에 패리티-미러 저장 장치(1602)로부터 복구될 수 있다. 다른 실시예에서, 데이터 세그먼트는 사용 불가능한 데이터 세그먼트의 카피를 포함하는 미러 저장 장치로부터 복구될 수 있다. 일반적으로 복구된 데이터 세그먼트가 하나 또는 그 이상의 패리티-미러 저장 장치(1602)에 구비되지 않은 경우, 데이터 세그먼트는 미러 저장 장치로부터 복구되지만, 비록 매칭 데이터 세그먼트가 미러 저장 장치에서 사용 가능할지라도 미러 저장 장치로부터 복구될 수 있다.
다른 예에서, 복구된 데이터 세그먼트가 패리티-미러 저장 장치(1602) 또는 미러 저장 장치에 구비되지 않은 경우, 재생성된 데이터 세그먼트는 하나 또는 그 이상의 패리티 데이터 세그먼트 및 N 개의 데이터 세그먼트의 사용 가능한 데이터 세그먼트로부터 재생성된다. 일반적으로 손실된 데이터 세그먼트는 오직 이것이 임의의 형태로 다른 저장 장치(150)에 존재하지 않은 경우에만 재생성된다.
다른 실시예에서, 상기 장치(1700)는 복구된 패리티 데이터 세그먼트를 패리티 재건 동작으로 대체 저장 장치에 재건하는 패리티 재건 모듈(1726)을 포함하며, 여기서 복구된 패리티 데이터 세그먼트는 사용 불가능한 패리티-미러 저장 장치에 저장된 사용 불가능한 패리티 데이터 세그먼트를 매치시킨다. 사용 불가능한 패리티-미러 저장 장치는 하나 또는 그 이상의 패리티-미러 저장 장치(1602) 중 하나이다. 패리티 재건 동작은 패리티 데이터 세그먼트를 대체 저장 장치에 복구시켜 사용 불가능한 패리티-미러 저장 장치에 이전에 저장된 패리티 데이터 세그먼트를 매치시킨다.
복구된 패리티 데이터 세그먼트를 재건 동작으로 재생성하기 위해, 재건을 위해 사용된 데이터는 다양한 소스로부터 올 수 있다. 일 예에서, 복구된 패리티 데이터 세그먼트는 스트라이프의 미러 카피를 저장하는 저장 장치(150)의 제 2 세트 내의 패리티-미러 저장 장치(1602)에 저장된 패리티 데이터 세그먼트를 사용하여 복구된다. 미러 카피가 사용 가능한 경우, 미러링된 패리티 데이터 세그먼트의 사용이 요구되며, 이는 복구된 패리티 데이터 세그먼트가 재계산될 필요가 없기 때문이다. 다른 예에서, N 개의 데이터 세그먼트가 N 개의 저장 장치에서 사용 가능한 경우, 복구된 패리티 데이터 세그먼트는 N 개의 저장 장치(150) 중 하나에 저장된 N 개의 데이터 세그먼트로부터 재생성된다. 일반적으로, N 개의 데이터 세그먼트는 N 개의 저장 장치(150)에서 사용 가능할 것이며, 여기서 단일의 실패(failure)는 재건된 패리티-미러 저장 장치(1602)에서 발생한다.
다른 예에서, 하나 또는 그 이상의 N 개의 데이터 세그먼트가 제 1 저장 장치 세트(1604)의 N개의 저장 장치(150)로부터 사용 불가능하고 매칭된 패리티 데이터 세그먼트가 저장 장치(150)의 제 2 세트에서 사용 불가능한 경우, 복구된 패리티 데이터 세그먼트는 N 개의 데이터 세그먼트의 카피를 저장하는 저장 장치(150)의 제 2 세트의 하나 또는 그 이상의 저장 장치(150)로부터 재생성된다. 여전히 다른 예에서, 복구된 패리티 데이터 세그먼트는 하나 또는 그 이상의 저장 장치(150)의 세트 내의 위치에 관계 없이, 사용 가능한 데이터 세그먼트 및 비-매칭된 패리티 데이터 세그먼트로부터 재생성된다.
패리티-미러 저장 장치가 저장 장치 세트(1604)의 저장 장치(150) 사이에서 교대되는 경우, 일반적으로 데이터 재건 모듈(1724) 및 패리티 재건 모듈(1726)은 재건 저장 장치(150) 상의 재건된 데이터 세그먼트 및 패리티 데이터 세그먼트와 함께 동작한다. 제 2 패리티-미러 저장 장치(1602b)가 사용 가능한 경우, 데이터 재건 모듈(1724) 및 패리티 재건 모듈(1726)은 저장 장치 세트(1604)의 두 개의 저장 장치(150,1602)의 실패 후 두 개의 저장 장치를 재건할 수 있다. 패리티-미러 저장 장치(1602)가 진행되어 스트라이프를 위한 패리티 데이터 세그먼트가 계산되고 삭제된 패리티 데이터 세그먼트를 계산하기 위해 사용된 패리티-미러 저장 장치(1602)에 N 개의 데이터 세그먼트를 저장하는 경우보다, 패리티-미러 저장 장치(1602)가 패리티-미러 데이터 세그먼트를 생성하도록 진행되지 않은 경우, 데이터 세그먼트 또는 저장 장치(150)의 복구는 더 빠르게 진행된다.
도 18은 본 발명에 따른 프로그레시브 RAID를 사용한 데이터 세그먼트의 업데이트를 위한 장치(1800)의 일 실시예를 설명하는 개략적인 블록도이다. 일반적으로, 상기 장치(1800)는 RAID그룹에 부속되고, 여기서 하나 또는 그 이상의 패리티-미러 저장 장치(1602)는 진행되고 패리티 데이터 세그먼트를 포함하지만 패리티 데이터 세그먼트를 생성하기 위해 사용된 N 개의 데이터 세그먼트는 포함하지 않는다. 상기 장치(1800)는 업데이트 리시버 모듈(1802), 업데이트 카피 모듈(1804), 패리티 업데이트 모듈(1806)을 포함하며, 이는 이하 기술된다. 상기 장치(1800)의 모듈(1802-1806)은 서버(112)에 도시되지만, 이는 저장 장치(150), 클라이언트(114), 또는 장치의 임의의 조합에 구비될 수 있거나, 또는 다수의 장치에 분산될 수 있다.
스트라이프, 데이터 세그먼트, 저장 장치(150), 저장 장치 세트(1604), 패리티 데이터 세그먼트, 및 하나 또는 그 이상의 패리티-미러 저장 장치(1602)는 도 11의 장치(1700)와 관련하여 상술된 스트라이프와 실질적으로 유사하다. 상기 장치(1800)는 업데이트된 데이터 세그먼트를 수신하는 업데이트 리시버 모듈(1802)을 포함하며, 여기서 업데이트된 데이터 세그먼트는 기존 스트라이프의 기존 데이터 세그먼트에 대응한다. 다른 실시예에서, 업데이트 리시버 모듈(1802)은 또한 다수의 업데이트를 수신할 수 있고, 업데이트를 함께 또는 개별적으로 다룰 수 있다.
상기 장치(1800)는 업데이트된 데이터 세그먼트를 저장 장치(150)로 카피하는 업데이트 카피 모듈(1804)을 포함하며, 여기서 해당 기존 데이터 세그먼트는 기존 스트라이프에 대응하는 하나 또는 그 이상의 패리티-미러 저장 장치(1602)에 저장된다. 다른 실시예에서, 업데이트 카피 모듈(1804)은 업데이트된 데이터 세그먼트를 패리티-미러 저장 장치(1602) 또는 기존 데이터 세그먼트를 저장하는 저장 장치(150) 중 어느 하나로 카피하며, 그리고 나서 업데이트된 데이터 세그먼트의 카피가 다른 장치(1602,150)로 전달되었음을 검증한다.
상기 장치(1800)는 스토리지 통합 동작에 응답하여 기존 스트라이프의 하나 또는 그 이상의 패리티-미러 저장 장치를 위한 하나 또는 그 이상의 업데이트된 패리티 데이터 세그먼트를 계산하는 패리티 업데이트 모듈(1806)을 포함한다. 스토리지 통합 동작은 도 11의 장치(1700)와 관련하여 기술된 스토리지 통합 동작과 유사하다. 스토리지 통합 동작은 하나 또는 그 이상의 업데이트된 패리티 데이터 세그먼트를 사용하여 적어도 저장 공간 및/또는 하나 또는 그 이상의 패리티-미러 저장 장치(1602)의 데이터를 복구하도록 동작된다. 하나 또는 그 이상의 패리티 데이터 세그먼트가 업데이트되도록 대기함으로써, 업데이트는 더욱 편리해질 때까지 또는 저장 공간을 통합하기에 필요한 때까지 연기될 수 있다.
일 실시예에서, 업데이트된 패리티 데이터 세그먼트는 기존 패리티 데이터 세그먼트, 업데이트된 데이터 세그먼트, 및 기존 데이터 세그먼트로부터 계산된다. 일 실시예에서, 기존 데이터 세그먼트는 업데이트된 패리티 데이터 세그먼트의 생성을 위한 기존 데이터 세그먼트의 독출 전에, 적절한 장소에서 유지된다. 이 실시예의 장점은 기존 데이터 세그먼트를 패리티-미러 저장 장치(1602) 또는 업데이트된 패리티 데이터 세그먼트가 생성된 다른 장소로 카피함으로부터 결합된 오버헤드가 필요할 때까지 연기될 수 있는 것이다. 이 실시예의 단점은 기존 데이터 세그먼트를 유지하는 저장 장치(150)가 실패한 경우, 기존 데이터 세그먼트는 업데이트된 패리티 데이터 세그먼트가 생성되기 전에 복구되어야하는 것이다.
다른 실시예에서, 기존 데이터 세그먼트가 저장된 N 개의 저장 장치(150a-n)의 저장 장치(150)가 업데이트된 데이터 세그먼트의 카피를 수신한 경우, 기존 데이터 세그먼트는 데이터-미러 저장 장치(1602)로 카피된다. 그리고 나서 기존 데이터 세그먼트는 스토리지 통합 동작이 수행될 때까지 저장된다. 다른 실시예에서, 스토리지 통합 동작이 업데이트된 패리티 데이터 세그먼트의 계산을 시작하는(trigger) 스토리지 통합 동작 전에 발생한 경우, 기존 데이터 세그먼트는 기존 데이터 세그먼트가 저장된 N 개의 저장 장치(150a-n)의 저장 장치(150) 상의 스토리지 통합 동작에 응답하여 데이터-미러 저장 장치(1602)로 카피된다. 후자의 실시예는 기존 데이터 세그먼트가 저장된 저장 장치(150) 또는 패리티-미러 저장 장치(1602) 중 어느 하나 상의 스토리지 통합 동작에 의해 요구될 때까지 카피되지 않으므로 유리하다.
일 실시예에서, 업데이트된 패리티 데이터 세그먼트는 기존 패리티 데이터 세그먼트, 업데이트된 데이터 세그먼트, 및 델타(delta) 데이터 세그먼트로부터 계산되며, 여기서 델타 데이터 세그먼트는 업데이트된 데이터 세그먼트 및 기존 데이터 세그먼트 간의 차이로서 생성된다. 일반적으로, 델타 데이터 세그먼트의 생성은 패리티 데이터 세그먼트의 업데이트에서 부분적인 솔루션 또는 중간 단계이다. 델타 데이터 세그먼트의 생성은 매우 압축적일 수 있고 전송 전에 압축될 수 있어 유리하다.
일 실시예에서, 델타 데이터 세그먼트는 업데이트된 패리티 데이터 세그먼트의 생성을 위한 델타 데이터 세그먼트의 독출 전에, 기존 데이터 세그먼트를 저낭하는 저장 장치에 저장된다. 다른 실시예에서, 델타 데이터 세그먼트는 기존 데이터 세그먼트가 저장된 저장 장치(150)가 업데이트된 데이터 세그먼트의 카피를 수신한 경우, 데이터-미러 저장 장치(1602)로 카피된다. 다른 실시예에서, 델타 데이터 세그먼트는 기존 데이터 세그먼트가 저장된 저장 장치(150) 상의 스토리지 통합 동작에 응답하여 데이터-미러 저장 장치(1602)로 카피된다. 기존 데이터 세그먼트의 카피에 의해, 후자의 실시예는 델타 데이터 파일이 기존 데이터 세그먼트를 저장하는 저장 장치(150) 상의 스토리지 통합 동작 또는 업데이트된 패리티 데이터 세그먼트의 계산을 시작하는 다른 스토리지 통합 동작 전까지는 이동되지 않으므로 유리하다.
다양한 실시예에서, 모듈(1802,1804,1806)의 동작의 전부 또는 일부, 즉 업데이트된 데이터 세그먼트를 수신하고, 업데이트된 데이터 세그먼트를 카피하고, 업데이트된 데이터 세그먼트를 계산하는 동작은 저장 장치 세트(1604), 클라이언트(114), 또는 제 3 RAID 관리 장치의 저장 장치(150)에서 발생한다. 다른 실시예에서, 스토리지 통합 동작은 업데이트 리시버 모듈(1802) 및 업데이트 카피 모듈(1804)의 동작으로부터 자발적으로 수행된다.
도 19는 본 발명에 따른 프로그레시브 RAID를 사용하여 데이터를 관리하는 방법(1900)을 설명하는 개략적인 흐름도이다. 상기 방법(1900)은 개시하여(1902), 스토리지 요청 리시버 모듈(1702)이 데이터를 저장시키는 요청을 수신하고(1904), 여기서 데이터는 파일 또는 객체의 데이터이다. 스트라이핑 모듈(1704)은 데이터를 위한 스트라이프 패턴을 계산하고, N 개의 데이터 세그먼트를 N 개의 저장 장치(150)에 기록한다(1906). 각각의 스트라이프는 N 개의 데이터 세그먼트의 세트를 포함하며, 여기서 각각의 N 개의 데이터 세그먼트는 스트라이프에 할당된 저장 장치의 세트(1604) 내의 분리된 저장 장치(150)에 기록된다.
패리티-미러 모듈(1706)은 스트라이프의 N 개의 데이터 세그먼트의 세트를 저장 장치의 세트(1604) 내의 하나 또는 그 이상의 패리티-미러 저장 장치(1602)에 기록한다(1908). 하나 또는 그 이상의 패리티-미러 저장 장치는 N 개의 저장 장치(150a-n)에 추가된다. 패리티 생성 모듈(1708)은 진행 중인 스토리지 통합 동작이 있는지 여부를 결정한다(1910). 패리티 생성 모듈(1708)이 진행 중인 스토리지 통합 동작이 없음을 결정하는 경우(1910), 상기 방법(1900)은 되돌아와 다시 진행 중인 스토리지 통합 동작이 있는지 여부를 결정한다(1910). 다른 실시예에서, 스토리지 요청 리시버 모듈(1702), 스트라이핑 모듈(1704), 및 패리티-미러 모듈(1706)은 스토리지 요청을 수신하고, 스트라이핑 패턴을 계산하고, 그리고 데이터 세그먼트를 저장하도록 지속된다.
패리티 생성 모듈(1708)이 진행 중인 스토리지 통합 동작이 없음을 결정한 경우(1910), 패리티 생성 모듈(1708)은 스트라이프를 위한 패리티 데이터 세그먼트를 계산한다(1914). 패리티 데이터 세그먼트는 패리티-미러 저장 장치(1602)에 저장된 N 개의 데이터 세그먼트로부터 계산된다. 패리티 생성 모듈(1708)은 패리티 데이터 세그먼트를 패리티-미러 저장 장치(1602)에 저장하고(1912), 상기 방법(1900)은 종료한다(1916). 스토리지 통합 동작은 N 개의 데이터 세그먼트를 저장시키는 요청을 수신하는 단계(1904). N 개의 데이터 세그먼트를 N 개의 저장 장치로 기록하는 단계(1906), 또는 N 개의 데이터 세그먼트를 하나 또는 그 이상의 패리티-미러 저장 장치에 기록하는 단계(1908)로부터 자발적으로 수행된다. 스토리지 통합 동작은 적어도 저장 공간 또는 패리티-미러 저장 장치(1602) 상의 데이터를 복구하도록 수행된다.
도 20은 본 발명에 따른 프로그레시브 RAID를 사용하여 데이터 세그먼트를 업데이트하는 방법(2000)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(2000)은 개시하여(2002), 업데이트 리시버 모듈(1802)이 업데이트된 데이터 세그먼트를 수신하고(2004), 여기서 업데이트된 데이터 세그먼트는 기존 스트라이프의 기존 데이터 세그먼트에 대응한다. 업데이트 카피 모듈(1804)은 업데이트된 데이터 세그먼트를 해당 기존 데이터 세그먼트가 저장된 저장 장치(150) 및 기존 스트라이프에 대응하는 하나 또는 그 이상의 패리티-미러 저장 장치(1602)로 카피한다(2006).
패리티 업데이트 모듈(1806)은 스토리지 통합 동작이 진행중인지 여부를 결정한다(2008). 패리티 업데이트 모듈(1806)이 진행 중인 스토리지 통합 동작이 없음을 결정한 경우(2008), 패리티 업데이트 모듈(1806)은 기존 스트라이프의 하나 또는 그 이상의 패리티-미러 저장 장치를 위한 하나 또는 그 이상의 업데이트된 패리티 데이터 세그먼트를 계산하고(2010), 상기 방법(2000)은 종료한다(2012).
전단 분산된 RAID(Front-End Distributed RAID)
종래의 RAID 시스템은 데이터를 수신하고, 데이터에 대한 스트라이핑 패턴(striping pattern)을 계산하고, 데이터를 데이터 세그먼트로 분할하고, 패리티 스트라이프(parity stripe)를 계산하고, 데이터를 저장 장치에 저장하고, 데이터 세그먼트를 업데이트하는 등과 같이 동작하는 RAID 컨트롤러로 구성된다. 반면 일부 RAID 컨트롤러는 일부 기능이 분산되도록 하며, RAID 컨트롤러에 의해 관리되는 저장 장치는 RAID에 스트라이프된 데이터를 저장하기 위해 클라이언트(114)와 직접적으로 통신하지 않는다. 대신 스토리지 요청(storage request) 및 RAID를 위한 데이터를 스토리지 컨트롤러로 전달한다.
RAID 컨트롤러가 RAID에 저장될 모든 데이터를 접촉하도록 요구하는 것은 데이터 흐름의 병목현상(bottleneck)을 초래하기 때문에 비효율적이다. 이는 RAID 그룹 내의 모든 드라이브의 대역폭 및 성능이 소비되는 반면 오직 서브셋(subset)만이 실제로 업데이트되는 독출-변경-기록(read-modify-write) 프로세스에서 특히 두드러진다. 또한, RAID 컨트롤러에 의해 관리되는 데이터를 위해 지정된 저장 장치의 영역은 일반적으로 RAID 그룹에게 전념되고 독립적으로 액세스될 수 없다. 클라이언트에 의한 저장 장치(150)로의 액세스는 일반적으로 저장 장치(150)를 파티션함으로써 달성되어야만 한다. 파티션이 사용되는 경우, 일반 스토리지를 위해 액세스 가능한 파티션은 RAID를 위해 사용되지 않고 RAID 그룹에 대해 할당된 파티션은 일반 데이터 스토리지를 위해 액세스 가능하지 않다. 전체적으로 사용을 최적화하기 위해 파티션을 과다신청하는(oversubscribe) 구성은 복잡하고 관리하기에 더 어렵다. 또한, 하나의 RAID 그룹을 위해 할당된 저장 공간은 하나의 RAID 컨트롤러가 마스터로 지정되고 마스터 RAID 컨트롤러가 비활성화되거나, 불구동되지 않는 경우 다른 RAID 컨트롤러가 슬레이브로서 구동하지 않는 한, 하나 이상의 RAID 컨트롤러에 의해 액세스될 수 없다.
일반적으로 RAID 컨트롤러는 또한 RAID 그룹의 저장 장치(150)의 외부에서 패리티 데이터 세그먼트를 생성한다. 이는 패리티 데이터 세그먼트가 일반적으로 생성되고 그리고 나서 저장을 위해 저장 장치(150)로 전송되며, 이는 RAID 컨트롤러의 용량(capacity)을 계산하는 것을 요구하므로 비효율적이다. 패리티 데이터 세그먼트 위치를 추적하고 업데이트하는 것은 또한 저장 장치(150)에서 자발적으로 수행되는 대신 RAID 컨트롤러에서 수행되어야 한다.
분리된 RAID 컨트롤러가 오프라인에 있는 경우 데이터가 사용 가능하도록 남아있는지 보증할 필요가 있다면, RAID 컨트롤러는 일반적으로 드라이브와 상호 간에 교차 연결되고(cross connected), 및/또는 완전한 세트로서 미러링되며(mirrored), 이는 데이터 유효성(availability)을 비싸고 관리하기 어렵게 하고, 스토리지 서브시스템의 신뢰성을 크게 감소시킨다.
데이터 세그먼트, 객체, 파일, 또는 유사한 성분(basis) 각각에 대해 RAID를 허용하고, 클라이언트 및 저장 장치 사이에 위치된 RAID 컨트롤러 및 RAID 컨트롤러 커플릿(couplet)의 필요를 제거하는 전단 분산된(front-end distributed) RAID에 대한 시스템, 장치, 및 방법을 필요로 한다. 이러한 시스템, 장치, 및 방법에서, RAID 그룹은 하나의 데이터 세그먼트, 객체, 또는 파일을 위해 생성될 수 있고, 하나의 RAID 컨트롤러에 의해 하나의 그룹의 저장 장치 내에서 관리되는 반면 제 2 RAID 그룹은 제 1 RAID 그룹의 동일한 저장 장치의 일부를 둘러싸는 다른 데이터 세그먼트, 객체, 또는 파일을 위해 생성될 수 있다. RAID 컨트롤 기능은 클라이언트(114), 제 3 RAID 관리 장치, 또는 저장 장치(150) 사이에서 분산될 수 있다. 전단 분산된 RAID 시스템, 장치, 및 방법은 또한 명령을 RAID 그룹의 저장 장치(150)로 전송할 수 있고, 저장 장치(150)가 DMA(Direct Memory Access), 또는 RDMA(Remote DMA)를 통해 데이터를 직접 액세스하고 카피하도록 할 수 있다.
도 10은 본 발명에 따른 전단 분산된(front-end distributed) RAID에 대해 액세스될 수 있는 시스템(1600)의 일 실시예를 설명하는 개략적인 블록도이다. 프로그레시브 RAID와 관련된 도 16에 도시된 컴포넌트에 대한 상기 기술은 또한 전단 분산된 RAID에도 적용 가능하다. 전단 분산된 RAID와 관련하여, 저장 장치 세트(1604)는 RAID 그룹을 형성하고, 자발적이고 네트워크(116) 또는 하나 또는 그 이상의 리던던트 네트워크(116)를 통해 클라이언트(114)로부터 스토리지 요청을 독립적으로 수신하고 서비스할 수 있는 저장 장치(150)를 포함한다.
저장 장치 세트(1604) 내의 저장 장치(150) 사이에서, 하나 또는 그 이상은 스트라이프를 위한 패리티-미러 저장 장치(1602)로 지정된다. 일반적으로, 하나 또는 그 이상의 패리티-미러 저장 장치(1602)는 실질적으로 다른 저장 장치(150)와 유사하게 기능한다. 일반적인 구성에서, 지정된 패리티-미러 저장 장치(1602)가 저장 장치 세트(1604)의 저장 장치(150) 사이에서 교대하는(alternate) 경우, vo(1602)는 필수적으로 다른 저장 장치(150)과 동일한 특성을 구비하고, 이는 이들이 또한 비-패리티-미러(non-parity-mirror) 저장 장치로서 동작해야하기 때문이다. 유사한 특성은 RAID 그룹 내의 동작 및 상술한 바와 같은 독립적인 클라이언트(114) 통신을 위한 자발적인 동작과 관련된다. 다양한 실시예에서, 저장 장치 세트(1604)의 저장 장치(150)는 기술된 RAID 환경 내의 기능과 관련되지 않은 다른 양상과 다를 수 있다.
저장 장치 세트(1604)의 저장 장치(150)는 하나 또는 그 이상의 서버(112) 내에 홀로 또는 그룹으로 구성될 수 있거나, 각각이 서버(112) 내에 구비될 수 있거나, 하나 또는 그 이상의 서버(112)를 통해 액세스될 수 있다. 하나 또는 그 이상의 클라이언트(114)는 하나 또는 그 이상의 저장 장치(150)를 포함하는 서버(112) 내에 구비될 수 있거나, 분리된 서버(112) 내에 구비될 수 있거나, 하나 또는 그 이상의 컴퓨터 네트워크(116) 등을 통해 저장 장치(150)에 액세스하는 컴퓨터, 워크스테이션, 랩탑 등에 구비될 수 있다.
일 실시예에서, 네트워크(116)는 시스템 버스 및 시스템 버스를 사용하여 통신하는 저장 장치 세트(1604)의 저장 장치(150,1602) 중 하나 또는 그 이상을 포함한다. 예를 들어, 시스템 버스는 PCI-e 버스, 직렬 ATA(Serial Advanced Technology Attachment) 버스, 병렬(parallel) ATA 등일 수 있다. 다른 실시예에서, 시스템 버스는 SCSI(Small Computer System Interface), 파이어와이어(FireWire), 파이버 채널, ISB, PCIe-AS, 인피니밴드 등과 같은 외부 버스이다. 당업자는 자발적이며, 하나 또는 그 이상의 네트워크(116)를 통해 클라이언트(114)로부터 스토리지 요청을 독립적으로 수신하고 서비스할 수 있는 저장 장치(150)를 구비한 다른 시스템(1600) 구성을 파악할 것이다.
도 11은 본 발명에 따른 전단 분산된 RAID를 위한 장치(2100)의 일 실시예를 설명하는 개략적인 블록도이다. 일 실시예에서, 상기 장치(2100)는 스토리지 요청 리시버 모듈(2102), 스트라이핑 결합 모듈(2104), 패리티-미러 결합 모듈(2106), 스토리지 요청 트랜스미터 모듈(2108), 전단 패리티 생성 모듈(2110), 패리티 교대 모듈(2112), 데이터 세그먼트 복구 모듈(2114), 데이터 재건 모듈(2116), 패리티 재건 모듈(2118), 및 피어-투-피어 통신 모듈(2120)을 포함하며, 이는 이하 기술된다. 다양한 실시예에서, 상기 장치(2100)는 솔리드-스테이트 스토리지 장치(102), 솔리드-스테이트 스토리지 컨트롤러(104)와 같은 스토리지 장치 컨트롤러(152), 서버(112), 제 3 RAID 관리 장치 등과 같은 저장 장치(150) 내에 포함될 수 있거나, 하나 이상의 컴포넌트 사이에 분산될 수 있다.
상기 장치(2100)는 데이터를 저장 장치 세트(1604)에 저장시키는 스토리지 요청을 수신한다. 데이터는 파일 또는 객체의 부분일 수 있거나, 전체 파일 또는 객체일 수 있다. 파일은 자의적인 정보(arbitrary information)의 블록, 또는 정보 저장을 위한 리소스일 수 있으며, 이는 컴퓨터 프로그램에 사용 가능하다. 파일은 프로세서에 의해 액세스되는 임의의 데이터 구조를 포함할 수 있다. 파일은 데이터베이스, 텍스트의 스트링, 컴퓨터 코드 등을 포함할 수 있다. 객체는 일반적으로 객체-지향 프로그래밍을 위한 데이터 구조이며, 데이터를 구비하거나 구비하지 않은 구조를 포함할 수 있다. 일 실시예에서, 객체는 파일의 서브셋(subset)이다. 다른 실시예에서, 객체는 파일로부터 독립적이다. 임의의 경우에서, 객체 및 파일은 여기에서 데이터, 데이터 구조, 컴퓨터 코드, 및 저장 장치에 저장될 수 있는 다른 정보의 전체 세트를 포함하도록 정의된다.
저장 장치 세트(1604)는 하나 또는 그 이상의 네트워크(116)를 통해 클라이언트(114)로부터 독립적으로 스토리지 요청을 수신하는 RAID 그룹을 형성하는 자발적인 저장 장치(150)를 포함한다. 저장 장치 세트(1604) 내의 자발적인 저장 장치(150)의 하나 또는 그 이상은 스트라이프를 위한 패리티-미러 저장 장치(1602)로 지정된다. 다른 클라이언트(114)로부터의 다른 스토리지 요청은 제 2 저장 장치 세트에 저장될 수 있으며, 여기서 제 2 저장 장치 세트는 제 1 저장 장치 세트(1604)와 동일한 저장 장치(150)(및 패리티-미러 저장 장치(1602))의 하나 또는 그 이상을 포함할 수 있다. 두 저장 장치 세트(1604)에 공통된 저장 장치(150)는 공통 저장 장치(150) 내의 중복되는 할당된 저장 공간을 구비할 수 있다.
상기 장치(2100)는 데이터를 위한 스트라이프 패턴을 계산하는 스트라이핑 결합 모듈(2104)를 포함한다. 스트라이프 패턴은 하나 또는 그 이상의 스트라이프를 포함한다. 각각의 스트라이프는 N 개의 데이터 세그먼트의 세트를 포함한다. 스트라이프의 N 개의 데이터 세그먼트는 또한 하나 또는 그 이상의 빈 데이터 세그먼트를 포함한다. 스트라이핑 결합 모듈(2104)은 N 개의 데이터 세그먼트의 각각을 스트라이프에 할당된 저장 장치 세트(1604) 내의 N 개의 저장 장치(150a-n) 중 하나와 결합시킨다. 일 실시예에서, 스트라이핑 결합 모듈(2104)은 스토리지 요청을 전송하는 클라이언트(114)로부터 저장 장치(150)가 데이터 세그먼트에 대응하는 데이터를 수신하도록 지시하는 저장 장치(150)로 전송될 스토리지 요청을 사용하여, 데이터 세그먼트를 저장 장치(150)와 결합시킨다.
다른 실시예에서, 스토리지 요청은 데이터 세그먼트의 데이터를 실질적으로 갖지 않는다. 데이터를 실질적으로 갖지 않는 것은 스토리지 요청이 일반적으로 스토리지 요청의 영향을 받는 데이터를 포함하지 않고 데이터의 일부일 수 있는 문자, 문자 스트링 등을 포함할 수 있음을 의미한다. 예를 들어, 데이터가 반복되고, 동일한 문자의 연속, 예컨대 영의 연속을 포함하는 경우, 스토리지 요청은 데이터 내에 포함된 영의 모두를 포함하지 않으면서, 데이터가 영의 연속을 포함함을 알리는 지시어를 포함할 수 있다. 당업자는 데이터의 벌크(bulk)를 전송하지 않으면서 여전히 스토리지 요청 내에 작은 양 또는 단일 예의 특정 문자 또는 문자 스트링을 허용하는 스토리지 요청을 전송하는 다른 방법을 파악할 것이다. 스토리지 요청은 N 개의 저장 장치(150a-n)가 DMA 또는 RDMA 동작 등을 사용하여 데이터를 검색하도록 허용하는 명령을 포함한다.
다른 실시예에서, 스트라이핑 결합 모듈(2104)은 저장 장치(150)로 전송될 스토리지 요청 내에서 데이터 세그먼트의 데이터를 식별함으로써, 데이터 세그먼트를 저장 장치(150)와 결합시킨다. 데이터 세그먼트의 데이터를 식별하는 것은 데이터 세그먼트 식별자, 데이터 세그먼트 위치 또는 어드레스, 데이터 세그먼트 길이, 또는 저장 장치(150)가 어떤 데이터가 데이터 세그먼트를 포함하는지 파악하도록 하는 다른 정보를 포함할 수 있다.
일 실시예에서, 스트라이핑 결합 모듈(2104)은 스토리지 요청 내에서 데이터 세그먼트를 저장 장치(150)와 결합시켜, 클라이언트(114)가 데이터 세그먼트를 포함하는 데이터를 방송(broadcast)으로 전송할 수 있어, 각각의 저장 장치(150)가 결합된 데이터 세그먼트를 저장하고 저장 장치(150)에 할당되지 않은 데이터 세그먼트에 대응하는 데이터를 폐기할 수 있도록 한다. 다른 실시예에서, 스트라이핑 결합 모듈(2104)은 각각의 데이터 세그먼트를 어드레싱(addressing)함으로써, 스토리지 요청 내에서 데이터 세그먼트를 저장 장치(150)와 결합시켜, 클라이언트(114)가 데이터 세그먼트를 포함하는 데이터를 멀티캐스트(multicast)로 전송할 수 있어, 각각의 저장 장치(150)가 결합된 데이터 세그먼트를 저장하고 저장 장치(150)에 할당되지 않은 데이터 세그먼트에 대응하는 데이터를 폐기할 수 있도록 한다. 당업자는 스트라이핑 모듈(2104)이 데이터 세그먼트를 저장 장치(150)와 결합시켜, 하나 또는 그 이상의 데이터 세그먼트를 하나 또는 그 이상의 저장 장치로 방송, 멀티캐스트, 유니캐스트(unicast), 애니캐스트(anycast) 등을 하도록 하는 다른 방법을 파악할 것이다.
관련된 실시예에서, 스트라이핑 결합 모듈(2104)은 스토리지 요청에서 데이터 세그먼트를 저장 장치(150)와 결합시켜, 클라이언트(114)가 스토리지 요청을 방송, 멀티캐스트, 유니캐스트 등을 할 수 있도록 하고, 각각의 저장 장치(150)가 저장 장치(150)와 결합된 데이터 세그먼트에 관계한 클라이언트(114)로부터 스토리지 요청의 일부를 수신할 수 있고, 저장 장치(150)와 결합되지 않은 하나 또는 그 이상의 데이터 세그먼트와 관계하지 않는 스토리지 요청의 해당 부분을 폐기할 수 있도록 한다.
다른 실시예에서, 스토리지 요청 리시버 모듈(2102)에 의해 수신된 스토리지 요청은 스토리지 요청의 영향을 받는 데이터를 포함하고, 스트라이핑 결합 모듈(2104)은 데이터 세그먼트를 포함한 저장 장치(150)를 위한 스토리지 요청을 준비함으로써, 데이터 세그먼트를 저장 장치(150)와 결합시킨다. 스트라이핑 결합 모듈(2104)은 클라이언트(114), 제 3 RAID 관리 장치, 저장 장치(150,1602) 등의 내부에서 구동할 수 있다.
상기 장치(2100)는 N 개의 데이터 세그먼트의 세트를 저장 장치 세트(1604) 내의 하나 또는 그 이상의 패리티-미러 저장 장치(1602)와 결합시키는 패리티-미러 저장 장치(1602)를 포함한다. 하나 또는 그 이상의 패리티-미러 저장 장치(1602)는 N 개의 저장 장치(150a-n)에 추가된다. 일 실시예에서, 패리티-미러 결합 모듈(2106)은 N개의 데이터 세그먼트의 세트를 각각의 패리티-미러 저장 장치(1602)에 결합시켜, 각각의 패리티-미러 저장 장치(1602)가 패리티 데이터 세그먼트를 생성하기 위해 스트라이프의 N 개의 데이터 세그먼트를 수신하고 저장할 수 있도록 한다. 다른 실시예에서, 패리티-미러 결합 모듈(2106)은 스트라이프의 데이터 세그먼트를 각각의 패리티-미러 저장 장치(1602)와 결합시켜, 패리티-미러 저장 장치(1602a-m)가 N 개의 저장 장치(150a-n)에 저장된 N 개의 데이터 세그먼트로의 미러로서 동작하도록 한다.
다양한 실시예에서, 패리티-미러 결합 모듈(2106)은 단일 스토리지 요청, 다수 스토리지 요청, 또는 스트라이핑 결합 모듈(2104)과 연관되어 상술된 다른 결합 기술, 예컨대 DMA, RDMA, 방송, 멀티캐스트를 위해 패리티-미러 저장 장치(1602)를 설정하는 스토리지 요청을 사용하여, 또는 N 개의 데이터 세그먼트를 스토리지 요청에 포함시킴으로써, N 개의 데이터 세그먼트의 세트를 하나 또는 그 이상의 패리티-미러 저장 장치(1602)와 결합시킨다. 패리티-미러 결합 모듈(2106)은 클라이언트(114), 제 3 RAID 관리 장치, 저장 장치(150,1602) 등의 내부에서 구동할 수 있다.
상기 장치(2100)는 하나 또는 그 이상의 스토리지 요청을 저장 장치 세트(1604) 내의 각각의 저장 장치(150,1602)로 전송하는 스토리지 요청 트랜스미터 모듈(2108)을 포함하며, 각각의 스토리지 요청은 스토리지 요청을 수신하는 저장 장치(150,1602)와 결합된 하나 또는 그 이상의 데이터 세그먼트를 저장 장치(150,1602)에 저장하기에 충분하다. 일 실시예에서, 각각의 스토리지 요청은 스토리지 요청의 영향을 받는 데이터를 포함하지 않는다. 더한 실시예에서, 각각의 스토리지 요청은 저장 장치 세트(1604)의 N 개의 저장 장치(150) 및 패리티-미러 저장 장치(1602)가 DAM 또는 RDMA를 사용하여 결합된 데이터 세그먼트의 데이터를 다운로드할 수 있도록 한다. 다른 실시예에서, 스토리지 요청은 결합된 데이터 세그먼트를 위한 관련된 스토리지 요청 또는 관련된 데이터를 클라이언트(114)로부터 뽑아기에 충분한 정보를 포함한다. 다른 실시예에서, 스토리지 요청은 결합된 데이터 세그먼트의 데이터를 포함한다.
일 실시예에서, 각각의 스토리지 요청은 스트라이프의 저장 장치 세트(1604)의 일부인 저장 장치(150,1602)를 식별한다. 저장 장치 세트(1604)의 저장 장치(150,1602)의 식별을 포함함으로써, 마스터로서 구동하는 저장 장치(150)의 실패의 경우, 다른 저장 장치(150)가 RAID된 데이터를 관리하기 위한 마스터로서 구동할 수 있다. 다른 실시예에서, 저장 장치 세트(1604)의 식별은 저자 장치가 오프-라인에 있는 경우, 자발적인 저장 장치(150,1602)가 데이터를 복구할 수 있도록 하고, 클라이언트에 독립적으로 대체 저장 장치가 저장 장치 세트(1604) 내에 추가되는 경우, 데이터를 재건할 수 있도록 한다. 다른 실시예에서, 저장 장치 세트(1604)의 저장 장치(150,1602)의 식별은 데이터 세그먼트 또는 스토리지 요청의 전송을 위한 멀티캐스트 그룹을 나타낸다. 식별은 저장 장치 세트(1604) 내의 저장 장치(150,1602)에 저장된 객체 또는 파일에 대한 메타데이터와 함께 저장될 수 있다.
일 실시예에서, 패리티-미러 결합 모듈(2106)은 N 개의 데이터 세그먼트의 세트를 하나 또는 그 이상의 패리티-미러 저장 장치(1602) 각각과 결합시키며, 상기 장치(2100)는 클라이언트(114)에 독립적으로, 스트라이프를 위한 패리티 데이터 세그먼트를 계산하고 패리티 데이터 세그먼트를 패리티-미러 저장 장치(1602)에 저장하는 전단 패리티 생성 모듈(2110)을 포함한다. 패리티 데이터 세그먼트는 패리티-미러 저장 장치(1602)에 제공된 N 개의 데이터 세그먼트의 세트로부터 계산된다. 하나 이상의 패리티-미러 저장 장치(1602)가 저장 장치 세트(1604) 내에 포함되는 경우, 전단 패리티 생성 모듈(2110)은 일반적으로 다양한 패리티 데이터 세그먼트를 생성하여, 저장 장치 세트(1604) 내의 둘 또는 그 이상의 저장 장치(150,1602)는 실패할 수 있고, 패리티 데이터 세그먼트 정보는 사용 불가능한 데이터 세그먼트 또는 패리티 데의 복구를 허용할 수 있다.
다른 실시예에서, 전단 패리티 생성 모듈(2110)은 저장 장치 세트(1604) 및/또는 제 3 RAID 관리 장치의 저장 장치(150) 내에서 동작하는 경우, 패리티 데이터 세그먼트를 계산한다. 예를 들어, 스토리지 요청을 전송하는 클라이언트(114)로부터 분리된 서버(112)는 패리티 데이터 세그먼트를 계산할 수 있다. 다른 실시예에서, 전단 패리티 생성 모듈(2110)은 패리티 데이터 세그먼트를 계산하도록 패리티-미러 저장 장치 내에서 구동한다. 예를 들어, 패리티-미러 저장 장치(1602) 내의 스토리지 컨트롤러(152)는 저장 장치 세트(1604)에 의해 형성된 RAID 그룹을 위한 마스터 스토리지 컨트롤러로서 동작할 수 있다.
다른 실시예에서, 전단 패리티 생성 모듈(2110)은 패리티 데이터 세그먼트를 계산하고, 그리고 나서 계산된 패리티 데이터 세그먼트를 미러를 형성하는 제 2 세트의 저장 장치 내의 하나 또는 그 이상의 추가적인 패리티-미러 저장 장치(1604)로 전송한다. 이 실시예는 각각의 저장 장치 세트(1604)에 대해 패리티 데이터 세그먼트의 계산과 결합된 오버헤드가 소진되고, 네트워크(116) 상의 데이터 트래픽이 감소하는 추가적인 장점을 가지므로 유리하다.
일 실시예에서, 상기 장치(2100)는 또한 저장 장치(150)가 사용 불가능하고 사용 불가능한 데이터 세그먼트 또는 사용 불가능한 데이터 세그먼트를 포함한 데이터를 독출하도록 하는 요청이 수신된 경우, 저장 장치 세트(1604)의 저장 장치(150)에 저장된 데이터 세그먼트를 복구하는 데이터 세그먼트 복구 모듈(21112)를 포함한다. 데이터 세그먼트는 저장 장치 세트(1604)의 사용 가능한 저장 장치(150) 상의 데이터 세그먼트, 저장 장치 세트(1604)의 사용 가능한 저장 장치(150,1602) 상의 패리티 데이터 세그먼트와 데이터 세그먼트의 조합, 또는 데이터 세그먼트의 카피를 포함하는 미러 저장 장치를 사용하여 복구된다. 일반적으로, 미러 저장 장치는 N 개의 데이터 세그먼트의 카피를 저장하는 미러 저장 장치 세트의 하나의 저장 장치(150)이다. 데이터 세그먼트 복구 모듈(2112)은 동작하여 저장 장치(150), 패리티-미러 저장 장치(1604), 제 3 RAID 관리 장치, 미러 저장 장치 등으로부터 사용 불가능한 데이터 세그먼트를 복구할 수 있다.
다른 실시예에서, 상기 장치(2100)는 복구된 데이터 세그먼트를 재건 동작으로 대체 저장 장치(150)에 저장하는 데이터 재건 모듈(2114)을 포함한다. 예를 들어, 저장 장치(150)가 실패, 동기(synchronization)의 손실 등으로 인해 사용 불가능하게 된 경우, 데이터 재건 모듈(2114)은 저장 장치(150)를 재건하여 사용 불가능한 저장 장치(150)를 대체한다. 일 실시예에서, 재건된 저장 장치(150)는 사용 가능하게 만들어진 원래의 저장 장치(150)이다.
복구된 데이터 세그먼트는 저장 장치 세트(1604)의 사용 불가능한 저장 장치(150)에 저장된 사용 불가능한 데이터 세그먼트와 매칭된다. 재건 동작은 일반적으로 데이터 세그먼트 및 패리티 데이터 세그먼트 중 하나 또는 그 이상을 대체 저장 장치(150)에 복구시켜 사용 불가능한 저장 장치(150)에 이전에 저장된 데이터 세그먼트 및 패리티 데이터 세그먼트를 매칭시킨다.
일 실시예에서, 복구된 데이터 세그먼트는 재건 동작을 위해 저장 장치 세트(1604)의 사용 가능한 저장 장치(150)의 사용 가능한 데를 사용하여 복구된다. 다른 실시예에서, 복구된 데이터 세그먼트는 재건 동작을 위해 하나 또는 그 이상의 패리티-미러 저장 장치(1604)로부터의 패리티 데이터 세그먼트 및 저장 장치 세트(1604)의 사용 가능한 저장 장치(150)의 사용 가능한 데이터 세그먼트의 조합을 사용하여 복구된다. 다른 실시예에서, 복구된 데이터 세그먼트는 재건 동작을 위해 패리티-미러 저장 장치(1604)로부터 독출된 매칭(matching) 데이터 세그먼트를 사용하여 복구된다.
여전히 다른 실시예에서, 복구된 데이터 세그먼트는 재건 동작을 위해 미러 저장 장치로부터의 매칭 데이터 세그먼트를 사용하여 복구된다. 데이터 재건 모듈(2114)은 클라이언트(114), 제 3 RAID 관리 장치, 저장 장치(150,1602), 미러 저장 장치 등으로부터 수신된 데이터 세그먼트를 구동하고 저장할 수 있다.
다른 실시예에서, 상기 장치(2100)는 복구된 패리티 데이터 세그먼트를 재건 동작으로 대체 저장 장치(1602)에 재건하는 패리티 재건 모듈(2116)을 포함한다. 재건 동작은 실질적으로 데이터 재건 모듈(2114)과 관련하여 기술된 재건 동작과 유사하다. 패리티 재건 모듈(2116)이 복구된 패리티 데이터 세그먼트를 재건하는 것을 제외하고 패리티 재건 모듈(2116)은 데이터 재건 모듈(2114)와 유사하게 동작한다. 복구된 패리티 데이터 세그먼트는 스트라이프에 할당된 사용 불가능한 패리티-미러 저장 장치(1604)에 저장된 사용 불가능한 패리티 데이터 세그먼트를 매칭시킨다.
다양한 실시예에서, 패리티 데이터 세그먼트는 패리티-미러 저장 장치(1604)에 저장된 패리티 데이터 세그먼트를 미러링된 저장 장치 세트로 카피함으로써, 패리티-미러 저장 장치(1604)로부터의 패리티 데이터 세그먼트를 저장 장치 세트(1604)로 카피함으로써(사용 불가능한 패리티 데이터 세그먼트와 동일한 경우), 저장 장치 세트(1604)의 사용 가능한 저장 장치(150,1602) 및 데이터 세그먼트의 카피를 포함하는 미러 저장 장치에 저장된 N 개의 데이터 세그먼트 및 패리티 데이터 세그먼트 중 하나 또는 그 이상을 사용하여 패리티 데이터 세그먼트를 생성함으로써, 복구될 수 있다.
데이터 재건 모듈(2116)은 클라이언트(114), 제 3 RAID 관리 장치, 저장 장치(150), 미러 저장 장치 등에 구비되어 동작하고 복구된 데이터 세그먼트를 저장할 수 있다.
유리하게, 상기 장치(2100)는 저장 장치(150,1602) 내의 데이터를 여기에 기술된 전단 분산된 RAID 동작에 제공된 파티션으로 저장하는 것으로 제한되지 않는다. 대신, 자발적인 저장 장치(예컨대 150a)가 클라이언트(114)로부터 독립적으로 스토리지 요청을 수신하여, 스트라이핑 결합 모듈(2104), 패리티-미러 결합 모듈(2106), 및 전단 패리티 생성 모듈(2110)에 의한 데이터 저장을 위해 사용 가능한 저장 장치(150a)의 하나 또는 그 이상의 영역에 RAID되거나 RAID되지 않은 데이터를 저장할 수 있다.
일 실시예에서, 스토리지 요청 리시버 모듈(2102)에 의해 수신되거나 스토리지 요청 트랜스미터 모듈(2108)에 의해 전송된 하나 또는 그 이상의 스토리지 요청은 스트라이프의 저장 장치 세트(1604)를 포함하는 저장 장치(150)를 식별한다. 유리하게, 스토리지 요청에서 저장 장치 세트(1604)의 저장 장치(150)를 식별하는 것은 마스터 컨트롤러가 동작하지 않는 경우 구동할 수 있도록 백업(backup) RAID 컨트롤러를 구현한다. 예를 들어, 저장 장치 세트(1604)의 저장 장치(150)가 스토리지 요청에서 식별되고 마스터 컨트롤러가 패리티-미러 저장 장치(1604)에 구비되고 사용 불가능한 경우, 다른 패리티-미러 저장 장치(1602) 또는 N 개의 저장 장치(150a-n) 중 다른 저장 장치가 마스터 컨트롤러로 될 수 있다.
일 실시예에서, 상기 장치(2100)는 각각의 스트라이프에 대해, 저장 장치 세트(1604) 내의 저장 장치(150)가 스트라이프를 위한 패리티-미러 저장 장치(1602)로 지정되도록 교대하는(alternate) 패리티 교대 모듈(2118)을 포함한다. 패리티 교대 모듈(2118)의 장점은 상술된 바와 같다. 다른 실시예에서, 저장 장치 세트(1604)의 저장 장치(150)는 피어(peer)의 그룹을 형성하고 상기 장치(2100)는 저장 장치 세트(1604)의 저장 장치(150,1602) 내에서 스토리지 요청을 전송하고 수신하는 피어-투-피어(peer-to-peer) 통신 모듈(2120)을 포함한다. 피어-투-피어 통신 모듈(2120)은 또한 저장 장치 세트(1604)의 외부에 있는 피어 장치와 스토리지 요청을 전송하고 수신할 수 있다.
바람직한 실시예에서, 스토리지 요청은 상기 장치(2100)의 모듈들(2102-2120)을 사용하여 저장 장치 세트(1604)의 저장 장치(150,1602)를 거쳐 객체의 데이터를 스트라이핑함으로써 객체를 저장하는 객체 요청이다. 다른 실시예에서, 저장 장치 세트(1604)의 자발적인 저장 장치(150,1602) 중 하나 또는 그 이상은 제 1 객체 또는 파일의 적어도 일부를 위한 제 1 RAID 그룹 내에 배치되고, 제 2 객체 또는 파일의 적어도 일부를 위한 제 2 RAID 그룹 내에 배치된다. 예를 들어, 하나의 저장 장치(150a)는 하나 또는 그 이상의 스트라이프에 대한 저장 장치 세트(1604)를 위한 마스터 RAID 컨트롤러일 수 있고, 제 2 저장 장치(150b)는 저장 장치 세트의 저장 장치(150)의 일부 또는 전부를 포함하는 RAID 그룹을 위한 마스터 RAID 컨트롤러일 수 있다. 유리하게, 상기 장치(2100)는 저장 장치(150,1602)의 그룹화에 대한 유연성이 다양한 클라이언트(114)를 위한 RAID 그룹을 형성하도록 한다.
도 12는 본 발명에 따른 전단 분산된 RAID를 위한 방법(2200)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(2200)은 개시하여(2202) 스토리지 요청 리시버 모듈(2102)이 데이터를 저장 장치 세트(1604)의 N 개의 저장 장치(150a-n)에 저장시키는 스토리지 요청을 수신한다(2204). 스트라이핑 결합 모듈(2104)은 데이터를 위한 스트라이프 패턴을 계산하고(2206), N 개의 데이터 세그먼트 각각을 N 개의 저장 장치(150a-n) 중 하나와 결합시킨다.
패리티-미러 결합 모듈(2106)은 N 개의 데이터 세그먼트의 세트를 하나 또는 그 이상의 패리티-미러 저장 장치(1602)와 결합시킨다(2210). 스토리지 요청 트랜스미터 모듈(2108)은 하나 또는 그 이상의 스토리지 요청을 저장 장치 세트(1604) 내의 각각의 저장 장치(150,1602)로 전송한다(2212). 각각의 스토리지 요청은 스토리지 요청을 수신하는 저장 장치(150)와 결합된 하나 또는 그 이상의 데이터 세그먼트를 저장 장치(150)에 저장하기에 충분하다. 그리고 나서, 데이터의 데이터 세그먼트는 스토리지 요청에 의해 지시된 대로, DMA, RDMA, 방송, 멀티캐스트, 등을 사용하여 저장 장치 세트(1604)의 저장 장치(150,1602)로 전송된다. 선택적으로, 전단 패리티 생성 모듈(2110)은 스트라이프를 위한 패리티 데이터 세그먼트를 계산하고(2214), 상기 방법(2200)은 종료한다(2216).
공유되고, 전단 분산된 RAID(Shared, Front-ended, Distributed RAID)
종래의 RAID는 각각의 장치의 적어도 일부가 RAID로 제공되고 RAID 그룹을 형성하는 디스크 또는 다른 저장 장치의 어레이를 이용한다. RAID 컨트롤러는 RAID 그룹으로의 스토리지 요청을 관리한다. 리던던트 시스템에 대해, RAID 컨트롤러는 마스터 RAID 컨트롤러가 실패하거나 사용 불가능한 경우, 인계받도록 준비된 백업 RAID 컨트롤러를 구비한다. RAID 내에 저장된 동일한 데이터에 액세스하도록 추구하는 다수의 클라이언트로부터의 스토리지 요청은 일반적으로 도착 순서에 따라 순차적으로 실행된다.
도 10, 도 11 및 도 12에 각각 도시된 시스템(1600), 장치(2100) 및 방법(2200)과 관련하여 상술된 바와 같이, 전단의 분산된 RAID 시스템은 각각이 분산된 RAID 컨트롤러로서 동작할 수 있는 스토리지 컨트롤러(152)를 포함할 수 있는 자발적인 저장 장치(150)를 포함하며, 저장 장치(150)는 각각이 다수의 클라이언트(114)를 섬기는 다수의 중복되는 RAID 그룹에 구성될 수 있다. 가끔씩, 두 개의 클라이언트(114)가 동일한 데이터를 액세스하도록 추구할 수 있다. 하나의 스토리지 요청이 먼저 도착하고 실행된 경우, 일반적으로 데이터의 불일치(inconsistency)는 발생하지 않는다. 반면, 동일한 데이터에 대한 둘 또는 그 이상의 스토리지 요청이 동시 또는 거의 동시에 도달한 경우, 데이터는 오류가 발생할 수 있다.
예를 들어, 데이터가 RAID 그룹 내의 네 개의 저장 장치(150)에 저장되고, 저장 장치(150) 중 하나가 패리티-미러 저장 장치(1602)로 할당되고, 제 1 클라이언트(114)가 스토리지 요청을 RAID 컨트롤러로서 동작하는 제 1 스토리지 컨트롤러(150a)로 전송하고, 제 2 클라이언트(114)가 제 2 스토리지 요청을 제 2 RAID 컨트롤러로서 동작하는 제 2 저장 장치(150a)로 전송하고, 두 개의 스토리지 요청은 동일한 데이터를 액세스하는 경우, 제 1 저장 장치(150a)는 제 1 저장 장치(150a) 상의 스토리지 요청의 실행을 개시할 수 있고 그리고 나서 RAID 그룹의 다른 저장 장치(150b-n)에 대해 개시할 수 있다. 동시에, 제 2 저장 장치(150b) 상의 제 2 RAID 컨트롤러는 다른 저장 장치(예컨대 150b)에서 제 2 스토리지 요청의 실행을 개시할 수 있고, 그리고 나서 RAID 그룹의 남은 저장 장치(150a,c-n)에 대해 개시할 수 있다. 이러한 실행의 미스매치는 저장 장치(150) 간의 물리적 거리, 실행 시간의 불일치 등에 의해 야기될 수 있다. 결과는 오류가 발생된 데이터일 수 있다.
동일한 데이터의 액세스를 추구하는 동시의 스토리지 요청을 다루는 공유되고, 전단의, 분산된 RAID를 위한 시스템, 장치, 및 방법을 필요로 한다. 유리하게, 상기 시스템, 장치 및 방법은 데이터에 대한 액세스를 제어하고, 하나의 스토리지 요청은 제 2 스토리지 요청이 실행되기 전에 실행된다.
도 10은 프로그레시브(progressive) RAID 및 전단 분산된(front-end distributed) RAID에 추가하여, 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 시스템(1600)으로서 동작하는 일 실시예를 설명하는 개략적인 블록도이다. 프로그레시브 RAID 및 전단 분산된 RAID와 관련된 도 10에 도시된 컴포넌트를 위한 상기 기술은 또한 공유되고, 전단 분산된 RAID에도 적용 가능하다. 전단 분산된 RAID와 같이, 저장 장치 세트(1604)는 RAID 그룹을 형성하고 자발적이고, 네트워크(116)을 통해 클라이언트(114)로부터 스토리지 요청을 독립적으로 수신하고 서비스할 수 있는 저장 장치(150)를 포함한다.
공유되고, 전단 분산된 RAID에 관하여, 상기 시스템(1600)은 둘 또는 그 이상의 클라이언트(114)를 포함하여, 둘 또는 그 이상의 클라이언트(114) 각각이 동일한 데이터에 관련한 스토리지 요청을 전송한다. 스토리지 요청은 동시에 도달하여, 하나의 스토리지 요청은 다른 스토리지 요청의 도달 전에 완료되지 않는다. 저장 장치 세트(1604) 내의 저장 장치(150) 사이에서, 하나 또는 그 이상은 스트라이프를 위한 패리티-미러 저장 장치(1602)로서 지정된다. 일반적으로, 하나 또는 그 이상의 패리티-미러 저장장치(1602)는 실질적으로 다른 저장 장치(150)과 유사하게 기능한다.
지정된 패리티-미러 저장장치(1602)가 저장 장치 세트(1604)의 저장 장치(150) 사이에서 교대되는 일반적인 구성에서, 패리티-미러 저장장치(1602)는 필수적으로 다른 저장 장치(150)와 동일한 특성을 구비하며, 이는 이들이 또한 비-패리티-미러(non-parity-mirror) 저장 장치로서 동작해야하기 때문이다. 유사한 특성은 상술한 바와 같은 RAID 그룹 내의 동작 및 독립적인 클라이언트(114) 통신을 위한 자발적인 동작에 관한 것이다. 다양한 실시예에서, 저장 장치 세트(1604)의 저장 장치(150)는 기술된 RAID 환경 내의 기능과 관련되지 않은 다른 양상에서 상이할 수 있다.
저장 장치 세트(1604)의 저장 장치(150)는 하나 또는 그 이상의 서버(112) 내에 홀로 또는 그룹으로 구성될 수 있거나, 각각이 서버(112) 내에 구비될 수 있거나, 하나 또는 그 이상의 서버(112)를 통해 액세스될 수 있다. 하나 또는 그 이상의 클라이언트(114)는 하나 또는 그 이상의 저장 장치(150)를 포함하는 서버(112) 내에 구비될 수 있거나, 분리된 서버(112) 내에 구비될 수 있거나, 컴퓨터 네트워크(116) 등을 통해 저장 장치(150)에 액세스하는 컴퓨터, 워크스테이션, 랩탑 등에 구비될 수 있다.
일 실시예에서, 네트워크(116)는 시스템 버스 및 시스템 버스를 사용하여 통신하는 저장 장치 세트(1604)의 저장 장치(150,1602) 중 하나 또는 그 이상을 포함한다. 예를 들어, 시스템 버스는 PCI-e 버스, 직렬 ATA(Serial Advanced Technology Attachment) 버스, 병렬(parallel) ATA 등일 수 있다. 다른 실시예에서, 시스템 버스는 SCSI(Small Computer System Interface), 파이어와이어(FireWire), 파이버 채널, ISB, PCIe-AS, 인피니밴드 등과 같은 외부 버스이다. 당업자는 자발적이며, 하나 또는 그 이상의 네트워크(116)를 통해 클라이언트(114)로부터 스토리지 요청을 독립적으로 수신하고 서비스할 수 있는 저장 장치(150)를 구비한 다른 시스템(1600) 구성을 파악할 것이다.
도 13은 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 장치(2300)의 일 실시예를 설명하는 개략적인 블록도이다. 일 실시예에서, 상기 장치(2300)는 다수의 스토리지 요청 리시버 모듈(2302), 스트라이핑 모듈(2304), 패리티-미러 모듈(2306), 시퀀서(sequencer) 모듈(2308), 마스터 검증(validation) 모듈(2310), 마스터 결정 모듈(2312), 마스터 에러 모듈(2314), 패리티 생성 모듈(2316), 및 패리티 교대 모듈(2318)을 포함하며, 이는 이하 기술된다.
상기 장치(2300)는 적어도 두 개의 스토리지 요청을 적어도 두 개의 클라이언트(114)로부터 수신하여 데이터를 저장 장치 세트(1604)의 저장 장치(150)에 저장하는 다수의 스토리지 요청 리시버 모듈(2302)를 포함한다. 데이터는 파일 또는 객체의 데이터를 포함한다. 상기 장치에 중요한 스토리지 요청은 각각 데이터의 적어도 일부를 공통으로 구비하고, 또한 이는 도달에 의해 동시적인(concurrent) 스토리지 요청이며, 하나의 스토리지 요청은 다른 스토리지 요청의 도달 전에 완료되지 않는다. 이러한 동시적인 스토리지 요청은 전단 분산된 RAID 시스템(1600) 내의 공통 데이터에 대한 오류 발생의 위험을 가진다. 일 실시예에서, 동시적인 스토리지 요청은 하나의 클라이언트(114)로부터 올 수 있다. 다른 실시예에서, 동시적인 스토리지 요청은 둘 또는 그 이상의 클라이언트(114)로부터 올 수 있다.
다수의 스토리지 요청은 저장 장치 세트(1604)의 저장 장치(150)에 저장된 하나 또는 그 이상의 데이터 세그먼트를 업데이트할 수 있으며, 여기서 이전에 저장된 데이터는 스트라이핑 모듈(2304)에 의해 저장 장치 세트(1604)의 저장 장치(150)에 저장된 데이터 세그먼트로 스트라이프될 수 있다. 일 실시예에서, 스토리지 요청은 처음으로 데이터를 RAID 그룹으로 기록한다. 이 경우, 데이터는 일반적으로 임의의 장소에 존재되고 하나 또는 그 이상의 클라이언트(114)에 의해 액세스되고 그리고 나서, 하나의 스토리지 요청은 데이터를 RAID 그룹으로 카피하는 반면 다른 스토리지 요청은 동시적으로 데이터를 액세스한다.
다수의 스토리지 요청은 저장 장치 세트(1604)의 저장 장치(150)에 저장된 하나 또는 그 이상의 데이터 세그먼트를 업데이트하는 하나의 요청 및 데이터의 적어도 일부를 공통으로 타겟팅(targeting)하는 하나 또는 그 이상의 독출 요청을 포함할 수 있다. 업데이트 요청이 완료되지 않은 경우, 그리고 나서 저장 장치 세트(1604)의 저장 장치(150)로부터의 독출 요청 응답은 데이터에 오류를 발생시키는 기-존재(pre-existing)하고 업데이트된 데이터의 조합을 포함할 수 있다.
상기 장치(2300)는 각각의 동시적인 스토리지 요청에 대해, 데이터를 위한 스트라이프 패턴을 계산하고 스트라이프의 N 개의 데이터 세그먼트를 저장 장치 세트(1604) 내의 N 개의 저장 장치(150a-n)로 기록하는 스트라이핑 모듈(2304)을 포함한다. 스트라이프 패턴은 하나 또는 그 이상의 스트라이프를 포함하고 각각의 스트라이프는 N 개의 데이터 세그먼트의 세트를 포함한다. N 개의 데이터 세그먼트 각각은 저장 장치 세트(1604) 내의 분리된 저장 장치(150)로 기록되고 스트라이프에 할당된다. 상기 장치(2300)는 각각의 동시적인 스토리지 요청에 대해, 스트라이프의 N 개의 데이터 세그먼트의 세트를 패리티-미러 저장장치(1602)로 지정된 저장 장치 세트(1604) 내의 저장 장치(150)로 기록하는 패리티-미러 모듈(2306)을 포함한다. 패리티-미러 저장장치(1602)는 N 개의 저장 장치(150a-n)에 추가된다.
스트라이핑 모듈(2304)은 또한 하나 또는 그 이상의 저장 장치(150a-n)의 아이덴티티(identity)를 파일 또는 객체의 일부인 하나 또는 그 이상의 데이터 세그먼트로부터 계산한다.
상기 장치(2300)는 제 2 클라이언트(114)로부터의 제 2 스토리지 요청의 실행 전에, 제 1 클라이언트(114)로부터의 제 1 스토리지 요청의 완료를 보증하는 시퀀서(sequencer) 모듈(2308)을 포함하며, 여기서 적어도 두 개의 동시적인 스토리지 요청은 제 1 및 제 2 스토리지 요청을 포함한다. 다른 실시예에서, 시퀀서 모듈(2308)은 둘 또는 그 이상의 다른 동시적인 스토리지 요청을 실행하기 전에, 제 1 스토리지 요청의 완료를 보증한다. 유리하게, 시퀀서 모듈(2308)은 동시적인 스토리지 요청의 순차적인 실행을 구현하여 데이터의 오류 발생을 방지한다. 일 실시예에서, 시퀀서 모듈(2308)은 모든 스토리지 요청이 데이터를 위해 액세스해야하는 마스터 컨트롤러를 사용함으로써, 락킹 시스템(locking system), 이단계 커밋(two-phase commit), 또는 알려진 다른 수단을 사용함으로써, 동시적인 스토리지 요청의 실행을 조정한다. 시퀀서 모듈(2308)에 의해 사용되는 다른 방법은 이하 기술된다.
일 실시예에서, 시퀀서 모듈(2308)은 제 2 스토리지 요청의 실행 전에 제 1 스토리지 요청과 함께 스토리지 요청을 수신하는 저장 장치 세트(1602)의 저장 장치(150)의 각각으로부터 확인응답(acknowledgement)을 수신함으로써, 동시적인 스토리지 요청의 실행 전에 제 1 스토리지 요청의 완료를 보증한다. 일반적으로, 확인응답은 스토리지 요청의 완료를 확인한다. 일 실시예에서, 스토리지 요청에 의해 영향받는 저장 장치(150) 각각은 시퀀서 모듈(2308)이 제 2 스토리지 요청의 실행을 개시하기 전에, 저장 장치(150) 각각으로부터 수신된 확인응답이 기록된다.
일 실시예에서, 스토리지 요청의 완료는 단일 저장 장치(예컨대 150a) 상에서 진행중인 제 2 스토리지 요청의 일부의 실행 전, 동일한 저장 장치(150a)로 지시된 제 1 스토리지 요청의 일부의 완료를 포함할 수 있다. 시퀀서 모듈(2308)은 저장 장치(150) 상의 스토리지 요청의 일부의 완료를 독립적으로 검증할 수 있다. 이 실시예에서, 제 1 스토리지 요청과 관련된 데이터 세그먼트의 기록은 제 1 스토리지 요청의 모든 데이터 세그먼트가 완료될 때까지 보류될 필요는 없다. 시퀀서 모듈(2308)은 저장 장치 세트(1602)의 저장 장치(150)에서 일어나는 다양한 실행을 조정하여, 데이터에 오류가 발생하지 않도록 보증할 수 있다.
일 실시예에서, 스토리지 요청의 완료의 확인응답은 스트라이핑 모듈(2304) 및 패리티-미러 모듈(2306) 각각이 스토리지 요청과 관련된 데이터 세그먼트를 저장 장치 세트(1602)의 저장 장치(150)에 기록한 후에 수신된다. 다른 실시예에서, 스토리지 요청의 완료의 확인응답은 스트라이핑 모듈(2304) 및 패리티-미러 모듈(2306) 각각이 스토리지 요청과 관련된 데이터 세그먼트를 저장 장치 세트(1602)의 저장 장치(150)에 기록하고 각각의 저장 장치(150,1602)가 데이터 세그먼트가 기록되었음을 확인한 후에, 수신된다.
일 실시예에서, 시퀀서 모듈(2308)은 먼저 도달한 동시적인 요청 중에서 스토리지 요청을 선택함으로써, 실행을 위한 제 1 스토리지 요청을 선택한다. 다른 실시예에서, 시퀀서 모듈(2308)은 가장 빠른 타임스탬프를 가진 스토리지 요청을 선택함으로써 실행을 위한 제 1 스토리지 요청을 선택한다. 다른 실시예에서, 시퀀서 모듈(2308)은 임의의 선택 기준(criteria)을 사용하여 스토리지 요청을 선택함으로써, 실행을 위한 제 1 스토리지 요청을 선택한다. 예를 들어, 시퀀서 모듈(2308)은 높은 우선순위로 클라이언트(114)를 요청하는 방법으로 마크된 스토리지 요청을 선택할 수 있거나, 호의적인(favored) 클라이언트(114)로부터의 스토리지 요청 등을 선택할 수 있다. 당업자는 시퀀서 모듈(2308)이 임의의 선택 기준을 사용하여 제 1 스토리지 요청을 선택할 수 있는 다른 방법을 파악할 것이다.
일 실시예에서, 스토리지 요청 리시버 모듈(2302), 스트라이핑 모듈(2304), 패리티-미러 모듈(2306), 및 시퀀서 모듈(2308)은 동시적인 스토리지 요청을 제어하고 서비스하는 마스터 컨트롤러(미도시)의 일부이다. 마스터 컨트롤러의 전부 또는 일부는 클라이언트(114), 제 3 RAID 관리 장치, 저장 장치 세트(1602)의 저장 장치(150), 또는 저장 장치(150) 내의 스토리지 컨트롤러(152) 내에 구비되어 동작할 수 있다. 마스터 컨트롤러를 사용하여 데이터를 위한 서비스 요청을 실행함으로써, 시퀀서 모듈(2302)은 데이터로 지시되는 스토리지 요청을 파악할 수 있고, 그리고 나서 동시적인 스토리지 요청을 파악할 수 있고, 그리고 나서 저장 장치 세트의 저장 장치(150)에 저장된 데이터에 오류가 발생하지 않도록 하는 방식으로 동시적인 스토리지 요청을 정리할 수 있다. 당업자는 데이터에 지시된 스토리지 요청의 서비스를 제어하는 마스터 컨트롤러의 다른 실시예를 파악할 것이다.
다른 실시예에서, 마스터 컨트롤러는 하나 또는 그 이상의 클라이언트(114)로부터 동시적인 스토리지 요청을 서비스할 수 있는 둘 또는 그 이상의 마스터 컨트롤러의 그룹의 일부이며, 여기서 스토리지 요청은 저장 장치 세트(1602)의 저장 장치(150)에 저장된 데이터로 지시된다. 예를 들어, 마스터 컨트롤러는 제 1 클라이언트(114)를 위한 스토리지 요청을 서비스할 수 있고, 제 2 마스터 컨트롤러는 제 2 클라이언트(114)를 위한 스토리지 요청을 서비스할 수 있다. 제 1 및 제 2 클라이언트(114)는 둘 다 저장 장치 세트(1602)의 저장 장치(150)에 저장된 데이터로의 액세스를 구비할 수 있으며, 그 결과 동시적인 스토리지 요청을 가능하게 한다. 하나의 마스터 컨트롤러는 하나의 저장 장치(150a)의 일부일 수 있는 반면, 다른 마스터 컨트롤러는 제 2 저장 장치(150b)의 일부일 수 있다. 다른 실시예에서, 제 1 마스터 컨트롤러는 제 1 저장 장치 세트(1604a)의 일부일 수 있고, 제 2 마스터 컨트롤러는 제 2 저장 장치 세트(1604b)의 일부일 수 있다.
마스터 컨트롤러가 저장 장치 세트(1604)의 저장 장치(150)를 액세스하는 마스터 컨트롤러의 그룹의 일부인 경우, 상기 장치(2300)는 수신된 스토리지 요청을 서비스하는 마스터 컨트롤러가 수신된 스토리지 요청의 실행 전에, 하나 또는 그 이상의 동시적인 스토리지 요청의 실행에 앞서 스토리지 요청의 실행을 제어하고 있음을 확인하는 마스터 검증 모듈(2310)을 포함할 수 있다. 이 실시예에서, 동시적인 스토리지 요청은 다른 마스터 컨트롤러에 의해 수신되고, 서비스 요청은 다른 마스터 컨트롤러에 의해 수신된 동시적인 스토리지 요청과 데이터의 적어도 일부에서 공통된다.
예를 들어, 마스터 컨트롤러는 스토리지 요청을 수신할 수 있고, 그리고 나서 마스터 검증 모듈(2310)은 스토리지 요청의 실행 전에 다른 마스터 컨트롤러를 폴링(poll)하여 마스터 컨트롤러가 여전히 스토리지 요청의 데이터를 위한 마스터 컨트롤러인지 여부를 검증할 수 있다. 검증의 일부는 마스터 컨트롤러가 서로 간에 통신할 수 있어, 지정된 마스터 컨트롤러가 스토리지 요청의 실행 전에 검증되었음에 대한 검증을 포함할 수 있다. 이는 하나의 전단 RAID 컨트롤러가 마스터로 지정되고 다른 전단 RAID 컨트롤러가 백업으로 지정된 경우 유용할 수 있다. 다른 예에서, 마스터 컨트롤러는 파일 또는 객체로부터 데이터 세그먼트를 독출하는 스토리지 요청을 수신할 수 있고, 그리고 나서 마스터 검증 모듈(2310)은 다른 마스터 컨트롤러를 폴링하여 파일 또는 객체에 대한 어떠한 업데이트도 진행 중이지 않음을 검증할 수 있다. 다른 예에서, 마스터 컨트롤러는 스토리지 요청을 위한 데이터의 제어를 획득하기 위해 마스터 검증 모듈을 사용할 수 있다.
마스터 컨트롤러가 여전히 스토리지 요청의 실행에 대한 마스터임을 검증하는 한 방법은 컨트롤러가 진행될 스토리지 요청에 대한 마스터임을 투표하도록 두 개의 장치/컨트롤러가 사용 가능해야 하는 3 웨이 폴링 방법(three-way polling scheme)을 사용한다. 상기 방법은 마스터가 되도록 경쟁하는 컨트롤러에 대한 제 3 장치(third-party device)를 사용하고, 어떠한 컨트롤러가 마스터가 되도록 할당되었는지의 기록을 보유한다. 이러한 마스터 검증 장치는 다른 컨트롤러일 수 있고, 서버 내의 클라이언트(114) 등일 수 있고, 마스터 컨트롤러로서 동작할 수 있는 그룹 내의 컨트롤러와 통신할 수 있다. 그리고 나서 마스터 검증 모듈(2310)의 일부는 마스터 검증 모듈(2310)의 일부가 각각의 컨트롤러 내에 구비되어 마스터 검증 장치에 구비될 수 있다.
일 예에서, 상기 시스템(1600)은 제 1 전단 분산된 RAID 컨트롤러(제 1 컨트롤러), 제 2 전단 분산된 RAID 컨트롤러(제 2 컨트롤러), 및 분리된 마스터 검증 장치를 포함할 수 있으며, 제 1 및 제 2 컨트롤러 각각은 마스터일 수 있다. 제 1 및 제 2 컨트롤러 및 마스터 검증 장치는 서로 간에 모두 통신한다. 마스터 검증 모듈(2310)은 제 1 컨트롤러를 마스터 컨트롤러로 지정할 수 있고, 제 2 컨트롤러를 저장 장치 세트(1604)의 저장 장치(150)에 저장된 데이터를 위한 백업으로 지정할 수 있고, 마스터 검증 모듈(2310)은 컨트롤러 및 마스터 검증 장치에 대한 마스터 정보를 저장할 수 있다. 통신이 제 1 컨트롤러, 제 2 컨트롤러 및 마스터 검증 장치 간에 유지되는 한, 마스터 검증 모듈(2310)은 제 1 컨트롤러가 마스터임을 확인할 수 있다.
제 1의, 마스터 컨트롤러가 스토리지 요청를 수신하고 제 2의, 백업 컨트롤러가 사용 불가능하게 되거나 제 1 컨트롤러 및 마스터 검증 장치와의 통신을 잃어버린 경우, 마스터 검증 모듈(2310)은 마스터 검증 장치와 제 1의, 마스터 컨트롤러 간의 통신을 통해 제 1 컨트롤러가 여전히 마스터임을 검증할 수 있고, 제 1 컨트롤러가 실제로 마스터 컨트롤러임을 제 1 컨트롤러와 마스터 검증 장치 둘 모두가 확인하므로, 마스터 검증 모듈(2310)은 스토리지 요청이 진행되도록 허용할 수 있다. 마스터 검증 모듈(2310)을 통해 제 2 컨트롤러가 마스터가 아님을 파악하므로, 제 2 백업 컨트롤러에 의해 수신된 스토리지 요청은 진행되지 않을 것이다.
반면, 제 1의, 마스터 컨트롤러가 사용 불가능하거나 제 2의, 백업 컨트롤러 및 마스터 검증 장치와 통신할 수 없고, 제 2의, 백업 컨트롤러가 스토리지 요청을 수신한 경우, 마스터 검증 모듈(2310)은 제 2 컨트롤러 및 마스터 검증 모듈 둘 모두가 제 1 컨트롤러와 통신할 수 없음을 파악할 수 있고, 마스터 검증 모듈(2310)은 제 2의, 백업 컨트롤러를 마스터로 지정할 수 있고 스토리지 요청은 진행될 수 있다. 그리고 나서, 마스터 지정의 변경은 제 2 컨트롤러에 기록될 수 있다.
제 1 컨트롤러가 동작할 수 있고, 단순히 제 2 컨트롤러 및 마스터 검증 장치와의 통신을 잃은 경우, 제 1 컨트롤러에 의해 수신된 데이터를 위한 임의의 스토리지 요청은 실행되지 않을 것이다. 통신이 복구된 경우, 제 1 컨트롤러는 여전히 스토리지 요청을 실행하지 않을 것이며, 이는 제 2 컨트롤러 및 마스터 검증 장치 둘 모두가 제 2 컨트롤러를 마스터로서 인식하기 때문이다. 물론 이러한 마스터 지정은 리셋될 수 있다. 당업자는 마스터 지정을 마스터 컨트롤러들 중 하나로 할당하고 재할당하는 다양한 정적 및 동적 수단을 파악할 것이다.
마스터 검증 장치(master verification device)가 사용 불가능하고 제 1 스토리지 컨트롤러가 스토리지 요청을 수신한 경우, 제 1 및 제 2 컨트롤러에서 동작하는 마스터 검증 모듈(2310)의 일부는 제 1 컨트롤러가 마스터이고 스토리지 요청이 진행될 수 있음을 검증할 수 있다. 제 2 컨트롤러가 스토리지 요청을 수신한 경우, 제 1 및 제 2 컨트롤러에서 동작하는 마스터 검증 모듈(2310)의 일부는 제 1 컨트롤러가 마스터이고 스토리지 요청은 진행되지 않을 것임을 확인할 수 있다. 다른 실시예에서, 둘 이상의 컨트롤러는 폴링 구조(polling scheme)의 일부이다. 당업자는 스토리지 요청의 실행 전에 컨트롤러가 마스터임을 마스터 검증 모듈(2310)이 확인할 수 있는 다른 방법을 파악할 것이다.
다른 실시예에서, 상기 장치(2300)는 마스터 결정 모듈(2312)을 포함한다. 스토리지 요청을 전송하기 전에, 마스터 결정 모듈(2312)은 마스터 결정 요청을 마스터 컨트롤러의 그룹으로 전송한다. 그리고 나서 마스터 컨트롤러의 그룹은 어떠한 컨트롤러가 스토리지 요청을 위한 마스터로서 지정되었는지 식별하고, 마스터 컨트롤러를 식별하는 응답을 마스터 결정 모듈(2312)로 다시 전송한다. 마스터 결정 모듈(2312)은 스토리지 요청을 위한 마스터 컨트롤러의 식별을 수신하고, 요청 장치가 스토리지 요청을 지정된 마스터 컨트롤러로 전송하도록 지시한다. 일 실시예에서, 마스터 결정 모듈(2312)은 클라이언트(114) 내에 구비되어 동작한다. 다른 실시예에서, 마스터 결정 모듈(2312)은 제 3 RAID 관리 장치 내에 구비되어 실행된다. 다른 실시예에서, 마스터 검증 모듈(2312)은 저장 장치(150)에 구비된다. 다른 실시예에서, 마스터 검증 모듈은 둘 또는 그 이상의 저장 장치(150) 사이에 분산된다.
더한 실시예에서, 상기 장치(2300)는 에러 지시(error indication)를 반환하는 마스터 에러 모듈(2314)을 포함한다. 일 실시예에서, 마스터 컨트롤러에 의해 제어되는 다수의 스토리지 요청 리시버 모듈(2302)이 마스터 컨트롤러에 의해 제어되지 않는 스토리지 요청을 수신하는 경우, 마스터 에러 모듈(2314)은 에러 지시를 반환한다.
다른 실시예에서, 마스터 컨트롤러가 스토리지 요청의 실행의 완료 시기에 더 이상 결정된 마스터가 아님을 마스터 결정 모듈(2312) 또는 마스터 검증 모듈(2310)이 마스터 컨트롤러가 결정한 경우, 마스터 에러 모듈(2314)은 에러 지시를 반환한다. 이 실시예는 일반적으로 마스터 컨트롤러가 스토리지 요청을 실행하기 시작하고 그룹의 다른 마스터 컨트롤러와의 통신을 잃거나, 또는 폴링 구조에서, 다른 마스터 컨트롤러 및 마스터 검증 장치와의 통신을 잃은 경우 발생한다. 다른 실시예에서, 마스터 컨트롤러에 의해 제어되는 다수의 스토리지 요청 리시버 모듈(2302)이 마스터 컨트롤러에 의해 제어되지 않는 스토리지 요청을 수신한 경우, 마스터 에러 모듈(2312)은 에러 지시를 반환한다.
다른 실시예에서, 마스터 컨트롤러는 하나 또는 그 이상의 2차(secondary) 마스터 컨트롤러로의 스토리지 요청을 제어한다. 2차 마스터 컨트롤러 각각은 저장 장치 세트(1604)의 저장 장치(150,1602)에 저장된 데이터를 위한 스토리지 요청을 제어한다. 다른 실시예에서, 2차 마스터 컨트롤러를 제어하는 마스터 컨트롤러는 또한 저장 장치 세트(1604)의 저장 장치(150,1602)에 저장된 데이터로 지시되는 스토리지 요청을 위한 2차 마스터 컨트롤러이다.
다른 실시예에서, 마스터 컨트롤러는 하나 또는 그 이상의 2차 마스터 컨트롤러로의 스토리지 요청을 제어하고, 각각의 2차 마스터 컨트롤러는 2차 마스터 컨트롤러에 고유한 저장 장치 세트의 저장 장치(150)에 저장된 데이터를 위한 스토리지 요청을 제어한다. 상기 장치(2300)는 유연하여 임의의 마스터 컨트롤러는 2차 마스터 컨트롤러로 동작하는 다른 컨트롤러에 대한 마스터가 될 수 있다. 일부 2차 마스터 컨트롤러는 저장 장치 세트(1604)를 공유할 수 있고 다른 2차 마스터 컨트롤러는 다른 저장 장치 세트를 제어할 수 있다. 다른 실시예에서, 마스터 컨트롤러는 패리티-미러 저장 장치(1602) 또는 N 개의 저장 장치(150a-n) 중 하나일 수 있다.
다른 실시예에서, 마스터 컨트롤러가 오프라인에 있거나 또는 지정된 마스터로 결정될 수 없는 경우, 2차 마스터 컨트롤러는 마스터 컨트롤러가 될 수 있다. 당업자는 하나 또는 그 이상의 2차 마스터 컨트롤러 사이에서 마스터 지정을 할당하고 재할당하는 다양한 정적 및 동적 수단을 파악할 것이다.
바람직한 실시예에서, 상기 장치(2300)는 스트라이프를 위한 패리티 데이터 세그먼트를 계산하고 패리티 데이터 세그먼트를 패리티-미러 저장 장치(1602)에 저장하는 패리티 생성 모듈(2316)을 포함한다. 패리티 스트라이프는 패리티-미러 저장 장치(1602) 상의 N 개의 데이터 세그먼트의 세트로부터 계산된다. 이 실시예는 RAID 5, RAID 6 또는 일부 다른 RAID 레벨에서 일반적이지만, 일반적으로 RAID 0, RAID 1, RAID 10 등에는 포함되지 않는다.
다른 바람직한 실시예에서, 상기 장치(2300)는 각각의 스트라이프에 대해, 저장 장치 세트(1604) 내의 어떤 저장 장치(150)가 스트라이프를 위한 하나 또는 그 이상의 패리티-미러 저장 장치(1602)로 할당되는지 교대하는(alternate) 패리티 교대 모듈(2318)을 포함한다. 스트라이프 당 패리티 데이터 세그먼트를 순환하는 것은 성능을 향상시킨다. 패리티 교대 모듈(2318)은 스트라이핑 모듈(2304)와 함께 사용되어 파일 또는 객체의 일부인 하나 또는 그 이상의 데이터 세그먼트를 독출하거나, 기록하거나, 또는 업데이트하도록 하나 또는 그 이상의 저장 장치(150a-n)의 아이덴티티를 계산한다.
다양한 모듈(2302-2318)의 기능은 단일의 마스터 컨트롤러 내에 함께 구비될 수 있거나, 또는 하나 또는 그 이상의 클라이언트(114), 제 3 RAID 관리 장치, 및 하나 또는 그 이상의 저장 장치(150,1602) 사이에 분산될 수 있다. 당업자는 여기에 기술된 기능이 분산되는 다양한 실시예를 파악할 것이다.
도 14는 본 발명에 따른 공유되고, 전단 분산된 RAID를 위한 방법(2400)의 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(2400)은 개시하여(2402), 다수의 스토리지 요청 리시버 모듈(2302)이 적어도 두 개의 클라이언트(114)로부터 적어도 두 개의 스토리지 요청을 수신하여(2404), 저장 장치 세트(1604)의 저장 장치(150)에 데이터를 독출하거나 기록한다. 데이터는 파일 또는 객체로부터 오고, 스토리지 요청 각각은 데이터의 적어도 일부가 공통되고, 도달함에 있어 동시적이며(concurrent), 그 결과 하나의 스토리지 요청은 적어도 두 개의 스토리지 요청의 다른 하나가 도달하기 전까지 완료되지 않는다. 스트라이핑 모듈(2304)은 데이터를 위한 스트라이프 패턴을 계산하며(2406), 여기서 스트라이프 패턴은 하나 또는 그 이상의 스트라이프를 포함하고, 각각의 스트라이프는 N 개의 데이터 세그먼트의 세트를 포함한다. 스트라이핑 모듈(2304)은 또한 스트라이프의 N 개의 데이터 세그먼트를 저장 장치 세트(1604) 내의 N 개의 저장 장치(150a-n)에 독출하거나 기록하며(2408), 여기서 N 개의 데이터 세그먼트 각각은 분리된 저장 장치(150)에 기록되거나 그로부터 독출된다.
스토리지 요청이 기록 동작인 경우, 패리티-미러 모듈(2306)은 스트라이프의 N 개의 데이터 세그먼트의 세트를 저장 장치 세트(1604) 내의 하나 또는 그 이상의 패리티-미러 저장 장치(1602)로 기록하며(2410), 여기서 패리티-미러 저장 장치(1602)는 N 개의 저장 장치(150a-n)에 추가된다. 패리티-미러 모듈(2306)은 또한 패리티-미러 장치(1602)에 저장된 데이터 세그먼트 또는 패리티 데이터 세그먼트를 독출할 수 있다(2410). 시퀀서 모듈(2308)은 제 2 클라이언트(114)로부터의 제 2 스토리지 요청의 실행 전에, 제 1 클라이언트(114)로부터의 제 1 스토리지 요청의 완료를 보증하고(2412), 상기 방법(2400)은 종료한다(2416). 제 1 및 제 2 스토리지 요청은 동시적인 스토리지 요청이다.
본 발명은 그 본질 또는 필수적인 특성으로부터 분리되지 않으면서 다른 특정 형태로 구현될 수 있다. 기술된 실시예는 오직 설명적이고 비제한적으로 간주될 것이다. 따라서, 본 발명의 범위는 전술한 발명의 상세한 설명보다는 첨부된 청구범위에 의해 결정된다. 청구범위의 균등성의 의미 및 범위에 포함되는 모든 변경은 본 발명의 범위 내에 포함될 것이다.
고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지(Solid-State Storage as Cache for High-Capacity, Non-Volatile Storage)
일반적으로, 자주 액세스되거나 애플리케이션 또는 운영체제의 일부로서 로딩되는 데이터가 캐시에 저장됨으로써, 데이터가 고-용량, 비-휘발성(HCNV, High-Capacity Non-Volatile) 저장 장치, 예컨대 HDD(Hard Disk Drive), 광학 드라이브, 테잎 스토리지 등을 통해 액세스되는 경우보다 후속 액세스가 훨씬 빠르게 수행되기 때문에 캐시(cache)는 유익하다. 캐시는 일반적으로 컴퓨터 내에 포함된다.
일부 저장 장치 및 시스템은 HCNV 저장 장치 내에 캐시를 포함한다. 일부 HCNV 저장 장치는 비-휘발성 솔리드 스테이트 캐시를 포함하며; 이는 액세스 시간을 감소시키는 장점을 제공하지만, 통상 HCNV 저장 장치 인터페이스의 제한된 용량에 따라서만 성능을 제공할 수 있다. 일부 비-휘발성 솔리드-스테이트 캐시 저장 장치는 일반적으로 마더보드에 위치되며; 이러한 장치는 캐시 코히어런스(cache coherence)가 제공되지 않기 때문에 멀티-클라이언트 환경에서는 사용될 수 없다. HCNV 장치의 일부 컨트롤러는 또한 캐시를 포함한다. 리던던트(redundant) HCNV 캐시 컨트롤러가 다수의 클라이언트 간에 공유되는 경우, 복잡한 캐시 코히어런스 알고리즘은 데이터에 오류가 발생하지 않음을 보증하기 위해 요구된다.
일반적으로, 캐시는 DRAM에 구현되며, 이는 캐시 용량을 우수하게 만들고, 상대적으로 성능 당 높은 파워를 요구한다. 휘발성 캐시를 지원하는 파워가 손실되면, 캐시에 저장된 데이터는 손실된다. 일반적으로, 일부 배터리 백업이 파워 실패(power failure)의 경우 데이터 손실을 방지하도록 사용되며, 이는 배터리 백업의 실패가 발생하기 전에 캐시를 비-휘발성 메모리로 플러시(flush)하기에 충분한 용량을 구비한다. 또한, 배터리 백업 시스템은 파워를 소비하며, 리던던시(redundancy)를 요구하며, 신뢰성에 부정적으로 영향을 미치고 공간을 차지한다. 배터리는 또한 표준 기준에 서비스되어야하고, 배터리 백업은 상대적으로 고가이다.
전술한 바와 같이, 솔리드-스테이트 스토리지를 사용하여 데이터를 관리하는 장치, 시스템, 및 방법에 대한 요구가 존재하는 것은 분명하다. 유리하게, 그러한 장치, 시스템 및 방법은 적은 파워를 소비하는 비-휘발성 캐시를 제공하고, 두드러지게 큰 용량을 제공하고 캐시에 저장된 데이터를 유지하기 위해 배터리 백업을 요구하지 않는다.
도 15는 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지(110)를 구비한 시스템(3400)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 시스템(3400)은 솔리드-스테이트 스토리지 컨트롤러(104) 및 HCNV 컨트롤러(3402)를 포함한 스토리지 컨트롤러(152)를 구비한 솔리드-스테이트 스토리지 장치(102), 솔리드-스테이트 스토리지(110), 및 네트워크 인터페이스(156)를 포함한다. 상기 시스템(3400)은 컴퓨터 네트워크(116)을 통해 솔리드-스테이트 스토리지 장치(102)에 연결된 요청 장치(155), 및 하나 또는 그 이상의 HCNV 저장 장치(3404a-n)을 포함한다. 당업자는 도 15에 도시된 상기 시스템(3400)이 단지 일 실시예에 불과하고 솔리드-스테이트 스토리지(110)이 저장 장치를 위한 캐시로 구성되도록 허용하는 많은 다른 구성이 가능함을 파악할 것이다.
상기 시스템(3400)은 네트워크 인터페이스(156) 및 스토리지 컨트롤러(152)를 구비한 솔리드-스테이트 스토리지 장치(102)를 포함한다. 다른 실시예에서, 네트워크 인터페이스(156)은 솔리드-스테이트 스토리지 장치(102)의 외부에 구비된다. 예를 들어, 네트워크 인터페이스(156)은 솔리드-스테이트 스토리지 장치(102)를 포함할 수 있거나 포함하지 않을 수 있는 서버(112) 내에 구비될 수 있다.
도시된 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 솔리드-스테이트 스토리지 컨트롤러(104) 및 HCNV(High-Capacity, Non-Volatile) 스토리지 컨트롤러(3402)를 포함한 스토리지 컨트롤러(152)를 포함한다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 스토리지 컨트롤러(152)에 구비되지 않은 솔리드-스테이트 스토리지 컨트롤러(104) 및 HCNV 스토리지 컨트롤러(3402)를 포함한다. 다른 실시예에서, 솔리드-스테이트 스토리지 장치(102)는 HCNV 스토리지 컨트롤러(3402)를 포함하는 솔리드-스테이트 스토리지 컨트롤러(104)를 포함하거나 또는 그 역을 포함할 수 있다.
도시된 실시예에서, 상기 시스템(3400)은 통합된 솔리드-스테이트 스토리지(110)를 구비하고, 외부 HCNV 저장 장치(3404a-n)을 구비한 솔리드-스테이트 스토리지 장치(102)를 포함한다. 다른 실시예에서, 스토리지 컨트롤러(152,104,3402) 및 솔리드-스테이트 스토리지(110)는 HCNV 저장 장치(3404)에 포함된다. HCNV 저장 장치(3404)는 또한 네트워크 인터페이스(156)을 포함할 수 있다. 당업자는 많은 다른 구성이 가능함을 파악할 것이다. 솔리드-스테이트 스토리지 장치(102), 솔리드-스테이트 스토리지 컨트롤러(104), 솔리드-스테이트 스토리지(110), 스토리지 I/O 버스(210), 네트워크 인터페이스(156), 컴퓨터 네트워크(116), 및 요청 장치(155)는 실질적으로 상술된 장치 및 버스의 다른 실시예와 유사하다.
일 실시예에서, 요청 장치(155)는 시스템 버스를 통해 솔리드-스테이트 스토리지 장치(102), 스토리지 컨트롤러(152), 솔리드-스테이트 스토리지 컨트롤러(104) 등과 연결된다. 요청 장치(155)와 솔리드-스테이트 스토리지(110) 간의 데이터 전송은 시스템 버스를 통해 발생할 수 있다.
HCNV 저장 장치(3404)는 일반적으로 비-휘발성 스토리지를 제공하는 고-용량 저장 장치이며, 일반적으로 솔리드-스테이트 스토리지(110)보다 데이터 기록 및 독출에서 더 느리다. HCNV 저장 장치(3404)는 또한 솔리드-스테이트 스토리지(110)보다 단위 저장 용량 당 가격이 더 저렴할 수 있다. HCNV 저장 장치(3404)는 HDD(HArd Disk Drive), 광학 드라이브, 테잎 스토리지 등일 수 있다. HCNV 저장 장치(3404)를 위한 캐시로서 솔리드-스테이트 스토리지(110)를 제공하는 것은 일반적으로 데이터 액세스 및 저장이 속도를 증가시킨다. 당업자는 HCNV 저장 장치(3404)를 위한 캐시로서의 솔리드-스테이트 스토리지(110)의 다른 장점을 파악할 것이다.
일 실시예에서, HCNV 저장 장치(3404)는 SAN(Storage Area Network)를통해 스토리지 컨트롤러(152)에 연결된다. 일 실시예에서, 분리된 SAN 컨트롤러는 HCNV 저장 장치(3404)를 스토리지 컨트롤러(152)로 연결한다. 다른 실시예에서, HCNV 저장 장치(3404) 또는 스토리지 컨트롤러(152)는 SAN 컨트롤러로서 동작한다. 당업자는 HCNV 저장 장치(3404)가 SAN에 연결될 수 있는 다른 방법을 파악할 것이다.
도 16은 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 구비한 장치(3500)의 일 실시예를 설명하는 개략적인 블록도이다. 상기 장치(3500)는 캐시 전단 모듈(3502), 캐시 후단 모듈(3504), 객체 스토리지 컨트롤러(3506), HCNV 모듈(3508), 및 표준 장치 에뮬레이션 모듈(3510)을 포함하며, 이는 이하 기술된다. 상기 장치(3500)의 모듈(3502-3510)은 솔리드-스테이트 스토리지 컨트롤러(104) 및 HCNV 스토리지 컨트롤러(3402)를 구비하는 스토리지 컨트롤러(152) 내에 도시되지만, 각각의 모듈(3502-3510)의 일부 또는 전부는 솔리드-스테이트 스토리지 컨트롤러(104), HCNV 스토리지 컨트롤러(3402), 서버(112), HCNV 저장 장치(3404), 또는 다른 장소에 포함될 수 있다.
상기 장치(3500)는 스토리지 요청과 결합된 데이터 전송을 관리하는 캐시 전단 모듈(3502)를 포함하며, 여기서 데이터 전송은 요청 장치(155) 및 하나 또는 그 이상의 HCNV 저장 장치(3404a-n)를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지(110) 간에 수행된다. 상기 장치(3500)는 또한 솔리드-스테이트 스토리지(110) 및 HCNV 저장 장치(3404a-n) 간의 데이터 전송을 관리하는 캐시 후단 모듈(3504)을 포함한다. 데이터 전송은 데이터, 메타데이터, 및/또는 메타데이터 인덱스를 포함할 수 있다. 상술한 바와 같이, 솔리드-스테이트 스토리지(110)는 비-휘발성, 솔리드-스테이트 데이터 스토리지 엘리먼트(216,218,220)의 어레이이며, 이는 일반적으로 뱅크(214)로 배열된다. 다양한 실시예에서, 솔리드-스테이트 스토리지(110)는 플래시 메모리, 나노 RAM(NRAM), MRAM(Magneto-resistive RAM), DRAM(Dynamic RAM), PRAM(Phase change RAM) 등일 수 있다.
일반적으로, 캐시 전단 모듈(3502), 캐시 후단 모듈(3504), 및 솔리드-스테이트 스토리지 컨트롤러(104)는 요청 장치(155)로부터 자발적으로 동작한다. 예를 들어, 요청 장치(155)는 결합된 스토리지(110,3404a-n)와 함께, 솔리드-스테이트 스토리지 컨트롤러(104) 및 HCNV 스토리지 컨트롤러(3402)를 구비한 스토리지 컨트롤러(152)를 단일 저장 장치로서 바라볼 수 있다. 다른 예에서, 요청 장치(155)는 HCNV 저장 장치(3404a-n)를 바라볼 수 있고, 솔리드-스테이트 스토리지(110)는 투명할 수 있다(transparent).
일 실시예에서, 솔리드-스테이트 스토리지 컨트롤러(104)는 하나 또는 그 이상의 요청 장치(155)로부터 객체 요청을 서비스하는 객체 스토리지 컨트롤러 모듈(3506)을 포함하고, 솔리드-스테이트 스토리지(110) 내의 객체 요청의 객체를 관리한다. 실시예에서, 솔리드-스테이트 컨트롤러(104)는 객체 스토리지 컨트롤러 모듈(3506)과 함께 상술한 바와 같이 객체 요청을 관리하고, 구체적으로 도 2a에 도시된 장치(200)에 관련하여 기술된 바와 같이 관리한다.
일 실시예에서, 상기 장치(3500)는 RAID 레벨에 일관된 독립 드라이브(RAID)의 리던던트 어레이(redundant array) 내의 둘 또는 그 이상의 HCNV 저장 장치(3404a-n) 내의 솔리드-스테이트 스토리지(110) 내에 캐시된(cached) 데이터를 저장하는 HCNV RAID 모듈(3508)을 포함한다. 실시예에서, 데이터는 전체로서 요청 장치(155)에 나타나며, 그 결과 RAID화(RAIDing)는 요청 장치(155)로부터 숨겨진다. 예를 들어, 캐시 전단 모듈(3502)은 솔리드-스테이트 스토리지(110) 내의 요청 장치(155)로부터 데이터를 캐시(cache)할 수 있고, 캐시 후단 모듈(3504)은 데이터를 스트라이프하도록 HCNV RAID 모듈(3508)을 사용하여 조정하고 데이터 세그먼트 및 패리티 데이터 세그먼트를 RAID 레벨에 일관된 HCNV 저장 장치(3404ㅁ-n)에 저장할 수 있다. 당업자는 요청 장치(155)로부터의 데이터가 HCNV 저장 장치(3404ㅁ-n) 내에서 RAID화될 수 있는 다른 방법을 파악할 것이다.
다른 실시예에서, 솔리드-스테이트 스토리지(110) 및 HCNV 저장 장치는 RAID 그룹으로 구성된 하이브리드 저장 장치 세트 내의 하이브리드 저장 장치를 포함한다. 예를 들어, 하이브리드 저장 장치 세트는 전단의 분산된 RAID 저장 장치 세트(1604)일 수 있고, 하이브리드 저장 장치는 도 10, 도 11 및 도 12에 각각 도시된 시스템(1600), 장치(2100), 및 방법(2200)과 관련되어 상술된 바와 같은 저장 장치 세트 내의 저장 장치(150,1602)일 수 있다. 실시예에서, 솔리드-스테이트 스토리지(110)에 캐시되고 추후 HCNV 저장 장치(3404)에 저장되는 데이터 세그먼트는 스트라이프의 N 개의 데이터 세그먼트 또는 스트라이프의 패리티 데이터 세그먼트 중 하나이다. 전단 RAID에서와 같이, 하이브리드 저장 장치는 RAID 스트라이프의 데이터 세그먼트에 독립적인 하나 또는 그 이상의 클라이언트(114)로부터 스토리지 요청을 수신한다.
더한 실시예에서, 도 10, 도 13 및 도 14에 각각 도시된 시스템(1600), 장치(2300), 및 방법(2400)과 관련하여 기술된 공유된 전단 RAID와 관련하여 상술한 바와 같이, 하이브리드 저장 장치는 둘 또는 그 이상의 클라이언트(114)로부터 둘 또는 그 이상의 동시적인 스토리지 요청을 수신하는 공유되고, 전단 분산된 RAID 그룹의 저장 장치(150,1602)이다. 유리하게, 이 실시예는 공유된, 리던던트 캐시가 추가적이고, 복잡한 코히어런스 알고리즘 및 프로토콜을 사용하지 않고도 코히어런스를 유지할 수 있도록 보증한다.
다른 실시예에서, 솔리드-스테이트 스토리지(110) 및 HCNV 저장 장치(3404a-n)는 하이브리드 저장 장치를 포함하고, 상기 장치(3500)는 요청 장치(155)를 로딩하기 전에, 하이브리드 저장 장치의 동작에 특화된 코드를 사용하여 하나 또는 그 이상의 요청 장치(155)에 부착된 표준 장치를 에뮬레이팅함으로써, 하이브리드 저장 장치로의 액세스를 제공하는 표준 장치 에물레이션 모듈(3510)을 포함한다. 실시예에서, 표준 장치는 산업 표준 BIOS에 의해 지원된다. 이러한 부트스트랩(bootstrap) 동작은 솔리드-스테이트 스토리지 컨트롤러(104), HCNV 스토리지 컨트롤러(3404), 및 상기 장치(3500)의 가능한 다른 모듈(3502-3510)에 특화된 드라이버가 요청 장치(155)에 로딩될 수 있을 때까지, 제한된 기능성으로 요청 장치(155)에 의해 인식되고 액세스되도록 한다.
일 실시예에서, 솔리드-스테이트 스토리지 장치(110)는 둘 또는 그 이상의 영역으로 분할될 수 있으며, 여기서 파티션의 하나 또는 그 이상은 HCNV 저장 장치(3404)를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지에 독립적인 솔리드-스테이트 스토리지로서 사용된다. 예를 들어, 솔리드-스테이트 스토리지(110)의 일부 파티션은 일반적인 데이터 저장을 위해 클라이언트(114)에 의해 액세스될 수 있는 반면, 하나 또는 그 이상의 파티션은 HCNV 저장 장치(3404)를 위한 캐시로서 사용된다.
일 실시예에서, 하나 이상의 클라이언트(114)(또는 요청 장치(155))는 캐시 제어 메시지를 캐시 전단 모듈(3502) 및 캐시 후단 모듈(3504)로 전송하여, 솔리드-스테이트 스토리지 장치(110) 및 하나 또는 그 이상의 HCNV 저장 장치(3404) 내에 저장된 하나 또는 그 이상의 파일 또는 객체의 상태를 관리할 수 있다. 유리하게, 파일 당(per file), 객체 당(per object), 또는 데이터 세그먼트 기초 당(per data segment basis)의 캐시 관리를 위한 클라이언트(114)/요청 장치(155)를 위한 기능은 솔리드-스테이트 스토리지 장치(110)의 공유를 위한 많은 유연성을 제공한다.
많은 캐시 제어 메시지가 허용되고 가능하다. 예를 들어, 캐시 제어 메시지는 캐시 후단 모듈(3504)가 솔리드-스테이트 스토리지(110) 내의 객체 또는 파일의 일부를 피닝(pin)하도록 야기하는 제어 메시지를 포함할 수 있다. 다른 캐시 제어 메시지는 캐시 후단 모듈(3504)이 솔리드-스테이트 스토리지(110) 내의 객체 또는 파일의 일부를 언피닝(unpin)하도록 야기하는 제어 메시지를 포함할 수 있다. 다른 캐시 제어 메시지는 캐시 후단 모듈(3404)이 솔리드-스테이트 스토리지(110) 내의 객체 또는 파일의 일부를 하나 또는 그 이상의 HCNV 저장 장치(3404)로 플러시(flush)하도록 야기하는 제어 메시지를 포함할 수 있다. 다른 캐시 제어 메시지는 캐시 후단 모듈(3404)이 하나 또는 그 이상의 HCNV 저장 장치(3404)로부터 객체 또는 파일의 일부를 솔리드-스테이트 스토리지(110)으로 프리로드(preload)하도록 야기하는 제어 메시지를 포함할 수 있다. 다른 캐시 제어 메시지는 캐시 후단 모듈(3404)이 하나 또는 그 이상의 객체 또는 파일의 하나 또는 그 이상의 일부를 솔리드-스테이트 스토리지로부터 HCNV 저장 장치(3404)로 오프로드(offload)하여, 솔리드-스테이트 스토리지(110) 내의 결정된 양의 저장 공간을 자유롭게 하도록 야기하는 제어 메시지를 포함할 수 있다. 당업자는 다른 가능한 캐시 제어 메시지를 파악할 것이다.
일 실시예에서, 캐시 제어 메시지는 객체 또는 파일을 위한 메타데이터("캐시 컨트롤 메타데이터")를 통해 통신된다. 일 실시예에서, 캐시 제어 메타데이터는 영속적이다. 다른 실시예에서, 캐시 제어 메타데이터는 파일 또는 객체의 생성 시 속성 세트(attributes set)를 통해 구축된다. 실시예에서, 속성은 특정 객체 클래스, 특정 파일 타입의 기본 특성(defaults characteristic) 등으로의 관계를 통해 인계받을 수 있다. 다른 실시예에서, 캐시 제어 메타데이터는 파일 또는 객체 관리 시스템으로부터 획득된다. 당업자는 캐시 제어 메시지가 메타데이터를 통해 통신될 수 있는 다른 방법을 파악할 것이다.
일 실시예에서, 상기 시스템(3400)은 휘발성 캐시 스토리지 엘리먼트를 포함한다. 예를 들어, 솔리드-스테이트 스토리지(110)에 추가하여, 상기 시스템(3400)은 또한 휘발성인 일부 타입의 RAM(Random Access Memory)를 포함할 수 있다. 이 실시예에서, 캐시 전단 모듈(3502) 및 캐시 후단 모듈(3504)은 휘발성 캐시 스토리지 엘리먼트 내의 일부 데이터를 저장하고, 솔리드-스테이트 스토리지(110) 및 휘발성 캐시 스토리지 엘리먼트에 저장된 데이터를 관리하고, 후단 스토리지 모듈(3504)은 또한 휘발성 캐시 스토리지 엘리먼트, 솔리드-스테이트 스토리지, 및 HCNV 저장 장치 간의 데이터 전송을 관리한다. 예를 들어, 중요하지 않거나 다른 소스로부터 용이하게 복구할 수 있는 데이터는 휘발성 캐시에 저장될 수 있는 반면, 다른 데이터는 캐시로서 기능하는 솔리드-스테이트 스토리지(110)에 저장될 수 있다.
더한 실시예에서, HCNV 저장 장치(3404)에 저장된 객체 및 파일을 위한 메타데이터 및/또는 인덱스 메타데이터는 솔리드-스테이트 스토리지 장치(110) 및 휘발성 캐시 스토리지 엘리먼트 내에서 관리된다. 도 2a에 도시된 장치(200)에 관련하여 상술한 바와 같이, 특정 메타데이터는 휘발성 캐시 스토리지 엘리먼트에 저장될 수 있고, 휘발성 캐시 스토리지 엘리먼트 내의 데이터가 손실된 경우 인덱스를 재건하도록 사용될 수 있다. 일 실시예에서, 메타데이터 및 인덱스 메타데이터는 휘발성 캐시 스토리지 엘리먼트가 포함되지 않은 솔리드-스테이트 스토리지(110)에 저장된다. 당업자는 캐시로서 기능하는 솔리드-스테이트 스토리지(110)과 함께 휘발성 캐시 스토리지 엘리먼트를 사용하는 다른 장점 및 방법을 파악할 것이다.
도 17은 본 발명에 따른 고-용량, 비-휘발성 저장 장치를 위한 캐시로서 솔리드-스테이트 스토리지를 사용하는 방법(3600)의 일 실시예를 설명하는 개략적인 흐름도이다. 상기 방법(3600)은 개시하여(3602) 캐시 전단 모듈(3502)이 스토리지 요청과 결합된 데이터 전송을 관리하며(3604), 여기서 데이터 전송은 요청 장치(155) 및 하나 또는 그 이상의 HCNV 저장 장치(3404a-n)를 위한 캐시로서 기능하는 솔리드-스테이트 스토리지(110) 간에 수행된다. 캐시 후단 모듈(3504)은 솔리드-스테이트 스토리지(110) 및 하나 또는 그 이상의 HCNV 저장 장치(110) 간의 데이터 전송을 관리하고(3606), 상기 방법(3600)은 종료한다(3608). 상기 방법(3600)은 실질적으로 도 10의 장치(3500)와 관련되어 상술된 바와 유사하게 동작한다.
본 발명은 그 사상 또는 필수 특성으로부터 분리되지 않으면서 다른 특정 형태로 구현될 수 있다. 기술된 실시예는 오직 설명적이고 제한적이지 않은 관점으로 간주된다. 따라서, 본 발명의 범위는 전술한 명세서보다 첨부된 청구범위에 의해 지시된다. 청구범위의 균등의 의미 및 범위 내에 들어오는 모든 변화는 그 범위 내에 포함될 것이다.
Claims (30)
- 하나 이상의 HCNV(High-Capacity, Non-Volatile) 저장 장치의 데이터 저장을 관리하는 장치로서,
스토리지 요청(storage request)과 관련된 데이터의 전송을 관리하며, 상기 데이터의 전송은 요청 장치와 하나 이상의 HCNV 저장 장치를 위한 캐시(cache)로서 기능하는 솔리드-스테이트 스토리지 간에 수행되며, 데이터 전송은 데이터, 메타데이터 및 메타데이터 인덱스 중 하나 이상을 포함하며, 상기 솔리드-스테이트 스토리지는 비-휘발성, 솔리드-스테이트 데이터 스토리지 엘리먼트의 어레이를 포함하는, 캐시 전단 모듈(cache front-end module);
상기 솔리드-스테이트 스토리지 및 상기 하나 이상의 HCNV 저장 장치 간의 데이터 전송을 관리하는, 캐시 후단 모듈(cache back-end module);
솔리드-스테이트 스토리지 컨트롤러를 포함하고,
상기 솔리드-스테이트 스토리지 컨트롤러는, 상기 솔리드-스테이트 스토리지 장치의 스토리지 디비전 내에 캐시로 전송된 데이터를 일시적으로 정렬하는 순차적 스토리지 모듈을 포함하고, 상기 순차적 스토리지 모듈은, 프로세싱 순서에 의해 순차적으로 데이터를 정렬하고, 상기 순차적 스토리지 모듈은 스토리지 디비전에 대한 순차적 순서로 스토리지 디비전의 임시 순서를 관리하는,
데이터 저장 관리 장치. - 제 1 항에 있어서,
상기 데이터 전송과 관련된 데이터의 적어도 일부와 ECC 블록에서 에러를 정정할 수 있는 에러 정정 코드(ECC)를 포함하는 ECC 블록을 생성하는 ECC 생성기를 더 포함하고, 제 1 솔리드 스테이트 스토리지 엘리먼트에 ECC 블록의 제 1 부분을 저장하고 제 2 솔리드 스테이트 스토리지 엘리먼트에 ECC 블록의 제 2 부분을 저장하는, 데이터 저장 관리 장치. - 제 2 항에 있어서,
ECC 블록의 제 1 부분을 저장하고, ECC 블록의 제 2 부분을 저장하는 것은, ECC 블록의 제 1 부분을 제 1 솔리드 스테이트 스토리지 엘리먼트의 페이지와, ECC 블록의 제 2 부분을 제 2 솔리드 스테이트 스토리지 엘리먼트의 페이지에 저장하는 것을 포함하는, 데이터 저장 관리 장치. - 제 3 항에 있어서,
ECC의 길이가 기설정되어 ECC 블록에서 특정 수의 비트 에러를 정정하고, 에러를 정정하는 코드의 길이는 요청 장치로부터 수신한 데이터 블록 사이즈에 대해 독립적으로 기설정되는, 데이터 저장 관리 장치. - 제 3 항에 있어서,
ECC 의 길이는 기설정되어 ECC 블록에서 특정 수의 비트 에러를 정정하고, 에러를 정정하는 코드의 길이는 솔리드 스테이트 스토리지 엘리먼트의 물리적인 페이지 사이즈에 대해 독립적으로 기설정되는, 데이터 저장 관리 장치. - 제 2 항에 있어서,
데이터를 하나 이상의 패킷으로 패킷화하는 패킷타이저를 더 포함하고, ECC 블록은 패킷들 중 적어도 하나의 적어도 일부분을 포함하고, ECC 블록은 패킷 사이즈와 ECC 블록 사이즈간의 고정된 관계를 가지지 않는, 데이터 저장 관리 장치. - 제 6 항에 있어서,
상기 데이터 저장 관리 장치는,
스토리지 디비전이 기설정된 기준치보다 많은 무효 데이터를 포함함을 식별하여 복구를 위한 솔리드 스테이트 스토리지 장치의 스토리지 디비전을 선택하고, 유효 데이터 패킷을 스토리지 디비전 내에서 솔리드 스테이트 스토리지 장치로 순차적으로 기입될 타 데이터 패킷과 함께 대기시키는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
하나 이상의 요청 장치로부터 객체 요청을 서비스하고, 상기 솔리드-스테이트 스토리지 장치 내에서 상기 객체 요청의 객체를 관리하는 객체 스토리지 컨트롤러 모듈을 포함하는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
RAID 레벨에 일관된(consistent), 독립 드라이브의 리던던트 어레이(redundant array of independent drives; RAID) 내의 둘 이상의 HCNV 저장 장치 에서 상기 솔리드-스테이트 스토리지 장치 내에 캐시된(cached) 데이터를 저장하는 HCNV RAID 모듈을 더 포함하는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
솔리드 스테이트 스토리지 장치 및 하나 이상의 HCNV 저장 장치는, RAID 그룹으로 구성된 하이브리드 저장 장치 세트 내에 하이브리드 저장 장치를 포함하며,
상기 솔리드-스테이트 스토리지 장치에 캐시되고 추후 HCNV 장치에 저장되는 데이터 세그먼트는, 스트라이프의 N 개의 데이터 세그먼트 중 하나 또는 상기 스트라이프의 패리티 데이터 세그먼트를 포함하며,
상기 하이브리드 저장 장치는 RAID 스트라이프의 데이터 세그먼트에 독립적인 하나 이상의 클라이언트로부터 스토리지 요청을 수신하는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
데이터 기록 파이프라인이, 버스를 통해 병렬로 비휘발성 솔리드 스테이트 스토리지 엘리먼트의 어레이에서 솔리드 스테이트 스토리지 엘리먼트에 접근하는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
상기 솔리드-스테이트 스토리지 장치 및 상기 하나 이상의 HCNV 저장 장치는 하이브리드 저장 장치를 포함하고,
상기 데이터 저장 관리 장치는, 상기 하이브리드 저장 장치의 동작에 특화된 코드를 가지고 상기 하나 이상의 요청 장치의 로딩 전에 하나 이상의 요청 장치에 부착된 표준 장치(standard device)를 에뮬레이트(emulate)함으로써, 상기 하이브리드 저장 장치로의 액세스를 제공하는 표준 장치 에뮬레이션 모듈을 더 포함하며,
상기 표준 장치는 산업 표준 BIOS에 의해 지원되는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
솔리드 스테이트 스토리지 장치는 둘 이상의 파티션으로 구획될 수 있으며,
하나 이상의 파티션은, 상기 HCNV 저장 장치를 위한 캐시로서 기능하는 상기 솔리드-스테이트 스토리지 장치에 독립적인 솔리드-스테이트 스토리지로서 사용될 수 있는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
하나 또는 그 이상의 클라이언트는, 상기 캐시 전단 모듈 및 상기 캐시 후단 모듈로 캐시 제어 메시지를 전송하여,
상기 캐시 제어 메시지는:
상기 캐시 후단 모듈이 상기 솔리드-스테이트 스토리지 장치 내의 객체 또는 파일의 일부를 피닝(pin)하도록 야기하는 제어 메시지;
상기 캐시 후단 모듈이 상기 솔리드-스테이트 스토리지 장치 내의 객체 또는 파일의 일부를 언피닝(unpin)하도록 야기하는 제어 메시지;
상기 캐시 후단 모듈이 상기 솔리드-스테이트 스토리지 장치로부터 상기 하나 이상의 HCNV 저장 장치로 객체 또는 파일의 일부를 플러시(flush)하도록 야기하는 제어 메시지;
상기 캐시 후단 모듈이 상기 하나 이상의 HCNV 저장 장치로부터 상기 솔리드-스테이트 스토리지 장치로 객체 또는 파일의 일부를 프리로드(preload)하도록 야기하는 제어 메시지; 및
상기 캐시 후단 모듈이 상기 솔리드-스테이트 스토리지 장치로부터 상기 하나 이상의 HCNV 저장 장치로, 하나 이상의 객체 또는 파일의 하나 이상의 부분을 오프로드(offload)하도록 야기하여, 상기 솔리드-스테이트 스토리지 장치 내의 기결정된 저장 공간의 양을 자유롭게 하는 제어 메시지;
중 하나 이상을 포함하는, 데이터 저장 관리 장치. - 제 7 항에 있어서,
상기 캐시 제어 메시지는 데이터 전송을 위한 메타데이터(캐시 제어 메타데이터)를 통해 통신되는, 데이터 저장 관리 장치. - 제 15 항에 있어서,
캐시 제어 메타데이터는 지속적인(persistent), 데이터 저장 관리 장치. - 제 1 항에 있어서,
휘발성 캐시 스토리지 엘리먼트를 더 포함하고,
상기 캐시 전단 모듈 및 상기 캐시 후단 모듈은, 상기 휘발성 캐시 스토리지 엘리먼트에 데이터를 저장하고, 상기 솔리드-스테이트 스토리지 장치 및 휘발성 캐시 스토리지 엘리먼트에 저장된 데이터를 관리하고,
후단 스토리지 모듈이 상기 휘발성 캐시 스토리지 엘리먼트, 상기 솔리드-스테이트 스토리지 및 상기 HCNV 저장 장치 간의 데이터 전송을 관리하는, 데이터 저장 관리 장치. - 제 1 항에 있어서,
상기 HCNV 저장 장치에 저장된 객체 및 파일을 위한 메타데이터 및 인덱스 메타데이터 중 하나 이상은, 상기 솔리드-스테이트 스토리지 장치내에서 유지되는, 데이터 저장 관리 장치. - 하나 이상의 HCNV(High-Capacity, Non-Volatile) 저장 장치의 데이터 저장을 관리하는 시스템으로서,
비-휘발성, 솔리드-스테이트 데이터 스토리지 엘리먼트의 어레이를 포함하는 솔리드-스테이트 스토리지 장치;
하나 또는 그 이상의 HCNV 저장 장치; 및
스토리지 컨트롤러를 포함하며,
상기 스토리지 컨트롤러는:
솔리드-스테이트 스토리지 컨트롤러;
HCNV 저장 장치 컨트롤러;
스토리지 요청(storage request)과 관련된 데이터의 전송을 관리하며, 상기 데이터의 전송은 요청 장치와 하나 이상의 HCNV 저장 장치를 위한 캐시(cache)로서 기능하는 솔리드-스테이트 스토리지 간에 수행되는, 캐시 전단 모듈;
상기 솔리드-스테이트 스토리지 장치 및 상기 하나 이상의 HCNV 저장 장치 간의 데이터 전송을 관리하는 캐시 후단 모듈; 및
상기 솔리드-스테이트 스토리지 장치의 스토리지 디비전 내에 캐시로 전송된 데이터를 일시적으로 정렬하는 순차적 스토리지 모듈을 포함하고, 상기 순차적 스토리지 모듈은, 프로세싱 순서에 의해 순차적으로 데이터를 정렬하고, 상기 순차적 스토리지 모듈은 스토리지 디비전에 대한 순차적 순서로 스토리지 디비전의 임시 순서를 관리하는, 데이터 저장 관리 시스템. - 제 19 항에 있어서,
상기 스토리지 컨트롤러와 연결된 네트워크 인터페이스를 더 포함하며,
상기 네트워크 인터페이스는 컴퓨터 네트워크를 통해 상기 요청 장치 및 상기 솔리드-스테이트 스토리지 컨트롤러 간의 데이터 전송을 구현하는, 데이터 저장 관리 시스템. - 제 19 항에 있어서,
서버를 더 포함하고,
서버는 솔리드-스테이트 스토리지, 하나 이상의 HCNV 저장 장치 및 스토리지 컨트롤러를 포함하는, 데이터 저장 관리 시스템. - 제 19 항에 있어서,
하나 이상의 HCNV 저장 장치는 SAN(Storage Area Network)를 통해 상기 스토리지 컨트롤러에 연결되는, 데이터 저장 관리 시스템. - 하나 이상의 HCNV(High-Capacity, Non-Volatile) 저장 장치의 데이터 저장을 관리하는 동작 수행을 실행할 수 있는 컴퓨터 사용가능 프로그램 코드를 구비하는, 컴퓨터 판독가능한 매체로서,
상기 컴퓨터 사용가능 프로그램 코드의 동작은,
스토리지 요청(storage request)과 관련된 데이터의 전송을 관리하는 단계로서, 상기 데이터의 전송은 요청 장치와 하나 이상의 HCNV 저장 장치를 위한 캐시(cache)로서 기능하는 솔리드-스테이트 스토리지 장치 간에 수행되며, 상기 솔리드-스테이트 스토리지 장치는 비-휘발성, 솔리드-스테이트 스토리지 엘리먼트의 어레이를 포함하는, 단계;
상기 솔리드-스테이트 스토리지 장치와 상기 하나 이상의 HCNV 저장 장치 간의 데이터 전송을 관리하는 단계; 및
상기 솔리드-스테이트 스토리지 장치의 스토리지 디비전 내에 캐시로 전송된 데이터를 일시적으로 정렬하고, 일시적 정렬은 프로세싱 순서에 의해 순차적인, 단계;
스토리지 디비전에 대한 순차적 순서로 스토리지 디비전의 임시 순서를 관리하는 단계를 포함하는, 컴퓨터 판독가능한 매체. - 하나 이상의 HCNV(High-Capacity, Non-Volatile) 저장 장치의 데이터 저장을 관리하는 방법으로서,
스토리지 요청(storage request)과 관련된 데이터의 전송을 관리하는 단계로서, 상기 데이터의 전송은 요청 장치와 하나 이상의 HCNV 저장 장치를 위한 캐시(cache)로서 기능하는 솔리드-스테이트 스토리지 장치 간에 수행되며, 상기 솔리드-스테이트 스토리지 장치는 비-휘발성, 솔리드-스테이트 스토리지 엘리먼트의 어레이를 포함하는, 단계
상기 솔리드-스테이트 스토리지 장치와 상기 하나 이상의 HCNV 저장 장치 간의 데이터 전송을 관리하는 단계; 및
상기 솔리드-스테이트 스토리지 장치의 스토리지 디비전 내에 캐시로 전송된 데이터를 일시적으로 정렬하고, 일시적 정렬은 프로세싱 순서에 의해 순차적인, 단계;
스토리지 디비전에 대한 순차적 순서로 스토리지 디비전의 임시 순서를 관리하는 단계를 포함하는, 데이터 저장 관리 방법. - 제 24 항에 있어서,
데이터 전송과 관련된 데이터의 적어도 일부를 포함하는 ECC 블록을 생성하고, ECC는 ECC 블록에서 에러를 정정할 수 있는 단계; 및
제 1 솔리드 스테이트 스토리지 엘리먼트에 ECC 블록의 제 1 부분을 저장하고, 제 2 솔리드 스테이트 스토리지 엘리먼트에 ECC 블록의 제 2 부분을 저장하는 단계를 더 포함하는, 데이터 저장 관리 방법. - 제 25 항에 있어서,
ECC 블록의 제 1 부분을 저장하고, ECC 블록의 제 2 부분을 저장하는 단계는, 제 1 솔리드 스테이트 스토리지 엘리먼트의 페이지에 ECC 블록의 제 1 부분을 저장하고, 제 2 솔리드 스테이트 스토리지 엘리먼트의 페이지에 ECC 블록의 제 2 부분을 저장하는 단계를 포함하는, 데이터 저장 관리 방법. - 제 26 항에 있어서,
ECC의 길이는 기결정되어 ECC 블록에서 특정 수의 비트 에러를 정정하고, 에러를 정정하는 코드의 길이는 요청 장치로부터 수신된 데이터의 블록 사이즈에 대해 독립적으로 기결정되는, 데이터 저장 관리 방법. - 제 26 항에 있어서,
ECC의 길이는 기결정되어 ECC 블록에서 특정 수의 비트 에러를 정정하고, 에러를 정정하는 코드의 길이는 솔리드 스테이트 스토리지 엘리먼트의 물리적인 페이지 사이즈에 대해 독립적으로 기결정되는, 데이터 저장 관리 방법. - 제 25 항에 있어서,
데이터를 하나 이상의 패킷으로 패킷화하는 단계를 더 포함하고,
ECC블록은 적어도 하나의 패킷의 적어도 일부를 포함하고, ECC 블록은 패킷 사이즈와 ECC 블록 사이즈 간의 관계가 고정되지 않은, 데이터 저장 관리 방법. - 제 29 항에 있어서,
스토리지 디비전이 기설정된 기준치보다 많은 무효 데이터를 포함함을 식별하여 복구를 위한 솔리드 스테이트 스토리지 장치의 스토리지 디비전을 선택하고, 유효 데이터 패킷을 스토리지 디비전 내에서 솔리드 스테이트 스토리지 장치로 순차적으로 기입될 타 데이터 패킷과 함께 대기시키는, 데이터 저장 관리 방법.
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US87311106P | 2006-12-06 | 2006-12-06 | |
US60/873,111 | 2006-12-06 | ||
US97447007P | 2007-09-22 | 2007-09-22 | |
US60/974,470 | 2007-09-22 | ||
PCT/US2007/025049 WO2008070173A1 (en) | 2006-12-06 | 2007-12-06 | Apparatus, system, and method for solid-state storage as cache for high-capacity, non-volatile storage |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020097014058A Division KR20090087498A (ko) | 2006-12-06 | 2007-12-06 | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20140133923A KR20140133923A (ko) | 2014-11-20 |
KR101532951B1 true KR101532951B1 (ko) | 2015-07-09 |
Family
ID=39223046
Family Applications (7)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020147028326A KR101532951B1 (ko) | 2006-12-06 | 2007-12-06 | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 |
KR1020097014058A KR20090087498A (ko) | 2006-12-06 | 2007-12-06 | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 |
KR1020097014054A KR20090087119A (ko) | 2006-12-06 | 2007-12-06 | 빈 데이터 토큰 지시어를 사용한 저장 장치 내의 데이터 관리 장치, 시스템 및 방법 |
KR1020097014065A KR20090095641A (ko) | 2006-12-06 | 2007-12-06 | 데이터 파이프라인을 이용한 데이터 관리 장치, 시스템 및 방법 |
KR1020097014064A KR20090102788A (ko) | 2006-12-06 | 2007-12-06 | 전단의 분산된 raid장치, 시스템 및 방법 |
KR1020097014067A KR20090102789A (ko) | 2006-12-06 | 2007-12-06 | 프로그레시브 raid를 이용한 데이터 저장 장치, 시스템 및 방법 |
KR1020097014055A KR101490327B1 (ko) | 2006-12-06 | 2007-12-06 | 뱅크 인터리브를 이용한 솔리드-스테이트 스토리지의 명령 관리 장치, 시스템 및 방법 |
Family Applications After (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020097014058A KR20090087498A (ko) | 2006-12-06 | 2007-12-06 | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 |
KR1020097014054A KR20090087119A (ko) | 2006-12-06 | 2007-12-06 | 빈 데이터 토큰 지시어를 사용한 저장 장치 내의 데이터 관리 장치, 시스템 및 방법 |
KR1020097014065A KR20090095641A (ko) | 2006-12-06 | 2007-12-06 | 데이터 파이프라인을 이용한 데이터 관리 장치, 시스템 및 방법 |
KR1020097014064A KR20090102788A (ko) | 2006-12-06 | 2007-12-06 | 전단의 분산된 raid장치, 시스템 및 방법 |
KR1020097014067A KR20090102789A (ko) | 2006-12-06 | 2007-12-06 | 프로그레시브 raid를 이용한 데이터 저장 장치, 시스템 및 방법 |
KR1020097014055A KR101490327B1 (ko) | 2006-12-06 | 2007-12-06 | 뱅크 인터리브를 이용한 솔리드-스테이트 스토리지의 명령 관리 장치, 시스템 및 방법 |
Country Status (8)
Country | Link |
---|---|
US (39) | US20080140724A1 (ko) |
EP (9) | EP2100214B1 (ko) |
JP (4) | JP2010515116A (ko) |
KR (7) | KR101532951B1 (ko) |
CN (7) | CN101690068A (ko) |
CA (2) | CA2672035A1 (ko) |
ES (1) | ES2507072T3 (ko) |
WO (15) | WO2008070798A1 (ko) |
Families Citing this family (1283)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7146524B2 (en) * | 2001-08-03 | 2006-12-05 | Isilon Systems, Inc. | Systems and methods for providing a distributed file system incorporating a virtual hot spare |
US7685126B2 (en) | 2001-08-03 | 2010-03-23 | Isilon Systems, Inc. | System and methods for providing a distributed file system utilizing metadata to track information about data stored throughout the system |
US7650510B2 (en) * | 2002-04-30 | 2010-01-19 | General Dynamics Advanced Information Systems, Inc. | Method and apparatus for in-line serial data encryption |
EP2284735A1 (en) | 2002-11-14 | 2011-02-16 | Isilon Systems, Inc. | Systems and methods for restriping files in a distributed file system |
US8346884B2 (en) | 2003-01-21 | 2013-01-01 | Nextio Inc. | Method and apparatus for a shared I/O network interface controller |
US8782654B2 (en) | 2004-03-13 | 2014-07-15 | Adaptive Computing Enterprises, Inc. | Co-allocating a reservation spanning different compute resources types |
USRE45593E1 (en) | 2004-03-13 | 2015-06-30 | Adaptive Computing Enterprises, Inc. | System and method for providing object triggers |
US20070266388A1 (en) | 2004-06-18 | 2007-11-15 | Cluster Resources, Inc. | System and method for providing advanced reservations in a compute environment |
US8176490B1 (en) | 2004-08-20 | 2012-05-08 | Adaptive Computing Enterprises, Inc. | System and method of interfacing a workload manager and scheduler with an identity manager |
US8051425B2 (en) | 2004-10-29 | 2011-11-01 | Emc Corporation | Distributed system with asynchronous execution systems and methods |
US8055711B2 (en) | 2004-10-29 | 2011-11-08 | Emc Corporation | Non-blocking commit protocol systems and methods |
US8238350B2 (en) | 2004-10-29 | 2012-08-07 | Emc Corporation | Message batching with checkpoints systems and methods |
CA2586763C (en) | 2004-11-08 | 2013-12-17 | Cluster Resources, Inc. | System and method of providing system jobs within a compute environment |
US8863143B2 (en) | 2006-03-16 | 2014-10-14 | Adaptive Computing Enterprises, Inc. | System and method for managing a hybrid compute environment |
ES2666563T3 (es) | 2005-03-16 | 2018-05-07 | Iii Holdings 12, Llc | Transferencia automática de carga a un centro bajo demanda |
US9231886B2 (en) | 2005-03-16 | 2016-01-05 | Adaptive Computing Enterprises, Inc. | Simple integration of an on-demand compute environment |
ES2614751T3 (es) | 2005-04-07 | 2017-06-01 | Iii Holdings 12, Llc | Acceso bajo demanda a recursos informáticos |
US8112655B2 (en) * | 2005-04-21 | 2012-02-07 | Violin Memory, Inc. | Mesosynchronous data bus apparatus and method of data transmission |
US8452929B2 (en) | 2005-04-21 | 2013-05-28 | Violin Memory Inc. | Method and system for storage of data in non-volatile media |
US8200887B2 (en) | 2007-03-29 | 2012-06-12 | Violin Memory, Inc. | Memory management system and method |
US9384818B2 (en) | 2005-04-21 | 2016-07-05 | Violin Memory | Memory power management |
US9286198B2 (en) | 2005-04-21 | 2016-03-15 | Violin Memory | Method and system for storage of data in non-volatile media |
US8143653B2 (en) * | 2005-08-10 | 2012-03-27 | Samsung Electronics Co., Ltd. | Variable resistance memory device and system thereof |
US8325768B2 (en) | 2005-08-24 | 2012-12-04 | Intel Corporation | Interleaving data packets in a packet-based communication system |
JP5008845B2 (ja) | 2005-09-01 | 2012-08-22 | 株式会社日立製作所 | ストレージシステムとストレージ装置及びその制御方法 |
US20080220880A1 (en) * | 2005-09-07 | 2008-09-11 | Bally Gaming, Inc. | Trusted Cabinet Identification System |
US7551572B2 (en) | 2005-10-21 | 2009-06-23 | Isilon Systems, Inc. | Systems and methods for providing variable protection |
US7917474B2 (en) | 2005-10-21 | 2011-03-29 | Isilon Systems, Inc. | Systems and methods for accessing and updating distributed data |
US7788303B2 (en) | 2005-10-21 | 2010-08-31 | Isilon Systems, Inc. | Systems and methods for distributed system scanning |
US7797283B2 (en) | 2005-10-21 | 2010-09-14 | Isilon Systems, Inc. | Systems and methods for maintaining distributed data |
US7848261B2 (en) | 2006-02-17 | 2010-12-07 | Isilon Systems, Inc. | Systems and methods for providing a quiescing protocol |
JP4733138B2 (ja) * | 2006-03-31 | 2011-07-27 | パナソニック株式会社 | コマンド出力制御装置、コマンド出力制御方法およびプログラム |
US7756898B2 (en) | 2006-03-31 | 2010-07-13 | Isilon Systems, Inc. | Systems and methods for notifying listeners of events |
US8046629B1 (en) | 2006-07-24 | 2011-10-25 | Marvell World Trade Ltd. | File server for redundant array of independent disks (RAID) system |
US7634686B2 (en) | 2006-07-24 | 2009-12-15 | Marvell World Trade Ltd. | File server for redundant array of independent disks (RAID) system |
US7680836B2 (en) | 2006-08-18 | 2010-03-16 | Isilon Systems, Inc. | Systems and methods for a snapshot of data |
US7590652B2 (en) * | 2006-08-18 | 2009-09-15 | Isilon Systems, Inc. | Systems and methods of reverse lookup |
US7680842B2 (en) | 2006-08-18 | 2010-03-16 | Isilon Systems, Inc. | Systems and methods for a snapshot of data |
US7953704B2 (en) | 2006-08-18 | 2011-05-31 | Emc Corporation | Systems and methods for a snapshot of data |
US7899800B2 (en) | 2006-08-18 | 2011-03-01 | Isilon Systems, Inc. | Systems and methods for providing nonlinear journaling |
US7822932B2 (en) | 2006-08-18 | 2010-10-26 | Isilon Systems, Inc. | Systems and methods for providing nonlinear journaling |
US7882071B2 (en) | 2006-08-18 | 2011-02-01 | Isilon Systems, Inc. | Systems and methods for a snapshot of data |
US8028186B2 (en) | 2006-10-23 | 2011-09-27 | Violin Memory, Inc. | Skew management in an interconnection system |
US8443134B2 (en) | 2006-12-06 | 2013-05-14 | Fusion-Io, Inc. | Apparatus, system, and method for graceful cache device degradation |
US8706968B2 (en) | 2007-12-06 | 2014-04-22 | Fusion-Io, Inc. | Apparatus, system, and method for redundant write caching |
US8489817B2 (en) | 2007-12-06 | 2013-07-16 | Fusion-Io, Inc. | Apparatus, system, and method for caching data |
KR101532951B1 (ko) | 2006-12-06 | 2015-07-09 | 론지튜드 엔터프라이즈 플래시 에스.에이.알.엘. | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 |
US8935302B2 (en) | 2006-12-06 | 2015-01-13 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for data block usage information synchronization for a non-volatile storage volume |
US9104599B2 (en) * | 2007-12-06 | 2015-08-11 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for destaging cached data |
US9495241B2 (en) | 2006-12-06 | 2016-11-15 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for adaptive data storage |
US9116823B2 (en) | 2006-12-06 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for adaptive error-correction coding |
US7813366B2 (en) * | 2006-12-19 | 2010-10-12 | International Business Machines Corporation | Migration of a virtual endpoint from one virtual plane to another |
US7836238B2 (en) * | 2006-12-19 | 2010-11-16 | International Business Machines Corporation | Hot-plug/remove of a new component in a running PCIe fabric |
US7836129B2 (en) * | 2006-12-19 | 2010-11-16 | International Business Machines Corporation | Communication between host systems using a queuing system and shared memories |
US8271604B2 (en) * | 2006-12-19 | 2012-09-18 | International Business Machines Corporation | Initializing shared memories for sharing endpoints across a plurality of root complexes |
US7657663B2 (en) * | 2006-12-19 | 2010-02-02 | International Business Machines Corporation | Migrating stateless virtual functions from one virtual plane to another |
US7860930B2 (en) * | 2006-12-19 | 2010-12-28 | International Business Machines Corporation | Communication between host systems using a transaction protocol and shared memories |
US7984454B2 (en) * | 2006-12-19 | 2011-07-19 | International Business Machines Corporation | Migration of single root stateless virtual functions |
US7991839B2 (en) * | 2006-12-19 | 2011-08-02 | International Business Machines Corporation | Communication between host systems using a socket connection and shared memories |
US8286029B2 (en) | 2006-12-21 | 2012-10-09 | Emc Corporation | Systems and methods for managing unavailable storage devices |
US7593938B2 (en) | 2006-12-22 | 2009-09-22 | Isilon Systems, Inc. | Systems and methods of directory entry encodings |
US8139432B2 (en) * | 2006-12-27 | 2012-03-20 | Samsung Electronics Co., Ltd. | Variable resistance memory device and system thereof |
US8239706B1 (en) * | 2007-01-03 | 2012-08-07 | Board Of Governors For Higher Education, State Of Rhode Island And Providence Plantations | Data retrieval system and method that provides retrieval of data to any point in time |
US7509448B2 (en) | 2007-01-05 | 2009-03-24 | Isilon Systems, Inc. | Systems and methods for managing semantic locks |
US11010076B2 (en) | 2007-03-29 | 2021-05-18 | Violin Systems Llc | Memory system with multiple striping of raid groups and method for performing the same |
US9632870B2 (en) * | 2007-03-29 | 2017-04-25 | Violin Memory, Inc. | Memory system with multiple striping of raid groups and method for performing the same |
US7779048B2 (en) | 2007-04-13 | 2010-08-17 | Isilon Systems, Inc. | Systems and methods of providing possible value ranges |
US8966080B2 (en) | 2007-04-13 | 2015-02-24 | Emc Corporation | Systems and methods of managing resource utilization on a threaded computer system |
US7900015B2 (en) | 2007-04-13 | 2011-03-01 | Isilon Systems, Inc. | Systems and methods of quota accounting |
US8332574B2 (en) * | 2007-04-30 | 2012-12-11 | Sandisk Il Ltd. | Method for efficient storage of metadata in flash memory |
US8309521B2 (en) * | 2007-06-19 | 2012-11-13 | Zimmer, Inc. | Spacer with a coating thereon for use with an implant device |
US8204225B2 (en) | 2007-07-23 | 2012-06-19 | Savi Technology, Inc. | Method and apparatus for providing security in a radio frequency identification system |
US7743204B2 (en) * | 2007-08-01 | 2010-06-22 | Transcend Information, Inc. | Non-volatile memory device and data access circuit and data access method |
KR20090014828A (ko) * | 2007-08-07 | 2009-02-11 | 삼성전자주식회사 | 에러 정정 코드를 암호화하는 플래시 메모리 시스템 및플래시 메모리 시스템의 암호화 방법 |
US11237956B2 (en) * | 2007-08-13 | 2022-02-01 | Digital Kiva, Inc. | Apparatus and system for object-based storage solid-state device |
US7966289B2 (en) | 2007-08-21 | 2011-06-21 | Emc Corporation | Systems and methods for reading objects in a file system |
US7949692B2 (en) | 2007-08-21 | 2011-05-24 | Emc Corporation | Systems and methods for portals into snapshot data |
US7882068B2 (en) | 2007-08-21 | 2011-02-01 | Isilon Systems, Inc. | Systems and methods for adaptive copy on write |
WO2009095902A2 (en) | 2008-01-31 | 2009-08-06 | Densbits Technologies Ltd. | Systems and methods for handling immediate data errors in flash memory |
US8041773B2 (en) | 2007-09-24 | 2011-10-18 | The Research Foundation Of State University Of New York | Automatic clustering for self-organizing grids |
DE112008002634T5 (de) * | 2007-09-27 | 2011-01-13 | Hilton, Ronald N., Holladay | Gerät, System und Verfahren zur systemübergreifenden Proxy-basierten Aufgabenentlastung |
US8694715B2 (en) | 2007-10-22 | 2014-04-08 | Densbits Technologies Ltd. | Methods for adaptively programming flash memory devices and flash memory systems incorporating same |
US8959307B1 (en) | 2007-11-16 | 2015-02-17 | Bitmicro Networks, Inc. | Reduced latency memory read transactions in storage devices |
WO2009072102A2 (en) | 2007-12-05 | 2009-06-11 | Densbits Technologies Ltd. | System and methods employing mock thresholds to generate actual reading thresholds in flash memory devices |
US8316277B2 (en) | 2007-12-06 | 2012-11-20 | Fusion-Io, Inc. | Apparatus, system, and method for ensuring data validity in a data storage process |
US9519540B2 (en) | 2007-12-06 | 2016-12-13 | Sandisk Technologies Llc | Apparatus, system, and method for destaging cached data |
US7836226B2 (en) | 2007-12-06 | 2010-11-16 | Fusion-Io, Inc. | Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment |
TWI350454B (en) * | 2007-12-10 | 2011-10-11 | Phison Electronics Corp | Anti-attacking method for private key, controller and storage device executing the same |
US8359516B2 (en) | 2007-12-12 | 2013-01-22 | Densbits Technologies Ltd. | Systems and methods for error correction and decoding on multi-level physical media |
US8220041B2 (en) * | 2007-12-13 | 2012-07-10 | Trend Micro Incorporated | Method and system for protecting a computer system during boot operation |
US7978516B2 (en) * | 2007-12-27 | 2011-07-12 | Pliant Technology, Inc. | Flash memory controller having reduced pinout |
US9112886B2 (en) * | 2007-12-27 | 2015-08-18 | Verizon Patent And Licensing Inc. | Method and system for providing centralized data field encryption, and distributed storage and retrieval |
US9047468B2 (en) * | 2007-12-28 | 2015-06-02 | Intel Corporation | Migration of full-disk encrypted virtualized storage between blade servers |
CN101217468A (zh) * | 2007-12-28 | 2008-07-09 | 华为技术有限公司 | 路由查表系统、三态内容寻址存储器和网络处理器 |
GB2458260A (en) * | 2008-02-26 | 2009-09-16 | Advanced Risc Mach Ltd | Selectively disabling error repair circuitry in an integrated circuit |
KR101086855B1 (ko) * | 2008-03-10 | 2011-11-25 | 주식회사 팍스디스크 | 고속 동작하는 반도체 스토리지 시스템 및 그 제어 방법 |
JP5245472B2 (ja) * | 2008-03-13 | 2013-07-24 | 富士通株式会社 | 制御方法、ディスクアレイ装置 |
WO2009118720A2 (en) | 2008-03-25 | 2009-10-01 | Densbits Technologies Ltd. | Apparatus and methods for hardware-efficient unbiased rounding |
US7953709B2 (en) | 2008-03-27 | 2011-05-31 | Emc Corporation | Systems and methods for a read only mode for a portion of a storage system |
US7984324B2 (en) * | 2008-03-27 | 2011-07-19 | Emc Corporation | Systems and methods for managing stalled storage devices |
US7870345B2 (en) | 2008-03-27 | 2011-01-11 | Isilon Systems, Inc. | Systems and methods for managing stalled storage devices |
US7949636B2 (en) | 2008-03-27 | 2011-05-24 | Emc Corporation | Systems and methods for a read only mode for a portion of a storage system |
JP2009238094A (ja) * | 2008-03-28 | 2009-10-15 | Hitachi Ltd | ストレージシステム及びデータ保存方法 |
US10248398B2 (en) * | 2008-04-07 | 2019-04-02 | Blackberry Limited | Method for virtualizing software applications |
US8194492B2 (en) * | 2008-04-08 | 2012-06-05 | Samsung Electronics Co., Ltd. | Variable resistance memory device and system |
EP2111011A1 (en) * | 2008-04-16 | 2009-10-21 | Thomson Telecom Belgium | Device and method for sharing files |
US7933939B2 (en) * | 2008-04-16 | 2011-04-26 | Quantum Corporation | Apparatus and method for partitioning data blocks |
US20090319772A1 (en) * | 2008-04-25 | 2009-12-24 | Netapp, Inc. | In-line content based security for data at rest in a network storage system |
US9395929B2 (en) * | 2008-04-25 | 2016-07-19 | Netapp, Inc. | Network storage server with integrated encryption, compression and deduplication capability |
TWI476610B (zh) * | 2008-04-29 | 2015-03-11 | Maxiscale Inc | 同級間冗餘檔案伺服器系統及方法 |
US8589697B2 (en) | 2008-04-30 | 2013-11-19 | Netapp, Inc. | Discarding sensitive data from persistent point-in-time image |
US8117464B1 (en) | 2008-04-30 | 2012-02-14 | Netapp, Inc. | Sub-volume level security for deduplicated data |
WO2009139115A1 (ja) * | 2008-05-12 | 2009-11-19 | パナソニック株式会社 | 半導体記録装置 |
WO2009140112A1 (en) | 2008-05-13 | 2009-11-19 | Rambus Inc. | Fractional program commands for memory devices |
CN102124527A (zh) | 2008-05-16 | 2011-07-13 | 弗森-艾奥公司 | 用于检测和替代失效的数据存储器的装置、系统和方法 |
US8775718B2 (en) * | 2008-05-23 | 2014-07-08 | Netapp, Inc. | Use of RDMA to access non-volatile solid-state memory in a network storage system |
US20090300282A1 (en) * | 2008-05-30 | 2009-12-03 | Promise Technology, Inc. | Redundant array of independent disks write recovery system |
US8127076B2 (en) | 2008-06-06 | 2012-02-28 | Pivot3 | Method and system for placement of data on a storage device |
US8893160B2 (en) * | 2008-06-09 | 2014-11-18 | International Business Machines Corporation | Block storage interface for virtual memory |
CN101609413A (zh) * | 2008-06-18 | 2009-12-23 | 鸿富锦精密工业(深圳)有限公司 | 远程获取系统信息的装置及方法 |
US8185505B1 (en) * | 2008-06-20 | 2012-05-22 | Emc Corporation | Techniques for processing recovery points |
US8843691B2 (en) * | 2008-06-25 | 2014-09-23 | Stec, Inc. | Prioritized erasure of data blocks in a flash storage device |
US8719485B2 (en) * | 2008-06-27 | 2014-05-06 | Marvell World Trade Ltd. | Solid-state disk with wireless functionality |
US8300825B2 (en) * | 2008-06-30 | 2012-10-30 | Intel Corporation | Data encryption and/or decryption by integrated circuit |
US8615678B1 (en) * | 2008-06-30 | 2013-12-24 | Emc Corporation | Auto-adapting multi-tier cache |
US8219750B2 (en) | 2008-06-30 | 2012-07-10 | Pivot3 | Method and system for execution of applications in conjunction with distributed RAID |
US9323681B2 (en) | 2008-09-18 | 2016-04-26 | Avere Systems, Inc. | File storage system, cache appliance, and method |
US8214404B2 (en) | 2008-07-11 | 2012-07-03 | Avere Systems, Inc. | Media aware distributed data layout |
US9342528B2 (en) * | 2010-04-01 | 2016-05-17 | Avere Systems, Inc. | Method and apparatus for tiered storage |
US9118695B1 (en) * | 2008-07-15 | 2015-08-25 | Pc-Doctor, Inc. | System and method for secure optimized cooperative distributed shared data storage with redundancy |
US8819011B2 (en) | 2008-07-16 | 2014-08-26 | Cleversafe, Inc. | Command line interpreter for accessing a data object stored in a distributed storage network |
US20100017650A1 (en) * | 2008-07-19 | 2010-01-21 | Nanostar Corporation, U.S.A | Non-volatile memory data storage system with reliability management |
US20100125695A1 (en) * | 2008-11-15 | 2010-05-20 | Nanostar Corporation | Non-volatile memory storage system |
US20100017556A1 (en) * | 2008-07-19 | 2010-01-21 | Nanostar Corporationm U.S.A. | Non-volatile memory storage system with two-stage controller architecture |
CN101334797B (zh) * | 2008-08-04 | 2010-06-02 | 中兴通讯股份有限公司 | 一种分布式文件系统及其数据块一致性管理的方法 |
US20100030963A1 (en) * | 2008-08-04 | 2010-02-04 | Sandisk Il Ltd. | Managing storage of cached content |
KR101636777B1 (ko) * | 2008-08-08 | 2016-07-21 | 시게이트 테크놀로지 엘엘씨 | 하이브리드 저장 장치 및 그에 대한 논리 블록 어드레스 할당 방법 |
US8145749B2 (en) * | 2008-08-11 | 2012-03-27 | International Business Machines Corporation | Data processing in a hybrid computing environment |
JP2010044827A (ja) | 2008-08-13 | 2010-02-25 | Toshiba Corp | 不揮発性半導体記憶装置 |
US8359514B2 (en) * | 2008-08-15 | 2013-01-22 | Micron Technology, Inc. | Data and error correction code mixing device and method |
US8078906B2 (en) * | 2008-08-21 | 2011-12-13 | Infinidat, Ltd. | Grid storage system and method of operating thereof |
US8495291B2 (en) | 2008-08-21 | 2013-07-23 | Infinidat Ltd. | Grid storage system and method of operating thereof |
US8452922B2 (en) * | 2008-08-21 | 2013-05-28 | Infinidat Ltd. | Grid storage system and method of operating thereof |
US20100049919A1 (en) * | 2008-08-21 | 2010-02-25 | Xsignnet Ltd. | Serial attached scsi (sas) grid storage system and method of operating thereof |
US8443137B2 (en) * | 2008-08-21 | 2013-05-14 | Infinidat Ltd. | Grid storage system and method of operating thereof |
US8307044B2 (en) * | 2008-08-28 | 2012-11-06 | Netapp, Inc. | Circuits, systems, and methods to integrate storage virtualization in a storage controller |
GB2463078B (en) * | 2008-09-02 | 2013-04-17 | Extas Global Ltd | Distributed storage |
US7984267B2 (en) * | 2008-09-04 | 2011-07-19 | International Business Machines Corporation | Message passing module in hybrid computing system starting and sending operation information to service program for accelerator to execute application program |
US8141102B2 (en) | 2008-09-04 | 2012-03-20 | International Business Machines Corporation | Data processing in a hybrid computing environment |
US8230442B2 (en) * | 2008-09-05 | 2012-07-24 | International Business Machines Corporation | Executing an accelerator application program in a hybrid computing environment |
WO2010026648A1 (ja) * | 2008-09-05 | 2010-03-11 | 富士通株式会社 | Macアドレス管理方法 |
US8225019B2 (en) * | 2008-09-22 | 2012-07-17 | Micron Technology, Inc. | SATA mass storage device emulation on a PCIe interface |
KR20110067111A (ko) * | 2008-09-25 | 2011-06-21 | 엘에스아이 코포레이션 | 외부 스토리지 어레이에서의 대역외 관리 애플리케이션을 인증하기 위한 방법 및/또는 장치 |
CN101685381B (zh) * | 2008-09-26 | 2013-07-24 | 美光科技公司 | 固态大容量存储装置的数据串流 |
US20100083247A1 (en) * | 2008-09-26 | 2010-04-01 | Netapp, Inc. | System And Method Of Providing Multiple Virtual Machines With Shared Access To Non-Volatile Solid-State Memory Using RDMA |
US8074039B2 (en) * | 2008-09-29 | 2011-12-06 | Intel Corporation | Redundant array of independent disks-related operations |
US9213612B2 (en) * | 2008-09-29 | 2015-12-15 | Cisco Technology, Inc. | Method and system for a storage area network |
JP5183403B2 (ja) * | 2008-09-30 | 2013-04-17 | 株式会社日立製作所 | ストレージシステムおよび制御プログラムならびにストレージシステム制御方法 |
TWI380642B (en) * | 2008-10-01 | 2012-12-21 | Network bridging apparatus for storage device and data stream transmitting method thereof | |
US7934124B2 (en) * | 2008-10-10 | 2011-04-26 | Oracle America, Inc. | Self-contained densely packed solid-state storage subsystem |
US9626124B2 (en) * | 2008-10-24 | 2017-04-18 | Hewlett-Packard Development Company, L.P. | Direct-attached/network-attached storage device |
US7904749B2 (en) * | 2008-10-24 | 2011-03-08 | Hitachi, Ltd. | Fast data recovery from HDD failure |
US8176247B2 (en) | 2008-10-28 | 2012-05-08 | Pivot3 | Method and system for protecting against multiple failures in a RAID system |
US9189427B2 (en) * | 2008-10-29 | 2015-11-17 | Bruce Backa | System and method for policy-based data archiving triggered by user activity |
EP2350830A4 (en) * | 2008-10-30 | 2013-05-22 | Lsi Corp | REDISTRIBUTION OF STORAGE CONTROLLER DATA |
TWI385672B (zh) * | 2008-11-05 | 2013-02-11 | Lite On It Corp | 儲存裝置之適應性多通道控制器及其方法 |
EP3361371A1 (en) * | 2008-11-07 | 2018-08-15 | Dell International L.L.C. | Thin import for a data storage system |
US8275933B2 (en) * | 2008-11-10 | 2012-09-25 | Fusion-10, Inc | Apparatus, system, and method for managing physical regions in a solid-state storage device |
KR20110086725A (ko) * | 2008-11-10 | 2011-07-29 | 퓨전-아이오, 인크. | 솔리드-스테이트 저장장치의 고장을 예측하는 장치, 시스템 및 방법 |
US9063874B2 (en) | 2008-11-10 | 2015-06-23 | SanDisk Technologies, Inc. | Apparatus, system, and method for wear management |
TW201021494A (en) * | 2008-11-20 | 2010-06-01 | Inventec Corp | Remote data access device and remote data access method |
US8065422B2 (en) * | 2008-11-26 | 2011-11-22 | Netapp, Inc. | Method and/or apparatus for certifying an in-band management application of an external storage array |
US8316201B2 (en) * | 2008-12-18 | 2012-11-20 | Sandisk Il Ltd. | Methods for executing a command to write data from a source location to a destination location in a memory device |
US20100161932A1 (en) * | 2008-12-18 | 2010-06-24 | Ori Moshe Stern | Methods for writing data from a source location to a destination location in a memory device |
US8694750B2 (en) * | 2008-12-19 | 2014-04-08 | Nvidia Corporation | Method and system for data structure management |
US8732350B2 (en) * | 2008-12-19 | 2014-05-20 | Nvidia Corporation | Method and system for improving direct memory access offload |
US9208108B2 (en) * | 2008-12-19 | 2015-12-08 | Nvidia Corporation | Method and system for improved flash controller commands selection |
EP2359248A4 (en) * | 2008-12-19 | 2012-06-13 | Hewlett Packard Development Co | REDUNDANT MEMORIZATION OF DATA FOR A UNIFORM READING LATENCY |
US7925925B2 (en) * | 2008-12-30 | 2011-04-12 | Intel Corporation | Delta checkpoints for a non-volatile memory indirection table |
US8438455B2 (en) * | 2008-12-31 | 2013-05-07 | Intel Corporation | Error correction in a solid state disk |
US20100180182A1 (en) * | 2009-01-09 | 2010-07-15 | Seagate Technology Llc | Data memory device and controller with interface error detection and handling logic |
KR101627321B1 (ko) * | 2009-01-13 | 2016-06-03 | 삼성전자주식회사 | I/o 리퀘스트 핸들링 방법 및 이를 이용한 솔리드 스테이트 드라이브 |
TWI397821B (zh) * | 2009-01-19 | 2013-06-01 | Phison Electronics Corp | 資料串傳送方法、系統及其控制器 |
US8527734B2 (en) * | 2009-01-23 | 2013-09-03 | International Business Machines Corporation | Administering registered virtual addresses in a hybrid computing environment including maintaining a watch list of currently registered virtual addresses by an operating system |
US9286232B2 (en) * | 2009-01-26 | 2016-03-15 | International Business Machines Corporation | Administering registered virtual addresses in a hybrid computing environment including maintaining a cache of ranges of currently registered virtual addresses |
US8347050B2 (en) * | 2009-01-27 | 2013-01-01 | Microsoft Corporation | Append-based shared persistent storage |
US8843880B2 (en) * | 2009-01-27 | 2014-09-23 | International Business Machines Corporation | Software development for a hybrid computing environment |
US8255909B2 (en) | 2009-01-28 | 2012-08-28 | International Business Machines Corporation | Synchronizing access to resources in a hybrid computing environment |
US9170864B2 (en) * | 2009-01-29 | 2015-10-27 | International Business Machines Corporation | Data processing in a hybrid computing environment |
US8001206B2 (en) | 2009-01-29 | 2011-08-16 | International Business Machines Corporation | Broadcasting data in a hybrid computing environment |
KR101552753B1 (ko) * | 2009-01-29 | 2015-09-11 | 엘에스아이 코포레이션 | 볼륨들에 대해 동적 저장 계층화 온라인 데이터 배치를 제공하기 위한 방법 및 시스템 |
US20100191923A1 (en) * | 2009-01-29 | 2010-07-29 | International Business Machines Corporation | Data Processing In A Computing Environment |
US8543756B2 (en) * | 2009-02-02 | 2013-09-24 | Marvell World Trade Ltd. | Solid-state drive command grouping |
US8010718B2 (en) * | 2009-02-03 | 2011-08-30 | International Business Machines Corporation | Direct memory access in a hybrid computing environment |
KR20100091379A (ko) * | 2009-02-10 | 2010-08-19 | 삼성전자주식회사 | 반도체 디스크 장치 및 그것의 프로그램 페일 처리 방법 |
US9152585B2 (en) * | 2009-02-12 | 2015-10-06 | Rambus Inc. | Memory interface with reduced read-write turnaround delay |
KR101023883B1 (ko) * | 2009-02-13 | 2011-03-22 | (주)인디링스 | 고속 저장 장치를 캐쉬로 사용하는 스토리지 시스템 |
US20100211546A1 (en) * | 2009-02-13 | 2010-08-19 | Lennox Manufacturing Inc. | System and method to backup data about devices in a network |
US8195878B2 (en) | 2009-02-19 | 2012-06-05 | Pmc-Sierra, Inc. | Hard disk drive with attached solid state drive cache |
US8386724B2 (en) | 2009-02-19 | 2013-02-26 | Micron Technology, Inc. | Methods and apparatus for designating or using data status indicators |
KR101563647B1 (ko) * | 2009-02-24 | 2015-10-28 | 삼성전자주식회사 | 메모리 시스템 및 그것의 데이터 처리 방법 |
CN101504670A (zh) * | 2009-03-04 | 2009-08-12 | 成都市华为赛门铁克科技有限公司 | 数据操作方法、系统、客户端和数据服务器 |
JP4719802B2 (ja) * | 2009-03-09 | 2011-07-06 | 富士通株式会社 | ストレージ管理装置、ストレージ管理方法およびストレージシステム |
TWI406130B (zh) * | 2009-03-10 | 2013-08-21 | Phison Electronics Corp | 資料處理系統、控制器及其搜尋特定記憶體區的方法 |
US20100241868A1 (en) * | 2009-03-19 | 2010-09-23 | Hani Nachef | Method and apparatus for storing, managing, and securing personal information |
US8725946B2 (en) * | 2009-03-23 | 2014-05-13 | Ocz Storage Solutions, Inc. | Mass storage system and method of using hard disk, solid-state media, PCIe edge connector, and raid controller |
US8074037B2 (en) * | 2009-03-30 | 2011-12-06 | Inventec Corporation | Storage service device with dual controller and backup method thereof |
CN101856912B (zh) * | 2009-04-01 | 2013-05-22 | 精工爱普生株式会社 | 存储装置和包括能够与主机电路电连接的存储装置的系统 |
JP5663843B2 (ja) * | 2009-04-01 | 2015-02-04 | セイコーエプソン株式会社 | 記憶装置、基板、液体容器、不揮発性のデータ記憶部の制御方法、ホスト回路と着脱可能な記憶装置を含むシステム |
US8458574B2 (en) | 2009-04-06 | 2013-06-04 | Densbits Technologies Ltd. | Compact chien-search based decoding apparatus and method |
US8819385B2 (en) | 2009-04-06 | 2014-08-26 | Densbits Technologies Ltd. | Device and method for managing a flash memory |
US8595572B2 (en) * | 2009-04-08 | 2013-11-26 | Google Inc. | Data storage device with metadata command |
US20100262979A1 (en) * | 2009-04-08 | 2010-10-14 | Google Inc. | Circular command queues for communication between a host and a data storage device |
US8239724B2 (en) | 2009-04-08 | 2012-08-07 | Google Inc. | Error correction for a data storage device |
US8806165B2 (en) | 2009-04-10 | 2014-08-12 | Kaminario Technologies Ltd. | Mass-storage system utilizing auxiliary solid-state storage subsystem |
US20100262755A1 (en) * | 2009-04-10 | 2010-10-14 | Honeywell International Inc. | Memory systems for computing devices and systems |
WO2010116419A1 (en) * | 2009-04-10 | 2010-10-14 | Hitachi, Ltd. | Storage apparatus and method for shredding storage medium |
US8799572B2 (en) * | 2009-04-20 | 2014-08-05 | Microsoft Corporation | Sliding-window multi-class striping |
US8560879B1 (en) * | 2009-04-22 | 2013-10-15 | Netapp Inc. | Data recovery for failed memory device of memory device array |
US8037217B2 (en) * | 2009-04-23 | 2011-10-11 | International Business Machines Corporation | Direct memory access in a hybrid computing environment |
US8214621B2 (en) | 2009-04-29 | 2012-07-03 | Microsoft Corporation | Storage optimization across media with differing capabilities |
US8165030B2 (en) * | 2009-04-30 | 2012-04-24 | Avaya Inc. | System and method for monitoring a network communication at multiple network layers |
US8072890B2 (en) * | 2009-05-01 | 2011-12-06 | Avaya Inc. | System and method for testing a dynamic communication across a network |
CN101882119B (zh) * | 2009-05-08 | 2014-05-14 | 上海炬力集成电路设计有限公司 | 与非型闪存控制器及其数据传输方法 |
US8250282B2 (en) * | 2009-05-14 | 2012-08-21 | Micron Technology, Inc. | PCM memories for storage bus interfaces |
US8238254B2 (en) * | 2009-05-14 | 2012-08-07 | Avaya Inc. | Detection and display of packet changes in a network |
US8307258B2 (en) | 2009-05-18 | 2012-11-06 | Fusion-10, Inc | Apparatus, system, and method for reconfiguring an array to operate with less storage elements |
US8281227B2 (en) | 2009-05-18 | 2012-10-02 | Fusion-10, Inc. | Apparatus, system, and method to increase data integrity in a redundant storage system |
KR20100124087A (ko) * | 2009-05-18 | 2010-11-26 | 삼성전자주식회사 | 메모리 컨트롤러, 그것을 포함하는 메모리 시스템 그리고 그것의 동작 방법 |
US8161251B2 (en) | 2009-05-27 | 2012-04-17 | Microsoft Corporation | Heterogeneous storage array optimization through eviction |
US9377967B2 (en) | 2009-05-27 | 2016-06-28 | Dell Products L.P. | Systems and methods for scalable storage management |
US8732396B2 (en) * | 2009-06-08 | 2014-05-20 | Lsi Corporation | Method and apparatus for protecting the integrity of cached data in a direct-attached storage (DAS) system |
US9123409B2 (en) * | 2009-06-11 | 2015-09-01 | Micron Technology, Inc. | Memory device for a hierarchical memory architecture |
WO2010144587A2 (en) | 2009-06-12 | 2010-12-16 | Violin Memory, Inc. | Memory system having persistent garbage collection |
US8321630B1 (en) | 2010-01-28 | 2012-11-27 | Microsoft Corporation | Application-transparent hybridized caching for high-performance storage |
US20100318720A1 (en) * | 2009-06-16 | 2010-12-16 | Saranyan Rajagopalan | Multi-Bank Non-Volatile Memory System with Satellite File System |
US20110004742A1 (en) * | 2009-07-06 | 2011-01-06 | Eonsil, Inc. | Variable-Cycle, Event-Driven Multi-Execution Flash Processor |
US8291131B2 (en) * | 2009-07-06 | 2012-10-16 | Micron Technology, Inc. | Data transfer management |
CN102265267A (zh) * | 2009-07-07 | 2011-11-30 | Lsi公司 | 用于分层非易失性存储设备的系统和方法 |
KR101662824B1 (ko) * | 2009-07-08 | 2016-10-06 | 삼성전자주식회사 | 고체 상태 드라이브 장치 및 그것의 구동 방법 |
EP2460104A4 (en) | 2009-07-27 | 2016-10-05 | Ibm | METHOD AND SYSTEM FOR TRANSFORMING LOGICAL DATA OBJECTS FOR STORAGE USE |
US8527838B2 (en) * | 2009-07-31 | 2013-09-03 | Cleversafe, Inc. | Memory controller utilizing an error coding dispersal function |
US8180972B2 (en) * | 2009-08-07 | 2012-05-15 | International Business Machines Corporation | Reducing remote reads of memory in a hybrid computing environment by maintaining remote memory values locally |
KR20110015217A (ko) * | 2009-08-07 | 2011-02-15 | 삼성전자주식회사 | 향상된 신호 무결성을 가지는 메모리 시스템 |
CN101996685B (zh) * | 2009-08-11 | 2013-12-04 | 中颖电子股份有限公司 | 存储器管理数据的差错控制方法及差错控制器 |
US8359431B2 (en) * | 2009-08-20 | 2013-01-22 | Hitachi, Ltd. | Storage subsystem and its data processing method for reducing the amount of data to be stored in a semiconductor nonvolatile memory |
US8995197B1 (en) | 2009-08-26 | 2015-03-31 | Densbits Technologies Ltd. | System and methods for dynamic erase and program control for flash memory device memories |
US9330767B1 (en) | 2009-08-26 | 2016-05-03 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Flash memory module and method for programming a page of flash memory cells |
JP5342014B2 (ja) * | 2009-08-31 | 2013-11-13 | 株式会社日立製作所 | 複数のフラッシュパッケージを有するストレージシステム |
US8407562B2 (en) * | 2009-09-01 | 2013-03-26 | Marvell World Trade Ltd. | Systems and methods for compressing data in non-volatile semiconductor memory drives |
US8665601B1 (en) | 2009-09-04 | 2014-03-04 | Bitmicro Networks, Inc. | Solid state drive with improved enclosure assembly |
US8447908B2 (en) | 2009-09-07 | 2013-05-21 | Bitmicro Networks, Inc. | Multilevel memory bus system for solid-state mass storage |
JP5999645B2 (ja) * | 2009-09-08 | 2016-10-05 | ロンギチュード エンタープライズ フラッシュ エスエイアールエル | ソリッドステート記憶デバイス上にデータをキャッシングするための装置、システム、および方法 |
US9223514B2 (en) | 2009-09-09 | 2015-12-29 | SanDisk Technologies, Inc. | Erase suspend/resume for memory |
US9122579B2 (en) | 2010-01-06 | 2015-09-01 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for a storage layer |
EP2476079A4 (en) * | 2009-09-09 | 2013-07-03 | Fusion Io Inc | APPARATUS, SYSTEM, AND METHOD FOR STORAGE ALLOCATION |
KR101689420B1 (ko) | 2009-09-09 | 2016-12-23 | 샌디스크 테크놀로지스 엘엘씨 | 저장 장치의 전력 감소 관리를 위한 장치, 시스템, 및 방법 |
FI126228B (fi) * | 2009-09-16 | 2016-08-31 | Varaani Works Oy | Menetelmä ja tallennuspalvelin tiedon varmentamiseen |
US20130107444A1 (en) | 2011-10-28 | 2013-05-02 | Calxeda, Inc. | System and method for flexible storage and networking provisioning in large scalable processor installations |
US9054990B2 (en) | 2009-10-30 | 2015-06-09 | Iii Holdings 2, Llc | System and method for data center security enhancements leveraging server SOCs or server fabrics |
US9876735B2 (en) | 2009-10-30 | 2018-01-23 | Iii Holdings 2, Llc | Performance and power optimized computer system architectures and methods leveraging power optimized tree fabric interconnect |
US9069929B2 (en) | 2011-10-31 | 2015-06-30 | Iii Holdings 2, Llc | Arbitrating usage of serial port in node card of scalable and modular servers |
US8599863B2 (en) * | 2009-10-30 | 2013-12-03 | Calxeda, Inc. | System and method for using a multi-protocol fabric module across a distributed server interconnect fabric |
US9465771B2 (en) | 2009-09-24 | 2016-10-11 | Iii Holdings 2, Llc | Server on a chip and node cards comprising one or more of same |
US20110103391A1 (en) | 2009-10-30 | 2011-05-05 | Smooth-Stone, Inc. C/O Barry Evans | System and method for high-performance, low-power data center interconnect fabric |
US9077654B2 (en) | 2009-10-30 | 2015-07-07 | Iii Holdings 2, Llc | System and method for data center security enhancements leveraging managed server SOCs |
US8526605B2 (en) * | 2009-10-09 | 2013-09-03 | Seagate Technology Llc | Data encryption to provide data security and memory cell bit wear leveling |
US8730729B2 (en) | 2009-10-15 | 2014-05-20 | Densbits Technologies Ltd. | Systems and methods for averaging error rates in non-volatile devices and storage systems |
JP5391993B2 (ja) * | 2009-10-19 | 2014-01-15 | 富士通株式会社 | ディスクアレイ装置 |
US8724387B2 (en) | 2009-10-22 | 2014-05-13 | Densbits Technologies Ltd. | Method, system, and computer readable medium for reading and programming flash memory cells using multiple bias voltages |
US9680770B2 (en) * | 2009-10-30 | 2017-06-13 | Iii Holdings 2, Llc | System and method for using a multi-protocol fabric module across a distributed server interconnect fabric |
US9098376B2 (en) * | 2009-10-30 | 2015-08-04 | Cleversafe, Inc. | Distributed storage network for modification of a data object |
US9311269B2 (en) | 2009-10-30 | 2016-04-12 | Iii Holdings 2, Llc | Network proxy for high-performance, low-power data center interconnect fabric |
US10877695B2 (en) | 2009-10-30 | 2020-12-29 | Iii Holdings 2, Llc | Memcached server functionality in a cluster of data processing nodes |
US9648102B1 (en) | 2012-12-27 | 2017-05-09 | Iii Holdings 2, Llc | Memcached server functionality in a cluster of data processing nodes |
US11720290B2 (en) | 2009-10-30 | 2023-08-08 | Iii Holdings 2, Llc | Memcached server functionality in a cluster of data processing nodes |
EP2323135A1 (en) * | 2009-11-12 | 2011-05-18 | SiTel Semiconductor B.V. | Method and apparatus for emulating byte wise programmable functionality into sector wise erasable memory |
US8352834B2 (en) * | 2009-11-12 | 2013-01-08 | Broadlogic Network Technologies Inc. | High throughput interleaver / deinterleaver |
US20110119462A1 (en) * | 2009-11-19 | 2011-05-19 | Ocz Technology Group, Inc. | Method for restoring and maintaining solid-state drive performance |
US8495471B2 (en) * | 2009-11-30 | 2013-07-23 | International Business Machines Corporation | Solid-state storage system with parallel access of multiple flash/PCM devices |
US8327069B2 (en) * | 2009-12-08 | 2012-12-04 | Hitachi, Ltd. | Storage system and storage control apparatus provided with cache memory group including volatile memory and nonvolatile memory |
US20110137861A1 (en) * | 2009-12-09 | 2011-06-09 | International Business Machines Corporation | Methods for Achieving Efficient Coherent Access to Data in a Cluster of Data Processing Computing Nodes |
US8375225B1 (en) * | 2009-12-11 | 2013-02-12 | Western Digital Technologies, Inc. | Memory protection |
WO2011070526A1 (en) * | 2009-12-11 | 2011-06-16 | International Business Machines Corporation | Flash memory controller |
US8433865B2 (en) * | 2009-12-11 | 2013-04-30 | Microsoft Corporation | Consistency without ordering dependency |
KR101670746B1 (ko) * | 2009-12-15 | 2016-11-09 | 엘지전자 주식회사 | 무선 통신 시스템에서의 멀티캐스트 및 브로드캐스트 서비스 데이터를 위한 자원 할당 방법 및 이를 위한 장치 |
US8683293B2 (en) * | 2009-12-16 | 2014-03-25 | Nvidia Corporation | Method and system for fast two bit error correction |
US8250380B2 (en) * | 2009-12-17 | 2012-08-21 | Hitachi Global Storage Technologies Netherlands B.V. | Implementing secure erase for solid state drives |
TWI497293B (zh) * | 2009-12-17 | 2015-08-21 | Ibm | 固態儲存裝置內之資料管理 |
WO2011073940A1 (en) * | 2009-12-17 | 2011-06-23 | International Business Machines Corporation | Data management in solid state storage systems |
US9037777B2 (en) | 2009-12-22 | 2015-05-19 | Densbits Technologies Ltd. | Device, system, and method for reducing program/read disturb in flash arrays |
US8321501B2 (en) * | 2009-12-23 | 2012-11-27 | Intel Corporation | Secure out-of-band storage control |
US8533564B2 (en) * | 2009-12-23 | 2013-09-10 | Sandisk Technologies Inc. | System and method of error correction of control data at a memory device |
KR20110073932A (ko) * | 2009-12-24 | 2011-06-30 | 주식회사 하이닉스반도체 | Ecc 회로를 포함하는 반도체 스토리지 시스템 및 그 제어 방법 |
US9369526B2 (en) * | 2009-12-29 | 2016-06-14 | International Business Machines Corporation | Distributed storage time synchronization based on retrieval delay |
US20110161553A1 (en) * | 2009-12-30 | 2011-06-30 | Nvidia Corporation | Memory device wear-leveling techniques |
US8443263B2 (en) * | 2009-12-30 | 2013-05-14 | Sandisk Technologies Inc. | Method and controller for performing a copy-back operation |
US9594675B2 (en) * | 2009-12-31 | 2017-03-14 | Nvidia Corporation | Virtualization of chip enables |
US8327225B2 (en) * | 2010-01-04 | 2012-12-04 | Micron Technology, Inc. | Error correction in a stacked memory |
US8868575B2 (en) * | 2010-01-13 | 2014-10-21 | International Business Machines Corporation | Method and system for transformation of logical data objects for storage |
TWI587139B (zh) * | 2010-01-20 | 2017-06-11 | 旺玖科技股份有限公司 | 驅動裝置及其取得資料之方法 |
US11301592B2 (en) * | 2010-01-28 | 2022-04-12 | Pure Storage, Inc. | Distributed storage with data obfuscation and method for use therewith |
US9417905B2 (en) * | 2010-02-03 | 2016-08-16 | International Business Machines Corporation | Terminating an accelerator application program in a hybrid computing environment |
US8447916B2 (en) * | 2010-02-17 | 2013-05-21 | Microsoft Corporation | Interfaces that facilitate solid state storage configuration |
US8843459B1 (en) * | 2010-03-09 | 2014-09-23 | Hitachi Data Systems Engineering UK Limited | Multi-tiered filesystem |
US9244768B2 (en) * | 2010-03-12 | 2016-01-26 | International Business Machines Corporation | Dispersed storage network file system directory |
US20110230711A1 (en) * | 2010-03-16 | 2011-09-22 | Kano Akihito | Endoscopic Surgical Instrument |
CN102207910A (zh) * | 2010-03-29 | 2011-10-05 | 联想(北京)有限公司 | 一种只读存储器、数据安全保护系统、方法及计算机 |
CN102208987A (zh) * | 2010-03-29 | 2011-10-05 | 鸿富锦精密工业(深圳)有限公司 | 主板管理控制器网络配置系统及方法 |
US8578132B2 (en) | 2010-03-29 | 2013-11-05 | International Business Machines Corporation | Direct injection of data to be transferred in a hybrid computing environment |
JP5447092B2 (ja) * | 2010-03-30 | 2014-03-19 | 富士通株式会社 | 処理装置,データ移行方法及びデータ移行プログラム |
US8577986B2 (en) | 2010-04-02 | 2013-11-05 | Microsoft Corporation | Mapping RDMA semantics to high speed storage |
US9015268B2 (en) * | 2010-04-02 | 2015-04-21 | Intel Corporation | Remote direct storage access |
JP5521716B2 (ja) * | 2010-04-06 | 2014-06-18 | 富士通株式会社 | ストレージ制御プログラム、ストレージ制御方法およびストレージ制御装置 |
US8745317B2 (en) | 2010-04-07 | 2014-06-03 | Densbits Technologies Ltd. | System and method for storing information in a multi-level cell memory |
US8407517B2 (en) * | 2010-04-08 | 2013-03-26 | Hitachi, Ltd. | Methods and apparatus for managing error codes for storage systems coupled with external storage systems |
US8296508B1 (en) * | 2010-04-27 | 2012-10-23 | Micron Technology, Inc. | Secure memory device erase |
US9015443B2 (en) | 2010-04-30 | 2015-04-21 | International Business Machines Corporation | Reducing remote reads of memory in a hybrid computing environment |
JP5684815B2 (ja) * | 2010-04-30 | 2015-03-18 | 株式会社日立製作所 | 計算機システム及びその制御方法 |
US9811662B2 (en) * | 2010-05-03 | 2017-11-07 | Panzura, Inc. | Performing anti-virus checks for a distributed filesystem |
EP2567323A1 (en) * | 2010-05-05 | 2013-03-13 | Marvell World Trade Ltd. | Caching storage adapter architecture |
US8634186B2 (en) * | 2010-05-07 | 2014-01-21 | Advanced Micro Devices, Inc. | Non-volatile memory controller cable arrangement |
CN102244591B (zh) * | 2010-05-10 | 2015-04-15 | 淮南东正电子科技有限公司 | 客户端服务器及对其功能测试全程监测的方法 |
WO2011143628A2 (en) | 2010-05-13 | 2011-11-17 | Fusion-Io, Inc. | Apparatus, system, and method for conditional and atomic storage operations |
US8495296B2 (en) | 2010-05-18 | 2013-07-23 | International Business Machines Corporation | System and method for optimizing data remanence over hubrid disk clusters using various storage technologies |
TWI469576B (zh) * | 2010-05-20 | 2015-01-11 | Hon Hai Prec Ind Co Ltd | 用戶端伺服器及對其功能測試全程監測的方法 |
JP5598089B2 (ja) * | 2010-05-28 | 2014-10-01 | 富士通株式会社 | プログラム、情報処理装置及び情報処理方法 |
US20110296131A1 (en) * | 2010-05-31 | 2011-12-01 | Samsung Electronics Co., Ltd | Nonvolatile memory system and the operation method thereof |
JP4829365B1 (ja) * | 2010-05-31 | 2011-12-07 | 株式会社東芝 | データ記憶装置及びデータ書き込み方法 |
US8904104B2 (en) * | 2010-06-09 | 2014-12-02 | Taejin Info Tech Co., Ltd. | Hybrid storage system with mid-plane |
US8892980B2 (en) | 2010-06-15 | 2014-11-18 | Fusion-Io, Inc. | Apparatus, system, and method for providing error correction |
US8719675B1 (en) * | 2010-06-16 | 2014-05-06 | Google Inc. | Orthogonal coding for data storage, access, and maintenance |
US8793440B2 (en) | 2010-06-17 | 2014-07-29 | Microsoft Corporation | Error detection for files |
CN101883181A (zh) * | 2010-06-18 | 2010-11-10 | 中兴通讯股份有限公司 | 处理短消息的方法及终端 |
US8522076B2 (en) * | 2010-06-23 | 2013-08-27 | International Business Machines Corporation | Error detection and recovery in a shared pipeline |
KR20120002760A (ko) * | 2010-07-01 | 2012-01-09 | 삼성전자주식회사 | 낸드 플래쉬 메모리의 동작 신뢰성을 향상시키는 데이터 기록 방법 및 데이터 기록 장치 |
US8621321B2 (en) | 2010-07-01 | 2013-12-31 | Densbits Technologies Ltd. | System and method for multi-dimensional encoding and decoding |
JP2012022422A (ja) * | 2010-07-13 | 2012-02-02 | Panasonic Corp | 半導体記録再生装置 |
US8281043B2 (en) | 2010-07-14 | 2012-10-02 | Intel Corporation | Out-of-band access to storage devices through port-sharing hardware |
US8782434B1 (en) | 2010-07-15 | 2014-07-15 | The Research Foundation For The State University Of New York | System and method for validating program execution at run-time |
US8484415B2 (en) * | 2010-07-19 | 2013-07-09 | Taejin Info Tech Co., Ltd. | Hybrid storage system for a multi-level raid architecture |
TWI455144B (zh) | 2010-07-22 | 2014-10-01 | Silicon Motion Inc | 使用於快閃記憶體的控制方法與控制器 |
EP2598996B1 (en) | 2010-07-28 | 2019-07-10 | SanDisk Technologies LLC | Apparatus, system, and method for conditional and atomic storage operations |
US8725934B2 (en) | 2011-12-22 | 2014-05-13 | Fusion-Io, Inc. | Methods and appratuses for atomic storage operations |
US8510519B2 (en) * | 2010-08-02 | 2013-08-13 | Taejin Info Tech Co., Ltd. | Hybrid raid controller |
US8713268B2 (en) | 2010-08-05 | 2014-04-29 | Ut-Battelle, Llc | Coordinated garbage collection for raid array of solid state disks |
US9146875B1 (en) * | 2010-08-09 | 2015-09-29 | Western Digital Technologies, Inc. | Hybrid drive converting non-volatile semiconductor memory to read only based on life remaining |
US9530436B1 (en) * | 2010-08-12 | 2016-12-27 | Western Digital Technologies, Inc. | Methods and systems for providing data security in data storage devices |
US8964464B2 (en) | 2010-08-24 | 2015-02-24 | Densbits Technologies Ltd. | System and method for accelerated sampling |
US8621271B2 (en) * | 2010-08-26 | 2013-12-31 | Cleversafe, Inc. | Reprovisioning a memory device into a dispersed storage network memory |
US8850114B2 (en) | 2010-09-07 | 2014-09-30 | Daniel L Rosenband | Storage array controller for flash-based storage devices |
US8412672B1 (en) | 2010-09-08 | 2013-04-02 | Netapp, Inc. | High availability network storage system incorporating non-shared storage suitable for use with virtual storage servers |
US8583867B1 (en) | 2010-09-08 | 2013-11-12 | Netapp, Inc. | Non-disruptive data migration between processing systems that do not share storage |
US8984216B2 (en) | 2010-09-09 | 2015-03-17 | Fusion-Io, Llc | Apparatus, system, and method for managing lifetime of a storage device |
US8589625B2 (en) * | 2010-09-15 | 2013-11-19 | Pure Storage, Inc. | Scheduling of reconstructive I/O read operations in a storage environment |
CN101957767A (zh) * | 2010-09-21 | 2011-01-26 | 深圳创维数字技术股份有限公司 | 基于与非型闪存存储设备的系统软件升级方法 |
US20120079583A1 (en) * | 2010-09-23 | 2012-03-29 | Microsoft Corporation | Offload reads and writes |
JP2012068936A (ja) * | 2010-09-24 | 2012-04-05 | Toshiba Corp | メモリシステム |
US8463991B2 (en) | 2010-09-28 | 2013-06-11 | Pure Storage Inc. | Intra-device data protection in a raid array |
WO2012050935A2 (en) * | 2010-09-28 | 2012-04-19 | Fusion-Io, Inc. | Apparatus, system, and method for data transformations within a data storage device |
US8775868B2 (en) | 2010-09-28 | 2014-07-08 | Pure Storage, Inc. | Adaptive RAID for an SSD environment |
US9244769B2 (en) | 2010-09-28 | 2016-01-26 | Pure Storage, Inc. | Offset protection data in a RAID array |
US9251058B2 (en) * | 2010-09-28 | 2016-02-02 | SanDisk Technologies, Inc. | Servicing non-block storage requests |
WO2012050934A2 (en) * | 2010-09-28 | 2012-04-19 | Fusion-Io, Inc. | Apparatus, system, and method for a direct interface between a memory controller and non-volatile memory using a command protocol |
US9229808B2 (en) | 2010-10-01 | 2016-01-05 | Pure Storage, Inc. | Reconstruct reads in a raid array with dynamic geometries |
US9348696B2 (en) | 2010-10-01 | 2016-05-24 | Pure Storage, Inc. | Distributed multi-level protection in a raid array based storage system |
US8755221B2 (en) * | 2010-10-18 | 2014-06-17 | Avalanche Technology, Inc. | Emulation of static random access memory (SRAM) by magnetic random access memory (MRAM) |
US8892809B2 (en) * | 2010-10-25 | 2014-11-18 | Marvell World Trade Ltd. | Data compression and encoding in a memory system |
US8938574B2 (en) * | 2010-10-26 | 2015-01-20 | Lsi Corporation | Methods and systems using solid-state drives as storage controller cache memory |
US8447925B2 (en) | 2010-11-01 | 2013-05-21 | Taejin Info Tech Co., Ltd. | Home storage device and software including management and monitoring modules |
US8990494B2 (en) | 2010-11-01 | 2015-03-24 | Taejin Info Tech Co., Ltd. | Home storage system and method with various controllers |
US9092149B2 (en) | 2010-11-03 | 2015-07-28 | Microsoft Technology Licensing, Llc | Virtualization and offload reads and writes |
US9063878B2 (en) | 2010-11-03 | 2015-06-23 | Densbits Technologies Ltd. | Method, system and computer readable medium for copy back |
US9465728B2 (en) | 2010-11-03 | 2016-10-11 | Nvidia Corporation | Memory controller adaptable to multiple memory devices |
CN102467440A (zh) * | 2010-11-09 | 2012-05-23 | 鸿富锦精密工业(深圳)有限公司 | 内存错误检测系统及方法 |
TWI474329B (zh) * | 2010-11-15 | 2015-02-21 | Silicon Motion Inc | 提昇錯誤更正能力之方法以及記憶裝置及控制器 |
US8601197B2 (en) * | 2010-11-15 | 2013-12-03 | Atmel Rousset S.A.S. | Microcontroller including flexible connections between modules |
TW201222273A (en) * | 2010-11-29 | 2012-06-01 | Inventec Corp | Computer system and method for managing computer device |
TW201224288A (en) * | 2010-12-01 | 2012-06-16 | Hon Hai Prec Ind Co Ltd | System and method for controlling a fan |
CN103348330B (zh) * | 2010-12-01 | 2017-05-24 | 希捷科技有限公司 | 采用独立硅元件的动态较高级冗余模式管理 |
US8850100B2 (en) | 2010-12-07 | 2014-09-30 | Densbits Technologies Ltd. | Interleaving codeword portions between multiple planes and/or dies of a flash memory device |
JP2012123499A (ja) * | 2010-12-07 | 2012-06-28 | Toshiba Corp | メモリシステム |
US9021472B2 (en) * | 2010-12-10 | 2015-04-28 | Lenovo Enterprise Solutions (Singapore) Pte. Ltd. | Virtualizing baseboard management controller operation |
US10817502B2 (en) | 2010-12-13 | 2020-10-27 | Sandisk Technologies Llc | Persistent memory management |
US10817421B2 (en) | 2010-12-13 | 2020-10-27 | Sandisk Technologies Llc | Persistent data structures |
US9280477B2 (en) * | 2010-12-13 | 2016-03-08 | Seagate Technology Llc | Data storage management in a memory device |
US9218278B2 (en) | 2010-12-13 | 2015-12-22 | SanDisk Technologies, Inc. | Auto-commit memory |
US9208071B2 (en) | 2010-12-13 | 2015-12-08 | SanDisk Technologies, Inc. | Apparatus, system, and method for accessing memory |
EP2652623B1 (en) | 2010-12-13 | 2018-08-01 | SanDisk Technologies LLC | Apparatus, system, and method for auto-commit memory |
US9047178B2 (en) | 2010-12-13 | 2015-06-02 | SanDisk Technologies, Inc. | Auto-commit memory synchronization |
JP5296041B2 (ja) * | 2010-12-15 | 2013-09-25 | 株式会社東芝 | メモリシステムおよびメモリシステムの制御方法 |
US8560792B2 (en) | 2010-12-16 | 2013-10-15 | International Business Machines Corporation | Synchronous extent migration protocol for paired storage |
CN105702277B (zh) | 2010-12-17 | 2018-05-08 | 艾沃思宾技术公司 | 存储器系统和存储器控制器 |
US20120239860A1 (en) | 2010-12-17 | 2012-09-20 | Fusion-Io, Inc. | Apparatus, system, and method for persistent data management on a non-volatile storage media |
US8412816B2 (en) * | 2010-12-17 | 2013-04-02 | Dell Products L.P. | Native bi-directional communication for hardware management |
US8438247B1 (en) * | 2010-12-21 | 2013-05-07 | Amazon Technologies, Inc. | Techniques for capturing data sets |
AU2015202148B2 (en) * | 2010-12-21 | 2016-05-05 | Amazon Technologies, Inc. | Techniques for capturing data sets |
TW201241615A (en) | 2011-01-18 | 2012-10-16 | Lsi Corp | Higher-level redundancy information computation |
US9213594B2 (en) | 2011-01-19 | 2015-12-15 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for managing out-of-service conditions |
US8972650B2 (en) * | 2011-01-28 | 2015-03-03 | Apple Inc. | Methods and systems for performing efficient page reads in a non-volatile memory |
US20120198126A1 (en) * | 2011-01-28 | 2012-08-02 | Apple Inc. | Methods and systems for performing selective block switching to perform read operations in a non-volatile memory |
US9092337B2 (en) | 2011-01-31 | 2015-07-28 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for managing eviction of data |
US8595415B2 (en) * | 2011-02-02 | 2013-11-26 | Micron Technology, Inc. | At least semi-autonomous modules in a memory system and methods |
US8639971B1 (en) * | 2011-02-17 | 2014-01-28 | Scale Computing | Condition detection and reporting in complex systems |
CN102110154B (zh) * | 2011-02-21 | 2012-12-26 | 中国科学院计算技术研究所 | 一种集群文件系统中文件冗余存储方法 |
KR20120096212A (ko) * | 2011-02-22 | 2012-08-30 | 삼성전자주식회사 | 비휘발성 메모리 장치, 메모리 컨트롤러, 및 이들의 동작 방법 |
WO2012116369A2 (en) * | 2011-02-25 | 2012-08-30 | Fusion-Io, Inc. | Apparatus, system, and method for managing contents of a cache |
US8705544B2 (en) | 2011-03-07 | 2014-04-22 | Broadcom Corporation | Method and apparatus for routing in a single tier switched network |
US9146765B2 (en) | 2011-03-11 | 2015-09-29 | Microsoft Technology Licensing, Llc | Virtual disk storage techniques |
WO2012129191A2 (en) | 2011-03-18 | 2012-09-27 | Fusion-Io, Inc. | Logical interfaces for contextual storage |
US9563555B2 (en) | 2011-03-18 | 2017-02-07 | Sandisk Technologies Llc | Systems and methods for storage allocation |
US8601085B1 (en) * | 2011-03-28 | 2013-12-03 | Emc Corporation | Techniques for preferred path determination |
JP5581256B2 (ja) * | 2011-03-28 | 2014-08-27 | 株式会社東芝 | メモリシステム、コントローラ、およびメモリシステムの制御方法 |
US8924500B2 (en) * | 2011-03-29 | 2014-12-30 | Amazon Technologies, Inc. | Local storage linked to networked storage system |
US9047955B2 (en) | 2011-03-30 | 2015-06-02 | Stec, Inc. | Adjusting operating parameters for memory cells based on wordline address and cycle information |
US8677031B2 (en) | 2011-03-31 | 2014-03-18 | Intel Corporation | Facilitating, at least in part, by circuitry, accessing of at least one controller command interface |
US9252985B2 (en) * | 2011-04-04 | 2016-02-02 | Taejin Info Tech Co., Ltd | Impedance matching between FPGA and memory modules |
US8990665B1 (en) | 2011-04-06 | 2015-03-24 | Densbits Technologies Ltd. | System, method and computer program product for joint search of a read threshold and soft decoding |
US10838886B2 (en) | 2011-04-19 | 2020-11-17 | Micron Technology, Inc. | Channel depth adjustment in memory systems |
TWI467365B (zh) * | 2011-04-20 | 2015-01-01 | Taejin Infotech Co Ltd | 受RAID控制的半導體儲存裝置及其形成方法以及PCI-Express類型的受RAID控制的半導體儲存裝置 |
US8527699B2 (en) | 2011-04-25 | 2013-09-03 | Pivot3, Inc. | Method and system for distributed RAID implementation |
US20120278527A1 (en) * | 2011-04-26 | 2012-11-01 | Byungcheol Cho | System architecture based on hybrid raid storage |
US20120278550A1 (en) * | 2011-04-26 | 2012-11-01 | Byungcheol Cho | System architecture based on raid controller collaboration |
US9176670B2 (en) * | 2011-04-26 | 2015-11-03 | Taejin Info Tech Co., Ltd. | System architecture based on asymmetric raid storage |
US8862804B2 (en) | 2011-04-29 | 2014-10-14 | Western Digital Technologies, Inc. | System and method for improved parity determination within a data redundancy scheme in a solid state memory |
US8909888B2 (en) * | 2011-04-29 | 2014-12-09 | Seagate Technology Llc | Secure erasure of data from a non-volatile memory |
US8832402B2 (en) * | 2011-04-29 | 2014-09-09 | Seagate Technology Llc | Self-initiated secure erasure responsive to an unauthorized power down event |
US9372792B1 (en) | 2011-05-12 | 2016-06-21 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Advanced management of a non-volatile memory |
US9396106B2 (en) | 2011-05-12 | 2016-07-19 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Advanced management of a non-volatile memory |
US8996790B1 (en) * | 2011-05-12 | 2015-03-31 | Densbits Technologies Ltd. | System and method for flash memory management |
US9110785B1 (en) | 2011-05-12 | 2015-08-18 | Densbits Technologies Ltd. | Ordered merge of data sectors that belong to memory space portions |
US9501392B1 (en) | 2011-05-12 | 2016-11-22 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Management of a non-volatile memory module |
US9195592B1 (en) | 2011-05-12 | 2015-11-24 | Densbits Technologies Ltd. | Advanced management of a non-volatile memory |
US8543758B2 (en) * | 2011-05-31 | 2013-09-24 | Micron Technology, Inc. | Apparatus including memory channel control circuit and related methods for relaying commands to logical units |
CN102223510B (zh) * | 2011-06-03 | 2012-11-14 | 浙江宇视科技有限公司 | 缓存调度方法和装置 |
KR101835604B1 (ko) | 2011-06-03 | 2018-03-07 | 삼성전자 주식회사 | 메모리를 위한 스케줄러 |
US20120311271A1 (en) * | 2011-06-06 | 2012-12-06 | Sanrad, Ltd. | Read Cache Device and Methods Thereof for Accelerating Access to Data in a Storage Area Network |
WO2012168960A1 (en) * | 2011-06-07 | 2012-12-13 | Hitachi, Ltd. | Semiconductor storage apparatus and method of controlling semiconductor storage apparatus |
US9329939B2 (en) * | 2011-06-08 | 2016-05-03 | Taejin Info Tech Co., Ltd | Two-way raid controller for a semiconductor storage device |
US9183165B2 (en) * | 2011-06-10 | 2015-11-10 | International Business Machines Corporation | Firmware management of storage class memory for connected or disconnected I/O adapters |
US8819302B2 (en) | 2011-06-13 | 2014-08-26 | Lsi Corporation | System to manage input/output performance and/or deadlock in network attached storage gateway connected to a storage area network environment |
US9417894B1 (en) | 2011-06-15 | 2016-08-16 | Ryft Systems, Inc. | Methods and apparatus for a tablet computer system incorporating a reprogrammable circuit module |
US20120324143A1 (en) | 2011-06-15 | 2012-12-20 | Data Design Corporation | Methods and apparatus for data access by a reprogrammable circuit module |
US8819316B2 (en) * | 2011-06-21 | 2014-08-26 | Taejin Info Tech Co., Ltd. | Two-way raid controller with programmable host interface for a semiconductor storage device |
US8924630B2 (en) * | 2011-06-21 | 2014-12-30 | Taejin Info Tech Co., Ltd. | Semiconductor storage device-based high-speed cache storage system |
US8904106B2 (en) | 2011-06-22 | 2014-12-02 | International Business Machines Corporation | Parallel block allocation for declustered logical disks |
US10966339B1 (en) * | 2011-06-28 | 2021-03-30 | Amazon Technologies, Inc. | Storage system with removable solid state storage devices mounted on carrier circuit boards |
CN102855146B (zh) * | 2011-06-30 | 2016-05-11 | 鸿富锦精密工业(深圳)有限公司 | 固件更新系统及方法 |
US9207879B2 (en) * | 2011-07-06 | 2015-12-08 | Taejin Info Tech Co., Ltd. | Redundant array of independent disk (RAID) controlled semiconductor storage device (SSD)-based system having a high-speed non-volatile host interface |
US9417823B2 (en) | 2011-07-12 | 2016-08-16 | Violin Memory Inc. | Memory system management |
US9335939B2 (en) | 2011-07-12 | 2016-05-10 | Violin Memory Inc. | RAIDed memory system |
US9104651B1 (en) | 2011-07-15 | 2015-08-11 | Scale Computing, Inc. | Techniques for distributing tests and test suites across a network |
US8949305B1 (en) * | 2011-07-15 | 2015-02-03 | Scale Computing, Inc. | Distributed dynamic system configuration |
US8671249B2 (en) | 2011-07-22 | 2014-03-11 | Fusion-Io, Inc. | Apparatus, system, and method for managing storage capacity recovery |
US8880977B2 (en) | 2011-07-22 | 2014-11-04 | Sandisk Technologies Inc. | Systems and methods of storing data |
US12099752B2 (en) | 2011-07-27 | 2024-09-24 | Pure Storage, Inc. | Error prediction based on correlation using event records |
US11016702B2 (en) | 2011-07-27 | 2021-05-25 | Pure Storage, Inc. | Hierarchical event tree |
WO2013016013A1 (en) * | 2011-07-27 | 2013-01-31 | Cleversafe, Inc. | Generating dispersed storage network event records |
US10678619B2 (en) | 2011-07-27 | 2020-06-09 | Pure Storage, Inc. | Unified logs and device statistics |
US9063841B1 (en) * | 2011-08-01 | 2015-06-23 | Marvell Israel (M.L.S.L.) Ltd. | External memory management in a network device |
US20130036263A1 (en) * | 2011-08-01 | 2013-02-07 | Shu-Min Liu | Solid state storage device using volatile memory |
US8776094B2 (en) | 2011-08-11 | 2014-07-08 | Microsoft Corporation | Runtime system |
US9385874B2 (en) | 2013-01-23 | 2016-07-05 | Nexenta Systems, Inc. | Scalable transport with client-consensus rendezvous |
KR20130021633A (ko) * | 2011-08-23 | 2013-03-06 | 삼성전자주식회사 | 오류정정부호를 이용한 데이터의 은닉과 검출 방법 및 장치 |
US8931107B1 (en) * | 2011-08-30 | 2015-01-06 | Amazon Technologies, Inc. | Techniques for generating block level data captures |
US8656251B2 (en) * | 2011-09-02 | 2014-02-18 | Apple Inc. | Simultaneous data transfer and error control to reduce latency and improve throughput to a host |
US8713357B1 (en) | 2011-09-06 | 2014-04-29 | Western Digital Technologies, Inc. | Systems and methods for detailed error reporting in data storage systems |
US8700834B2 (en) | 2011-09-06 | 2014-04-15 | Western Digital Technologies, Inc. | Systems and methods for an enhanced controller architecture in data storage systems |
US9195530B1 (en) * | 2011-09-06 | 2015-11-24 | Western Digital Technologies, Inc. | Systems and methods for improved data management in data storage systems |
US8707104B1 (en) | 2011-09-06 | 2014-04-22 | Western Digital Technologies, Inc. | Systems and methods for error injection in data storage systems |
US20130067289A1 (en) * | 2011-09-14 | 2013-03-14 | Ariel Maislos | Efficient non-volatile read cache for storage system |
US20130081033A1 (en) * | 2011-09-23 | 2013-03-28 | Elwha Llc | Configuring interface devices with respect to tasks and subtasks |
US9269063B2 (en) | 2011-09-23 | 2016-02-23 | Elwha Llc | Acquiring and transmitting event related tasks and subtasks to interface devices |
US9619357B2 (en) | 2011-09-28 | 2017-04-11 | International Business Machines Corporation | Hybrid storage devices |
EP3451176B1 (en) | 2011-09-30 | 2023-05-24 | Intel Corporation | Apparatus and method for implementing a multi-level memory hierarchy having different operating modes |
WO2013048490A1 (en) | 2011-09-30 | 2013-04-04 | Intel Corporation | Non-volatile random access memory (nvram) as a replacement for traditional mass storage |
CN107391397B (zh) * | 2011-09-30 | 2021-07-27 | 英特尔公司 | 支持近存储器和远存储器访问的存储器通道 |
EP2761476B1 (en) | 2011-09-30 | 2017-10-25 | Intel Corporation | Apparatus, method and system that stores bios in non-volatile random access memory |
CN103946814B (zh) * | 2011-09-30 | 2017-06-06 | 英特尔公司 | 计算机系统中的非易失性随机存取存储器的自主初始化 |
JP5869135B2 (ja) | 2011-09-30 | 2016-02-24 | インテル コーポレイション | コプロセッサのためのダイレクトi/oアクセス |
US8782492B2 (en) * | 2011-10-04 | 2014-07-15 | Cleversafe, Inc. | Updating data stored in a dispersed storage network |
US9372755B1 (en) | 2011-10-05 | 2016-06-21 | Bitmicro Networks, Inc. | Adaptive power cycle sequences for data recovery |
CN102447732A (zh) * | 2011-10-11 | 2012-05-09 | 浪潮电子信息产业股份有限公司 | 一种在bmc开发中智能配置宿主机嵌入式环境的方法 |
US9813491B2 (en) * | 2011-10-20 | 2017-11-07 | Oracle International Corporation | Highly available network filer with automatic load balancing and performance adjustment |
US9263106B2 (en) * | 2011-10-21 | 2016-02-16 | Nvidia Corporation | Efficient command mapping scheme for short data burst length memory devices |
US9047068B2 (en) * | 2011-10-31 | 2015-06-02 | Dell Products L.P. | Information handling system storage device management information access |
US8694855B1 (en) | 2011-11-02 | 2014-04-08 | Pmc-Sierra Us, Inc. | Error correction code technique for improving read stress endurance |
US8938658B2 (en) | 2011-11-07 | 2015-01-20 | Sandisk Enterprise Ip Llc | Statistical read comparison signal generation for memory systems |
US8966172B2 (en) | 2011-11-15 | 2015-02-24 | Pavilion Data Systems, Inc. | Processor agnostic data storage in a PCIE based shared storage enviroment |
TW201321943A (zh) * | 2011-11-17 | 2013-06-01 | Hon Hai Prec Ind Co Ltd | 風扇控制系統及方法 |
US9015411B2 (en) * | 2011-12-02 | 2015-04-21 | Compellent Technologies | System and method for unbalanced raid management |
US20130238900A1 (en) | 2011-12-12 | 2013-09-12 | Cleversafe, Inc. | Dispersed storage network secure hierarchical file directory |
US10176045B2 (en) | 2011-12-12 | 2019-01-08 | International Business Machines Corporation | Internet based shared memory in a distributed computing system |
US9298548B2 (en) * | 2011-12-12 | 2016-03-29 | Cleversafe, Inc. | Distributed computing in a distributed storage and task network |
US10671585B2 (en) * | 2012-01-31 | 2020-06-02 | Pure Storage, Inc. | Storing indexed data to a dispersed storage network |
US9430286B2 (en) | 2011-12-12 | 2016-08-30 | International Business Machines Corporation | Authorizing distributed task processing in a distributed storage network |
US8959416B1 (en) * | 2011-12-16 | 2015-02-17 | Western Digital Technologies, Inc. | Memory defect management using signature identification |
US8694849B1 (en) * | 2011-12-19 | 2014-04-08 | Pmc-Sierra Us, Inc. | Shuffler error correction code system and method |
US8806111B2 (en) | 2011-12-20 | 2014-08-12 | Fusion-Io, Inc. | Apparatus, system, and method for backing data of a non-volatile storage device using a backing store |
CN103176759A (zh) * | 2011-12-20 | 2013-06-26 | 鸿富锦精密工业(深圳)有限公司 | Bios post代码显示系统及方法 |
US10133662B2 (en) | 2012-06-29 | 2018-11-20 | Sandisk Technologies Llc | Systems, methods, and interfaces for managing persistent data of atomic storage operations |
US9274937B2 (en) | 2011-12-22 | 2016-03-01 | Longitude Enterprise Flash S.A.R.L. | Systems, methods, and interfaces for vector input/output operations |
JP2015507798A (ja) * | 2011-12-29 | 2015-03-12 | メモリー テクノロジーズ リミティド ライアビリティ カンパニー | メモリ・モジュールにおいてデータ・エンティティを消去するための方法 |
US10209768B1 (en) | 2012-01-06 | 2019-02-19 | Seagate Technology Llc | File-aware priority driver |
US9817582B2 (en) * | 2012-01-09 | 2017-11-14 | Microsoft Technology Licensing, Llc | Offload read and write offload provider |
KR101888074B1 (ko) * | 2012-01-09 | 2018-08-13 | 삼성전자주식회사 | 저장 장치 및 불휘발성 메모리 장치, 그리고 그것의 동작 방법 |
US9767032B2 (en) | 2012-01-12 | 2017-09-19 | Sandisk Technologies Llc | Systems and methods for cache endurance |
US10102117B2 (en) | 2012-01-12 | 2018-10-16 | Sandisk Technologies Llc | Systems and methods for cache and storage device coordination |
WO2013105960A1 (en) * | 2012-01-12 | 2013-07-18 | Fusion-Io, Inc. | Systems and methods for managing cache admission |
US8782344B2 (en) | 2012-01-12 | 2014-07-15 | Fusion-Io, Inc. | Systems and methods for managing cache admission |
US9251052B2 (en) | 2012-01-12 | 2016-02-02 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for profiling a non-volatile cache having a logical-to-physical translation layer |
WO2013112634A1 (en) * | 2012-01-23 | 2013-08-01 | The Regents Of The University Of California | System and method for implementing transactions using storage device support for atomic updates and flexible interface for managing data logging |
US9251086B2 (en) | 2012-01-24 | 2016-02-02 | SanDisk Technologies, Inc. | Apparatus, system, and method for managing a cache |
US10359972B2 (en) | 2012-08-31 | 2019-07-23 | Sandisk Technologies Llc | Systems, methods, and interfaces for adaptive persistence |
US8775714B2 (en) * | 2012-01-30 | 2014-07-08 | Infineon Technologies Ag | System and method for a bus interface |
US9652182B2 (en) | 2012-01-31 | 2017-05-16 | Pavilion Data Systems, Inc. | Shareable virtual non-volatile storage device for a server |
US20130205065A1 (en) * | 2012-02-02 | 2013-08-08 | Lsi Corporation | Methods and structure for an improved solid-state drive for use in caching applications |
KR101445025B1 (ko) | 2012-02-09 | 2014-09-26 | 서울시립대학교 산학협력단 | 신뢰성 있는 ssd를 위한 효율적인 raid 기법 |
WO2013119074A1 (ko) * | 2012-02-09 | 2013-08-15 | Noh Sam Hyuk | 신뢰성 있는 ssd를 위한 효율적인 raid 기법 |
US8996788B2 (en) | 2012-02-09 | 2015-03-31 | Densbits Technologies Ltd. | Configurable flash interface |
US8947941B2 (en) | 2012-02-09 | 2015-02-03 | Densbits Technologies Ltd. | State responsive operations relating to flash memory cells |
US8949512B2 (en) * | 2012-02-17 | 2015-02-03 | Apple Inc. | Trim token journaling |
US9195586B2 (en) | 2012-02-23 | 2015-11-24 | Hgst Technologies Santa Ana, Inc. | Determining bias information for offsetting operating variations in memory cells based on wordline address |
US9171031B2 (en) * | 2012-03-02 | 2015-10-27 | Cleversafe, Inc. | Merging index nodes of a hierarchical dispersed storage index |
US10019353B2 (en) | 2012-03-02 | 2018-07-10 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for referencing data on a storage medium |
US20130238832A1 (en) * | 2012-03-07 | 2013-09-12 | Netapp, Inc. | Deduplicating hybrid storage aggregate |
US20130238851A1 (en) * | 2012-03-07 | 2013-09-12 | Netapp, Inc. | Hybrid storage aggregate block tracking |
US20130242425A1 (en) * | 2012-03-16 | 2013-09-19 | Toshiba America Electronics Components, Inc. | Write reordering in a hybrid disk drive |
JP5659178B2 (ja) * | 2012-03-16 | 2015-01-28 | 株式会社東芝 | 不揮発性記憶装置及び不揮発性メモリの制御方法 |
US8301832B1 (en) * | 2012-03-23 | 2012-10-30 | DSSD, Inc. | Storage system with guaranteed read latency |
US8554963B1 (en) * | 2012-03-23 | 2013-10-08 | DSSD, Inc. | Storage system with multicast DMA and unified address space |
CN103365667B (zh) * | 2012-03-26 | 2018-01-26 | 联想企业方案(新加坡)有限公司 | 一种在主机系统中安装操作系统的方法和装置 |
US9053008B1 (en) | 2012-03-26 | 2015-06-09 | Western Digital Technologies, Inc. | Systems and methods for providing inline parameter service in data storage devices |
US9135192B2 (en) | 2012-03-30 | 2015-09-15 | Sandisk Technologies Inc. | Memory system with command queue reordering |
US9268692B1 (en) * | 2012-04-05 | 2016-02-23 | Seagate Technology Llc | User selectable caching |
US9542324B1 (en) * | 2012-04-05 | 2017-01-10 | Seagate Technology Llc | File associated pinning |
CN104205779A (zh) * | 2012-04-06 | 2014-12-10 | 交互数字专利控股公司 | 端对端内容递送服务的优化 |
KR101969883B1 (ko) * | 2012-04-13 | 2019-04-17 | 에스케이하이닉스 주식회사 | 데이터 저장 장치 및 그것의 동작 방법 |
CN102681794B (zh) * | 2012-04-23 | 2014-12-10 | 浪潮(北京)电子信息产业有限公司 | 基于双控制器实现磁盘冗余阵列保护的方法及系统 |
US8996793B1 (en) | 2012-04-24 | 2015-03-31 | Densbits Technologies Ltd. | System, method and computer readable medium for generating soft information |
CN103377161A (zh) * | 2012-04-24 | 2013-10-30 | 鸿富锦精密工业(深圳)有限公司 | 主板及应用于该主板的数据处理方法 |
US9218462B2 (en) * | 2012-04-25 | 2015-12-22 | Hewlett Packard Enterprise Development Lp | Authentication using lights-out management credentials |
US10270652B2 (en) * | 2012-04-25 | 2019-04-23 | Hewlett Packard Enterprise Development Lp | Network management |
US8839073B2 (en) | 2012-05-04 | 2014-09-16 | Lsi Corporation | Zero-one balance management in a solid-state disk controller |
US8751710B2 (en) | 2012-05-08 | 2014-06-10 | Entegra Technologies, Inc. | Reconfigurable modular computing device |
KR101961324B1 (ko) * | 2012-05-09 | 2019-03-22 | 삼성전자주식회사 | 메모리 장치 및 메모리 장치의 파워 관리 방법 |
US8838937B1 (en) | 2012-05-23 | 2014-09-16 | Densbits Technologies Ltd. | Methods, systems and computer readable medium for writing and reading data |
US9077665B1 (en) | 2012-05-24 | 2015-07-07 | Scale Computing, Inc. | Transferring virtual machines and resource localization in a distributed fault-tolerant system |
US9251019B2 (en) | 2012-05-29 | 2016-02-02 | SanDisk Technologies, Inc. | Apparatus, system and method for managing solid-state retirement |
US9749413B2 (en) | 2012-05-29 | 2017-08-29 | Intel Corporation | Peer-to-peer interrupt signaling between devices coupled via interconnects |
CN102710763B (zh) * | 2012-05-29 | 2015-11-25 | 新华网股份有限公司 | 一种分布式缓存池化、分片及故障转移的方法及系统 |
US8879325B1 (en) | 2012-05-30 | 2014-11-04 | Densbits Technologies Ltd. | System, method and computer program product for processing read threshold information and for reading a flash memory module |
US8984201B2 (en) | 2012-06-01 | 2015-03-17 | International Business Machines Corporation | Providing I2C bus over Ethernet |
EP2859553B1 (en) * | 2012-06-07 | 2023-09-27 | VSIP Holdings LLC | Memory system management |
US9229901B1 (en) | 2012-06-08 | 2016-01-05 | Google Inc. | Single-sided distributed storage system |
US9172744B2 (en) * | 2012-06-14 | 2015-10-27 | Microsoft Technology Licensing, Llc | Scalable storage with programmable networks |
US20130339583A1 (en) * | 2012-06-19 | 2013-12-19 | Marvell World Trade Ltd. | Systems and methods for transferring data out of order in next generation solid state drive controllers |
US9003162B2 (en) | 2012-06-20 | 2015-04-07 | Microsoft Technology Licensing, Llc | Structuring storage based on latch-free B-trees |
US8924832B1 (en) * | 2012-06-26 | 2014-12-30 | Western Digital Technologies, Inc. | Efficient error handling mechanisms in data storage systems |
US20140006537A1 (en) * | 2012-06-28 | 2014-01-02 | Wiliam H. TSO | High speed record and playback system |
US9098302B2 (en) * | 2012-06-28 | 2015-08-04 | Intel Corporation | System and apparatus to improve boot speed in serial peripheral interface system using a baseboard management controller |
WO2014016860A1 (en) * | 2012-07-23 | 2014-01-30 | Hitachi, Ltd. | Raid storage system and rebuild process |
JP2014026388A (ja) * | 2012-07-25 | 2014-02-06 | Toshiba Corp | 記憶装置、コントローラ、および書き込み制御方法 |
US9712373B1 (en) * | 2012-07-30 | 2017-07-18 | Rambus Inc. | System and method for memory access in server communications |
US8856431B2 (en) | 2012-08-02 | 2014-10-07 | Lsi Corporation | Mixed granularity higher-level redundancy for non-volatile memory |
US20140052897A1 (en) * | 2012-08-17 | 2014-02-20 | Seagate Technology Llc | Dynamic formation of garbage collection units in a memory |
US9699263B1 (en) | 2012-08-17 | 2017-07-04 | Sandisk Technologies Llc. | Automatic read and write acceleration of data accessed by virtual machines |
CN103629132B (zh) * | 2012-08-20 | 2016-09-14 | 国网浙江桐庐县供电公司 | 风扇共享控制系统及方法 |
US10430216B1 (en) | 2012-08-23 | 2019-10-01 | Scale Computing Inc | Virtual machine automated selection |
US10019287B1 (en) | 2012-08-23 | 2018-07-10 | Scale Computing | Virtual machine resource display |
US9921954B1 (en) | 2012-08-27 | 2018-03-20 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Method and system for split flash memory management between host and storage controller |
US9094163B2 (en) * | 2012-08-28 | 2015-07-28 | Aoptix Technologies, Inc. | Assessment and correction of transmitted data |
US8862561B1 (en) | 2012-08-30 | 2014-10-14 | Google Inc. | Detecting read/write conflicts |
US9058122B1 (en) | 2012-08-30 | 2015-06-16 | Google Inc. | Controlling access in a single-sided distributed storage system |
US8676851B1 (en) | 2012-08-30 | 2014-03-18 | Google Inc. | Executing transactions in distributed storage systems |
US9164702B1 (en) | 2012-09-07 | 2015-10-20 | Google Inc. | Single-sided distributed cache system |
US20140075091A1 (en) * | 2012-09-10 | 2014-03-13 | Texas Instruments Incorporated | Processing Device With Restricted Power Domain Wakeup Restore From Nonvolatile Logic Array |
US9122873B2 (en) | 2012-09-14 | 2015-09-01 | The Research Foundation For The State University Of New York | Continuous run-time validation of program execution: a practical approach |
JP2014063497A (ja) * | 2012-09-21 | 2014-04-10 | Plx Technology Inc | 論理装置の機能を有するpciエクスプレススイッチ |
US10318495B2 (en) | 2012-09-24 | 2019-06-11 | Sandisk Technologies Llc | Snapshots for a non-volatile device |
US10509776B2 (en) | 2012-09-24 | 2019-12-17 | Sandisk Technologies Llc | Time sequence data management |
US9304828B2 (en) * | 2012-09-27 | 2016-04-05 | Hitachi, Ltd. | Hierarchy memory management |
TWI502600B (zh) * | 2012-09-28 | 2015-10-01 | Leadconn Technology Co Ltd | 記憶體識別碼修正裝置 |
US9069782B2 (en) | 2012-10-01 | 2015-06-30 | The Research Foundation For The State University Of New York | System and method for security and privacy aware virtual machine checkpointing |
US9652216B2 (en) * | 2012-10-04 | 2017-05-16 | Dell Products L.P. | System and method for providing out-of-band software or firmware upgrades for a switching device |
KR102081980B1 (ko) * | 2012-10-08 | 2020-02-27 | 삼성전자 주식회사 | 메모리 시스템에서의 라이트 동작 또는 리드 동작 수행 방법 |
US20140114928A1 (en) * | 2012-10-22 | 2014-04-24 | Robert Beers | Coherence protocol tables |
CN107045479B (zh) * | 2012-10-22 | 2020-09-01 | 英特尔公司 | 高性能互连物理层 |
US8972826B2 (en) | 2012-10-24 | 2015-03-03 | Western Digital Technologies, Inc. | Adaptive error correction codes for data storage systems |
US10216822B2 (en) * | 2012-11-02 | 2019-02-26 | Vod2, Inc. | Data distribution methods and systems |
US20150331615A1 (en) * | 2012-11-20 | 2015-11-19 | Empire Technology Development Llc | Multi-element solid-state storage device management |
US9098401B2 (en) | 2012-11-21 | 2015-08-04 | Apple Inc. | Fast secure erasure schemes for non-volatile memory |
US9368225B1 (en) | 2012-11-21 | 2016-06-14 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Determining read thresholds based upon read error direction statistics |
KR101988287B1 (ko) | 2012-11-26 | 2019-06-12 | 삼성전자주식회사 | 저장 장치 및 그것을 포함하는 컴퓨팅 시스템, 및 그것의 데이터 전송 방법 |
US9021339B2 (en) | 2012-11-29 | 2015-04-28 | Western Digital Technologies, Inc. | Data reliability schemes for data storage systems |
US9059736B2 (en) | 2012-12-03 | 2015-06-16 | Western Digital Technologies, Inc. | Methods, solid state drive controllers and data storage devices having a runtime variable raid protection scheme |
US9448883B1 (en) * | 2012-12-04 | 2016-09-20 | Cadence Design Systems, Inc. | System and method for allocating data in memory array having regions of varying storage reliability |
US9071585B2 (en) | 2012-12-12 | 2015-06-30 | Microsoft Technology Licensing, Llc | Copy offload for disparate offload providers |
CN104603737A (zh) | 2012-12-13 | 2015-05-06 | 株式会社日立制作所 | 实现存储设备的高速访问和数据保护的计算机、计算机系统和i/o请求处理方法 |
US9251201B2 (en) | 2012-12-14 | 2016-02-02 | Microsoft Technology Licensing, Llc | Compatibly extending offload token size |
CN104704569B (zh) * | 2012-12-19 | 2017-11-14 | 慧与发展有限责任合伙企业 | Nvram路径选择 |
US9639457B1 (en) * | 2012-12-20 | 2017-05-02 | Datadirect Networks, Inc. | Data storage system and method for data migration between high-performance computing architectures and data storage devices using storage controller with distributed XOR capability |
US9214963B1 (en) | 2012-12-21 | 2015-12-15 | Western Digital Technologies, Inc. | Method and system for monitoring data channel to enable use of dynamically adjustable LDPC coding parameters in a data storage system |
US9049265B1 (en) | 2012-12-26 | 2015-06-02 | Google Inc. | Serving remote access to storage resources |
US9501398B2 (en) | 2012-12-26 | 2016-11-22 | Sandisk Technologies Llc | Persistent storage device with NVRAM for staging writes |
US9612948B2 (en) | 2012-12-27 | 2017-04-04 | Sandisk Technologies Llc | Reads and writes between a contiguous data block and noncontiguous sets of logical address blocks in a persistent storage device |
US9703697B2 (en) | 2012-12-27 | 2017-07-11 | Intel Corporation | Sharing serial peripheral interface flash memory in a multi-node server system on chip platform environment |
US9239751B1 (en) | 2012-12-27 | 2016-01-19 | Sandisk Enterprise Ip Llc | Compressing data from multiple reads for error control management in memory systems |
US9848029B2 (en) * | 2012-12-28 | 2017-12-19 | Opentv, Inc. | Highly-scalable data transmission |
WO2014102879A1 (en) * | 2012-12-28 | 2014-07-03 | Hitachi, Ltd. | Data storage apparatus and control method thereof |
US9454420B1 (en) | 2012-12-31 | 2016-09-27 | Sandisk Technologies Llc | Method and system of reading threshold voltage equalization |
US9069659B1 (en) | 2013-01-03 | 2015-06-30 | Densbits Technologies Ltd. | Read threshold determination using reference read threshold |
US9727268B2 (en) | 2013-01-08 | 2017-08-08 | Lyve Minds, Inc. | Management of storage in a storage network |
JP5985403B2 (ja) * | 2013-01-10 | 2016-09-06 | 株式会社東芝 | ストレージ装置 |
US8995302B1 (en) | 2013-01-16 | 2015-03-31 | Pmc-Sierra Us, Inc. | Method and apparatus for translated routing in an interconnect switch |
US9224452B2 (en) * | 2013-01-17 | 2015-12-29 | Qualcomm Incorporated | Heterogeneous memory systems, and related methods and computer-readable media for supporting heterogeneous memory access requests in processor-based systems |
JP2014137721A (ja) * | 2013-01-17 | 2014-07-28 | Toshiba Corp | 記憶制御装置、データ記憶装置及び記憶制御方法 |
US9143279B2 (en) * | 2013-01-18 | 2015-09-22 | Qualcomm Incorporated | Methods and devices for facilitating data retransmissions in wireless communication systems |
US9542101B2 (en) * | 2013-01-22 | 2017-01-10 | Avago Technologies General Ip (Singapore) Pte. Ltd. | System and methods for performing embedded full-stripe write operations to a data volume with data elements distributed across multiple modules |
US9195585B2 (en) | 2013-01-23 | 2015-11-24 | Vmware, Inc. | Techniques for allocating and surfacing host-side storage capacity to virtual machines |
US9652376B2 (en) | 2013-01-28 | 2017-05-16 | Radian Memory Systems, Inc. | Cooperative flash memory control |
US11249652B1 (en) | 2013-01-28 | 2022-02-15 | Radian Memory Systems, Inc. | Maintenance of nonvolatile memory on host selected namespaces by a common memory controller |
US9092353B1 (en) | 2013-01-29 | 2015-07-28 | Pmc-Sierra Us, Inc. | Apparatus and method based on LDPC codes for adjusting a correctable raw bit error rate limit in a memory system |
US9128858B1 (en) | 2013-01-29 | 2015-09-08 | Pmc-Sierra Us, Inc. | Apparatus and method for adjusting a correctable raw bit error rate limit in a memory system using strong log-likelihood (LLR) values |
US9256384B2 (en) | 2013-02-04 | 2016-02-09 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Method and system for reducing write latency in a data storage system by using a command-push model |
US9930066B2 (en) | 2013-02-12 | 2018-03-27 | Nicira, Inc. | Infrastructure level LAN security |
US20140229695A1 (en) * | 2013-02-13 | 2014-08-14 | Dell Products L.P. | Systems and methods for backup in scale-out storage clusters |
US8990661B1 (en) | 2013-03-05 | 2015-03-24 | Pmc-Sierra Us, Inc. | Layer specific attenuation factor LDPC decoder |
US10230396B1 (en) | 2013-03-05 | 2019-03-12 | Microsemi Solutions (Us), Inc. | Method and apparatus for layer-specific LDPC decoding |
US9813080B1 (en) | 2013-03-05 | 2017-11-07 | Microsemi Solutions (U.S.), Inc. | Layer specific LDPC decoder |
US11966355B2 (en) * | 2013-03-10 | 2024-04-23 | Mellanox Technologies, Ltd. | Network adapter with a common queue for both networking and data manipulation work requests |
US10275375B2 (en) | 2013-03-10 | 2019-04-30 | Mellanox Technologies, Ltd. | Network interface controller with compression capabilities |
US9397701B1 (en) | 2013-03-11 | 2016-07-19 | Microsemi Storage Solutions (Us), Inc. | System and method for lifetime specific LDPC decoding |
US8935598B1 (en) | 2013-03-12 | 2015-01-13 | Pmc-Sierra Us, Inc. | System and method for adaptive check node approximation in LDPC decoding |
US9870830B1 (en) | 2013-03-14 | 2018-01-16 | Sandisk Technologies Llc | Optimal multilevel sensing for reading data from a storage medium |
US9727453B2 (en) * | 2013-03-14 | 2017-08-08 | Sandisk Technologies Llc | Multi-level table deltas |
US8984376B1 (en) | 2013-03-14 | 2015-03-17 | Pmc-Sierra Us, Inc. | System and method for avoiding error mechanisms in layered iterative decoding |
US9478271B2 (en) * | 2013-03-14 | 2016-10-25 | Seagate Technology Llc | Nonvolatile memory data recovery after power failure |
US8984365B1 (en) | 2013-03-14 | 2015-03-17 | Pmc-Sierra Us, Inc. | System and method for reduced memory storage in LDPC decoding |
US10817312B2 (en) * | 2013-03-14 | 2020-10-27 | Microsoft Technology Licensing, Llc | Programming model for performant computing in document-oriented storage services |
US9934045B1 (en) | 2013-03-15 | 2018-04-03 | Bitmicro Networks, Inc. | Embedded system boot from a storage device |
US9842053B2 (en) * | 2013-03-15 | 2017-12-12 | Sandisk Technologies Llc | Systems and methods for persistent cache logging |
US9367246B2 (en) | 2013-03-15 | 2016-06-14 | Sandisk Technologies Inc. | Performance optimization of data transfer for soft information generation |
US10120694B2 (en) | 2013-03-15 | 2018-11-06 | Bitmicro Networks, Inc. | Embedded system boot from a storage device |
US9590656B2 (en) | 2013-03-15 | 2017-03-07 | Microsemi Storage Solutions (Us), Inc. | System and method for higher quality log likelihood ratios in LDPC decoding |
US9092350B1 (en) | 2013-03-15 | 2015-07-28 | Sandisk Enterprise Ip Llc | Detection and handling of unbalanced errors in interleaved codewords |
US9136877B1 (en) | 2013-03-15 | 2015-09-15 | Sandisk Enterprise Ip Llc | Syndrome layered decoding for LDPC codes |
US8983967B2 (en) * | 2013-03-15 | 2015-03-17 | Datadirect Networks, Inc. | Data storage system having mutable objects incorporating time |
US10489318B1 (en) | 2013-03-15 | 2019-11-26 | Bitmicro Networks, Inc. | Scatter-gather approach for parallel data transfer in a mass storage system |
US9430386B2 (en) | 2013-03-15 | 2016-08-30 | Bitmicro Networks, Inc. | Multi-leveled cache management in a hybrid storage system |
US9454414B2 (en) | 2013-03-15 | 2016-09-27 | Microsemi Storage Solutions (Us), Inc. | System and method for accumulating soft information in LDPC decoding |
US9798688B1 (en) | 2013-03-15 | 2017-10-24 | Bitmicro Networks, Inc. | Bus arbitration with routing and failover mechanism |
US8954657B1 (en) * | 2013-09-27 | 2015-02-10 | Avalanche Technology, Inc. | Storage processor managing solid state disk array |
US9244763B1 (en) | 2013-03-15 | 2016-01-26 | Sandisk Enterprise Ip Llc | System and method for updating a reading threshold voltage based on symbol transition information |
US9236886B1 (en) | 2013-03-15 | 2016-01-12 | Sandisk Enterprise Ip Llc | Universal and reconfigurable QC-LDPC encoder |
US9448738B2 (en) | 2013-03-15 | 2016-09-20 | Western Digital Technologies, Inc. | Compression and formatting of data for data storage systems |
US9335950B2 (en) * | 2013-03-15 | 2016-05-10 | Western Digital Technologies, Inc. | Multiple stream compression and formatting of data for data storage systems |
US9672178B1 (en) | 2013-03-15 | 2017-06-06 | Bitmicro Networks, Inc. | Bit-mapped DMA transfer with dependency table configured to monitor status so that a processor is not rendered as a bottleneck in a system |
US9450610B1 (en) | 2013-03-15 | 2016-09-20 | Microsemi Storage Solutions (Us), Inc. | High quality log likelihood ratios determined using two-index look-up table |
US9235467B2 (en) | 2013-03-15 | 2016-01-12 | Pmc-Sierra Us, Inc. | System and method with reference voltage partitioning for low density parity check decoding |
US9501436B1 (en) | 2013-03-15 | 2016-11-22 | Bitmicro Networks, Inc. | Multi-level message passing descriptor |
US9612900B2 (en) * | 2013-03-15 | 2017-04-04 | SEAKR Engineering, Inc. | Centralized configuration control of reconfigurable computing devices |
US9990382B1 (en) * | 2013-04-10 | 2018-06-05 | Amazon Technologies, Inc. | Secure erasure and repair of non-mechanical storage media |
US9552176B2 (en) * | 2013-04-12 | 2017-01-24 | Microsoft Technology Licensing, Llc | Block storage using a hybrid memory device |
US10102144B2 (en) | 2013-04-16 | 2018-10-16 | Sandisk Technologies Llc | Systems, methods and interfaces for data virtualization |
US10558561B2 (en) | 2013-04-16 | 2020-02-11 | Sandisk Technologies Llc | Systems and methods for storage metadata management |
TWI489296B (zh) * | 2013-05-17 | 2015-06-21 | Wistron Corp | 電腦 |
US10127166B2 (en) * | 2013-05-21 | 2018-11-13 | Sandisk Technologies Llc | Data storage controller with multiple pipelines |
US9336166B1 (en) * | 2013-05-30 | 2016-05-10 | Emc Corporation | Burst buffer appliance with operating system bypass functionality to facilitate remote direct memory access |
JP2014235531A (ja) * | 2013-05-31 | 2014-12-15 | 株式会社東芝 | データ転送装置、データ転送システム、およびプログラム |
US9009375B2 (en) | 2013-06-11 | 2015-04-14 | Lsi Corporation | Sharing of bypassed I/O transaction information |
US9159437B2 (en) | 2013-06-11 | 2015-10-13 | Sandisk Enterprise IP LLC. | Device and method for resolving an LM flag issue |
US9058267B2 (en) | 2013-06-11 | 2015-06-16 | Avago Technologies General IP Singapore) Pte Ltd | I/O path selection |
US9697358B2 (en) * | 2013-06-13 | 2017-07-04 | Google Inc. | Non-volatile memory operations |
US9136876B1 (en) | 2013-06-13 | 2015-09-15 | Densbits Technologies Ltd. | Size limited multi-dimensional decoding |
CN103336671B (zh) * | 2013-06-17 | 2016-07-13 | 北京奇虎科技有限公司 | 从网络中获取数据的方法和设备 |
CN104238638A (zh) * | 2013-06-17 | 2014-12-24 | 中兴通讯股份有限公司 | 一种小型化的计算存储融合系统 |
US9519591B2 (en) * | 2013-06-22 | 2016-12-13 | Microsoft Technology Licensing, Llc | Latch-free, log-structured storage for multiple access methods |
US9785355B2 (en) | 2013-06-26 | 2017-10-10 | Cnex Labs, Inc. | NVM express controller for remote access of memory and I/O over ethernet-type networks |
US9785356B2 (en) | 2013-06-26 | 2017-10-10 | Cnex Labs, Inc. | NVM express controller for remote access of memory and I/O over ethernet-type networks |
US10063638B2 (en) | 2013-06-26 | 2018-08-28 | Cnex Labs, Inc. | NVM express controller for remote access of memory and I/O over ethernet-type networks |
US9430412B2 (en) * | 2013-06-26 | 2016-08-30 | Cnex Labs, Inc. | NVM express controller for remote access of memory and I/O over Ethernet-type networks |
US9122712B1 (en) * | 2013-06-28 | 2015-09-01 | Emc Corporation | Compressing container files |
US9311110B2 (en) * | 2013-07-08 | 2016-04-12 | Intel Corporation | Techniques to initialize from a remotely accessible storage device |
US9030883B2 (en) * | 2013-07-16 | 2015-05-12 | Freescale Semiconductor, Inc. | Adaptive erase recovery for non-volatile memory (NVM) systems |
US8949486B1 (en) | 2013-07-17 | 2015-02-03 | Mellanox Technologies Ltd. | Direct memory access to storage devices |
US9092321B2 (en) | 2013-07-24 | 2015-07-28 | NXGN Data, Inc. | System and method for performing efficient searches and queries in a storage node |
US9336313B1 (en) | 2013-07-24 | 2016-05-10 | NXGN Data, Inc. | Systems and methods for performing single and multi threaded searches and complex pattern matching in a solid state drive |
US9021189B2 (en) * | 2013-07-24 | 2015-04-28 | NXGN Data, Inc. | System and method for performing efficient processing of data stored in a storage node |
US9336135B1 (en) | 2013-07-24 | 2016-05-10 | NXGN Data, Inc. | Systems and methods for performing search and complex pattern matching in a solid state drive |
US9524235B1 (en) | 2013-07-25 | 2016-12-20 | Sandisk Technologies Llc | Local hash value generation in non-volatile data storage systems |
US9384126B1 (en) | 2013-07-25 | 2016-07-05 | Sandisk Technologies Inc. | Methods and systems to avoid false negative results in bloom filters implemented in non-volatile data storage systems |
CN105283923A (zh) * | 2013-07-31 | 2016-01-27 | 惠普发展公司,有限责任合伙企业 | 存储器模块外的ecc辅助存储器系统 |
US9842128B2 (en) | 2013-08-01 | 2017-12-12 | Sandisk Technologies Llc | Systems and methods for atomic storage operations |
US9448896B2 (en) | 2013-08-07 | 2016-09-20 | Seagate Technology Llc | Torn write mitigation |
KR102081588B1 (ko) | 2013-08-08 | 2020-02-26 | 삼성전자 주식회사 | Ecc 디코더의 동작 방법 및 그것을 포함하는 메모리 컨트롤러 |
US9639463B1 (en) | 2013-08-26 | 2017-05-02 | Sandisk Technologies Llc | Heuristic aware garbage collection scheme in storage systems |
US9361221B1 (en) | 2013-08-26 | 2016-06-07 | Sandisk Technologies Inc. | Write amplification reduction through reliable writes during garbage collection |
GB201315435D0 (en) | 2013-08-30 | 2013-10-16 | Ibm | Cache management in a computerized system |
US9684686B1 (en) * | 2013-09-04 | 2017-06-20 | Amazon Technologies, Inc. | Database system recovery using non-volatile system memory |
EP2926214B1 (en) * | 2013-09-04 | 2017-04-12 | IDT Europe GmbH | Fpga power management system |
US9313274B2 (en) * | 2013-09-05 | 2016-04-12 | Google Inc. | Isolating clients of distributed storage systems |
US9298534B2 (en) * | 2013-09-05 | 2016-03-29 | Kabushiki Kaisha Toshiba | Memory system and constructing method of logical block |
US20150082063A1 (en) * | 2013-09-18 | 2015-03-19 | Lenovo (Singapore) Pte. Ltd. | Baseboard management controller state transitions |
CN103488435B (zh) * | 2013-09-24 | 2017-08-04 | 华为技术有限公司 | Raid子系统及其数据读写方法 |
US9658799B2 (en) | 2013-09-25 | 2017-05-23 | International Business Machines Corporation | Data storage device deferred secure delete |
CN105579983A (zh) * | 2013-09-25 | 2016-05-11 | 慧与发展有限责任合伙企业 | 提供对等系统标识的基板管理控制器 |
US9413491B1 (en) | 2013-10-08 | 2016-08-09 | Avago Technologies General Ip (Singapore) Pte. Ltd. | System and method for multiple dimension decoding and encoding a message |
US9348694B1 (en) | 2013-10-09 | 2016-05-24 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Detecting and managing bad columns |
US9397706B1 (en) | 2013-10-09 | 2016-07-19 | Avago Technologies General Ip (Singapore) Pte. Ltd. | System and method for irregular multiple dimension decoding and encoding |
US9786388B1 (en) | 2013-10-09 | 2017-10-10 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Detecting and managing bad columns |
US10019320B2 (en) | 2013-10-18 | 2018-07-10 | Sandisk Technologies Llc | Systems and methods for distributed atomic storage operations |
US9298608B2 (en) | 2013-10-18 | 2016-03-29 | Sandisk Enterprise Ip Llc | Biasing for wear leveling in storage systems |
US10019352B2 (en) | 2013-10-18 | 2018-07-10 | Sandisk Technologies Llc | Systems and methods for adaptive reserve storage |
US9442662B2 (en) | 2013-10-18 | 2016-09-13 | Sandisk Technologies Llc | Device and method for managing die groups |
US10444998B1 (en) | 2013-10-24 | 2019-10-15 | Western Digital Technologies, Inc. | Data storage device providing data maintenance services |
US9330143B2 (en) * | 2013-10-24 | 2016-05-03 | Western Digital Technologies, Inc. | Data storage device supporting accelerated database operations |
US9690515B2 (en) * | 2013-10-25 | 2017-06-27 | Sandisk Technologies Llc | Delayed automation to maximize the utilization of read and write cache |
CN103530417B (zh) * | 2013-10-29 | 2016-08-17 | 北京视博数字电视科技有限公司 | 文件解包方法和装置 |
US9436831B2 (en) | 2013-10-30 | 2016-09-06 | Sandisk Technologies Llc | Secure erase in a memory device |
US9263156B2 (en) | 2013-11-07 | 2016-02-16 | Sandisk Enterprise Ip Llc | System and method for adjusting trip points within a storage device |
US10073630B2 (en) | 2013-11-08 | 2018-09-11 | Sandisk Technologies Llc | Systems and methods for log coordination |
TWI510910B (zh) * | 2013-11-11 | 2015-12-01 | Wistron Corp | 電腦系統及其遠端控制方法 |
US9244785B2 (en) | 2013-11-13 | 2016-01-26 | Sandisk Enterprise Ip Llc | Simulated power failure and data hardening |
US9703816B2 (en) | 2013-11-19 | 2017-07-11 | Sandisk Technologies Llc | Method and system for forward reference logging in a persistent datastore |
US9520197B2 (en) | 2013-11-22 | 2016-12-13 | Sandisk Technologies Llc | Adaptive erase of a storage device |
US9141291B2 (en) | 2013-11-26 | 2015-09-22 | Sandisk Technologies Inc. | Adaptive context disbursement for improved performance in non-volatile memory systems |
US9520162B2 (en) | 2013-11-27 | 2016-12-13 | Sandisk Technologies Llc | DIMM device controller supervisor |
US9218891B2 (en) * | 2013-11-27 | 2015-12-22 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9582058B2 (en) | 2013-11-29 | 2017-02-28 | Sandisk Technologies Llc | Power inrush management of storage devices |
US9235245B2 (en) | 2013-12-04 | 2016-01-12 | Sandisk Enterprise Ip Llc | Startup performance and power isolation |
US9129665B2 (en) | 2013-12-17 | 2015-09-08 | Sandisk Enterprise Ip Llc | Dynamic brownout adjustment in a storage device |
US9998359B2 (en) | 2013-12-18 | 2018-06-12 | Mellanox Technologies, Ltd. | Simultaneous operation of remote management and link aggregation |
WO2015089843A1 (zh) * | 2013-12-20 | 2015-06-25 | 华为技术有限公司 | 一种传输数据的方法和设备 |
US9678678B2 (en) * | 2013-12-20 | 2017-06-13 | Lyve Minds, Inc. | Storage network data retrieval |
US9632880B2 (en) * | 2013-12-26 | 2017-04-25 | Silicon Motion, Inc. | Data storage device and flash memory control method |
TWI524183B (zh) * | 2014-01-09 | 2016-03-01 | 群聯電子股份有限公司 | 資料寫入方法、記憶體控制電路單元與記憶體儲存裝置 |
US9454434B2 (en) | 2014-01-17 | 2016-09-27 | Netapp, Inc. | File system driven raid rebuild technique |
US20150205534A1 (en) * | 2014-01-17 | 2015-07-23 | Kabushiki Kaisha Toshiba | Controller, solid-state drive and control method |
US9536612B1 (en) | 2014-01-23 | 2017-01-03 | Avago Technologies General Ip (Singapore) Pte. Ltd | Digital signaling processing for three dimensional flash memory arrays |
US10148746B2 (en) | 2014-01-28 | 2018-12-04 | Mellanox Technologies, Ltd. | Multi-host network interface controller with host management |
US9946616B2 (en) * | 2014-01-29 | 2018-04-17 | Hitachi, Ltd. | Storage apparatus |
US10120792B1 (en) | 2014-01-29 | 2018-11-06 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Programming an embedded flash storage device |
US9798620B2 (en) | 2014-02-06 | 2017-10-24 | Sandisk Technologies Llc | Systems and methods for non-blocking solid-state memory |
US10521387B2 (en) | 2014-02-07 | 2019-12-31 | Toshiba Memory Corporation | NAND switch |
US9286208B2 (en) * | 2014-02-07 | 2016-03-15 | Kabushiki Kaisha Toshiba | Controller controlling an interleave operation, solid-state drive including the controller, and control method controlling an interleave operation |
US9933980B2 (en) | 2014-02-24 | 2018-04-03 | Toshiba Memory Corporation | NAND raid controller for connection between an SSD controller and multiple non-volatile storage units |
KR102188062B1 (ko) * | 2014-02-28 | 2020-12-07 | 삼성전자 주식회사 | 데이터 저장 장치의 동작 방법과 상기 데이터 저장 장치를 포함하는 시스템의 동작 방법 |
US9666244B2 (en) * | 2014-03-01 | 2017-05-30 | Fusion-Io, Inc. | Dividing a storage procedure |
US9703636B2 (en) | 2014-03-01 | 2017-07-11 | Sandisk Technologies Llc | Firmware reversion trigger and control |
US10031933B2 (en) | 2014-03-02 | 2018-07-24 | Netapp, Inc. | Peer to peer ownership negotiation |
US9958178B2 (en) * | 2014-03-06 | 2018-05-01 | Dell Products, Lp | System and method for providing a server rack management controller |
US20150254082A1 (en) * | 2014-03-10 | 2015-09-10 | Plx Technology, Inc. | Remote booting over pci express using synthetic remote boot capability |
US9639285B2 (en) * | 2014-03-13 | 2017-05-02 | Aupera Technologies, Inc. | Distributed raid in a flash based memory system |
US9727503B2 (en) | 2014-03-17 | 2017-08-08 | Mellanox Technologies, Ltd. | Storage system and server |
US10296371B2 (en) | 2014-03-17 | 2019-05-21 | International Business Machines Corporation | Passive two-phase commit system for high-performance distributed transaction execution |
US9696942B2 (en) | 2014-03-17 | 2017-07-04 | Mellanox Technologies, Ltd. | Accessing remote storage devices using a local bus protocol |
US9390814B2 (en) | 2014-03-19 | 2016-07-12 | Sandisk Technologies Llc | Fault detection and prediction for data storage elements |
US9454448B2 (en) | 2014-03-19 | 2016-09-27 | Sandisk Technologies Llc | Fault testing in storage devices |
US9448876B2 (en) | 2014-03-19 | 2016-09-20 | Sandisk Technologies Llc | Fault detection and prediction in storage devices |
US9626400B2 (en) | 2014-03-31 | 2017-04-18 | Sandisk Technologies Llc | Compaction of information in tiered data structure |
US9626399B2 (en) | 2014-03-31 | 2017-04-18 | Sandisk Technologies Llc | Conditional updates for reducing frequency of data modification operations |
US9390021B2 (en) | 2014-03-31 | 2016-07-12 | Sandisk Technologies Llc | Efficient cache utilization in a tiered data structure |
US9697267B2 (en) | 2014-04-03 | 2017-07-04 | Sandisk Technologies Llc | Methods and systems for performing efficient snapshots in tiered data structures |
US9781027B1 (en) * | 2014-04-06 | 2017-10-03 | Parallel Machines Ltd. | Systems and methods to communicate with external destinations via a memory network |
US10025736B1 (en) | 2014-04-17 | 2018-07-17 | Bitmicro Networks, Inc. | Exchange message protocol message transmission between two devices |
US9952991B1 (en) | 2014-04-17 | 2018-04-24 | Bitmicro Networks, Inc. | Systematic method on queuing of descriptors for multiple flash intelligent DMA engine operation |
US10055150B1 (en) | 2014-04-17 | 2018-08-21 | Bitmicro Networks, Inc. | Writing volatile scattered memory metadata to flash device |
US10078604B1 (en) | 2014-04-17 | 2018-09-18 | Bitmicro Networks, Inc. | Interrupt coalescing |
US10042792B1 (en) | 2014-04-17 | 2018-08-07 | Bitmicro Networks, Inc. | Method for transferring and receiving frames across PCI express bus for SSD device |
US9911477B1 (en) * | 2014-04-18 | 2018-03-06 | Altera Corporation | Memory controller architecture with improved memory scheduling efficiency |
KR102318478B1 (ko) | 2014-04-21 | 2021-10-27 | 삼성전자주식회사 | 스토리지 컨트롤러, 스토리지 시스템 및 상기 스토리지 컨트롤러의 동작 방법 |
US9354872B2 (en) * | 2014-04-24 | 2016-05-31 | Xitore, Inc. | Apparatus, system, and method for non-volatile data storage and retrieval |
US10048962B2 (en) | 2014-04-24 | 2018-08-14 | Xitore, Inc. | Apparatus, system, and method for non-volatile data storage and retrieval |
JP6213366B2 (ja) * | 2014-04-25 | 2017-10-18 | 富士通株式会社 | 演算処理装置とその制御方法 |
JP5936152B2 (ja) * | 2014-05-17 | 2016-06-15 | インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation | メモリアクセストレース方法 |
US9280293B2 (en) * | 2014-05-23 | 2016-03-08 | Lenovo Enterprise Solutions (Singapore) Pte. Ltd. | RAID 1 mirror meshed into a co-existing RAID 5 parity stream |
US9891993B2 (en) | 2014-05-23 | 2018-02-13 | International Business Machines Corporation | Managing raid parity stripe contention |
CN104020962B (zh) * | 2014-05-27 | 2018-03-13 | 华为技术有限公司 | 一种raid 1数据写入的方法、cpu系统及存储设备 |
US9542262B1 (en) | 2014-05-29 | 2017-01-10 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Error correction |
US10656840B2 (en) | 2014-05-30 | 2020-05-19 | Sandisk Technologies Llc | Real-time I/O pattern recognition to enhance performance and endurance of a storage device |
US10162748B2 (en) | 2014-05-30 | 2018-12-25 | Sandisk Technologies Llc | Prioritizing garbage collection and block allocation based on I/O history for logical address regions |
US10656842B2 (en) | 2014-05-30 | 2020-05-19 | Sandisk Technologies Llc | Using history of I/O sizes and I/O sequences to trigger coalesced writes in a non-volatile storage device |
US10146448B2 (en) | 2014-05-30 | 2018-12-04 | Sandisk Technologies Llc | Using history of I/O sequences to trigger cached read ahead in a non-volatile storage device |
US10372613B2 (en) | 2014-05-30 | 2019-08-06 | Sandisk Technologies Llc | Using sub-region I/O history to cache repeatedly accessed sub-regions in a non-volatile storage device |
US9703491B2 (en) | 2014-05-30 | 2017-07-11 | Sandisk Technologies Llc | Using history of unaligned writes to cache data and avoid read-modify-writes in a non-volatile storage device |
US9093160B1 (en) | 2014-05-30 | 2015-07-28 | Sandisk Technologies Inc. | Methods and systems for staggered memory operations |
US10114557B2 (en) | 2014-05-30 | 2018-10-30 | Sandisk Technologies Llc | Identification of hot regions to enhance performance and endurance of a non-volatile storage device |
US9070481B1 (en) | 2014-05-30 | 2015-06-30 | Sandisk Technologies Inc. | Internal current measurement for age measurements |
GB2526873A (en) * | 2014-06-06 | 2015-12-09 | Roke Manor Research | System and method for mitigating remanence in volatile memory |
CN106462525A (zh) * | 2014-06-10 | 2017-02-22 | 慧与发展有限责任合伙企业 | 使用远程直接内存访问(rdma)复制数据 |
US9594571B2 (en) | 2014-06-10 | 2017-03-14 | Cisco Technology, Inc. | Mechanism for obviating the need for host-side basic input/output system (BIOS) or boot serial peripheral interface (SPI) device(s) |
US9652381B2 (en) | 2014-06-19 | 2017-05-16 | Sandisk Technologies Llc | Sub-block garbage collection |
US9892033B1 (en) | 2014-06-24 | 2018-02-13 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Management of memory units |
US9613218B2 (en) * | 2014-06-30 | 2017-04-04 | Nicira, Inc. | Encryption system in a virtualized environment |
US9972393B1 (en) | 2014-07-03 | 2018-05-15 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Accelerating programming of a flash memory module |
US9584159B1 (en) | 2014-07-03 | 2017-02-28 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Interleaved encoding |
US9417804B2 (en) | 2014-07-07 | 2016-08-16 | Microsemi Storage Solutions (Us), Inc. | System and method for memory block pool wear leveling |
US9449702B1 (en) | 2014-07-08 | 2016-09-20 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Power management |
US9588843B2 (en) | 2014-07-14 | 2017-03-07 | International Business Machines Corporation | System and method for transferring traditional RAID to distributed array |
US9514211B2 (en) | 2014-07-20 | 2016-12-06 | Microsoft Technology Licensing, Llc | High throughput data modifications using blind update operations |
TWI505078B (zh) | 2014-07-28 | 2015-10-21 | Ibm | 系統管理控制器、電腦系統、以及系統管理方法 |
US9442798B2 (en) * | 2014-07-31 | 2016-09-13 | Winbond Electronics Corporation | NAND flash memory having an enhanced buffer read capability and method of operation thereof |
US10402113B2 (en) | 2014-07-31 | 2019-09-03 | Hewlett Packard Enterprise Development Lp | Live migration of data |
US9367392B2 (en) | 2014-08-01 | 2016-06-14 | Winbond Electronics Corporation | NAND flash memory having internal ECC processing and method of operation thereof |
WO2016032548A1 (en) * | 2014-08-25 | 2016-03-03 | Hewlett Packard Enterprise Development Lp | Providing transactional support to a data storage system |
FR3025333B1 (fr) * | 2014-08-26 | 2017-12-08 | Bull Sas | Serveur comprenant une pluralite de modules |
US10540109B2 (en) | 2014-09-02 | 2020-01-21 | Hewlett Packard Enterprise Development Lp | Serializing access to fault tolerant memory |
US9443601B2 (en) | 2014-09-08 | 2016-09-13 | Sandisk Technologies Llc | Holdup capacitor energy harvesting |
US10552085B1 (en) | 2014-09-09 | 2020-02-04 | Radian Memory Systems, Inc. | Techniques for directed data migration |
US9542118B1 (en) | 2014-09-09 | 2017-01-10 | Radian Memory Systems, Inc. | Expositive flash memory control |
KR102330391B1 (ko) * | 2014-09-11 | 2021-11-24 | 삼성전자주식회사 | 저장 장치 및 그것을 포함하는 데이터 저장 시스템의 가비지 컬렉션 방법 |
US20160077959A1 (en) * | 2014-09-12 | 2016-03-17 | Qualcomm Incorporated | System and Method for Sharing a Solid-State Non-Volatile Memory Resource |
US10275171B2 (en) * | 2014-09-16 | 2019-04-30 | Kove Ip, Llc | Paging of external memory |
US10146468B2 (en) * | 2014-09-20 | 2018-12-04 | Netronome Systems, Inc. | Addressless merge command with data item identifier |
US9720789B2 (en) * | 2014-10-15 | 2017-08-01 | Netapp, Inc. | Multicast transport configuration |
US10666682B2 (en) * | 2014-10-15 | 2020-05-26 | Marvell Asia Pte, Ltd. | Systems and methods for allowing flexible chip configuration by external entity while maintaining secured boot environment |
US10635504B2 (en) | 2014-10-16 | 2020-04-28 | Microsoft Technology Licensing, Llc | API versioning independent of product releases |
US9984768B2 (en) | 2014-10-20 | 2018-05-29 | Sandisk Technologies Llc | Distributing storage of ECC code words |
US9959059B2 (en) * | 2014-10-20 | 2018-05-01 | Sandisk Technologies Llc | Storage error management |
US10594442B2 (en) | 2014-10-24 | 2020-03-17 | Hewlett Packard Enterprise Development Lp | End-to-end negative acknowledgment |
US9712382B2 (en) | 2014-10-27 | 2017-07-18 | Quanta Computer Inc. | Retrieving console messages after device failure |
CN104391805B (zh) * | 2014-10-27 | 2017-12-05 | 浪潮集团有限公司 | 一种用于加密固态存储的数据结构 |
US9519442B2 (en) * | 2014-10-27 | 2016-12-13 | Aeroflex Colorado Springs Inc. | Method for concurrent system management and error detection and correction requests in integrated circuits through location aware avoidance logic |
CN104281499B (zh) * | 2014-10-28 | 2017-10-13 | 苏州工业职业技术学院 | 基于奇偶校验的raid条带镜像数据分布方法 |
WO2016068903A1 (en) | 2014-10-29 | 2016-05-06 | Hewlett Packard Enterprise Development Lp | Trans-fabric instruction set for a communication fabric |
EP3213218A4 (en) * | 2014-10-29 | 2018-05-30 | Hewlett-Packard Development Company, L.P. | Communicating over portions of a communication medium |
US9712619B2 (en) | 2014-11-04 | 2017-07-18 | Pavilion Data Systems, Inc. | Virtual non-volatile memory express drive |
US9565269B2 (en) | 2014-11-04 | 2017-02-07 | Pavilion Data Systems, Inc. | Non-volatile memory express over ethernet |
US9524211B1 (en) | 2014-11-18 | 2016-12-20 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Codeword management |
US20160162186A1 (en) * | 2014-12-09 | 2016-06-09 | San Disk Technologies Inc. | Re-Ordering NAND Flash Commands for Optimal Throughput and Providing a Specified Quality-of-Service |
US9582463B2 (en) | 2014-12-09 | 2017-02-28 | Intel Corporation | Heterogeneous input/output (I/O) using remote direct memory access (RDMA) and active message |
US9519429B2 (en) * | 2014-12-09 | 2016-12-13 | Intel Corporation | Techniques to manage multiple sequential write streams to a solid state drive |
KR102301937B1 (ko) | 2014-12-22 | 2021-09-15 | 삼성전자주식회사 | 가상 머신 환경에서의 입출력 방법 |
US9846576B2 (en) * | 2014-12-27 | 2017-12-19 | Intel Corporation | Technologies for reprogramming network interface cards over a network |
US9747319B2 (en) * | 2014-12-31 | 2017-08-29 | Nexenta Systems, Inc. | Read-modify-write processing of chunks at the storage server level in a distributed object storage system |
US10423670B1 (en) * | 2015-01-05 | 2019-09-24 | Amazon Technologies, Inc. | Object coding in a host-side processing device |
US9853873B2 (en) | 2015-01-10 | 2017-12-26 | Cisco Technology, Inc. | Diagnosis and throughput measurement of fibre channel ports in a storage area network environment |
US9542320B2 (en) * | 2015-01-12 | 2017-01-10 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Multi-node cache coherency with input output virtualization |
US9933950B2 (en) | 2015-01-16 | 2018-04-03 | Sandisk Technologies Llc | Storage operation interrupt |
WO2016118607A1 (en) | 2015-01-20 | 2016-07-28 | Ultrata Llc | Distributed index for fault tolerant object memory fabric |
EP4012548B1 (en) | 2015-01-20 | 2024-05-01 | Ultrata LLC | Object memory data flow instruction execution |
US9529580B2 (en) * | 2015-01-21 | 2016-12-27 | Ford Global Technologies, Llc | Vehicle control update methods and systems |
US10229085B2 (en) | 2015-01-23 | 2019-03-12 | Hewlett Packard Enterprise Development Lp | Fibre channel hardware card port assignment and management method for port names |
WO2016122642A1 (en) | 2015-01-30 | 2016-08-04 | Hewlett Packard Enterprise Development Lp | Determine failed components in fault-tolerant memory |
WO2016122610A1 (en) | 2015-01-30 | 2016-08-04 | Hewlett Packard Enterprise Development Lp | Preventing data corruption and single point of failure in a fault-tolerant memory |
US10409681B2 (en) | 2015-01-30 | 2019-09-10 | Hewlett Packard Enterprise Development Lp | Non-idempotent primitives in fault-tolerant memory |
US10305515B1 (en) | 2015-02-02 | 2019-05-28 | Avago Technologies International Sales Pte. Limited | System and method for encoding using multiple linear feedback shift registers |
US9729440B2 (en) | 2015-02-22 | 2017-08-08 | Mellanox Technologies, Ltd. | Differentiating among multiple management control instances using IP addresses |
US9985820B2 (en) | 2015-02-22 | 2018-05-29 | Mellanox Technologies, Ltd. | Differentiating among multiple management control instances using addresses |
WO2016135872A1 (ja) * | 2015-02-25 | 2016-09-01 | 株式会社日立製作所 | ストレージ装置及び記憶デバイス |
EP3262500A4 (en) | 2015-02-26 | 2018-10-03 | Agency For Science, Technology And Research | Data stripping, allocation and reconstruction |
US10440115B2 (en) * | 2015-02-27 | 2019-10-08 | Pure Storage, Inc. | Write intent messaging in a dispersed storage network |
US11188665B2 (en) | 2015-02-27 | 2021-11-30 | Pure Storage, Inc. | Using internal sensors to detect adverse interference and take defensive actions |
US9728245B2 (en) * | 2015-02-28 | 2017-08-08 | Intel Corporation | Precharging and refreshing banks in memory device with bank group architecture |
US9946607B2 (en) | 2015-03-04 | 2018-04-17 | Sandisk Technologies Llc | Systems and methods for storage error management |
US20160266813A1 (en) * | 2015-03-09 | 2016-09-15 | Unisys Corporation | Storage subsystem technologies |
US20160267050A1 (en) * | 2015-03-09 | 2016-09-15 | Unisys Corporation | Storage subsystem technologies |
KR102398213B1 (ko) | 2015-03-09 | 2022-05-17 | 삼성전자주식회사 | 저장 장치, 그것을 포함하는 호스트 시스템, 및 그것의 맵 테이블 업데이트 방법 |
US20160266802A1 (en) * | 2015-03-10 | 2016-09-15 | Kabushiki Kaisha Toshiba | Storage device, memory system and method of managing data |
US9600181B2 (en) * | 2015-03-11 | 2017-03-21 | Microsoft Technology Licensing, Llc | Live configurable storage |
US9940234B2 (en) * | 2015-03-26 | 2018-04-10 | Pure Storage, Inc. | Aggressive data deduplication using lazy garbage collection |
US9900250B2 (en) | 2015-03-26 | 2018-02-20 | Cisco Technology, Inc. | Scalable handling of BGP route information in VXLAN with EVPN control plane |
US9830093B2 (en) * | 2015-03-27 | 2017-11-28 | Intel Corporation | Method and apparatus for improving immunity to defects in a non-volatile memory |
WO2016159996A1 (en) | 2015-03-31 | 2016-10-06 | Hewlett Packard Enterprise Development Lp | Preventing data corruption and single point of failure in fault-tolerant memory fabrics |
US9800547B2 (en) | 2015-04-16 | 2017-10-24 | International Business Machines Corporation | Preventing network attacks on baseboard management controllers |
KR102309798B1 (ko) * | 2015-04-16 | 2021-10-06 | 삼성전자주식회사 | Sr-iov 기반 비휘발성 메모리 컨트롤러 및 그 비휘발성 메모리 컨트롤러에 의해 큐에 리소스를 동적 할당하는 방법 |
US9979799B2 (en) * | 2015-04-27 | 2018-05-22 | Lenovo Enterprise Solutions (Singapore) Pte. Ltd. | Impersonating a specific physical hardware configuration on a standard server |
US10255206B2 (en) | 2015-05-02 | 2019-04-09 | Hewlett Packard Enterprise Development Lp | Storage memory direct access |
US10121013B2 (en) * | 2015-05-07 | 2018-11-06 | Samsung Electronics Co., Ltd. | XOR-based scrambler/descrambler for SSD communication protocols |
US9519433B2 (en) | 2015-05-13 | 2016-12-13 | VSector Security Technologies, LLC | Secure virtual sector erasure method and system |
US10222986B2 (en) | 2015-05-15 | 2019-03-05 | Cisco Technology, Inc. | Tenant-level sharding of disks with tenant-specific storage modules to enable policies per tenant in a distributed storage system |
US10332613B1 (en) | 2015-05-18 | 2019-06-25 | Microsemi Solutions (Us), Inc. | Nonvolatile memory system with retention monitor |
US10244250B2 (en) | 2015-05-29 | 2019-03-26 | Samsung Electronics Co., Ltd. | Variable-rate texture compression using fixed-rate codes |
US9760314B2 (en) | 2015-05-29 | 2017-09-12 | Netapp, Inc. | Methods for sharing NVM SSD across a cluster group and devices thereof |
US20160357456A1 (en) * | 2015-06-03 | 2016-12-08 | Kabushiki Kaisha Toshiba | Memory device that divides write data into a plurality of data portions for data writing |
US9886210B2 (en) | 2015-06-09 | 2018-02-06 | Ultrata, Llc | Infinite memory fabric hardware implementation with router |
US10698628B2 (en) | 2015-06-09 | 2020-06-30 | Ultrata, Llc | Infinite memory fabric hardware implementation with memory |
US9971542B2 (en) | 2015-06-09 | 2018-05-15 | Ultrata, Llc | Infinite memory fabric streams and APIs |
US11588783B2 (en) | 2015-06-10 | 2023-02-21 | Cisco Technology, Inc. | Techniques for implementing IPV6-based distributed storage space |
US10628255B1 (en) | 2015-06-11 | 2020-04-21 | Avago Technologies International Sales Pte. Limited | Multi-dimensional decoding |
TWI553477B (zh) * | 2015-06-12 | 2016-10-11 | 群聯電子股份有限公司 | 記憶體管理方法、記憶體控制電路單元及記憶體儲存裝置 |
US10048898B2 (en) * | 2015-06-15 | 2018-08-14 | Sandisk Technologies Llc | Data retention in a memory block based on local heating |
US10248610B2 (en) * | 2015-06-23 | 2019-04-02 | Mellanox Technologies, Ltd. | Enforcing transaction order in peer-to-peer interactions |
WO2016209268A1 (en) * | 2015-06-26 | 2016-12-29 | Hewlett Packard Enterprise Development Lp | Self-tune controller |
US9857986B2 (en) | 2015-06-30 | 2018-01-02 | International Business Machines Corporation | Wear leveling of a memory array |
US9910791B1 (en) * | 2015-06-30 | 2018-03-06 | EMC IP Holding Company LLC | Managing system-wide encryption keys for data storage systems |
CN105159851A (zh) * | 2015-07-02 | 2015-12-16 | 浪潮(北京)电子信息产业有限公司 | 多控存储系统 |
US9851921B1 (en) | 2015-07-05 | 2017-12-26 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Flash memory chip processing |
KR102036514B1 (ko) * | 2015-07-13 | 2019-10-28 | 엘에스산전 주식회사 | 메모리 소자를 이용한 데이터 엑세스 장치 |
US10089196B2 (en) * | 2015-07-14 | 2018-10-02 | Shannon Systems Ltd. | Methods for reconfiguring a storage controller when control logic fails and apparatuses using the same |
US10303647B2 (en) | 2015-07-15 | 2019-05-28 | Mellanox Technologies, Ltd. | Access control in peer-to-peer transactions over a peripheral component bus |
US10778765B2 (en) | 2015-07-15 | 2020-09-15 | Cisco Technology, Inc. | Bid/ask protocol in scale-out NVMe storage |
US9799405B1 (en) | 2015-07-29 | 2017-10-24 | Ip Gem Group, Llc | Nonvolatile memory system with read circuit for performing reads using threshold voltage shift read instruction |
US10579519B2 (en) | 2015-07-30 | 2020-03-03 | Hewlett Packard Enterprise Development Lp | Interleaved access of memory |
US10257273B2 (en) | 2015-07-31 | 2019-04-09 | Netapp, Inc. | Systems, methods and devices for RDMA read/write operations |
US9952797B2 (en) | 2015-07-31 | 2018-04-24 | Netapp, Inc. | Systems, methods and devices for addressing data blocks in mass storage filing systems |
US10078614B2 (en) | 2015-08-10 | 2018-09-18 | Sandisk Technologies Llc | Systems and methods of data transfer |
KR102401600B1 (ko) * | 2015-08-31 | 2022-05-25 | 삼성전자주식회사 | 데이터 양에 기초하여 복수의 데이터 스트림을 관리하도록 구성되는 스토리지 장치 |
US9484954B1 (en) * | 2015-09-10 | 2016-11-01 | Intel Corporation | Methods and apparatus to parallelize data decompression |
US10736239B2 (en) | 2015-09-22 | 2020-08-04 | Z-Impact, Inc. | High performance computing rack and storage system with forced cooling |
US10078494B2 (en) * | 2015-09-25 | 2018-09-18 | Arizona Board Of Regents On Behalf Of Arizona State University | Secure true random number generation using 1.5-T transistor flash memory |
US10013323B1 (en) | 2015-09-29 | 2018-07-03 | EMC IP Holding Company LLC | Providing resiliency to a raid group of storage devices |
US10853266B2 (en) * | 2015-09-30 | 2020-12-01 | Pure Storage, Inc. | Hardware assisted data lookup methods |
US10459891B2 (en) * | 2015-09-30 | 2019-10-29 | Western Digital Technologies, Inc. | Replicating data across data storage devices of a logical volume |
WO2017058221A1 (en) * | 2015-09-30 | 2017-04-06 | Hewlett Packard Enterprise Development Lp | Cryptographic-based initialization of memory content |
US10320905B2 (en) | 2015-10-02 | 2019-06-11 | Oracle International Corporation | Highly available network filer super cluster |
US10360119B2 (en) * | 2015-10-06 | 2019-07-23 | Netapp, Inc. | Data recovery in a distributed storage system |
US20170102952A1 (en) * | 2015-10-07 | 2017-04-13 | Dell Products, L.P. | Accessing data stored in a remote target using a baseboard management controler (bmc) independently of the status of the remote target's operating system (os) |
US9678682B2 (en) | 2015-10-13 | 2017-06-13 | International Business Machines Corporation | Backup storage of vital debug information |
WO2017065209A1 (ja) * | 2015-10-16 | 2017-04-20 | 国立大学法人東北大学 | 情報処理システム、情報処理装置、情報処理方法、及び、プログラム |
US9886196B2 (en) | 2015-10-21 | 2018-02-06 | Western Digital Technologies, Inc. | Method and system for efficient common processing in memory device controllers |
US10108340B2 (en) | 2015-10-21 | 2018-10-23 | Western Digital Technologies, Inc. | Method and system for a common processing framework for memory device controllers |
US9934094B2 (en) * | 2015-10-30 | 2018-04-03 | Seagate Technology Llc | Process for verification of randomly generated I/O requests |
US10254998B2 (en) | 2015-11-03 | 2019-04-09 | Samsung Electronics Co., Ltd. | Coordinated garbage collection of flash devices in a distributed storage system |
US20170123700A1 (en) * | 2015-11-03 | 2017-05-04 | Samsung Electronics Co., Ltd. | Io redirection methods with cost estimation |
KR102314137B1 (ko) * | 2015-11-04 | 2021-10-18 | 삼성전자 주식회사 | 리커버리 동작을 선택적으로 수행하는 불휘발성 메모리 장치 및 그 동작방법 |
TWI559155B (zh) * | 2015-11-26 | 2016-11-21 | 英業達股份有限公司 | 輸入/輸出埠切換方法及其電子裝置及系統 |
US9811259B2 (en) * | 2015-11-27 | 2017-11-07 | Netapp, Inc. | Read I/O completions outside file operating system domain |
US10303372B2 (en) | 2015-12-01 | 2019-05-28 | Samsung Electronics Co., Ltd. | Nonvolatile memory device and operation method thereof |
EP3387547B1 (en) | 2015-12-08 | 2023-07-05 | Ultrata LLC | Memory fabric software implementation |
CN115061971A (zh) | 2015-12-08 | 2022-09-16 | 乌尔特拉塔有限责任公司 | 使用容错对象的存储器结构操作和一致性 |
US9892075B2 (en) | 2015-12-10 | 2018-02-13 | Cisco Technology, Inc. | Policy driven storage in a microserver computing environment |
US9886214B2 (en) | 2015-12-11 | 2018-02-06 | Ip Gem Group, Llc | Nonvolatile memory system with erase suspend circuit and method for erase suspend management |
US10437483B2 (en) * | 2015-12-17 | 2019-10-08 | Samsung Electronics Co., Ltd. | Computing system with communication mechanism and method of operation thereof |
US10339098B2 (en) * | 2015-12-22 | 2019-07-02 | Spectra Logic, Corp. | Container-level array storage |
US10063422B1 (en) * | 2015-12-29 | 2018-08-28 | Amazon Technologies, Inc. | Controlled bandwidth expansion in compressed disaggregated storage systems |
US9892794B2 (en) | 2016-01-04 | 2018-02-13 | Ip Gem Group, Llc | Method and apparatus with program suspend using test mode |
US10713211B2 (en) * | 2016-01-13 | 2020-07-14 | Red Hat, Inc. | Pre-registering memory regions for remote direct memory access in a distributed file system |
US10901937B2 (en) | 2016-01-13 | 2021-01-26 | Red Hat, Inc. | Exposing pre-registered memory regions for remote direct memory access in a distributed file system |
US9899092B2 (en) | 2016-01-27 | 2018-02-20 | Ip Gem Group, Llc | Nonvolatile memory system with program step manager and method for program step management |
US10157153B2 (en) * | 2016-02-03 | 2018-12-18 | Qualcomm Incorporated | Inline cryptographic engine (ICE) for peripheral component interconnect express (PCIe) systems |
CN113407244A (zh) * | 2016-03-01 | 2021-09-17 | 华为技术有限公司 | 一种级联板、ssd远程共享访问的系统和方法 |
US10776272B2 (en) | 2016-03-02 | 2020-09-15 | Mellanox Technologies, Ltd. | Control of persistent memory via a computer bus |
US9954558B1 (en) | 2016-03-03 | 2018-04-24 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Fast decoding of data stored in a flash memory |
US10409719B2 (en) | 2016-03-17 | 2019-09-10 | Samsung Electronics Co., Ltd. | User configurable passive background operation |
US10230810B1 (en) | 2016-03-18 | 2019-03-12 | Barefoot Networks, Inc. | Storing packet data in mirror buffer |
US9583182B1 (en) * | 2016-03-22 | 2017-02-28 | Intel Corporation | Multi-level memory management |
US10303646B2 (en) | 2016-03-25 | 2019-05-28 | Microsoft Technology Licensing, Llc | Memory sharing for working data using RDMA |
US9852025B2 (en) * | 2016-03-29 | 2017-12-26 | Alibaba Group Holding Limited | Protecting data stored on a solid state drive |
US10404676B2 (en) * | 2016-03-29 | 2019-09-03 | Intel Corporation | Method and apparatus to coordinate and authenticate requests for data |
US20170300249A1 (en) * | 2016-04-15 | 2017-10-19 | Western Digital Technologies, Inc. | Validity tracking for garbage collection |
US10140172B2 (en) | 2016-05-18 | 2018-11-27 | Cisco Technology, Inc. | Network-aware storage repairs |
CN107436725B (zh) * | 2016-05-25 | 2019-12-20 | 杭州海康威视数字技术股份有限公司 | 一种数据写、读方法、装置及分布式对象存储集群 |
KR102643467B1 (ko) | 2016-05-31 | 2024-03-06 | 에스케이하이닉스 주식회사 | 메모리 시스템 및 메모리 시스템의 동작 방법 |
US20170351639A1 (en) | 2016-06-06 | 2017-12-07 | Cisco Technology, Inc. | Remote memory access using memory mapped addressing among multiple compute nodes |
US10664169B2 (en) | 2016-06-24 | 2020-05-26 | Cisco Technology, Inc. | Performance of object storage system by reconfiguring storage devices based on latency that includes identifying a number of fragments that has a particular storage device as its primary storage device and another number of fragments that has said particular storage device as its replica storage device |
CN106201338B (zh) | 2016-06-28 | 2019-10-22 | 华为技术有限公司 | 数据存储方法及装置 |
US9690886B1 (en) * | 2016-06-30 | 2017-06-27 | Zerto Ltd. | System and method for a simulation of a block storage system on an object storage system |
KR102635134B1 (ko) * | 2016-06-30 | 2024-02-08 | 에스케이하이닉스 주식회사 | 메모리 컨트롤러, 비동기식 메모리 버퍼칩 및 이를 포함하는 메모리 시스템 |
CN106201352B (zh) * | 2016-07-07 | 2019-11-29 | 广东高云半导体科技股份有限公司 | 非易失性fpga片上数据流文件的保密系统及解密方法 |
US10120702B2 (en) * | 2016-07-12 | 2018-11-06 | American Megatrends, Inc. | Platform simulation for management controller development projects |
TWI620074B (zh) * | 2016-07-12 | 2018-04-01 | 緯創資通股份有限公司 | 伺服器系統及儲存單元的控制方法 |
US10534716B2 (en) * | 2016-07-13 | 2020-01-14 | Seagate Technology Llc | Limiting access operations in a data storage device |
US10037150B2 (en) * | 2016-07-15 | 2018-07-31 | Advanced Micro Devices, Inc. | Memory controller with virtual controller mode |
US10739996B1 (en) * | 2016-07-18 | 2020-08-11 | Seagate Technology Llc | Enhanced garbage collection |
US10034407B2 (en) * | 2016-07-22 | 2018-07-24 | Intel Corporation | Storage sled for a data center |
US10291263B2 (en) | 2016-07-28 | 2019-05-14 | Ip Gem Group, Llc | Auto-learning log likelihood ratio |
US10283215B2 (en) | 2016-07-28 | 2019-05-07 | Ip Gem Group, Llc | Nonvolatile memory system with background reference positioning and local reference positioning |
US10236915B2 (en) | 2016-07-29 | 2019-03-19 | Microsemi Solutions (U.S.), Inc. | Variable T BCH encoding |
US20180039427A1 (en) * | 2016-08-08 | 2018-02-08 | Nuvoton Technology Corporation | Reducing programming time of memory devices using data encoding |
US10387303B2 (en) | 2016-08-16 | 2019-08-20 | Western Digital Technologies, Inc. | Non-volatile storage system with compute engine to accelerate big data applications |
US10379778B2 (en) * | 2016-08-18 | 2019-08-13 | International Business Machines Corporation | Using a master encryption key to sanitize a dispersed storage network memory |
US10798073B2 (en) | 2016-08-26 | 2020-10-06 | Nicira, Inc. | Secure key management protocol for distributed network encryption |
US10152393B2 (en) | 2016-08-28 | 2018-12-11 | Microsoft Technology Licensing, Llc | Out-of-band data recovery in computing systems |
US11563695B2 (en) | 2016-08-29 | 2023-01-24 | Cisco Technology, Inc. | Queue protection using a shared global memory reserve |
JP6351901B1 (ja) * | 2016-09-05 | 2018-07-04 | 三菱電機株式会社 | 組込みシステムおよび組込みシステム制御方法 |
US10236917B2 (en) * | 2016-09-15 | 2019-03-19 | Qualcomm Incorporated | Providing memory bandwidth compression in chipkill-correct memory architectures |
US10193634B2 (en) | 2016-09-19 | 2019-01-29 | Hewlett Packard Enterprise Development Lp | Optical driver circuits |
US10162752B2 (en) | 2016-09-22 | 2018-12-25 | Qualcomm Incorporated | Data storage at contiguous memory addresses |
US9824034B1 (en) * | 2016-09-27 | 2017-11-21 | International Business Machines Corporation | Parallel ordering queue using encoded command types |
US10031050B2 (en) | 2016-10-13 | 2018-07-24 | International Business Machines Corporation | Universal manufacturing test platform |
KR20180045220A (ko) * | 2016-10-25 | 2018-05-04 | 삼성전자주식회사 | 읽기 요청 횟수를 줄이는 데이터 복원 동작을 수행하는 데이터 스토리지 시스템 |
US10459644B2 (en) | 2016-10-28 | 2019-10-29 | Western Digital Techologies, Inc. | Non-volatile storage system with integrated compute engine and optimized use of local fast memory |
US10545770B2 (en) | 2016-11-14 | 2020-01-28 | Intel Corporation | Configurable client hardware |
US10685710B2 (en) * | 2016-11-17 | 2020-06-16 | Toshiba Memory Corporation | Memory controller |
US10198378B2 (en) * | 2016-11-18 | 2019-02-05 | Microsoft Technology Licensing, Llc | Faster data transfer with simultaneous alternative remote direct memory access communications |
US10198397B2 (en) | 2016-11-18 | 2019-02-05 | Microsoft Technology Licensing, Llc | Flow control in remote direct memory access data communications with mirroring of ring buffers |
RU168565U1 (ru) * | 2016-11-21 | 2017-02-08 | Федеральное государственное унитарное предприятие "Научно-исследовательский институт "Квант" | Реконфигурируемый вычислительный модуль |
US20180150256A1 (en) * | 2016-11-29 | 2018-05-31 | Intel Corporation | Technologies for data deduplication in disaggregated architectures |
CN106775874B (zh) * | 2016-12-20 | 2020-08-25 | 珠海全志科技股份有限公司 | 终端设备的系统升级方法 |
US11461273B1 (en) * | 2016-12-20 | 2022-10-04 | Pure Storage, Inc. | Modifying storage distribution in a storage system that includes one or more storage devices |
US10397144B2 (en) * | 2016-12-22 | 2019-08-27 | Intel Corporation | Receive buffer architecture method and apparatus |
US11113133B2 (en) | 2016-12-27 | 2021-09-07 | Intel Corporation | Cross-component health monitoring and improved repair for self-healing platforms |
US10275179B2 (en) | 2017-01-16 | 2019-04-30 | Oracle International Corporation | Distributed virtual block storage network |
US10545914B2 (en) | 2017-01-17 | 2020-01-28 | Cisco Technology, Inc. | Distributed object storage |
US10452288B2 (en) | 2017-01-19 | 2019-10-22 | International Business Machines Corporation | Identifying processor attributes based on detecting a guarded storage event |
US10496292B2 (en) | 2017-01-19 | 2019-12-03 | International Business Machines Corporation | Saving/restoring guarded storage controls in a virtualized environment |
US10579377B2 (en) | 2017-01-19 | 2020-03-03 | International Business Machines Corporation | Guarded storage event handling during transactional execution |
US10496311B2 (en) | 2017-01-19 | 2019-12-03 | International Business Machines Corporation | Run-time instrumentation of guarded storage event processing |
US10732858B2 (en) | 2017-01-19 | 2020-08-04 | International Business Machines Corporation | Loading and storing controls regulating the operation of a guarded storage facility |
US10725685B2 (en) | 2017-01-19 | 2020-07-28 | International Business Machines Corporation | Load logical and shift guarded instruction |
US10979223B2 (en) * | 2017-01-31 | 2021-04-13 | Pure Storage, Inc. | Separate encryption for a solid-state drive |
US10243823B1 (en) | 2017-02-24 | 2019-03-26 | Cisco Technology, Inc. | Techniques for using frame deep loopback capabilities for extended link diagnostics in fibre channel storage area networks |
US10713203B2 (en) | 2017-02-28 | 2020-07-14 | Cisco Technology, Inc. | Dynamic partition of PCIe disk arrays based on software configuration / policy distribution |
US10254991B2 (en) | 2017-03-06 | 2019-04-09 | Cisco Technology, Inc. | Storage area network based extended I/O metrics computation for deep insight into application performance |
US11003381B2 (en) * | 2017-03-07 | 2021-05-11 | Samsung Electronics Co., Ltd. | Non-volatile memory storage device capable of self-reporting performance capabilities |
CN106843989A (zh) * | 2017-03-10 | 2017-06-13 | 郑州云海信息技术有限公司 | 一种实现程序更新的系统及方法 |
US10079612B1 (en) | 2017-03-15 | 2018-09-18 | Alibaba Group Holding Limited | Distributed erasure coding pool deployed in hyperscale infrastructure |
US10664406B2 (en) | 2017-03-21 | 2020-05-26 | International Business Machines Corporation | Coordinated utilization of parallel paths to improve efficiency |
CN114089915B (zh) * | 2017-03-27 | 2022-12-20 | 珠海极海半导体有限公司 | 基于flash存储器的文件追加写操作方法及装置 |
CN108665939B (zh) * | 2017-03-31 | 2021-01-05 | 厦门旌存半导体技术有限公司 | 为存储器提供ecc的方法与装置 |
US10552050B1 (en) | 2017-04-07 | 2020-02-04 | Bitmicro Llc | Multi-dimensional computer storage system |
US10565123B2 (en) | 2017-04-10 | 2020-02-18 | Western Digital Technologies, Inc. | Hybrid logical to physical address translation for non-volatile storage devices with integrated compute module |
US10795836B2 (en) * | 2017-04-17 | 2020-10-06 | Microsoft Technology Licensing, Llc | Data processing performance enhancement for neural networks using a virtualized data iterator |
US10705911B2 (en) * | 2017-04-24 | 2020-07-07 | Hewlett Packard Enterprise Development Lp | Storing data in a distributed storage system |
US10524022B2 (en) | 2017-05-02 | 2019-12-31 | Seagate Technology Llc | Data storage system with adaptive data path routing |
US11563789B2 (en) * | 2017-05-09 | 2023-01-24 | EMC IP Holding Company LLC | Executing streaming data writes without duplication or loss |
US20180329634A1 (en) * | 2017-05-10 | 2018-11-15 | Strato Scale Ltd. | Object overlay for storage-area network (san) appliances |
US10459807B2 (en) | 2017-05-23 | 2019-10-29 | International Business Machines Corporation | Determining modified portions of a RAID storage array |
US10860508B2 (en) * | 2017-05-25 | 2020-12-08 | Western Digital Technologies, Inc. | Offloaded disaggregated storage architecture |
US10635529B2 (en) * | 2017-05-25 | 2020-04-28 | Western Digital Technologies, Inc. | Parity offload for multiple data storage devices |
US10725859B2 (en) | 2017-05-25 | 2020-07-28 | Western Digital Technologies, Inc. | Parity generation offload using peer-to-peer data transfers in data storage system |
JP7087279B2 (ja) * | 2017-05-26 | 2022-06-21 | 富士通株式会社 | 情報処理装置及びプログラム |
CN107145428A (zh) * | 2017-05-26 | 2017-09-08 | 郑州云海信息技术有限公司 | 一种服务器及服务器监控方法 |
US10915405B2 (en) * | 2017-05-26 | 2021-02-09 | Netapp, Inc. | Methods for handling storage element failures to reduce storage device failure rates and devices thereof |
KR102234725B1 (ko) * | 2017-05-30 | 2021-04-02 | 에스케이하이닉스 주식회사 | 컨트롤러 및 메모리 시스템 및 메모리 시스템의 동작 방법 |
US10616076B2 (en) * | 2017-05-30 | 2020-04-07 | International Business Machines Corporation | Network asset management |
US10223318B2 (en) * | 2017-05-31 | 2019-03-05 | Hewlett Packard Enterprise Development Lp | Hot plugging peripheral connected interface express (PCIe) cards |
US11416447B2 (en) | 2017-06-08 | 2022-08-16 | Hitachi Vantara Llc | Deduplicating distributed erasure coded objects |
US10152422B1 (en) | 2017-06-13 | 2018-12-11 | Seagate Technology Llc | Page-based method for optimizing cache metadata updates |
US11003532B2 (en) * | 2017-06-16 | 2021-05-11 | Microsoft Technology Licensing, Llc | Distributed data object management system operations |
KR102077283B1 (ko) * | 2017-06-27 | 2020-02-14 | 주식회사 케이티 | 원격 백업 디바이스 |
US10389342B2 (en) | 2017-06-28 | 2019-08-20 | Hewlett Packard Enterprise Development Lp | Comparator |
US10216685B1 (en) * | 2017-07-19 | 2019-02-26 | Agiga Tech Inc. | Memory modules with nonvolatile storage and rapid, sustained transfer rates |
US10303534B2 (en) | 2017-07-20 | 2019-05-28 | Cisco Technology, Inc. | System and method for self-healing of application centric infrastructure fabric memory |
US10785301B2 (en) * | 2017-08-03 | 2020-09-22 | Toshiba Memory Corporation | NVM express over fabrics |
US20190042781A1 (en) * | 2017-08-04 | 2019-02-07 | Bitdefender IPR Management Ltd. | Secure Storage Device |
CN107506138B (zh) * | 2017-08-11 | 2020-12-18 | 东莞记忆存储科技有限公司 | 一种固态硬盘提升寿命的方法 |
US10831935B2 (en) * | 2017-08-31 | 2020-11-10 | Pure Storage, Inc. | Encryption management with host-side data reduction |
US11321208B2 (en) * | 2017-09-06 | 2022-05-03 | Hitachi, Ltd. | Distributed storage system and distributed storage control method |
US10949199B1 (en) | 2017-09-14 | 2021-03-16 | Barefoot Networks, Inc. | Copying packet data to mirror buffer |
US10503590B2 (en) * | 2017-09-21 | 2019-12-10 | International Business Machines Corporation | Storage array comprising a host-offloaded storage function |
US10474528B2 (en) | 2017-10-02 | 2019-11-12 | Western Digital Technologies, Inc. | Redundancy coding stripe based on coordinated internal address scheme across multiple devices |
US10379948B2 (en) | 2017-10-02 | 2019-08-13 | Western Digital Technologies, Inc. | Redundancy coding stripe based on internal addresses of storage devices |
US10404596B2 (en) | 2017-10-03 | 2019-09-03 | Cisco Technology, Inc. | Dynamic route profile storage in a hardware trie routing table |
US10469367B2 (en) | 2017-10-04 | 2019-11-05 | Cisco Technology, Inc. | Segment routing network processing of packets including operations signaling and processing of packets in manners providing processing and/or memory efficiencies |
US10353606B2 (en) | 2017-10-12 | 2019-07-16 | International Business Machines Corporation | Partial data replay in a distributed memory buffer system |
WO2019071595A1 (zh) * | 2017-10-13 | 2019-04-18 | 华为技术有限公司 | 分布式块存储系统中数据存储方法、装置及计算机可读存储介质 |
US10942666B2 (en) | 2017-10-13 | 2021-03-09 | Cisco Technology, Inc. | Using network device replication in distributed storage clusters |
CN107748704A (zh) * | 2017-10-13 | 2018-03-02 | 郑州云海信息技术有限公司 | 基于fpga的内存镜像实现的方法及装置 |
US11005771B2 (en) | 2017-10-16 | 2021-05-11 | Mellanox Technologies, Ltd. | Computational accelerator for packet payload operations |
US11502948B2 (en) | 2017-10-16 | 2022-11-15 | Mellanox Technologies, Ltd. | Computational accelerator for storage operations |
CN109697017B (zh) * | 2017-10-20 | 2022-03-15 | 上海宝存信息科技有限公司 | 数据储存装置以及非挥发式存储器操作方法 |
KR102427323B1 (ko) * | 2017-11-08 | 2022-08-01 | 삼성전자주식회사 | 반도체 메모리 모듈, 반도체 메모리 시스템, 그리고 반도체 메모리 모듈을 액세스하는 액세스 방법 |
CN108062358B (zh) * | 2017-11-28 | 2020-12-29 | 厦门市美亚柏科信息股份有限公司 | innodb引擎删除记录的离线恢复方法、存储介质 |
US10708240B2 (en) | 2017-12-14 | 2020-07-07 | Mellanox Technologies, Ltd. | Offloading communication security operations to a network interface controller |
CN108235751B (zh) * | 2017-12-18 | 2020-04-14 | 华为技术有限公司 | 识别对象存储设备亚健康的方法、装置和数据存储系统 |
FR3075413B1 (fr) * | 2017-12-20 | 2020-01-10 | Bull Sas | Procede de pre-chargement de donnees |
KR102032878B1 (ko) * | 2017-12-22 | 2019-10-16 | 한국외국어대학교 연구산학협력단 | 플래시 메모리 컨트롤러의 에러 정정 방법 |
CN109976663B (zh) * | 2017-12-27 | 2021-12-28 | 浙江宇视科技有限公司 | 分布式存储响应方法和系统 |
US10592173B2 (en) * | 2018-01-10 | 2020-03-17 | International Business Machines Corporation | Increasing storage efficiency of a data protection technique |
CN110096451B (zh) * | 2018-01-29 | 2023-08-04 | 华为技术有限公司 | 一种数据存储方法及装置 |
CN110096220B (zh) * | 2018-01-31 | 2020-06-26 | 华为技术有限公司 | 一种分布式存储系统、数据处理方法和存储节点 |
US10608939B1 (en) | 2018-02-13 | 2020-03-31 | Barefoot Networks, Inc. | Identifying congestion in a network |
US11157356B2 (en) | 2018-03-05 | 2021-10-26 | Samsung Electronics Co., Ltd. | System and method for supporting data protection across FPGA SSDs |
US10909066B2 (en) * | 2018-04-03 | 2021-02-02 | Microsoft Technology Licensing, Llc | Virtual RDMA switching for containerized applications |
CN108804027B (zh) * | 2018-04-10 | 2021-06-08 | 四川中电昆辰科技有限公司 | 单比特定位时隙分配表的压缩存储方法 |
CN115174733B (zh) * | 2018-04-28 | 2024-09-24 | 华为技术有限公司 | 一种界面显示方法、装置及设备 |
US10579606B2 (en) * | 2018-05-03 | 2020-03-03 | Samsung Electronics Co., Ltd | Apparatus and method of data analytics in key-value solid state device (KVSSD) including data and analytics containers |
US11003537B2 (en) * | 2018-05-29 | 2021-05-11 | Micron Technology, Inc. | Determining validity of data read from memory by a controller |
US10558565B2 (en) | 2018-05-29 | 2020-02-11 | Microsoft Technology Licensing, Llc | Garbage collection implementing erasure coding |
CN110597451B (zh) * | 2018-06-12 | 2021-02-23 | 华为技术有限公司 | 一种虚拟化缓存的实现方法及物理机 |
US10785024B2 (en) | 2018-06-20 | 2020-09-22 | International Business Machines Corporation | Encryption key structure within block based memory |
US10515042B1 (en) | 2018-06-20 | 2019-12-24 | Quanta Computer Inc. | DAS storage cable identification |
US11509606B2 (en) * | 2018-06-29 | 2022-11-22 | Intel Corporation | Offload of storage node scale-out management to a smart network interface controller |
CN110659234B (zh) * | 2018-06-30 | 2024-02-02 | 联想企业解决方案(新加坡)有限公司 | 服务器主板和主板dimm插槽的填充方法 |
US10409511B1 (en) | 2018-06-30 | 2019-09-10 | Western Digital Technologies, Inc. | Multi-device storage system with distributed read/write processing |
US10725941B2 (en) * | 2018-06-30 | 2020-07-28 | Western Digital Technologies, Inc. | Multi-device storage system with hosted services on peer storage devices |
US10725862B2 (en) * | 2018-07-06 | 2020-07-28 | Macronix International Co., Ltd. | Data recovery method to error correction code in memory |
US11194588B2 (en) * | 2018-07-09 | 2021-12-07 | Dell Products L.P. | Information handling systems and method to provide secure shared memory access at OS runtime |
CN110729006B (zh) * | 2018-07-16 | 2022-07-05 | 超威半导体(上海)有限公司 | 存储器控制器中的刷新方案 |
KR102495539B1 (ko) * | 2018-07-16 | 2023-02-06 | 에스케이하이닉스 주식회사 | 메모리 시스템 및 메모리 시스템의 동작방법 |
US11238005B2 (en) | 2018-07-20 | 2022-02-01 | Samsung Electronics Co., Ltd. | SFF-TA-100X based multi-mode protocols solid state devices |
US10831411B2 (en) | 2018-07-24 | 2020-11-10 | International Business Machines Corporation | Storage controller with OCS for managing active-passive backend storage arrays |
US10825477B2 (en) * | 2018-08-02 | 2020-11-03 | Western Digital Technologies, Inc. | RAID storage system with logical data group priority |
US10901848B2 (en) * | 2018-08-03 | 2021-01-26 | Western Digital Technologies, Inc. | Storage systems with peer data recovery |
US11132256B2 (en) | 2018-08-03 | 2021-09-28 | Western Digital Technologies, Inc. | RAID storage system with logical data group rebuild |
US10824526B2 (en) | 2018-08-03 | 2020-11-03 | Western Digital Technologies, Inc. | Using failed storage device in peer-to-peer storage system to perform storage-centric task |
US10649843B2 (en) | 2018-08-03 | 2020-05-12 | Western Digital Technologies, Inc. | Storage systems with peer data scrub |
US10831603B2 (en) | 2018-08-03 | 2020-11-10 | Western Digital Technologies, Inc. | Rebuild assist using failed storage device |
US10592144B2 (en) | 2018-08-03 | 2020-03-17 | Western Digital Technologies, Inc. | Storage system fabric with multichannel compute complex |
US11347678B2 (en) | 2018-08-06 | 2022-05-31 | Oracle International Corporation | One-sided reliable remote direct memory operations |
KR20200021819A (ko) * | 2018-08-21 | 2020-03-02 | 에스케이하이닉스 주식회사 | 메모리 컨트롤러, 저장 장치 및 그 동작 방법 |
CN109240608B (zh) * | 2018-08-22 | 2021-08-31 | 郑州云海信息技术有限公司 | 一种配置信息同步方法及装置 |
CN109362236A (zh) * | 2018-08-31 | 2019-02-19 | 深圳大学 | 基于双云端的数据安全存储方法、装置、设备及存储介质 |
JP7091203B2 (ja) | 2018-09-19 | 2022-06-27 | キオクシア株式会社 | メモリシステムおよび制御方法 |
US11030316B2 (en) | 2018-09-20 | 2021-06-08 | Samsung Electronics Co., Ltd. | System and method for providing security protection for FPGA based solid state drives |
DE102018007628A1 (de) * | 2018-09-26 | 2020-03-26 | Giesecke+Devrient Mobile Security Gmbh | Dezentralisierte Identitätsmanagement-Lösung |
US10877810B2 (en) | 2018-09-29 | 2020-12-29 | Western Digital Technologies, Inc. | Object storage system with metadata operation priority processing |
US10956071B2 (en) * | 2018-10-01 | 2021-03-23 | Western Digital Technologies, Inc. | Container key value store for data storage devices |
US10817430B2 (en) | 2018-10-02 | 2020-10-27 | Micron Technology, Inc. | Access unit and management segment memory operations |
US10652208B2 (en) | 2018-10-03 | 2020-05-12 | Axonius Solutions Ltd. | System and method for managing network connected devices |
TWI679532B (zh) * | 2018-10-05 | 2019-12-11 | 緯穎科技服務股份有限公司 | 監測系統與方法 |
US20200117722A1 (en) * | 2018-10-12 | 2020-04-16 | Goke Us Research Laboratory | Efficient file storage and retrieval system, method and apparatus |
CN109586931B (zh) * | 2018-10-18 | 2021-01-15 | 招商证券股份有限公司 | 组播方法及终端设备 |
KR20200046495A (ko) * | 2018-10-24 | 2020-05-07 | 에스케이하이닉스 주식회사 | 메모리 시스템 및 그것의 동작방법 |
US10761932B2 (en) * | 2018-10-25 | 2020-09-01 | Hewlett Packard Enterprise Development Lp | Data and metadata storage in storage devices |
US11023155B2 (en) | 2018-10-29 | 2021-06-01 | International Business Machines Corporation | Processing event messages for changed data objects to determine a storage pool to store the changed data objects |
US10983985B2 (en) * | 2018-10-29 | 2021-04-20 | International Business Machines Corporation | Determining a storage pool to store changed data objects indicated in a database |
GB2578600B (en) * | 2018-10-31 | 2021-10-13 | Advanced Risc Mach Ltd | Memory transaction request management |
US10936295B2 (en) * | 2018-11-01 | 2021-03-02 | Dell Products L.P. | Software update system |
US11409900B2 (en) | 2018-11-15 | 2022-08-09 | International Business Machines Corporation | Processing event messages for data objects in a message queue to determine data to redact |
US11429674B2 (en) | 2018-11-15 | 2022-08-30 | International Business Machines Corporation | Processing event messages for data objects to determine data to redact from a database |
CN109683809B (zh) * | 2018-11-19 | 2021-08-31 | 深圳市艾锐达光电有限公司 | 一种数据存储方法及终端 |
US10749758B2 (en) | 2018-11-21 | 2020-08-18 | International Business Machines Corporation | Cognitive data center management |
US10951403B2 (en) * | 2018-12-03 | 2021-03-16 | Winbond Electronics Corporation | Updating cryptographic keys stored in non-volatile memory |
CN109788697B (zh) | 2018-12-04 | 2021-04-09 | 华为技术有限公司 | 具有平行背板的电子设备及存储设备 |
US10949297B2 (en) * | 2018-12-05 | 2021-03-16 | Micron Technology, Inc. | NAND device mixed parity management |
US11734192B2 (en) | 2018-12-10 | 2023-08-22 | International Business Machines Corporation | Identifying location of data granules in global virtual address space |
US11016908B2 (en) * | 2018-12-11 | 2021-05-25 | International Business Machines Corporation | Distributed directory of named data elements in coordination namespace |
US11204819B2 (en) | 2018-12-21 | 2021-12-21 | Samsung Electronics Co., Ltd. | System and method for offloading application functions to a device |
CN111367466B (zh) * | 2018-12-26 | 2023-08-15 | 深圳市茁壮网络股份有限公司 | 一种磁盘预退休方法和装置 |
CN109710547B (zh) * | 2018-12-29 | 2020-12-08 | 浙江理工大学 | 一种工业物联网中的缓冲内存管理设计与实现方法 |
US11182258B2 (en) * | 2019-01-04 | 2021-11-23 | Western Digital Technologies, Inc. | Data rebuild using dynamic peer work allocation |
US11455402B2 (en) | 2019-01-30 | 2022-09-27 | Seagate Technology Llc | Non-volatile memory with precise write-once protection |
KR20200095130A (ko) * | 2019-01-31 | 2020-08-10 | 에스케이하이닉스 주식회사 | 메모리 컨트롤러 및 그 동작 방법 |
US11068424B2 (en) * | 2019-02-04 | 2021-07-20 | American Megatrends International, Llc | Enablement of software defined storage solution for NVME over ethernet fabric management on a processor |
CN109947447A (zh) * | 2019-02-25 | 2019-06-28 | 南京百敖软件有限公司 | 一种服务器传感器监控在线更新方法 |
KR101995034B1 (ko) * | 2019-02-26 | 2019-07-02 | 에스케이하이닉스 주식회사 | 데이터 저장 장치 및 그것의 동작 방법 |
US10997029B2 (en) * | 2019-03-07 | 2021-05-04 | International Business Machines Corporation | Core repair with failure analysis and recovery probe |
WO2020185623A1 (en) | 2019-03-08 | 2020-09-17 | Mobileye Vision Technologies Ltd. | Priority based management of access to shared resources |
US11151093B2 (en) * | 2019-03-29 | 2021-10-19 | International Business Machines Corporation | Distributed system control for on-demand data access in complex, heterogenous data storage |
US11184439B2 (en) | 2019-04-01 | 2021-11-23 | Mellanox Technologies, Ltd. | Communication with accelerator via RDMA-based network adapter |
US11494107B2 (en) * | 2019-04-11 | 2022-11-08 | Apple Inc. | Managing parity information for data stored on a storage device |
TWI704567B (zh) * | 2019-04-18 | 2020-09-11 | 大陸商上海川源信息科技有限公司 | 磁碟陣列系統的資料還原方法 |
US11316904B2 (en) * | 2019-04-25 | 2022-04-26 | Super Micro Computer, Inc. | Network switches with secured switch ports to baseboard management controllers |
CN111857547B (zh) * | 2019-04-29 | 2024-05-24 | 伊姆西Ip控股有限责任公司 | 用于管理数据存储的方法、设备和计算机可读介质 |
US20200342109A1 (en) * | 2019-04-29 | 2020-10-29 | Hewlett Packard Enterprise Development Lp | Baseboard management controller to convey data |
KR20200126531A (ko) * | 2019-04-30 | 2020-11-09 | 에스케이하이닉스 주식회사 | 메모리 시스템 및 그의 커맨드 수행 방법 |
DE112020002484T5 (de) * | 2019-05-23 | 2022-04-28 | Hewlett Packard Enterprise Development Lp | System und verfahren zur erleichterung der feinkörnigen flusssteuerung in einer netzwerkschnittstellensteuerung (nic) |
US11487616B2 (en) * | 2019-05-24 | 2022-11-01 | Texas Instruments Incorporated | Write control for read-modify-write operations in cache memory |
US11620389B2 (en) | 2019-06-24 | 2023-04-04 | University Of Maryland Baltimore County | Method and system for reducing false positives in static source code analysis reports using machine learning and classification techniques |
US20220253236A1 (en) * | 2019-07-02 | 2022-08-11 | Microsoft Technology Licensing, Llc | Hardware-based memory compression |
US11086719B2 (en) | 2019-07-16 | 2021-08-10 | Microsoft Technology Licensing, Llc | Use of error correction codes to prevent errors in neighboring storage |
US11172455B2 (en) | 2019-07-16 | 2021-11-09 | Microsoft Technology Licensing, Llc | Peak to average power output reduction of RF systems utilizing error correction |
US11044044B2 (en) | 2019-07-16 | 2021-06-22 | Microsoft Technology Licensing, Llc | Peak to average power ratio reduction of optical systems utilizing error correction |
US11075656B2 (en) | 2019-07-16 | 2021-07-27 | Microsoft Technology Licensing, Llc | Bit error reduction of communication systems using error correction |
US11063696B2 (en) | 2019-07-16 | 2021-07-13 | Microsoft Technology Licensing, Llc | Increasing average power levels to reduce peak-to-average power levels using error correction codes |
US11031961B2 (en) | 2019-07-16 | 2021-06-08 | Microsoft Technology Licensing, Llc | Smart symbol changes for optimization of communications using error correction |
US10911284B1 (en) | 2019-07-16 | 2021-02-02 | Microsoft Technology Licensing, Llc | Intelligent optimization of communication systems utilizing error correction |
US11983277B2 (en) | 2019-07-16 | 2024-05-14 | Hewlett Packard Enterprise Development Lp | Identifying a security vulnerability in a computer system |
CN110489367B (zh) * | 2019-07-29 | 2020-10-02 | 苏州浪潮智能科技有限公司 | 一种灵活调配且易于cpld管理背板的方法与系统 |
US10911141B1 (en) | 2019-07-30 | 2021-02-02 | Microsoft Technology Licensing, Llc | Dynamically selecting a channel model for optical communications |
KR102650809B1 (ko) | 2019-08-02 | 2024-03-26 | 삼성전자주식회사 | 스토리지 장치 및 그것의 동작 방법 |
US11200106B2 (en) | 2019-08-12 | 2021-12-14 | Advanced Micro Devices, Inc. | Data integrity for persistent memory systems and the like |
US11487908B2 (en) * | 2019-08-16 | 2022-11-01 | Macronix International Co., Ltd. | Secure memory |
US11150812B2 (en) | 2019-08-20 | 2021-10-19 | Micron Technology, Inc. | Predictive memory management |
CN110569262A (zh) * | 2019-08-21 | 2019-12-13 | 广州汇思信息科技有限公司 | 一种电子试卷生成方法、电子设备以及存储介质 |
US10817460B2 (en) * | 2019-08-28 | 2020-10-27 | Advanced New Technologies Co., Ltd. | RDMA data sending and receiving methods, electronic device, and readable storage medium |
KR102316271B1 (ko) * | 2019-08-29 | 2021-10-22 | 동국대학교 산학협력단 | 데이터 저장장치의 주소 맵핑 테이블 운용 방법 |
US10866861B1 (en) | 2019-08-29 | 2020-12-15 | Micron Technology, Inc. | Deferred error-correction parity calculations |
US11016692B2 (en) | 2019-09-11 | 2021-05-25 | International Business Machines Corporation | Dynamically switching between memory copy and memory mapping to optimize I/O performance |
JP2021043708A (ja) * | 2019-09-11 | 2021-03-18 | キオクシア株式会社 | メモリシステム |
US10942857B1 (en) | 2019-09-11 | 2021-03-09 | International Business Machines Corporation | Dynamically adjusting a number of memory copy and memory mapping windows to optimize I/O performance |
CN110688328B (zh) * | 2019-09-27 | 2023-03-14 | 山东华芯半导体有限公司 | 一种axi总线分主机映射集的可配置重映射实现方法 |
US11360949B2 (en) * | 2019-09-30 | 2022-06-14 | Dell Products L.P. | Method and system for efficient updating of data in a linked node system |
US11481293B2 (en) | 2019-09-30 | 2022-10-25 | Dell Products L.P. | Method and system for replica placement in a linked node system |
US11604771B2 (en) | 2019-09-30 | 2023-03-14 | Dell Products L.P. | Method and system for data placement in a linked node system |
US11288372B2 (en) | 2019-10-07 | 2022-03-29 | Microsoft Technology Licensing, Llc | Secure installation of baseboard management controller firmware via a physical interface |
US11243859B2 (en) * | 2019-10-09 | 2022-02-08 | Microsoft Technology Licensing, Llc | Baseboard management controller that initiates a diagnostic operation to collect host information |
US11151041B2 (en) * | 2019-10-15 | 2021-10-19 | Micron Technology, Inc. | Tokens to indicate completion of data storage |
CN110990324A (zh) * | 2019-10-25 | 2020-04-10 | 苏州浪潮智能科技有限公司 | 一种实现输出控制的方法、装置、计算机存储介质及终端 |
CN110753121A (zh) * | 2019-10-25 | 2020-02-04 | 北京浪潮数据技术有限公司 | 一种镜像仓库的部署方法、装置、设备及介质 |
US11251979B2 (en) * | 2019-10-30 | 2022-02-15 | International Business Machines Corporation | Control of information units for encryption |
CN110795508B (zh) * | 2019-11-04 | 2023-04-07 | 中国建设银行股份有限公司 | 数据的复制方法、装置、设备和存储介质 |
US11580233B1 (en) * | 2019-11-13 | 2023-02-14 | Meta Platforms, Inc. | Baseboard-management-controller storage module |
US11016905B1 (en) | 2019-11-13 | 2021-05-25 | Western Digital Technologies, Inc. | Storage class memory access |
WO2021095252A1 (ja) | 2019-11-15 | 2021-05-20 | キオクシア株式会社 | ストレージデバイスおよびストレージシステム |
WO2021095232A1 (ja) | 2019-11-15 | 2021-05-20 | キオクシア株式会社 | ストレージシステム及びウェハ |
CN110866291B (zh) * | 2019-11-15 | 2023-03-24 | 北京工业大学 | 一种基于双重安全机制的废旧电子产品信息清除方法 |
CN111080840B (zh) * | 2019-12-04 | 2022-02-18 | 中国直升机设计研究所 | 一种直升机飞控系统数据发送及复现方法 |
US12099746B2 (en) * | 2019-12-16 | 2024-09-24 | Micron Technology, Inc. | Interrupt signaling for a memory device |
US11256448B2 (en) | 2019-12-16 | 2022-02-22 | Samsung Electronics Co., Ltd. | Network storage gateway |
US11706479B2 (en) * | 2019-12-19 | 2023-07-18 | Comcast Cable Communications, Llc | Methods and systems for storing user-specific media sequences |
CN111211944B (zh) * | 2020-01-07 | 2021-11-12 | 深圳市吉祥腾达科技有限公司 | 一种路由器一wan多拨稳定性测试系统及测试方法 |
US10978097B1 (en) | 2020-01-16 | 2021-04-13 | International Business Machines Corporation | Indicating tracks as erased without deleting data for the tracks |
KR20210094178A (ko) * | 2020-01-20 | 2021-07-29 | 삼성전자주식회사 | 직렬로 연결된 전자 장치들 사이에서 컴플리션을 조기에 전송하기 위한 컴퓨팅 시스템 |
US11210002B2 (en) | 2020-01-29 | 2021-12-28 | Samsung Electronics Co., Ltd. | Offloaded device-driven erasure coding |
US11316917B2 (en) * | 2020-03-04 | 2022-04-26 | Samsung Electronics Co., Ltd. | Methods and apparatus for peer-to-peer data channels for storage devices |
US11231934B2 (en) | 2020-03-05 | 2022-01-25 | Samsung Electronics Co., Ltd. | System and method for controlling the order of instruction execution by a target device |
KR102289834B1 (ko) * | 2020-03-09 | 2021-08-12 | 한림대학교 산학협력단 | 센서 장치의 저장 공간을 이용한 가상 스토리지 시스템 및 이의 작동 방법 |
KR102289835B1 (ko) * | 2020-03-10 | 2021-08-12 | 한림대학교 산학협력단 | 블록 단위로 저장 데이터를 송수신하는 가상 스토리지 시스템 및 이의 작동 방법 |
CN113495681B (zh) * | 2020-04-07 | 2024-09-24 | 杭州萤石软件有限公司 | 一种nand flash文件数据存取方法、装置及存储介质 |
US20210342169A1 (en) * | 2020-04-29 | 2021-11-04 | Hewlett Packard Enterprise Development Lp | Emulating physical security devices |
US11481203B2 (en) | 2020-04-30 | 2022-10-25 | Forcepoint Llc | Shared pipeline for multiple services |
US11249921B2 (en) | 2020-05-06 | 2022-02-15 | Western Digital Technologies, Inc. | Page modification encoding and caching |
US11586385B1 (en) | 2020-05-06 | 2023-02-21 | Radian Memory Systems, Inc. | Techniques for managing writes in nonvolatile memory |
US20210349781A1 (en) * | 2020-05-11 | 2021-11-11 | Samsung Electronics Co., Ltd. | Systems, methods, and devices for data recovery using parity space as recovery space |
US20210357119A1 (en) * | 2020-05-15 | 2021-11-18 | Rey Bruce | Artificial intelligence-based hybrid raid controller device |
CN111835610B (zh) * | 2020-05-29 | 2022-05-03 | 中车株洲电力机车研究所有限公司 | 数据共享方法、系统、存储介质及电子设备 |
US11962518B2 (en) | 2020-06-02 | 2024-04-16 | VMware LLC | Hardware acceleration techniques using flow selection |
US11307782B2 (en) * | 2020-06-03 | 2022-04-19 | Micron Technology, Inc. | Host identification and verification system and method for a memory system |
US11507544B2 (en) | 2020-06-05 | 2022-11-22 | Vmware, Inc. | Efficient erasure-coded storage in distributed data systems |
US11334497B2 (en) * | 2020-06-05 | 2022-05-17 | Vmware, Inc. | Efficient segment cleaning employing local copying of data blocks in log-structured file systems of distributed data systems |
US11263146B2 (en) * | 2020-06-05 | 2022-03-01 | Vmware, Inc. | Efficient accessing methods for bypassing second layer mapping of data blocks in file systems of distributed data systems |
US11262919B2 (en) * | 2020-06-05 | 2022-03-01 | Vmware, Inc. | Efficient segment cleaning employing remapping of data blocks in log-structured file systems of distributed data systems |
JP7475989B2 (ja) * | 2020-06-26 | 2024-04-30 | キオクシア株式会社 | メモリシステムおよび制御方法 |
KR102208497B1 (ko) * | 2020-07-01 | 2021-01-27 | 주식회사 파두 | 메모리 컨트롤러 및 이를 포함하는 스토리지 디바이스 |
US11283719B2 (en) | 2020-07-13 | 2022-03-22 | Google Llc | Content addressable memory (CAM) based hardware architecture for datacenter networking |
WO2022020404A1 (en) * | 2020-07-22 | 2022-01-27 | Analog Devices, Inc. | Synchronizing communication channels between digital front-end processors |
US11237906B1 (en) * | 2020-07-28 | 2022-02-01 | Micron Technology, Inc. | Generating a balanced codeword protected by an error correction code |
US11567831B2 (en) | 2020-07-28 | 2023-01-31 | Micron Technology, Inc. | Generating a protected and balanced codeword |
US11494264B2 (en) | 2020-07-28 | 2022-11-08 | Micron Technology, Inc. | Generating a protected and balanced codeword |
IL276538B2 (en) | 2020-08-05 | 2023-08-01 | Mellanox Technologies Ltd | A cryptographic device for data communication |
CN114095153A (zh) | 2020-08-05 | 2022-02-25 | 迈络思科技有限公司 | 密码数据通信装置 |
US20220046080A1 (en) * | 2020-08-06 | 2022-02-10 | Dell Products L.P. | Systems and methods for shared access among host information handling system and multiple client information handling systems via management controller |
US11327858B2 (en) * | 2020-08-11 | 2022-05-10 | Seagate Technology Llc | Preserving data integrity during controller failure |
JP7175944B2 (ja) * | 2020-08-31 | 2022-11-21 | 楽天グループ株式会社 | 通信システム、送信装置、受信装置、通信方法、及びプログラム |
TWI817039B (zh) * | 2020-09-08 | 2023-10-01 | 以色列商無比視視覺科技有限公司 | 用以管理多個啟動器存取共享資源之方法及系統以及相關電腦程式產品 |
CN116097235B (zh) * | 2020-09-17 | 2023-08-04 | 华为技术有限公司 | 一种基于内部集成电路的通信方法及装置 |
CN111930517B (zh) * | 2020-09-18 | 2023-07-14 | 北京中科立维科技有限公司 | 一种高性能自适应垃圾收集方法和计算机系统 |
US11636053B2 (en) | 2020-09-28 | 2023-04-25 | Vmware, Inc. | Emulating a local storage by accessing an external storage through a shared port of a NIC |
US12021759B2 (en) | 2020-09-28 | 2024-06-25 | VMware LLC | Packet processing with hardware offload units |
US11606310B2 (en) | 2020-09-28 | 2023-03-14 | Vmware, Inc. | Flow processing offload using virtual port identifiers |
US11716383B2 (en) * | 2020-09-28 | 2023-08-01 | Vmware, Inc. | Accessing multiple external storages to present an emulated local storage through a NIC |
US11593278B2 (en) | 2020-09-28 | 2023-02-28 | Vmware, Inc. | Using machine executing on a NIC to access a third party storage not supported by a NIC or host |
US11829793B2 (en) | 2020-09-28 | 2023-11-28 | Vmware, Inc. | Unified management of virtual machines and bare metal computers |
US12061583B1 (en) * | 2020-09-29 | 2024-08-13 | Amazon Technologies, Inc. | Systems for processing data using stages |
US11809282B2 (en) * | 2020-09-29 | 2023-11-07 | EMC IP Holding Company LLC | Optimized pipeline to boost de-dup system performance |
US11914492B2 (en) * | 2020-10-13 | 2024-02-27 | Dell Products, L.P. | System and method for highly granular power/thermal control in information handling systems |
US11327909B1 (en) | 2020-10-26 | 2022-05-10 | Mellanox Technologies, Ltd. | System for improving input / output performance |
US11544205B2 (en) | 2020-11-20 | 2023-01-03 | Western Digital Technologies, Inc. | Peer storage devices sharing host control data |
US11531498B2 (en) * | 2020-11-20 | 2022-12-20 | Western Digital Technologies, Inc. | Peer storage device messaging over control bus |
TWI754473B (zh) * | 2020-11-27 | 2022-02-01 | 中強光電股份有限公司 | 用於光譜模型解釋的電子裝置和方法 |
CN112380071B (zh) * | 2020-12-09 | 2023-10-27 | 成都傲梅科技有限公司 | 一种快速备份ntfs文件系统的方法 |
US11543992B2 (en) * | 2020-12-09 | 2023-01-03 | Western Digital Technologies, Inc. | Decreasing physical secure erase times in solid state drives |
TWI758013B (zh) * | 2020-12-15 | 2022-03-11 | 技嘉科技股份有限公司 | 基板管理控制系統、電子裝置以及基板管理控制方法 |
CN112698697A (zh) * | 2020-12-30 | 2021-04-23 | 湖南博匠信息科技有限公司 | 一种软件定义vpx机箱 |
US11556424B2 (en) | 2021-01-19 | 2023-01-17 | Western Digital Technologies, Inc. | Non-volatile storage device having fast boot code transfer with low speed fallback |
US11606422B2 (en) * | 2021-01-20 | 2023-03-14 | Samsung Electronics Co., Ltd. | Server for controlling data transmission through data pipeline and operation method thereof |
CN114817121A (zh) * | 2021-01-22 | 2022-07-29 | 伊姆西Ip控股有限责任公司 | 用于处理数据的方法、电子设备和计算机程序产品 |
CN112765223B (zh) * | 2021-01-26 | 2023-07-14 | 红云红河烟草(集团)有限责任公司 | 一种基于队列的设备参数数据对齐方法 |
US11645219B2 (en) * | 2021-02-02 | 2023-05-09 | American Megatrends International, Llc | Method for generating a hybrid BMC system and hybrid BMC system |
JP2022122478A (ja) * | 2021-02-10 | 2022-08-23 | 株式会社日立製作所 | ストレージコントローラのネットワークインタフェース |
US11573718B2 (en) * | 2021-02-12 | 2023-02-07 | Western Digital Technologies, Inc. | Disaggregation of control path and data path |
US11934658B2 (en) | 2021-03-25 | 2024-03-19 | Mellanox Technologies, Ltd. | Enhanced storage protocol emulation in a peripheral device |
US11940935B2 (en) * | 2021-04-19 | 2024-03-26 | Mellanox Technologies, Ltd. | Apparatus, method and computer program product for efficient software-defined network accelerated processing using storage devices which are local relative to a host |
CN117256102A (zh) * | 2021-04-21 | 2023-12-19 | 拉姆伯斯公司 | 具有用于并发接口操作的单向端口的集成电路存储器设备 |
US12081526B2 (en) * | 2021-05-19 | 2024-09-03 | Western Digital Technologies, Inc. | Data storage device data recovery using remote network storage |
US12040988B2 (en) | 2021-05-25 | 2024-07-16 | Google Llc | Acknowledgement coalescing module utilized in content addressable memory (CAM) based hardware architecture for data center networking |
EP4200852A4 (en) | 2021-06-01 | 2024-01-03 | Yangtze Memory Technologies Co., Ltd. | POWER MANAGEMENT FOR A MEMORY SYSTEM |
US11783866B2 (en) | 2021-06-02 | 2023-10-10 | Western Digital Technologies, Inc. | Data storage device and method for legitimized data transfer |
CN113538754B (zh) * | 2021-06-08 | 2023-04-07 | 福建新大陆通信科技股份有限公司 | 一种ctid智能门锁授权数据管理方法及系统 |
US11782641B2 (en) * | 2021-06-09 | 2023-10-10 | International Business Machines Corporation | Backend aware virtualized storage |
CN117616378A (zh) * | 2021-06-24 | 2024-02-27 | 净睿存储股份有限公司 | 在分区式驱动器存储系统中高效地写入数据 |
US11625189B2 (en) * | 2021-06-28 | 2023-04-11 | Western Digital Technologies, Inc. | Systems and methods for fragmentation management in host buffers |
US11321178B1 (en) * | 2021-06-29 | 2022-05-03 | Dell Products, L. P. | Automated recovery from raid double failure |
US11726666B2 (en) | 2021-07-11 | 2023-08-15 | Mellanox Technologies, Ltd. | Network adapter with efficient storage-protocol emulation |
US11675602B2 (en) | 2021-07-28 | 2023-06-13 | International Business Machines Corporation | Methods and systems for creating root-of-trust for computing system components |
CN113590043B (zh) * | 2021-07-29 | 2024-08-16 | 北京沃东天骏信息技术有限公司 | 一种数据存储方法、装置、设备及存储介质 |
US12074962B2 (en) | 2021-08-10 | 2024-08-27 | Samsung Electronics Co., Ltd. | Systems, methods, and apparatus for dividing and encrypting data |
US20230049602A1 (en) * | 2021-08-10 | 2023-02-16 | Samsung Electronics Co., Ltd. | Systems, methods, and apparatus for hierarchical aggregation for computational storage |
CN115905056A (zh) | 2021-08-11 | 2023-04-04 | 迈络思科技有限公司 | 改进存储子系统中的步调 |
US11609700B2 (en) | 2021-08-11 | 2023-03-21 | Mellanox Technologies, Ltd. | Pacing in a storage sub-system |
CN115906722A (zh) * | 2021-08-16 | 2023-04-04 | 富联精密电子(天津)有限公司 | 用于提高可编程器件引脚复用率的服务器系统及方法 |
US12132802B2 (en) | 2021-09-01 | 2024-10-29 | Google Llc | Off-chip memory backed reliable transport connection cache hardware architecture |
US12112200B2 (en) | 2021-09-13 | 2024-10-08 | International Business Machines Corporation | Pipeline parallel computing using extended memory |
US11662955B2 (en) * | 2021-09-27 | 2023-05-30 | GRAID Technology Inc. | Direct memory access data path for RAID storage |
US20230121562A1 (en) * | 2021-10-15 | 2023-04-20 | Dell Products, L.P. | Telemetry of artificial intelligence (ai) and/or machine learning (ml) workloads |
EP4418096A1 (en) * | 2021-10-21 | 2024-08-21 | Seoul National University R&DB Foundation | Storage device system for quantum circuit simulation |
CN114143276B (zh) * | 2021-11-23 | 2024-10-01 | 青芯半导体科技(上海)有限公司 | 一种PCI-e交换机及其配置分支模式的方法 |
JP2023091307A (ja) * | 2021-12-20 | 2023-06-30 | キオクシア株式会社 | 半導体装置および制御方法 |
US11863376B2 (en) | 2021-12-22 | 2024-01-02 | Vmware, Inc. | Smart NIC leader election |
US11995024B2 (en) | 2021-12-22 | 2024-05-28 | VMware LLC | State sharing between smart NICs |
US11971771B2 (en) | 2022-01-25 | 2024-04-30 | Western Digital Technologies, Inc. | Peer storage device messaging for power management |
US11921602B2 (en) | 2022-02-14 | 2024-03-05 | Cribl, Inc. | Edge-based data collection system for an observability pipeline system |
US20230351019A1 (en) * | 2022-04-27 | 2023-11-02 | Dell Products L.P. | Secure smart network interface controller firmware update |
US11853201B2 (en) | 2022-05-25 | 2023-12-26 | Micron Technology, Inc. | Selective single-level memory cell operation |
KR102537770B1 (ko) * | 2022-06-08 | 2023-05-30 | 삼성전자주식회사 | 기입 스로틀링을 이용한 스토리지 장치의 데이터 기입 방법 및 이를 수행하는 스토리지 장치 |
US11928062B2 (en) | 2022-06-21 | 2024-03-12 | VMware LLC | Accelerating data message classification with smart NICs |
US11928367B2 (en) | 2022-06-21 | 2024-03-12 | VMware LLC | Logical memory addressing for network devices |
US11899594B2 (en) | 2022-06-21 | 2024-02-13 | VMware LLC | Maintenance of data message classification cache on smart NIC |
US12079084B2 (en) * | 2022-08-01 | 2024-09-03 | Microsoft Technology Licensing, Llc | Distributed raid for parity-based flash storage devices |
US12081450B2 (en) * | 2022-08-30 | 2024-09-03 | Xerox Corporation | System and method using improved message queue and packing scheme for electronic device |
US12117948B2 (en) | 2022-10-31 | 2024-10-15 | Mellanox Technologies, Ltd. | Data processing unit with transparent root complex |
US12007921B2 (en) | 2022-11-02 | 2024-06-11 | Mellanox Technologies, Ltd. | Programmable user-defined peripheral-bus device implementation using data-plane accelerator (DPA) |
CN115657963B (zh) * | 2022-11-14 | 2023-04-11 | 苏州浪潮智能科技有限公司 | 基于固态硬盘的顺序写方法、装置、电子设备及存储介质 |
CN115801633B (zh) * | 2023-02-08 | 2023-04-28 | 湖南国科亿存信息科技有限公司 | San存储的多客户端共享并发性能测试方法和系统 |
US12093220B1 (en) * | 2023-06-27 | 2024-09-17 | International Business Machines Corporation | Controlling layers in container images to reduce redundant content between layers |
US11979459B1 (en) * | 2023-10-12 | 2024-05-07 | International Business Machines Corporation | Configuration of data connections between a host and a shared network adapter |
CN117407324B (zh) * | 2023-12-12 | 2024-03-15 | 深圳市银闪科技有限公司 | 基于固态硬盘的数据存储方法、装置、固态硬盘控制器 |
CN117667465B (zh) * | 2024-01-31 | 2024-04-16 | 苏州元脑智能科技有限公司 | 代码共享方法、装置、交换机、多主机系统、设备和介质 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2001296974A (ja) * | 2000-02-25 | 2001-10-26 | Hewlett Packard Co <Hp> | データ記憶システム及びデータ記憶方法 |
WO2006113334A2 (en) * | 2005-04-15 | 2006-10-26 | Microsoft Corporation | In-line non volatile memory disk read cache and write buffer |
Family Cites Families (1283)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
USRE20535E (en) | 1937-10-19 | Valve for aerated liquid vessels | ||
GB123416A (en) | 1918-02-28 | 1919-02-27 | John Buchanan | Composite Valve for all Classes of Internal Combustion Engines. |
SE347103B (ko) | 1964-10-30 | 1972-07-24 | Olivetti & Co Spa | |
US4092732A (en) * | 1977-05-31 | 1978-05-30 | International Business Machines Corporation | System for recovering data stored in failed memory unit |
US4290105A (en) * | 1979-04-02 | 1981-09-15 | American Newspaper Publishers Association | Method and apparatus for testing membership in a set through hash coding with allowable errors |
NL8201847A (nl) * | 1982-05-06 | 1983-12-01 | Philips Nv | Inrichting voor het beschermen tegen onbevoegd uitlezen van in een geheugen te memoriseren programmawoorden. |
US4571674A (en) * | 1982-09-27 | 1986-02-18 | International Business Machines Corporation | Peripheral storage system having multiple data transfer rates |
US4598361A (en) * | 1985-01-11 | 1986-07-01 | Burroughs Corporation | Allocator for a reduction processor evaluating programs stored as binary directed graphs employing variable-free applicative language codes |
US5043871A (en) | 1986-03-26 | 1991-08-27 | Hitachi, Ltd. | Method and apparatus for database update/recovery |
US4761785B1 (en) | 1986-06-12 | 1996-03-12 | Ibm | Parity spreading to enhance storage access |
US4980861A (en) | 1987-01-16 | 1990-12-25 | Microchip Technology Incorporated | NAND stack ROM |
US4858070A (en) | 1987-04-24 | 1989-08-15 | Racal Data Communications Inc. | Modular expandable housing arrangement for electronic apparatus |
JPH02105730A (ja) | 1988-10-14 | 1990-04-18 | Sony Corp | データ記録方法 |
JPH02148235A (ja) | 1988-11-30 | 1990-06-07 | Toshiba Corp | データ退避方式 |
US5359726A (en) | 1988-12-22 | 1994-10-25 | Thomas Michael E | Ferroelectric storage device used in place of a rotating disk drive unit in a computer system |
US5394531A (en) | 1989-04-03 | 1995-02-28 | International Business Machines Corporation | Dynamic storage allocation system for a prioritized cache |
US5535328A (en) | 1989-04-13 | 1996-07-09 | Sandisk Corporation | Non-volatile memory system card with flash erasable sectors of EEprom cells including a mechanism for substituting defective cells |
US7190617B1 (en) * | 1989-04-13 | 2007-03-13 | Sandisk Corporation | Flash EEprom system |
US5371885A (en) | 1989-08-29 | 1994-12-06 | Microsoft Corporation | High performance file system |
US5247658A (en) * | 1989-10-31 | 1993-09-21 | Microsoft Corporation | Method and system for traversing linked list record based upon write-once predetermined bit value of secondary pointers |
US5111463A (en) | 1989-11-09 | 1992-05-05 | Exabyte Corporation | Error correction method and apparatus |
US5197130A (en) | 1989-12-29 | 1993-03-23 | Supercomputer Systems Limited Partnership | Cluster architecture for a highly parallel scalar/vector multiprocessor system |
US5124987A (en) | 1990-04-16 | 1992-06-23 | Storage Technology Corporation | Logical track write scheduling system for a parallel disk drive array data storage subsystem |
US5261068A (en) * | 1990-05-25 | 1993-11-09 | Dell Usa L.P. | Dual path memory retrieval system for an interleaved dynamic RAM memory unit |
US5193184A (en) | 1990-06-18 | 1993-03-09 | Storage Technology Corporation | Deleted data file space release system for a dynamically mapped virtual data storage subsystem |
US5307497A (en) * | 1990-06-25 | 1994-04-26 | International Business Machines Corp. | Disk operating system loadable from read only memory using installable file system interface |
ATE110478T1 (de) * | 1990-08-14 | 1994-09-15 | Siemens Ag | Einrichtung zur interruptverteilung in einem mehrrechnersystem. |
US5544347A (en) | 1990-09-24 | 1996-08-06 | Emc Corporation | Data storage system controlled remote data mirroring with respectively maintained data indices |
US5291496A (en) | 1990-10-18 | 1994-03-01 | The United States Of America As Represented By The United States Department Of Energy | Fault-tolerant corrector/detector chip for high-speed data processing |
JP3227707B2 (ja) | 1990-12-29 | 2001-11-12 | 日本電気株式会社 | 走行モード別キャッシュメモリ制御方式 |
GB2251324B (en) | 1990-12-31 | 1995-05-10 | Intel Corp | File structure for a non-volatile semiconductor memory |
US5274799A (en) * | 1991-01-04 | 1993-12-28 | Array Technology Corporation | Storage device array architecture with copyback cache |
US5325509A (en) | 1991-03-05 | 1994-06-28 | Zitel Corporation | Method of operating a cache memory including determining desirability of cache ahead or cache behind based on a number of available I/O operations |
US5325523A (en) | 1991-04-10 | 1994-06-28 | International Business Machines Corporation | Method for deleting objects from library resident optical disks by accumulating pending delete requests |
US5438671A (en) | 1991-07-19 | 1995-08-01 | Dell U.S.A., L.P. | Method and system for transferring compressed bytes of information between separate hard disk drive units |
US5465355A (en) * | 1991-09-04 | 1995-11-07 | International Business Machines Corporation | Establishing and restoring paths in a data processing I/O system |
US5313475A (en) | 1991-10-31 | 1994-05-17 | International Business Machines Corporation | ECC function with self-contained high performance partial write or read/modify/write and parity look-ahead interface scheme |
US5263003A (en) | 1991-11-12 | 1993-11-16 | Allen-Bradley Company, Inc. | Flash memory circuit and method of operation |
US5323489A (en) * | 1991-11-14 | 1994-06-21 | Bird Peter L | Method and apparatus employing lookahead to reduce memory bank contention for decoupled operand references |
US5499367A (en) | 1991-11-15 | 1996-03-12 | Oracle Corporation | System for database integrity with multiple logs assigned to client subsets |
US5469555A (en) * | 1991-12-19 | 1995-11-21 | Opti, Inc. | Adaptive write-back method and apparatus wherein the cache system operates in a combination of write-back and write-through modes for a cache-based microprocessor system |
JP3058743B2 (ja) | 1992-01-21 | 2000-07-04 | 株式会社日立製作所 | ディスクアレイ制御装置 |
US6256642B1 (en) | 1992-01-29 | 2001-07-03 | Microsoft Corporation | Method and system for file system management using a flash-erasable, programmable, read-only memory |
US5481708A (en) * | 1992-06-05 | 1996-01-02 | Borland International, Inc. | System and methods for optimizing object-oriented compilations |
JP3328321B2 (ja) | 1992-06-22 | 2002-09-24 | 株式会社日立製作所 | 半導体記憶装置 |
US5414840A (en) | 1992-06-25 | 1995-05-09 | Digital Equipment Corporation | Method and system for decreasing recovery time for failed atomic transactions by keeping copies of altered control structures in main memory |
JPH0628108A (ja) * | 1992-07-09 | 1994-02-04 | Hitachi Ltd | データ記憶システム |
JPH0644139A (ja) * | 1992-07-22 | 1994-02-18 | Ricoh Co Ltd | ディスクキャッシュシステムおよびそのページ置き換え制御方法 |
US5596736A (en) * | 1992-07-22 | 1997-01-21 | Fujitsu Limited | Data transfers to a backing store of a dynamically mapped data storage system in which data has nonsequential logical addresses |
US5381528A (en) | 1992-10-15 | 1995-01-10 | Maxtor Corporation | Demand allocation of read/write buffer partitions favoring sequential read cache |
US5388108A (en) * | 1992-10-23 | 1995-02-07 | Ncr Corporation | Delayed initiation of read-modify-write parity operations in a raid level 5 disk array |
US5357475A (en) * | 1992-10-30 | 1994-10-18 | Intel Corporation | Method for detaching sectors in a flash EEPROM memory array |
US5337275A (en) | 1992-10-30 | 1994-08-09 | Intel Corporation | Method for releasing space in flash EEPROM memory array to allow the storage of compressed data |
US5416915A (en) | 1992-12-11 | 1995-05-16 | International Business Machines Corporation | Method and system for minimizing seek affinity and enhancing write sensitivity in a DASD array |
US5579474A (en) * | 1992-12-28 | 1996-11-26 | Hitachi, Ltd. | Disk array system and its control method |
US5845329A (en) | 1993-01-29 | 1998-12-01 | Sanyo Electric Co., Ltd. | Parallel computer |
EP0612015A1 (en) * | 1993-02-16 | 1994-08-24 | International Business Machines Corporation | Improved disk array system having special parity groups for data blocks with high update activity |
US5459850A (en) | 1993-02-19 | 1995-10-17 | Conner Peripherals, Inc. | Flash solid state drive that emulates a disk drive and stores variable length and fixed lenth data blocks |
JP2856621B2 (ja) | 1993-02-24 | 1999-02-10 | インターナショナル・ビジネス・マシーンズ・コーポレイション | 一括消去型不揮発性メモリおよびそれを用いる半導体ディスク装置 |
JP3594626B2 (ja) | 1993-03-04 | 2004-12-02 | 株式会社ルネサステクノロジ | 不揮発性メモリ装置 |
US5404485A (en) | 1993-03-08 | 1995-04-04 | M-Systems Flash Disk Pioneers Ltd. | Flash file system |
US5761402A (en) * | 1993-03-08 | 1998-06-02 | Hitachi, Ltd. | Array type disk system updating redundant data asynchronously with data access |
US5479638A (en) | 1993-03-26 | 1995-12-26 | Cirrus Logic, Inc. | Flash memory mass storage architecture incorporation wear leveling technique |
US5485595A (en) | 1993-03-26 | 1996-01-16 | Cirrus Logic, Inc. | Flash memory mass storage architecture incorporating wear leveling technique without using cam cells |
US5388083A (en) | 1993-03-26 | 1995-02-07 | Cirrus Logic, Inc. | Flash memory mass storage architecture |
US6078520A (en) | 1993-04-08 | 2000-06-20 | Hitachi, Ltd. | Flash memory control method and information processing system therewith |
JP2784440B2 (ja) * | 1993-04-14 | 1998-08-06 | インターナショナル・ビジネス・マシーンズ・コーポレイション | データ・ページの転送制御方法 |
CA2121852A1 (en) * | 1993-04-29 | 1994-10-30 | Larry T. Jost | Disk meshing and flexible storage mapping with enhanced flexible caching |
US5499354A (en) | 1993-05-19 | 1996-03-12 | International Business Machines Corporation | Method and means for dynamic cache management by variable space and time binding and rebinding of cache extents to DASD cylinders |
US5765207A (en) | 1993-06-22 | 1998-06-09 | International Business Machines Corporation | Recursive hardware state machine |
US5592641A (en) | 1993-06-30 | 1997-01-07 | Intel Corporation | Method and device for selectively locking write access to blocks in a memory array using write protect inputs and block enabled status |
US5682497A (en) | 1993-09-28 | 1997-10-28 | Intel Corporation | Managing file structures for a flash memory file system in a computer |
US5535399A (en) | 1993-09-30 | 1996-07-09 | Quantum Corporation | Solid state disk drive unit having on-board backup non-volatile memory |
JPH07110784A (ja) | 1993-10-14 | 1995-04-25 | Fujitsu Ltd | 追加形式レコード格納方法及び装置 |
JPH086854A (ja) | 1993-12-23 | 1996-01-12 | Unisys Corp | アウトボードファイルキャッシュ外部処理コンプレックス |
US5809527A (en) | 1993-12-23 | 1998-09-15 | Unisys Corporation | Outboard file cache system |
GB9326499D0 (en) | 1993-12-24 | 1994-03-02 | Deas Alexander R | Flash memory system with arbitrary block size |
US5559988A (en) | 1993-12-30 | 1996-09-24 | Intel Corporation | Method and circuitry for queuing snooping, prioritizing and suspending commands |
US5379304A (en) | 1994-01-28 | 1995-01-03 | International Business Machines Corporation | Method and structure for providing error correction code and parity for each byte on SIMM's |
JP3378874B2 (ja) | 1994-03-18 | 2003-02-17 | 富士通株式会社 | 情報処理装置及びメモリボード |
US5553261A (en) | 1994-04-01 | 1996-09-03 | Intel Corporation | Method of performing clean-up of a solid state disk while executing a read command |
US5596708A (en) * | 1994-04-04 | 1997-01-21 | At&T Global Information Solutions Company | Method and apparatus for the protection of write data in a disk array |
US5603001A (en) | 1994-05-09 | 1997-02-11 | Kabushiki Kaisha Toshiba | Semiconductor disk system having a plurality of flash memories |
US5434994A (en) | 1994-05-23 | 1995-07-18 | International Business Machines Corporation | System and method for maintaining replicated data coherency in a data processing system |
US5696917A (en) * | 1994-06-03 | 1997-12-09 | Intel Corporation | Method and apparatus for performing burst read operations in an asynchronous nonvolatile memory |
US5504882A (en) * | 1994-06-20 | 1996-04-02 | International Business Machines Corporation | Fault tolerant data storage subsystem employing hierarchically arranged controllers |
IT1274925B (it) | 1994-09-21 | 1997-07-29 | Texas Instruments Italia Spa | Architettura di memoria per dischi a stato solido |
US5845331A (en) | 1994-09-28 | 1998-12-01 | Massachusetts Institute Of Technology | Memory system including guarded pointers |
US5664187A (en) | 1994-10-26 | 1997-09-02 | Hewlett-Packard Company | Method and system for selecting data for migration in a hierarchic data storage system using frequency distribution tables |
JPH08153014A (ja) | 1994-11-30 | 1996-06-11 | Hitachi Ltd | クライアントサーバシステム |
DE19540915A1 (de) | 1994-11-10 | 1996-05-15 | Raymond Engineering | Redundante Anordnung von Festkörper-Speicherbausteinen |
US6002411A (en) | 1994-11-16 | 1999-12-14 | Interactive Silicon, Inc. | Integrated video and memory controller with data processing and graphical processing capabilities |
US6170047B1 (en) | 1994-11-16 | 2001-01-02 | Interactive Silicon, Inc. | System and method for managing system memory and/or non-volatile memory using a memory controller with integrated compression and decompression capabilities |
JP3011035B2 (ja) * | 1994-12-08 | 2000-02-21 | 株式会社日立製作所 | 計算機システム |
US5586291A (en) | 1994-12-23 | 1996-12-17 | Emc Corporation | Disk controller with volatile and non-volatile cache memories |
US5541886A (en) | 1994-12-27 | 1996-07-30 | Intel Corporation | Method and apparatus for storing control information in multi-bit non-volatile memory arrays |
US5566315A (en) | 1994-12-30 | 1996-10-15 | Storage Technology Corporation | Process of predicting and controlling the use of cache memory in a computer system |
US5651133A (en) | 1995-02-01 | 1997-07-22 | Hewlett-Packard Company | Methods for avoiding over-commitment of virtual capacity in a redundant hierarchic data storage system |
US5745671A (en) | 1995-02-28 | 1998-04-28 | International Business Machines Corporation | Data storage system with localized XOR function |
US5574882A (en) * | 1995-03-03 | 1996-11-12 | International Business Machines Corporation | System and method for identifying inconsistent parity in an array of storage |
US5701434A (en) | 1995-03-16 | 1997-12-23 | Hitachi, Ltd. | Interleave memory controller with a common access queue |
US5742787A (en) | 1995-04-10 | 1998-04-21 | Intel Corporation | Hardware reset of a write state machine for flash memory |
US5799140A (en) | 1995-04-21 | 1998-08-25 | International Business Machines Corporation | Disk array system and method for storing data |
EP0747825B1 (en) | 1995-06-06 | 2001-09-19 | Hewlett-Packard Company, A Delaware Corporation | SDRAM data allocation system and method |
US5682499A (en) * | 1995-06-06 | 1997-10-28 | International Business Machines Corporation | Directory rebuild method and apparatus for maintaining and rebuilding directory information for compressed data on direct access storage device (DASD) |
JP3732869B2 (ja) * | 1995-06-07 | 2006-01-11 | 株式会社日立製作所 | 外部記憶装置 |
US5721874A (en) | 1995-06-16 | 1998-02-24 | International Business Machines Corporation | Configurable cache with variable, dynamically addressable line sizes |
JPH096706A (ja) | 1995-06-22 | 1997-01-10 | Hitachi Ltd | 疎結合計算機システム |
JP3062050B2 (ja) | 1995-07-21 | 2000-07-10 | インターナショナル・ビジネス・マシーンズ・コーポレ−ション | ディスク駆動制御方法及び装置 |
US5930815A (en) | 1995-07-31 | 1999-07-27 | Lexar Media, Inc. | Moving sequential sectors within a block of information in a flash memory mass storage architecture |
US5845313A (en) * | 1995-07-31 | 1998-12-01 | Lexar | Direct logical block addressing flash memory mass storage architecture |
US5907856A (en) | 1995-07-31 | 1999-05-25 | Lexar Media, Inc. | Moving sectors within a block of information in a flash memory mass storage architecture |
US6757800B1 (en) * | 1995-07-31 | 2004-06-29 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6801979B1 (en) | 1995-07-31 | 2004-10-05 | Lexar Media, Inc. | Method and apparatus for memory control circuit |
US6728851B1 (en) | 1995-07-31 | 2004-04-27 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6081878A (en) * | 1997-03-31 | 2000-06-27 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US8171203B2 (en) * | 1995-07-31 | 2012-05-01 | Micron Technology, Inc. | Faster write operations to nonvolatile memory using FSInfo sector manipulation |
US5838614A (en) | 1995-07-31 | 1998-11-17 | Lexar Microsystems, Inc. | Identification and verification of a sector within a block of mass storage flash memory |
US6978342B1 (en) | 1995-07-31 | 2005-12-20 | Lexar Media, Inc. | Moving sectors within a block of information in a flash memory mass storage architecture |
US5754563A (en) | 1995-09-11 | 1998-05-19 | Ecc Technologies, Inc. | Byte-parallel system for implementing reed-solomon error-correcting codes |
US5835935A (en) | 1995-09-13 | 1998-11-10 | Lexar Media, Inc. | Method of and architecture for controlling system data with automatic wear leveling in a semiconductor non-volatile mass storage memory |
GB2291991A (en) * | 1995-09-27 | 1996-02-07 | Memory Corp Plc | Disk drive emulation with a block-erasable memory |
US5933847A (en) | 1995-09-28 | 1999-08-03 | Canon Kabushiki Kaisha | Selecting erase method based on type of power supply for flash EEPROM |
US5799200A (en) | 1995-09-28 | 1998-08-25 | Emc Corporation | Power failure responsive apparatus and method having a shadow dram, a flash ROM, an auxiliary battery, and a controller |
US5893138A (en) | 1995-10-02 | 1999-04-06 | International Business Machines Corporation | System and method for improving channel hardware performance for an array controller |
JP3363292B2 (ja) * | 1995-10-12 | 2003-01-08 | 株式会社日立製作所 | データベース管理システム |
US6470405B2 (en) * | 1995-10-19 | 2002-10-22 | Rambus Inc. | Protocol for communication with dynamic memory |
US6014724A (en) | 1995-10-27 | 2000-01-11 | Scm Microsystems (U.S.) Inc. | Flash translation layer block indication map revision system and method |
US6330688B1 (en) | 1995-10-31 | 2001-12-11 | Intel Corporation | On chip error correction for devices in a solid state drive |
US5758118A (en) | 1995-12-08 | 1998-05-26 | International Business Machines Corporation | Methods and data storage devices for RAID expansion by on-line addition of new DASDs |
US6745292B1 (en) | 1995-12-08 | 2004-06-01 | Ncr Corporation | Apparatus and method for selectively allocating cache lines in a partitioned cache shared by multiprocessors |
US5734861A (en) * | 1995-12-12 | 1998-03-31 | International Business Machines Corporation | Log-structured disk array with garbage collection regrouping of tracks to preserve seek affinity |
US5787486A (en) | 1995-12-15 | 1998-07-28 | International Business Machines Corporation | Bus protocol for locked cycle cache hit |
US5720025A (en) * | 1996-01-18 | 1998-02-17 | Hewlett-Packard Company | Frequently-redundant array of independent disks |
JPH09198336A (ja) * | 1996-01-22 | 1997-07-31 | Nec Corp | 二次記憶装置への遠隔アクセス方法 |
US5757567A (en) | 1996-02-08 | 1998-05-26 | International Business Machines Corporation | Method and apparatus for servo control with high efficiency gray code for servo track ID |
US6385710B1 (en) | 1996-02-23 | 2002-05-07 | Sun Microsystems, Inc. | Multiple-mode external cache subsystem |
US5835964A (en) | 1996-04-29 | 1998-11-10 | Microsoft Corporation | Virtual memory system with hardware TLB and unmapped software TLB updated from mapped task address maps using unmapped kernel address map |
US5805501A (en) | 1996-05-22 | 1998-09-08 | Macronix International Co., Ltd. | Flash memory device with multiple checkpoint erase suspend logic |
US5922080A (en) | 1996-05-29 | 1999-07-13 | Compaq Computer Corporation, Inc. | Method and apparatus for performing error detection and correction with memory devices |
JP3545535B2 (ja) * | 1996-05-29 | 2004-07-21 | 株式会社アドバンテスト | 半導体メモリ試験方法および装置 |
US5778070A (en) * | 1996-06-28 | 1998-07-07 | Intel Corporation | Method and apparatus for protecting flash memory |
US6424872B1 (en) | 1996-08-23 | 2002-07-23 | Fieldbus Foundation | Block oriented control system |
US5768152A (en) * | 1996-08-28 | 1998-06-16 | International Business Machines Corp. | Performance monitoring through JTAG 1149.1 interface |
TW338165B (en) | 1996-09-09 | 1998-08-11 | Sony Co Ltd | Semiconductor nand type flash memory with incremental step pulse programming |
US5996054A (en) | 1996-09-12 | 1999-11-30 | Veritas Software Corp. | Efficient virtualized mapping space for log device data storage system |
US5832515A (en) | 1996-09-12 | 1998-11-03 | Veritas Software | Log device layered transparently within a filesystem paradigm |
JP3608694B2 (ja) * | 1996-09-18 | 2005-01-12 | 株式会社アドバンテスト | メモリ試験装置 |
US6201739B1 (en) | 1996-09-20 | 2001-03-13 | Intel Corporation | Nonvolatile writeable memory with preemption pin |
US5798968A (en) | 1996-09-24 | 1998-08-25 | Sandisk Corporation | Plane decode/virtual sector architecture |
US5960462A (en) | 1996-09-26 | 1999-09-28 | Intel Corporation | Method and apparatus for analyzing a main memory configuration to program a memory controller |
US5754567A (en) | 1996-10-15 | 1998-05-19 | Micron Quantum Devices, Inc. | Write reduction in flash memory systems through ECC usage |
TW349196B (en) * | 1996-10-18 | 1999-01-01 | Ibm | Cached synchronous DRAM architecture having a mode register programmable cache policy |
US5890192A (en) | 1996-11-05 | 1999-03-30 | Sandisk Corporation | Concurrent write of multiple chunks of data into multiple subarrays of flash EEPROM |
US5822759A (en) | 1996-11-22 | 1998-10-13 | Versant Object Technology | Cache system |
US6148377A (en) | 1996-11-22 | 2000-11-14 | Mangosoft Corporation | Shared memory computer networks |
JPH10154101A (ja) * | 1996-11-26 | 1998-06-09 | Toshiba Corp | データ記憶システム及び同システムに適用するキャッシュ制御方法 |
US5867430A (en) * | 1996-12-20 | 1999-02-02 | Advanced Micro Devices Inc | Bank architecture for a non-volatile memory enabling simultaneous reading and writing |
US6073218A (en) * | 1996-12-23 | 2000-06-06 | Lsi Logic Corp. | Methods and apparatus for coordinating shared multiple raid controller access to common storage devices |
US5933824A (en) | 1996-12-23 | 1999-08-03 | Lsi Logic Corporation | Methods and apparatus for locking files within a clustered storage environment |
US6279069B1 (en) | 1996-12-26 | 2001-08-21 | Intel Corporation | Interface for flash EEPROM memory arrays |
DE19700112C2 (de) | 1997-01-03 | 1999-03-04 | Fraunhofer Ges Forschung | Vorrichtung zur Lichtumlenkung mittels Totalreflexion |
US5802602A (en) | 1997-01-17 | 1998-09-01 | Intel Corporation | Method and apparatus for performing reads of related data from a set-associative cache memory |
US6311290B1 (en) | 1997-02-14 | 2001-10-30 | Intel Corporation | Methods of reliably allocating, de-allocating, re-allocating, and reclaiming objects in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture |
US6182188B1 (en) | 1997-04-06 | 2001-01-30 | Intel Corporation | Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture |
TW465234B (en) | 1997-02-18 | 2001-11-21 | Discovision Ass | Single chip VLSI implementation of a digital receiver employing orthogonal frequency division multiplexing |
US6073232A (en) * | 1997-02-25 | 2000-06-06 | International Business Machines Corporation | Method for minimizing a computer's initial program load time after a system reset or a power-on using non-volatile storage |
US5961660A (en) | 1997-03-03 | 1999-10-05 | International Business Machines Corporation | Method and apparatus for optimizing ECC memory performance |
US6311305B1 (en) | 1997-03-06 | 2001-10-30 | T.T.R. Technologies Ltd. | Method and system for overriding error correction |
US5953737A (en) | 1997-03-31 | 1999-09-14 | Lexar Media, Inc. | Method and apparatus for performing erase operations transparent to a solid state storage system |
US6034897A (en) | 1999-04-01 | 2000-03-07 | Lexar Media, Inc. | Space management for managing high capacity nonvolatile memory |
JPH10301719A (ja) | 1997-04-28 | 1998-11-13 | Yamaha Corp | ディスクアレイ装置及びそれを用いた情報処理システム |
JPH10320270A (ja) | 1997-05-15 | 1998-12-04 | Matsushita Electric Ind Co Ltd | メモリモジュール |
JP3459868B2 (ja) | 1997-05-16 | 2003-10-27 | 日本電気株式会社 | メモリ障害時におけるグループ入れ替え方式 |
US6038619A (en) * | 1997-05-29 | 2000-03-14 | International Business Machines Corporation | Disk drive initiated data transfers responsive to sequential or near sequential read or write requests |
US6578113B2 (en) | 1997-06-02 | 2003-06-10 | At&T Corp. | Method for cache validation for proxy caches |
US6092158A (en) | 1997-06-13 | 2000-07-18 | Intel Corporation | Method and apparatus for arbitrating between command streams |
US6047334A (en) * | 1997-06-17 | 2000-04-04 | Intel Corporation | System for delaying dequeue of commands received prior to fence command until commands received before fence command are ordered for execution in a fixed sequence |
US6311256B2 (en) * | 1997-06-30 | 2001-10-30 | Emc Corporation | Command insertion and reordering at the same storage controller |
US6044438A (en) | 1997-07-10 | 2000-03-28 | International Business Machiness Corporation | Memory controller for controlling memory accesses across networks in distributed shared memory processing systems |
US5893086A (en) | 1997-07-11 | 1999-04-06 | International Business Machines Corporation | Parallel file system and method with extensible hashing |
US6298401B1 (en) * | 1997-08-11 | 2001-10-02 | Seagate Technology Llc | Object oriented storage device having a disc drive controller providing an interface exposing methods which are invoked to access objects stored in a storage media |
US6000006A (en) | 1997-08-25 | 1999-12-07 | Bit Microsystems, Inc. | Unified re-map and cache-index table with dual write-counters for wear-leveling of non-volatile flash RAM mass storage |
US6092215A (en) | 1997-09-29 | 2000-07-18 | International Business Machines Corporation | System and method for reconstructing data in a storage array system |
US6014747A (en) | 1997-09-30 | 2000-01-11 | Intel Corporation | Method and apparatus for system's and chassis protection utilizing system management interrupts |
US6418478B1 (en) | 1997-10-30 | 2002-07-09 | Commvault Systems, Inc. | Pipelined high speed data transfer mechanism |
US6061678A (en) | 1997-10-31 | 2000-05-09 | Oracle Corporation | Approach for managing access to large objects in database systems using large object indexes |
US6205521B1 (en) | 1997-11-03 | 2001-03-20 | Compaq Computer Corporation | Inclusion map for accelerated cache flush |
US6334173B1 (en) | 1997-11-17 | 2001-12-25 | Hyundai Electronics Industries Co. Ltd. | Combined cache with main memory and a control method thereof |
US6237059B1 (en) | 1997-11-26 | 2001-05-22 | Compaq Computer Corporation | Method for estimating statistics of properties of memory system interactions among contexts in a computer system |
US6470238B1 (en) | 1997-11-26 | 2002-10-22 | Intel Corporation | Method and apparatus to control device temperature |
US6567889B1 (en) | 1997-12-19 | 2003-05-20 | Lsi Logic Corporation | Apparatus and method to provide virtual solid state disk in cache memory in a storage controller |
US6374336B1 (en) | 1997-12-24 | 2002-04-16 | Avid Technology, Inc. | Computer system and process for transferring multiple high bandwidth streams of data between multiple storage units and multiple applications in a scalable and reliable manner |
US6415373B1 (en) | 1997-12-24 | 2002-07-02 | Avid Technology, Inc. | Computer system and process for transferring multiple high bandwidth streams of data between multiple storage units and multiple applications in a scalable and reliable manner |
US6725331B1 (en) | 1998-01-07 | 2004-04-20 | Emc Corporation | Method and apparatus for managing the dynamic assignment resources in a data storage system |
US6748487B1 (en) | 1998-02-04 | 2004-06-08 | Hitachi, Ltd. | Disk cache control method, disk array system, and storage system |
US6115793A (en) | 1998-02-11 | 2000-09-05 | Ati Technologies, Inc. | Mapping logical cache indexes to physical cache indexes to reduce thrashing and increase cache size |
US6292844B1 (en) | 1998-02-12 | 2001-09-18 | Sony Corporation | Media storage device with embedded data filter for dynamically processing data during read and write operations |
US7200623B2 (en) | 1998-11-24 | 2007-04-03 | Oracle International Corp. | Methods to perform disk writes in a distributed shared disk system needing consistency across failures |
US6112319A (en) * | 1998-02-20 | 2000-08-29 | Micron Electronics, Inc. | Method and system for verifying the accuracy of stored data |
US6295581B1 (en) | 1998-02-20 | 2001-09-25 | Ati Technologies, Inc. | Method and apparatus for assuring cache coherency |
US5969986A (en) | 1998-06-23 | 1999-10-19 | Invox Technology | High-bandwidth read and write architectures for non-volatile memories |
US6170042B1 (en) | 1998-02-24 | 2001-01-02 | Seagate Technology Llc | Disc drive data storage system and method for dynamically scheduling queued commands |
US6295577B1 (en) | 1998-02-24 | 2001-09-25 | Seagate Technology Llc | Disc storage system having a non-volatile cache to store write data in the event of a power failure |
US6170063B1 (en) | 1998-03-07 | 2001-01-02 | Hewlett-Packard Company | Method for performing atomic, concurrent read and write operations on multiple storage devices |
US7188001B2 (en) * | 1998-03-23 | 2007-03-06 | Cepheid | System and method for temperature control |
US6157963A (en) * | 1998-03-24 | 2000-12-05 | Lsi Logic Corp. | System controller with plurality of memory queues for prioritized scheduling of I/O requests from priority assigned clients |
US6138125A (en) * | 1998-03-31 | 2000-10-24 | Lsi Logic Corporation | Block coding method and system for failure recovery in disk arrays |
ATE210878T1 (de) * | 1998-04-01 | 2001-12-15 | Hewlett Packard Co | Datenspeichergerät und verfahren |
US6209003B1 (en) | 1998-04-15 | 2001-03-27 | Inktomi Corporation | Garbage collection in an object cache |
US6467022B1 (en) * | 1998-04-16 | 2002-10-15 | International Business Machines Corporation | Extending adapter memory with solid state disks in JBOD and RAID environments |
US6101601A (en) * | 1998-04-20 | 2000-08-08 | International Business Machines Corporation | Method and apparatus for hibernation within a distributed data processing system |
US6219751B1 (en) * | 1998-04-28 | 2001-04-17 | International Business Machines Corporation | Device level coordination of access operations among multiple raid control units |
US5957158A (en) | 1998-05-11 | 1999-09-28 | Automatic Switch Company | Visual position indicator |
US6321263B1 (en) * | 1998-05-11 | 2001-11-20 | International Business Machines Corporation | Client-based application availability |
US6061511A (en) * | 1998-06-12 | 2000-05-09 | Ikos Systems, Inc. | Reconstruction engine for a hardware circuit emulator |
US6883063B2 (en) * | 1998-06-30 | 2005-04-19 | Emc Corporation | Method and apparatus for initializing logical objects in a data storage system |
JP2000020490A (ja) * | 1998-07-01 | 2000-01-21 | Fujitsu Ltd | 遠隔手続き呼出し機構またはオブジェクトリクエストブローカ機構を有する計算機、データ転送方法、および転送方法記憶媒体 |
US6505305B1 (en) * | 1998-07-16 | 2003-01-07 | Compaq Information Technologies Group, L.P. | Fail-over of multiple memory blocks in multiple memory modules in computer system |
US6185654B1 (en) | 1998-07-17 | 2001-02-06 | Compaq Computer Corporation | Phantom resource memory address mapping system |
GB2368415B (en) | 1998-07-21 | 2002-10-30 | Seagate Technology Llc | Improved memory system apparatus and method |
US7170906B2 (en) | 1998-07-22 | 2007-01-30 | Synchrodyne Networks, Inc. | Time-based grooming and degrooming methods with common time reference for optical networks |
US6507911B1 (en) | 1998-07-22 | 2003-01-14 | Entrust Technologies Limited | System and method for securely deleting plaintext data |
US6374266B1 (en) * | 1998-07-28 | 2002-04-16 | Ralph Shnelvar | Method and apparatus for storing information in a data processing system |
US20010042195A1 (en) | 1998-08-04 | 2001-11-15 | Ralph M. Kling | Method and apparatus for performing predicate prediction |
US6353878B1 (en) | 1998-08-13 | 2002-03-05 | Emc Corporation | Remote control of backup media in a secondary storage subsystem through access to a primary storage subsystem |
JP2000076117A (ja) * | 1998-08-31 | 2000-03-14 | Kano Densan Hongkong Yugenkoshi | 電子機器及びその制御方法及び記憶媒体 |
US6269382B1 (en) | 1998-08-31 | 2001-07-31 | Microsoft Corporation | Systems and methods for migration and recall of data from local and remote storage |
US6209088B1 (en) * | 1998-09-21 | 2001-03-27 | Microsoft Corporation | Computer hibernation implemented by a computer operating system |
KR100331542B1 (ko) * | 1998-10-09 | 2002-06-20 | 윤종용 | 불량메모리셀어레이블락들을스킵할수있는어드레스디코더를구비하는반도체메모리장치및이를사용하는복합반도체장치 |
JP2000122814A (ja) * | 1998-10-15 | 2000-04-28 | Hitachi Ltd | 拡張型ネットワーク接続二次記憶方法及び装置 |
KR100285967B1 (ko) | 1998-10-20 | 2001-04-16 | 윤덕용 | 플래쉬 메모리를 이용한 데이터 저장장치 및 방법 |
FR2785693B1 (fr) | 1998-11-06 | 2000-12-15 | Bull Sa | Dispositif et procede de cache disque securise en ecriture pour disques durs de sous-systeme a memoire de masse |
US7043568B1 (en) | 1998-11-12 | 2006-05-09 | Klingman Edwin E | Configuration selection for USB device controller |
US6279041B1 (en) | 1998-11-13 | 2001-08-21 | International Business Machines Corporation | Methods, systems and computer program products for differencing data communications using a message queue |
US6034882A (en) * | 1998-11-16 | 2000-03-07 | Matrix Semiconductor, Inc. | Vertically stacked field programmable nonvolatile memory and method of fabrication |
WO2000033192A1 (en) | 1998-11-25 | 2000-06-08 | Sun Microsystems, Inc. | A method for enabling comprehensive profiling of garbage-collected memory systems |
US6470436B1 (en) | 1998-12-01 | 2002-10-22 | Fast-Chip, Inc. | Eliminating memory fragmentation and garbage collection from the process of managing dynamically allocated memory |
US7233977B2 (en) | 1998-12-18 | 2007-06-19 | Emc Corporation | Messaging mechanism employing mailboxes for inter processor communications |
US6189078B1 (en) | 1998-12-22 | 2001-02-13 | Unisys Corporation | System and method for increasing data transfer throughput for cache purge transactions using multiple data response indicators to maintain processor consistency |
US6629112B1 (en) * | 1998-12-31 | 2003-09-30 | Nortel Networks Limited | Resource management for CORBA-based applications |
US6601151B1 (en) * | 1999-02-08 | 2003-07-29 | Sun Microsystems, Inc. | Apparatus and method for handling memory access requests in a data processing system |
US6618451B1 (en) | 1999-02-13 | 2003-09-09 | Altocom Inc | Efficient reduced state maximum likelihood sequence estimator |
GB9903490D0 (en) | 1999-02-17 | 1999-04-07 | Memory Corp Plc | Memory system |
US6795890B1 (en) | 1999-02-19 | 2004-09-21 | Mitsubishi Denki Kabushiki Kaisha | Data storage method, and data processing device using an erasure block buffer and write buffer for writing and erasing data in memory |
US6571312B1 (en) | 1999-02-19 | 2003-05-27 | Mitsubishi Denki Kabushiki Kaisha | Data storage method and data processing device using an erasure block buffer and write buffer for writing and erasing data in memory |
US6347341B1 (en) * | 1999-02-22 | 2002-02-12 | International Business Machines Corporation | Computer program product used for exchange and transfer of data having a siga vector and utilizing a queued direct input-output device |
US6412080B1 (en) * | 1999-02-23 | 2002-06-25 | Microsoft Corporation | Lightweight persistent storage system for flash memory devices |
US6321345B1 (en) * | 1999-03-01 | 2001-11-20 | Seachange Systems, Inc. | Slow response in redundant arrays of inexpensive disks |
MY122279A (en) * | 1999-03-03 | 2006-04-29 | Sony Corp | Nonvolatile memory and nonvolatile memory reproducing apparatus |
JP2000259525A (ja) | 1999-03-10 | 2000-09-22 | Nec Corp | 通信プロトコルにおける応答返却方法および通信制御装置 |
US6295571B1 (en) | 1999-03-19 | 2001-09-25 | Times N Systems, Inc. | Shared memory apparatus and method for multiprocessor systems |
US6535869B1 (en) | 1999-03-23 | 2003-03-18 | International Business Machines Corporation | Increasing efficiency of indexing random-access files composed of fixed-length data blocks by embedding a file index therein |
EP1228510B1 (en) * | 1999-04-01 | 2006-09-20 | Lexar Media, Inc. | Space management for managing high capacity nonvolatile memory |
US6141249A (en) | 1999-04-01 | 2000-10-31 | Lexar Media, Inc. | Organization of blocks within a nonvolatile memory unit to effectively decrease sector write operation time |
US6412030B1 (en) | 1999-04-16 | 2002-06-25 | Koninklijke Philips Electronics N.V. | System and method to optimize read performance while accepting write data in a PCI bus architecture |
US6535949B1 (en) | 1999-04-19 | 2003-03-18 | Research In Motion Limited | Portable electronic device having a log-structured file system in flash memory |
US6105076A (en) | 1999-04-23 | 2000-08-15 | International Business Machines Corporation | Method, system, and program for performing data transfer operations on user data |
KR100330164B1 (ko) | 1999-04-27 | 2002-03-28 | 윤종용 | 무효 블록들을 가지는 복수의 플래시 메모리들을 동시에 프로그램하는 방법 |
US6341289B1 (en) * | 1999-05-06 | 2002-01-22 | International Business Machines Corporation | Object identity and partitioning for user defined extents |
US6849480B1 (en) | 1999-05-07 | 2005-02-01 | Seagate Technology Llc | Surface mount IC stacking method and device |
US6535997B1 (en) | 1999-05-19 | 2003-03-18 | International Business Machines Corporation | Data integrity in smartcard transactions |
US7194740B1 (en) | 1999-05-28 | 2007-03-20 | Oracle International Corporation | System for extending an addressable range of memory |
JP4106811B2 (ja) | 1999-06-10 | 2008-06-25 | 富士通株式会社 | 半導体記憶装置及び電子装置 |
TW443083B (en) | 1999-06-23 | 2001-06-23 | Asustek Comp Inc | Printed circuit board structure |
US6557084B2 (en) | 1999-07-13 | 2003-04-29 | International Business Machines Corporation | Apparatus and method to improve performance of reads from and writes to shared memory locations |
US6513112B1 (en) | 1999-07-26 | 2003-01-28 | Microsoft Corporation | System and apparatus for administration of configuration information using a catalog server object to describe and manage requested configuration information to be stored in a table object |
US20040230710A1 (en) | 1999-07-27 | 2004-11-18 | Inline Connection Corporation | System and method of automatic installation of computer peripherals |
JP2001043031A (ja) * | 1999-07-30 | 2001-02-16 | Toshiba Corp | 分散パリティ生成機能を備えたディスクアレイ制御装置 |
EP1073064A1 (en) * | 1999-07-30 | 2001-01-31 | STMicroelectronics S.r.l. | Non-volatile memory with the functional capability of simultaneous modification of the contents and burst mode read or page mode read |
US8078794B2 (en) | 2000-01-06 | 2011-12-13 | Super Talent Electronics, Inc. | Hybrid SSD using a combination of SLC and MLC flash memory arrays |
US7934074B2 (en) | 1999-08-04 | 2011-04-26 | Super Talent Electronics | Flash module with plane-interleaved sequential writes to restricted-write flash chips |
US7660941B2 (en) | 2003-09-10 | 2010-02-09 | Super Talent Electronics, Inc. | Two-level RAM lookup table for block and page allocation and wear-leveling in limited-write flash-memories |
US7889544B2 (en) * | 2004-04-05 | 2011-02-15 | Super Talent Electronics, Inc. | High-speed controller for phase-change memory peripheral device |
US7620769B2 (en) | 2000-01-06 | 2009-11-17 | Super Talent Electronics, Inc. | Recycling partially-stale flash blocks using a sliding window for multi-level-cell (MLC) flash memory |
US7457897B1 (en) * | 2004-03-17 | 2008-11-25 | Suoer Talent Electronics, Inc. | PCI express-compatible controller and interface for flash memory |
US6336174B1 (en) * | 1999-08-09 | 2002-01-01 | Maxtor Corporation | Hardware assisted memory backup system and method |
KR100577380B1 (ko) * | 1999-09-29 | 2006-05-09 | 삼성전자주식회사 | 플래시 메모리와 그 제어 방법 |
JP3756708B2 (ja) * | 1999-09-30 | 2006-03-15 | 株式会社東芝 | 情報処理端末装置およびそのファイル管理方法 |
US6779145B1 (en) * | 1999-10-01 | 2004-08-17 | Stmicroelectronics Limited | System and method for communicating with an integrated circuit |
US6401175B1 (en) * | 1999-10-01 | 2002-06-04 | Sun Microsystems, Inc. | Shared write buffer for use by multiple processor units |
US6742078B1 (en) | 1999-10-05 | 2004-05-25 | Feiya Technology Corp. | Management, data link structure and calculating method for flash memory |
EP1100001B1 (en) | 1999-10-25 | 2003-08-13 | Sun Microsystems, Inc. | Storage system supporting file-level and block-level accesses |
WO2001031512A2 (en) | 1999-10-25 | 2001-05-03 | Infolibria, Inc. | Fast indexing of web objects |
US6496366B1 (en) | 1999-10-26 | 2002-12-17 | Rackable Systems, Llc | High density computer equipment storage system |
US6850408B1 (en) | 1999-10-26 | 2005-02-01 | Rackable Systems, Inc. | High density computer equipment storage systems |
US6278633B1 (en) | 1999-11-05 | 2001-08-21 | Multi Level Memory Technology | High bandwidth flash memory that selects programming parameters according to measurements of previous programming operations |
US6684274B1 (en) * | 1999-11-09 | 2004-01-27 | Sun Microsystems, Inc. | Host bus adapter based scalable performance storage architecture |
US20020049883A1 (en) | 1999-11-29 | 2002-04-25 | Eric Schneider | System and method for restoring a computer system after a failure |
US6405201B1 (en) * | 1999-12-02 | 2002-06-11 | Sun Microsystems, Inc. | Method and apparatus for reducing network traffic for remote file append operations |
DE19961499A1 (de) | 1999-12-20 | 2001-07-05 | Ericsson Telefon Ab L M | Caching von Objekten in Platten-gestützten Datenbanken |
US7024695B1 (en) | 1999-12-30 | 2006-04-04 | Intel Corporation | Method and apparatus for secure remote system management |
US20060161725A1 (en) | 2005-01-20 | 2006-07-20 | Lee Charles C | Multiple function flash memory system |
US8266367B2 (en) | 2003-12-02 | 2012-09-11 | Super Talent Electronics, Inc. | Multi-level striping and truncation channel-equalization for flash-memory system |
US8171204B2 (en) | 2000-01-06 | 2012-05-01 | Super Talent Electronics, Inc. | Intelligent solid-state non-volatile memory device (NVMD) system with multi-level caching of multiple channels |
US20080320209A1 (en) | 2000-01-06 | 2008-12-25 | Super Talent Electronics, Inc. | High Performance and Endurance Non-volatile Memory Based Storage Systems |
US20080195798A1 (en) | 2000-01-06 | 2008-08-14 | Super Talent Electronics, Inc. | Non-Volatile Memory Based Computer Systems and Methods Thereof |
US20050204187A1 (en) | 2004-03-11 | 2005-09-15 | Lee Charles C. | System and method for managing blocks in flash memory |
US8452912B2 (en) | 2007-10-11 | 2013-05-28 | Super Talent Electronics, Inc. | Flash-memory system with enhanced smart-storage switch and packed meta-data cache for mitigating write amplification by delaying and merging writes until a host read |
US6779080B2 (en) * | 2000-01-11 | 2004-08-17 | International Business Machines Corporation | Serial data storage system with automatically adjusted data protection to implement worm media with limited overwrite allowing write appending |
TW504694B (en) * | 2000-01-12 | 2002-10-01 | Hitachi Ltd | Non-volatile semiconductor memory device and semiconductor disk device |
US6785835B2 (en) | 2000-01-25 | 2004-08-31 | Hewlett-Packard Development Company, L.P. | Raid memory |
US6671757B1 (en) | 2000-01-26 | 2003-12-30 | Fusionone, Inc. | Data transfer and synchronization system |
US6757291B1 (en) * | 2000-02-10 | 2004-06-29 | Simpletech, Inc. | System for bypassing a server to achieve higher throughput between data network and data storage system |
USD475705S1 (en) | 2000-02-18 | 2003-06-10 | Rackable Systems, Inc. | Computer chassis for dual, opposing main boards |
EP1130516A1 (en) | 2000-03-01 | 2001-09-05 | Hewlett-Packard Company, A Delaware Corporation | Address mapping in solid state storage device |
JP2001250044A (ja) * | 2000-03-07 | 2001-09-14 | Nec Corp | 電子商取引システム、電子商取引方法、及び電子商取引プログラムを記録する記録媒体 |
US6609212B1 (en) | 2000-03-09 | 2003-08-19 | International Business Machines Corporation | Apparatus and method for sharing predictive failure information on a computer network |
US6240040B1 (en) * | 2000-03-15 | 2001-05-29 | Advanced Micro Devices, Inc. | Multiple bank simultaneous operation for a flash memory |
US6823398B1 (en) * | 2000-03-31 | 2004-11-23 | Dphi Acquisitions, Inc. | File system management embedded in a storage device |
US6587937B1 (en) | 2000-03-31 | 2003-07-01 | Rockwell Collins, Inc. | Multiple virtual machine system with efficient cache memory design |
US6523102B1 (en) | 2000-04-14 | 2003-02-18 | Interactive Silicon, Inc. | Parallel compression/decompression system and method for implementation of in-memory compressed cache improving storage density and access speed for industry standard memory subsystems and in-line memory modules |
US7089391B2 (en) | 2000-04-14 | 2006-08-08 | Quickshift, Inc. | Managing a codec engine for memory compression/decompression operations using a data movement engine |
JP2001297316A (ja) | 2000-04-14 | 2001-10-26 | Mitsubishi Electric Corp | メモリカード及びその制御方法 |
US6643748B1 (en) * | 2000-04-20 | 2003-11-04 | Microsoft Corporation | Programmatic masking of storage units |
US6487636B1 (en) * | 2000-04-24 | 2002-11-26 | Hewlett-Packard Co. | Method and apparatus for mapping data in a heterogeneous disk array storage system |
US6420215B1 (en) * | 2000-04-28 | 2002-07-16 | Matrix Semiconductor, Inc. | Three-dimensional memory array and method of fabrication |
US6697797B1 (en) | 2000-04-28 | 2004-02-24 | Micro Data Base Systems, Inc. | Method and apparatus for tracking data in a database, employing last-known location registers |
JP4601119B2 (ja) * | 2000-05-02 | 2010-12-22 | 株式会社アドバンテスト | メモリ試験方法・メモリ試験装置 |
KR100399034B1 (ko) | 2000-05-02 | 2003-09-22 | 한국과학기술원 | 효율적 메모리 셀 어레이 관리 방법 |
US6675349B1 (en) | 2000-05-11 | 2004-01-06 | International Business Machines Corporation | Error correction coding of data blocks with included parity bits |
US7269631B2 (en) | 2000-06-02 | 2007-09-11 | Hewlett-Packard Development Company, L.P. | Architecture for parallel distributed table driven I/O mapping |
US6865657B1 (en) | 2000-06-02 | 2005-03-08 | Sun Microsystems, Inc. | Garbage collector for a virtual heap |
US6763440B1 (en) | 2000-06-02 | 2004-07-13 | Sun Microsystems, Inc. | Garbage collection using nursery regions for new objects in a virtual heap |
US6751769B2 (en) | 2000-06-06 | 2004-06-15 | International Business Machines Corporation | (146,130) error correction code utilizing address information |
US6532527B2 (en) | 2000-06-19 | 2003-03-11 | Storage Technology Corporation | Using current recovery mechanisms to implement dynamic mapping operations |
US6779094B2 (en) * | 2000-06-19 | 2004-08-17 | Storage Technology Corporation | Apparatus and method for instant copy of data by writing new data to an additional physical storage area |
US6804755B2 (en) | 2000-06-19 | 2004-10-12 | Storage Technology Corporation | Apparatus and method for performing an instant copy of data based on a dynamically changeable virtual mapping scheme |
US6912537B2 (en) | 2000-06-20 | 2005-06-28 | Storage Technology Corporation | Dynamically changeable virtual mapping scheme |
JP3951918B2 (ja) * | 2000-06-23 | 2007-08-01 | インテル・コーポレーション | 不揮発性キャッシュ |
US6813686B1 (en) | 2000-06-27 | 2004-11-02 | Emc Corporation | Method and apparatus for identifying logical volumes in multiple element computer storage domains |
US6859824B1 (en) | 2000-06-30 | 2005-02-22 | Hitachi, Ltd. | Storage system connected to a data network with data integrity |
US6525926B1 (en) | 2000-07-11 | 2003-02-25 | Racklogic Technologies, Inc. | Multinode high density computing apparatus |
US6981070B1 (en) | 2000-07-12 | 2005-12-27 | Shun Hang Luk | Network storage device having solid-state non-volatile memory |
US7167944B1 (en) | 2000-07-21 | 2007-01-23 | Lexar Media, Inc. | Block management for mass storage |
US6567307B1 (en) | 2000-07-21 | 2003-05-20 | Lexar Media, Inc. | Block management for mass storage |
US6675318B1 (en) | 2000-07-25 | 2004-01-06 | Sun Microsystems, Inc. | Two-dimensional storage array with prompt parity in one dimension and delayed parity in a second dimension |
US6892298B2 (en) | 2000-07-26 | 2005-05-10 | Times N Systems, Inc. | Load/store micropacket handling system |
US6883044B1 (en) | 2000-07-28 | 2005-04-19 | Micron Technology, Inc. | Synchronous flash memory with simultaneous access to one or more banks |
US7085445B2 (en) | 2000-08-04 | 2006-08-01 | Seungug Koh | Micro-opto-electro-mechanical waveguide switches |
JP2002056671A (ja) * | 2000-08-14 | 2002-02-22 | Hitachi Ltd | ダイナミック型ramのデータ保持方法と半導体集積回路装置 |
JP4397109B2 (ja) * | 2000-08-14 | 2010-01-13 | 富士通株式会社 | 情報処理装置及びクロスバーボードユニット・バックパネル組立体の製造方法 |
KR100819730B1 (ko) | 2000-08-14 | 2008-04-07 | 샌디스크 쓰리디 엘엘씨 | 밀집한 어레이 및 전하 저장 장치와, 그 제조 방법 |
US6658438B1 (en) * | 2000-08-14 | 2003-12-02 | Matrix Semiconductor, Inc. | Method for deleting stored digital data from write-once memory device |
JP3671138B2 (ja) | 2000-08-17 | 2005-07-13 | ジャパンコンポジット株式会社 | 通気性防水被覆構造体、およびその施工方法 |
US6636879B1 (en) | 2000-08-18 | 2003-10-21 | Network Appliance, Inc. | Space allocation in a write anywhere file system |
US6404647B1 (en) | 2000-08-24 | 2002-06-11 | Hewlett-Packard Co. | Solid-state mass memory storage device |
US7155559B1 (en) | 2000-08-25 | 2006-12-26 | Lexar Media, Inc. | Flash memory architecture with separate storage of overhead and user data |
US6728866B1 (en) | 2000-08-31 | 2004-04-27 | International Business Machines Corporation | Partitioned issue queue and allocation strategy |
US6883079B1 (en) | 2000-09-01 | 2005-04-19 | Maxtor Corporation | Method and apparatus for using data compression as a means of increasing buffer bandwidth |
US20020057798A1 (en) | 2000-09-11 | 2002-05-16 | Zhang Jinglong F. | Method and apparatus employing one-way transforms |
US20040236798A1 (en) | 2001-09-11 | 2004-11-25 | Sudhir Srinivasan | Migration of control in a distributed segmented file system |
US6625685B1 (en) | 2000-09-20 | 2003-09-23 | Broadcom Corporation | Memory controller with programmable configuration |
US6725342B1 (en) | 2000-09-26 | 2004-04-20 | Intel Corporation | Non-volatile mass storage cache coherency apparatus |
JP3922516B2 (ja) | 2000-09-28 | 2007-05-30 | 株式会社ルネサステクノロジ | 不揮発性メモリと不揮発性メモリの書き込み方法 |
US6745284B1 (en) * | 2000-10-02 | 2004-06-01 | Sun Microsystems, Inc. | Data storage subsystem including a storage disk array employing dynamic data striping |
JP4413406B2 (ja) | 2000-10-03 | 2010-02-10 | 株式会社東芝 | 不揮発性半導体メモリ及びそのテスト方法 |
US7039727B2 (en) * | 2000-10-17 | 2006-05-02 | Microsoft Corporation | System and method for controlling mass storage class digital imaging devices |
DE60041263D1 (de) * | 2000-10-18 | 2009-02-12 | St Microelectronics Srl | Verschachtelte Speichereinrichtung mit willkürlichem und sequentiellem Zugriff |
US6594712B1 (en) * | 2000-10-20 | 2003-07-15 | Banderacom, Inc. | Inifiniband channel adapter for performing direct DMA between PCI bus and inifiniband link |
US20030021417A1 (en) * | 2000-10-20 | 2003-01-30 | Ognjen Vasic | Hidden link dynamic key manager for use in computer systems with database structure for storage of encrypted data and method for storage and retrieval of encrypted data |
US6779088B1 (en) | 2000-10-24 | 2004-08-17 | International Business Machines Corporation | Virtual uncompressed cache size control in compressed memory systems |
US7185162B1 (en) | 2000-10-26 | 2007-02-27 | Cypress Semiconductor Corporation | Method and apparatus for programming a flash memory |
US7248691B1 (en) | 2000-10-31 | 2007-07-24 | Microsoft Corporation | Hashing using multiple sub-hashes |
US6694453B1 (en) | 2000-11-14 | 2004-02-17 | Hewlett-Packard Development Company, L.P. | Apparatus and method to handle power supply failures for a peripheral device |
US6549987B1 (en) | 2000-11-16 | 2003-04-15 | Intel Corporation | Cache structure for storing variable length data |
US7113507B2 (en) * | 2000-11-22 | 2006-09-26 | Silicon Image | Method and system for communicating control information via out-of-band symbols |
US6564288B2 (en) | 2000-11-30 | 2003-05-13 | Hewlett-Packard Company | Memory controller with temperature sensors |
JP4216457B2 (ja) | 2000-11-30 | 2009-01-28 | 富士通マイクロエレクトロニクス株式会社 | 半導体記憶装置及び半導体装置 |
US6754785B2 (en) | 2000-12-01 | 2004-06-22 | Yan Chiew Chow | Switched multi-channel network interfaces and real-time streaming backup |
US6976060B2 (en) | 2000-12-05 | 2005-12-13 | Agami Sytems, Inc. | Symmetric shared file storage system |
US7020739B2 (en) | 2000-12-06 | 2006-03-28 | Tdk Corporation | Memory controller, flash memory system having memory controller and method for controlling flash memory device |
JP2002184190A (ja) | 2000-12-11 | 2002-06-28 | Toshiba Corp | 不揮発性半導体記憶装置 |
US20020103819A1 (en) * | 2000-12-12 | 2002-08-01 | Fresher Information Corporation | Technique for stabilizing data in a non-log based information storage and retrieval system |
US20020108016A1 (en) * | 2000-12-13 | 2002-08-08 | Seagate Technology Llc | System for characterizing performance of data handling systems under particular stimuli |
US6938252B2 (en) | 2000-12-14 | 2005-08-30 | International Business Machines Corporation | Hardware-assisted method for scheduling threads using data cache locality |
US7013376B2 (en) | 2000-12-20 | 2006-03-14 | Hewlett-Packard Development Company, L.P. | Method and system for data block sparing in a solid-state storage device |
SE0004736D0 (sv) * | 2000-12-20 | 2000-12-20 | Ericsson Telefon Ab L M | Mapping system and method |
US7107480B1 (en) | 2000-12-22 | 2006-09-12 | Simpletech, Inc. | System and method for preventing data corruption in solid-state memory devices after a power failure |
US6611836B2 (en) | 2000-12-26 | 2003-08-26 | Simdesk Technologies, Inc. | Server-side recycle bin system |
KR100365725B1 (ko) | 2000-12-27 | 2002-12-26 | 한국전자통신연구원 | 플래시 메모리를 이용한 파일 시스템에서 등급별 지움정책 및 오류 복구 방법 |
EP1220228B1 (en) | 2000-12-29 | 2008-12-24 | STMicroelectronics S.r.l. | Method for storing data in a nonvolatile memory |
KR100708475B1 (ko) | 2001-01-08 | 2007-04-18 | 삼성전자주식회사 | 펑쳐링된 패리티심벌을 복원하는 터보디코더용 프리디코더 및 터보코드의 복원방법 |
US6553472B2 (en) | 2001-01-12 | 2003-04-22 | Sun Microsystems, Inc. | Method for programming clock delays, command delays, read command parameter delays, and write command parameter delays of a memory controller in a high performance microprocessor |
US6763424B2 (en) | 2001-01-19 | 2004-07-13 | Sandisk Corporation | Partial block data programming and reading operations in a non-volatile memory |
JP4818812B2 (ja) | 2006-05-31 | 2011-11-16 | 株式会社日立製作所 | フラッシュメモリストレージシステム |
GB2383853A (en) * | 2001-01-26 | 2003-07-09 | Xmg Ltd | A method system and apparatus for networking devices over an asynchronous network such as the internet |
US6990547B2 (en) * | 2001-01-29 | 2006-01-24 | Adaptec, Inc. | Replacing file system processors by hot swapping |
US20020161846A1 (en) * | 2001-01-29 | 2002-10-31 | Ulrich Thomas R. | Data path controller architecture |
US6862692B2 (en) * | 2001-01-29 | 2005-03-01 | Adaptec, Inc. | Dynamic redistribution of parity groups |
US6516380B2 (en) | 2001-02-05 | 2003-02-04 | International Business Machines Corporation | System and method for a log-based non-volatile write cache in a storage controller |
US6606690B2 (en) | 2001-02-20 | 2003-08-12 | Hewlett-Packard Development Company, L.P. | System and method for accessing a storage area network as network attached storage |
US20040233910A1 (en) | 2001-02-23 | 2004-11-25 | Wen-Shyen Chen | Storage area network using a data communication protocol |
US6862609B2 (en) * | 2001-03-07 | 2005-03-01 | Canopy Group, Inc. | Redundant storage for multiple processors in a ring network |
US6802023B2 (en) * | 2001-03-15 | 2004-10-05 | Hewlett-Packard Development Company, L.P. | Redundant controller data storage system having hot insertion system and method |
US6779045B2 (en) * | 2001-03-21 | 2004-08-17 | Intel Corporation | System and apparatus for increasing the number of operations per transmission for a media management system |
US6965638B2 (en) | 2001-04-17 | 2005-11-15 | Texas Instruments Incorporated | Increasing performance in modems in presence of noise |
US7260820B1 (en) | 2001-04-26 | 2007-08-21 | Vm Ware, Inc. | Undefeatable transformation for virtual machine I/O operations |
US6742081B2 (en) * | 2001-04-30 | 2004-05-25 | Sun Microsystems, Inc. | Data storage array employing block checksums and dynamic striping |
EP1391040A2 (en) | 2001-05-08 | 2004-02-25 | International Business Machines Corporation | 8b/10b encoding and decoding for high speed applications |
CA2475472C (en) * | 2001-05-22 | 2017-07-04 | Imagine Broadband Limited | Simulating user activity in a broaband network |
US6824393B2 (en) * | 2001-05-29 | 2004-11-30 | International Business Machines Corporation | Fragmented backplane system for I/O applications |
US7062644B2 (en) * | 2001-05-30 | 2006-06-13 | International Business Machines Corporation | Method, system, and program for initializing a storage device comprising multiple storage units through a storage controller |
US6684301B1 (en) | 2001-05-31 | 2004-01-27 | Lsi Logic Corporation | Out of order execution memory access request FIFO |
US6731447B2 (en) | 2001-06-04 | 2004-05-04 | Xerox Corporation | Secure data file erasure |
US6876656B2 (en) | 2001-06-15 | 2005-04-05 | Broadcom Corporation | Switch assisted frame aliasing for storage virtualization |
JP3976227B2 (ja) * | 2001-06-18 | 2007-09-12 | 日立ソフトウエアエンジニアリング株式会社 | 端末のデータ消去管理方法及びプログラム。 |
US7107430B2 (en) | 2001-06-19 | 2006-09-12 | Massachusetts Institute Of Technology | Mechanism to reduce the cost of forwarding pointer aliasing |
JP4256600B2 (ja) * | 2001-06-19 | 2009-04-22 | Tdk株式会社 | メモリコントローラ、メモリコントローラを備えるフラッシュメモリシステム及びフラッシュメモリの制御方法 |
JP2003006041A (ja) | 2001-06-20 | 2003-01-10 | Hitachi Ltd | 半導体装置 |
US6839808B2 (en) | 2001-07-06 | 2005-01-04 | Juniper Networks, Inc. | Processing cluster having multiple compute engines and shared tier one caches |
US7076510B2 (en) * | 2001-07-12 | 2006-07-11 | Brown William P | Software raid methods and apparatuses including server usage based write delegation |
US6694281B2 (en) * | 2001-07-12 | 2004-02-17 | Seagate Technology Llc | Real time signal analysis of a remote block data storage device |
US6950966B2 (en) | 2001-07-17 | 2005-09-27 | Seachange International, Inc. | Data transmission from raid services |
US7036068B2 (en) | 2001-07-25 | 2006-04-25 | Hewlett-Packard Development Company, L.P. | Error correction coding and decoding in a solid-state storage device |
US6785776B2 (en) | 2001-07-26 | 2004-08-31 | International Business Machines Corporation | DMA exclusive cache state providing a fully pipelined input/output DMA write mechanism |
US6556440B2 (en) | 2001-07-26 | 2003-04-29 | Dell Products L.P. | Dishrack shroud for shielding and cooling |
JP4156817B2 (ja) * | 2001-07-27 | 2008-09-24 | 株式会社日立製作所 | 記憶装置システム |
US6996668B2 (en) | 2001-08-06 | 2006-02-07 | Seagate Technology Llc | Synchronized mirrored data in a data storage device |
US7245632B2 (en) * | 2001-08-10 | 2007-07-17 | Sun Microsystems, Inc. | External storage for modular computer systems |
US6525953B1 (en) * | 2001-08-13 | 2003-02-25 | Matrix Semiconductor, Inc. | Vertically-stacked, field-programmable, nonvolatile memory and method of fabrication |
US7165005B2 (en) * | 2001-08-14 | 2007-01-16 | National Instruments Corporation | Measurement module interface protocol database and registration system |
US7013232B2 (en) * | 2001-08-15 | 2006-03-14 | National Insurance Corporation | Network-based system for configuring a measurement system using configuration information generated based on a user specification |
JP4583755B2 (ja) | 2001-08-30 | 2010-11-17 | 富士通株式会社 | プリント板ユニット及び電子機器 |
US7275135B2 (en) | 2001-08-31 | 2007-09-25 | Intel Corporation | Hardware updated metadata for non-volatile mass storage cache |
US6735546B2 (en) | 2001-08-31 | 2004-05-11 | Matrix Semiconductor, Inc. | Memory device and method for temperature-based control over write and/or read operations |
US6760805B2 (en) | 2001-09-05 | 2004-07-06 | M-Systems Flash Disk Pioneers Ltd. | Flash management system for large page size |
US7177197B2 (en) | 2001-09-17 | 2007-02-13 | Sandisk Corporation | Latched programming of memory and method |
US6845465B2 (en) * | 2001-09-17 | 2005-01-18 | Sun Microsystems, Inc. | Method and system for leveraging spares in a data storage system including a plurality of disk drives |
KR100437610B1 (ko) | 2001-09-20 | 2004-06-30 | 주식회사 하이닉스반도체 | 정상 모드와 부분 어레이 셀프 리프레쉬 모드를 갖는저전력 반도체 메모리 장치 |
US20030061296A1 (en) | 2001-09-24 | 2003-03-27 | International Business Machines Corporation | Memory semantic storage I/O |
US20030058681A1 (en) | 2001-09-27 | 2003-03-27 | Intel Corporation | Mechanism for efficient wearout counters in destructive readout memory |
US6938133B2 (en) | 2001-09-28 | 2005-08-30 | Hewlett-Packard Development Company, L.P. | Memory latency and bandwidth optimizations |
GB0123416D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Non-volatile memory control |
GB0123415D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Method of writing data to non-volatile memory |
US6823417B2 (en) * | 2001-10-01 | 2004-11-23 | Hewlett-Packard Development Company, L.P. | Memory controller for memory card manages file allocation table |
US6892264B2 (en) | 2001-10-05 | 2005-05-10 | International Business Machines Corporation | Storage area network methods and apparatus for associating a logical identification with a physical identification |
US6515909B1 (en) | 2001-10-05 | 2003-02-04 | Micron Technology Inc. | Flash memory device with a variable erase pulse |
US7000063B2 (en) | 2001-10-05 | 2006-02-14 | Matrix Semiconductor, Inc. | Write-many memory device and method for limiting a number of writes to the write-many memory device |
US6643181B2 (en) | 2001-10-24 | 2003-11-04 | Saifun Semiconductors Ltd. | Method for erasing a memory cell |
US6552955B1 (en) | 2001-10-30 | 2003-04-22 | Mitsubishi Denki Kabushiki Kaisha | Semiconductor memory device with reduced power consumption |
US6710901B2 (en) | 2001-11-02 | 2004-03-23 | Canadian Production Promotion Group Inc. | Method and apparatus for two-photon, volumetric spatially resolved holographic data storage in photosensitive glass |
US6754800B2 (en) * | 2001-11-14 | 2004-06-22 | Sun Microsystems, Inc. | Methods and apparatus for implementing host-based object storage schemes |
US20030093741A1 (en) | 2001-11-14 | 2003-05-15 | Cenk Argon | Parallel decoder for product codes |
US6977847B2 (en) | 2001-11-23 | 2005-12-20 | M-Systems Flash Disk Pioneers Ltd. | Detecting partially erased units in flash devices |
US7136436B2 (en) | 2001-11-28 | 2006-11-14 | Texas Instruments Incorporated | Boundary detection using multiple correlations |
US6715046B1 (en) * | 2001-11-29 | 2004-03-30 | Cisco Technology, Inc. | Method and apparatus for reading from and writing to storage using acknowledged phases of sets of data |
US7013379B1 (en) | 2001-12-10 | 2006-03-14 | Incipient, Inc. | I/O primitives |
US7173929B1 (en) | 2001-12-10 | 2007-02-06 | Incipient, Inc. | Fast path for performing data operations |
US6883068B2 (en) * | 2001-12-17 | 2005-04-19 | Sun Microsystems, Inc. | Methods and apparatus for implementing a chche replacement scheme |
US7548975B2 (en) | 2002-01-09 | 2009-06-16 | Cisco Technology, Inc. | Methods and apparatus for implementing virtualization of storage within a storage area network through a virtual enclosure |
US7036043B2 (en) | 2001-12-28 | 2006-04-25 | Storage Technology Corporation | Data management with virtual recovery mapping and backward moves |
US6839819B2 (en) | 2001-12-28 | 2005-01-04 | Storage Technology Corporation | Data management appliance |
US6697076B1 (en) | 2001-12-31 | 2004-02-24 | Apple Computer, Inc. | Method and apparatus for address re-mapping |
US6925573B2 (en) | 2002-01-02 | 2005-08-02 | Intel Corporation | Method and apparatus to manage use of system power within a given specification |
US6785078B2 (en) * | 2002-01-04 | 2004-08-31 | International Business Machines Corporation | Concurrent read and write access to simulated sequential data of a removable random access data storage medium |
WO2003060722A1 (fr) | 2002-01-09 | 2003-07-24 | Renesas Technology Corp. | Système de mémoire et carte mémoire |
US7069349B2 (en) | 2002-01-10 | 2006-06-27 | Intel Corporation | IPMI dual-domain controller |
US20030130969A1 (en) | 2002-01-10 | 2003-07-10 | Intel Corporation | Star intelligent platform management bus topology |
TWI257085B (en) | 2002-01-21 | 2006-06-21 | Koninkl Philips Electronics Nv | Method of encoding and decoding |
JP4154893B2 (ja) | 2002-01-23 | 2008-09-24 | 株式会社日立製作所 | ネットワークストレージ仮想化方法 |
US20030145230A1 (en) * | 2002-01-31 | 2003-07-31 | Huimin Chiu | System for exchanging data utilizing remote direct memory access |
US6839826B2 (en) | 2002-02-06 | 2005-01-04 | Sandisk Corporation | Memory device with pointer structure to map logical to physical addresses |
US6724640B1 (en) | 2002-02-15 | 2004-04-20 | Steve Cooper | Blade armor shielding |
US6748504B2 (en) | 2002-02-15 | 2004-06-08 | International Business Machines Corporation | Deferred copy-on-write of a snapshot |
US6871257B2 (en) | 2002-02-22 | 2005-03-22 | Sandisk Corporation | Pipelined parallel programming operation in a non-volatile memory system |
US7085879B2 (en) | 2002-02-27 | 2006-08-01 | Microsoft Corporation | Dynamic data structures for tracking data stored in a flash memory device |
US6901499B2 (en) | 2002-02-27 | 2005-05-31 | Microsoft Corp. | System and method for tracking data stored in a flash memory device |
US7533214B2 (en) | 2002-02-27 | 2009-05-12 | Microsoft Corporation | Open architecture flash driver |
US7010662B2 (en) | 2002-02-27 | 2006-03-07 | Microsoft Corporation | Dynamic data structures for tracking file system free space in a flash memory device |
US20030163633A1 (en) | 2002-02-27 | 2003-08-28 | Aasheim Jered Donald | System and method for achieving uniform wear levels in a flash memory device |
US7197567B1 (en) | 2002-02-28 | 2007-03-27 | Cisco Technology, Inc. | Devices, softwares and methods for enabling SIP devices to operate in H.323 networks and H.323 devices to operate in sip networks |
JP3722767B2 (ja) * | 2002-03-13 | 2005-11-30 | 三菱電機インフォメーションテクノロジー株式会社 | ハードディスク装置、コンピュータ |
JP2003281071A (ja) | 2002-03-20 | 2003-10-03 | Seiko Epson Corp | データ転送制御装置、電子機器及びデータ転送制御方法 |
US7010663B2 (en) | 2002-03-22 | 2006-03-07 | Sun Microsystems, Inc. | Method and system for dividing a plurality of existing volumes of storage into a plurality of virtual logical units of storage |
US6850969B2 (en) * | 2002-03-27 | 2005-02-01 | International Business Machined Corporation | Lock-free file system |
JP4042841B2 (ja) * | 2002-03-29 | 2008-02-06 | 富士通株式会社 | 行列演算処理装置 |
US7421642B2 (en) | 2002-04-05 | 2008-09-02 | Seagate Technology Llc | Method and apparatus for error detection |
JP4050548B2 (ja) | 2002-04-18 | 2008-02-20 | 株式会社ルネサステクノロジ | 半導体記憶装置 |
US6948102B2 (en) * | 2002-04-29 | 2005-09-20 | International Business Machines Corporation | Predictive failure analysis for storage networks |
US6707748B2 (en) | 2002-05-07 | 2004-03-16 | Ritek Corporation | Back up power embodied non-volatile memory device |
US7293196B2 (en) | 2002-05-08 | 2007-11-06 | Xiotech Corporation | Method, apparatus, and system for preserving cache data of redundant storage controllers |
US7149857B2 (en) * | 2002-05-14 | 2006-12-12 | Micron Technology, Inc. | Out of order DRAM sequencer |
US6751129B1 (en) | 2002-05-21 | 2004-06-15 | Sandisk Corporation | Efficient read, write methods for multi-state memory |
US6898667B2 (en) | 2002-05-23 | 2005-05-24 | Hewlett-Packard Development Company, L.P. | Managing data in a multi-level raid storage array |
US6766432B2 (en) | 2002-05-24 | 2004-07-20 | Sun Microsystems, Inc. | Memory management system supporting object deletion in non-volatile memory |
US7013364B2 (en) * | 2002-05-27 | 2006-03-14 | Hitachi, Ltd. | Storage subsystem having plural storage systems and storage selector for selecting one of the storage systems to process an access request |
US7318173B1 (en) | 2002-06-03 | 2008-01-08 | National Semiconductor Corporation | Embedded controller based BIOS boot ROM select |
US20030229689A1 (en) | 2002-06-06 | 2003-12-11 | Microsoft Corporation | Method and system for managing stored data on a computer network |
AU2003251492A1 (en) * | 2002-06-11 | 2003-12-22 | Ashish A. Pandya | High performance ip processor for tcp/ip, rdma and ip storage applications |
JP2004021811A (ja) * | 2002-06-19 | 2004-01-22 | Hitachi Ltd | 不揮発メモリを使用したディスク制御装置 |
US6894931B2 (en) | 2002-06-20 | 2005-05-17 | Kabushiki Kaisha Toshiba | Nonvolatile semiconductor memory device |
US7043599B1 (en) | 2002-06-20 | 2006-05-09 | Rambus Inc. | Dynamic memory supporting simultaneous refresh and data-access transactions |
US7562089B2 (en) | 2002-06-26 | 2009-07-14 | Seagate Technology Llc | Systems and methods for storing information to allow users to manage files |
US7082495B2 (en) | 2002-06-27 | 2006-07-25 | Microsoft Corporation | Method and apparatus to reduce power consumption and improve read/write performance of hard disk drives using non-volatile memory |
US7081377B2 (en) | 2002-06-27 | 2006-07-25 | Sandisk 3D Llc | Three-dimensional memory |
JP2004030438A (ja) | 2002-06-27 | 2004-01-29 | Renesas Technology Corp | マイクロコンピュータ |
US6737675B2 (en) | 2002-06-27 | 2004-05-18 | Matrix Semiconductor, Inc. | High density 3D rail stack arrays |
JP4001516B2 (ja) | 2002-07-05 | 2007-10-31 | 富士通株式会社 | 縮退制御装置及び方法 |
US7305668B2 (en) | 2002-07-31 | 2007-12-04 | Intel Corporation | Secure method to perform computer system firmware updates |
US6950952B2 (en) | 2002-08-01 | 2005-09-27 | Intel Corporation | Dynamic power level control based on a board latch state |
US7051152B1 (en) | 2002-08-07 | 2006-05-23 | Nvidia Corporation | Method and system of improving disk access time by compression |
US7043610B2 (en) | 2002-08-19 | 2006-05-09 | Aristos Logic Corporation | System and method for maintaining cache coherency without external controller intervention |
JP2004086295A (ja) | 2002-08-23 | 2004-03-18 | Megawin Technology Co Ltd | Nand型フラッシュメモリディスク装置及び論理アドレス検出の方法 |
KR100505638B1 (ko) | 2002-08-28 | 2005-08-03 | 삼성전자주식회사 | 워킹 콘텍스트 저장 및 복구 장치 및 방법 |
US7103731B2 (en) | 2002-08-29 | 2006-09-05 | International Business Machines Corporation | Method, system, and program for moving data among storage units |
US7130979B2 (en) | 2002-08-29 | 2006-10-31 | Micron Technology, Inc. | Dynamic volume management |
US7882081B2 (en) * | 2002-08-30 | 2011-02-01 | Netapp, Inc. | Optimized disk repository for the storage and retrieval of mostly sequential data |
US20040054867A1 (en) * | 2002-09-13 | 2004-03-18 | Paulus Stravers | Translation lookaside buffer |
US7051174B2 (en) | 2002-09-24 | 2006-05-23 | International Business Machines Corporation | Method, system, and program for restoring data in cache |
US20040064558A1 (en) | 2002-09-26 | 2004-04-01 | Hitachi Ltd. | Resource distribution management method over inter-networks |
JP4005895B2 (ja) | 2002-09-30 | 2007-11-14 | 株式会社東芝 | 不揮発性半導体メモリ装置 |
US7219169B2 (en) * | 2002-09-30 | 2007-05-15 | Sun Microsystems, Inc. | Composite DMA disk controller for efficient hardware-assisted data transfer operations |
JP4130615B2 (ja) | 2003-07-02 | 2008-08-06 | 株式会社日立製作所 | ストレージ装置を有するネットワークにおける障害情報管理方法及び管理サーバ |
US7200758B2 (en) | 2002-10-09 | 2007-04-03 | Intel Corporation | Encapsulation of a TCPA trusted platform module functionality within a server management coprocessor subsystem |
US6822878B2 (en) | 2002-10-09 | 2004-11-23 | Hewlett-Packard Development Company, L.P. | Circuit board support arrangement, method, and method for using the same |
US7225247B2 (en) * | 2002-10-17 | 2007-05-29 | Intel Corporation | Serial port redirection using a management controller |
US7340566B2 (en) | 2002-10-21 | 2008-03-04 | Microsoft Corporation | System and method for initializing a memory device from block oriented NAND flash |
US20040260947A1 (en) * | 2002-10-21 | 2004-12-23 | Brady Gerard Anthony | Methods and systems for analyzing security events |
US7171536B2 (en) | 2002-10-28 | 2007-01-30 | Sandisk Corporation | Unusable block management within a non-volatile memory system |
US6973531B1 (en) | 2002-10-28 | 2005-12-06 | Sandisk Corporation | Tracking the most frequently erased blocks in non-volatile memory systems |
JP3929872B2 (ja) | 2002-10-30 | 2007-06-13 | 株式会社東芝 | キャッシュメモリ、プロセッサ及びキャッシュ制御方法 |
US7415565B2 (en) * | 2002-10-31 | 2008-08-19 | Ring Technology Enterprises, Llc | Methods and systems for a storage system with a program-controlled switch for routing data |
US7085953B1 (en) * | 2002-11-01 | 2006-08-01 | International Business Machines Corporation | Method and means for tolerating multiple dependent or arbitrary double disk failures in a disk array |
JP4199519B2 (ja) | 2002-11-05 | 2008-12-17 | パナソニック株式会社 | メモリ管理装置及びメモリ管理方法 |
US7035974B2 (en) * | 2002-11-06 | 2006-04-25 | Synology Inc. | RAID-5 disk having cache memory implemented using non-volatile RAM |
US6996676B2 (en) | 2002-11-14 | 2006-02-07 | International Business Machines Corporation | System and method for implementing an adaptive replacement cache policy |
US6845053B2 (en) | 2002-11-15 | 2005-01-18 | Micron Technology, Inc. | Power throughput adjustment in flash memory |
US7254676B2 (en) | 2002-11-15 | 2007-08-07 | Intel Corporation | Processor cache memory as RAM for execution of boot code |
US20040098544A1 (en) * | 2002-11-15 | 2004-05-20 | Gaither Blaine D. | Method and apparatus for managing a memory system |
US7178088B2 (en) | 2002-11-18 | 2007-02-13 | Matsushita Electric Industrial Co., Ltd. | Method and circuit for error correction, error correction encoding, data reproduction, or data recording |
JP2004171411A (ja) | 2002-11-21 | 2004-06-17 | Hitachi Global Storage Technologies Netherlands Bv | データ記憶装置及びバッファメモリの管理方法 |
US6836434B2 (en) | 2002-11-21 | 2004-12-28 | Micron Technology, Inc. | Mode selection in a flash memory device |
US7093101B2 (en) | 2002-11-21 | 2006-08-15 | Microsoft Corporation | Dynamic data structures for tracking file system free space in a flash memory device |
US7003620B2 (en) | 2002-11-26 | 2006-02-21 | M-Systems Flash Disk Pioneers Ltd. | Appliance, including a flash memory, that is robust under power failure |
US7399043B2 (en) | 2002-12-02 | 2008-07-15 | Silverbrook Research Pty Ltd | Compensation for uneven printhead module lengths in a multi-module printhead |
US6922754B2 (en) | 2002-12-09 | 2005-07-26 | Infabric Technologies, Inc. | Data-aware data flow manager |
US7324614B2 (en) * | 2002-12-18 | 2008-01-29 | Texas Instruments Incorporated | High speed decoder |
US7552192B2 (en) | 2002-12-18 | 2009-06-23 | Ronnie Gerome Carmichael | Massively parallel computer network-utilizing MPACT and multipoint parallel server (MPAS) technologies |
US7069307B1 (en) | 2002-12-20 | 2006-06-27 | Network Appliance, Inc. | System and method for inband management of a virtual disk |
EP1573962B1 (en) | 2002-12-20 | 2011-03-16 | International Business Machines Corporation | Secure system and method for san management in a non-trusted server environment |
US6957158B1 (en) * | 2002-12-23 | 2005-10-18 | Power Measurement Ltd. | High density random access memory in an intelligent electric device |
US6849905B2 (en) * | 2002-12-23 | 2005-02-01 | Matrix Semiconductor, Inc. | Semiconductor device with localized charge storage dielectric and method of making same |
KR100502608B1 (ko) | 2002-12-24 | 2005-07-20 | 한국전자통신연구원 | 계산이 간단한 저밀도 패리티 검사 부호를 위한 메시지 전달 복호기 |
US7010645B2 (en) | 2002-12-27 | 2006-03-07 | International Business Machines Corporation | System and method for sequentially staging received data to a write cache in advance of storing the received data |
US6973551B1 (en) | 2002-12-30 | 2005-12-06 | Emc Corporation | Data storage system having atomic memory operation |
US7505321B2 (en) | 2002-12-31 | 2009-03-17 | Sandisk 3D Llc | Programmable memory array structure incorporating series-connected transistor strings and methods for fabrication and operation of same |
US7005350B2 (en) | 2002-12-31 | 2006-02-28 | Matrix Semiconductor, Inc. | Method for fabricating programmable memory array structures incorporating series-connected transistor strings |
EP1435576B1 (en) | 2003-01-03 | 2013-03-20 | Austria Card Plastikkarten und Ausweissysteme GmbH | Method and apparatus for block-oriented memory management provided in smart card controllers |
US7024551B2 (en) * | 2003-01-07 | 2006-04-04 | Sun Microsystems, Inc. | Method and apparatus for updating boot code using a system controller |
US6816917B2 (en) | 2003-01-15 | 2004-11-09 | Hewlett-Packard Development Company, L.P. | Storage system with LUN virtualization |
JP2004227098A (ja) * | 2003-01-20 | 2004-08-12 | Hitachi Ltd | 記憶デバイス制御装置の制御方法、及び記憶デバイス制御装置 |
US7664909B2 (en) | 2003-04-18 | 2010-02-16 | Nextio, Inc. | Method and apparatus for a shared I/O serial ATA controller |
US7698483B2 (en) * | 2003-01-21 | 2010-04-13 | Nextio, Inc. | Switching apparatus and method for link initialization in a shared I/O environment |
US20040148360A1 (en) | 2003-01-24 | 2004-07-29 | Hewlett-Packard Development Company | Communication-link-attached persistent memory device |
WO2004077219A2 (en) | 2003-01-30 | 2004-09-10 | Vaman Technologies (R & D) Limited | System and method of mapping patterns of data, optimising disk read and write, verifying data integrity across clients and servers of different functionality having shared resources |
US7065618B1 (en) | 2003-02-14 | 2006-06-20 | Google Inc. | Leasing scheme for data-modifying operations |
US7107419B1 (en) | 2003-02-14 | 2006-09-12 | Google Inc. | Systems and methods for performing record append operations |
US7181569B2 (en) | 2003-02-26 | 2007-02-20 | International Business Machines Corporation | Method, system, and article of manufacture for writing on sequential storage media |
US7526598B2 (en) | 2003-03-03 | 2009-04-28 | Sandisk Il, Ltd. | Efficient flash memory device driver |
JP2004265162A (ja) * | 2003-03-03 | 2004-09-24 | Renesas Technology Corp | 記憶装置およびアドレス管理方法 |
US6959369B1 (en) | 2003-03-06 | 2005-10-25 | International Business Machines Corporation | Method, system, and program for data backup |
US7227959B2 (en) | 2003-03-10 | 2007-06-05 | Shure Incorporated | Multi-channel digital feedback reducer system |
JP4233564B2 (ja) | 2003-03-10 | 2009-03-04 | シャープ株式会社 | データ処理装置、データ処理用のプログラムおよび記録媒体 |
US7076723B2 (en) | 2003-03-14 | 2006-07-11 | Quantum Corporation | Error correction codes |
JP2004278439A (ja) | 2003-03-17 | 2004-10-07 | Toshiba Kyaria Kk | 流体機械 |
US8041878B2 (en) * | 2003-03-19 | 2011-10-18 | Samsung Electronics Co., Ltd. | Flash file system |
JP2004280752A (ja) | 2003-03-19 | 2004-10-07 | Sony Corp | データ記憶装置、およびデータ記憶装置における管理情報更新方法、並びにコンピュータ・プログラム |
KR100526178B1 (ko) | 2003-03-31 | 2005-11-03 | 삼성전자주식회사 | 플래시 메모리 액세스 장치 및 방법 |
US7197657B1 (en) | 2003-04-03 | 2007-03-27 | Advanced Micro Devices, Inc. | BMC-hosted real-time clock and non-volatile RAM replacement |
US7293165B1 (en) | 2003-04-03 | 2007-11-06 | Advanced Micro Devices, Inc. | BMC-hosted boot ROM interface |
US7987249B2 (en) | 2003-04-09 | 2011-07-26 | Intel Corporation | Soft system failure recovery for management consoles supporting ASF RMCP |
JP2004310621A (ja) | 2003-04-10 | 2004-11-04 | Hitachi Ltd | 記憶装置システムにおけるファイルアクセス方法及びファイルアクセスのためのプログラム |
US6865122B2 (en) * | 2003-04-11 | 2005-03-08 | Intel Corporation | Reclaiming blocks in a block-alterable memory |
CN100342377C (zh) | 2003-04-16 | 2007-10-10 | 华为技术有限公司 | 一种提高数据处理效率的方法 |
US20040207440A1 (en) * | 2003-04-17 | 2004-10-21 | Naysen Robertson | Electrical circuit for controling another circuit or system |
WO2004095304A1 (en) | 2003-04-23 | 2004-11-04 | Dot Hill Systems Corporation | Network storage appliance with integrated redundant servers and storage controllers |
US20040230866A1 (en) * | 2003-04-30 | 2004-11-18 | Hewlett-Packard Development Company, L.P. | Test system for testing components of an open architecture modular computing system |
US7281076B2 (en) | 2003-04-30 | 2007-10-09 | Hewlett-Packard Development Company, L.P. | Form factor converter and tester in an open architecture modular computing system |
US7610348B2 (en) | 2003-05-07 | 2009-10-27 | International Business Machines | Distributed file serving architecture system with metadata storage virtualization and data access at the data server connection speed |
JP4270371B2 (ja) | 2003-05-09 | 2009-05-27 | インターナショナル・ビジネス・マシーンズ・コーポレーション | 記憶システム、制御装置、制御方法、及び、プログラム |
US7320100B2 (en) * | 2003-05-20 | 2008-01-15 | Cray Inc. | Apparatus and method for memory with bit swapping on the fly and testing |
JP2004348818A (ja) * | 2003-05-20 | 2004-12-09 | Sharp Corp | 半導体記憶装置の書込制御方法及びシステム並びに携帯電子機器 |
US7412449B2 (en) | 2003-05-23 | 2008-08-12 | Sap Aktiengesellschaft | File object storage and retrieval using hashing techniques |
US7035111B1 (en) | 2003-05-23 | 2006-04-25 | Hewlett-Packard Development Company, L.P. | Circuit board orientation with different width portions |
US7388904B2 (en) | 2003-06-03 | 2008-06-17 | Vativ Technologies, Inc. | Near-end, far-end and echo cancellers in a multi-channel transceiver system |
US7434097B2 (en) * | 2003-06-05 | 2008-10-07 | Copan System, Inc. | Method and apparatus for efficient fault-tolerant disk drive replacement in raid storage systems |
US7380081B2 (en) | 2003-06-06 | 2008-05-27 | Hewlett-Packard Development Company, L.P. | Asynchronous data redundancy technique |
US7380198B2 (en) * | 2003-06-11 | 2008-05-27 | International Business Machines Corporation | System and method for detecting write errors in a storage device |
US7454555B2 (en) | 2003-06-12 | 2008-11-18 | Rambus Inc. | Apparatus and method including a memory device having multiple sets of memory banks with duplicated data emulating a fast access time, fixed latency memory device |
US7263607B2 (en) * | 2003-06-12 | 2007-08-28 | Microsoft Corporation | Categorizing electronic messages based on trust between electronic messaging entities |
US7243203B2 (en) | 2003-06-13 | 2007-07-10 | Sandisk 3D Llc | Pipeline circuit for low latency memory |
US7047366B1 (en) | 2003-06-17 | 2006-05-16 | Emc Corporation | QOS feature knobs |
US7237141B2 (en) | 2003-06-19 | 2007-06-26 | Lsi Corporation | Method for recovering data from a redundant storage object |
WO2004114114A1 (en) | 2003-06-23 | 2004-12-29 | Koninklijke Philips Electronics N.V. | Device and method for recording information |
US6906961B2 (en) * | 2003-06-24 | 2005-06-14 | Micron Technology, Inc. | Erase block data splitting |
US7400996B2 (en) | 2003-06-26 | 2008-07-15 | Benjamin Thomas Percer | Use of I2C-based potentiometers to enable voltage rail variation under BMC control |
US7437258B2 (en) | 2003-06-26 | 2008-10-14 | Hewlett-Packard Development Company, L.P. | Use of I2C programmable clock generator to enable frequency variation under BMC control |
US7493226B2 (en) | 2003-06-26 | 2009-02-17 | Hewlett-Packard Development Company, L.P. | Method and construct for enabling programmable, integrated system margin testing |
US7117326B2 (en) | 2003-06-26 | 2006-10-03 | Intel Corporation | Tracking modifications to a memory |
US20040267483A1 (en) | 2003-06-26 | 2004-12-30 | Percer Benjamin Thomas | Methods and systems for masking faults in a margin testing environment |
US20040268359A1 (en) * | 2003-06-27 | 2004-12-30 | Hanes David H. | Computer-readable medium, method and computer system for processing input/output requests |
US7275098B1 (en) | 2003-06-27 | 2007-09-25 | Emc Corporation | Methods and apparatus for administering software modules in a storage area network management application |
US7010630B2 (en) | 2003-06-30 | 2006-03-07 | International Business Machines Corporation | Communicating to system management in a data processing system |
US7373514B2 (en) | 2003-07-23 | 2008-05-13 | Intel Corporation | High-performance hashing system |
AU2004260518B2 (en) * | 2003-07-24 | 2009-11-26 | Lucidyne Technologies, Inc. | Wood tracking by identification of surface characteristics |
GB0320142D0 (en) | 2003-08-28 | 2003-10-01 | Ibm | Data storage systems |
US7149947B1 (en) | 2003-09-04 | 2006-12-12 | Emc Corporation | Method of and system for validating an error correction code and parity information associated with a data word |
US20050055495A1 (en) * | 2003-09-05 | 2005-03-10 | Nokia Corporation | Memory wear leveling |
JP2005108304A (ja) | 2003-09-29 | 2005-04-21 | Toshiba Corp | 半導体記憶装置及びその制御方法 |
US7487235B2 (en) | 2003-09-24 | 2009-02-03 | Dell Products L.P. | Dynamically varying a raid cache policy in order to optimize throughput |
US7483974B2 (en) | 2003-09-24 | 2009-01-27 | Intel Corporation | Virtual management controller to coordinate processing blade management in a blade server environment |
US20050091215A1 (en) | 2003-09-29 | 2005-04-28 | Chandra Tushar D. | Technique for provisioning storage for servers in an on-demand environment |
US7299354B2 (en) | 2003-09-30 | 2007-11-20 | Intel Corporation | Method to authenticate clients and hosts to provide secure network boot |
US20050071461A1 (en) | 2003-09-30 | 2005-03-31 | Intel Corporation | Proxy alerting |
IES20030722A2 (en) | 2003-10-01 | 2005-04-06 | Yqa Now Ltd | A data storage device |
US7173852B2 (en) | 2003-10-03 | 2007-02-06 | Sandisk Corporation | Corrected data storage and handling methods |
JP2005115600A (ja) * | 2003-10-07 | 2005-04-28 | Hitachi Ltd | 情報処理装置及び方法 |
JP4492084B2 (ja) * | 2003-10-07 | 2010-06-30 | 株式会社日立製作所 | ストレージパス制御方法 |
US7337201B1 (en) | 2003-10-08 | 2008-02-26 | Sun Microsystems, Inc. | System and method to increase memory allocation efficiency |
US20050080887A1 (en) | 2003-10-08 | 2005-04-14 | Chun-Liang Lee | Redundant management control arbitration system |
TWI238325B (en) | 2003-10-09 | 2005-08-21 | Quanta Comp Inc | Apparatus of remote server console redirection |
US7127560B2 (en) | 2003-10-14 | 2006-10-24 | International Business Machines Corporation | Method of dynamically controlling cache size |
US7096321B2 (en) * | 2003-10-21 | 2006-08-22 | International Business Machines Corporation | Method and system for a cache replacement technique with adaptive skipping |
US20050091452A1 (en) * | 2003-10-28 | 2005-04-28 | Ying Chen | System and method for reducing data loss in disk arrays by establishing data redundancy on demand |
JP4379079B2 (ja) * | 2003-10-30 | 2009-12-09 | ソニー株式会社 | データ再生処理装置、情報処理装置、および情報処理方法、並びにコンピュータ・プログラム |
US7143240B2 (en) | 2003-10-31 | 2006-11-28 | International Business Machines Corporation | System and method for providing a cost-adaptive cache |
US7428691B2 (en) * | 2003-11-12 | 2008-09-23 | Norman Ken Ouchi | Data recovery from multiple failed data blocks and storage units |
WO2005065084A2 (en) * | 2003-11-13 | 2005-07-21 | Commvault Systems, Inc. | System and method for providing encryption in pipelined storage operations in a storage network |
US7412583B2 (en) * | 2003-11-14 | 2008-08-12 | International Business Machines Corporation | Virtual incremental storage method |
WO2005050453A1 (ja) | 2003-11-18 | 2005-06-02 | Matsushita Electric Industrial Co., Ltd. | ファイル記録装置 |
JP4493321B2 (ja) * | 2003-11-19 | 2010-06-30 | 株式会社日立製作所 | ディスクアレイ装置及びデータ退避方法 |
US7171514B2 (en) | 2003-11-20 | 2007-01-30 | International Business Machines Corporation | Apparatus and method to control access to logical volumes using parallel access volumes |
US20050114595A1 (en) | 2003-11-26 | 2005-05-26 | Veritas Operating Corporation | System and method for emulating operating system metadata to provide cross-platform access to storage volumes |
US8112574B2 (en) | 2004-02-26 | 2012-02-07 | Super Talent Electronics, Inc. | Swappable sets of partial-mapping tables in a flash-memory system with a command queue for combining flash writes |
US7162571B2 (en) | 2003-12-09 | 2007-01-09 | Emc Corporation | Methods and apparatus for parsing a content address to facilitate selection of a physical storage location in a data storage system |
US8892821B2 (en) | 2003-12-10 | 2014-11-18 | International Business Machines Corporation | Method and system for thread-based memory speculation in a memory subsystem of a data processing system |
US7350127B2 (en) * | 2003-12-12 | 2008-03-25 | Hewlett-Packard Development Company, L.P. | Error correction method and system |
US20050149819A1 (en) | 2003-12-15 | 2005-07-07 | Daewoo Electronics Corporation | Three-dimensional error correction method |
US7500000B2 (en) | 2003-12-17 | 2009-03-03 | International Business Machines Corporation | Method and system for assigning or creating a resource |
US7822790B2 (en) * | 2003-12-23 | 2010-10-26 | International Business Machines Corporation | Relative positioning and access of memory objects |
US20050149618A1 (en) | 2003-12-23 | 2005-07-07 | Mobile Action Technology Inc. | System and method of transmitting electronic files over to a mobile phone |
US7464100B2 (en) | 2003-12-24 | 2008-12-09 | Sap Ag | Reorganization-free mapping of objects in databases using a mapping chain |
JP4111910B2 (ja) * | 2003-12-26 | 2008-07-02 | 富士通株式会社 | ディスクキャッシュ装置 |
US7281114B2 (en) | 2003-12-26 | 2007-10-09 | Tdk Corporation | Memory controller, flash memory system, and method of controlling operation for data exchange between host system and flash memory |
US7418490B1 (en) * | 2003-12-29 | 2008-08-26 | Sun Microsystems, Inc. | System using multiple sets of device management policies for managing network devices connected on different network interfaces |
US8504798B2 (en) * | 2003-12-30 | 2013-08-06 | Sandisk Technologies Inc. | Management of non-volatile memory systems having large erase blocks |
US7139864B2 (en) | 2003-12-30 | 2006-11-21 | Sandisk Corporation | Non-volatile memory and method with block management system |
US7631138B2 (en) * | 2003-12-30 | 2009-12-08 | Sandisk Corporation | Adaptive mode switching of flash memory address mapping based on host usage characteristics |
US7162560B2 (en) | 2003-12-31 | 2007-01-09 | Intel Corporation | Partitionable multiprocessor system having programmable interrupt controllers |
US8250295B2 (en) | 2004-01-05 | 2012-08-21 | Smart Modular Technologies, Inc. | Multi-rank memory module that emulates a memory module having a different number of ranks |
JP4401788B2 (ja) * | 2004-01-06 | 2010-01-20 | 株式会社日立製作所 | ストレージ制御装置 |
JP2005196410A (ja) * | 2004-01-06 | 2005-07-21 | Sony Corp | データ通信装置及びデータ通信装置のメモリ管理方法 |
US20050154786A1 (en) | 2004-01-09 | 2005-07-14 | International Business Machines Corporation | Ordering updates in remote copying of data |
US7188229B2 (en) | 2004-01-17 | 2007-03-06 | Sun Microsystems, Inc. | Method and apparatus for memory management in a multi-processor computer system |
US7328307B2 (en) | 2004-01-22 | 2008-02-05 | Tquist, Llc | Method and apparatus for improving update performance of non-uniform access time persistent storage media |
JP4496790B2 (ja) * | 2004-01-26 | 2010-07-07 | ソニー株式会社 | データ記憶装置及び方法、並びに記録再生システム |
US7042664B2 (en) | 2004-01-26 | 2006-05-09 | Seagate Technology Llc | Method and system for host programmable data storage device self-testing |
JP4477365B2 (ja) | 2004-01-29 | 2010-06-09 | 株式会社日立製作所 | 複数インタフェースを有する記憶装置、および、その記憶装置の制御方法 |
US7356651B2 (en) | 2004-01-30 | 2008-04-08 | Piurata Technologies, Llc | Data-aware cache state machine |
US7305520B2 (en) | 2004-01-30 | 2007-12-04 | Hewlett-Packard Development Company, L.P. | Storage system with capability to allocate virtual storage segments among a plurality of controllers |
US7389465B2 (en) | 2004-01-30 | 2008-06-17 | Micron Technology, Inc. | Error detection and correction scheme for a memory device |
US7064994B1 (en) | 2004-01-30 | 2006-06-20 | Sun Microsystems, Inc. | Dynamic memory throttling for power and thermal limitations |
JP4524120B2 (ja) | 2004-02-03 | 2010-08-11 | 富士通株式会社 | ブレード型光伝送装置 |
JP2005222234A (ja) | 2004-02-04 | 2005-08-18 | Seiko Epson Corp | メディア変換装置、ネットワーク型ダイレクト出力システム、および出力処理指示の転送方法 |
US7130956B2 (en) | 2004-02-10 | 2006-10-31 | Sun Microsystems, Inc. | Storage system including hierarchical cache metadata |
US7130957B2 (en) | 2004-02-10 | 2006-10-31 | Sun Microsystems, Inc. | Storage system structure for storing relational cache metadata |
US7231590B2 (en) | 2004-02-11 | 2007-06-12 | Microsoft Corporation | Method and apparatus for visually emphasizing numerical data contained within an electronic document |
US7873693B1 (en) * | 2004-02-13 | 2011-01-18 | Habanero Holdings, Inc. | Multi-chassis fabric-backplane enterprise servers |
CN100468362C (zh) * | 2004-02-20 | 2009-03-11 | 西门子能量及自动化公司 | 用于初始化和利用plc的存储装置的方法 |
US7394271B2 (en) * | 2004-02-27 | 2008-07-01 | Wells-Cti, Llc | Temperature sensing and prediction in IC sockets |
DE102004011201B4 (de) * | 2004-03-04 | 2006-10-12 | Siemens Ag | Verfahren zum Management und zur Überwachung des Betriebs mehrerer in wenigstens ein Kommunikationsnetz eingebundener verteilter Hard- und/oder Softwaresysteme sowie System zur Durchführung des Verfahrens |
US7532537B2 (en) | 2004-03-05 | 2009-05-12 | Netlist, Inc. | Memory module with a circuit providing load isolation and memory domain translation |
JP2005250938A (ja) | 2004-03-05 | 2005-09-15 | Hitachi Ltd | 記憶制御システム及び方法 |
US7289386B2 (en) | 2004-03-05 | 2007-10-30 | Netlist, Inc. | Memory module decoder |
US7916574B1 (en) | 2004-03-05 | 2011-03-29 | Netlist, Inc. | Circuit providing load isolation and memory domain translation for memory module |
US7260695B2 (en) | 2004-03-05 | 2007-08-21 | International Business Machines Corporation | Scanning modified data during power loss |
US20080082736A1 (en) * | 2004-03-11 | 2008-04-03 | Chow David Q | Managing bad blocks in various flash memory cells for electronic data flash card |
US20050201306A1 (en) * | 2004-03-15 | 2005-09-15 | Engel Glenn R. | Method and system for supplying power to multiple devices using power-transmitting network connections |
US7165144B2 (en) | 2004-03-19 | 2007-01-16 | Intel Corporation | Managing input/output (I/O) requests in a cache memory system |
US7720864B1 (en) | 2004-03-25 | 2010-05-18 | Symantec Operating Corporation | Expiration of access tokens for quiescing a distributed system |
JP2005316951A (ja) | 2004-03-30 | 2005-11-10 | Seiko Epson Corp | 情報端末、情報処理システム、及び、これらの制御方法 |
JP2005293774A (ja) | 2004-04-02 | 2005-10-20 | Hitachi Global Storage Technologies Netherlands Bv | ディスク装置の制御方法 |
US7281192B2 (en) | 2004-04-05 | 2007-10-09 | Broadcom Corporation | LDPC (Low Density Parity Check) coded signal decoding using parallel and simultaneous bit node and check node processing |
US7788460B2 (en) * | 2004-04-13 | 2010-08-31 | Intel Corporation | Defragmenting objects in a storage medium |
US7224545B2 (en) * | 2004-04-15 | 2007-05-29 | Quantum Corporation | Methods and systems for overwrite protected storage media |
KR100647370B1 (ko) * | 2004-04-20 | 2006-11-23 | 주식회사 하이닉스반도체 | 멀티 프로토콜 시리얼 인터페이스 시스템 |
US7725628B1 (en) | 2004-04-20 | 2010-05-25 | Lexar Media, Inc. | Direct secondary device interface by a host |
US20050240713A1 (en) * | 2004-04-22 | 2005-10-27 | V-Da Technology | Flash memory device with ATA/ATAPI/SCSI or proprietary programming interface on PCI express |
EP1745394B1 (en) * | 2004-04-26 | 2009-07-15 | Storewiz, Inc. | Method and system for compression of files for storage and operation on compressed files |
US8374175B2 (en) * | 2004-04-27 | 2013-02-12 | Hewlett-Packard Development Company, L.P. | System and method for remote direct memory access over a network switch fabric |
US7412614B2 (en) | 2004-04-29 | 2008-08-12 | Hewlett-Packard Development Company, L.P. | Power management using a pre-determined thermal characteristic of a memory module |
US7773521B2 (en) | 2004-04-30 | 2010-08-10 | Emc Corporation | Storage switch traffic bandwidth control |
US7430571B2 (en) | 2004-04-30 | 2008-09-30 | Network Appliance, Inc. | Extension of write anywhere file layout write allocation |
US7370163B2 (en) | 2004-05-03 | 2008-05-06 | Gemini Storage | Adaptive cache engine for storage area network including systems and methods related thereto |
US7644239B2 (en) | 2004-05-03 | 2010-01-05 | Microsoft Corporation | Non-volatile memory cache performance improvement |
US7360015B2 (en) | 2004-05-04 | 2008-04-15 | Intel Corporation | Preventing storage of streaming accesses in a cache |
US7386663B2 (en) | 2004-05-13 | 2008-06-10 | Cousins Robert E | Transaction-based storage system and method that uses variable sized objects to store data |
US7512830B2 (en) | 2004-05-14 | 2009-03-31 | International Business Machines Corporation | Management module failover across multiple blade center chassis |
US20050257017A1 (en) * | 2004-05-14 | 2005-11-17 | Hideki Yagi | Method and apparatus to erase hidden memory in a memory card |
TWI255426B (en) | 2004-05-18 | 2006-05-21 | Carry Computer Eng Co Ltd | Storage control apparatus capable of analyzing volume information and the control method thereof |
US7831561B2 (en) | 2004-05-18 | 2010-11-09 | Oracle International Corporation | Automated disk-oriented backups |
WO2005114374A2 (en) * | 2004-05-21 | 2005-12-01 | Computer Associates Think, Inc. | Object-based storage |
JP2005339198A (ja) | 2004-05-27 | 2005-12-08 | Internatl Business Mach Corp <Ibm> | キャッシュヒット率推定装置、キャッシュヒット率推定方法、プログラム及び記録媒体 |
US7009889B2 (en) | 2004-05-28 | 2006-03-07 | Sandisk Corporation | Comprehensive erase verification for non-volatile memory |
US7904181B2 (en) | 2004-06-01 | 2011-03-08 | Ils Technology Llc | Model for communication between manufacturing and enterprise levels |
JP2005346321A (ja) | 2004-06-02 | 2005-12-15 | Hitachi Ltd | ディスクアレイ装置及びディスクアレイ装置のバッテリ出力制御方法 |
US7502369B2 (en) | 2004-06-02 | 2009-03-10 | Intel Corporation | High speed interface systems and methods |
US7590522B2 (en) | 2004-06-14 | 2009-09-15 | Hewlett-Packard Development Company, L.P. | Virtual mass storage device for server management information |
US7734643B1 (en) | 2004-06-30 | 2010-06-08 | Oracle America, Inc. | Method for distributed storage of data |
US7045717B2 (en) | 2004-06-30 | 2006-05-16 | International Business Machines Corporation | High speed cable interconnect to a computer midplane |
US7290116B1 (en) | 2004-06-30 | 2007-10-30 | Sun Microsystems, Inc. | Level 2 cache index hashing to avoid hot spots |
US7386890B2 (en) | 2004-06-30 | 2008-06-10 | Intel Corporation | Method and apparatus to preserve a hash value of an executable module |
JP2006023854A (ja) * | 2004-07-06 | 2006-01-26 | Sharp Corp | 情報処理装置、記憶装置、記憶制御装置及びプログラム |
JP2006031268A (ja) * | 2004-07-14 | 2006-02-02 | Sharp Corp | 情報処理装置、及び記憶制御装置 |
US7177883B2 (en) * | 2004-07-15 | 2007-02-13 | Hitachi, Ltd. | Method and apparatus for hierarchical storage management based on data value and user interest |
US7447847B2 (en) | 2004-07-19 | 2008-11-04 | Micron Technology, Inc. | Memory device trims |
US7594471B2 (en) * | 2004-07-21 | 2009-09-29 | Detnet South Africa (Pty) Ltd. | Blasting system and method of controlling a blasting operation |
US7395384B2 (en) | 2004-07-21 | 2008-07-01 | Sandisk Corproation | Method and apparatus for maintaining data on non-volatile memory systems |
US8607016B2 (en) | 2004-07-21 | 2013-12-10 | Sandisk Technologies Inc. | FAT analysis for optimized sequential cluster management |
US20060020616A1 (en) | 2004-07-22 | 2006-01-26 | Geoffrey Hardy | Indexing operational logs in a distributed processing system |
US9264384B1 (en) * | 2004-07-22 | 2016-02-16 | Oracle International Corporation | Resource virtualization mechanism including virtual host bus adapters |
US7366852B2 (en) * | 2004-07-29 | 2008-04-29 | Infortrend Technology, Inc. | Method for improving data reading performance and storage system for performing the same |
TWI300186B (en) | 2004-07-30 | 2008-08-21 | Mediatek Inc | Method and apparatus for data recording with pseudo-merge |
US7386700B2 (en) | 2004-07-30 | 2008-06-10 | Sandisk Il Ltd | Virtual-to-physical address translation in a flash file system |
US7203815B2 (en) | 2004-07-30 | 2007-04-10 | International Business Machines Corporation | Multi-level page cache for enhanced file system performance via read ahead |
US8407396B2 (en) | 2004-07-30 | 2013-03-26 | Hewlett-Packard Development Company, L.P. | Providing block data access for an operating system using solid-state memory |
US7213125B2 (en) | 2004-07-31 | 2007-05-01 | Hewlett-Packard Development Company, L.P. | Method for patching virtually aliased pages by a virtual-machine monitor |
JP2006048506A (ja) * | 2004-08-06 | 2006-02-16 | Toshiba Corp | プロセッサ、メモリ管理システム及びメモリ管理プログラム |
US7664239B2 (en) | 2004-08-09 | 2010-02-16 | Cox Communications, Inc. | Methods and computer-readable media for managing and configuring options for the real-time notification and disposition of voice services in a cable services network |
US20060036904A1 (en) * | 2004-08-13 | 2006-02-16 | Gemini Storage | Data replication method over a limited bandwidth network by mirroring parities |
JP4315876B2 (ja) | 2004-08-17 | 2009-08-19 | 富士通株式会社 | ファイル管理プログラム、ファイル管理方法、及びファイル管理装置 |
US7340487B2 (en) | 2004-08-18 | 2008-03-04 | International Business Machines Corporation | Delayed deletion of extended attributes |
US7477570B2 (en) | 2004-08-20 | 2009-01-13 | Micron Technology, Inc. | Sequential access memory with system and method |
US7398348B2 (en) | 2004-08-24 | 2008-07-08 | Sandisk 3D Llc | Method and apparatus for using a one-time or few-time programmable memory with a host device designed for erasable/rewritable memory |
US20060047926A1 (en) | 2004-08-25 | 2006-03-02 | Zheng Calvin G | Managing multiple snapshot copies of data |
WO2006025322A1 (ja) | 2004-08-30 | 2006-03-09 | Matsushita Electric Industrial Co., Ltd. | 記録装置 |
JP4646574B2 (ja) | 2004-08-30 | 2011-03-09 | 株式会社日立製作所 | データ処理システム |
US7299339B2 (en) * | 2004-08-30 | 2007-11-20 | The Boeing Company | Super-reconfigurable fabric architecture (SURFA): a multi-FPGA parallel processing architecture for COTS hybrid computing framework |
US20060075057A1 (en) * | 2004-08-30 | 2006-04-06 | International Business Machines Corporation | Remote direct memory access system and method |
US7241655B2 (en) | 2004-08-30 | 2007-07-10 | Micron Technology, Inc. | Method of fabricating a vertical wrap-around-gate field-effect-transistor for high density, low voltage logic and memory array |
JP4113170B2 (ja) | 2004-09-08 | 2008-07-09 | 株式会社東芝 | 半導体装置 |
JP4192129B2 (ja) | 2004-09-13 | 2008-12-03 | 株式会社東芝 | メモリ管理装置 |
JP4737438B2 (ja) | 2004-09-16 | 2011-08-03 | 日本電気株式会社 | 複数の処理ユニットでリソースを共有する情報処理装置 |
US7395452B2 (en) | 2004-09-24 | 2008-07-01 | Microsoft Corporation | Method and system for improved reliability in storage devices |
US7062624B2 (en) | 2004-09-29 | 2006-06-13 | Hitachi, Ltd. | Method for managing volume groups considering storage tiers |
JP4104586B2 (ja) | 2004-09-30 | 2008-06-18 | 株式会社東芝 | ファイル管理機能を備えたファイルシステム及びファイル管理方法 |
US7444493B2 (en) | 2004-09-30 | 2008-10-28 | Intel Corporation | Address translation for input/output devices using hierarchical translation tables |
US8655853B2 (en) | 2004-10-01 | 2014-02-18 | Sap Ag | System and method for optimizing database transaction termination |
JP4648674B2 (ja) | 2004-10-01 | 2011-03-09 | 株式会社日立製作所 | 記憶制御装置、記憶制御システム及び記憶制御方法 |
GB2418769B (en) * | 2004-10-02 | 2009-06-17 | Hewlett Packard Development Co | Method and system for storing data |
US7603532B2 (en) | 2004-10-15 | 2009-10-13 | Netapp, Inc. | System and method for reclaiming unused space from a thinly provisioned data container |
US7257690B1 (en) | 2004-10-15 | 2007-08-14 | Veritas Operating Corporation | Log-structured temporal shadow store |
US20060090948A1 (en) | 2004-10-18 | 2006-05-04 | Allen Gregory T | Driver side airbag detainment and containment device |
US7308603B2 (en) | 2004-10-18 | 2007-12-11 | International Business Machines Corporation | Method and system for reducing memory faults while running an operating system |
US8131969B2 (en) | 2004-10-20 | 2012-03-06 | Seagate Technology Llc | Updating system configuration information |
US7328317B2 (en) | 2004-10-21 | 2008-02-05 | International Business Machines Corporation | Memory controller and method for optimized read/modify/write performance |
US7565569B2 (en) | 2004-10-22 | 2009-07-21 | International Business Machines Corporation | Data protection in a mass storage system |
JP2006127028A (ja) | 2004-10-27 | 2006-05-18 | Hitachi Ltd | 記憶システム及び記憶制御装置 |
US7310711B2 (en) | 2004-10-29 | 2007-12-18 | Hitachi Global Storage Technologies Netherlands B.V. | Hard disk drive with support for atomic transactions |
US7318119B2 (en) * | 2004-10-29 | 2008-01-08 | International Business Machines Corporation | System and method for fault tolerant controller for network RAID |
ITMI20042072A1 (it) | 2004-10-29 | 2005-01-29 | St Microelectronics Srl | Dispositivo di memoria flsh dotato di interfaccia di comunicazione low pin count |
KR100645058B1 (ko) | 2004-11-03 | 2006-11-10 | 삼성전자주식회사 | 데이터 신뢰성을 향상시킬 수 있는 메모리 관리 기법 |
WO2006052830A2 (en) | 2004-11-05 | 2006-05-18 | Trusted Data Corporation | Storage system condition indicator and method |
US7873782B2 (en) | 2004-11-05 | 2011-01-18 | Data Robotics, Inc. | Filesystem-aware block storage system, apparatus, and method |
US20060106968A1 (en) * | 2004-11-15 | 2006-05-18 | Wooi Teoh Gary C | Intelligent platform management bus switch system |
US7441067B2 (en) | 2004-11-15 | 2008-10-21 | Sandisk Corporation | Cyclic flash memory wear leveling |
US7475274B2 (en) | 2004-11-17 | 2009-01-06 | Raytheon Company | Fault tolerance and recovery in a high-performance computing (HPC) system |
US7430465B2 (en) * | 2004-11-17 | 2008-09-30 | Spx Corporation | Open-ended PC host interface for vehicle data recorder |
US7337277B2 (en) | 2004-11-18 | 2008-02-26 | International Business Machines Corporation | Apparatus, system, and method for flushing cache data |
US7392428B2 (en) * | 2004-11-19 | 2008-06-24 | International Business Machines Corporation | Method and system for recovering from abnormal interruption of a parity update operation in a disk array system |
US7778984B2 (en) * | 2004-11-19 | 2010-08-17 | Microsoft Corporation | System and method for a distributed object store |
JP4500318B2 (ja) | 2004-11-29 | 2010-07-14 | 富士通株式会社 | 分散トランザクション処理方法、装置、及びプログラム |
US8595459B2 (en) * | 2004-11-29 | 2013-11-26 | Rambus Inc. | Micro-threaded memory |
US7668883B2 (en) * | 2004-11-30 | 2010-02-23 | Kabushiki Kaisha Toshiba | System for secure erasing of files |
US7610307B2 (en) | 2004-11-30 | 2009-10-27 | Microsoft Corporation | Method and system of detecting file system namespace changes and restoring consistency |
US20060149954A1 (en) * | 2004-12-03 | 2006-07-06 | Matt Hageman | Apparatus and method for accommodating different central processing units in a computer |
US20060120235A1 (en) * | 2004-12-06 | 2006-06-08 | Teac Aerospace Technologies | System and method of erasing non-volatile recording media |
CA2591333A1 (en) | 2004-12-06 | 2006-06-15 | Teac Aerospace Technologies, Inc. | System and method of erasing non-volatile recording media |
US8156281B1 (en) | 2004-12-07 | 2012-04-10 | Oracle America, Inc. | Data storage system and method using storage profiles to define and modify storage pools |
US8074041B2 (en) | 2004-12-09 | 2011-12-06 | International Business Machines Corporation | Apparatus, system, and method for managing storage space allocation |
US7694298B2 (en) * | 2004-12-10 | 2010-04-06 | Intel Corporation | Method and apparatus for providing virtual server blades |
US8495266B2 (en) | 2004-12-10 | 2013-07-23 | Hewlett-Packard Development Company, L.P. | Distributed lock |
US7120051B2 (en) | 2004-12-14 | 2006-10-10 | Sandisk Corporation | Pipelined programming of non-volatile memories using early data |
US7581118B2 (en) | 2004-12-14 | 2009-08-25 | Netapp, Inc. | Disk sanitization using encryption |
US7487320B2 (en) | 2004-12-15 | 2009-02-03 | International Business Machines Corporation | Apparatus and system for dynamically allocating main memory among a plurality of applications |
JP3810425B2 (ja) | 2004-12-16 | 2006-08-16 | 松下電器産業株式会社 | 改竄検出用データ生成方法、および改竄検出方法及び装置 |
US7366826B2 (en) | 2004-12-16 | 2008-04-29 | Sandisk Corporation | Non-volatile memory and method with multi-stream update tracking |
US20060136685A1 (en) | 2004-12-17 | 2006-06-22 | Sanrad Ltd. | Method and system to maintain data consistency over an internet small computer system interface (iSCSI) network |
US7739290B2 (en) | 2004-12-17 | 2010-06-15 | Sap (Ag) | System and method for object persistence |
KR100662256B1 (ko) | 2004-12-20 | 2006-12-28 | 한국전자통신연구원 | 낮은 프로세스 점유율을 가지는 객체기반 스토리지 장치및 그 제어 방법 |
KR100684887B1 (ko) | 2005-02-04 | 2007-02-20 | 삼성전자주식회사 | 플래시 메모리를 포함한 데이터 저장 장치 및 그것의 머지방법 |
US7409473B2 (en) | 2004-12-21 | 2008-08-05 | Sandisk Corporation | Off-chip data relocation |
US8122193B2 (en) | 2004-12-21 | 2012-02-21 | Samsung Electronics Co., Ltd. | Storage device and user device including the same |
KR100876084B1 (ko) | 2007-02-13 | 2008-12-26 | 삼성전자주식회사 | 플래시 저장 장치로 삭제 정보를 전달할 수 있는 컴퓨팅시스템 |
US8301810B2 (en) | 2004-12-21 | 2012-10-30 | Infortrend Technology, Inc. | SAS storage virtualization controller, subsystem and system using the same, and method therefor |
US20060136657A1 (en) | 2004-12-22 | 2006-06-22 | Intel Corporation | Embedding a filesystem into a non-volatile device |
US7392429B2 (en) | 2004-12-22 | 2008-06-24 | Microsoft Corporation | System and method for maintaining persistent state data |
US7472309B2 (en) | 2004-12-22 | 2008-12-30 | Intel Corporation | Methods and apparatus to write a file to a nonvolatile memory |
US20060143209A1 (en) * | 2004-12-29 | 2006-06-29 | Zimmer Vincent J | Remote management of a computer system |
US20060139330A1 (en) * | 2004-12-29 | 2006-06-29 | Kutch Patrick G | Adaptive mouse re-direction |
US20060143396A1 (en) | 2004-12-29 | 2006-06-29 | Mason Cabot | Method for programmer-controlled cache line eviction policy |
US7441081B2 (en) | 2004-12-29 | 2008-10-21 | Lsi Corporation | Write-back caching for disk drives |
US7254672B1 (en) | 2004-12-30 | 2007-08-07 | Storage Technology Corporation | Translation device driver for translating between disk device driver and tape device driver commands |
US7246195B2 (en) | 2004-12-30 | 2007-07-17 | Intel Corporation | Data storage management for flash memory devices |
CN1277213C (zh) * | 2004-12-31 | 2006-09-27 | 大唐微电子技术有限公司 | 一种闪存文件系统管理方法 |
KR100725390B1 (ko) | 2005-01-06 | 2007-06-07 | 삼성전자주식회사 | 수정 빈도를 고려하여 데이터를 비휘발성 캐쉬부에저장하는 장치 및 방법 |
KR100621631B1 (ko) | 2005-01-11 | 2006-09-13 | 삼성전자주식회사 | 반도체 디스크 제어 장치 |
US20060159456A1 (en) | 2005-01-18 | 2006-07-20 | Fujitsu Limited | System and method for conserving resources in an optical storage area network |
US7689599B1 (en) | 2005-01-31 | 2010-03-30 | Symantec Operating Corporation | Repair of inconsistencies between data and metadata stored on a temporal volume using transaction log replay |
US7877539B2 (en) | 2005-02-16 | 2011-01-25 | Sandisk Corporation | Direct data file storage in flash memories |
US20060184718A1 (en) | 2005-02-16 | 2006-08-17 | Sinclair Alan W | Direct file data programming and deletion in flash memories |
US9104315B2 (en) | 2005-02-04 | 2015-08-11 | Sandisk Technologies Inc. | Systems and methods for a mass data storage system having a file-based interface to a host and a non-file-based interface to secondary storage |
US20060184719A1 (en) | 2005-02-16 | 2006-08-17 | Sinclair Alan W | Direct data file storage implementation techniques in flash memories |
US7426649B2 (en) | 2005-02-09 | 2008-09-16 | International Business Machines Corporation | Power management via DIMM read operation limiter |
EP1851861A2 (en) | 2005-02-14 | 2007-11-07 | Koninklijke Philips Electronics N.V. | Block interleaving with memory table of reduced size |
US20060184736A1 (en) | 2005-02-17 | 2006-08-17 | Benhase Michael T | Apparatus, system, and method for storing modified data |
US20060190552A1 (en) * | 2005-02-24 | 2006-08-24 | Henze Richard H | Data retention system with a plurality of access protocols |
US7487343B1 (en) * | 2005-03-04 | 2009-02-03 | Netapp, Inc. | Method and apparatus for boot image selection and recovery via a remote management module |
US7747836B2 (en) | 2005-03-08 | 2010-06-29 | Netapp, Inc. | Integrated storage virtualization and switch system |
US7269534B2 (en) | 2005-03-11 | 2007-09-11 | Dell Products L.P. | Method to reduce IPMB traffic and improve performance for accessing sensor data |
US8446892B2 (en) | 2005-03-16 | 2013-05-21 | Qualcomm Incorporated | Channel structures for a quasi-orthogonal multiple-access communication system |
US20060212644A1 (en) | 2005-03-21 | 2006-09-21 | Acton John D | Non-volatile backup for data cache |
US8745011B2 (en) | 2005-03-22 | 2014-06-03 | International Business Machines Corporation | Method and system for scrubbing data within a data storage subsystem |
US7457166B2 (en) | 2005-03-31 | 2008-11-25 | Sandisk Corporation | Erase voltage manipulation in non-volatile memory for controlled shifts in threshold voltage |
US7522457B2 (en) | 2005-03-31 | 2009-04-21 | Sandisk Corporation | Systems for erase voltage manipulation in non-volatile memory for controlled shifts in threshold voltage |
US7408804B2 (en) | 2005-03-31 | 2008-08-05 | Sandisk Corporation | Systems for soft programming non-volatile memory utilizing individual verification and additional soft programming of subsets of memory cells |
US7254686B2 (en) | 2005-03-31 | 2007-08-07 | International Business Machines Corporation | Switching between mirrored and non-mirrored volumes |
US7463521B2 (en) | 2005-04-01 | 2008-12-09 | Sandisk Corporation | Method for non-volatile memory with managed execution of cached data |
US7451344B1 (en) | 2005-04-08 | 2008-11-11 | Western Digital Technologies, Inc. | Optimizing order of error recovery steps in a disk drive |
US7702928B2 (en) | 2005-04-08 | 2010-04-20 | Hewlett-Packard Development Company, L.P. | Memory module with on-board power-consumption monitoring |
KR101077992B1 (ko) | 2005-04-11 | 2011-10-31 | 엘지전자 주식회사 | 홈네트워크 제어 시스템 및 상기 홈네트워크 제어시스템에서의 데이터 흐름 제어 방법 |
US20060236061A1 (en) | 2005-04-18 | 2006-10-19 | Creek Path Systems | Systems and methods for adaptively deriving storage policy and configuration rules |
US9286198B2 (en) | 2005-04-21 | 2016-03-15 | Violin Memory | Method and system for storage of data in non-volatile media |
US8452929B2 (en) | 2005-04-21 | 2013-05-28 | Violin Memory Inc. | Method and system for storage of data in non-volatile media |
US7130960B1 (en) | 2005-04-21 | 2006-10-31 | Hitachi, Ltd. | System and method for managing disk space in a thin-provisioned storage subsystem |
US7620741B2 (en) * | 2005-04-22 | 2009-11-17 | Sun Microsystems, Inc. | Proxy-based device sharing |
US7702873B2 (en) | 2005-04-25 | 2010-04-20 | Network Appliance, Inc. | Managing common storage by allowing delayed allocation of storage after reclaiming reclaimable space in a logical volume |
US7366825B2 (en) | 2005-04-26 | 2008-04-29 | Microsoft Corporation | NAND flash memory management |
US7743210B1 (en) | 2005-04-29 | 2010-06-22 | Netapp, Inc. | System and method for implementing atomic cross-stripe write operations in a striped volume set |
US7523546B2 (en) | 2005-05-04 | 2009-04-28 | Nokia Corporation | Method for manufacturing a composite layer for an electronic device |
US7370261B2 (en) * | 2005-05-09 | 2008-05-06 | International Business Machines Corporation | Convolution-encoded raid with trellis-decode-rebuild |
US7707232B2 (en) | 2005-05-13 | 2010-04-27 | Microsoft Corporation | Implementation for collecting unmanaged memory |
JP2006324754A (ja) | 2005-05-17 | 2006-11-30 | Fujitsu Ltd | 最大事後確率復号方法及び復号装置 |
US20060265636A1 (en) | 2005-05-19 | 2006-11-23 | Klaus Hummler | Optimized testing of on-chip error correction circuit |
US7752381B2 (en) | 2005-05-24 | 2010-07-06 | Micron Technology, Inc. | Version based non-volatile memory translation layer |
KR101268984B1 (ko) | 2005-05-26 | 2013-05-29 | 삼성전자주식회사 | 메타 데이터를 제공하기 위한 애플리케이션이 포함된정보저장매체, 메타 데이터를 제공하는 장치 및 방법 |
JP2006331158A (ja) | 2005-05-27 | 2006-12-07 | Hitachi Ltd | ストレージシステム |
US20060293045A1 (en) | 2005-05-27 | 2006-12-28 | Ladue Christoph K | Evolutionary synthesis of a modem for band-limited non-linear channels |
US7383392B2 (en) | 2005-05-31 | 2008-06-03 | Hewlett-Packard Development Company, L.P. | Performing read-ahead operation for a direct input/output request |
US7536529B1 (en) | 2005-06-10 | 2009-05-19 | American Megatrends, Inc. | Method, system, apparatus, and computer-readable medium for provisioning space in a data storage system |
US7590799B2 (en) * | 2005-06-16 | 2009-09-15 | Seagate Technology Llc | OSD deterministic object fragmentation optimization in a disc drive |
US7444526B2 (en) | 2005-06-16 | 2008-10-28 | International Business Machines Corporation | Performance conserving method for reducing power consumption in a server system |
US7930589B2 (en) | 2005-06-17 | 2011-04-19 | Analog Devices, Inc. | Interrupt-responsive non-volatile memory system and method |
US20060294300A1 (en) | 2005-06-22 | 2006-12-28 | Seagate Technology Llc | Atomic cache transactions in a distributed storage system |
US20070027948A1 (en) | 2005-06-23 | 2007-02-01 | International Business Machines Corporation | Server blades connected via a wireless network |
US7590796B2 (en) | 2006-07-31 | 2009-09-15 | Metaram, Inc. | System and method for power management in memory systems |
US20080082763A1 (en) | 2006-10-02 | 2008-04-03 | Metaram, Inc. | Apparatus and method for power management of memory circuits by a system or component thereof |
US7533330B2 (en) * | 2005-06-27 | 2009-05-12 | Seagate Technology Llc | Redundancy for storage data structures |
US7340665B2 (en) | 2005-06-28 | 2008-03-04 | Seagate Technology Llc | Shared redundancy in error correcting code |
US7457910B2 (en) | 2005-06-29 | 2008-11-25 | Sandisk Corproation | Method and system for managing partitions in a storage device |
US20070006048A1 (en) | 2005-06-29 | 2007-01-04 | Intel Corporation | Method and apparatus for predicting memory failure in a memory system |
US7743217B2 (en) | 2005-06-29 | 2010-06-22 | Stmicroelectronics S.A. | Cache consistency in a multiprocessor system with shared memory |
US7797479B2 (en) * | 2005-06-30 | 2010-09-14 | Intel Corporation | Technique to write to a non-volatile memory |
US7774542B2 (en) | 2005-07-06 | 2010-08-10 | Ji Zhang | System and method for adaptive operation of storage capacities of RAID systems |
US7716387B2 (en) | 2005-07-14 | 2010-05-11 | Canon Kabushiki Kaisha | Memory control apparatus and method |
US7555676B2 (en) | 2005-07-18 | 2009-06-30 | Dell Products L.P. | Systems and methods for providing remotely accessible in-system emulation and/or debugging |
US7895398B2 (en) | 2005-07-19 | 2011-02-22 | Dell Products L.P. | System and method for dynamically adjusting the caching characteristics for each logical unit of a storage array |
US7991940B2 (en) * | 2005-07-25 | 2011-08-02 | Surf Communication Solutions Ltd. | Communication processor board |
JP5162846B2 (ja) | 2005-07-29 | 2013-03-13 | ソニー株式会社 | 記憶装置、コンピュータシステム、および記憶システム |
US20070028051A1 (en) | 2005-08-01 | 2007-02-01 | Arm Limited | Time and power reduction in cache accesses |
US7984084B2 (en) | 2005-08-03 | 2011-07-19 | SanDisk Technologies, Inc. | Non-volatile memory with scheduled reclaim operations |
US7552271B2 (en) | 2005-08-03 | 2009-06-23 | Sandisk Corporation | Nonvolatile memory with block management |
US7480766B2 (en) | 2005-08-03 | 2009-01-20 | Sandisk Corporation | Interfacing systems operating through a logical address space and on a direct data file basis |
US20070033371A1 (en) * | 2005-08-04 | 2007-02-08 | Andrew Dunshea | Method and apparatus for establishing a cache footprint for shared processor logical partitions |
US8417915B2 (en) | 2005-08-05 | 2013-04-09 | Arm Limited | Alias management within a virtually indexed and physically tagged cache memory |
US7480771B2 (en) | 2005-08-17 | 2009-01-20 | Sun Microsystems, Inc. | Conditional synchronization mechanisms allowing multiple store operations to become visible while a flagged memory location is owned and remains unchanged |
KR100739722B1 (ko) | 2005-08-20 | 2007-07-13 | 삼성전자주식회사 | 플래시 메모리 관리 방법 및 플래시 메모리 시스템 |
US7424577B2 (en) | 2005-08-26 | 2008-09-09 | Network Appliance, Inc. | Dynamic optimization of cache memory |
JP5008845B2 (ja) | 2005-09-01 | 2012-08-22 | 株式会社日立製作所 | ストレージシステムとストレージ装置及びその制御方法 |
US7580287B2 (en) | 2005-09-01 | 2009-08-25 | Micron Technology, Inc. | Program and read trim setting |
JP4701929B2 (ja) | 2005-09-02 | 2011-06-15 | 株式会社日立製作所 | ブート構成変更方法、管理サーバ、及び計算機システム |
JP2007071805A (ja) | 2005-09-09 | 2007-03-22 | Denso Corp | 力学量センサの製造方法 |
US7970015B2 (en) | 2005-09-12 | 2011-06-28 | Hob Gmbh & Co. Kg | Method for transmitting a message by compressed data transmission between a sender and a receiver via a data network |
US20070061508A1 (en) * | 2005-09-13 | 2007-03-15 | Quantum Corporation | Data storage cartridge with built-in tamper-resistant clock |
US7934049B2 (en) | 2005-09-14 | 2011-04-26 | Sandisk Corporation | Methods used in a secure yet flexible system architecture for secure devices with flash mass storage memory |
US7979394B2 (en) | 2005-09-20 | 2011-07-12 | Teradata Us, Inc. | Method of managing storage and retrieval of data objects |
US7523378B2 (en) | 2005-09-23 | 2009-04-21 | Intel Corporation | Techniques to determine integrity of information |
US7424666B2 (en) | 2005-09-26 | 2008-09-09 | Intel Corporation | Method and apparatus to detect/manage faults in a system |
KR100734629B1 (ko) | 2005-09-28 | 2007-07-03 | 한국전자통신연구원 | 부분 캐싱 방법 및 이를 이용한 적응형 콘텐츠 전송 방법 |
US7437510B2 (en) | 2005-09-30 | 2008-10-14 | Intel Corporation | Instruction-assisted cache management for efficient use of cache and memory |
US7652922B2 (en) | 2005-09-30 | 2010-01-26 | Mosaid Technologies Incorporated | Multiple independent serial link memory |
US8078588B2 (en) | 2005-10-10 | 2011-12-13 | Oracle International Corporation | Recoverable execution |
US7529905B2 (en) * | 2005-10-13 | 2009-05-05 | Sandisk Corporation | Method of storing transformed units of data in a memory system having fixed sized storage blocks |
CN1863081B (zh) * | 2005-10-14 | 2010-05-05 | 华为技术有限公司 | 基板管理控制器的管理系统和方法 |
US7631162B2 (en) | 2005-10-27 | 2009-12-08 | Sandisck Corporation | Non-volatile memory with adaptive handling of data writes |
US7457928B2 (en) | 2005-10-28 | 2008-11-25 | International Business Machines Corporation | Mirroring system memory in non-volatile random access memory (NVRAM) for fast power on/off cycling |
US20070100893A1 (en) | 2005-10-31 | 2007-05-03 | Sigmatel, Inc. | System and method for accessing data from a memory device |
US7516267B2 (en) | 2005-11-03 | 2009-04-07 | Intel Corporation | Recovering from a non-volatile memory failure |
US7634585B2 (en) | 2005-11-04 | 2009-12-15 | Sandisk Corporation | In-line cache using nonvolatile memory between host and disk device |
US7877554B2 (en) | 2005-11-04 | 2011-01-25 | Oracle America, Inc. | Method and system for block reallocation |
US8782186B2 (en) | 2005-11-12 | 2014-07-15 | Hewlett-Packard Development Company, L.P. | Systems and methods for addressing managed elements |
US7624239B2 (en) | 2005-11-14 | 2009-11-24 | Sandisk Corporation | Methods for the management of erase operations in non-volatile memories |
US7739472B2 (en) | 2005-11-22 | 2010-06-15 | Sandisk Corporation | Memory system for legacy hosts |
US7366808B2 (en) * | 2005-11-23 | 2008-04-29 | Hitachi, Ltd. | System, method and apparatus for multiple-protocol-accessible OSD storage subsystem |
US8112513B2 (en) | 2005-11-30 | 2012-02-07 | Microsoft Corporation | Multi-user display proxy server |
US7526614B2 (en) | 2005-11-30 | 2009-04-28 | Red Hat, Inc. | Method for tuning a cache |
US8799882B2 (en) | 2005-12-07 | 2014-08-05 | Microsoft Corporation | Compiler support for optimizing decomposed software transactional memory operations |
US7415575B1 (en) | 2005-12-08 | 2008-08-19 | Nvidia, Corporation | Shared cache with client-specific replacement policy |
US7877540B2 (en) | 2005-12-13 | 2011-01-25 | Sandisk Corporation | Logically-addressed file storage methods |
TW200722990A (en) | 2005-12-14 | 2007-06-16 | Inventec Corp | Power-on self test debugging system and method |
US7814479B2 (en) | 2005-12-14 | 2010-10-12 | International Business Machines Corporation | Simultaneous download to multiple targets |
US7376034B2 (en) | 2005-12-15 | 2008-05-20 | Stec, Inc. | Parallel data storage system |
JP4807063B2 (ja) | 2005-12-20 | 2011-11-02 | ソニー株式会社 | 復号装置、制御方法、およびプログラム |
US7234964B1 (en) * | 2005-12-20 | 2007-06-26 | International Business Machines Corporation | Systems, methods, and media for providing visual indication of a blade configuration |
US8032745B2 (en) * | 2005-12-20 | 2011-10-04 | International Business Machines Corporation | Authentication of I2C bus transactions |
US7793068B2 (en) | 2005-12-21 | 2010-09-07 | Sandisk Corporation | Dual mode access for non-volatile storage devices |
US20070156998A1 (en) | 2005-12-21 | 2007-07-05 | Gorobets Sergey A | Methods for memory allocation in non-volatile memories with a directly mapped file storage system |
US20070143561A1 (en) | 2005-12-21 | 2007-06-21 | Gorobets Sergey A | Methods for adaptive file data handling in non-volatile memories with a directly mapped file storage system |
US20070143560A1 (en) | 2005-12-21 | 2007-06-21 | Gorobets Sergey A | Non-volatile memories with memory allocation for a directly mapped file storage system |
US20070143566A1 (en) | 2005-12-21 | 2007-06-21 | Gorobets Sergey A | Non-volatile memories with data alignment in a directly mapped file storage system |
US7747837B2 (en) | 2005-12-21 | 2010-06-29 | Sandisk Corporation | Method and system for accessing non-volatile storage devices |
US20070143567A1 (en) | 2005-12-21 | 2007-06-21 | Gorobets Sergey A | Methods for data alignment in non-volatile memories with a directly mapped file storage system |
US7831783B2 (en) | 2005-12-22 | 2010-11-09 | Honeywell International Inc. | Effective wear-leveling and concurrent reclamation method for embedded linear flash file systems |
US7440455B2 (en) * | 2005-12-22 | 2008-10-21 | Level 3 Communications, Llc | Registration of multiple VoIP devices |
US7907600B2 (en) | 2005-12-23 | 2011-03-15 | Qualcomm Incorporated | System and method for optimizing robust header compression (ROHC) in high delay variance environment |
US7673111B2 (en) * | 2005-12-23 | 2010-03-02 | Intel Corporation | Memory system with both single and consolidated commands |
US20070150663A1 (en) | 2005-12-27 | 2007-06-28 | Abraham Mendelson | Device, system and method of multi-state cache coherence scheme |
US8713551B2 (en) | 2006-01-03 | 2014-04-29 | International Business Machines Corporation | Apparatus, system, and method for non-interruptively updating firmware on a redundant hardware controller |
US7849454B2 (en) | 2006-01-13 | 2010-12-07 | Dell Products L.P. | Automatic firmware corruption recovery and update |
US7613898B2 (en) | 2006-01-17 | 2009-11-03 | Globalfoundries Inc. | Virtualizing an IOMMU |
US7793059B2 (en) | 2006-01-18 | 2010-09-07 | Apple Inc. | Interleaving policies for flash memory |
US8055979B2 (en) | 2006-01-20 | 2011-11-08 | Marvell World Trade Ltd. | Flash memory with coding and signal processing |
US7827442B2 (en) * | 2006-01-23 | 2010-11-02 | Slt Logic Llc | Shelf management controller with hardware/software implemented dual redundant configuration |
TWM298188U (en) | 2006-01-23 | 2006-09-21 | Genesys Logic Inc | Control device for accessing Non-Volatile memory |
US9002795B2 (en) | 2006-01-26 | 2015-04-07 | Seagate Technology Llc | Object-based data storage device |
US7676666B2 (en) | 2006-02-02 | 2010-03-09 | Dell Products L.P. | Virtual BIOS firmware hub |
KR100746225B1 (ko) | 2006-02-13 | 2007-08-03 | 삼성전자주식회사 | 반도체 메모리 장치 및 이를 구비한 메모리 시스템 |
KR100746033B1 (ko) | 2006-02-17 | 2007-08-06 | 삼성전자주식회사 | 무결성 측정 장치 및 방법 |
US20070220369A1 (en) * | 2006-02-21 | 2007-09-20 | International Business Machines Corporation | Fault isolation and availability mechanism for multi-processor system |
KR100781520B1 (ko) | 2006-02-24 | 2007-12-03 | 삼성전자주식회사 | 비휘발성 메모리가 캐쉬로 사용되는 저장 장치 및 이를위한 맵핑 정보 복구 방법 |
US8166539B2 (en) | 2006-02-24 | 2012-04-24 | Dell Products L.P. | Authentication of baseboard management controller users in a blade server system |
WO2007097026A1 (ja) | 2006-02-27 | 2007-08-30 | Fujitsu Limited | キャッシュ制御装置およびキャッシュ制御プログラム |
KR20070089460A (ko) | 2006-02-28 | 2007-08-31 | 삼성전자주식회사 | 우선 순위에 따른 비휘발성 메모리의 연산 처리 장치 및방법 |
US7852873B2 (en) | 2006-03-01 | 2010-12-14 | Lantronix, Inc. | Universal computer management interface |
JP2007233903A (ja) * | 2006-03-03 | 2007-09-13 | Hitachi Ltd | 記憶制御装置及び記憶制御装置のデータ回復方法 |
US7747925B2 (en) | 2006-03-06 | 2010-06-29 | Fujifilm Corporation | Apparatus and method for error correction code striping |
US7344439B2 (en) | 2006-03-06 | 2008-03-18 | International Business Machines Corporation | System, method, and apparatus for distributing air in a blade server |
US20070208790A1 (en) | 2006-03-06 | 2007-09-06 | Reuter James M | Distributed data-storage system |
JP2007240904A (ja) | 2006-03-09 | 2007-09-20 | Hitachi Ltd | プラズマディスプレイ装置 |
US7421552B2 (en) | 2006-03-17 | 2008-09-02 | Emc Corporation | Techniques for managing data within a data storage system utilizing a flash-based memory vault |
US7840398B2 (en) * | 2006-03-28 | 2010-11-23 | Intel Corporation | Techniques for unified management communication for virtualization systems |
US20070245217A1 (en) | 2006-03-28 | 2007-10-18 | Stmicroelectronics S.R.L. | Low-density parity check decoding |
US7562180B2 (en) | 2006-03-28 | 2009-07-14 | Nokia Corporation | Method and device for reduced read latency of non-volatile memory |
US7551492B2 (en) | 2006-03-29 | 2009-06-23 | Mosaid Technologies, Inc. | Non-volatile semiconductor memory with page erase |
US7640249B2 (en) | 2006-03-29 | 2009-12-29 | Sap (Ag) | System and method for transactional session management |
EP2008164A2 (en) | 2006-03-30 | 2008-12-31 | Silicon Image, Inc. | Inter-port communication in a multi- port memory device |
US7831778B2 (en) | 2006-03-30 | 2010-11-09 | Silicon Image, Inc. | Shared nonvolatile memory architecture |
US7676628B1 (en) | 2006-03-31 | 2010-03-09 | Emc Corporation | Methods, systems, and computer program products for providing access to shared storage by computing grids and clusters with large numbers of nodes |
JP4733138B2 (ja) * | 2006-03-31 | 2011-07-27 | パナソニック株式会社 | コマンド出力制御装置、コマンド出力制御方法およびプログラム |
US20070233937A1 (en) | 2006-03-31 | 2007-10-04 | Coulson Richard L | Reliability of write operations to a non-volatile memory |
TW200739349A (en) | 2006-04-12 | 2007-10-16 | Giga Byte Tech Co Ltd | Volatile storage device and serial connection type mixed storage device having the same |
US7567472B2 (en) | 2006-04-12 | 2009-07-28 | Micron Technology, Inc. | Memory block testing |
JP4787055B2 (ja) | 2006-04-12 | 2011-10-05 | 富士通株式会社 | 情報分割記録機能を持つ情報処理装置 |
US7451264B2 (en) * | 2006-04-13 | 2008-11-11 | Sandisk Corporation | Cycle count storage methods |
US7395377B2 (en) | 2006-04-20 | 2008-07-01 | International Business Machines Corporation | Method and system for adaptive back-off and advance for non-volatile storage (NVS) occupancy level management |
US7636829B2 (en) | 2006-05-02 | 2009-12-22 | Intel Corporation | System and method for allocating and deallocating memory within transactional code |
US7509460B2 (en) | 2006-05-04 | 2009-03-24 | Sun Microsystems, Inc. | DRAM remote access cache in local memory in a distributed shared memory system |
US20070261030A1 (en) | 2006-05-04 | 2007-11-08 | Gaurav Wadhwa | Method and system for tracking and prioritizing applications |
US20070271468A1 (en) | 2006-05-05 | 2007-11-22 | Mckenney Paul E | Method and Apparatus for Maintaining Data Integrity When Switching Between Different Data Protection Methods |
US7653778B2 (en) * | 2006-05-08 | 2010-01-26 | Siliconsystems, Inc. | Systems and methods for measuring the useful life of solid-state storage devices |
US7653832B2 (en) | 2006-05-08 | 2010-01-26 | Emc Corporation | Storage array virtualization using a storage block mapping protocol client and server |
US8156403B2 (en) | 2006-05-12 | 2012-04-10 | Anobit Technologies Ltd. | Combined distortion estimation and error correction coding for memory devices |
US20070271495A1 (en) | 2006-05-18 | 2007-11-22 | Ian Shaeffer | System to detect and identify errors in control information, read data and/or write data |
US7464240B2 (en) | 2006-05-23 | 2008-12-09 | Data Ram, Inc. | Hybrid solid state disk drive with controller |
JP4681505B2 (ja) | 2006-05-23 | 2011-05-11 | 株式会社日立製作所 | 計算機システム、管理計算機及びプログラム配布方法 |
US7424587B2 (en) | 2006-05-23 | 2008-09-09 | Dataram, Inc. | Methods for managing data writes and reads to a hybrid solid-state disk drive |
WO2007138547A2 (en) | 2006-05-30 | 2007-12-06 | Philips Intellectual Property & Standards Gmbh | Detuning a radio-frequency coil |
US8453147B2 (en) | 2006-06-05 | 2013-05-28 | Cisco Technology, Inc. | Techniques for reducing thread overhead for systems with multiple multi-threaded processors |
US20080005222A1 (en) | 2006-06-07 | 2008-01-03 | Lambert Timothy M | System and Method for Server Information Handling System Management Through Local I/O Devices |
US7558913B2 (en) | 2006-06-20 | 2009-07-07 | Microsoft Corporation | Atomic commit of cache transfer with staging area |
US7650458B2 (en) | 2006-06-23 | 2010-01-19 | Microsoft Corporation | Flash memory driver |
US7694103B1 (en) | 2006-06-23 | 2010-04-06 | Emc Corporation | Efficient use of memory and accessing of stored records |
US8307148B2 (en) | 2006-06-23 | 2012-11-06 | Microsoft Corporation | Flash management techniques |
US8429242B1 (en) | 2006-06-26 | 2013-04-23 | Emc Corporation | Methods and apparatus for providing content |
US7853958B2 (en) | 2006-06-28 | 2010-12-14 | Intel Corporation | Virtual machine monitor management from a management service processor in the host processing platform |
US7660937B2 (en) * | 2006-06-28 | 2010-02-09 | Hewlett-Packard Development Company, L.P. | Emulating a USB host controller |
JP4842719B2 (ja) * | 2006-06-28 | 2011-12-21 | 株式会社日立製作所 | ストレージシステム及びそのデータ保護方法 |
US7810013B2 (en) | 2006-06-30 | 2010-10-05 | Intel Corporation | Memory device that reflects back error detection signals |
US7970989B2 (en) | 2006-06-30 | 2011-06-28 | Intel Corporation | Write ordering on disk cached platforms |
US7644206B2 (en) * | 2006-06-30 | 2010-01-05 | Seagate Technology Llc | Command queue ordering by positionally pushing access commands |
GB0613192D0 (en) | 2006-07-01 | 2006-08-09 | Ibm | Methods, apparatus and computer programs for managing persistence |
US7721059B2 (en) | 2006-07-06 | 2010-05-18 | Nokia Corporation | Performance optimization in solid-state media |
US20080052377A1 (en) | 2006-07-11 | 2008-02-28 | Robert Light | Web-Based User-Dependent Customer Service Interaction with Co-Browsing |
US7783956B2 (en) * | 2006-07-12 | 2010-08-24 | Cronera Systems Incorporated | Data recorder |
US7395390B2 (en) | 2006-07-12 | 2008-07-01 | Inventec Corporation | System for backing up cache memory in a double backup server structure |
US8046629B1 (en) * | 2006-07-24 | 2011-10-25 | Marvell World Trade Ltd. | File server for redundant array of independent disks (RAID) system |
CN102522118A (zh) | 2006-07-31 | 2012-06-27 | 株式会社东芝 | 控制非易失性存储器的方法 |
US7519830B2 (en) | 2006-08-03 | 2009-04-14 | Motorola, Inc. | Secure storage of data |
US8046660B2 (en) | 2006-08-07 | 2011-10-25 | Marvell World Trade Ltd. | System and method for correcting errors in non-volatile memory using product codes |
US8427489B2 (en) * | 2006-08-10 | 2013-04-23 | Avocent Huntsville Corporation | Rack interface pod with intelligent platform control |
US7594144B2 (en) | 2006-08-14 | 2009-09-22 | International Business Machines Corporation | Handling fatal computer hardware errors |
US7478299B2 (en) * | 2006-08-14 | 2009-01-13 | International Business Machines Corporation | Processor fault isolation |
US20080043769A1 (en) | 2006-08-16 | 2008-02-21 | Tyan Computer Corporation | Clustering system and system management architecture thereof |
US7899800B2 (en) | 2006-08-18 | 2011-03-01 | Isilon Systems, Inc. | Systems and methods for providing nonlinear journaling |
KR101128234B1 (ko) | 2006-08-23 | 2012-03-23 | 엘지전자 주식회사 | 메모리 접근 제어 장치 및 방법 |
US7676625B2 (en) | 2006-08-23 | 2010-03-09 | Sun Microsystems, Inc. | Cross-coupled peripheral component interconnect express switch |
US7500078B2 (en) | 2006-08-25 | 2009-03-03 | Dell Products L.P. | Thermal control of memory modules using proximity information |
US8060806B2 (en) | 2006-08-27 | 2011-11-15 | Anobit Technologies Ltd. | Estimation of non-linear distortion in memory devices |
US7788513B2 (en) | 2006-08-29 | 2010-08-31 | Hewlett-Packard Development Company, L.P. | Method of reducing power consumption of a computing system by evacuating selective platform memory components thereof |
US7870306B2 (en) | 2006-08-31 | 2011-01-11 | Cisco Technology, Inc. | Shared memory message switch and cache |
JP4932390B2 (ja) | 2006-08-31 | 2012-05-16 | 株式会社日立製作所 | 仮想化システム及び領域割当て制御方法 |
JP4452261B2 (ja) | 2006-09-12 | 2010-04-21 | 株式会社日立製作所 | ストレージシステムの論理ボリューム管理方法、論理ボリューム管理プログラム、及びストレージシステム |
US7774392B2 (en) | 2006-09-15 | 2010-08-10 | Sandisk Corporation | Non-volatile memory with management of a pool of update memory blocks based on each block's activity and data order |
US20080077767A1 (en) | 2006-09-27 | 2008-03-27 | Khosravi Hormuzd M | Method and apparatus for secure page swapping in virtual memory systems |
US7761625B2 (en) | 2006-09-28 | 2010-07-20 | Virident Systems, Inc. | Methods for main memory with non-volatile type memory modules, and related technologies |
US7752412B2 (en) | 2006-09-29 | 2010-07-06 | Sandisk Corporation | Methods of managing file allocation table information |
US7573744B2 (en) | 2006-09-29 | 2009-08-11 | Kabushiki Kaisha Toshiba | Semiconductor memory device having different capacity areas |
US7630225B2 (en) | 2006-09-29 | 2009-12-08 | Sandisk Corporation | Apparatus combining once-writeable and rewriteable information storage to support data processing |
US20080133861A1 (en) | 2006-10-05 | 2008-06-05 | Holt John M | Silent memory reclamation |
JP4942446B2 (ja) | 2006-10-11 | 2012-05-30 | 株式会社日立製作所 | ストレージ装置及びその制御方法 |
US7535766B2 (en) | 2006-10-13 | 2009-05-19 | Sandisk Corporation | Systems for partitioned soft programming in non-volatile memory |
US7499317B2 (en) | 2006-10-13 | 2009-03-03 | Sandisk Corporation | System for partitioned erase and erase verification in a non-volatile memory to compensate for capacitive coupling |
US7495954B2 (en) | 2006-10-13 | 2009-02-24 | Sandisk Corporation | Method for partitioned erase and erase verification to compensate for capacitive coupling effects in non-volatile memory |
US7499338B2 (en) | 2006-10-13 | 2009-03-03 | Sandisk Corporation | Partitioned soft programming in non-volatile memory |
US9465823B2 (en) | 2006-10-19 | 2016-10-11 | Oracle International Corporation | System and method for data de-duplication |
KR100771519B1 (ko) | 2006-10-23 | 2007-10-30 | 삼성전자주식회사 | 플래시 메모리를 포함한 메모리 시스템 및 그것의 머지방법 |
KR100843543B1 (ko) | 2006-10-25 | 2008-07-04 | 삼성전자주식회사 | 플래시 메모리 장치를 포함하는 시스템 및 그것의 데이터복구 방법 |
JP4437489B2 (ja) | 2006-10-25 | 2010-03-24 | 株式会社日立製作所 | 揮発性キャッシュメモリと不揮発性メモリとを備えたストレージシステム |
US7958280B2 (en) | 2006-10-27 | 2011-06-07 | Stec, Inc. | Parallel data transfer in solid-state storage |
US7822887B2 (en) | 2006-10-27 | 2010-10-26 | Stec, Inc. | Multi-channel solid-state storage system |
US8122196B2 (en) | 2006-10-30 | 2012-02-21 | Netapp, Inc. | System and procedure for rapid decompression and/or decryption of securely stored data |
US7685178B2 (en) | 2006-10-31 | 2010-03-23 | Netapp, Inc. | System and method for examining client generated content stored on a data container exported by a storage system |
KR100780773B1 (ko) | 2006-11-03 | 2007-11-30 | 주식회사 하이닉스반도체 | 플래시 메모리소자의 프로그램 시작 바이어스 설정방법 및이를 이용한 프로그램 방법 |
US7606681B2 (en) | 2006-11-03 | 2009-10-20 | Air Products And Chemicals, Inc. | System and method for process monitoring |
US20080109647A1 (en) | 2006-11-07 | 2008-05-08 | Lee Merrill Gavens | Memory controllers for performing resilient firmware upgrades to a functioning memory |
US7970859B2 (en) * | 2006-11-09 | 2011-06-28 | Raritan Americas, Inc. | Architecture and method for remote platform control management |
US7567462B2 (en) | 2006-11-16 | 2009-07-28 | Micron Technology, Inc. | Method and system for selectively limiting peak power consumption during programming or erase of non-volatile memory devices |
US7877358B2 (en) | 2006-11-21 | 2011-01-25 | Microsoft Corporation | Replacing system hardware |
US20080120469A1 (en) | 2006-11-22 | 2008-05-22 | International Business Machines Corporation | Systems and Arrangements for Cache Management |
CN100530070C (zh) | 2006-11-24 | 2009-08-19 | 骆建军 | 基于flash的硬盘 |
US7904647B2 (en) | 2006-11-27 | 2011-03-08 | Lsi Corporation | System for optimizing the performance and reliability of a storage controller cache offload circuit |
US7924648B2 (en) | 2006-11-28 | 2011-04-12 | Anobit Technologies Ltd. | Memory power and performance management |
US7783830B2 (en) | 2006-11-29 | 2010-08-24 | Seagate Technology Llc | Solid state device pattern for non-solid state storage media |
US7624235B2 (en) | 2006-11-30 | 2009-11-24 | Apple Inc. | Cache used both as cache and staging buffer |
US8595573B2 (en) | 2006-12-03 | 2013-11-26 | Apple Inc. | Automatic defect management in memory devices |
JP4923990B2 (ja) | 2006-12-04 | 2012-04-25 | 株式会社日立製作所 | フェイルオーバ方法、およびその計算機システム。 |
US9116823B2 (en) | 2006-12-06 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for adaptive error-correction coding |
US8443134B2 (en) | 2006-12-06 | 2013-05-14 | Fusion-Io, Inc. | Apparatus, system, and method for graceful cache device degradation |
US9104599B2 (en) | 2007-12-06 | 2015-08-11 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for destaging cached data |
KR101532951B1 (ko) | 2006-12-06 | 2015-07-09 | 론지튜드 엔터프라이즈 플래시 에스.에이.알.엘. | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 |
TW200825762A (en) | 2006-12-06 | 2008-06-16 | Inventec Corp | Apparatus and method for computer management |
US8074011B2 (en) | 2006-12-06 | 2011-12-06 | Fusion-Io, Inc. | Apparatus, system, and method for storage space recovery after reaching a read count limit |
CN101636712B (zh) | 2006-12-06 | 2016-04-13 | 才智知识产权控股公司(2) | 在存储控制器内服务对象请求的装置、系统和方法 |
US8935302B2 (en) | 2006-12-06 | 2015-01-13 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for data block usage information synchronization for a non-volatile storage volume |
US9495241B2 (en) | 2006-12-06 | 2016-11-15 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for adaptive data storage |
US8489817B2 (en) | 2007-12-06 | 2013-07-16 | Fusion-Io, Inc. | Apparatus, system, and method for caching data |
US8161353B2 (en) | 2007-12-06 | 2012-04-17 | Fusion-Io, Inc. | Apparatus, system, and method for validating that a correct data segment is read from a data storage device |
US8151082B2 (en) | 2007-12-06 | 2012-04-03 | Fusion-Io, Inc. | Apparatus, system, and method for converting a storage request into an append data storage command |
US20080140737A1 (en) * | 2006-12-08 | 2008-06-12 | Apple Computer, Inc. | Dynamic memory management |
US20080140918A1 (en) | 2006-12-11 | 2008-06-12 | Pantas Sutardja | Hybrid non-volatile solid state memory system |
US7930425B2 (en) | 2006-12-11 | 2011-04-19 | International Business Machines Corporation | Method of effectively establishing and maintaining communication linkages with a network interface controller |
TW200825696A (en) | 2006-12-15 | 2008-06-16 | Inventec Corp | Power management system |
US7660911B2 (en) | 2006-12-20 | 2010-02-09 | Smart Modular Technologies, Inc. | Block-based data striping to flash memory |
US7913051B1 (en) | 2006-12-22 | 2011-03-22 | Emc Corporation | Methods and apparatus for increasing the storage capacity of a zone of a storage system |
US20080155051A1 (en) * | 2006-12-23 | 2008-06-26 | Simpletech, Inc. | Direct file transfer system and method for a computer network |
KR101150654B1 (ko) | 2006-12-27 | 2012-07-10 | 인텔 코포레이션 | 비휘발성 메모리 상의 데이터 관리 방법 및 기계 판독 가능한 매체 |
US20080162787A1 (en) | 2006-12-28 | 2008-07-03 | Andrew Tomlin | System for block relinking |
US8060482B2 (en) | 2006-12-28 | 2011-11-15 | Intel Corporation | Efficient and consistent software transactional memory |
KR100811274B1 (ko) | 2006-12-28 | 2008-03-07 | 주식회사 하이닉스반도체 | 낸드형 플래쉬 메모리소자의 데이터 소거방법 |
US7978541B2 (en) | 2007-01-02 | 2011-07-12 | Marvell World Trade Ltd. | High speed interface for multi-level memory |
US8880480B2 (en) | 2007-01-03 | 2014-11-04 | Oracle International Corporation | Method and apparatus for data rollback |
US7769945B2 (en) | 2007-01-18 | 2010-08-03 | Sandisk Il Ltd. | Method and system for facilitating fast wake-up of a flash memory system |
US7564722B2 (en) | 2007-01-22 | 2009-07-21 | Micron Technology, Inc. | Memory system and method having volatile and non-volatile memory devices at same hierarchical level |
JP4813385B2 (ja) | 2007-01-29 | 2011-11-09 | 株式会社日立製作所 | ストレージシステムの複数の論理リソースを制御する制御装置 |
US20080183968A1 (en) | 2007-01-30 | 2008-07-31 | Chi-Ting Huang | Computer system having cache system directly connected to nonvolatile storage device and method thereof |
KR100817087B1 (ko) | 2007-02-13 | 2008-03-27 | 삼성전자주식회사 | 플래시 메모리를 구비하는 스토리지 장치에서의 버퍼 캐시운용 방법 |
US20080201535A1 (en) | 2007-02-21 | 2008-08-21 | Hitachi, Ltd. | Method and Apparatus for Provisioning Storage Volumes |
US20080205286A1 (en) | 2007-02-26 | 2008-08-28 | Inventec Corporation | Test system using local loop to establish connection to baseboard management control and method therefor |
US8380944B2 (en) | 2007-03-01 | 2013-02-19 | Douglas Dumitru | Fast block device and methodology |
US8190778B2 (en) * | 2007-03-06 | 2012-05-29 | Intel Corporation | Method and apparatus for network filtering and firewall protection on a secure partition |
US7499320B2 (en) | 2007-03-07 | 2009-03-03 | Sandisk Corporation | Non-volatile memory with cache page copy |
US7502255B2 (en) | 2007-03-07 | 2009-03-10 | Sandisk Corporation | Method for cache page copy in a non-volatile memory |
WO2008111058A2 (en) | 2007-03-12 | 2008-09-18 | Anobit Technologies Ltd. | Adaptive estimation of memory cell read thresholds |
US8490148B2 (en) * | 2007-03-12 | 2013-07-16 | Citrix Systems, Inc | Systems and methods for managing application security profiles |
US20080228862A1 (en) * | 2007-03-12 | 2008-09-18 | Timothy Mackey | Systems and Methods for End-User Experience Monitoring |
US20080229046A1 (en) | 2007-03-13 | 2008-09-18 | Microsoft Corporation | Unified support for solid state storage |
KR101395778B1 (ko) | 2007-03-14 | 2014-05-19 | 삼성전자주식회사 | 메모리 카드 및 그것을 포함하는 메모리 시스템 그리고그것의 동작 방법 |
US20080229045A1 (en) | 2007-03-16 | 2008-09-18 | Lsi Logic Corporation | Storage system provisioning architecture |
US7599967B2 (en) | 2007-03-20 | 2009-10-06 | Oracle International Corporation | No data loss system with reduced commit latency |
US9152349B2 (en) | 2007-03-23 | 2015-10-06 | Emc Corporation | Automated information life-cycle management with thin provisioning |
US7908501B2 (en) | 2007-03-23 | 2011-03-15 | Silicon Image, Inc. | Progressive power control of a multi-port memory device |
US8135900B2 (en) | 2007-03-28 | 2012-03-13 | Kabushiki Kaisha Toshiba | Integrated memory management and memory management method |
WO2008117520A1 (ja) | 2007-03-28 | 2008-10-02 | Panasonic Corporation | メモリコントローラ、不揮発性メモリシステムおよびホスト装置 |
US9632870B2 (en) | 2007-03-29 | 2017-04-25 | Violin Memory, Inc. | Memory system with multiple striping of raid groups and method for performing the same |
US20080244181A1 (en) | 2007-03-30 | 2008-10-02 | Michael Walz | Dynamic run-time cache size management |
JP2008250961A (ja) | 2007-03-30 | 2008-10-16 | Nec Corp | 記憶媒体の制御装置、データ記憶装置、データ記憶システム、方法、及び制御プログラム |
US20080243966A1 (en) | 2007-04-02 | 2008-10-02 | Croisettier Ramanakumari M | System and method for managing temporary storage space of a database management system |
WO2008131058A2 (en) | 2007-04-17 | 2008-10-30 | Rambus Inc. | Hybrid volatile and non-volatile memory device |
US8429677B2 (en) | 2007-04-19 | 2013-04-23 | Microsoft Corporation | Composite solid state drive identification and optimization technologies |
US9207876B2 (en) | 2007-04-19 | 2015-12-08 | Microsoft Technology Licensing, Llc | Remove-on-delete technologies for solid state drive optimization |
US7876621B2 (en) | 2007-04-23 | 2011-01-25 | Sandisk Il Ltd. | Adaptive dynamic reading of flash memories |
US7853759B2 (en) | 2007-04-23 | 2010-12-14 | Microsoft Corporation | Hints model for optimization of storage devices connected to host and write optimization schema for storage devices |
US7606079B2 (en) | 2007-04-25 | 2009-10-20 | Sandisk Corporation | Reducing power consumption during read operations in non-volatile storage |
JP2008276646A (ja) | 2007-05-02 | 2008-11-13 | Hitachi Ltd | ストレージ装置及びストレージ装置におけるデータの管理方法 |
US9009452B2 (en) | 2007-05-14 | 2015-04-14 | International Business Machines Corporation | Computing system with transactional memory using millicode assists |
US8175099B2 (en) * | 2007-05-14 | 2012-05-08 | Microsoft Corporation | Embedded system development platform |
US7752360B2 (en) | 2007-05-16 | 2010-07-06 | Nuova Systems, Inc. | Method and system to map virtual PCIe I/O devices and resources to a standard I/O bus |
US8301833B1 (en) | 2007-06-01 | 2012-10-30 | Netlist, Inc. | Non-volatile memory module |
US20080303692A1 (en) * | 2007-06-08 | 2008-12-11 | Tomonori Hirai | Method and System for Assigning Identity Addresses to Local Management Modules |
US9396103B2 (en) | 2007-06-08 | 2016-07-19 | Sandisk Technologies Llc | Method and system for storage address re-mapping for a memory device |
US20080320253A1 (en) | 2007-06-19 | 2008-12-25 | Andrew Tomlin | Memory device with circuitry for writing data of an atomic transaction |
US7752389B1 (en) * | 2007-06-20 | 2010-07-06 | Emc Corporation | Techniques for determining physical data layout of RAID devices |
US7865761B1 (en) | 2007-06-28 | 2011-01-04 | Emc Corporation | Accessing multiple non-volatile semiconductor memory modules in an uneven manner |
US7925936B1 (en) | 2007-07-13 | 2011-04-12 | Anobit Technologies Ltd. | Memory device with non-uniform programming levels |
US8074034B2 (en) | 2007-07-25 | 2011-12-06 | Agiga Tech Inc. | Hybrid nonvolatile ram |
US8046546B2 (en) | 2007-07-25 | 2011-10-25 | AGIGA Tech | Variable partitioning in a hybrid memory subsystem |
US8028198B2 (en) | 2007-07-30 | 2011-09-27 | Micron Technology, Inc. | Devices, methods, and apparatuses for detection, sensing, and reporting functionality for semiconductor memory |
US8001444B2 (en) | 2007-08-08 | 2011-08-16 | Intel Corporation | ECC functional block placement in a multi-channel mass storage device |
US7970919B1 (en) | 2007-08-13 | 2011-06-28 | Duran Paul A | Apparatus and system for object-based storage solid-state drive and method for configuring same |
US8850154B2 (en) * | 2007-09-11 | 2014-09-30 | 2236008 Ontario Inc. | Processing system having memory partitioning |
US20090070526A1 (en) | 2007-09-12 | 2009-03-12 | Tetrick R Scott | Using explicit disk block cacheability attributes to enhance i/o caching efficiency |
US7873803B2 (en) | 2007-09-25 | 2011-01-18 | Sandisk Corporation | Nonvolatile memory with self recovery |
TWI366828B (en) | 2007-09-27 | 2012-06-21 | Phison Electronics Corp | Wear leveling method and controller using the same |
US7934072B2 (en) | 2007-09-28 | 2011-04-26 | Lenovo (Singapore) Pte. Ltd. | Solid state storage reclamation apparatus and method |
US7773413B2 (en) | 2007-10-08 | 2010-08-10 | Anobit Technologies Ltd. | Reliable data storage in analog memory cells in the presence of temperature variations |
US8621605B2 (en) | 2007-10-09 | 2013-12-31 | International Business Machines Corporation | Method for reducing the time to diagnose the cause of unexpected changes to system files |
TWI578330B (zh) | 2007-10-09 | 2017-04-11 | A-Data Technology Co Ltd | Solid state semiconductor storage device with temperature control function and control method thereof |
KR101433859B1 (ko) | 2007-10-12 | 2014-08-27 | 삼성전자주식회사 | 불휘발성 메모리 시스템 및 그것의 파일 데이터 관리 방법 |
US8346912B2 (en) * | 2007-10-15 | 2013-01-01 | Dell Products, Lp | System and method of emulating a network controller within an information handling system |
WO2009052525A1 (en) | 2007-10-19 | 2009-04-23 | Virident Systems, Inc. | Managing memory systems containing components with asymmetric characteristics |
US20090113235A1 (en) * | 2007-10-30 | 2009-04-30 | Selinger Robert D | Raid with redundant parity |
ES2493015T3 (es) | 2007-11-05 | 2014-09-11 | Cellular Communications Equipment Llc | Método, aparato y soporte legible por ordenador para la transmisión de informes de estado de buffer |
US7840839B2 (en) | 2007-11-06 | 2010-11-23 | Vmware, Inc. | Storage handling for fault tolerance in virtual machines |
US8572310B2 (en) | 2007-11-06 | 2013-10-29 | Samsung Electronics Co., Ltd. | Invalidating storage area of non-volatile storage medium based on metadata |
US8548953B2 (en) | 2007-11-12 | 2013-10-01 | F5 Networks, Inc. | File deduplication using storage tiers |
JP2009122850A (ja) | 2007-11-13 | 2009-06-04 | Toshiba Corp | ブロックデバイス制御装置及びアクセス範囲管理方法 |
US8131927B2 (en) | 2007-11-30 | 2012-03-06 | Hitachi, Ltd. | Fast accessible compressed thin provisioning volume |
US8416657B2 (en) * | 2007-12-03 | 2013-04-09 | Mediatek Inc. | Method and system for managing data from host to optical disc |
US8001334B2 (en) | 2007-12-06 | 2011-08-16 | Silicon Image, Inc. | Bank sharing and refresh in a shared multi-port memory device |
US8195912B2 (en) | 2007-12-06 | 2012-06-05 | Fusion-io, Inc | Apparatus, system, and method for efficient mapping of virtual and physical addresses |
US7836226B2 (en) | 2007-12-06 | 2010-11-16 | Fusion-Io, Inc. | Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment |
JP5238235B2 (ja) | 2007-12-07 | 2013-07-17 | 株式会社日立製作所 | 管理装置及び管理方法 |
US9727452B2 (en) | 2007-12-14 | 2017-08-08 | Virident Systems, Llc | Distributing metadata across multiple different disruption regions within an asymmetric memory system |
JP5428288B2 (ja) | 2007-12-25 | 2014-02-26 | 日本電気硝子株式会社 | ガラス板の製造方法及び製造設備 |
US7978516B2 (en) | 2007-12-27 | 2011-07-12 | Pliant Technology, Inc. | Flash memory controller having reduced pinout |
US7917689B2 (en) | 2007-12-28 | 2011-03-29 | Intel Corporation | Methods and apparatuses for nonvolatile memory wear leveling |
US8239611B2 (en) | 2007-12-28 | 2012-08-07 | Spansion Llc | Relocating data in a memory device |
US20110066792A1 (en) | 2008-02-10 | 2011-03-17 | Rambus Inc. | Segmentation Of Flash Memory For Partial Volatile Storage |
US8856464B2 (en) | 2008-02-12 | 2014-10-07 | Virident Systems, Inc. | Systems for two-dimensional main memory including memory modules with read-writeable non-volatile memory devices |
US20090216944A1 (en) | 2008-02-22 | 2009-08-27 | International Business Machines Corporation | Efficient validation of writes for protection against dropped writes |
KR101086855B1 (ko) | 2008-03-10 | 2011-11-25 | 주식회사 팍스디스크 | 고속 동작하는 반도체 스토리지 시스템 및 그 제어 방법 |
US8489820B1 (en) | 2008-03-18 | 2013-07-16 | Netapp, Inc | Speculative copying of data from main buffer cache to solid-state secondary cache of a storage server |
US8175528B2 (en) | 2008-03-18 | 2012-05-08 | Spansion Llc | Wireless mass storage flash memory |
JP5040773B2 (ja) | 2008-03-31 | 2012-10-03 | 富士通株式会社 | メモリバッファ割当装置およびプログラム |
US8516185B2 (en) | 2009-07-16 | 2013-08-20 | Netlist, Inc. | System and method utilizing distributed byte-wise buffers on a memory module |
US8001434B1 (en) | 2008-04-14 | 2011-08-16 | Netlist, Inc. | Memory board with self-testing capability |
US8051243B2 (en) | 2008-04-30 | 2011-11-01 | Hitachi, Ltd. | Free space utilization in tiered storage systems |
US20090276654A1 (en) | 2008-05-02 | 2009-11-05 | International Business Machines Corporation | Systems and methods for implementing fault tolerant data processing services |
US8266114B2 (en) | 2008-09-22 | 2012-09-11 | Riverbed Technology, Inc. | Log structured content addressable deduplicating storage |
JP5159421B2 (ja) | 2008-05-14 | 2013-03-06 | 株式会社日立製作所 | ストレージシステム及び管理装置を用いたストレージシステムの管理方法 |
US8775718B2 (en) | 2008-05-23 | 2014-07-08 | Netapp, Inc. | Use of RDMA to access non-volatile solid-state memory in a network storage system |
US8554983B2 (en) | 2008-05-27 | 2013-10-08 | Micron Technology, Inc. | Devices and methods for operating a solid state drive |
US8127076B2 (en) | 2008-06-06 | 2012-02-28 | Pivot3 | Method and system for placement of data on a storage device |
US7917803B2 (en) | 2008-06-17 | 2011-03-29 | Seagate Technology Llc | Data conflict resolution for solid-state memory devices |
US8843691B2 (en) | 2008-06-25 | 2014-09-23 | Stec, Inc. | Prioritized erasure of data blocks in a flash storage device |
US8010738B1 (en) | 2008-06-27 | 2011-08-30 | Emc Corporation | Techniques for obtaining a specified lifetime for a data storage device |
US8135907B2 (en) | 2008-06-30 | 2012-03-13 | Oracle America, Inc. | Method and system for managing wear-level aware file systems |
US8019953B2 (en) | 2008-07-01 | 2011-09-13 | Lsi Corporation | Method for providing atomicity for host write input/outputs (I/Os) in a continuous data protection (CDP)-enabled volume using intent log |
JP5242264B2 (ja) | 2008-07-07 | 2013-07-24 | 株式会社東芝 | データ制御装置、ストレージシステムおよびプログラム |
US9772936B2 (en) | 2008-07-10 | 2017-09-26 | Micron Technology, Inc. | Data collection and compression in a solid state storage device |
US20100017556A1 (en) | 2008-07-19 | 2010-01-21 | Nanostar Corporationm U.S.A. | Non-volatile memory storage system with two-stage controller architecture |
KR101086857B1 (ko) | 2008-07-25 | 2011-11-25 | 주식회사 팍스디스크 | 데이터 머지를 수행하는 반도체 스토리지 시스템의 제어 방법 |
US7941591B2 (en) | 2008-07-28 | 2011-05-10 | CacheIQ, Inc. | Flash DIMM in a standalone cache appliance system and methodology |
JP5216463B2 (ja) | 2008-07-30 | 2013-06-19 | 株式会社日立製作所 | ストレージ装置、その記憶領域管理方法及びフラッシュメモリパッケージ |
US8046551B1 (en) | 2008-08-14 | 2011-10-25 | Emc Corporation | Techniques for processing I/O requests |
KR100977709B1 (ko) | 2008-08-20 | 2010-08-24 | 주식회사 셀픽 | 플래시메모리 저장장치 및 그에 따른 관리 방법 |
US8209439B2 (en) | 2008-08-25 | 2012-06-26 | Sandisk Il Ltd. | Managing multiple concurrent operations with various priority levels in a local storage device |
US8335889B2 (en) | 2008-09-11 | 2012-12-18 | Nec Laboratories America, Inc. | Content addressable storage systems and methods employing searchable blocks |
KR101487190B1 (ko) | 2008-09-11 | 2015-01-28 | 삼성전자주식회사 | 압축 코덱을 구비한 플래시 메모리 집적 회로 |
EP2350837A4 (en) | 2008-09-15 | 2012-10-17 | Virsto Software Corp | STORAGE MANAGEMENT SYSTEM FOR VIRTUAL MACHINES |
US8417928B2 (en) | 2008-09-24 | 2013-04-09 | Marvell International Ltd. | Turbo boot systems and methods for subsequent booting from a captured data stored in a non-volatile semiconductor memory |
US20100082922A1 (en) | 2008-09-30 | 2010-04-01 | Vmware, Inc. | Virtual machine migration using local storage |
US8327066B2 (en) | 2008-09-30 | 2012-12-04 | Samsung Electronics Co., Ltd. | Method of managing a solid state drive, associated systems and implementations |
US8407427B2 (en) | 2008-10-29 | 2013-03-26 | Silicon Image, Inc. | Method and system for improving serial port memory communication latency and reliability |
US7777652B2 (en) | 2008-10-29 | 2010-08-17 | Silicon Image, Inc. | Coding system for memory systems employing high-speed serial links |
US8990573B2 (en) | 2008-11-10 | 2015-03-24 | Citrix Systems, Inc. | System and method for using variable security tag location in network communications |
KR101541812B1 (ko) | 2008-11-19 | 2015-08-06 | 삼성전자주식회사 | 비휘발성 메모리 장치 |
US20100146187A1 (en) | 2008-12-05 | 2010-06-10 | Grimsrud Knut S | Endurance management technique |
US8205060B2 (en) | 2008-12-16 | 2012-06-19 | Sandisk Il Ltd. | Discardable files |
US9015209B2 (en) | 2008-12-16 | 2015-04-21 | Sandisk Il Ltd. | Download management of discardable files |
US8645641B2 (en) | 2008-12-17 | 2014-02-04 | Seagate Technology Llc | Intelligent storage device controller |
US8266365B2 (en) | 2008-12-17 | 2012-09-11 | Sandisk Il Ltd. | Ruggedized memory device |
US8205063B2 (en) | 2008-12-30 | 2012-06-19 | Sandisk Technologies Inc. | Dynamic mapping of logical ranges to write blocks |
EP2382637B1 (en) | 2008-12-30 | 2016-01-06 | Micron Technology, Inc. | Enhanced addressability for serial non-volatile memory |
US8347041B2 (en) | 2009-01-02 | 2013-01-01 | Lsi Corporation | System and method to preserve and recover unwritten data present in data cache of a disk subsystem across power outages |
US8037364B2 (en) * | 2009-01-09 | 2011-10-11 | International Business Machines Corporation | Forced management module failover by BMC impeachment consensus |
US20100199020A1 (en) | 2009-02-04 | 2010-08-05 | Silicon Storage Technology, Inc. | Non-volatile memory subsystem and a memory controller therefor |
US20100217948A1 (en) | 2009-02-06 | 2010-08-26 | Mason W Anthony | Methods and systems for data storage |
US8032708B2 (en) | 2009-02-11 | 2011-10-04 | Oracle America, Inc. | Method and system for caching data in a storgae system |
CN101819564B (zh) | 2009-02-26 | 2013-04-17 | 国际商业机器公司 | 协助在虚拟机之间进行通信的方法和装置 |
US8589700B2 (en) | 2009-03-04 | 2013-11-19 | Apple Inc. | Data whitening for writing and reading data to and from a non-volatile memory |
US8375195B2 (en) | 2009-03-05 | 2013-02-12 | Oracle America, Inc. | Accessing memory locations for paged memory objects in an object-addressed memory system |
US8296628B2 (en) | 2009-03-06 | 2012-10-23 | Texas Instruments Incorporated | Data path read/write sequencing for reduced power consumption |
US20100235597A1 (en) | 2009-03-10 | 2010-09-16 | Hiroshi Arakawa | Method and apparatus for conversion between conventional volumes and thin provisioning with automated tier management |
US8423710B1 (en) | 2009-03-23 | 2013-04-16 | Marvell International Ltd. | Sequential writes to flash memory |
US8418021B2 (en) | 2009-03-27 | 2013-04-09 | Mediatek Inc. | Storage controller with encoding/decoding circuit programmable to support different ECC requirements and related method thereof |
US8364923B2 (en) | 2009-03-30 | 2013-01-29 | Oracle America, Inc. | Data storage system manager and method for managing a data storage system |
US20100262979A1 (en) * | 2009-04-08 | 2010-10-14 | Google Inc. | Circular command queues for communication between a host and a data storage device |
US8239724B2 (en) | 2009-04-08 | 2012-08-07 | Google Inc. | Error correction for a data storage device |
US8595572B2 (en) * | 2009-04-08 | 2013-11-26 | Google Inc. | Data storage device with metadata command |
US8055816B2 (en) | 2009-04-09 | 2011-11-08 | Micron Technology, Inc. | Memory controllers, memory systems, solid state drives and methods for processing a number of commands |
US8214663B2 (en) | 2009-04-15 | 2012-07-03 | International Business Machines Corporation | Using power proxies combined with on-chip actuators to meet a defined power target |
KR101573722B1 (ko) | 2009-04-20 | 2015-12-03 | 삼성전자주식회사 | 비휘발성 메모리 장치 및 컨트롤러를 포함하는 메모리 시스템 |
US20100281207A1 (en) | 2009-04-30 | 2010-11-04 | Miller Steven C | Flash-based data archive storage system |
US8402069B2 (en) | 2009-05-04 | 2013-03-19 | Microsoft Corporation | Use of delete notifications by file systems and applications to release storage space |
US8095770B2 (en) | 2009-05-08 | 2012-01-10 | Oracle America Inc. | Method and system for mapping data to a process |
KR101606453B1 (ko) | 2009-05-13 | 2016-04-01 | 삼성전자주식회사 | 비휘발성 데이터 저장 장치의 읽기 및 쓰기 성능 향상 방법 |
US8095738B2 (en) | 2009-06-15 | 2012-01-10 | International Business Machines Corporation | Differential caching mechanism based on media I/O speed |
US8230257B2 (en) | 2009-06-26 | 2012-07-24 | Seagate Technology Llc | Systems, methods and devices for controlling backup power provided to memory devices and used for storing of sensitive data |
US20100332871A1 (en) | 2009-06-30 | 2010-12-30 | International Buisness Machines Corporation | Capping power consumption in a data storage system |
US8291131B2 (en) | 2009-07-06 | 2012-10-16 | Micron Technology, Inc. | Data transfer management |
US8234450B2 (en) | 2009-07-10 | 2012-07-31 | Via Technologies, Inc. | Efficient data prefetching in the presence of load hits |
US8214610B2 (en) | 2009-07-15 | 2012-07-03 | Lsi Corporation | Managing backup device metadata in a high availability disk subsystem |
US8516219B2 (en) | 2009-07-24 | 2013-08-20 | Apple Inc. | Index cache tree |
US20110029728A1 (en) | 2009-07-28 | 2011-02-03 | Lsi Corporation | Methods and apparatus for reducing input/output operations in a raid storage system |
US8332673B2 (en) | 2009-08-04 | 2012-12-11 | Hitachi, Ltd. | System and method to manage power consumption |
US20110035562A1 (en) | 2009-08-10 | 2011-02-10 | Hewlett-Packard Development Company, L.P. | Providing mirroring write data |
US8176284B2 (en) | 2009-08-11 | 2012-05-08 | Texas Memory Systems, Inc. | FLASH-based memory system with variable length page stripes including data protection information |
US7818525B1 (en) | 2009-08-12 | 2010-10-19 | Texas Memory Systems, Inc. | Efficient reduction of read disturb errors in NAND FLASH memory |
US8688894B2 (en) | 2009-09-03 | 2014-04-01 | Pioneer Chip Technology Ltd. | Page based management of flash storage |
US8560765B2 (en) | 2009-09-08 | 2013-10-15 | Lsi Corporation | Systems and methods for variable level use of a multi-level flash memory |
KR101689420B1 (ko) | 2009-09-09 | 2016-12-23 | 샌디스크 테크놀로지스 엘엘씨 | 저장 장치의 전력 감소 관리를 위한 장치, 시스템, 및 방법 |
US9122579B2 (en) | 2010-01-06 | 2015-09-01 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for a storage layer |
KR101644125B1 (ko) | 2009-09-22 | 2016-07-29 | 삼성전자주식회사 | 비휘발성 메모리를 이용한 로깅 최적화 장치 및 방법 |
EP2481050A1 (en) | 2009-09-23 | 2012-08-01 | Conor Maurice Ryan | A flash memory device and control method |
US10360039B2 (en) | 2009-09-28 | 2019-07-23 | Nvidia Corporation | Predicted instruction execution in parallel processors with reduced per-thread state information including choosing a minimum or maximum of two operands based on a predicate value |
TW201111986A (en) | 2009-09-29 | 2011-04-01 | Silicon Motion Inc | Memory apparatus and data access method for memories |
CA2680601C (en) | 2009-10-16 | 2010-11-02 | Ibm Canada Limited - Ibm Canada Limitee | Managing multiple speculative assist threads at differing cache levels |
US9753847B2 (en) | 2009-10-27 | 2017-09-05 | Western Digital Technologies, Inc. | Non-volatile semiconductor memory segregating sequential, random, and system data to reduce garbage collection for page based mapping |
US8364844B2 (en) | 2009-11-13 | 2013-01-29 | International Business Machines Corporation | Deadlock-free class routes for collective communications embedded in a multi-dimensional torus network |
US8327106B2 (en) | 2009-11-16 | 2012-12-04 | International Business Machines Corporation | Selective device access control |
US8250324B2 (en) | 2009-11-30 | 2012-08-21 | International Business Machines Corporation | Method to efficiently locate meta-data structures on a flash-based storage device |
EP2523831B2 (en) | 2010-01-13 | 2024-05-29 | Magna Electronics Inc. | Vehicular camera and method for periodic calibration of vehicular camera |
US8315092B2 (en) | 2010-01-27 | 2012-11-20 | Fusion-Io, Inc. | Apparatus, system, and method for determining a read voltage threshold for solid-state storage media |
US8478945B2 (en) | 2010-02-01 | 2013-07-02 | International Business Machines Corporation | Dynamic management of destage tasks in a storage controller |
US8589766B2 (en) | 2010-02-24 | 2013-11-19 | Apple Inc. | Codeword remapping schemes for non-volatile memories |
US8285937B2 (en) | 2010-02-24 | 2012-10-09 | Apple Inc. | Fused store exclusive/memory barrier operation |
US8850113B2 (en) | 2010-02-27 | 2014-09-30 | Cleversafe, Inc. | Data migration between a raid memory and a dispersed storage network memory |
US8712984B2 (en) | 2010-03-04 | 2014-04-29 | Microsoft Corporation | Buffer pool extension for database server |
US8438361B2 (en) | 2010-03-10 | 2013-05-07 | Seagate Technology Llc | Logical block storage in a storage device |
US8130551B2 (en) | 2010-03-31 | 2012-03-06 | Sandisk Technologies Inc. | Extra dummy erase pulses after shallow erase-verify to avoid sensing deep erased threshold voltage |
EP2574215A2 (en) | 2010-04-06 | 2013-04-03 | D. Naddor | Hd barcode |
US8463846B2 (en) | 2010-05-06 | 2013-06-11 | Cdnetworks Co., Ltd. | File bundling for cache servers of content delivery networks |
WO2011143628A2 (en) | 2010-05-13 | 2011-11-17 | Fusion-Io, Inc. | Apparatus, system, and method for conditional and atomic storage operations |
US8738724B2 (en) | 2010-05-25 | 2014-05-27 | Microsoft Corporation | Totally ordered log on appendable storage |
EP2577470A4 (en) | 2010-06-04 | 2013-12-25 | Sandisk Entpr Ip Llc | CACHE ADMINISTRATION AND ACCELERATION IN STORAGE MEDIA |
US20110314071A1 (en) | 2010-06-17 | 2011-12-22 | Openwave Systems Inc. | Metadata-based data access and control |
US8402226B1 (en) | 2010-06-18 | 2013-03-19 | Emc Corporation | Rate proportional cache write-back in a storage server |
EP2598996B1 (en) | 2010-07-28 | 2019-07-10 | SanDisk Technologies LLC | Apparatus, system, and method for conditional and atomic storage operations |
US8725934B2 (en) | 2011-12-22 | 2014-05-13 | Fusion-Io, Inc. | Methods and appratuses for atomic storage operations |
US8713268B2 (en) | 2010-08-05 | 2014-04-29 | Ut-Battelle, Llc | Coordinated garbage collection for raid array of solid state disks |
US8850114B2 (en) | 2010-09-07 | 2014-09-30 | Daniel L Rosenband | Storage array controller for flash-based storage devices |
WO2012050934A2 (en) | 2010-09-28 | 2012-04-19 | Fusion-Io, Inc. | Apparatus, system, and method for a direct interface between a memory controller and non-volatile memory using a command protocol |
US8452911B2 (en) | 2010-09-30 | 2013-05-28 | Sandisk Technologies Inc. | Synchronized maintenance operations in a multi-bank storage system |
WO2012051600A2 (en) | 2010-10-15 | 2012-04-19 | Kyquang Son | File system-aware solid-state storage management system |
US10558705B2 (en) | 2010-10-20 | 2020-02-11 | Microsoft Technology Licensing, Llc | Low RAM space, high-throughput persistent key-value store using secondary memory |
US8396936B2 (en) | 2010-10-28 | 2013-03-12 | Hewlett-Packard Development Company, L.P. | Computer system with cooperative cache |
US8990538B2 (en) | 2010-11-05 | 2015-03-24 | Microsoft Corporation | Managing memory with limited write cycles in heterogeneous memory systems |
US9208071B2 (en) | 2010-12-13 | 2015-12-08 | SanDisk Technologies, Inc. | Apparatus, system, and method for accessing memory |
EP2652623B1 (en) | 2010-12-13 | 2018-08-01 | SanDisk Technologies LLC | Apparatus, system, and method for auto-commit memory |
JP2012128660A (ja) | 2010-12-15 | 2012-07-05 | Toshiba Corp | 半導体記憶装置 |
US20120239860A1 (en) | 2010-12-17 | 2012-09-20 | Fusion-Io, Inc. | Apparatus, system, and method for persistent data management on a non-volatile storage media |
US8458145B2 (en) | 2011-01-20 | 2013-06-04 | Infinidat Ltd. | System and method of storage optimization |
US8364888B2 (en) | 2011-02-03 | 2013-01-29 | Stec, Inc. | Erase-suspend system and method |
US9063862B2 (en) | 2011-05-17 | 2015-06-23 | Sandisk Technologies Inc. | Expandable data cache |
US9274937B2 (en) | 2011-12-22 | 2016-03-01 | Longitude Enterprise Flash S.A.R.L. | Systems, methods, and interfaces for vector input/output operations |
US8904091B1 (en) | 2011-12-22 | 2014-12-02 | Western Digital Technologies, Inc. | High performance media transport manager architecture for data storage systems |
US10133662B2 (en) | 2012-06-29 | 2018-11-20 | Sandisk Technologies Llc | Systems, methods, and interfaces for managing persistent data of atomic storage operations |
JP2013137713A (ja) | 2011-12-28 | 2013-07-11 | Toshiba Corp | メモリコントローラ、メモリシステムおよびメモリ書込み方法 |
US9779038B2 (en) | 2013-01-31 | 2017-10-03 | Apple Inc. | Efficient suspend-resume operation in memory devices |
US9666244B2 (en) | 2014-03-01 | 2017-05-30 | Fusion-Io, Inc. | Dividing a storage procedure |
US10656864B2 (en) | 2014-03-20 | 2020-05-19 | Pure Storage, Inc. | Data replication within a flash storage array |
-
2007
- 2007-12-06 KR KR1020147028326A patent/KR101532951B1/ko active IP Right Grant
- 2007-12-06 US US11/952,098 patent/US20080140724A1/en not_active Abandoned
- 2007-12-06 KR KR1020097014058A patent/KR20090087498A/ko active Search and Examination
- 2007-12-06 WO PCT/US2007/086686 patent/WO2008070798A1/en active Application Filing
- 2007-12-06 CN CN200780051023A patent/CN101690068A/zh active Pending
- 2007-12-06 EP EP07865335.9A patent/EP2100214B1/en active Active
- 2007-12-06 WO PCT/US2007/025050 patent/WO2008070174A2/en active Application Filing
- 2007-12-06 US US12/001,065 patent/US8417774B2/en not_active Expired - Fee Related
- 2007-12-06 JP JP2009540483A patent/JP2010515116A/ja active Pending
- 2007-12-06 KR KR1020097014054A patent/KR20090087119A/ko not_active Application Discontinuation
- 2007-12-06 CN CN200780050982A patent/CN101681282A/zh active Pending
- 2007-12-06 WO PCT/US2007/086688 patent/WO2008070800A1/en active Search and Examination
- 2007-12-06 US US11/952,120 patent/US7934055B2/en not_active Expired - Fee Related
- 2007-12-06 WO PCT/US2007/086687 patent/WO2008070799A2/en active Search and Examination
- 2007-12-06 WO PCT/US2007/086683 patent/WO2008070796A2/en active Application Filing
- 2007-12-06 EP EP07867661.6A patent/EP2109822B1/en active Active
- 2007-12-06 KR KR1020097014065A patent/KR20090095641A/ko not_active Application Discontinuation
- 2007-12-06 CN CN200780050974A patent/CN101715575A/zh active Pending
- 2007-12-06 JP JP2009540489A patent/JP5611597B2/ja active Active
- 2007-12-06 US US11/952,109 patent/US8296337B2/en active Active
- 2007-12-06 CA CA002672035A patent/CA2672035A1/en not_active Abandoned
- 2007-12-06 WO PCT/US2007/025049 patent/WO2008070173A1/en active Search and Examination
- 2007-12-06 EP EP07869018A patent/EP2109812A2/en not_active Withdrawn
- 2007-12-06 CA CA002672100A patent/CA2672100A1/en not_active Abandoned
- 2007-12-06 EP EP07865346A patent/EP2126679A2/en not_active Withdrawn
- 2007-12-06 US US11/952,116 patent/US8019940B2/en active Active
- 2007-12-06 CN CN2007800510106A patent/CN101689131B/zh not_active Expired - Fee Related
- 2007-12-06 US US11/952,121 patent/US9734086B2/en active Active
- 2007-12-06 ES ES07867661.6T patent/ES2507072T3/es active Active
- 2007-12-06 WO PCT/US2007/025188 patent/WO2008070191A2/en active Search and Examination
- 2007-12-06 JP JP2009540484A patent/JP2010512584A/ja active Pending
- 2007-12-06 EP EP07873664A patent/EP2126698A2/en not_active Withdrawn
- 2007-12-06 US US11/952,123 patent/US8019938B2/en active Active
- 2007-12-06 US US11/952,124 patent/US20080313364A1/en not_active Abandoned
- 2007-12-06 US US11/952,101 patent/US8402201B2/en active Active
- 2007-12-06 CN CN2007800509700A patent/CN101622594B/zh active Active
- 2007-12-06 WO PCT/US2007/086690 patent/WO2008070802A2/en active Application Filing
- 2007-12-06 US US11/952,095 patent/US9575902B2/en active Active
- 2007-12-06 KR KR1020097014064A patent/KR20090102788A/ko not_active Application Discontinuation
- 2007-12-06 WO PCT/US2007/025048 patent/WO2008070172A2/en active Application Filing
- 2007-12-06 CN CN201210539998.3A patent/CN103049058B/zh active Active
- 2007-12-06 KR KR1020097014067A patent/KR20090102789A/ko not_active Application Discontinuation
- 2007-12-06 WO PCT/US2007/086705 patent/WO2008127458A2/en active Application Filing
- 2007-12-06 CN CN200780050972A patent/CN101689130A/zh active Pending
- 2007-12-06 EP EP07865345A patent/EP2115563A2/en not_active Ceased
- 2007-12-06 EP EP07853274A patent/EP2126709A2/en not_active Withdrawn
- 2007-12-06 WO PCT/US2007/086704 patent/WO2008070814A2/en active Application Filing
- 2007-12-06 US US11/952,113 patent/US8261005B2/en active Active
- 2007-12-06 WO PCT/US2007/086702 patent/WO2008070812A2/en active Application Filing
- 2007-12-06 JP JP2009540309A patent/JP5523835B2/ja not_active Expired - Fee Related
- 2007-12-06 WO PCT/US2007/086691 patent/WO2008070803A1/en active Application Filing
- 2007-12-06 WO PCT/US2007/086703 patent/WO2008070813A2/en active Application Filing
- 2007-12-06 US US11/952,091 patent/US8266496B2/en active Active
- 2007-12-06 US US11/952,115 patent/US8015440B2/en active Active
- 2007-12-06 EP EP07869020A patent/EP2126680A2/en not_active Withdrawn
- 2007-12-06 KR KR1020097014055A patent/KR101490327B1/ko active IP Right Grant
- 2007-12-06 WO PCT/US2007/086701 patent/WO2008070811A2/en active Application Filing
- 2007-12-06 US US11/952,106 patent/US8495292B2/en active Active
- 2007-12-06 EP EP07865334A patent/EP2108143A2/en not_active Ceased
-
2010
- 2010-12-29 US US12/981,394 patent/US8189407B2/en not_active Expired - Fee Related
-
2011
- 2011-03-29 US US13/075,000 patent/US8412904B2/en active Active
- 2011-05-27 US US13/118,237 patent/US20110252190A1/en not_active Abandoned
- 2011-06-30 US US13/174,449 patent/US20110258512A1/en not_active Abandoned
- 2011-07-13 US US13/182,315 patent/US8412979B2/en not_active Expired - Fee Related
- 2011-08-05 US US13/204,436 patent/US8214591B2/en active Active
- 2011-08-05 US US13/204,551 patent/US8285927B2/en not_active Expired - Fee Related
-
2012
- 2012-05-01 US US13/461,628 patent/US8482993B2/en active Active
- 2012-06-04 US US13/488,301 patent/US8601211B2/en active Active
- 2012-08-03 US US13/566,471 patent/US8762658B2/en active Active
- 2012-08-30 US US13/600,077 patent/US8533569B2/en active Active
- 2012-09-07 US US13/607,486 patent/US8533406B2/en active Active
- 2012-10-09 US US13/648,009 patent/US9519594B2/en active Active
- 2012-12-28 US US13/730,602 patent/US9454492B2/en active Active
-
2013
- 2013-07-11 US US13/939,927 patent/US9824027B2/en active Active
-
2014
- 2014-06-19 US US14/309,751 patent/US9632727B2/en active Active
-
2016
- 2016-08-04 US US15/228,893 patent/US10387327B2/en active Active
- 2016-09-15 US US15/266,486 patent/US10146700B2/en active Active
-
2017
- 2017-01-10 US US15/402,936 patent/US11061825B2/en active Active
- 2017-03-15 US US15/460,126 patent/US10387328B2/en active Active
-
2018
- 2018-11-29 US US16/204,947 patent/US20190171581A1/en not_active Abandoned
-
2019
- 2019-08-16 US US16/543,464 patent/US11640359B2/en active Active
-
2021
- 2021-06-09 US US17/343,116 patent/US11573909B2/en active Active
-
2022
- 2022-10-19 US US18/047,982 patent/US11960412B2/en active Active
- 2022-12-19 US US18/067,964 patent/US11847066B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2001296974A (ja) * | 2000-02-25 | 2001-10-26 | Hewlett Packard Co <Hp> | データ記憶システム及びデータ記憶方法 |
WO2006113334A2 (en) * | 2005-04-15 | 2006-10-26 | Microsoft Corporation | In-line non volatile memory disk read cache and write buffer |
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR101532951B1 (ko) | 고-용량, 비-휘발성 스토리지를 위한 캐시로서의 솔리드-스테이트 스토리지 장치, 시스템 및 방법 | |
JP2010512568A5 (ko) |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A107 | Divisional application of patent | ||
A201 | Request for examination | ||
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right | ||
N231 | Notification of change of applicant | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20180529 Year of fee payment: 4 |
|
FPAY | Annual fee payment |
Payment date: 20190530 Year of fee payment: 5 |