JP6228374B2 - 動的に適応されるキャッシュ格納のためのシステム - Google Patents
動的に適応されるキャッシュ格納のためのシステム Download PDFInfo
- Publication number
- JP6228374B2 JP6228374B2 JP2013054867A JP2013054867A JP6228374B2 JP 6228374 B2 JP6228374 B2 JP 6228374B2 JP 2013054867 A JP2013054867 A JP 2013054867A JP 2013054867 A JP2013054867 A JP 2013054867A JP 6228374 B2 JP6228374 B2 JP 6228374B2
- Authority
- JP
- Japan
- Prior art keywords
- data
- space
- storage device
- host
- amount
- 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.)
- Active
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0866—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches for peripheral storage systems, e.g. disk cache
- G06F12/0871—Allocation or management of cache space
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/10—Providing a specific technical effect
- G06F2212/1041—Resource optimization
- G06F2212/1044—Space efficiency improvement
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/40—Specific encoding of data in memory or cache
- G06F2212/401—Compressed data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/50—Control mechanisms for virtual memory, cache or TLB
- G06F2212/502—Control mechanisms for virtual memory, cache or TLB using adaptive policy
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/65—Details of virtual memory and virtual address translation
- G06F2212/657—Virtual address space management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Memory System Of A Hierarchy Structure (AREA)
- Memory System (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Description
一般的に、データ部が大きくなればなるほど、キャッシュ内で「ヒット」するホスト・アクセスの割合がより向上し、また、記憶システムの性能もより向上する。
[0013]いくつかの実施形態では、動的に適応される記憶システム・キャッシュが、図3の記憶デバイス302のような記憶デバイスに格納される。記憶デバイスは、規定した最大論理キャパシティを有する論理アドレス・スペースを、規定した物理サイズを有する、NANDフラッシュ・チップのような物理記憶デバイスにマップする。最大論理キャパシティの一部分は、記憶システム・キャッシュを管理しているより高位のレイヤのような、より高位レイヤに提示され、および/または利用可能となる。そしてこの一部分は、物理記憶デバイスの利用率(utilization)に少なくとも部分的に基づいて変化する。
物理記憶デバイスの利用態様は、次に、当該物理記憶デバイス内に格納されたデータについて、圧縮を経るというような縮小に少なくとも部分的に基づいて変化する。動的適応記憶システム・キャッシュに格納することが可能なデータの量は、次に、記憶システム・キャッシュを管理しているより高位レイヤに提示され、および/または利用可能となる最大論理キャパシティの部分に少なくとも部分的に従って変化する。このように、より縮小可能な(例えば、より圧縮可能な)データを格納するときに、この動的適応記憶システム・キャッシュは、有利に、最大論理キャパシティについてより大きな部分を提示および/または利用可能となり、つまり、より高性能でより多くのデータを格納およびデリバすることができる。様々な実施形態によれば、より高位のレイヤは、記憶デバイス、図3の制御モジュール304のような制御モジュール、および図3のホスト306のようなホストの内の1つ以上を備える。例えば、実施形態によっては、制御モジュールは、動的適応記憶システム・キャッシュについてのタグ(つまり、そのデータ・コンテンツ)を管理することもある。その一方で、他の実施形態では、ホストが動的適応記憶システム・キャッシュのタグを管理する。
Claims (20)
- 記憶デバイスを含む動的に適用されるキャッシュを管理する方法であって、
データをホストから受け取り、
前記受け取ったデータを圧縮データに圧縮し、
前記圧縮データを格納し、
前記記憶デバイス上の利用可能なスペース量を決定し、
前記記憶デバイス上の前記利用可能スペース量が設定閾値よりも大きいときに、前記受け取ったデータのサイズと前記圧縮データのサイズとの差の少なくとも一部に従う量によって、前記ホストに提示される論理キャパシティを増量する
ことを含む、方法。 - 前記利用可能スペース量が予約量よりも少ないときにスペースを開放することを更に含む、請求項1に記載の方法。
- 前記利用可能スペース量が前記予約量よりも少ないときに前記記憶デバイスのための制御モジュールへ信号を送信することを更に含む、請求項2に記載の方法。
- 前記利用可能スペース量を決定することが、
前記利用可能スペース量が前記設定閾値よりも大きいときに前記記憶デバイスのための制御モジュールへ信号を送信し、
前記利用可能スペース量を決定するために前記記憶デバイスに問い合わせを行う
ことを含む、請求項1に記載の方法。 - 該方法が、データが前記ホストから受け取られる毎に実行される、請求項1に記載の方法。
- 前記受け取ったデータを圧縮データに圧縮することが、無損失のアルゴリズムを用いて前記データを圧縮することを含む、請求項1に記載の方法。
- 動的に適用されるキャッシュ格納のためのシステムであって、
ホストから受け取ったデータを格納するための物理キャパシティを有する記憶デバイスと、
前記ホストから受け取った前記データを圧縮データ・サイズに圧縮するための圧縮モジュールと、
制御モジュールであって、前記ホストからデータを受け取るように構成され、前記記憶デバイス上の利用可能スペース量を決定するように構成され、及び前記ホストから受け取った前記データのサイズと前記圧縮データのサイズとの差に基づき再利用されるスペースを決定するように構成される、制御モジュールと、
前記再利用されるスペースの少なくとも一部を含み、及び可変サイズを有する、論理キャパシティを、前記ホストに提示するように構成される、インタフェース・モジュールと
を備える、システム。 - 前記制御モジュールが、前記記憶デバイス上の前記利用可能スペース量が予約量よりも少ないときに、前記記憶デバイス上のスペースを開放するように更に構成される、請求項7に記載のシステム。
- 前記記憶デバイスが半導体ドライブである、請求項7に記載のシステム。
- 固定の最小論理キャパシティが前記ホストに提示される、請求項7に記載のシステム。
- 方法であって、
記憶デバイスが記憶インタフェースを介して複数のデータ部分を受け取り、
前記データ部分のそれぞれを縮小して各縮小データ部分を形成し、前記データ部分のうちの少なくとも幾つかが前記各縮小データ部分よりも大きいサイズを有し、
前記データ部分を前記記憶デバイスのデータ・メモリ内に前記縮小データ部分として格納し、
前記データ・メモリの利用率(utilization)に従って前記データ・メモリの論理キャパシティを決定し、前記データ・メモリの前記論理キャパシティが前記縮小に従って変化することからなり、
前記論理キャパシティが、前記データ部分の総サイズと前記縮小データ部分の総サイズとの差が増すにつれて増量される、
方法。 - 前記論理キャパシティが、前記データ・メモリが格納することができる前記データ部分の数に対応する、請求項11に記載の方法。
- 前記利用率が特定の閾値を超過したことに応じて、前記データ・メモリから前記縮小データ部分のうちの1またはそれ以上を削除することを更に含む、請求項11に記載の方法。
- 前記削除することが、前記記憶デバイスのタグ・メモリにおける1またはそれ以上のエントリを無効にすることを含む、請求項13に記載の方法。
- 前記特定の閾値が、前記記憶デバイスのライト・アンプリフィケーションを特定の値未満に維持するものである、請求項13に記載の方法。
- 前記論理キャパシティが、前記データ部分の総サイズと前記縮小データ部分の総サイズとの差が減るにつれて減量される、請求項11に記載の方法。
- 前記記憶インタフェースが、SATAインタフェース、SASインタフェース、およびPCIeインタフェースのうちの1つである、請求項11に記載の方法。
- 前記データ・メモリが不揮発性データ・メモリである、請求項11に記載の方法。
- 前記縮小することが圧縮することを含む、請求項11に記載の方法。
- 前記データ部分のうちの特定の1つについての前記記憶デバイスへの要求に応じて、前記データ・メモリから前記各縮小データ部分を読み取り、前記各縮小データ部分の縮小を回復させて(reverse)前記特定のデータ部分を回復させ、前記特定のデータ部分をホストに戻すことを更に含む、請求項11に記載の方法。
Applications Claiming Priority (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201261614545P | 2012-03-23 | 2012-03-23 | |
US201261614548P | 2012-03-23 | 2012-03-23 | |
US61/614,548 | 2012-03-23 | ||
US61/614,545 | 2012-03-23 | ||
US13/566,204 US9158695B2 (en) | 2011-08-09 | 2012-08-03 | System for dynamically adaptive caching |
US13/566,204 | 2012-08-03 |
Publications (3)
Publication Number | Publication Date |
---|---|
JP2013200868A JP2013200868A (ja) | 2013-10-03 |
JP2013200868A5 JP2013200868A5 (ja) | 2016-04-28 |
JP6228374B2 true JP6228374B2 (ja) | 2017-11-08 |
Family
ID=47845763
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2013054867A Active JP6228374B2 (ja) | 2012-03-23 | 2013-03-18 | 動的に適応されるキャッシュ格納のためのシステム |
Country Status (5)
Country | Link |
---|---|
EP (1) | EP2642397A1 (ja) |
JP (1) | JP6228374B2 (ja) |
KR (1) | KR102022721B1 (ja) |
CN (1) | CN103324586B (ja) |
TW (1) | TWI584120B (ja) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104699219B (zh) * | 2013-12-10 | 2020-06-23 | 联想(北京)有限公司 | 一种电子设备及信息处理方法 |
CN104852812B (zh) * | 2015-04-03 | 2018-08-07 | 上海航天电子通讯设备研究所 | 1553b总线远置单元自适应收发数据方法 |
CN106484310B (zh) * | 2015-08-31 | 2020-01-10 | 华为数字技术(成都)有限公司 | 一种存储阵列操作方法和装置 |
CN105335100B (zh) | 2015-09-29 | 2018-09-21 | 华为技术有限公司 | 一种数据处理方法、装置及闪存设备 |
EP3755212A4 (en) * | 2018-02-21 | 2022-04-06 | Patchd, Inc. | PERSONAL MONITORING SYSTEMS AND PROCEDURES |
US10963332B2 (en) * | 2018-12-17 | 2021-03-30 | Western Digital Technologies, Inc. | Data storage systems and methods for autonomously adapting data storage system performance, capacity and/or operational requirements |
CN113722241A (zh) * | 2021-08-30 | 2021-11-30 | 锐掣(杭州)科技有限公司 | 数据处理方法、装置、设备、可读存储介质及程序产品 |
Family Cites Families (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4942552A (en) * | 1986-11-20 | 1990-07-17 | Allen-Bradley Company, Inc. | Method and apparatus for saving and performing industrial control commands |
US6877081B2 (en) * | 2001-02-13 | 2005-04-05 | International Business Machines Corporation | System and method for managing memory compression transparent to an operating system |
EP1421501B1 (en) * | 2001-08-24 | 2006-08-02 | Intel Corporation | A general intput/output architecture, protocol and related methods to implement flow control |
US6968424B1 (en) * | 2002-08-07 | 2005-11-22 | Nvidia Corporation | Method and system for transparent compressed memory paging in a computer system |
US20050132161A1 (en) * | 2003-12-15 | 2005-06-16 | Nokia Corporation | Creation of virtual memory space in a memory |
US7644239B2 (en) * | 2004-05-03 | 2010-01-05 | Microsoft Corporation | Non-volatile memory cache performance improvement |
US7243191B2 (en) * | 2004-08-31 | 2007-07-10 | Intel Corporation | Compressing data in a cache memory |
WO2007135602A1 (en) * | 2006-05-24 | 2007-11-29 | Koninklijke Philips Electronics N.V. | Electronic device and method for storing and retrieving data |
US7779056B2 (en) * | 2006-09-15 | 2010-08-17 | Sandisk Corporation | Managing a pool of update memory blocks based on each block's activity and data order |
KR100823171B1 (ko) * | 2007-02-01 | 2008-04-18 | 삼성전자주식회사 | 파티션된 플래시 변환 계층을 갖는 컴퓨터 시스템 및플래시 변환 계층의 파티션 방법 |
JP2009026296A (ja) * | 2007-06-21 | 2009-02-05 | Toshiba Corp | 電子デバイス、メモリデバイス、ホスト装置 |
US8078787B2 (en) * | 2007-06-22 | 2011-12-13 | Apple Inc. | Communication between a host device and an accessory via an intermediate device |
WO2012039002A1 (en) * | 2010-09-21 | 2012-03-29 | Hitachi, Ltd. | Semiconductor storage device and data control method thereof |
-
2013
- 2013-02-19 TW TW102105705A patent/TWI584120B/zh not_active IP Right Cessation
- 2013-02-28 KR KR1020130022004A patent/KR102022721B1/ko active IP Right Grant
- 2013-03-06 EP EP13158041.7A patent/EP2642397A1/en not_active Withdrawn
- 2013-03-18 JP JP2013054867A patent/JP6228374B2/ja active Active
- 2013-03-22 CN CN201310093364.4A patent/CN103324586B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN103324586B (zh) | 2018-01-12 |
CN103324586A (zh) | 2013-09-25 |
JP2013200868A (ja) | 2013-10-03 |
EP2642397A1 (en) | 2013-09-25 |
TW201342063A (zh) | 2013-10-16 |
TWI584120B (zh) | 2017-05-21 |
KR102022721B1 (ko) | 2019-09-18 |
KR20130108117A (ko) | 2013-10-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6228374B2 (ja) | 動的に適応されるキャッシュ格納のためのシステム | |
US9158695B2 (en) | System for dynamically adaptive caching | |
US11797191B2 (en) | Systems and methods for storing data in SSD | |
US8239648B2 (en) | Reclamation of thin provisioned disk storage | |
US10019352B2 (en) | Systems and methods for adaptive reserve storage | |
CN109725840B (zh) | 利用异步冲刷对写入进行节流 | |
US8793466B2 (en) | Efficient data object storage and retrieval | |
US8250335B2 (en) | Method, system and computer program product for managing the storage of data | |
US7584229B2 (en) | Method and system for priority-based allocation in a storage pool | |
US7792882B2 (en) | Method and system for block allocation for hybrid drives | |
US8539191B2 (en) | Estimating space in a compressed volume | |
US20150278274A1 (en) | Retrieving data in a storage system using thin provisioning | |
US9330105B1 (en) | Systems, methods, and computer readable media for lazy compression of data incoming to a data storage entity | |
CN104272272A (zh) | 混合储存集合去除重复 | |
US20120117328A1 (en) | Managing a Storage Cache Utilizing Externally Assigned Cache Priority Tags | |
US9311002B1 (en) | Systems, methods, and computer readable media for compressing data at a virtually provisioned storage entity | |
US9182912B2 (en) | Method to allow storage cache acceleration when the slow tier is on independent controller | |
US20090300315A1 (en) | Reserve Pool Management in Virtualized Storage Systems | |
US20150363134A1 (en) | Storage apparatus and data management | |
CN108139972B (zh) | 用于管理硬件辅助数据压缩中的存储器碎片的方法和设备 | |
US8862819B2 (en) | Log structure array | |
US9983826B2 (en) | Data storage device deferred secure delete | |
US20170228370A1 (en) | Performing nearline storage of a file | |
US9600197B2 (en) | Low power storage array with metadata access | |
WO2016032955A2 (en) | Nvram enabled storage systems |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
RD03 | Notification of appointment of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7423 Effective date: 20140801 |
|
RD04 | Notification of resignation of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7424 Effective date: 20140804 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20160309 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20160309 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20170118 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20170221 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20170414 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20170926 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20171013 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6228374 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |