WO2015088485A1 - Hardware interconnect based communication between solid state drive controllers - Google Patents
Hardware interconnect based communication between solid state drive controllers Download PDFInfo
- Publication number
- WO2015088485A1 WO2015088485A1 PCT/US2013/073949 US2013073949W WO2015088485A1 WO 2015088485 A1 WO2015088485 A1 WO 2015088485A1 US 2013073949 W US2013073949 W US 2013073949W WO 2015088485 A1 WO2015088485 A1 WO 2015088485A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- ssd
- ssd controller
- controller
- interconnect
- hardware interconnect
- 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.)
- Ceased
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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 OR CALCULATING; 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 OR CALCULATING; 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
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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 OR CALCULATING; 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/064—Management of blocks
- G06F3/0641—De-duplication techniques
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/0658—Controller construction arrangements
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/0662—Virtualisation aspects
- G06F3/0665—Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/0689—Disk arrays, e.g. RAID, JBOD
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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
Definitions
- SSD Solid state drive
- HDD hard disk drive
- SSD based storage options may provide advantages over legacy storage solutions ranging from faster data access to increased data throughput.
- the scalability of SSDs to petabytes and above demands dedicated hardware and software to address various challenges associated with legacy architectures. For example, scalability may be limited due to a communication bottleneck arising from housekeeping tasks associated with flash memory.
- Storage tasks such as redundant array of independent disks (RAID), backup, deduplication, defragmentation, garbage collection, and others may utilize substantial processing and networking resources available to an SSD.
- Scalability of SSDs may also be limited by the need to maintain association between metadata and data. Maintaining a coherent and updated description of the data may be challenging or non-practical while scaling legacy SSD implementations. Yet another limitation on scaling of SSDs may include scaling of input and output (I/O) bandwidth with flash memory associated with an SSD controller.
- I/O input and output
- the present disclosure generally describes techniques for implementing hardware interconnect based communication between solid state drive controllers.
- a method is provided to establish a hardware interconnect based communication between solid state drive (SSD) controllers.
- An example method may include detecting a first solid state drive (SSD) controller and a second SSD controller.
- the method may further include detecting the hardware interconnect between the first SSD controller and the second SSD controller, and establishing a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
- a computing device including a processor is provided to establish a hardware interconnect based communication between SSD controllers.
- the computing device may include a memory configured to store instructions, a processor, and a solid state drive (SSD) coupled to the memory and the processor.
- the SSD may include an interconnect module configured to detect a first SSD controller within the SSD and a second SSD controller within another SSD of the computing device.
- the interconnect module may be further configured to detect the hardware interconnect between the first SSD controller and the second SSD controller, and establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
- a computer readable medium may store instructions to establish a hardware interconnect based communication between SSD controllers.
- the instructions may cause a method to be performed when executed, the method may include detecting a first solid state drive (SSD) controller within a first SSD, detecting a second SSD controller within a second SSD, detecting a first hardware interconnect between the first SSD controller and the second SSD controller, establishing a first communication connection between the first and the second SSD through the first hardware interconnect, detecting a third SSD controller, detecting a second hardware interconnect between the second SSD controller and the third SSD controller, and establishing a second
- SSD solid state drive
- FIG. 1 illustrates example components of a solid state drive (SSD);
- FIG. 2 illustrates an example schema of hardware interconnect based communication between SSD controllers
- FIG. 3 illustrates addition and extension in function of a scalable architecture of an example SSD through hardware interconnect based communication between SSD controllers
- FIG. 4 illustrates a general purpose computing device, which may be used to establish hardware interconnect based communication between SSD controllers
- FIG. 5 is a flow diagram illustrating an example method to establish hardware interconnect based communication between SSD controllers.
- FIG. 6 illustrates a block diagram of an example computer program product to establish hardware interconnect based communication between SSD controllers
- This disclosure is generally drawn, inter alia, to methods, apparatus, systems, devices, and/or computer program products related to hardware interconnect based communication between solid stated drive (SSD) controllers.
- SSD solid stated drive
- a hardware interconnect based communication between SSD controllers According to some examples, a first solid state drive (SSD) controller and a second SSD controller are detected. The hardware interconnect is detected between the first SSD controller and the second SSD controller. Next, a communication connection between the first SSD controller and the second SSD controller is established through the hardware interconnect. The first SSD controller may be allowed to manage a flash controller of the second SSD controller for tasks that include a deduplication task and a low level redundant array of independent disks (RAID) task.
- RAID redundant array of independent disks
- FIG. 1 illustrates example components of a solid state drive (SSD), arranged in accordance with at least some embodiments described herein.
- SSD solid state drive
- a diagram 100 shows components of an SSD system 102.
- Components may include an SSD controller 104, a flash controller 106, and a flash memory 108.
- the flash memory 108 may include an integrated circuit (IC) capable of storing information in a non-volatile state.
- IC integrated circuit
- SLC single-level cell
- MLC multi-level cell
- TLC triple-level cell
- the flash controller 106 may include an IC to control one or more flash memories (for example, the flash memory 108).
- the flash controller 106 may provide error correcting code (ECC) related operations to manage error handling at the flash memory 108.
- ECC error correcting code
- the flash controller 106 may provide file system related functions to read data from and to write data to the flash memory 108.
- the SSD controller 104 may include an IC to control one or more flash controller(s) (for example, the flash controller 106).
- the SSD controller 104 may provide multi-controller architecture related functions to manage one or more flash controller(s).
- one or more SSD controller(s) may be connected through a hardware interconnect to establish a communication connection between the SSD controllers to move communication tasks associated with the SSD system 102 to the SSD controller 104.
- the SSD system 102 may include an IC that encapsulates the components previously mentioned.
- the SSD system 102 may perform high level functions such as data input and output (I/O) between components of the SSD system 102 and other devices.
- Data I/O may be provided through standardized data connection bus including, but not exclusive to, a peripheral component interconnect (PCI) express bus and a serial advance technology attachment (SATA) bus.
- PCI peripheral component interconnect
- SATA serial advance technology attachment
- a communication connection may be established between two or more SSD systems through a hardware interconnect that connects corresponding SSD controllers of the two or more SSD systems.
- a legacy network connection used to connect the two or more SSD systems may be circumvented through the hardware interconnect.
- the hardware interconnect may include any communication mechanism between SSD controller via electrical or optical communication signals.
- the hardware interconnect may confirm to a standard such as peripheral component interconnect express (PCIe), nonvolatile memory host controller interface, or comparable ones.
- PCIe peripheral component interconnect express
- the hardware interconnect may also be according to a proprietary approach.
- the hardware interconnect may allow the two or more SSD systems to establish a communication connection with shorter trace paths, shorter response time, faster data I/O, and faster data processing.
- the legacy network connections may not only include electrically and physically distances, but communication standards used over the legacy networks may also result in slower communication speeds.
- a direct hardware interconnect between the SSD controllers may provide shorter electrical and physical distances and allow much faster data exchanges. Communication tasks associated with the two or more SSD systems may be offloaded to the corresponding SSD controllers.
- the two or more SSD controllers within the SSD system 102 may be connected using the hardware interconnect.
- communication tasks associated with the SSD system 102 may be offloaded to the two or more SSD controllers.
- FIG. 2 illustrates an example schema of hardware interconnect based communication between SSD controllers, arranged in accordance with at least some of embodiments described herein.
- a diagram 200 shows a scheme using multiple hardware interconnects to establish communication connections between multiple SSD controllers.
- a first SSD controller 222 may manage a first flash controller 230 and a second flash controller 232.
- the first flash controller 230 may manage a first flash memory 240 and a second flash memory 242.
- the second flash controller 232 may manage a third flash memory 244 and a fourth flash memory 246.
- the first SSD controller 222 may be connected to a second SSD controller 220 within a first SSD system 214 through a first hardware interconnect 202.
- the first SSD controller 222 may be connected to a third SSD controller 224 of a second SSD system 216 through a second hardware interconnect 204.
- the first hardware interconnect 202 and the second hardware interconnect 204 may be used to provide functions associated with the first SSD system 214 and the second SSD system 216 through the second SSD controller 220, the first SSD controller 222, and the third SSD controller 224.
- the functions may include, by way of example, management of a scalable file system spanning multiple flash memory spanning one or more SSD systems.
- Data received through a first I/O port 210 and a second I/O port 212 may also be routed through the first hardware interconnect 202 and the second hardware interconnect 204 by the second SSD controller 220, the first SSD controller 222, or the third SSD controller 224 to access the first flash memory 240, the second flash memory 242, the third flash memory 244, or the fourth flash memory 246 associated with the data.
- data received through the first I/O port 210 may be routed through the second SSD controller 220 to the first hardware interconnect 202 to the first SSD controller 222 to the first flash controller 230 to access the first flash memory 240 or the second flash memory 242.
- data received through the second I/O port 212 may be routed through the third SSD controller 224 to the second hardware interconnect 204 to the first SSD controller 222 to the second flash controller 232 to access the third flash memory 244 or the fourth flash memory 246.
- FIG. 3 illustrates addition and extension in function of a scalable architecture of an example SSD through hardware interconnect based communication between SSD controllers, arranged in accordance with at least some of embodiments described herein.
- a diagram 300 shows an extended component diagram describing added functionality associated with hardware interconnects.
- a flash controller 306 may manage one or more flash memories such as a flash memory 308.
- the flash controller 306 may provide flash memory management functionality 324 including a device I/O connection, distributed file systems, device embedded ECC, TLC or MLC embedded ECC, stripe level ECC, on chip replication, lower level redundant array of independent disks (RAID), distributed computing, on chip read and write (RW) management, on chip data management, and chip level device monitor.
- the flash memory management functionality 324 may include management of embedded processor within the flash controller 306.
- On chip replication functionality may include data replication features associated with the flash controller 306.
- Distributed file systems and computing functionality may include management of operations associated with maintaining a file system spanning multiple flash memory managed through multiple flash controllers.
- An SSD controller 304 may manage one or more flash controllers.
- the SSD controller 304 may provide functionality including device I/O connection, expendable file systems, SSD ECC technology, scalable ECC technology, end to end protection, cross-SSD computing, virtual recovery, background processing, and SSD level device monitor.
- the SSD controller 304 may provide additional functionality corresponding to a communication connection established through hardware interconnect.
- the additional functionality may include a controller communication 312, a multi-controller architecture 314, a scalable file system 316, cross-chips replication, chips level RAID, and cross-chip RW management 318.
- the controller communication 312 may allow the SSD controller 304 to manage the controller communication bus as an extension of the device I/O.
- the controller communication 312 may support system level and intersystem communication.
- the controller communication 312 may address two level mapping of SSD controller addresses.
- the SSD controller can directly control the accessible memory in the SSD or it can control remote memory in another SSD drive.
- a communication port associated with the controller communication 312 may include standardized high speed communication bus such a SATA bus or a PCI Express bus.
- the multi-controller architecture 314 functionality may be used to provide a multi system addressing scheme.
- a first SSD controller may use the multi-controller architecture 314 functionality to control a flash controller connected to a second SSD controller.
- the first SSD controller may use the multi-controller architecture 314 in tasks such as, by way of example, backup, deduplication, defragmentation, garbage collection, or RAID.
- the scalable file system 316 may be used to offload functions from the SSD system 302.
- the scalable file system 316 may be used to create the SSD system 302 in which metadata and data reside in multiple SSD systems that are connected using hardware interconnects between SSD controllers.
- the scalable file system 316 may be used to update SSD controllers while shifting the update tasks away from the SSD system 302 to prevent overload of the SSD system 302 and any associated network connections.
- Cross-chips replication, RAID, and the cross-chip RW management 318 functionality may be provided through the SSD controller 304 using the hardware interconnect to communicate with other SSD controllers.
- Cross-chips replication, RAID, and the cross-chip RW management 318 functions may be implemented through SSD controllers to extend scope of the functions beyond one or more flash controller tree structure connected to a single controller such as the SSD controller 304.
- the SSD system 302 may provide system level functions
- System scalability function may include I/O
- system level functions 310 may include data integrity.
- Data integrity function may include system ECC technology, in system data replication, and data recovery related tasks.
- system level functions 310 may include performance and reliability.
- Performance and reliability functions may include tasks associated with monitoring and managing performance and reliability of the SSD system 302.
- Embodiments described herein may be implemented via combinations of hardware and software components.
- the software components may operate with
- embodiments are not limited to wired and/or wireless systems, but may be implemented in any measurement/determination device/application used in any electronics system that uses the measurement/determination device/application such as wireless networks, speech processors, (medical) image processors, and similar ones.
- FIG. 4 illustrates a general purpose computing device, which may be used to establish a hardware interconnect based communication between SSD controllers, arranged in accordance with at least some embodiments described herein.
- the computing device 400 of FIG. 4 may be one or more of the first SSD system 214, the second SSD system 216, the second SSD controller 220, the first SSD controller 222, and the third SSD controller 224, or some other device that is not shown in FIG. 2.
- computing device 400 typically includes one or more processors 404 and a system memory 406.
- a memory bus 408 may be used for communicating between processor 404 and system memory 406.
- processor 404 may be of any type including but not limited to a microprocessor ( ⁇ ), a microcontroller ( ⁇ ), a Digital Signal Processor (DSP), or any combination thereof.
- Processor 404 may include one more levels of caching, such as a level cache memory 412, a processor core 414, and registers 416.
- Example processor core 414 may include an Arithmetic Logic Unit (ALU), a floating point unit (FPU), a Digital Signal Processing core (DSP Core), or any combination thereof.
- An example memory controller 418 may also be used with processor 404, or in some implementations, memory controller 414 may be an internal part of processor 404.
- system memory 406 may be of any type including but not limited to volatile memory (such as RAM), non-volatile memory (such as ROM, flash memory, etc.) or any combination thereof.
- System memory 406 may include an operating system 420, one or more SSD applications 422, and program data 424.
- SSD application 422 may include an interconnect module 426 that is arranged to a hardware interconnect based communication between SSD controllers.
- Program data 424 may include one or more of controller communication data 428 and similar data as discussed above in conjunction with at least FIG. 1, 2, and 3. This data may be useful for establishing a hardware interconnect based communication between SSD controllers as is described herein.
- This described basic configuration 402 is illustrated in FIG. 4 by those components within the inner dashed line.
- Computing device 400 may have additional features or functionality, and additional interfaces to facilitate communications between basic configuration 402 and any required devices and interfaces.
- a bus/interface controller 430 may be used to facilitate communications between basic configuration 402 and one or more data storage devices 432 via a storage interface bus 434.
- Data storage devices 432 may be removable storage devices 436, non-removable storage devices 438, or a combination thereof.
- Examples of removable storage and non-removable storage devices include magnetic disk devices such as flexible disk drives and Hard-Disk Drives (HDDs), optical disk drives such as Compact Disk (CD) drives or Digital Versatile Disk (DVD) drives, Solid State Drives (SSDs), and tape drives to name a few.
- Example computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data.
- System memory 406, removable storage devices 436 and non-removable storage devices 438 are examples of computer storage media.
- Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD- ROM, digital versatile disks (DVDs) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which may be used to store information and which may be accessed by computing device 400. Any such computer storage media may be part of computing device 400.
- Computing device 400 may also include an interface bus 440 for facilitating communication from various interface devices (for example, output devices 442, peripheral interfaces 444, and communication devices 466 to basic configuration 402 via bus/interface controller 430.
- Example output devices 442 include a graphics processing unit 448 and an audio processing unit 440, which may be configured to communicate to various external devices such as a display or speakers via one or more A/V ports 442.
- Example peripheral interfaces 444 include a serial interface controller 444 or a parallel interface controller 446, which may be configured to communicate with external devices such as input devices (for example, keyboard, mouse, pen, voice input device, touch input device, etc.) or other peripheral devices (for example, printer, scanner, etc.) via one or more I/O ports 448.
- An example communication device 466 includes a network controller 460, which may be arranged to facilitate communications with one or more other computing devices 462 over a network communication link via one or more communication ports 464.
- the network communication link may be one example of a communication media.
- Communication media may typically be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and may include any information delivery media.
- a "modulated data signal" may be a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal.
- communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), microwave, infrared (IR) and other wireless media.
- RF radio frequency
- IR infrared
- the term computer readable media as used herein may include both storage media and communication media.
- Computing device 400 may be implemented as a portion of a physical server, virtual server, a computing cloud, or a hybrid device that include any of the above functions.
- Computing device 400 may also be implemented as a personal computer including both laptop computer and non-laptop computer configurations.
- computing device 400 may be implemented as a networked system or as part of a general purpose or specialized server.
- Networks for a networked system including computing device 400 may comprise any topology of servers, clients, switches, routers, modems, Internet service providers, and any appropriate communication media (for example, wired or wireless communications).
- a system according to embodiments may have a static or dynamic network topology.
- the networks may include a secure network such as an enterprise network (for example, a LAN, WAN, or WLAN), an unsecure network such as a wireless open network (for example, IEEE 802.1 1 wireless networks), or a world-wide network such (for example, the Internet).
- the networks may also comprise a plurality of distinct networks that are adapted to operate together. Such networks are configured to provide communication between the nodes described herein.
- these networks may include wireless media such as acoustic, RF, infrared and other wireless media.
- the networks may be portions of the same network or separate networks.
- FIG. 5 is a flow diagram illustrating an example method to establish hardware interconnect based communication between SSD controllers that may be performed by a computing device, such as the computing device 400 in FIG. 4, arranged in accordance with at least some embodiments described herein.
- a computing device 510 may be embodied as computing device 400, or similar devices executing instructions stored in a non-transitory computer-readable medium 520 for performing the method.
- a process to establish hardware interconnect based communication between SSD controllers may include one or more operations, functions or actions as is illustrated by one or more of blocks 522, 524, 526, and/or 528.
- Some example processes may begin with operation 522, "DETECT A FIRST SOLID STATE DRIVE (SSD) CONTROLLER.”
- a computing device 400 may query the first SSD controller 222 to determine available functions associated with the first SSD controller 222.
- Operation 522 may be followed by operation 524, "DETECT A SECOND SSD CONTROLLER.”
- the computing device 400 may query the second SSD controller 220 to determine available functions associated with the second SSD controller 220.
- Operation 524 may be followed by operation 526, "DETECT A HARDWARE INTERCONNECT BETWEEN THE FIRST SSD CONTROLLER AND THE SECOND SSD CONTROLLER.”
- the computing device 400 may determine the first hardware interconnect 204 exists by analyzing the available functions provided by the first SSD controller 222 and the second SSD controller 220.
- Operation 526 may be followed by operation 528, "ESTABLISH A
- the communication connection may be established to shift functionality associated with the first SSD system 214 or the second SSD system 216 associated with the first SSD controller 222 or the second SSD controller 220 to execute the functionality on the first SSD controller 222 and the second SSD controller 220 through the communication connection.
- FIG. 6 illustrates a block diagram of an example computer program product to establish hardware interconnect based communication between SSD controllers, arranged in accordance with at least some embodiments described herein.
- computer program product 600 may include a signal bearing medium 602 that may also include machine readable instructions 604 that, in response to execution by, for example, a processor, may provide the functionality described above with respect to FIG 1 through FIG. 5.
- a processor may provide the functionality described above with respect to FIG 1 through FIG. 5.
- one or more of the tasks shown in FIG. 6 may be undertaken in response to instructions 604 conveyed to the computing device 400 by medium 602 to perform actions associated with establishing a hardware interconnect based communication between SSD controllers as described herein.
- Some of those instructions may include to detect a first solid state drive (SSD) controller, to detect a second SSD controller, to detect the hardware interconnect between the first SSD controller and the second SSD controller, and to establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
- SSD solid state drive
- signal bearing medium 602 depicted in FIG. 6 may encompass a non-transitory computer-readable medium 606, such as, but not limited to, a hard disk drive, a Compact Disc (CD), a Digital Versatile Disk (DVD), a digital tape, memory, etc.
- signal bearing medium 602 may encompass a recordable medium 608, such as, but not limited to, memory, read/write (R/W) CDs, R/W DVDs, etc.
- signal bearing medium 602 may encompass a communications medium 610, such as, but not limited to, a digital and/or an analog communication medium (for example, a fiber optic cable, a waveguide, a wired
- computer program product 600 may be conveyed to the processor 604 by an RF signal bearing medium 602, where the signal bearing medium 602 is conveyed by a wireless communications medium 610 (for example, a wireless communications medium conforming with the IEEE 802.11 standard).
- a wireless communications medium 610 for example, a wireless communications medium conforming with the IEEE 802.11 standard.
- a method is provided to establish a hardware interconnect based communication between SSD controllers.
- An example method may include detecting a first solid state drive (SSD) controller, detecting a second SSD controller, detecting the hardware interconnect between the first SSD controller and the second SSD controller, and establishing a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
- SSD solid state drive
- the method may further include detecting a third SSD controller; detecting a second hardware interconnect between the second SSD controller and the third SSD controller; and establishing a second communication connection between the second SSD controller and the third SSD controller through the second hardware interconnect.
- the first SSD controller and the second SSD controller may be detected within a first SSD.
- the first SSD controller may be detected within a first SSD
- the second SSD controller may be detected within a second SSD.
- a communication bus associated with the communication connection between the first SSD controller and the second SSD controller may be managed as a first extension of a first device input and output (I/O) of the first SSD controller and a second extension of a second device I/O of the second SSD controller.
- an addressing scheme supporting a system level mapping and an intersystem communication mapping may be provided between the first SSD controller and the second SSD controller.
- a multi-controller architecture may be
- the first SSD controller may be allowed to manage a flash controller of the second SSD controller for tasks that include at least one of: a deduplication task and a low level redundant array of independent disks (RAID) task.
- the second SSD controller may also be allowed to manage a flash controller of the first SSD controller for tasks that include at least one of: a deduplication task and a low level redundant array of independent disks (RAID) task
- a scalable file system may be implemented to offload functions from at least one SSD system associated with the first SSD controller and the second SSD controller, data and associated metadata may be created within the scalable file system, and the metadata may be updated through the hardware interconnect without overload of the at least one SSD system and a network connection associated with the at least one SSD system.
- One or more functions associated with the first SSD controller and the second SSD controller may be implemented through the hardware interconnect, where the functions include at least one from a set of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
- a computing device to establish a hardware interconnect based communication between SSD controllers.
- the computing device may include a memory configured to store instructions, a processor, and a solid state drive (SSD) coupled to the memory and the processor.
- the SSD may include an interconnect module.
- the interconnect module may be configured to detect a first SSD controller within the SSD, detect a second SSD controller within another SSD of the computing device, detect the hardware interconnect between the first SSD controller and the second SSD controller, and establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
- the interconnect module may further manage a communication bus associated with the communication connection between the first SSD controller and the second SSD controller as a first extension of a first device input and output (I/O) of the first SSD controller and a second extension of a second device I/O of the second SSD controller.
- the interconnect module may also provide an addressing scheme to support a system level mapping and an intersystem communication mapping between the first SSD controller and the second SSD controller.
- the interconnect module may implement one or more functions associated with the first SSD controller and the second SSD controller through the hardware interconnect, where the functions include at least one of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
- the interconnect module may implement a multi- controller architecture to provide a multi-system addressing scheme through a process to: allow the first SSD controller to manage a flash controller of the second SSD controller for tasks that include at least one of: a first deduplication task and a first low level redundant array of independent disks (RAID) task, and allow the second SSD controller to manage a flash controller of the first SSD controller for tasks that include at least one from a set of: a second deduplication task and a second low level redundant array of independent disks (RAID) task.
- a multi- controller architecture to provide a multi-system addressing scheme through a process to: allow the first SSD controller to manage a flash controller of the second SSD controller for tasks that include at least one of: a first deduplication task and a first low level redundant array of independent disks (RAID) task, and allow the second SSD controller to manage a flash controller of the first SSD controller for tasks that include at least one from a set of: a second deduplication task and a second low level redundant array of independent
- the interconnect module may implement a scalable file system to offload functions from at least one SSD system associated with the first SSD controller and the second SSD controller, create data and associated metadata within the scalable file system, and update the metadata through the hardware interconnect with no overload of the at least one SSD system and a network connection associated with the at least one SSD system.
- a computer-readable storage medium may be provided to establish a hardware interconnect based communication between SSD controllers.
- the instructions may cause a method to be performed in response to execution, the method being similar to the methods described above.
- the implementer may opt for a mainly hardware and/or firmware vehicle; if flexibility is paramount, the implementer may opt for a mainly software implementation; or, yet again alternatively, the implementer may opt for some combination of hardware, software, and/or firmware.
- Examples of a signal bearing medium include, but are not limited to, the following: a recordable type medium such as a floppy disk, a hard disk drive, a Compact Disc (CD), a Digital Versatile Disk (DVD), a digital tape, a computer memory, etc.; and a transmission type medium such as a digital and/or an analog communication medium (for example, a fiber optic cable, a waveguide, a wired communications link, a wireless communication link, etc.).
- a typical data processing system generally includes one or more of a system unit housing, a video display device, a memory such as volatile and non-volatile memory, processors such as microprocessors and digital signal processors, computational entities such as operating systems, drivers, graphical user interfaces, and applications programs, one or more interaction devices, such as a touch pad or screen, and/or control systems including feedback loops.
- a typical data processing system may be implemented utilizing any suitable commercially available components, such as those typically found in data
- any two components so associated may also be viewed as being “operably connected”, or “operably coupled”, to each other to achieve the particular functionality, and any two components capable of being so associated may also be viewed as being “operably couplable”, to each other to achieve the particular functionality.
- operably couplable include but are not limited to physically connectable and/or physically interacting components and/or wirelessly interactable and/or wirelessly interacting components and/or logically interacting and/or logically interactable components.
- a range includes each individual member.
- a group having 1-3 cells refers to groups having 1, 2, or 3 cells.
- a group having 1-5 cells refers to groups having 1, 2, 3, 4, or 5 cells, and so forth.
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)
- Computer Security & Cryptography (AREA)
- Debugging And Monitoring (AREA)
Abstract
Technologies are generally described to establish a hardware interconnect based communication between SSD controllers. According to some examples, a first solid state drive (SSD) controller and a second SSD controller are detected. The hardware interconnect is detected between the first SSD controller and the second SSD controller. Next, a communication connection between the first SSD controller and the second SSD controller is established through the hardware interconnect. The first SSD controller may be allowed to manage a flash controller of the second SSD controller for tasks that include a deduplication task and a low level redundant array of independent disks (RAID) task.
Description
HARDWARE INTERCONNECT BASED COMMUNICATION BETWEEN SOLID
STATE DRIVE CONTROLLERS
BACKGROUND
[0001] Unless otherwise indicated herein, the materials described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section.
[0002] Solid state drive (SSD) technology is rapidly replacing hard disk drive (HDD) as non- volatile memory of choice in data centers and other environments. SSD based storage options may provide advantages over legacy storage solutions ranging from faster data access to increased data throughput. The scalability of SSDs to petabytes and above demands dedicated hardware and software to address various challenges associated with legacy architectures. For example, scalability may be limited due to a communication bottleneck arising from housekeeping tasks associated with flash memory. Storage tasks such as redundant array of independent disks (RAID), backup, deduplication, defragmentation, garbage collection, and others may utilize substantial processing and networking resources available to an SSD.
[0003] Scalability of SSDs may also be limited by the need to maintain association between metadata and data. Maintaining a coherent and updated description of the data may be challenging or non-practical while scaling legacy SSD implementations. Yet another limitation on scaling of SSDs may include scaling of input and output (I/O) bandwidth with flash memory associated with an SSD controller.
SUMMARY
[0004] The present disclosure generally describes techniques for implementing hardware interconnect based communication between solid state drive controllers.
[0005] According to some examples, a method is provided to establish a hardware interconnect based communication between solid state drive (SSD) controllers. An example method may include detecting a first solid state drive (SSD) controller and a second SSD controller. The method may further include detecting the hardware interconnect between the first SSD controller and the second SSD controller, and establishing a communication
connection between the first SSD controller and the second SSD controller through the hardware interconnect.
[0006] According to other examples, a computing device including a processor is provided to establish a hardware interconnect based communication between SSD controllers. The computing device may include a memory configured to store instructions, a processor, and a solid state drive (SSD) coupled to the memory and the processor. The SSD may include an interconnect module configured to detect a first SSD controller within the SSD and a second SSD controller within another SSD of the computing device. The interconnect module may be further configured to detect the hardware interconnect between the first SSD controller and the second SSD controller, and establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
[0007] According to some examples, a computer readable medium may store instructions to establish a hardware interconnect based communication between SSD controllers. The instructions may cause a method to be performed when executed, the method may include detecting a first solid state drive (SSD) controller within a first SSD, detecting a second SSD controller within a second SSD, detecting a first hardware interconnect between the first SSD controller and the second SSD controller, establishing a first communication connection between the first and the second SSD through the first hardware interconnect, detecting a third SSD controller, detecting a second hardware interconnect between the second SSD controller and the third SSD controller, and establishing a second
communication connection between the second SSD controller and the third SSD controller through the second hardware interconnect.
[0008] The foregoing summary is illustrative only and is not intended to be in any way limiting. In addition to the illustrative aspects, embodiments, and features described above, further aspects, embodiments, and features will become apparent by reference to the drawings and the following detailed description.
BRIEF DESCRIPTION OF THE DRAWINGS
[0009] The foregoing and other features of this disclosure will become more fully apparent from the following description and appended claims, taken in conjunction with the accompanying drawings. Understanding that these drawings depict only several embodiments
in accordance with the disclosure and are, therefore, not to be considered limiting of its scope, the disclosure will be described with additional specificity and detail through use of the accompanying drawings, in which:
FIG. 1 illustrates example components of a solid state drive (SSD);
FIG. 2 illustrates an example schema of hardware interconnect based communication between SSD controllers;
FIG. 3 illustrates addition and extension in function of a scalable architecture of an example SSD through hardware interconnect based communication between SSD controllers;
FIG. 4 illustrates a general purpose computing device, which may be used to establish hardware interconnect based communication between SSD controllers;
FIG. 5 is a flow diagram illustrating an example method to establish hardware interconnect based communication between SSD controllers; and
FIG. 6 illustrates a block diagram of an example computer program product to establish hardware interconnect based communication between SSD controllers,
all arranged in accordance with at least some embodiments described herein.
DETAILED DESCRIPTION
[0010] In the following detailed description, reference is made to the accompanying drawings, which form a part hereof. In the drawings, similar symbols typically identify similar components, unless context dictates otherwise. The illustrative embodiments described in the detailed description, drawings, and claims are not meant to be limiting. Other embodiments may be utilized, and other changes may be made, without departing from the spirit or scope of the subject matter presented herein. The aspects of the present disclosure, as generally described herein, and illustrated in the Figures, can be arranged, substituted, combined, separated, and designed in a wide variety of different configurations, all of which are explicitly contemplated herein.
[0011] This disclosure is generally drawn, inter alia, to methods, apparatus, systems, devices, and/or computer program products related to hardware interconnect based communication between solid stated drive (SSD) controllers.
[0012] Briefly stated, technologies are generally described to establish a hardware interconnect based communication between SSD controllers. According to some examples, a first solid state drive (SSD) controller and a second SSD controller are detected. The
hardware interconnect is detected between the first SSD controller and the second SSD controller. Next, a communication connection between the first SSD controller and the second SSD controller is established through the hardware interconnect. The first SSD controller may be allowed to manage a flash controller of the second SSD controller for tasks that include a deduplication task and a low level redundant array of independent disks (RAID) task.
[0013] FIG. 1 illustrates example components of a solid state drive (SSD), arranged in accordance with at least some embodiments described herein.
[0014] As depicted, a diagram 100 shows components of an SSD system 102.
Components may include an SSD controller 104, a flash controller 106, and a flash memory 108. The flash memory 108 may include an integrated circuit (IC) capable of storing information in a non-volatile state. Although there are many forms of the flash memory 108, some modern non-limiting examples include single-level cell (SLC), multi-level cell (MLC), and triple-level cell (TLC) based ICs used to store information.
[0015] The flash controller 106 may include an IC to control one or more flash memories (for example, the flash memory 108). The flash controller 106 may provide error correcting code (ECC) related operations to manage error handling at the flash memory 108. In addition, the flash controller 106 may provide file system related functions to read data from and to write data to the flash memory 108.
[0016] The SSD controller 104 may include an IC to control one or more flash controller(s) (for example, the flash controller 106). The SSD controller 104 may provide multi-controller architecture related functions to manage one or more flash controller(s). In addition, one or more SSD controller(s) may be connected through a hardware interconnect to establish a communication connection between the SSD controllers to move communication tasks associated with the SSD system 102 to the SSD controller 104.
[0017] The SSD system 102 may include an IC that encapsulates the components previously mentioned. In addition, the SSD system 102 may perform high level functions such as data input and output (I/O) between components of the SSD system 102 and other devices. Data I/O may be provided through standardized data connection bus including, but not exclusive to, a peripheral component interconnect (PCI) express bus and a serial advance technology attachment (SATA) bus.
[0018] A communication connection may be established between two or more SSD systems through a hardware interconnect that connects corresponding SSD controllers of the two or more SSD systems. A legacy network connection used to connect the two or more SSD systems may be circumvented through the hardware interconnect. The hardware interconnect may include any communication mechanism between SSD controller via electrical or optical communication signals. The hardware interconnect may confirm to a standard such as peripheral component interconnect express (PCIe), nonvolatile memory host controller interface, or comparable ones. The hardware interconnect may also be according to a proprietary approach. Thus, by avoiding legacy network connections between the SSD controllers, the hardware interconnect may allow the two or more SSD systems to establish a communication connection with shorter trace paths, shorter response time, faster data I/O, and faster data processing. The legacy network connections may not only include electrically and physically distances, but communication standards used over the legacy networks may also result in slower communication speeds. In contrast, a direct hardware interconnect between the SSD controllers may provide shorter electrical and physical distances and allow much faster data exchanges. Communication tasks associated with the two or more SSD systems may be offloaded to the corresponding SSD controllers.
[0019] Alternatively, the two or more SSD controllers within the SSD system 102 may be connected using the hardware interconnect. In such a scenario, communication tasks associated with the SSD system 102 may be offloaded to the two or more SSD controllers.
[0020] FIG. 2 illustrates an example schema of hardware interconnect based communication between SSD controllers, arranged in accordance with at least some of embodiments described herein.
[0021] As depicted, a diagram 200 shows a scheme using multiple hardware interconnects to establish communication connections between multiple SSD controllers. In an example scenario, a first SSD controller 222 may manage a first flash controller 230 and a second flash controller 232. The first flash controller 230 may manage a first flash memory 240 and a second flash memory 242. The second flash controller 232 may manage a third flash memory 244 and a fourth flash memory 246.
[0022] The first SSD controller 222 may be connected to a second SSD controller 220 within a first SSD system 214 through a first hardware interconnect 202. In addition, the first SSD controller 222 may be connected to a third SSD controller 224 of a second SSD system
216 through a second hardware interconnect 204. The first hardware interconnect 202 and the second hardware interconnect 204 may be used to provide functions associated with the first SSD system 214 and the second SSD system 216 through the second SSD controller 220, the first SSD controller 222, and the third SSD controller 224. The functions may include, by way of example, management of a scalable file system spanning multiple flash memory spanning one or more SSD systems. Data received through a first I/O port 210 and a second I/O port 212 may also be routed through the first hardware interconnect 202 and the second hardware interconnect 204 by the second SSD controller 220, the first SSD controller 222, or the third SSD controller 224 to access the first flash memory 240, the second flash memory 242, the third flash memory 244, or the fourth flash memory 246 associated with the data. In an example scenario, data received through the first I/O port 210 may be routed through the second SSD controller 220 to the first hardware interconnect 202 to the first SSD controller 222 to the first flash controller 230 to access the first flash memory 240 or the second flash memory 242. Alternatively, data received through the second I/O port 212 may be routed through the third SSD controller 224 to the second hardware interconnect 204 to the first SSD controller 222 to the second flash controller 232 to access the third flash memory 244 or the fourth flash memory 246.
[0023] FIG. 3 illustrates addition and extension in function of a scalable architecture of an example SSD through hardware interconnect based communication between SSD controllers, arranged in accordance with at least some of embodiments described herein.
[0024] As depicted, a diagram 300 shows an extended component diagram describing added functionality associated with hardware interconnects. A flash controller 306 may manage one or more flash memories such as a flash memory 308. The flash controller 306 may provide flash memory management functionality 324 including a device I/O connection, distributed file systems, device embedded ECC, TLC or MLC embedded ECC, stripe level ECC, on chip replication, lower level redundant array of independent disks (RAID), distributed computing, on chip read and write (RW) management, on chip data management, and chip level device monitor. In addition, the flash memory management functionality 324 may include management of embedded processor within the flash controller 306. On chip replication functionality may include data replication features associated with the flash controller 306. Distributed file systems and computing functionality may include
management of operations associated with maintaining a file system spanning multiple flash memory managed through multiple flash controllers.
[0025] An SSD controller 304 may manage one or more flash controllers. The SSD controller 304 may provide functionality including device I/O connection, expendable file systems, SSD ECC technology, scalable ECC technology, end to end protection, cross-SSD computing, virtual recovery, background processing, and SSD level device monitor. The SSD controller 304 may provide additional functionality corresponding to a communication connection established through hardware interconnect. The additional functionality may include a controller communication 312, a multi-controller architecture 314, a scalable file system 316, cross-chips replication, chips level RAID, and cross-chip RW management 318.
[0026] The controller communication 312 may allow the SSD controller 304 to manage the controller communication bus as an extension of the device I/O. The controller communication 312 may support system level and intersystem communication. In addition, the controller communication 312 may address two level mapping of SSD controller addresses. The SSD controller can directly control the accessible memory in the SSD or it can control remote memory in another SSD drive. A communication port associated with the controller communication 312 may include standardized high speed communication bus such a SATA bus or a PCI Express bus.
[0027] The multi-controller architecture 314 functionality may be used to provide a multi system addressing scheme. In an example scenario, a first SSD controller may use the multi-controller architecture 314 functionality to control a flash controller connected to a second SSD controller. The first SSD controller may use the multi-controller architecture 314 in tasks such as, by way of example, backup, deduplication, defragmentation, garbage collection, or RAID.
[0028] The scalable file system 316 may be used to offload functions from the SSD system 302. The scalable file system 316 may be used to create the SSD system 302 in which metadata and data reside in multiple SSD systems that are connected using hardware interconnects between SSD controllers. The scalable file system 316 may be used to update SSD controllers while shifting the update tasks away from the SSD system 302 to prevent overload of the SSD system 302 and any associated network connections.
[0029] Cross-chips replication, RAID, and the cross-chip RW management 318 functionality may be provided through the SSD controller 304 using the hardware
interconnect to communicate with other SSD controllers. Cross-chips replication, RAID, and the cross-chip RW management 318 functions may be implemented through SSD controllers to extend scope of the functions beyond one or more flash controller tree structure connected to a single controller such as the SSD controller 304.
[0030] In addition, the SSD system 302 may provide system level functions
3 lOincluding system scalability. System scalability function may include I/O
interconnection, scalable file systems, and resource management related tasks. Furthermore, the system level functions 310 may include data integrity. Data integrity function may include system ECC technology, in system data replication, and data recovery related tasks. Moreover, the system level functions 310 may include performance and reliability.
Performance and reliability functions may include tasks associated with monitoring and managing performance and reliability of the SSD system 302.
[0031] Embodiments described herein may be implemented via combinations of hardware and software components. The software components may operate with
communication or signaling systems, to establish a hardware interconnect based
communication between SSD controllers. Moreover, embodiments are not limited to wired and/or wireless systems, but may be implemented in any measurement/determination device/application used in any electronics system that uses the measurement/determination device/application such as wireless networks, speech processors, (medical) image processors, and similar ones.
[0032] While embodiments have been discussed above using specific examples, components, scenarios, and configurations in FIG. 1, FIG. 2, and FIG. 3 they are intended to provide a general guideline to be used to establish a hardware interconnect based
communication between SSD controllers. These examples do not constitute a limitation on the embodiments, which may be implemented using other components, optimization schemes, and configurations using the principles described herein. For example, other algorithms may be implemented than those provided as example.
[0033] FIG. 4 illustrates a general purpose computing device, which may be used to establish a hardware interconnect based communication between SSD controllers, arranged in accordance with at least some embodiments described herein. The computing device 400 of FIG. 4 may be one or more of the first SSD system 214, the second SSD system 216, the second SSD controller 220, the first SSD controller 222, and the third SSD controller 224, or
some other device that is not shown in FIG. 2. In a very basic configuration 402, computing device 400 typically includes one or more processors 404 and a system memory 406. A memory bus 408 may be used for communicating between processor 404 and system memory 406.
[0034] Depending on a particular configuration, processor 404 may be of any type including but not limited to a microprocessor (μΡ), a microcontroller (μθ), a Digital Signal Processor (DSP), or any combination thereof. Processor 404 may include one more levels of caching, such as a level cache memory 412, a processor core 414, and registers 416.
Example processor core 414 may include an Arithmetic Logic Unit (ALU), a floating point unit (FPU), a Digital Signal Processing core (DSP Core), or any combination thereof. An example memory controller 418 may also be used with processor 404, or in some implementations, memory controller 414 may be an internal part of processor 404.
[0035] Depending on the particular configuration, system memory 406 may be of any type including but not limited to volatile memory (such as RAM), non-volatile memory (such as ROM, flash memory, etc.) or any combination thereof. System memory 406 may include an operating system 420, one or more SSD applications 422, and program data 424. SSD application 422 may include an interconnect module 426 that is arranged to a hardware interconnect based communication between SSD controllers. Program data 424 may include one or more of controller communication data 428 and similar data as discussed above in conjunction with at least FIG. 1, 2, and 3. This data may be useful for establishing a hardware interconnect based communication between SSD controllers as is described herein. This described basic configuration 402 is illustrated in FIG. 4 by those components within the inner dashed line.
[0036] Computing device 400 may have additional features or functionality, and additional interfaces to facilitate communications between basic configuration 402 and any required devices and interfaces. For example, a bus/interface controller 430 may be used to facilitate communications between basic configuration 402 and one or more data storage devices 432 via a storage interface bus 434. Data storage devices 432 may be removable storage devices 436, non-removable storage devices 438, or a combination thereof.
Examples of removable storage and non-removable storage devices include magnetic disk devices such as flexible disk drives and Hard-Disk Drives (HDDs), optical disk drives such as Compact Disk (CD) drives or Digital Versatile Disk (DVD) drives, Solid State Drives
(SSDs), and tape drives to name a few. Example computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data.
[0037] System memory 406, removable storage devices 436 and non-removable storage devices 438 are examples of computer storage media. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD- ROM, digital versatile disks (DVDs) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which may be used to store information and which may be accessed by computing device 400. Any such computer storage media may be part of computing device 400.
[0038] Computing device 400 may also include an interface bus 440 for facilitating communication from various interface devices (for example, output devices 442, peripheral interfaces 444, and communication devices 466 to basic configuration 402 via bus/interface controller 430. Example output devices 442 include a graphics processing unit 448 and an audio processing unit 440, which may be configured to communicate to various external devices such as a display or speakers via one or more A/V ports 442. Example peripheral interfaces 444 include a serial interface controller 444 or a parallel interface controller 446, which may be configured to communicate with external devices such as input devices (for example, keyboard, mouse, pen, voice input device, touch input device, etc.) or other peripheral devices (for example, printer, scanner, etc.) via one or more I/O ports 448. An example communication device 466 includes a network controller 460, which may be arranged to facilitate communications with one or more other computing devices 462 over a network communication link via one or more communication ports 464.
[0039] The network communication link may be one example of a communication media. Communication media may typically be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and may include any information delivery media. A "modulated data signal" may be a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF),
microwave, infrared (IR) and other wireless media. The term computer readable media as used herein may include both storage media and communication media.
[0040] Computing device 400 may be implemented as a portion of a physical server, virtual server, a computing cloud, or a hybrid device that include any of the above functions. Computing device 400 may also be implemented as a personal computer including both laptop computer and non-laptop computer configurations. Moreover, computing device 400 may be implemented as a networked system or as part of a general purpose or specialized server.
[0041] Networks for a networked system including computing device 400 may comprise any topology of servers, clients, switches, routers, modems, Internet service providers, and any appropriate communication media (for example, wired or wireless communications). A system according to embodiments may have a static or dynamic network topology. The networks may include a secure network such as an enterprise network (for example, a LAN, WAN, or WLAN), an unsecure network such as a wireless open network (for example, IEEE 802.1 1 wireless networks), or a world-wide network such (for example, the Internet). The networks may also comprise a plurality of distinct networks that are adapted to operate together. Such networks are configured to provide communication between the nodes described herein. By way of example, and not limitation, these networks may include wireless media such as acoustic, RF, infrared and other wireless media.
Furthermore, the networks may be portions of the same network or separate networks.
[0042] FIG. 5 is a flow diagram illustrating an example method to establish hardware interconnect based communication between SSD controllers that may be performed by a computing device, such as the computing device 400 in FIG. 4, arranged in accordance with at least some embodiments described herein.
[0043] As depicted, a computing device 510 may be embodied as computing device 400, or similar devices executing instructions stored in a non-transitory computer-readable medium 520 for performing the method. A process to establish hardware interconnect based communication between SSD controllers may include one or more operations, functions or actions as is illustrated by one or more of blocks 522, 524, 526, and/or 528.
[0044] Some example processes may begin with operation 522, "DETECT A FIRST SOLID STATE DRIVE (SSD) CONTROLLER." At operation 522, a computing device 400
may query the first SSD controller 222 to determine available functions associated with the first SSD controller 222.
[0045] Operation 522 may be followed by operation 524, "DETECT A SECOND SSD CONTROLLER." At operation 524, the computing device 400 may query the second SSD controller 220 to determine available functions associated with the second SSD controller 220.
[0046] Operation 524 may be followed by operation 526, "DETECT A HARDWARE INTERCONNECT BETWEEN THE FIRST SSD CONTROLLER AND THE SECOND SSD CONTROLLER." At operation 526, the computing device 400 may determine the first hardware interconnect 204 exists by analyzing the available functions provided by the first SSD controller 222 and the second SSD controller 220.
[0047] Operation 526 may be followed by operation 528, "ESTABLISH A
COMMUNICATION CONNECTION BETWEEN THE FIRST SSD AND THE SECOND SSD CONTROLLER THROUGH THE HARDWARE INTERCONNECT." At operation 528, the communication connection may be established to shift functionality associated with the first SSD system 214 or the second SSD system 216 associated with the first SSD controller 222 or the second SSD controller 220 to execute the functionality on the first SSD controller 222 and the second SSD controller 220 through the communication connection.
[0048] FIG. 6 illustrates a block diagram of an example computer program product to establish hardware interconnect based communication between SSD controllers, arranged in accordance with at least some embodiments described herein.
[0049] In some examples, as shown in FIG. 6, computer program product 600 may include a signal bearing medium 602 that may also include machine readable instructions 604 that, in response to execution by, for example, a processor, may provide the functionality described above with respect to FIG 1 through FIG. 5. Thus, for example, referring to computing device 400, one or more of the tasks shown in FIG. 6 may be undertaken in response to instructions 604 conveyed to the computing device 400 by medium 602 to perform actions associated with establishing a hardware interconnect based communication between SSD controllers as described herein. Some of those instructions may include to detect a first solid state drive (SSD) controller, to detect a second SSD controller, to detect the hardware interconnect between the first SSD controller and the second SSD controller,
and to establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
[0050] In some implementations, signal bearing medium 602 depicted in FIG. 6 may encompass a non-transitory computer-readable medium 606, such as, but not limited to, a hard disk drive, a Compact Disc (CD), a Digital Versatile Disk (DVD), a digital tape, memory, etc. In some implementations, signal bearing medium 602 may encompass a recordable medium 608, such as, but not limited to, memory, read/write (R/W) CDs, R/W DVDs, etc. In some implementations, signal bearing medium 602 may encompass a communications medium 610, such as, but not limited to, a digital and/or an analog communication medium (for example, a fiber optic cable, a waveguide, a wired
communications link, a wireless communication link, etc.). Thus, for example, computer program product 600 may be conveyed to the processor 604 by an RF signal bearing medium 602, where the signal bearing medium 602 is conveyed by a wireless communications medium 610 (for example, a wireless communications medium conforming with the IEEE 802.11 standard).
[0051] According to some examples, a method is provided to establish a hardware interconnect based communication between SSD controllers. An example method may include detecting a first solid state drive (SSD) controller, detecting a second SSD controller, detecting the hardware interconnect between the first SSD controller and the second SSD controller, and establishing a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
[0052] According to other examples, the method may further include detecting a third SSD controller; detecting a second hardware interconnect between the second SSD controller and the third SSD controller; and establishing a second communication connection between the second SSD controller and the third SSD controller through the second hardware interconnect. The first SSD controller and the second SSD controller may be detected within a first SSD. The first SSD controller may be detected within a first SSD, and the second SSD controller may be detected within a second SSD. A communication bus associated with the communication connection between the first SSD controller and the second SSD controller may be managed as a first extension of a first device input and output (I/O) of the first SSD controller and a second extension of a second device I/O of the second SSD controller.
[0053] According to further examples, an addressing scheme supporting a system level mapping and an intersystem communication mapping may be provided between the first SSD controller and the second SSD controller. A multi-controller architecture may be
implemented to provide a multi-system addressing scheme. The first SSD controller may be allowed to manage a flash controller of the second SSD controller for tasks that include at least one of: a deduplication task and a low level redundant array of independent disks (RAID) task. The second SSD controller may also be allowed to manage a flash controller of the first SSD controller for tasks that include at least one of: a deduplication task and a low level redundant array of independent disks (RAID) task
[0054] According to yet other examples, a scalable file system may be implemented to offload functions from at least one SSD system associated with the first SSD controller and the second SSD controller, data and associated metadata may be created within the scalable file system, and the metadata may be updated through the hardware interconnect without overload of the at least one SSD system and a network connection associated with the at least one SSD system. One or more functions associated with the first SSD controller and the second SSD controller may be implemented through the hardware interconnect, where the functions include at least one from a set of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
[0055] According to other examples, a computing device is provided to establish a hardware interconnect based communication between SSD controllers. The computing device may include a memory configured to store instructions, a processor, and a solid state drive (SSD) coupled to the memory and the processor. The SSD may include an interconnect module. The interconnect module may be configured to detect a first SSD controller within the SSD, detect a second SSD controller within another SSD of the computing device, detect the hardware interconnect between the first SSD controller and the second SSD controller, and establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
[0056] According to some examples, the interconnect module may further manage a communication bus associated with the communication connection between the first SSD controller and the second SSD controller as a first extension of a first device input and output (I/O) of the first SSD controller and a second extension of a second device I/O of the second SSD controller. The interconnect module may also provide an addressing scheme to support
a system level mapping and an intersystem communication mapping between the first SSD controller and the second SSD controller. In addition, the interconnect module may implement one or more functions associated with the first SSD controller and the second SSD controller through the hardware interconnect, where the functions include at least one of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
[0057] According to further examples, the interconnect module may implement a multi- controller architecture to provide a multi-system addressing scheme through a process to: allow the first SSD controller to manage a flash controller of the second SSD controller for tasks that include at least one of: a first deduplication task and a first low level redundant array of independent disks (RAID) task, and allow the second SSD controller to manage a flash controller of the first SSD controller for tasks that include at least one from a set of: a second deduplication task and a second low level redundant array of independent disks (RAID) task.
[0058] According to yet other examples, the interconnect module may implement a scalable file system to offload functions from at least one SSD system associated with the first SSD controller and the second SSD controller, create data and associated metadata within the scalable file system, and update the metadata through the hardware interconnect with no overload of the at least one SSD system and a network connection associated with the at least one SSD system.
[0059] According to yet further examples, a computer-readable storage medium may be provided to establish a hardware interconnect based communication between SSD controllers. The instructions may cause a method to be performed in response to execution, the method being similar to the methods described above.
[0060] There is little distinction left between hardware and software implementations of aspects of systems; the use of hardware or software is generally (but not always, in that in certain contexts the choice between hardware and software may become significant) a design choice representing cost vs. efficiency tradeoffs. There are various vehicles by which processes and/or systems and/or other technologies described herein may be effected (for example, hardware, software, and/or firmware), and that the preferred vehicle will vary with the context in which the processes and/or systems and/or other technologies are deployed. For example, if an implementer determines that speed and accuracy are paramount, the
implementer may opt for a mainly hardware and/or firmware vehicle; if flexibility is paramount, the implementer may opt for a mainly software implementation; or, yet again alternatively, the implementer may opt for some combination of hardware, software, and/or firmware.
[0061] The foregoing detailed description has set forth various embodiments of the devices and/or processes via the use of block diagrams, flowcharts, and/or examples. Insofar as such block diagrams, flowcharts, and/or examples contain one or more functions and/or operations, it will be understood by those within the art that each function and/or operation within such block diagrams, flowcharts, or examples may be implemented, individually and/or collectively, by a wide range of hardware, software, firmware, or virtually any combination thereof. In one embodiment, several portions of the subject matter described herein may be implemented via Application Specific Integrated Circuits (ASICs), Field Programmable Gate Arrays (FPGAs), digital signal processors (DSPs), or other integrated formats. However, those skilled in the art will recognize that some aspects of the embodiments disclosed herein, in whole or in part, may be equivalently implemented in integrated circuits, as one or more computer programs running on one or more computers (for example, as one or more programs running on one or more computer systems), as one or more programs running on one or more processors (for example as one or more programs running on one or more microprocessors), as firmware, or as virtually any combination thereof, and that designing the circuitry and/or writing the code for the software and or firmware would be well within the skill of one of skill in the art in light of this disclosure.
[0062] The present disclosure is not to be limited in terms of the particular
embodiments described in this application, which are intended as illustrations of various aspects. Many modifications and variations can be made without departing from its spirit and scope, as will be apparent to those skilled in the art. Functionally equivalent methods and apparatuses within the scope of the disclosure, in addition to those enumerated herein, will be apparent to those skilled in the art from the foregoing descriptions. Such modifications and variations are intended to fall within the scope of the appended claims. The present disclosure is to be limited only by the terms of the appended claims, along with the full scope of equivalents to which such claims are entitled. It is to be understood that this disclosure is not limited to particular methods, systems, or components, which can, of course, vary. It is
also to be understood that the terminology used herein is for the purpose of describing particular embodiments only, and is not intended to be limiting.
[0063] In addition, those skilled in the art will appreciate that the mechanisms of the subject matter described herein are capable of being distributed as a program product in a variety of forms, and that an illustrative embodiment of the subject matter described herein applies regardless of the particular type of signal bearing medium used to actually carry out the distribution. Examples of a signal bearing medium include, but are not limited to, the following: a recordable type medium such as a floppy disk, a hard disk drive, a Compact Disc (CD), a Digital Versatile Disk (DVD), a digital tape, a computer memory, etc.; and a transmission type medium such as a digital and/or an analog communication medium (for example, a fiber optic cable, a waveguide, a wired communications link, a wireless communication link, etc.).
[0064] Those skilled in the art will recognize that it is common within the art to describe devices and/or processes in the fashion set forth herein, and thereafter use engineering practices to integrate such described devices and/or processes into data processing systems. That is, at least a portion of the devices and/or processes described herein may be integrated into a data processing system via a reasonable amount of experimentation. Those having skill in the art will recognize that a typical data processing system generally includes one or more of a system unit housing, a video display device, a memory such as volatile and non-volatile memory, processors such as microprocessors and digital signal processors, computational entities such as operating systems, drivers, graphical user interfaces, and applications programs, one or more interaction devices, such as a touch pad or screen, and/or control systems including feedback loops.
[0065] A typical data processing system may be implemented utilizing any suitable commercially available components, such as those typically found in data
computing/communication and/or network computing/communication systems. The herein described subject matter sometimes illustrates different components contained within, or connected with, different other components. It is to be understood that such depicted architectures are merely exemplary, and that in fact many other architectures may be implemented which achieve the same functionality. In a conceptual sense, any arrangement of components to achieve the same functionality is effectively "associated" such that particular functionality is achieved. Hence, any two components herein combined to achieve
a particular functionality may be seen as "associated with" each other such that the particular functionality is achieved, irrespective of architectures or intermediate components. Likewise, any two components so associated may also be viewed as being "operably connected", or "operably coupled", to each other to achieve the particular functionality, and any two components capable of being so associated may also be viewed as being "operably couplable", to each other to achieve the particular functionality. Specific examples of operably couplable include but are not limited to physically connectable and/or physically interacting components and/or wirelessly interactable and/or wirelessly interacting components and/or logically interacting and/or logically interactable components.
[0066] With respect to the use of substantially any plural and/or singular terms herein, those having skill in the art can translate from the plural to the singular and/or from the singular to the plural as is appropriate to the context and/or application. The various singular/plural permutations may be expressly set forth herein for sake of clarity.
[0067] It will be understood by those within the art that, in general, terms used herein, and especially in the appended claims (for example, bodies of the appended claims) are generally intended as "open" terms (for example, the term "including" should be interpreted as "including but not limited to," the term "having" should be interpreted as "having at least," the term "includes" should be interpreted as "includes but is not limited to," etc.). It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases "at least one" and "one or more" to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles "a" or "an" limits any particular claim containing such introduced claim recitation to embodiments containing only one such recitation, even when the same claim includes the introductory phrases "one or more" or "at least one" and indefinite articles such as "a" or "an" (for example, "a" and/or "an" should be interpreted to mean "at least one" or "one or more"); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should be interpreted to mean at
least the recited number (for example, the bare recitation of "two recitations," without other modifiers, means at least two recitations, or two or more recitations).
[0068] Furthermore, in those instances where a convention analogous to "at least one of A, B, and C, etc." is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (for example, " a system having at least one of A, B, and C" would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). It will be further understood by those within the art that virtually any disjunctive word and/or phrase presenting two or more alternative terms, whether in the description, claims, or drawings, should be understood to contemplate the possibilities of including one of the terms, either of the terms, or both terms. For example, the phrase "A or B" will be understood to include the possibilities of "A" or "B" or "A and B."
[0069] As will be understood by one skilled in the art, for any and all purposes, such as in terms of providing a written description, all ranges disclosed herein also encompass any and all possible subranges and combinations of subranges thereof. Any listed range can be easily recognized as sufficiently describing and enabling the same range being broken down into at least equal halves, thirds, quarters, fifths, tenths, etc. As a non-limiting example, each range discussed herein can be readily broken down into a lower third, middle third and upper third, etc. As will also be understood by one skilled in the art all language such as "up to," "at least," "greater than," "less than," and the like include the number recited and refer to ranges which can be subsequently broken down into subranges as discussed above. Finally, as will be understood by one skilled in the art, a range includes each individual member. Thus, for example, a group having 1-3 cells refers to groups having 1, 2, or 3 cells. Similarly, a group having 1-5 cells refers to groups having 1, 2, 3, 4, or 5 cells, and so forth.
[0070] While various aspects and embodiments have been disclosed herein, other aspects and embodiments will be apparent to those skilled in the art. The various aspects and embodiments disclosed herein are for purposes of illustration and are not intended to be limiting, with the true scope and spirit being indicated by the following claims.
Claims
1. A method to establish a hardware interconnect based communication between SSD controllers, the method comprising:
detecting a first solid state drive (SSD) controller;
detecting a second SSD controller;
detecting the hardware interconnect between the first SSD controller and the second SSD controller; and
establishing a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
2. The method of claim I, further comprising:
detecting a third SSD controller;
detecting a second hardware interconnect between the second SSD controller and the third SSD controller; and
establishing a second communication connection between the second SSD controller and the third SSD controller through the second hardware interconnect.
3. The method of claim I, further comprising detecting the first SSD controller and the second SSD controller within a first SSD.
4. The method of claim I, further comprising:
detecting the first SSD controller within a first SSD; and
detecting the second SSD controller within a second SSD.
5. The method of claim I, further comprising managing a communication bus associated with the communication connection between the first SSD controller and the second SSD controller as a first extension of a first device input and output (I/O) of the first SSD controller and a second extension of a second device I/O of the second SSD controller.
6. The method of claim 1, further comprising providing an addressing scheme supporting a system level mapping and an intersystem communication mapping between the first SSD controller and the second SSD controller.
7. The method of claim 1, further comprising:
implementing a multi-controller architecture providing a multi-system addressing scheme.
8. The method of claim 7, further comprising:
allowing the first SSD controller to manage a flash controller of the second SSD controller for tasks that include at least one of: a deduplication task and a low level redundant array of independent disks (RAID) task.
9. The method of claim 7, further comprising:
allowing the second SSD controller to manage a flash controller of the first SSD controller for tasks that include at least one of: a deduplication task and a low level redundant array of independent disks (RAID) task.
10. The method of claim 1, further comprising:
implementing a scalable file system to offload functions from at least one SSD system associated with the first SSD controller and the second SSD controller;
creating data and associated metadata within the scalable file system; and
updating the metadata through the hardware interconnect without overload of the at least one
SSD system and a network connection associated with the at least one SSD system.
1 1. The method of claim 1 , further comprising:
implementing one or more functions associated with the first SSD controller and the second SSD controller through the hardware interconnect, wherein the functions include at least one from a set of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
12. A computing device to establish a hardware interconnect based communication between SSD controllers, the computing device comprising:
a memory configured to store instructions;
a processor; and
a solid state drive (SSD) coupled to the memory and the processor, wherein the SSD includes an interconnect module configured to:
detect a first SSD controller within the SSD;
detect a second SSD controller within another SSD of the computing device;
detect the hardware interconnect between the first SSD controller and the second SSD controller; and
establish a communication connection between the first SSD controller and the second SSD controller through the hardware interconnect.
13. The computing device according to claim 12, wherein the interconnect module is further configured to:
manage a communication bus associated with the communication connection between the first SSD controller and the second SSD controller as a first extension of a first device input and output (I/O) of the first SSD controller and a second extension of a second device I/O of the second SSD controller.
14. The computing device according to claim 12, wherein the interconnect module is further configured to:
provide an addressing scheme to support a system level mapping and an intersystem communication mapping between the first SSD controller and the second SSD controller.
15. The computing device according to claim 12, wherein the interconnect module is further configured to:
implement one or more functions associated with the first SSD controller and the second SSD controller through the hardware interconnect, wherein the functions include at least one of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
16. The computing device according to claim 12, wherein the interconnect module is further configured to:
implement a multi-controller architecture to provide a multi-system addressing scheme through a process to:
allow the first SSD controller to manage a flash controller of the second SSD controller for tasks that include at least one of: a first deduplication task and a first low level redundant array of independent disks (RAID) task; and
allow the second SSD controller to manage a flash controller of the first SSD controller for tasks that include at least one from a set of: a second deduplication task and a second low level redundant array of independent disks (RAID) task.
17. The computing device according to claim 12, wherein the interconnect module is further configured to:
implement a scalable file system to offload functions from at least one SSD system associated with the first SSD controller and the second SSD controller;
create data and associated metadata within the scalable file system; and
update the metadata through the hardware interconnect with no overload of the at least one
SSD system and a network connection associated with the at least one SSD system.
18. A computer-readable storage medium with instructions stored thereon to establish a hardware interconnect based communication between SSD controllers, the instructions in response to execution cause a method to be performed, wherein the method comprises:
detecting a first solid state drive (SSD) controller within a first SSD;
detecting a second SSD controller within a second SSD;
detecting a first hardware interconnect between the first SSD controller and the second SSD controller;
establishing a first communication connection between the first and the second SSD through the first hardware interconnect;
detecting a third SSD controller;
detecting a second hardware interconnect between the second SSD controller and the third SSD controller; and
establishing a second communication connection between the second SSD controller and the third SSD controller through the second hardware interconnect.
19. The computer-readable storage medium according to claim 18, wherein functions associated with the first SSD controller, the second SSD controller, and the third SSD controller are implemented through the first hardware interconnect and the second hardware interconnect and include at least one from a set of: a cross processor replication, a redundant array of independent disks (RAID), and a read and write (RW) management.
20. The computer-readable storage medium according to claim 18, wherein an addressing scheme is provided to support a system level mapping and an intersystem communication mapping between the first SSD controller, the second SSD controller, and the third SSD controller.
21. The computer-readable storage medium according to claim 18, wherein a multi-controller architecture is implemented to provide a multi-system addressing scheme to allow the first SSD controller to manage a flash controller of the second SSD controller for tasks that include at least one from a set of: a first deduplication task and a first low level redundant array of independent disks (RAID) task, and to allow the second SSD controller to manage a flash controller of the first SSD controller for tasks that include at least one of: a second deduplication task and a second low level redundant array of independent disks (RAID) task.
Priority Applications (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| PCT/US2013/073949 WO2015088485A1 (en) | 2013-12-09 | 2013-12-09 | Hardware interconnect based communication between solid state drive controllers |
| US14/371,706 US9898195B2 (en) | 2013-12-09 | 2013-12-09 | Hardware interconnect based communication between solid state drive controllers |
Applications Claiming Priority (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| PCT/US2013/073949 WO2015088485A1 (en) | 2013-12-09 | 2013-12-09 | Hardware interconnect based communication between solid state drive controllers |
Publications (1)
| Publication Number | Publication Date |
|---|---|
| WO2015088485A1 true WO2015088485A1 (en) | 2015-06-18 |
Family
ID=53371599
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| PCT/US2013/073949 Ceased WO2015088485A1 (en) | 2013-12-09 | 2013-12-09 | Hardware interconnect based communication between solid state drive controllers |
Country Status (2)
| Country | Link |
|---|---|
| US (1) | US9898195B2 (en) |
| WO (1) | WO2015088485A1 (en) |
Families Citing this family (9)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US9846661B2 (en) * | 2014-07-17 | 2017-12-19 | Empire Technology Development Llc | Utilization of solid state memory devices |
| KR102387973B1 (en) | 2015-12-01 | 2022-04-19 | 삼성전자주식회사 | Duplicated storage device, server system having the same, and operation method thereof |
| US10372346B2 (en) | 2016-07-29 | 2019-08-06 | Western Digital Technologies, Inc. | Extensible storage system controller |
| KR102760170B1 (en) * | 2016-09-22 | 2025-02-04 | 삼성전자주식회사 | Storage device, user device including storage device, and operation method of user device |
| TWI621017B (en) * | 2017-03-06 | 2018-04-11 | 慧榮科技股份有限公司 | Data storage device and operating method therefor |
| US20190102321A1 (en) * | 2017-09-29 | 2019-04-04 | Intel Corporation | Techniques to provide access protection to shared virtual memory |
| CN112181293B (en) * | 2020-09-17 | 2023-08-22 | 深圳大普微电子科技有限公司 | Solid state disk controller, solid state disk, storage system and data processing method |
| US12014052B2 (en) * | 2021-03-22 | 2024-06-18 | Google Llc | Cooperative storage architecture |
| CN118672510B (en) * | 2024-06-27 | 2025-09-23 | 苏州元脑智能科技有限公司 | Hard disk management system and method |
Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20100079885A1 (en) * | 2008-09-30 | 2010-04-01 | Mckean Brian | System and method for providing performance-enhanced rebuild of a solid-state drive (SSD) in a solid-state drive hard disk drive (SSD HDD) redundant array of inexpensive disks 1 (RAID 1) pair |
| US20110138113A1 (en) * | 2009-12-08 | 2011-06-09 | Ocz Technology Group, Inc. | Raid storage systems having arrays of solid-state drives and methods of operation |
| US20120059978A1 (en) * | 2010-09-07 | 2012-03-08 | Daniel L Rosenband | Storage array controller for flash-based storage devices |
| US20120079318A1 (en) * | 2010-09-28 | 2012-03-29 | John Colgrove | Adaptive raid for an ssd environment |
| US20130246841A1 (en) * | 2009-11-12 | 2013-09-19 | International Business Machines | Method, apparatus, and system for a redundant and fault tolerant solid state disk |
Family Cites Families (8)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| EP1026575A3 (en) * | 1999-02-08 | 2006-09-06 | Hitachi, Ltd. | Disk array system and method of changing its configuration |
| US7228538B1 (en) * | 2000-05-02 | 2007-06-05 | International Business Machines Corporation | Method, system, and program for updating firmware to a storage system comprised of multiple controllers |
| KR100340686B1 (en) * | 2000-09-19 | 2002-06-15 | 오길록 | The Apparatus for Redundant Interconnection between Multiple Hosts and RAID |
| US7711793B1 (en) * | 2001-07-17 | 2010-05-04 | Adaptec, Inc. | No single point of failure RAID box using SATA drives |
| US20090193184A1 (en) * | 2003-12-02 | 2009-07-30 | Super Talent Electronics Inc. | Hybrid 2-Level Mapping Tables for Hybrid Block- and Page-Mode Flash-Memory System |
| US20120278550A1 (en) | 2011-04-26 | 2012-11-01 | Byungcheol Cho | System architecture based on raid controller collaboration |
| US20140059278A1 (en) * | 2011-11-14 | 2014-02-27 | Lsi Corporation | Storage device firmware and manufacturing software |
| US9213633B2 (en) * | 2013-04-30 | 2015-12-15 | Seagate Technology Llc | Flash translation layer with lower write amplification |
-
2013
- 2013-12-09 WO PCT/US2013/073949 patent/WO2015088485A1/en not_active Ceased
- 2013-12-09 US US14/371,706 patent/US9898195B2/en not_active Expired - Fee Related
Patent Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20100079885A1 (en) * | 2008-09-30 | 2010-04-01 | Mckean Brian | System and method for providing performance-enhanced rebuild of a solid-state drive (SSD) in a solid-state drive hard disk drive (SSD HDD) redundant array of inexpensive disks 1 (RAID 1) pair |
| US20130246841A1 (en) * | 2009-11-12 | 2013-09-19 | International Business Machines | Method, apparatus, and system for a redundant and fault tolerant solid state disk |
| US20110138113A1 (en) * | 2009-12-08 | 2011-06-09 | Ocz Technology Group, Inc. | Raid storage systems having arrays of solid-state drives and methods of operation |
| US20120059978A1 (en) * | 2010-09-07 | 2012-03-08 | Daniel L Rosenband | Storage array controller for flash-based storage devices |
| US20120079318A1 (en) * | 2010-09-28 | 2012-03-29 | John Colgrove | Adaptive raid for an ssd environment |
Also Published As
| Publication number | Publication date |
|---|---|
| US9898195B2 (en) | 2018-02-20 |
| US20150242128A1 (en) | 2015-08-27 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US9898195B2 (en) | Hardware interconnect based communication between solid state drive controllers | |
| US11907139B2 (en) | Memory system design using buffer(s) on a mother board | |
| CN104603739B (en) | The block level of parallel memorizing is accessed | |
| US9164840B2 (en) | Managing a solid state drive (‘SSD’) in a redundant array of inexpensive drives (‘RAID’) | |
| US8806124B2 (en) | Methods and structure for transferring ownership of a logical volume by transfer of native-format metadata in a clustered storage environment | |
| US9740409B2 (en) | Virtualized storage systems | |
| US20170102952A1 (en) | 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) | |
| US11231858B2 (en) | Dynamically configuring a storage system to facilitate independent scaling of resources | |
| US8447947B2 (en) | Method and interface for allocating storage capacities to plural pools | |
| US9798638B2 (en) | Systems and methods providing mount catalogs for rapid volume mount | |
| JP5893028B2 (en) | System and method for efficient sequential logging on a storage device that supports caching | |
| US9830110B2 (en) | System and method to enable dynamic changes to virtual disk stripe element sizes on a storage controller | |
| US9940019B2 (en) | Online migration of a logical volume between storage systems | |
| US10216562B2 (en) | Generating diagnostic data | |
| US11416155B1 (en) | System and method for managing blocks of data and metadata utilizing virtual block devices | |
| US9921753B2 (en) | Data replication across host systems via storage controller | |
| US9471223B2 (en) | Volume class management | |
| US8554995B2 (en) | Connecting a storage subsystem and an electronic device with a control device that hides details of the storage subsystem | |
| US10528294B2 (en) | Provisioning and managing virtual machines from a storage management system | |
| CN121116158A (en) | Saving data activity temperatures from cloud to local multi-tier data storage system | |
| US10031823B2 (en) | Dangerous system command detection |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| WWE | Wipo information: entry into national phase |
Ref document number: 14371706 Country of ref document: US |
|
| 121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 13899236 Country of ref document: EP Kind code of ref document: A1 |
|
| NENP | Non-entry into the national phase |
Ref country code: DE |
|
| 122 | Ep: pct application non-entry in european phase |
Ref document number: 13899236 Country of ref document: EP Kind code of ref document: A1 |