JP2020531959A5 - - Google Patents
Download PDFInfo
- Publication number
- JP2020531959A5 JP2020531959A5 JP2020507995A JP2020507995A JP2020531959A5 JP 2020531959 A5 JP2020531959 A5 JP 2020531959A5 JP 2020507995 A JP2020507995 A JP 2020507995A JP 2020507995 A JP2020507995 A JP 2020507995A JP 2020531959 A5 JP2020531959 A5 JP 2020531959A5
- Authority
- JP
- Japan
- Prior art keywords
- track
- type
- list
- tracks
- cache
- 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
- 238000004590 computer program Methods 0.000 claims 2
- 238000007726 management method Methods 0.000 claims 1
- 230000004044 response Effects 0.000 claims 1
Claims (13)
- キャッシュ管理の方法であって、
キャッシュ中の第1のタイプのトラックのリストを生成するステップと、
前記キャッシュ中に第2のタイプのトラックのリストを生成するステップであって、I/Oオペレーションは、前記第2のタイプのトラックに対してよりも前記第1のタイプのトラックに対して相対的により速く完了される、前記生成するステップと、
ある1つのトラックを前記第1のタイプのトラックの前記リストから、または前記第2のタイプのトラックの前記リストからデモートすべきかどうかを判定するステップと
を備える、方法。 - 前記第1のタイプのトラックは、syncioトラックであり、syncioトラックに対してI/Oオペレーションを行うために、アプリケーション・スレッドがスピン・ループ中に保持されて、前記I/Oオペレーションが完了するのを待機する、請求項1に記載の方法。
- 前記第2のタイプのトラックは、non−syncioトラックであり、non−syncioトラックに対して前記I/Oオペレーションを行うために、前記アプリケーション・スレッドを前記スピン・ループ中に保持するステップが回避され、前記トラック上で行われる最後のI/Oオペレーションがsyncioオペレーションを備える第1のタイプのI/Oオペレーションまたはnon−syncioオペレーションを備える第2のタイプのI/Oオペレーションであるかどうかに基づいて、ある1つのトラックが前記第1のタイプのトラックの前記リストへ、または前記第2のタイプのトラックの前記リストへ追加される、請求項2に記載の方法。
- 前記第1のタイプのトラックの前記リスト中のトラックは、前記第1のタイプのトラックの前記リスト中の各トラックがどれほど最近に用いられたかに基づいて順序付けられ、前記第2のタイプのトラックの前記リスト中のトラックは、前記第2のタイプのトラックの前記リスト中の各トラックがどれほど最近に用いられたかに基づいて順序付けられる、請求項3に記載の方法。
- 前記方法は、
前記第2のタイプのトラックの前記リスト中のトラックについてのリード・ヒット率が前記第1のタイプのトラックにおけるトラックについてのリード・ヒット率の所定の係数より小さいと判定するステップに応答して、ある1つのトラックを前記第2のタイプのトラックの前記リストからデモートするステップ
をさらに備える、請求項4に記載の方法。 - 前記第1のタイプのトラックの前記リスト中のトラックについての前記リード・ヒット率および前記第2のタイプのトラックの前記リスト中のトラックについての前記リード・ヒット率は、前記第1のタイプのトラックおよび前記第2のタイプのトラックの前記リストの所定の底の部分に対するリード・ヒットに基づいて計算される、請求項5に記載の方法。
- 前記方法は、
入力/出力(I/O)オペレーションの速度を増加させるために前記所定の係数を調整するステップ
をさらに備える、請求項5に記載の方法。 - キャッシュ管理のためのシステムであって、
メモリ、および
前記メモリに結合されたプロセッサを備え、前記プロセッサは、オペレーションを行い、前記プロセッサによって行われる前記オペレーションは、
キャッシュ中の第1のタイプのトラックのリストを生成するステップと、
前記キャッシュ中に第2のタイプのトラックのリストを生成するステップであって、I/Oオペレーションは、前記第2のタイプのトラックに対してよりも前記第1のタイプのトラックに対して相対的により速く完了される、前記生成するステップと、
ある1つのトラックを前記第1のタイプのトラックの前記リストから、または前記第2のタイプのトラックの前記リストからデモートすべきかどうかを判定するステップと
を備える、方法。 - 前記第1のタイプのトラックは、syncioトラックであり、syncioトラックに対してI/Oオペレーションを行うために、アプリケーション・スレッドがスピン・ループ中に保持されて、前記I/Oオペレーションが完了するのを待機する、請求項8に記載のシステム。
- 前記第2のタイプのトラックは、non−syncioトラックであり、non−syncioトラックに対して前記I/Oオペレーションを行うために、前記アプリケーション・スレッドを前記スピン・ループ中に保持するステップが回避され、前記トラック上で行われる最後のI/Oオペレーションがsyncioオペレーションを備える第1のタイプのI/Oオペレーションまたはnon−syncioオペレーションを備える第2のタイプのI/Oオペレーションであるかどうかに基づいて、ある1つのトラックが前記第1のタイプのトラックの前記リストへ、または前記第2のタイプのトラックの前記リストへ追加される、請求項9に記載のシステム。
- 前記第1のタイプのトラックの前記リスト中のトラックは、前記第1のタイプのトラックの前記リスト中の各トラックがどれほど最近に用いられたかに基づいて順序付けられ、前記第2のタイプのトラックの前記リスト中のトラックは、前記第2のタイプのトラックの前記リスト中の各トラックがどれほど最近に用いられたかに基づいて順序付けられる、請求項10に記載のシステム。
- キャッシュ管理のためのコンピュータ・プログラムであって、
キャッシュ中の第1のタイプのトラックのリストを生成するステップと、
前記キャッシュ中に第2のタイプのトラックのリストを生成するステップであって、I/Oオペレーションは、前記第2のタイプのトラックに対してよりも前記第1のタイプのトラックに対して相対的により速く完了される、前記生成するステップと、
ある1つのトラックを前記第1のタイプのトラックの前記リストから、または前記第2のタイプのトラックの前記リストからデモートすべきかどうかを判定するステップと
をコンピュータに実行させるコンピュータ・プログラム。 - キャッシュ管理のためのストレージ・コントローラであって、
キャッシュ、および前記ストレージ・コントローラ中に維持されたキャッシュ管理アプリケーションを備え、前記キャッシュ管理アプリケーションは、オペレーションを行い、前記オペレーションは、
前記キャッシュ中の第1のタイプのトラックのリストを生成するステップと、
前記キャッシュ中に第2のタイプのトラックのリストを生成するステップであって、I/Oオペレーションは、前記第2のタイプのトラックに対してよりも前記第1のタイプのトラックに対して相対的により速く完了される、前記生成するステップと、
ある1つのトラックを前記第1のタイプのトラックの前記リストから、または前記第2のタイプのトラックの前記リストからデモートすべきかどうかを判定するステップと
を備える、ストレージ・コントローラ。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/680,577 US10417139B2 (en) | 2017-08-18 | 2017-08-18 | Cache management based on types of I/O operations |
US15/680,577 | 2017-08-18 | ||
PCT/IB2018/056028 WO2019034976A1 (en) | 2017-08-18 | 2018-08-10 | CACHE MEMORY MANAGEMENT |
Publications (3)
Publication Number | Publication Date |
---|---|
JP2020531959A JP2020531959A (ja) | 2020-11-05 |
JP2020531959A5 true JP2020531959A5 (ja) | 2021-02-12 |
JP7095074B2 JP7095074B2 (ja) | 2022-07-04 |
Family
ID=65361546
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2020507995A Active JP7095074B2 (ja) | 2017-08-18 | 2018-08-10 | キャッシュ管理のための方法、システム、およびコンピュータ・プログラム |
Country Status (6)
Country | Link |
---|---|
US (3) | US10417139B2 (ja) |
JP (1) | JP7095074B2 (ja) |
CN (1) | CN111033479B (ja) |
DE (1) | DE112018003133T5 (ja) |
GB (1) | GB2579329B (ja) |
WO (1) | WO2019034976A1 (ja) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10417139B2 (en) | 2017-08-18 | 2019-09-17 | International Business Machines Corporation | Cache management based on types of I/O operations |
US11188474B2 (en) * | 2018-06-19 | 2021-11-30 | Western Digital Technologies, Inc. | Balanced caching between a cache and a non-volatile memory based on rates corresponding to the cache and the non-volatile memory |
US11379427B2 (en) | 2020-02-28 | 2022-07-05 | International Business Machines Corporation | Auxilary LRU list to improve asynchronous data replication performance |
US11726913B2 (en) | 2021-09-03 | 2023-08-15 | International Business Machines Corporation | Using track status information on active or inactive status of track to determine whether to process a host request on a fast access channel |
US11720500B2 (en) | 2021-09-03 | 2023-08-08 | International Business Machines Corporation | Providing availability status on tracks for a host to access from a storage controller cache |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5381539A (en) * | 1992-06-04 | 1995-01-10 | Emc Corporation | System and method for dynamically controlling cache management |
US8793436B2 (en) * | 2011-05-23 | 2014-07-29 | International Business Machines Corporation | Cache management of tracks in a first cache and a second cache for a storage |
US9063945B2 (en) | 2011-06-14 | 2015-06-23 | International Business Machines Corporation | Apparatus and method to copy data |
US9262321B2 (en) * | 2011-11-17 | 2016-02-16 | International Business Machines Corporation | Adjustment of destage rate based on read and write response time requirements |
US8966178B2 (en) | 2012-01-17 | 2015-02-24 | International Business Machines Corporation | Populating a first stride of tracks from a first cache to write to a second stride in a second cache |
US20140115260A1 (en) * | 2012-10-18 | 2014-04-24 | Oracle International Corporation | System and method for prioritizing data in a cache |
US9361241B2 (en) | 2013-04-03 | 2016-06-07 | International Business Machines Corporation | Grouping tracks for destaging |
US9996476B2 (en) | 2015-09-03 | 2018-06-12 | International Business Machines Corporation | Management of cache lists via dynamic sizing of the cache lists |
US10241918B2 (en) | 2015-09-29 | 2019-03-26 | International Business Machines Corporation | Considering a frequency of access to groups of tracks to select groups of tracks to destage |
US9715352B2 (en) * | 2015-10-01 | 2017-07-25 | International Business Machines Corporation | Synchronous input/output using a low latency storage controller connection |
US9384143B1 (en) | 2015-11-12 | 2016-07-05 | International Business Machines Corporation | Selecting cache lists indicating tracks in a cache to process for demotion |
US10133691B2 (en) * | 2016-06-23 | 2018-11-20 | International Business Machines Corporation | Synchronous input/output (I/O) cache line padding |
US10417139B2 (en) | 2017-08-18 | 2019-09-17 | International Business Machines Corporation | Cache management based on types of I/O operations |
US10866901B2 (en) * | 2018-06-02 | 2020-12-15 | International Business Machines Corporation | Invalidating CKD data tracks prior to unpinning, wherein upon destaging invalid track image from cache to a track of data on storage drive, the track of data on the storage drive is unpinned which enables destages of data from the cache to the track of data on the storage drive going forward |
-
2017
- 2017-08-18 US US15/680,577 patent/US10417139B2/en not_active Expired - Fee Related
-
2018
- 2018-08-10 CN CN201880052360.2A patent/CN111033479B/zh active Active
- 2018-08-10 JP JP2020507995A patent/JP7095074B2/ja active Active
- 2018-08-10 WO PCT/IB2018/056028 patent/WO2019034976A1/en active Application Filing
- 2018-08-10 GB GB2003615.8A patent/GB2579329B/en active Active
- 2018-08-10 DE DE112018003133.0T patent/DE112018003133T5/de active Pending
-
2019
- 2019-07-22 US US16/518,790 patent/US11023383B2/en active Active
-
2021
- 2021-04-26 US US17/240,908 patent/US11494309B2/en active Active
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP2020531959A5 (ja) | ||
US20170364304A1 (en) | Tracking hot areas of disk drive | |
US9519429B2 (en) | Techniques to manage multiple sequential write streams to a solid state drive | |
JP2019032875A5 (ja) | ||
JP2017535854A5 (ja) | ||
JP6757299B2 (ja) | メモリモジュール及びその動作方法 | |
GB2579329A (en) | Cache management | |
JP2013542486A5 (ja) | ||
JP2008310524A5 (ja) | ||
JP2018528515A5 (ja) | ||
US20170185354A1 (en) | Techniques for a Write Transaction at a Storage Device | |
JP2016537720A5 (ja) | ||
JP2010282628A5 (ja) | ||
KR102034659B1 (ko) | 컨볼루션 뉴럴 네트워크를 위한 하드웨어 가속기 및 컨볼루션 연산량 감소 방법 | |
US20120226859A1 (en) | Spatial extent migration for tiered storage architecture | |
JP2016515269A5 (ja) | ||
JP2018517210A5 (ja) | ||
TWI734681B (zh) | 資料緩存的預熱方法及其裝置 | |
US9471227B2 (en) | Implementing enhanced performance with read before write to phase change memory to avoid write cancellations | |
JP2018022317A (ja) | Hilシミュレーションシステム及びその制御方法 | |
JP2012173814A5 (ja) | 情報処理装置及び情報処理装置を制御する制御方法及びプログラム | |
US20150212949A1 (en) | Storage control device and storage control method | |
US9501766B2 (en) | Generating a storage drive qualification test plan | |
JP2012083870A5 (ja) | ||
US11347904B2 (en) | Techniques for modeling behaviors of systems via transformations of authoritative models |