JP7187698B2 - 2の非累乗のメモリ構成 - Google Patents
2の非累乗のメモリ構成 Download PDFInfo
- Publication number
- JP7187698B2 JP7187698B2 JP2021531209A JP2021531209A JP7187698B2 JP 7187698 B2 JP7187698 B2 JP 7187698B2 JP 2021531209 A JP2021531209 A JP 2021531209A JP 2021531209 A JP2021531209 A JP 2021531209A JP 7187698 B2 JP7187698 B2 JP 7187698B2
- Authority
- JP
- Japan
- Prior art keywords
- subset
- memory
- address bits
- physical address
- bits
- 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
Images
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/06—Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
- G06F12/0615—Address space extension
- G06F12/0623—Address space extension for memory modules
-
- 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/06—Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
- G06F12/0607—Interleaved addressing
-
- 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
-
- 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
- G06F13/1605—Handling requests for interconnection or transfer for access to memory bus based on arbitration
- G06F13/1647—Handling requests for interconnection or transfer for access to memory bus based on arbitration with interleaved bank access
-
- 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
- G06F13/1605—Handling requests for interconnection or transfer for access to memory bus based on arbitration
- G06F13/1652—Handling requests for interconnection or transfer for access to memory bus based on arbitration in a multiprocessor architecture
- G06F13/1657—Access to multiple memories
-
- 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
- G06F13/1668—Details of memory controller
- G06F13/1684—Details of memory controller using multiple buses
-
- 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/25—Using a specific main memory architecture
- G06F2212/253—Centralized memory
- G06F2212/2532—Centralized memory comprising a plurality of modules
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Memory System (AREA)
- Power Sources (AREA)
Description
Claims (20)
- システムであって、
1つ以上のクライアントと、
総メモリチャネルに対するアクティブメモリチャネルの第1の比率を有するメモリサブシステムと、を備え、
前記メモリサブシステムは、
前記第1の比率を、第1の数対第2の数の第2の比率に低減することと、
前記1つ以上のクライアントのうち何れかのクライアントからメモリ要求を受信することと、
前記メモリ要求の物理アドレスビットの第1のサブセットが前記第1の数以上の値を有すると判別したことに応じて、
前記第1の数を法とする前記物理アドレスビットの第2のサブセットに対応する値に基づいて、第3の数を計算することと、
前記第3の数と、前記物理アドレスビットの第3のサブセットと、の連結を使用して、前記複数のメモリチャネルの中からメモリチャネルを選択することと、
選択されたメモリチャネルに対する前記メモリ要求を完了することと、
を行うように構成されている、
システム。 - 前記メモリサブシステムは、前記メモリ要求の前記物理アドレスビットの第1のサブセットが前記第1の数以上の値を有すると判別したことに応じて、
第5の数だけシフトアップされた前記物理アドレスビットの第1のサブセットに基づく第4の数を計算することであって、前記第5の数は、前記メモリサブシステムのアドレス空間のサイズに基づいて計算される、ことと、
正規化アドレスビットの第1のサブセットを、前記物理アドレスビットの第2のサブセットに等しいものとして計算することであって、上位ビットが前記物理アドレスビットの第1のサブセットで置き換えられる、ことと、
正規化アドレスビットの第2のサブセットを、物理アドレスビットの第4のサブセットと物理アドレスビットの第5のサブセットとの連結に等しいものとして計算することと、
前記選択されたメモリチャネルにおいて正規化アドレスに対する前記メモリ要求を完了することであって、前記正規化アドレスは、前記正規化アドレスビットの第1のサブセットと、前記正規化アドレスビットの第2のサブセットと、を含む、ことと、
をさらに行うように構成されている、
請求項1のシステム。 - 前記メモリサブシステムは、2の非累乗の数のアクティブメモリチャネルを有する、
請求項1のシステム。 - 前記物理アドレスビットの第1のサブセットは、前記物理アドレスビットの第3のサブセットに隣接している、
請求項1のシステム。 - 前記物理アドレスビットの第4のサブセットは、前記物理アドレスビットの第1のサブセットに隣接している、
請求項2のシステム。 - 前記物理アドレスビットの第3のサブセットは、前記物理アドレスビットの第5のサブセットに隣接している、
請求項2のシステム。 - 前記1つ以上のクライアントはグラフィックエンジンであり、前記メモリ要求は、ディスプレイに表示されるピクセルをレンダリングするためのアプリケーションの一部として生成される、
請求項1のシステム。 - 方法であって、
第1のデバイスの制御ユニットによって、メモリサブシステム内の物理メモリチャネルの総数のうちアクティブメモリチャネルの数を決定することと、
前記物理メモリチャネルの総数に対する前記アクティブメモリチャネルの数の比率を、第1の数対第2の数に低減することと、
受信したメモリ要求の物理アドレスビットの第1のサブセットが前記第1の数以上であると判別したことに応じて、
前記第1の数を法とする物理アドレスビットの第2のサブセットに対応する値に基づいて、第3の数を計算することと、
前記第3の数と、物理アドレスビットの第3のサブセットと、の連結を使用して、複数のメモリチャネルの中からメモリチャネルを選択することと、
選択されたメモリチャネルに対する前記メモリ要求を完了することと、を含む、
方法。 - 前記メモリ要求の前記物理アドレスビットの第1のサブセットが前記第1の数以上であると判別したことに応じて、
第5の数だけシフトアップされた前記物理アドレスビットの第1のサブセットに基づく第4の数を計算することであって、前記第5の数は、前記メモリサブシステムのアドレス空間のサイズに基づいて計算される、ことと、
正規化アドレスビットの第1のサブセットを、前記物理アドレスビットの第2のサブセットに等しいものとして計算することであって、上位ビットが前記物理アドレスビットの第1のサブセットで置き換えられる、ことと、
正規化アドレスビットの第2のサブセットを、物理アドレスビットの第4のサブセットと物理アドレスビットの第5のサブセットとの連結に等しいものとして計算することと、
前記選択されたメモリチャネルにおいて正規化アドレスに対する前記メモリ要求を完了することであって、前記正規化アドレスは、前記正規化アドレスビットの第1のサブセットと、前記正規化アドレスビットの第2のサブセットと、を含む、ことと、をさらに含む、
請求項8の方法。 - 前記メモリサブシステムは、2の非累乗の数のアクティブメモリチャネルを有する、
請求項8の方法。 - 前記物理アドレスビットの第1のサブセットは、前記物理アドレスビットの第3のサブセットに隣接している、
請求項8の方法。 - 前記物理アドレスビットの第4のサブセットは、前記物理アドレスビットの第1のサブセットに隣接している、
請求項9の方法。 - 前記物理アドレスビットの第3のサブセットは、前記物理アドレスビットの第5のサブセットに隣接している、
請求項9の方法。 - 前記メモリ要求を、ディスプレイに表示されるピクセルをレンダリングするためのアプリケーションの一部として生成することをさらに含む、
請求項8の方法。 - 装置であって、
制御ユニットと、
複数のメモリチャネルを備えるメモリサブシステムと、を備え、
前記制御ユニットは、
前記メモリサブシステム内の物理メモリチャネルの総数のうちアクティブメモリチャネルの数を決定することと、
前記物理メモリチャネルの総数に対する前記アクティブメモリチャネルの数の比率を、第1の数対第2の数に低減することと、
受信したメモリ要求の物理アドレスビットの第1のサブセットが前記第1の数以上であると判別したことに応じて、
前記第1の数を法とする物理アドレスビットの第2のサブセットに基づいて、第3の数を計算することと、
前記第3の数と、物理アドレスビットの第3のサブセットと、の連結を使用して、前記複数のメモリチャネルの中からメモリチャネルを選択することと、
選択されたメモリチャネルに対する前記メモリ要求を完了することと、
を行うように構成されている、
装置。 - 前記制御ユニットは、前記メモリ要求の物理アドレスビットの第1のサブセットが前記第1の数以上であると判別したことに応じて、
第5の数だけシフトアップされた前記物理アドレスビットの第1のサブセットに基づく第4の数を計算することであって、前記第5の数は、前記メモリサブシステムのアドレス空間のサイズに基づいて計算される、ことと、
正規化アドレスビットの第1のサブセットを、前記物理アドレスビットの第2のサブセットに等しいものとして計算することであって、上位ビットが前記物理アドレスビットの第1のサブセットで置き換えられる、ことと、
正規化アドレスビットの第2のサブセットを、物理アドレスビットの第4のサブセットと物理アドレスビットの第5のサブセットとの連結に等しいものとして計算することと、
前記選択されたメモリチャネルにおいて正規化アドレスに対する前記メモリ要求を完了することであって、前記正規化アドレスは、前記正規化アドレスビットの第1のサブセットと、前記正規化アドレスビットの第2のサブセットと、を含む、ことと、
をさらに行うように構成されている、
請求項15の装置。 - 前記メモリサブシステムは、2の非累乗の数のアクティブメモリチャネルを有する、
請求項15の装置。 - 前記物理アドレスビットの第1のサブセットは、前記物理アドレスビットの第3のサブセットに隣接している、
請求項15の装置。 - 前記物理アドレスビットの第4のサブセットは、前記物理アドレスビットの第1のサブセットに隣接している、
請求項16の装置。 - 前記物理アドレスビットの第3のサブセットは、前記物理アドレスビットの第5のサブセットに隣接している、
請求項16の装置。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/208,139 US10642734B1 (en) | 2018-12-03 | 2018-12-03 | Non-power of two memory configuration |
US16/208,139 | 2018-12-03 | ||
PCT/US2019/064017 WO2020117678A1 (en) | 2018-12-03 | 2019-12-02 | Non-power of two memory configuration |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2022510970A JP2022510970A (ja) | 2022-01-28 |
JP7187698B2 true JP7187698B2 (ja) | 2022-12-12 |
Family
ID=69005938
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2021531209A Active JP7187698B2 (ja) | 2018-12-03 | 2019-12-02 | 2の非累乗のメモリ構成 |
Country Status (6)
Country | Link |
---|---|
US (1) | US10642734B1 (ja) |
EP (1) | EP3891615A1 (ja) |
JP (1) | JP7187698B2 (ja) |
KR (1) | KR20210088694A (ja) |
CN (1) | CN113168376A (ja) |
WO (1) | WO2020117678A1 (ja) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2604153A (en) * | 2021-02-26 | 2022-08-31 | Advanced Risc Mach Ltd | Data Processors |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150089168A1 (en) | 2013-09-20 | 2015-03-26 | Advanced Micro Devices, Inc. | Nested channel address interleaving |
JP2016085541A (ja) | 2014-10-23 | 2016-05-19 | 京セラドキュメントソリューションズ株式会社 | メモリーコントローラー |
US20180019006A1 (en) | 2016-07-15 | 2018-01-18 | Advanced Micro Devices, Inc. | Memory controller with flexible address decoding |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6941438B2 (en) * | 2003-01-10 | 2005-09-06 | Intel Corporation | Memory interleaving |
WO2008040028A2 (en) | 2006-09-28 | 2008-04-03 | Virident Systems, Inc. | Systems, methods, and apparatus with programmable memory control for heterogeneous main memory |
US8914568B2 (en) | 2009-12-23 | 2014-12-16 | Intel Corporation | Hybrid memory architectures |
KR101572403B1 (ko) | 2011-12-22 | 2015-11-26 | 인텔 코포레이션 | 메모리 채널 셧다운에 의한 전력 절약 |
US9734079B2 (en) | 2013-06-28 | 2017-08-15 | Intel Corporation | Hybrid exclusive multi-level memory architecture with memory management |
CN107180001B (zh) * | 2016-03-10 | 2020-02-21 | 华为技术有限公司 | 访问动态随机存储器dram的方法和总线 |
-
2018
- 2018-12-03 US US16/208,139 patent/US10642734B1/en active Active
-
2019
- 2019-12-02 JP JP2021531209A patent/JP7187698B2/ja active Active
- 2019-12-02 EP EP19828002.6A patent/EP3891615A1/en active Pending
- 2019-12-02 CN CN201980079894.9A patent/CN113168376A/zh active Pending
- 2019-12-02 KR KR1020217017890A patent/KR20210088694A/ko not_active Application Discontinuation
- 2019-12-02 WO PCT/US2019/064017 patent/WO2020117678A1/en unknown
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150089168A1 (en) | 2013-09-20 | 2015-03-26 | Advanced Micro Devices, Inc. | Nested channel address interleaving |
JP2016085541A (ja) | 2014-10-23 | 2016-05-19 | 京セラドキュメントソリューションズ株式会社 | メモリーコントローラー |
US20180019006A1 (en) | 2016-07-15 | 2018-01-18 | Advanced Micro Devices, Inc. | Memory controller with flexible address decoding |
JP2019520660A (ja) | 2016-07-15 | 2019-07-18 | アドバンスト・マイクロ・ディバイシズ・インコーポレイテッドAdvanced Micro Devices Incorporated | 柔軟なアドレスデコード機能を備えるメモリコントローラ |
Non-Patent Citations (1)
Title |
---|
Takuya Toyoshima et al,An Application-adaptive Data Allocation Method for Multi-channel Memory,[online],米国,IEEE,2017年06月15日,pp. 1-3,[検索日:2022年6月24日], インターネット<https://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=7946381>,ISSN:2473-4683 |
Also Published As
Publication number | Publication date |
---|---|
JP2022510970A (ja) | 2022-01-28 |
EP3891615A1 (en) | 2021-10-13 |
KR20210088694A (ko) | 2021-07-14 |
WO2020117678A1 (en) | 2020-06-11 |
US10642734B1 (en) | 2020-05-05 |
CN113168376A (zh) | 2021-07-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8866830B2 (en) | Memory controller interface for micro-tiled memory access | |
US20170255552A1 (en) | Systems and methods for dynamic random access memory (dram) sub-channels | |
US11513689B2 (en) | Dedicated interface for coupling flash memory and dynamic random access memory | |
JP2016509280A (ja) | グラフィックスプロセッシングユニットベースのメモリ転送動作を行うためのマルチモードメモリアクセス技法 | |
US10048899B2 (en) | Storage device, computing system including the storage device, and method of operating the storage device | |
JPWO2007069506A1 (ja) | 記憶領域割当システム及び方法と制御装置 | |
CN110582745A (zh) | 存储器装置及可促进张量存储器存取的方法 | |
CN108139989B (zh) | 配备有存储器中的处理和窄访问端口的计算机设备 | |
TW201714090A (zh) | 記憶體裝置、記憶體定址方法與包括有形儲存媒體的物品 | |
CN111831220B (zh) | 用于存储器写入操作的设备、方法和存储器模块 | |
US20140160876A1 (en) | Address bit remapping scheme to reduce access granularity of dram accesses | |
US10019358B2 (en) | Bank address remapping to load balance memory traffic among banks of memory | |
JP7187698B2 (ja) | 2の非累乗のメモリ構成 | |
CN108701085B (zh) | 用于固态装置的多个地址寄存器的设备及方法 | |
KR20200011136A (ko) | 불휘발성 메모리 장치, 불휘발성 메모리 장치의 동작 방법 및 불휘발성 메모리 장치를 제어하는 메모리 컨트롤러의 동작 방법 | |
US20240168896A1 (en) | Memory controller, electric system including the same and method of controlling memory access | |
US11775431B2 (en) | Cache memory with randomized eviction | |
US11960410B2 (en) | Unified kernel virtual address space for heterogeneous computing | |
US11782830B2 (en) | Cache memory with randomized eviction | |
CN113808000B (zh) | 数据管理装置及数据管理方法 | |
CN106708747A (zh) | 一种存储器切换方法及装置 | |
CN112835513A (zh) | 控制数据读写装置与方法 | |
JP2018010338A (ja) | 回路装置及び電子機器 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20210707 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20220624 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20220705 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20221005 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20221024 |
|
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: 20221108 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20221130 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 7187698 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |