EP1100001A2 - Storage system supporting file-level and block-level accesses - Google Patents
Storage system supporting file-level and block-level accesses Download PDFInfo
- Publication number
- EP1100001A2 EP1100001A2 EP00203639A EP00203639A EP1100001A2 EP 1100001 A2 EP1100001 A2 EP 1100001A2 EP 00203639 A EP00203639 A EP 00203639A EP 00203639 A EP00203639 A EP 00203639A EP 1100001 A2 EP1100001 A2 EP 1100001A2
- Authority
- EP
- European Patent Office
- Prior art keywords
- block
- access
- storage
- level
- storage system
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- 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/0626—Reducing size or complexity of 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/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/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0674—Disk device
Definitions
- the present invention relates to secondary storage systems for computers. More specifically, the present invention relates to a secondary storage system that supports both file-level and block-level access protocols.
- processor clock speeds continue to increase at an exponential rate and the price of semiconductor memories continues to fall, it is becoming possible to incorporate larger amounts of processing power and semiconductor memory into secondary storage devices, such as disk drives.
- This additional processing power and memory is being used to buffer requests into secondary storage devices in order to minimize the number of accesses to rotating storage. Accessing rotating storage can severely limit processor performance because at current processor clock speeds it is possible to execute millions of instructions in the time it takes to retrieve a single block of data from rotating storage.
- a read operation to a disk may include a device number that identifies a disk to which the read operation is directed, and a block or track number, which specifies the block or track that is to be retrieved from the disk during the read operation.
- intelligent secondary storage systems Upon receiving a block-level command, intelligent secondary storage systems typically process the command using a software emulator that emulates an unsophisticated disk drive.
- This software emulator uses the block-level request to lookup entries in a cache of disk blocks that are maintained within semiconductor memory in the secondary storage system. In some cases, this block-level access ultimately results in an access to the disk. This access to the disk must pass through a device driver for the disk, which converts the access back into a form that is suitable for communication with the disk.
- this storage system would only be compatible with computer systems that are configured to send higher-level file access commands to a storage device. Such a storage system would not be compatible with existing computer systems that provide commands in a block-level format.
- One embodiment of the present invention provides a storage system that services access requests received from a computer system.
- the storage system receives a file system access from the computer system across a communication channel.
- This file system access includes an identifier for a file and an offset into the file.
- the storage system translates this file system access into a block-level access, which includes a device number and a block number.
- This block-level access is forwarded to a storage device.
- the storage system receives block-level access, which includes a device number and a block number. The storage system forwards this block-level access to the storage device.
- the system passes the block-level access through a storage device emulator, then through a cache for the storage device. If the block level access cannot be serviced within the cache, the system passes the block-level access through a driver for the storage device before forwarding the block-level access to the storage device.
- the file system access is received from a client-side portion of a file system and is translated into a block-level access within a server-side portion of the file system.
- the file system access is received from one of a plurality of processors coupled to the storage system.
- a computer readable storage medium which may be any device or medium that can store code and/or data for use by a computer system.
- the transmission medium may include a communications network, such as the Internet.
- FIG. 1 illustrates storage system 120 coupled to computers 102-104 in accordance with an embodiment of the present invention.
- Computers 102-104 can include any type of computer that can use storage system 120 to store code/and or data. This includes, but is not limited to, computers based upon microprocessors, mainframe processors, device controllers, and computational engines within appliances. Note that computers 102-104 may include semiconductor memory in addition to other computer system components.
- Network 106 may include any type of wire or wireless communication channel capable of coupling together computers 102-104. This includes, but is not limited to, a local area network, a wide area network, or a combination of networks. In one embodiment of the present invention, network 106 includes the Internet.
- computers 102-104 provide fault-tolerance by allowing failovers between computers 102-104. For example, suppose computer 102 is acting as a primary server and computer 103 is acting as a backup secondary server, If computer 102 fails, computer 103 can take over the server functions performed by computer 102.
- the present invention can be applied to any type of computer system that includes an intelligent storage system 120 for storing code and/or data.
- the present invention can be applied to a non-fault-tolerant single processor system.
- Storage system 120 includes controller 122 and cache 124, which are coupled to storage devices 130-133.
- Storage system 120 additionally includes controller 123 and cache 125, which are similarly coupled to storage devices 130-133.
- Controllers 122-123 can include any type of computational devices that can be configured to act as controllers. During operation, controllers 122-123 manage a number of components, including storage devices 130-133 and caches 124-125. Controllers 122-123 can also manage mirroring of caches 124-125. This keeps caches 124 and 125 consistent with each other for fault-tolerance purposes.
- Caches 124 and 125 can include any type of random access memory for caching data from computers 102-104.
- caches 124-125 include non-volatile random access memory based upon flash memory or battery backed up memory. This allows a transaction to be permanently committed into non-volatile storage in caches 124-125 without having to wait for storage devices 130-133.
- Storage devices 130-133 can include any type of non-volatile storage devices for storing code and/or data for computers 102-104. This includes, but is not limited to, magnetic storage devices (such as disk drives or tape drives), optical storage devices and magneto-optical storage devices. This also includes non-volatile semiconductor storage devices, such as flash memories or battery-backed up random access memories. In one embodiment of the present invention storage, storage devices 130-133 include disk drives.
- communication links 108-110 adhere to the fiber channel standard.
- a computer such as computer 102
- makes an access request such as a read operation
- a storage system 120 receives the access request and tries to satisfy the access request within local cache 124. If necessary, controller 122 sends a request to a storage device, such as storage device 130, to complete the request. If the access is a read operation, storage device 130 returns the requested data, and controller 122 forwards to requested data back to computer 102.
- FIG. 2 illustrates system layers involved in performing a file system access wherein block-level commands are transferred to storage system 120 in accordance with an embodiment of the present invention. These layers are used during one mode of operation for storage system 120. During another mode of operation, storage system 120 can receive file system commands.
- Application 202 first initiates a file system access by executing an instruction that causes a file system call.
- This file system access may include a read operation, a write operation, or any other type of file access or file maintenance operation.
- the file system access passes into file system 204, which converts the file system access into lower-level commands to access logical blocks of storage.
- Logical volume manager 206 receives these lower-level commands and converts them into even lower-level block access commands. Note that logical volume manager 206 may additionally perform mirroring for fault-tolerance purposes.
- Logical volume manager 206 passes the block-level commands to SCSI driver 208.
- SCSI driver 208 converts the block-level commands into a form that adheres to the SCSI protocol.
- SCSI driver 208 passes the commands through a layer that converts the SCSI protocol command into a form that is suitable for transmission over a communication link that adheres to the fiber channel communication protocol. Note that although on embodiment of the present invention is described in items of the SCSI protocol, the present invention can generally be used with other data transfer protocols.
- the block-level command received from computer 102 across the fiber channel is converted back into a SCSI protocol command 212, and is then passed into SCSI emulator 214.
- SCSI emulator 214 provides an interface that appears to be a dumb SCSI device, such as a disk drive.
- the block-level command is converted into a format that allows the block to be looked up within cache 124. If the access request cannot be serviced from entirely within cache 124, the access request passes through logical volume manager 217 to controller 218. Controller 218 passes the access request through SCSI device driver 220 and through SCSI to fiber channel converter 222 before forwarding the request to storage device 130.
- a block level access can be serviced from cache 124 (without accessing storage device 130) if the block-level access is a read operation, and the requested block is present in cache 124. During a write operation, a block that is written into cache 124 will eventually be written back to storage device 130.
- FIG. 3 illustrates system layers involved in performing a file system access wherein file-level commands are transferred to a storage device in accordance with an embodiment of the present invention.
- application 202 generates a file system access and this access is passed into file system 302 (which is a client-side portion of a distributed file system).
- file system 302 which is a client-side portion of a distributed file system.
- transport layer 304 which packages the file system access for transport across a communication link from computer 102 to storage system 120.
- file system access passes through another transport layer which unpackages the file system access and then passes into file system 308 (which is a server-side portion of a distributed file system).
- file system 302 on the client side
- file system 308 on the server side
- act in concert to provide high availability.
- computer 102 fails during a file system operation.
- the highly available system allows a secondary backup computer, such as computer 103, to continue operating in place of computer 102.
- secondary backup computer such as computer 103
- the present invention also applies to computer systems that do not provide high availability.
- File system 308 within storage system 120 passes the file system access to underlying file system 310. (Note that in general any file system can used the implement underlying file system 310.) Underlying file system 310 attempts to satisfy the file system request from cache 124. If a further access is required to storage device 130, the file system access is converted in a block-level request. This block-level request passes through logical volume manager 217 to SCSI device driver 220. Next, the block-level request passes through SCSI device driver 220 and is converted into a format suitable for transmission over a communication channel adhering to the fiber channel standard. This block-level request is then forwarded to storage device 130.
- a first mode of operation (illustrated in FIG. 3) allows storage system 120 to accept higher-level file access commands.
- a second mode of operation (illustrated in FIG. 2) allows storage system 120 to accept lower-level block access commands.
- the first mode of operation eliminates the work involved in converting an access request into a block-level form within computer 102, and then emulating a simple SCSI device with storage system 120, which converts the access into a higher-level form that is subsequently converted back down into a lower-level form before passing to storage device 130.
- the first mode of operation sends the higher-level file system access directly to storage system 120 without first converting it into a block-level form.
- FIG. 4A illustrates some of the components that make up a file system access 401 in accordance with an embodiment of the present invention.
- File system access 401 includes file handle 402, offset 404 and length 406.
- File handle 402 is an identifier that facilitates referencing a file.
- Offset 404 specifies an offset into the file and length 406 specifies a length for the request. Note that this length 406 can specify a single byte or many megabytes. Hence, a single file access can generate one or more block accesses into a storage device.
- FIG. 4B illustrates some of the components that make up a block-level access 409 in accordance with an embodiment of the present invention.
- Block-level access 409 includes disk number 408 and block number 410.
- Disk number 408 identifies a specific disk (or a specific storage device) and block number 410 specifies a particular block within the storage device.
- block number 410 may specify a logical block or a physical block within a storage device.
- file system access 401 and block-level access 409 also include other components, which are not illustrated, such as an access type, which determines whether the access is a read operation or a write operation.
- FIG. 5 is a flow chart illustrating operation of storage system 120 in accordance with an embodiment of the present invention.
- the system first determines if it is configured to operate in a first mode of operation or a second mode of operation (step 502). In the first mode of operation, storage system 120 receives file system accesses, whereas in the second mode of operation, the file system receives block-level accesses.
- Configuration can take place at a number of different times. Configuration can take place when the physical components of a computer system are being integrated together. This can be accomplished by setting jumpers or switches to select a configuration. Configuration can also take place under program control during a system boot up operation. Configuration can additionally take place dynamically during computer system operation.
- storage system 120 receives a file system access (step 504).
- Storage system 120 translates the file system access 401 into a block-level access 409 (step 506).
- This block-level access 409 is subsequently forwarded to storage device 130 (step 508).
- Block-level access 409 passes through SCSI emulator 214 (step 512) and through disk controller 218 (step 514). Block-level access 409 additionally passes through SCSI device driver 220 (step 516) before being forwarded to storage device 130 (step 518).
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Human Computer Interaction (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Debugging And Monitoring (AREA)
Abstract
Description
- The present invention relates to secondary storage systems for computers. More specifically, the present invention relates to a secondary storage system that supports both file-level and block-level access protocols.
- As processor clock speeds continue to increase at an exponential rate and the price of semiconductor memories continues to fall, it is becoming possible to incorporate larger amounts of processing power and semiconductor memory into secondary storage devices, such as disk drives. This additional processing power and memory is being used to buffer requests into secondary storage devices in order to minimize the number of accesses to rotating storage. Accessing rotating storage can severely limit processor performance because at current processor clock speeds it is possible to execute millions of instructions in the time it takes to retrieve a single block of data from rotating storage.
- Unfortunately, protocols that are typically used by computers to communicate with secondary storage systems were designed presuming that the secondary storage systems possess very little processing power and semiconductor memory. Common protocols, such as the SCSI protocol, present device-specific commands at the block-level. For example, a read operation to a disk may include a device number that identifies a disk to which the read operation is directed, and a block or track number, which specifies the block or track that is to be retrieved from the disk during the read operation.
- Upon receiving a block-level command, intelligent secondary storage systems typically process the command using a software emulator that emulates an unsophisticated disk drive. This software emulator uses the block-level request to lookup entries in a cache of disk blocks that are maintained within semiconductor memory in the secondary storage system. In some cases, this block-level access ultimately results in an access to the disk. This access to the disk must pass through a device driver for the disk, which converts the access back into a form that is suitable for communication with the disk.
- Consequently, many of the processing operations performed by an intelligent secondary storage system are spent undoing a conversion into a block-level format and then redoing the conversion to create a request for the disk drive.
- What is needed is an intelligent secondary storage system that is able to process higher-level file access commands so that lower-level format conversion operations do not need to be undone and then redone by the storage system.
- However, if such a storage system is developed, this storage system would only be compatible with computer systems that are configured to send higher-level file access commands to a storage device. Such a storage system would not be compatible with existing computer systems that provide commands in a block-level format.
- What is needed is an intelligent storage system that is able to process both higher-level file access commands and lower-level block access commands.
- One embodiment of the present invention provides a storage system that services access requests received from a computer system. In a first mode of operation, the storage system receives a file system access from the computer system across a communication channel. This file system access includes an identifier for a file and an offset into the file. The storage system translates this file system access into a block-level access, which includes a device number and a block number. This block-level access is forwarded to a storage device. In a second mode of operation, the storage system receives block-level access, which includes a device number and a block number. The storage system forwards this block-level access to the storage device.
- In a variation on the above embodiment, during the second mode of operation, after receiving the block-level access, the system passes the block-level access through a storage device emulator, then through a cache for the storage device. If the block level access cannot be serviced within the cache, the system passes the block-level access through a driver for the storage device before forwarding the block-level access to the storage device.
- In a variation on the above embodiment, the file system access is received from a client-side portion of a file system and is translated into a block-level access within a server-side portion of the file system.
- In a variation on the above embodiment, the file system access is received from one of a plurality of processors coupled to the storage system.
-
- FIG. 1 illustrates a storage system coupled to a plurality of computers in accordance with an embodiment of the present invention.
- FIG. 2 illustrates system layers involved in performing a file system access wherein block-level commands are transferred to a storage system in accordance with an embodiment of the present invention.
- FIG. 3 illustrates system layers involved in performing a file system access wherein file-level commands are transferred to a storage system in accordance with an embodiment of the present invention.
- FIG. 4A illustrates some of the items within a file system access in accordance with an embodiment of the present invention.
- FIG. 4B illustrates some of the items within a block-level access in accordance with an embodiment of the present invention.
- FIG. 5 is a flow chart illustrating operation of a storage system in accordance with an embodiment of the present invention.
-
- The following description is presented to enable any person skilled in the art to make and use the invention, and is provided in the context of a particular application and its requirements. Various modifications to the disclosed embodiments will be readily apparent to those skilled in the art, and the general principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the present invention. Thus, the present invention is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein.
- The data structures and code described in this detailed description are typically stored on a computer readable storage medium, which may be any device or medium that can store code and/or data for use by a computer system. This includes, but is not limited to, magnetic and optical storage devices such as disk drives, magnetic tape, CDs (compact discs) and DVDs (digital video discs), and computer instruction signals embodied in a transmission medium (with or without a carrier wave upon which the signals are modulated). For example, the transmission medium may include a communications network, such as the Internet.
- FIG. 1 illustrates
storage system 120 coupled to computers 102-104 in accordance with an embodiment of the present invention. Computers 102-104 can include any type of computer that can usestorage system 120 to store code/and or data. This includes, but is not limited to, computers based upon microprocessors, mainframe processors, device controllers, and computational engines within appliances. Note that computers 102-104 may include semiconductor memory in addition to other computer system components. - In the illustrated embodiment, computers 102-104 are coupled together through
network 106. Network 106 may include any type of wire or wireless communication channel capable of coupling together computers 102-104. This includes, but is not limited to, a local area network, a wide area network, or a combination of networks. In one embodiment of the present invention,network 106 includes the Internet. - In one embodiment of the present invention, computers 102-104 provide fault-tolerance by allowing failovers between computers 102-104. For example, suppose
computer 102 is acting as a primary server andcomputer 103 is acting as a backup secondary server, Ifcomputer 102 fails,computer 103 can take over the server functions performed bycomputer 102. - Note that the present invention can be applied to any type of computer system that includes an
intelligent storage system 120 for storing code and/or data. For example, the present invention can be applied to a non-fault-tolerant single processor system. -
Storage system 120 includescontroller 122 andcache 124, which are coupled to storage devices 130-133.Storage system 120 additionally includescontroller 123 andcache 125, which are similarly coupled to storage devices 130-133. - Note that providing two controllers 122 -123 and two caches 124 -125 allows
storage system 120 to provide fault tolerance in cases where one of the two controllers 122-123 or one of the two caches 124-125 fails. Also note that the present invention can additionally apply to non-fault-tolerant storage systems that include only a single controller and a single cache. - Controllers 122-123 can include any type of computational devices that can be configured to act as controllers. During operation, controllers 122-123 manage a number of components, including storage devices 130-133 and caches 124-125. Controllers 122-123 can also manage mirroring of caches 124-125. This keeps
caches -
Caches - Storage devices 130-133 can include any type of non-volatile storage devices for storing code and/or data for computers 102-104. This includes, but is not limited to, magnetic storage devices (such as disk drives or tape drives), optical storage devices and magneto-optical storage devices. This also includes non-volatile semiconductor storage devices, such as flash memories or battery-backed up random access memories. In one embodiment of the present invention storage, storage devices 130-133 include disk drives.
- Note that computer 102-104 are coupled with
storage system 120 through communication links 108-110. In embodiment of the present invention, communication links 108-110 adhere to the fiber channel standard. - The system illustrated in FIG. 1 operates generally as follows. A computer, such as
computer 102, makes an access request, such as a read operation, to astorage system 120.Controller 122 withinstorage system 120 receives the access request and tries to satisfy the access request withinlocal cache 124. If necessary,controller 122 sends a request to a storage device, such asstorage device 130, to complete the request. If the access is a read operation,storage device 130 returns the requested data, andcontroller 122 forwards to requested data back tocomputer 102. - FIG. 2 illustrates system layers involved in performing a file system access wherein block-level commands are transferred to
storage system 120 in accordance with an embodiment of the present invention. These layers are used during one mode of operation forstorage system 120. During another mode of operation,storage system 120 can receive file system commands. - A number of layers are illustrated within
computer 102.Application 202 first initiates a file system access by executing an instruction that causes a file system call. This file system access may include a read operation, a write operation, or any other type of file access or file maintenance operation. The file system access passes intofile system 204, which converts the file system access into lower-level commands to access logical blocks of storage.Logical volume manager 206 receives these lower-level commands and converts them into even lower-level block access commands. Note thatlogical volume manager 206 may additionally perform mirroring for fault-tolerance purposes.Logical volume manager 206 passes the block-level commands toSCSI driver 208.SCSI driver 208 converts the block-level commands into a form that adheres to the SCSI protocol.SCSI driver 208 passes the commands through a layer that converts the SCSI protocol command into a form that is suitable for transmission over a communication link that adheres to the fiber channel communication protocol. Note that although on embodiment of the present invention is described in items of the SCSI protocol, the present invention can generally be used with other data transfer protocols. - Within
storage system 120, the block-level command received fromcomputer 102 across the fiber channel is converted back into aSCSI protocol command 212, and is then passed intoSCSI emulator 214.SCSI emulator 214 provides an interface that appears to be a dumb SCSI device, such as a disk drive. WithinSCSI emulator 214, the block-level command is converted into a format that allows the block to be looked up withincache 124. If the access request cannot be serviced from entirely withincache 124, the access request passes throughlogical volume manager 217 tocontroller 218.Controller 218 passes the access request throughSCSI device driver 220 and through SCSI tofiber channel converter 222 before forwarding the request tostorage device 130. - Note that a block level access can be serviced from cache 124 (without accessing storage device 130) if the block-level access is a read operation, and the requested block is present in
cache 124. During a write operation, a block that is written intocache 124 will eventually be written back tostorage device 130. - FIG. 3 illustrates system layers involved in performing a file system access wherein file-level commands are transferred to a storage device in accordance with an embodiment of the present invention. In this embodiment,
application 202 generates a file system access and this access is passed into file system 302 (which is a client-side portion of a distributed file system). This file system access is immediately passed intotransport layer 304, which packages the file system access for transport across a communication link fromcomputer 102 tostorage system 120. - Within
storage system 120, the file system access passes through another transport layer which unpackages the file system access and then passes into file system 308 (which is a server-side portion of a distributed file system). - In one embodiment of the present invention, file system 302 (on the client side) and file system 308 (on the server side) act in concert to provide high availability. For example, suppose
computer 102 fails during a file system operation. The highly available system allows a secondary backup computer, such ascomputer 103, to continue operating in place ofcomputer 102. Note that the present invention also applies to computer systems that do not provide high availability. -
File system 308 withinstorage system 120 passes the file system access tounderlying file system 310. (Note that in general any file system can used the implementunderlying file system 310.) Underlyingfile system 310 attempts to satisfy the file system request fromcache 124. If a further access is required tostorage device 130, the file system access is converted in a block-level request. This block-level request passes throughlogical volume manager 217 toSCSI device driver 220. Next, the block-level request passes throughSCSI device driver 220 and is converted into a format suitable for transmission over a communication channel adhering to the fiber channel standard. This block-level request is then forwarded tostorage device 130. - Note that the present invention allows for two modes of operation. A first mode of operation (illustrated in FIG. 3) allows
storage system 120 to accept higher-level file access commands. A second mode of operation (illustrated in FIG. 2) allowsstorage system 120 to accept lower-level block access commands. - The first mode of operation eliminates the work involved in converting an access request into a block-level form within
computer 102, and then emulating a simple SCSI device withstorage system 120, which converts the access into a higher-level form that is subsequently converted back down into a lower-level form before passing tostorage device 130. - Instead, the first mode of operation sends the higher-level file system access directly to
storage system 120 without first converting it into a block-level form. - FIG. 4A illustrates some of the components that make up a
file system access 401 in accordance with an embodiment of the present invention.File system access 401 includesfile handle 402, offset 404 andlength 406.File handle 402 is an identifier that facilitates referencing a file. Offset 404 specifies an offset into the file andlength 406 specifies a length for the request. Note that thislength 406 can specify a single byte or many megabytes. Hence, a single file access can generate one or more block accesses into a storage device. - FIG. 4B illustrates some of the components that make up a block-
level access 409 in accordance with an embodiment of the present invention. Block-level access 409 includesdisk number 408 andblock number 410.Disk number 408 identifies a specific disk (or a specific storage device) andblock number 410 specifies a particular block within the storage device. Note thatblock number 410 may specify a logical block or a physical block within a storage device. - Note that
file system access 401 and block-level access 409 also include other components, which are not illustrated, such as an access type, which determines whether the access is a read operation or a write operation. - FIG. 5 is a flow chart illustrating operation of
storage system 120 in accordance with an embodiment of the present invention. - The system first determines if it is configured to operate in a first mode of operation or a second mode of operation (step 502). In the first mode of operation,
storage system 120 receives file system accesses, whereas in the second mode of operation, the file system receives block-level accesses. - The configuration process can take place at a number of different times. Configuration can take place when the physical components of a computer system are being integrated together. This can be accomplished by setting jumpers or switches to select a configuration. Configuration can also take place under program control during a system boot up operation. Configuration can additionally take place dynamically during computer system operation.
- During the first mode of operation,
storage system 120 receives a file system access (step 504).Storage system 120 translates thefile system access 401 into a block-level access 409 (step 506). This block-level access 409 is subsequently forwarded to storage device 130 (step 508). - During the second mode of operation,
storage system 120 receives a block-level access 409 (step 510). Block-level access 409 passes through SCSI emulator 214 (step 512) and through disk controller 218 (step 514). Block-level access 409 additionally passes through SCSI device driver 220 (step 516) before being forwarded to storage device 130 (step 518). - The foregoing descriptions of embodiments of the invention have been presented for purposes of illustration and description only. They are not intended to be exhaustive or to limit the invention to the forms disclosed. Accordingly, many modifications and variations will be apparent to practitioners skilled in the art. Additionally, the above disclosure is not intended to limit the invention. The scope of the invention is defined by the appended claims.
Claims (28)
- A method for servicing access requests directed to a storage system (120) within a computer system, comprising:if the storage system is operating in a first mode of operation, receiving (504) a file system access (401) at the storage system, translating (506) the file system access into a first block-level access (409),
andforwarding (508) the first block-level access to a storage device (130) within the storage system;if the storage system is operating in a second mode of operation, receiving 9510) a second block-level access (404) at the storage system, and forwarding (518) the second block-level access to the storage device (130). - The method of claim 1, wherein receiving the file system access (401) includes receiving an identifier (402) for a file and an offset (404) into the file.
- The method of claim 1 or claim 2, wherein receiving the file system access (401) includes receiving the file system access across a communication channel from a processor in the computer system.
- The method of claim 3, wherein the communication channel conforms to the fiber channel standard.
- A method according to any preceding claim, wherein forwarding the first block-level access (409) includes forwarding a device number (408) and a block number (410).
- The method of claim 5, wherein the device number (408) identifies a disk within the storage system (120).
- A method according to any preceding claim, wherein receiving the second block-level access includes receiving a second device number (408) and a second block number (410).
- A method according to any preceding claim, wherein if the storage system is operating in the second mode of operation, the method further comprises:after receiving the second block-level access (409) at the storage system (120), passing the second block-level access through a block storage device emulator within the storage system;passing the second block-level access through a cache (124; 125) for the storage device; andif the second block-level access (409) cannot be serviced by the cache, passing the second block-level access through a driver (220) for the storage device (130) before forwarding the second block-level access to the storage device.
- A method according to any preceding claim, wherein receiving the file system access at the storage system (302) includes receiving the file system access from a client-side portion of a file system; and
wherein translating the file system access into the first block-level access includes translating the file system access within a server-side portion of the file system. - A method according to any preceding claim, wherein the first block-level access conforms to the SCSI protocol standard.
- A method according to any preceding claim, wherein the file system access conforms to the POSIX standard.
- A method according to any preceding claim, wherein receiving the file system access includes receiving the file system access from one of a plurality of processors coupled to the storage system.
- A method according to any preceding claim, wherein forwarding the first block-level access to the storage device includes mirroring the first block-level access for fault-tolerance purposes.
- A method according to any preceding claim, wherein the file system access additionally includes an access length (406).
- An apparatus for storing data for a computer system (102; 103; 104), comprising:a storage system (120);a first communication channel (108; 109; 110) that couples the storage system to the computer system;a storage device within the storage system, including a non-volatile storage medium;a second communication channel that couples the storage system to the storage device; anda controller (122; 123) within the storage system coupled between the first communication channel and the second communication channel, for co-ordinating operation of the storage system;
wherein during a first mode of operation, the controller is configured to,receive (504) a file system access (401) at the storage system, translate (506) the file system access into a first block-level access (409), forward (508) the first block-level access to the storage device;
wherein during a second mode of operation, the controller is configured to,receive (510) a second block-level access (409) at the storage system, and forward (518) the second block-level access to the storage device. - The apparatus of claim 15, wherein the file system access (401) includes an identifier (402) for a file and an offset (404) into the file.
- The apparatus of claim 15 or claim 16, wherein the first block-level access (409) includes a device number (408) and a block number (410).
- The apparatus of claim 17, wherein the device number (408) identifies a disk within the storage system (120).
- An apparatus according to any one of claims 15 to 18, wherein the second block-level access includes a second device number (408) and a second block number (410).
- An apparatus according to any one of claims 15 to 19, wherein if the storage system is operating in the second mode of operation, the controller is further configured to:pass the second block-level access through a block storage device emulator within the storage system; andif the second block level-access cannot be serviced within the cache (124, 125), to pass the second block-level access through a driver for the storage device before forwarding the second block-level access to the storage device.
- The apparatus according to any one of claims 15 to 20, further comprising a server-side portion of a file system within the storage device, and wherein the controller is configured to receive the file system access from a corresponding client-side portion of the file system.
- The apparatus according to any one of claims 15 to 21, wherein the first communication channel conforms to the fiber channel standard.
- The apparatus according to any one of claims 15 to 22, wherein the first block-level access conforms to the SCSI protocol standard.
- The apparatus according to any one of claims 15 to 23, wherein the file system access conforms to the POSIX standard.
- The apparatus according to any one of claims 15 to 24, further comprising a third communication channel that couples the storage device to a second computer system.
- The apparatus according to any one of claims 15 to 25, wherein the controller is configured to mirror the first block-level access for fault-tolerance purposes.
- The apparatus according to any one of claims 15 to 26, wherein the file system access additionally includes an access length.
- A computer readable storage medium storing instructions that when executed by a controller (122; 123) within a storage system (120) cause the controller to perform a method for servicing access requests directed to the storage system according to any one of claims 1 to 14forwarding the first block-level access to a storage device within the storage system;if the storage system is operating in a second mode of operation, receiving a second block-level access at the storage system, and forwarding the second block-level access to the storage device.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US427377 | 1995-04-24 | ||
US42737799A | 1999-10-25 | 1999-10-25 |
Publications (3)
Publication Number | Publication Date |
---|---|
EP1100001A2 true EP1100001A2 (en) | 2001-05-16 |
EP1100001A3 EP1100001A3 (en) | 2001-06-13 |
EP1100001B1 EP1100001B1 (en) | 2003-08-13 |
Family
ID=23694611
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP00203639A Expired - Lifetime EP1100001B1 (en) | 1999-10-25 | 2000-10-18 | Storage system supporting file-level and block-level accesses |
Country Status (3)
Country | Link |
---|---|
EP (1) | EP1100001B1 (en) |
AT (1) | ATE247296T1 (en) |
DE (1) | DE60004463D1 (en) |
Cited By (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1315074A2 (en) * | 2001-11-22 | 2003-05-28 | Hitachi, Ltd. | Storage system and control method |
EP1357463A2 (en) * | 2002-04-26 | 2003-10-29 | Hitachi, Ltd. | Storage system |
EP1358582A1 (en) * | 2000-12-18 | 2003-11-05 | Spinnaker Networks, Inc | A mechanism for handling file level and block level remote file accesses using the same server |
FR2865817A1 (en) * | 2004-01-29 | 2005-08-05 | Hitachi Ltd | MEMORIZATION SYSTEM HAVING A PLURALITY OF INTERFACES |
FR2880444A1 (en) * | 2005-01-06 | 2006-07-07 | Gemplus Sa | DATA STORAGE DEVICE |
WO2005101181A3 (en) * | 2004-04-12 | 2006-11-09 | Network Appliance Inc | System and method for supporting block-based protocols on a virtual storage appliance executing within a physical storage appliance |
EP1280047A3 (en) * | 2001-07-27 | 2006-11-15 | Hitachi, Ltd. | A storage system having a plurality of controllers |
EP1291755A3 (en) * | 2001-05-25 | 2007-11-07 | Hitachi Ltd. | Storage system, a method of file data back up and a method of copying of file data |
US7404192B2 (en) | 2004-08-03 | 2008-07-22 | International Business Machines Corporation | Apparatus, system, and method for isolating a storage application from a network interface driver |
US7426584B2 (en) * | 2002-07-29 | 2008-09-16 | Sandisk Il Ltd | Portable storage media as file servers |
WO2008070802A3 (en) * | 2006-12-06 | 2008-10-09 | David Flynn | Apparatus, system, and method for an in-server storage area network |
US7493404B2 (en) * | 2002-05-30 | 2009-02-17 | Lsi Corporation | Apparatus and method for providing transparent sharing of channel resources by multiple host machines utilizing mixed mode block and file protocols |
US7523487B2 (en) | 2000-12-01 | 2009-04-21 | Netapp, Inc. | Decentralized virus scanning for stored data |
US7778981B2 (en) * | 2000-12-01 | 2010-08-17 | Netapp, Inc. | Policy engine to control the servicing of requests received by a storage server |
US7793068B2 (en) * | 2005-12-21 | 2010-09-07 | Sandisk Corporation | Dual mode access for non-volatile storage devices |
US7953919B2 (en) * | 2007-12-21 | 2011-05-31 | Spansion Llc | Physical block addressing of electronic memory devices |
US20120042142A1 (en) * | 2008-08-08 | 2012-02-16 | Amazon Technologies, Inc. | Providing executing programs with reliable access to non-local block data storage |
US8855714B2 (en) | 2005-09-14 | 2014-10-07 | Sandisk Il Ltd. | Removable media player for mobile phones |
US9236080B2 (en) | 2004-01-15 | 2016-01-12 | Sandisk Il Ltd. | Removable medium with bookmark |
US9612966B2 (en) | 2012-07-03 | 2017-04-04 | Sandisk Technologies Llc | Systems, methods and apparatus for a virtual machine cache |
US9767032B2 (en) | 2012-01-12 | 2017-09-19 | Sandisk Technologies Llc | Systems and methods for cache endurance |
US9842053B2 (en) | 2013-03-15 | 2017-12-12 | Sandisk Technologies Llc | Systems and methods for persistent cache logging |
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 |
US10102117B2 (en) | 2012-01-12 | 2018-10-16 | Sandisk Technologies Llc | Systems and methods for cache and storage device coordination |
US10339056B2 (en) | 2012-07-03 | 2019-07-02 | Sandisk Technologies Llc | Systems, methods and apparatus for cache transfers |
US10346095B2 (en) | 2012-08-31 | 2019-07-09 | Sandisk Technologies, Llc | Systems, methods, and interfaces for adaptive cache persistence |
Families Citing this family (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
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 |
US7877539B2 (en) | 2005-02-16 | 2011-01-25 | Sandisk Corporation | Direct data file storage in flash memories |
US20060184719A1 (en) | 2005-02-16 | 2006-08-17 | Sinclair Alan W | Direct data file storage implementation techniques in flash memories |
US20060184718A1 (en) | 2005-02-16 | 2006-08-17 | Sinclair Alan W | Direct file data programming and deletion in flash memories |
US7409489B2 (en) | 2005-08-03 | 2008-08-05 | Sandisk Corporation | Scheduling of reclaim operations in non-volatile memory |
US7669003B2 (en) | 2005-08-03 | 2010-02-23 | Sandisk Corporation | Reprogrammable non-volatile memory systems with indexing of directly stored data files |
US7949845B2 (en) | 2005-08-03 | 2011-05-24 | Sandisk Corporation | Indexing of file data in reprogrammable non-volatile memories that directly store data files |
US7814262B2 (en) | 2005-10-13 | 2010-10-12 | Sandisk Corporation | Memory system storing transformed units of data in fixed sized storage blocks |
US7877540B2 (en) | 2005-12-13 | 2011-01-25 | Sandisk Corporation | Logically-addressed file storage methods |
US7769978B2 (en) | 2005-12-21 | 2010-08-03 | Sandisk Corporation | Method and system for accessing non-volatile storage devices |
US7747837B2 (en) | 2005-12-21 | 2010-06-29 | Sandisk Corporation | Method and system for accessing non-volatile storage devices |
US9116823B2 (en) | 2006-12-06 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for adaptive error-correction coding |
US8489817B2 (en) | 2007-12-06 | 2013-07-16 | Fusion-Io, Inc. | Apparatus, system, and method for caching data |
US8443134B2 (en) | 2006-12-06 | 2013-05-14 | Fusion-Io, Inc. | Apparatus, system, and method for graceful cache device degradation |
US9495241B2 (en) | 2006-12-06 | 2016-11-15 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for adaptive data storage |
US9104599B2 (en) | 2007-12-06 | 2015-08-11 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for destaging cached data |
US8706968B2 (en) | 2007-12-06 | 2014-04-22 | Fusion-Io, Inc. | Apparatus, system, and method for redundant write caching |
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 |
US7783666B1 (en) | 2007-09-26 | 2010-08-24 | Netapp, Inc. | Controlling access to storage resources by using access pattern based quotas |
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 |
US9519540B2 (en) | 2007-12-06 | 2016-12-13 | Sandisk Technologies Llc | Apparatus, system, and method for destaging cached data |
KR101717644B1 (en) | 2009-09-08 | 2017-03-27 | 샌디스크 테크놀로지스 엘엘씨 | Apparatus, system, and method for caching data on a solid-state storage device |
US9092337B2 (en) | 2011-01-31 | 2015-07-28 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for managing eviction of data |
US8874823B2 (en) | 2011-02-15 | 2014-10-28 | Intellectual Property Holdings 2 Llc | Systems and methods for managing data input/output operations |
US9201677B2 (en) | 2011-05-23 | 2015-12-01 | Intelligent Intellectual Property Holdings 2 Llc | Managing data input/output operations |
US9003104B2 (en) | 2011-02-15 | 2015-04-07 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for a file-level cache |
WO2012116369A2 (en) | 2011-02-25 | 2012-08-30 | Fusion-Io, Inc. | Apparatus, system, and method for managing contents of a cache |
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 |
US9251086B2 (en) | 2012-01-24 | 2016-02-02 | SanDisk Technologies, Inc. | Apparatus, system, and method for managing a cache |
US9116812B2 (en) | 2012-01-27 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for a de-duplication cache |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH08335180A (en) * | 1995-06-06 | 1996-12-17 | Mitsubishi Electric Corp | File input/output control system |
US5592662A (en) * | 1992-09-30 | 1997-01-07 | Kabushiki Kaisha Tishiba | File management system and method for managing access and storage of data within multiple external memory devices |
US5619690A (en) * | 1993-06-21 | 1997-04-08 | Hitachi, Ltd. | Computer system including a computer which requests an access to a logical address in a secondary storage system with specification of a local address in the secondary storage system |
-
2000
- 2000-10-18 AT AT00203639T patent/ATE247296T1/en not_active IP Right Cessation
- 2000-10-18 EP EP00203639A patent/EP1100001B1/en not_active Expired - Lifetime
- 2000-10-18 DE DE60004463T patent/DE60004463D1/en not_active Expired - Lifetime
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5592662A (en) * | 1992-09-30 | 1997-01-07 | Kabushiki Kaisha Tishiba | File management system and method for managing access and storage of data within multiple external memory devices |
US5619690A (en) * | 1993-06-21 | 1997-04-08 | Hitachi, Ltd. | Computer system including a computer which requests an access to a logical address in a secondary storage system with specification of a local address in the secondary storage system |
JPH08335180A (en) * | 1995-06-06 | 1996-12-17 | Mitsubishi Electric Corp | File input/output control system |
Non-Patent Citations (1)
Title |
---|
PATENT ABSTRACTS OF JAPAN vol. 1997, no. 04, 30 April 1997 (1997-04-30) & JP 08 335180 A (MITSUBISHI ELECTRIC CORP), 17 December 1996 (1996-12-17) * |
Cited By (50)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7778981B2 (en) * | 2000-12-01 | 2010-08-17 | Netapp, Inc. | Policy engine to control the servicing of requests received by a storage server |
US7523487B2 (en) | 2000-12-01 | 2009-04-21 | Netapp, Inc. | Decentralized virus scanning for stored data |
EP1358582A1 (en) * | 2000-12-18 | 2003-11-05 | Spinnaker Networks, Inc | A mechanism for handling file level and block level remote file accesses using the same server |
EP1358582A4 (en) * | 2000-12-18 | 2009-01-28 | Network Appliance Inc | A mechanism for handling file level and block level remote file accesses using the same server |
EP1291755A3 (en) * | 2001-05-25 | 2007-11-07 | Hitachi Ltd. | Storage system, a method of file data back up and a method of copying of file data |
US8341199B2 (en) | 2001-05-25 | 2012-12-25 | Hitachi, Ltd. | Storage system, a method of file data back up and a method of copying of file data |
US7260656B2 (en) | 2001-07-27 | 2007-08-21 | Hitachi, Ltd. | Storage system having a plurality of controllers |
EP1280047A3 (en) * | 2001-07-27 | 2006-11-15 | Hitachi, Ltd. | A storage system having a plurality of controllers |
US7216148B2 (en) | 2001-07-27 | 2007-05-08 | Hitachi, Ltd. | Storage system having a plurality of controllers |
US7424491B2 (en) | 2001-11-22 | 2008-09-09 | Hitachi, Ltd. | Storage system and control method |
EP1315074A2 (en) * | 2001-11-22 | 2003-05-28 | Hitachi, Ltd. | Storage system and control method |
EP1315074A3 (en) * | 2001-11-22 | 2007-12-26 | Hitachi, Ltd. | Storage system and control method |
EP1357463A2 (en) * | 2002-04-26 | 2003-10-29 | Hitachi, Ltd. | Storage system |
US7444468B2 (en) | 2002-04-26 | 2008-10-28 | Hitachi, Ltd. | Storage system and method using interface control devices of different types |
EP1357463A3 (en) * | 2002-04-26 | 2008-03-19 | Hitachi, Ltd. | Storage system |
US7493404B2 (en) * | 2002-05-30 | 2009-02-17 | Lsi Corporation | Apparatus and method for providing transparent sharing of channel resources by multiple host machines utilizing mixed mode block and file protocols |
US7426584B2 (en) * | 2002-07-29 | 2008-09-16 | Sandisk Il Ltd | Portable storage media as file servers |
US9236080B2 (en) | 2004-01-15 | 2016-01-12 | Sandisk Il Ltd. | Removable medium with bookmark |
US7191287B2 (en) | 2004-01-29 | 2007-03-13 | Hitachi, Ltd. | Storage system having a plurality of interfaces |
US7404038B2 (en) | 2004-01-29 | 2008-07-22 | Hitachi, Ltd. | Storage system having a plurality of interfaces |
US7120742B2 (en) | 2004-01-29 | 2006-10-10 | Hitachi, Ltd. | Storage system having a plurality of interfaces |
FR2865817A1 (en) * | 2004-01-29 | 2005-08-05 | Hitachi Ltd | MEMORIZATION SYSTEM HAVING A PLURALITY OF INTERFACES |
WO2005101181A3 (en) * | 2004-04-12 | 2006-11-09 | Network Appliance Inc | System and method for supporting block-based protocols on a virtual storage appliance executing within a physical storage appliance |
US8230085B2 (en) | 2004-04-12 | 2012-07-24 | Netapp, Inc. | System and method for supporting block-based protocols on a virtual storage appliance executing within a physical storage appliance |
US7404192B2 (en) | 2004-08-03 | 2008-07-22 | International Business Machines Corporation | Apparatus, system, and method for isolating a storage application from a network interface driver |
US8239884B2 (en) | 2004-08-03 | 2012-08-07 | International Business Machines Corporation | Apparatus, system, and method for isolating a storage application from a network interface driver |
FR2880444A1 (en) * | 2005-01-06 | 2006-07-07 | Gemplus Sa | DATA STORAGE DEVICE |
WO2006072500A1 (en) * | 2005-01-06 | 2006-07-13 | Gemplus | Data storage device |
US8855714B2 (en) | 2005-09-14 | 2014-10-07 | Sandisk Il Ltd. | Removable media player for mobile phones |
US7793068B2 (en) * | 2005-12-21 | 2010-09-07 | Sandisk Corporation | Dual mode access for non-volatile storage devices |
US9734086B2 (en) | 2006-12-06 | 2017-08-15 | Sandisk Technologies Llc | Apparatus, system, and method for a device shared between multiple independent hosts |
US9824027B2 (en) | 2006-12-06 | 2017-11-21 | Sandisk Technologies Llc | Apparatus, system, and method for a storage area network |
US11960412B2 (en) | 2006-12-06 | 2024-04-16 | Unification Technologies Llc | Systems and methods for identifying storage resources that are not in use |
US11847066B2 (en) | 2006-12-06 | 2023-12-19 | Unification Technologies Llc | Apparatus, system, and method for managing commands of solid-state storage using bank interleave |
US8495292B2 (en) | 2006-12-06 | 2013-07-23 | Fusion-Io, Inc. | Apparatus, system, and method for an in-server storage area network |
US11640359B2 (en) | 2006-12-06 | 2023-05-02 | Unification Technologies Llc | Systems and methods for identifying storage resources that are not in use |
WO2008070802A3 (en) * | 2006-12-06 | 2008-10-09 | David Flynn | Apparatus, system, and method for an in-server storage area network |
US11573909B2 (en) | 2006-12-06 | 2023-02-07 | Unification Technologies Llc | Apparatus, system, and method for managing commands of solid-state storage using bank interleave |
US7953919B2 (en) * | 2007-12-21 | 2011-05-31 | Spansion Llc | Physical block addressing of electronic memory devices |
US9262273B2 (en) | 2008-08-08 | 2016-02-16 | Amazon Technologies, Inc. | Providing executing programs with reliable access to non-local block data storage |
US20120042142A1 (en) * | 2008-08-08 | 2012-02-16 | Amazon Technologies, Inc. | Providing executing programs with reliable access to non-local block data storage |
US8769186B2 (en) * | 2008-08-08 | 2014-07-01 | Amazon Technologies, Inc. | Providing executing programs with reliable access to non-local block data storage |
US10102117B2 (en) | 2012-01-12 | 2018-10-16 | Sandisk Technologies Llc | Systems and methods for cache and storage device coordination |
US9767032B2 (en) | 2012-01-12 | 2017-09-19 | Sandisk Technologies Llc | Systems and methods for cache endurance |
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 |
US10339056B2 (en) | 2012-07-03 | 2019-07-02 | Sandisk Technologies Llc | Systems, methods and apparatus for cache transfers |
US9612966B2 (en) | 2012-07-03 | 2017-04-04 | Sandisk Technologies Llc | Systems, methods and apparatus for a virtual machine cache |
US10346095B2 (en) | 2012-08-31 | 2019-07-09 | Sandisk Technologies, Llc | Systems, methods, and interfaces for adaptive cache persistence |
US10359972B2 (en) | 2012-08-31 | 2019-07-23 | Sandisk Technologies Llc | Systems, methods, and interfaces for adaptive persistence |
US9842053B2 (en) | 2013-03-15 | 2017-12-12 | Sandisk Technologies Llc | Systems and methods for persistent cache logging |
Also Published As
Publication number | Publication date |
---|---|
EP1100001B1 (en) | 2003-08-13 |
EP1100001A3 (en) | 2001-06-13 |
DE60004463D1 (en) | 2003-09-18 |
ATE247296T1 (en) | 2003-08-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP1100001B1 (en) | Storage system supporting file-level and block-level accesses | |
EP0869438B1 (en) | Heterogeneous computer system, heterogeneous input/output system and data back-up method for the systems | |
US20190075163A1 (en) | Apparatus including an i/o interface and a network interface and related method of use | |
US7533181B2 (en) | Apparatus, system, and method for data access management | |
US7401129B2 (en) | Network system, server, data processing method and program | |
US6772290B1 (en) | System and method for providing safe data movement using third party copy techniques | |
JP4410557B2 (en) | Method and system for accessing a tape device in a computer system | |
US6842833B1 (en) | Computer system and method for transferring data between multiple peer-level storage units | |
US6405201B1 (en) | Method and apparatus for reducing network traffic for remote file append operations | |
JP5063078B2 (en) | Apparatus and method for autonomous virtualization of data storage server | |
US6941429B1 (en) | System and method for improving performance of a data backup operation | |
JP2002014777A (en) | Data moving method and protocol converting device, and switching device using the same | |
US6105076A (en) | Method, system, and program for performing data transfer operations on user data | |
EP1094392A1 (en) | Method and apparatus for interfacing with a secondary storage system | |
JP2004533039A (en) | Method and system for file sharing in a network | |
EP1566041B1 (en) | High-performance lock management for flash copy in n-way shared storage systems | |
EP1122924B1 (en) | Method and apparatus for providing local path I/O in a distributed file system | |
JP2002007182A (en) | Shared file control system for external storage device | |
US7099995B2 (en) | Metadata access during error handling routines | |
US7266622B2 (en) | Method, computer program product, and system for automatic application buffering | |
US7260576B2 (en) | Implementing a distributed file system that can use direct connections from client to disk | |
US6516344B1 (en) | Reducing network traffic for remote file system accesses by keeping track of unallocated regions in files | |
EP1107119A2 (en) | Extending cluster membership and quorum determinations to intelligent storage systems | |
CN115079931A (en) | Processing system, method, apparatus, device and medium for distributed storage nodes | |
US6401151B1 (en) | Method for configuring bus architecture through software control |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
PUAL | Search report despatched |
Free format text: ORIGINAL CODE: 0009013 |
|
AK | Designated contracting states |
Kind code of ref document: A2 Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE |
|
AX | Request for extension of the european patent |
Free format text: AL;LT;LV;MK;RO;SI |
|
AK | Designated contracting states |
Kind code of ref document: A3 Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE |
|
AX | Request for extension of the european patent |
Free format text: AL;LT;LV;MK;RO;SI |
|
17P | Request for examination filed |
Effective date: 20011015 |
|
AKX | Designation fees paid |
Free format text: AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
AK | Designated contracting states |
Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT;WARNING: LAPSES OF ITALIAN PATENTS WITH EFFECTIVE DATE BEFORE 2007 MAY HAVE OCCURRED AT ANY TIME BEFORE 2007. THE CORRECT EFFECTIVE DATE MAY BE DIFFERENT FROM THE ONE RECORDED. Effective date: 20030813 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20030813 Ref country code: CH Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20030813 Ref country code: LI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20030813 Ref country code: NL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20030813 Ref country code: BE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20030813 Ref country code: FR Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20030813 Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20030813 |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: EP |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: FG4D |
|
REF | Corresponds to: |
Ref document number: 60004463 Country of ref document: DE Date of ref document: 20030918 Kind code of ref document: P |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20031018 Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20031018 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: IE Payment date: 20031023 Year of fee payment: 4 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MC Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20031031 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20031113 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20031113 Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20031113 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20031114 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20031124 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20040113 |
|
NLV1 | Nl: lapsed or annulled due to failure to fulfill the requirements of art. 29p and 29m of the patents act | ||
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
26N | No opposition filed |
Effective date: 20040514 |
|
EN | Fr: translation not filed | ||
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20041018 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20051012 Year of fee payment: 6 |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: MM4A |
|
GBPC | Gb: european patent ceased through non-payment of renewal fee |
Effective date: 20061018 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: GB Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20061018 |