Methods, systems, and computer readable media for solid state drive caching across a host bus

US9507722B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9507722-B2
Application numberUS-201414297563-A
CountryUS
Kind codeB2
Filing dateJun 5, 2014
Priority dateJun 5, 2014
Publication dateNov 29, 2016
Grant dateNov 29, 2016

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Methods, systems, and computer readable media for solid state drive caching across a host bus are disclosed. According to one aspect, a method for solid state caching across host bus includes, during operation of a solid state drive (SSD) having non-volatile memory (NVM) for bulk storage of data and metadata, a first random access memory (RAM), and a host bust interface for accessing a second RAM memory located on a host and separate from the first RAM, using the first RAM as a cache for storing a first portion of metadata, and using the second RAM as a cache for storing a second portion of metadata, where the second RAM is accessed by the SSD via the host bus interface.

First claim

Opening claim text (preview).

What is claimed is: 1. A method for solid state caching across host bus, the method comprising: during operation of a solid state drive (SSD) having non-volatile memory (NVM) for bulk storage of data and metadata, a first random access memory (RAM), and a host bus interface located on the SSD for accessing a second RAM located on a host and separate from the first RAM: using the first RAM as a cache for storing a first portion of metadata; and using the second RAM as a cache for storing a second portion of metadata, wherein the second RAM is accessed by the SSD via the host bus interface located on the SSD using a protocol that allows the SSD to be the master of the host bus and directly read from and write to memory space of the cache implemented using the second RAM, wherein the host is configured to notify the SDD of an intent to reclaim at least a portion of the memory space in the second RAM that is allocated to the SSD and transfer some or all of the second portion of metadata back to the SSD via the host bus or provide the SDD an opportunity to request and retrieve some or all of the second portion of metadata. 2. The method of claim 1 wherein metadata comprises at least one of: control tables for management of the NVM on the SSD; configuration data for the SSD; garbage collection data for sources available on the SSD; and data used by a flash translation layer (FTL). 3. The method of claim 1 wherein using the first RAM as a cache for storing a first portion of metadata and using the second RAM as a cache for storing a second portion of metadata includes: receiving an I/O request from the host; in response to receiving an I/O request from the host, determining whether first metadata associated with the I/O request is stored in the first RAM; in response to determining that first metadata is stored in the first RAM, retrieving the first metadata from the first RAM and using the retrieved metadata to process the I/O request; in response to determining that the first metadata is not stored in the first RAM, determining whether the first metadata is stored in the second RAM; in response to determining that the first metadata is stored in the second RAM, retrieving the first metadata from the second RAM via the host bus and using the retrieved metadata to process the I/O request; and in response to determining that the first metadata is not stored in the second RAM, retrieving the first metadata from the NVM and using the retrieved metadata to process the I/O request. 4. The method of claim 1 comprising, after retrieving the first metadata, determining whether to store at least some metadata in the second RAM, and, upon a determination that some metadata should be stored in the second RAM, identifying metadata to be stored in the second RAM and transferring the identified metadata into the second RAM via the host bus. 5. The method of claim 1 wherein the host bus interface comprises a non-volatile memory express (NVMe) interface. 6. The method of claim 5 wherein using the second RAM as a cache includes reserving a portion of the second RAM by issuing requests for host address buffer space. 7. The method of claim 2 wherein the second portion of metadata comprises metadata that can be recreated by the SSD in the event that the SSD loses access to the second RAM. 8. The method of claim 1 wherein the host bus interface comprises a peripheral component interconnect express (PCIe) interface and wherein the method further comprises utilizing a high priority virtual channel accessible via the PCIe interface for transferring metadata to and from the second RAM memory and a low priority virtual channel for transferring data to and from the second RAM memory. 9. The method of claim 1 wherein the NVM comprises a 3D NAND NVM. 10. A system for solid state caching across host bus, the system comprising: a solid state drive (SSD) having non-volatile memory (NVM) for bulk storage of data and metadata, a first random access memory (RAM), and a host bus interface located on the SSD for accessing a second RAM memory located on a host and separate from the first RAM, wherein the SSD drive is configured to: use the first RAM as a cache for storing a first portion of metadata; and use the second RAM as a cache for storing a second portion of metadata, wherein the second RAM is accessed by the SSD via the host bus interface located on the SSD using a protocol that allows the SSD to be the master of the host bus and directly read from and write to memory space of the cache implemented using the second RAM, wherein the host is configured to notify the SDD of an intent to reclaim at least a portion of the memory space in the second RAM that is allocated to the SSD and transfer some or all of the second portion of metadata back to the SSD via the host bus or provide the SDD an opportunity to request and retrieve some or all of the second portion of metadata. 11. The system of claim 10 wherein metadata comprises at least one of: control tables for management of the NVM on the SSD; configuration data for the SSD; garbage collection data for sources available on the SSD; and data used by a flash translation layer (FTL). 12. The system of claim 10 wherein the SSD is configured for: receiving an I/O request from the host; in response to receiving an I/O request from the host, determining whether first metadata associated with the I/O request is stored in the first RAM; in response to determining that first metadata is stored in the first RAM, retrieving the first metadata from the first RAM and using the retrieved metadata to process the I/O request; in response to determining that the first metadata is not stored in the first RAM, determining whether the first metadata is stored in the second RAM; in response to determining that the first metadata is stored in the second RAM, retrieving the first metadata from the second RAM via the host bus and using the retrieved metadata to process the I/O request; and in response to determining that the first metadata is not stored in the second RAM, retrieving the first metadata from the NVM and using the retrieved metadata to process the I/O request. 13. The system of claim 10 wherein the SSD is configured for, after retrieving the first metadata, determining whether to store at least some metadata in the second RAM, and, upon a determination that some metadata should be stored in the second RAM, identifying metadata to be stored in the second RAM and transferring the identified metadata into the second RAM via the host bus. 14. The system of claim 10 wherein the host bus interface comprises a non-volatile memory express (NVMe) interface. 15. The system of claim 14 wherein using the second RAM as a cache includes reserving a portion of the second RAM by issuing requests for host address buffer space. 16. The system of claim 10 wherein the second portion of metadata comprises metadata that can be recreated by the SSD in the event that the SSD loses access to the second RAM. 17. The system of claim 10 wherein the host bus interface comprises a peripheral component interconnect express (PCIe) interface and wherein the host bus interface utilizes a high priority virtual channel accessible via the PCIe interface for transferring metadata to and from the second RAM memory and a low priority virtual channel for transferring data to and from the second RAM memory. 18. The system of claim 10 wherein the NVM comprises a 3D NAND NVM. 19. A non-transitory computer readable medium having stored

Assignees

Inventors

Classifications

  • with two or more cache hierarchy levels (with multilevel cache hierarchies G06F12/0811) · CPC title

  • Data transfer between cache memory and other subsystems, e.g. storage devices or host systems · CPC title

  • with age lists, e.g. queue, most recently used [MRU] list or least recently used [LRU] list · CPC title

  • Performance improvement · CPC title

  • In host system · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9507722B2 cover?
Methods, systems, and computer readable media for solid state drive caching across a host bus are disclosed. According to one aspect, a method for solid state caching across host bus includes, during operation of a solid state drive (SSD) having non-volatile memory (NVM) for bulk storage of data and metadata, a first random access memory (RAM), and a host bust interface for accessing a second R…
Who is the assignee on this patent?
Sandisk Technologies Inc, Sandisk Technologies Llc
What technology area does this patent fall under?
Primary CPC classification G06F12/0868. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Nov 29 2016 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 3 related publications on this page (citations in our corpus or others sharing the same primary CPC).