JP2011258193A - 持続性メモリのためのキャッシュコヒーレンスプロトコル - Google Patents
持続性メモリのためのキャッシュコヒーレンスプロトコル Download PDFInfo
- Publication number
- JP2011258193A JP2011258193A JP2011114340A JP2011114340A JP2011258193A JP 2011258193 A JP2011258193 A JP 2011258193A JP 2011114340 A JP2011114340 A JP 2011114340A JP 2011114340 A JP2011114340 A JP 2011114340A JP 2011258193 A JP2011258193 A JP 2011258193A
- Authority
- JP
- Japan
- Prior art keywords
- memory
- main memory
- persistent
- cache
- main
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
-
- 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/0806—Multiuser, multiprocessor or multiprocessing cache systems
- G06F12/0815—Cache consistency protocols
- G06F12/0831—Cache consistency protocols using a bus scheme, e.g. with bus monitoring or watching means
-
- 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
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
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)
Abstract
【解決手段】処理システム100は、メインメモリ120に対する少なくとも1つの第1のインターフェースと、2つ以上の処理エンティティ110に対する少なくとも1つの第2のインターフェースとを持つメモリコントローラ115を具備し、前記メモリコントローラ115は、前記処理エンティティ110がキャッシュコヒーレンシプロトコルに従って前記メインメモリ120にアクセスすることを可能にすることができ、かつ、前記メインメモリ120の少なくとも一部は持続性メモリを備える。キャッシュコヒーレンスプロトコル140には、インプロセス状態142が持続性メモリに適応するために含まれる。
【選択図】図1
Description
Claims (22)
- メインメモリに対する少なくとも1つの第1のインターフェースと、2つ以上の処理エンティティに対する少なくとも1つの第2のインターフェースとを持つメモリコントローラを具備してなり、
前記メモリコントローラは、前記処理エンティティがキャッシュコヒーレンシプロトコルに従って前記メインメモリにアクセスすることを可能にすることができ、かつ、前記メインメモリの少なくとも一部は持続性メモリを備えることを特徴とするメモリデバイス。 - 前記キャッシュコヒーレンシプロトコルは、前記メインメモリが現在更新処理中であるかどうかを示す第1の状態と、前記更新処理が完了しているかどうかを示す第2の状態とを含むことを特徴とする請求項1に記載のメモリデバイス。
- 前記メモリコントローラは、更に、前記更新処理中に前記メインメモリにアクセスすることを待つように、前記2以上の処理エンティティの少なくとも1つに対して信号を送信することができることを特徴とする請求項2に記載のメモリデバイス。
- 前記メモリコントローラは、更に、持続性メモリを備える前記メインメモリの前記少なくとも一部をメモリ記述子が特定することを可能にすることができること特徴とする請求項1に記載のメモリデバイス。
- 前記持続性メモリは、相変化メモリ(PCM)を備えることを特徴とする請求項1に記載のメモリデバイス。
- 前記持続性メモリは、非対称的な読み出し速度/書き込み速度を持つメモリを備えることを特徴とする請求項1に記載のメモリデバイス。
- 前記2以上の処理エンティティは、複数の中央処理装置(CPU)を備えることを特徴とする請求項1に記載のメモリデバイス。
- 前記メモリコントローラは、更に、前記2以上の処理エンティティに共有される1つまたは複数のレベルのキャッシュメモリを含むメモリ階層を有効にすることができることを特徴とする請求項1に記載のメモリデバイス。
- 前記1つまたは複数のレベルのキャッシュメモリの少なくとも一部は、持続性メモリを備えることを特徴とする請求項8に記載のメモリデバイス。
- 複数の処理エンティティがメインメモリを共有することを可能にするように、キャッシュコヒーレンシプロトコルを管理するステップを具備してなり、
前記メインメモリの少なくとも一部は、持続性メモリを備えることを特徴とする方法。 - 前記メインメモリの更新処理中に前記メインメモリにアクセスすることを待つように前記複数の処理エンティティに対して命令する第1の状態に、前記キャッシュコヒーレンシプロトコルを遷移させるステップを更に含むことを特徴とする請求項10に記載の方法。
- 前記更新処理が完了していることを前記複数の処理エンティティに通知する第2の状態に、前記キャッシュコヒーレンシプロトコルを遷移させるステップを更に含むことを特徴とする請求項11に記載の方法。
- 前記持続性メモリは、相変化メモリ(PCM)を備えることを特徴とする請求項10に記載の方法。
- 前記持続性メモリは、非対称的な読み出し速度/書き込み速度を持つメモリを備えることを特徴とする請求項10に記載の方法。
- 前記キャッシュコヒーレンシプロトコルは、少なくとも部分的には、前記持続性メモリの1つまたは複数の待ち時間プロパティに基づくことを特徴とする請求項10に記載の方法。
- 前記複数の処理エンティティは、1つまたは複数の中央処理装置(CPU)を備えることを特徴とする請求項10に記載の方法。
- 複数の処理エンティティと、メモリデバイスとを具備してなるシステムであって、
前記メモリデバイスは、メインメモリに対する少なくとも1つの第1のインターフェースと、前記複数の処理エンティティに対する少なくとも1つの第2のインターフェースとを持つメモリコントローラを備え、
前記メモリコントローラは、前記複数の処理エンティティがキャッシュコヒーレンシプロトコルに従って前記メインメモリにアクセスすることを可能にすることができ、かつ、前記メインメモリの少なくとも一部は持続性メモリを備えることを特徴とするシステム。 - 前記キャッシュコヒーレンシプロトコルは、前記メインメモリが現在更新処理中であるかどうかを示す第1の状態と、前記更新処理が完了しているかどうかを示す第2の状態とを含むことを特徴とする請求項17に記載のシステム。
- 前記メモリコントローラは、更に、前記更新処理中に前記メインメモリにアクセスすることを待つように、前記2以上の処理エンティティの少なくとも1つに対して信号を送信することができることを特徴とする請求項18に記載のシステム。
- 前記処理エンティティは、前記更新処理中に前記メインメモリにアクセスすることを待つことができることを特徴とする請求項18に記載のシステム。
- ダイナミックランダムアクセスメモリ(DRAM)部分及び持続性メモリ部分と、
前記DRAM部分と前記持続性メモリ部分との間の待ち時間の差に適応するためのコードを実行するキャッシュコヒーレンスプロトコルブロックと
を具備することを特徴とするメインメモリ。 - 前記持続性メモリ部分内におけるメモリロケーションのアドレスまたは前記メモリロケーションのアドレス範囲を特定する持続性メモリ記述子を更に備えることを特徴とする請求項21に記載のメインメモリ。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/797,522 US9448938B2 (en) | 2010-06-09 | 2010-06-09 | Cache coherence protocol for persistent memories |
US12/797,522 | 2010-06-09 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2011258193A true JP2011258193A (ja) | 2011-12-22 |
JP5348429B2 JP5348429B2 (ja) | 2013-11-20 |
Family
ID=45020214
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2011114340A Active JP5348429B2 (ja) | 2010-06-09 | 2011-05-23 | 持続性メモリのためのキャッシュコヒーレンスプロトコル |
Country Status (6)
Country | Link |
---|---|
US (1) | US9448938B2 (ja) |
JP (1) | JP5348429B2 (ja) |
KR (1) | KR101385430B1 (ja) |
CN (1) | CN102279817B (ja) |
DE (1) | DE102011076895B4 (ja) |
TW (1) | TWI530786B (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2017519275A (ja) * | 2014-05-09 | 2017-07-13 | 華為技術有限公司Huawei Technologies Co.,Ltd. | データキャッシング方法、キャッシュおよびコンピュータシステム |
Families Citing this family (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8694737B2 (en) | 2010-06-09 | 2014-04-08 | Micron Technology, Inc. | Persistent memory for processor main memory |
US9037788B2 (en) | 2010-09-30 | 2015-05-19 | Micron Technology, Inc. | Validating persistent memory content for processor main memory |
KR101293260B1 (ko) | 2011-12-14 | 2013-08-09 | 한국전자통신연구원 | 이동 통신 단말 및 방법 |
US9841920B2 (en) | 2011-12-29 | 2017-12-12 | Intel Corporation | Heterogeneous memory die stacking for energy efficient computing |
CN107045479B (zh) * | 2012-10-22 | 2020-09-01 | 英特尔公司 | 高性能互连物理层 |
US20140114928A1 (en) | 2012-10-22 | 2014-04-24 | Robert Beers | Coherence protocol tables |
US9367472B2 (en) * | 2013-06-10 | 2016-06-14 | Oracle International Corporation | Observation of data in persistent memory |
WO2015030819A1 (en) | 2013-08-30 | 2015-03-05 | Hewlett-Packard Development Company, L.P. | Completion packet return |
US9785554B2 (en) | 2014-05-30 | 2017-10-10 | International Business Machines Corporation | Synchronizing updates of page table status indicators in a multiprocessing environment |
US9384133B2 (en) | 2014-05-30 | 2016-07-05 | International Business Machines Corporation | Synchronizing updates of page table status indicators and performing bulk operations |
US20170192886A1 (en) * | 2014-07-31 | 2017-07-06 | Hewlett Packard Enterprise Development Lp | Cache management for nonvolatile main memory |
US9430396B2 (en) * | 2014-12-22 | 2016-08-30 | Intel Corporation | Updating persistent data in persistent memory-based storage |
US10152435B2 (en) | 2016-06-20 | 2018-12-11 | Western Digital Technologies, Inc. | Coherent controller |
CN108959133B (zh) * | 2017-05-22 | 2021-12-10 | 扬智科技股份有限公司 | 可共用存储器的电路结构与数字视频转换装置 |
US10459824B2 (en) * | 2017-09-18 | 2019-10-29 | Microsoft Technology Licensing, Llc | Cache-based trace recording using cache coherence protocol data |
US11907091B2 (en) | 2018-02-16 | 2024-02-20 | Microsoft Technology Licensing, Llc | Trace recording by logging influxes to an upper-layer shared cache, plus cache coherence protocol transitions among lower-layer caches |
KR102412423B1 (ko) * | 2020-01-09 | 2022-06-23 | 성균관대학교산학협력단 | 비휘발성 메모리 장치, 이것을 포함하는 컴퓨팅 시스템 및 이것의 동작 방법 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0895861A (ja) * | 1994-09-22 | 1996-04-12 | Toshiba Corp | キャッシュメモリを有する電子計算機 |
JPH10161930A (ja) * | 1996-11-29 | 1998-06-19 | Hitachi Ltd | マルチプロセッサシステムおよびキャッシュコヒーレンシ制御方法 |
JP2004334996A (ja) * | 2003-05-09 | 2004-11-25 | Hitachi Ltd | 半導体装置 |
JP2006323739A (ja) * | 2005-05-20 | 2006-11-30 | Renesas Technology Corp | メモリモジュール、メモリシステム、及び情報機器 |
WO2009017890A2 (en) * | 2007-08-02 | 2009-02-05 | Freescale Semiconductor Inc. | Cache locking device and methods thereof |
JP2009295156A (ja) * | 2008-05-30 | 2009-12-17 | Intel Corp | インバリデーショントランザクションのスヌープフィルタからの削除 |
Family Cites Families (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0358163A (ja) | 1989-07-26 | 1991-03-13 | Nec Corp | 疎結合型マルチプロセッサシステム |
JPH06150031A (ja) | 1992-10-30 | 1994-05-31 | Nec Corp | Cpuモジュール |
US5442704A (en) | 1994-01-14 | 1995-08-15 | Bull Nh Information Systems Inc. | Secure memory card with programmed controlled security access control |
JPH0816470A (ja) | 1994-07-04 | 1996-01-19 | Hitachi Ltd | 並列計算機 |
JPH10171676A (ja) | 1996-12-10 | 1998-06-26 | Toshiba Corp | マイクロプロセッサのテスト容易化回路 |
US6516384B1 (en) | 1999-12-30 | 2003-02-04 | Intel Corporation | Method and apparatus to perform a round robin and locking cache replacement scheme |
US6760819B2 (en) | 2001-06-29 | 2004-07-06 | International Business Machines Corporation | Symmetric multiprocessor coherence mechanism |
MXPA04000534A (es) | 2001-07-18 | 2004-05-04 | Matsushita Electric Ind Co Ltd | Aparato de escritura, tarjeta de memoria de semiconductor, programa de escritura y metodo de escritura. |
US6658539B2 (en) * | 2001-10-16 | 2003-12-02 | International Business Machines Corporation | Super-coherent data mechanisms for shared caches in a multiprocessing system |
US6983348B2 (en) | 2002-01-24 | 2006-01-03 | Intel Corporation | Methods and apparatus for cache intervention |
US6892283B2 (en) | 2002-12-05 | 2005-05-10 | International Business Machines Corporation | High speed memory cloner with extended cache coherency protocols and responses |
US7322042B2 (en) | 2003-02-07 | 2008-01-22 | Broadon Communications Corp. | Secure and backward-compatible processor and secure software execution thereon |
US20050080999A1 (en) | 2003-10-08 | 2005-04-14 | Fredrik Angsmark | Memory interface for systems with multiple processors and one memory system |
US20050251617A1 (en) * | 2004-05-07 | 2005-11-10 | Sinclair Alan W | Hybrid non-volatile memory system |
US20050160229A1 (en) | 2004-01-16 | 2005-07-21 | International Business Machines Corporation | Method and apparatus for preloading translation buffers |
US7644287B2 (en) | 2004-07-29 | 2010-01-05 | Microsoft Corporation | Portion-level in-memory module authentication |
US7240137B2 (en) | 2004-08-26 | 2007-07-03 | International Business Machines Corporation | System and method for message delivery across a plurality of processors |
US7451166B2 (en) | 2005-01-13 | 2008-11-11 | International Business Machines Corporation | System and method for maintaining checkpoints of a keyed data structure using a sequential log |
WO2006107095A1 (ja) | 2005-03-31 | 2006-10-12 | Nec Corporation | 計算機システム、メモリ管理方法、およびそのプログラム |
US7130960B1 (en) * | 2005-04-21 | 2006-10-31 | Hitachi, Ltd. | System and method for managing disk space in a thin-provisioned storage subsystem |
US20060265544A1 (en) | 2005-05-17 | 2006-11-23 | John Rudelic | Internally authenticated flash remediation |
US7389402B2 (en) | 2005-06-07 | 2008-06-17 | Advanced Micro Devices, Inc. | Microprocessor including a configurable translation lookaside buffer |
US20070226795A1 (en) | 2006-02-09 | 2007-09-27 | Texas Instruments Incorporated | Virtual cores and hardware-supported hypervisor integrated circuits, systems, methods and processes of manufacture |
JP4335300B2 (ja) | 2006-02-24 | 2009-09-30 | 富士通株式会社 | マルチプロセッサシステム、プロセッサ、およびキャッシュ制御方法 |
US8051253B2 (en) * | 2006-09-28 | 2011-11-01 | Virident Systems, Inc. | Systems and apparatus with programmable memory control for heterogeneous main memory |
CN100492274C (zh) | 2007-08-17 | 2009-05-27 | 杭州华三通信技术有限公司 | 存储控制系统及其处理节点 |
US8055847B2 (en) | 2008-07-07 | 2011-11-08 | International Business Machines Corporation | Efficient processing of data requests with the aid of a region cache |
US8250350B2 (en) | 2008-08-26 | 2012-08-21 | Texas Digital And Multimedia Systems | Computer system with non-volatile write-protected memory based operating system and secure system architecture |
CN101673245B (zh) | 2008-09-09 | 2016-02-03 | 株式会社东芝 | 包括存储器管理装置的信息处理装置和存储器管理方法 |
TW201017421A (en) | 2008-09-24 | 2010-05-01 | Panasonic Corp | Cache memory, memory system and control method therefor |
US8261019B2 (en) | 2009-02-13 | 2012-09-04 | Oracle America, Inc. | Conveying critical data in a multiprocessor system |
US8250282B2 (en) | 2009-05-14 | 2012-08-21 | Micron Technology, Inc. | PCM memories for storage bus interfaces |
US8180981B2 (en) * | 2009-05-15 | 2012-05-15 | Oracle America, Inc. | Cache coherent support for flash in a memory hierarchy |
US8291175B2 (en) * | 2009-10-16 | 2012-10-16 | Oracle America, Inc. | Processor-bus attached flash main-memory module |
US8694737B2 (en) | 2010-06-09 | 2014-04-08 | Micron Technology, Inc. | Persistent memory for processor main memory |
-
2010
- 2010-06-09 US US12/797,522 patent/US9448938B2/en active Active
-
2011
- 2011-05-23 JP JP2011114340A patent/JP5348429B2/ja active Active
- 2011-06-01 DE DE102011076895.5A patent/DE102011076895B4/de active Active
- 2011-06-09 CN CN201110159791.9A patent/CN102279817B/zh active Active
- 2011-06-09 KR KR1020110055706A patent/KR101385430B1/ko active IP Right Grant
- 2011-06-09 TW TW100120245A patent/TWI530786B/zh active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0895861A (ja) * | 1994-09-22 | 1996-04-12 | Toshiba Corp | キャッシュメモリを有する電子計算機 |
JPH10161930A (ja) * | 1996-11-29 | 1998-06-19 | Hitachi Ltd | マルチプロセッサシステムおよびキャッシュコヒーレンシ制御方法 |
JP2004334996A (ja) * | 2003-05-09 | 2004-11-25 | Hitachi Ltd | 半導体装置 |
JP2006323739A (ja) * | 2005-05-20 | 2006-11-30 | Renesas Technology Corp | メモリモジュール、メモリシステム、及び情報機器 |
WO2009017890A2 (en) * | 2007-08-02 | 2009-02-05 | Freescale Semiconductor Inc. | Cache locking device and methods thereof |
JP2009295156A (ja) * | 2008-05-30 | 2009-12-17 | Intel Corp | インバリデーショントランザクションのスヌープフィルタからの削除 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2017519275A (ja) * | 2014-05-09 | 2017-07-13 | 華為技術有限公司Huawei Technologies Co.,Ltd. | データキャッシング方法、キャッシュおよびコンピュータシステム |
US10241919B2 (en) | 2014-05-09 | 2019-03-26 | Huawei Technologies Co., Ltd. | Data caching method and computer system |
Also Published As
Publication number | Publication date |
---|---|
KR20110134855A (ko) | 2011-12-15 |
CN102279817B (zh) | 2015-11-25 |
US20110307653A1 (en) | 2011-12-15 |
DE102011076895B4 (de) | 2014-12-24 |
TW201222252A (en) | 2012-06-01 |
US9448938B2 (en) | 2016-09-20 |
KR101385430B1 (ko) | 2014-04-29 |
TWI530786B (zh) | 2016-04-21 |
DE102011076895A1 (de) | 2011-12-15 |
CN102279817A (zh) | 2011-12-14 |
JP5348429B2 (ja) | 2013-11-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5348429B2 (ja) | 持続性メモリのためのキャッシュコヒーレンスプロトコル | |
US10389839B2 (en) | Method and apparatus for generating data prefetches specifying various sizes to prefetch data from a remote computing node | |
US9384134B2 (en) | Persistent memory for processor main memory | |
CN107608910B (zh) | 用于实现具有不同操作模式的多级存储器分级结构的设备和方法 | |
US11341059B2 (en) | Using multiple memory elements in an input-output memory management unit for performing virtual address to physical address translations | |
US20170344430A1 (en) | Method and apparatus for data checkpointing and restoration in a storage device | |
EP3382557B1 (en) | Method and apparatus for persistently caching storage data in a page cache | |
US10402338B2 (en) | Method and apparatus for erase block granularity eviction in host based caching | |
US20170177482A1 (en) | Computing system having multi-level system memory capable of operating in a single level system memory mode | |
CN110597742A (zh) | 用于具有持久系统存储器的计算机系统的改进存储模型 | |
US9037804B2 (en) | Efficient support of sparse data structure access | |
US10331385B2 (en) | Cooperative write-back cache flushing for storage devices |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20130215 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20130312 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20130605 Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20130605 |
|
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: 20130716 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20130806 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 5348429 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 |
|
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 |