JP5576030B2 - データ応答を順序変更するためのシステム - Google Patents
データ応答を順序変更するためのシステム Download PDFInfo
- Publication number
- JP5576030B2 JP5576030B2 JP2008120193A JP2008120193A JP5576030B2 JP 5576030 B2 JP5576030 B2 JP 5576030B2 JP 2008120193 A JP2008120193 A JP 2008120193A JP 2008120193 A JP2008120193 A JP 2008120193A JP 5576030 B2 JP5576030 B2 JP 5576030B2
- Authority
- JP
- Japan
- Prior art keywords
- data
- memory
- memory controller
- bus
- response
- 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.)
- Expired - Fee Related
Links
Images
Classifications
-
- 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/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4204—Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus
- G06F13/4234—Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a memory bus
- G06F13/4239—Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a memory bus with asynchronous protocol
-
- 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/161—Handling requests for interconnection or transfer for access to memory bus based on arbitration with latency improvement
- G06F13/1626—Handling requests for interconnection or transfer for access to memory bus based on arbitration with latency improvement by reordering requests
-
- 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)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Memory System (AREA)
- Advance Control (AREA)
Description
カウンタi>LSTART およびカウンタi<LEND 、或いは
(カウンタi+tReadData)>LSTART および(カウンタi+tReadData)LEND
但し、LSTARTは、トランザクションがリンクを要求する最初のものであり、
LENDは、それがリンクを要求するときの最後のものであり、
tReadData は、読取りデータが返送のために必要とする期間である。
カウンタ0<Lstart
シフト(SHIFT)i-1 が1にセットされるとき(カウンタI<Lstart)、カウンタi-1=カウンタi
置換(REPLACE)n-1 が1にセットされるとき、カウンタi-1=Lstart
保存(RETAIN)i-1 が1にセットされるとき、カウンタi-1=カウンタi-1-1.
RETAINi-1=!REPLACEi-1!SHIFTi-1(図9は、SHIFTおよびREPLACE信号を使用してRETAIN信号を生成する方法を示す)
SHIFTi-1=COUNTERi<LSTART(図10は、カウンタn-1がカウンタnの値によって更新されるべきであるかどうかを決定するためのロジックの使用を示す)
REPLACEi=1
i=nである場合、REPLACEn=COUNTERn<LSTART=SHIFTn−1
i<nである場合、REPLACEi=COUNTERi<LSTART およびREPLACE=0(図11、図12、および図13は、デコーダ1001およびREPLACE信号を生成するためのロジックを示す)
Claims (11)
- データ・チャネルの利用率を高めるためのシステムであって、
複数のメモリ・モジュールをデイジー・チェーンで備えているメモリ・システムと、
前記メモリ・システムにリンクを介して電気的に接続されたメモリ・コントローラと
を備えており、
前記メモリ・コントローラは、要求順序を有するデータ要求を前記メモリ・システムに送信し、
前記メモリ・システムは、前記データ要求を前記メモリ・コントローラから受信し、前記データ要求に対する複数のデータ応答を前記メモリ・コントローラに送信し、
前記メモリ・コントローラは、前記複数のデータ応答を前記メモリ・システムから受信し、当該受信した複数のデータ応答それぞれを複数のキューのうちの一つに格納し、
前記リンクは、前記メモリ・コントローラから前記メモリ・システムへデータ要求を送信するためのバス(以下、第1のバスという)と、前記メモリ・システムから前記メモリ・コントローラへデータ応答を返送するためのバス(以下、第2のバスという)を備えており、
前記メモリ・コントローラは、前記複数のデータ応答による前記第2のバスの使用を追跡して、前記複数のデータ応答が返送される順序と前記複数のキューの順序が一致するように、前記データ応答に関連付けられたタグを使わずに前記複数のキューにおいて前記複数のデータ応答を順序変更し、且つ、前記複数のメモリ・モジュールうち、前記複数のメモリ・モジュールそれぞれからからのデータ応答のうちの最初のデータ応答を返送する第1のメモリ・モジュールからの第1のデータ応答が前記第2のバスの使用を開始する時間と、前記複数のメモリ・モジュールそれぞれからからのデータ応答のうちの最後のデータ応答を返送する第2のメモリ・モジュールからの第2の応答が前記第2のバスの使用を完了する時間との間のリンク・ウィンドウ内において前記各データ応答が前記第2のバスを使用する各ビジー期間を決定し、前記ウィンドウ内において前記ビジー期間以外の期間(以下、未使用期間という)がある場合に、当該未使用の期間内にデータ応答を返送するように挿入する、
前記システム。 - 前記メモリ・コントローラは、前記リンク・ウィンドウ内におけるn個のビジー期間に割り当てられたn個のカウンタを含み、nは自然数である、請求項1に記載のシステム。
- 前記メモリ・コントローラは、前記n個のビジー期間への前記n個のカウンタの割り当てを、デクリメンタを介して更新する、請求項2に記載のシステム。
- 前記メモリ・コントローラは、前記n個のビジー期間への前記n個のカウンタの割り当てと、前記n個のビジー期間への前記n個のカウンタの割り当てを置換し、シフトし、および保存するグループから選択された命令とを受け取るマルチプレクサを備えている、請求項2に記載のシステム。
- 前記マルチプレクサは、カウンタの割り当てを出力するために、前記プロセッサが実行し得る命令を実装する回路として構成されている、請求項4に記載のシステム。
- 複数のメモリ・モジュールをデイジー・チェーンで備えているメモリ・システムと前記メモリ・システムにリンクを介して電気的に接続されたメモリ・コントローラとの間のデータ・チャネルの利用率を高めるための方法であって、
前記メモリ・コントローラが、要求順序を有するデータ要求を前記メモリ・システムに送信するステップと、
前記メモリ・システムが、前記データ要求を前記メモリ・コントローラから受信し、前記データ要求に対する複数のデータ応答を前記メモリ・コントローラに送信するステップと、
前記メモリ・コントローラが、前記複数のデータ応答を前記メモリ・システムから受信し、当該受信した複数のデータ応答それぞれを複数のキューのうちの一つに格納するステップと
を含み、
前記リンクは、前記メモリ・コントローラから前記メモリ・システムへデータ要求を送信するためのバス(以下、第1のバスという)と、前記メモリ・システムから前記メモリ・コントローラへデータ応答を返送するためのバス(以下、第2のバスという)を備えており、
前記メモリ・コントローラは、前記複数のデータ応答による前記第2のバスの使用を追跡して、前記複数のデータ応答が返送される順序と前記複数のキューの順序が一致するように、前記データ応答に関連付けられたタグを使わずに前記複数のキューにおいて前記複数のデータ応答を順序変更し、且つ、前記複数のメモリ・モジュールうち、前記複数のメモリ・モジュールそれぞれからからのデータ応答のうちの最初のデータ応答を返送する第1のメモリ・モジュールからの第1のデータ応答が前記第2のバスの使用を開始する時間と、前記複数のメモリ・モジュールそれぞれからからのデータ応答のうちの最後のデータ応答を返送する第2のメモリ・モジュールからの第2の応答が前記第2のバスの使用を完了する時間との間のリンク・ウィンドウ内において前記各データ応答が前記第2のバスを使用する各ビジー期間を決定し、前記ウィンドウ内において前記ビジー期間以外の期間(以下、未使用期間という)がある場合に、当該未使用の期間内にデータ応答を返送するように挿入するステップ
をさらに含む、前記方法。 - 前記メモリ・コントローラは、前記リンク・ウィンドウ内におけるn個のビジー期間に割り当てられたn個のカウンタを含み、nは自然数である、請求項6に記載の方法。
- 前記メモリ・コントローラは、前記n個のビジー期間への前記n個のカウンタの割り当てを、デクリメンタを介して更新する、請求項7に記載の方法。
- 前記メモリ・コントローラは、前記n個のビジー期間への前記n個のカウンタの割り当てと、前記n個のビジー期間への前記n個のカウンタの割り当てを置換し、シフトし、および保存するグループから選択された命令とを受け取るマルチプレクサを備えている、請求項7に記載の方法。
- 前記マルチプレクサは、カウンタの割り当てを出力するために、前記プロセッサが実行し得る命令を実装する回路として構成されている、請求項9に記載の方法。
- 複数のメモリ・モジュールをデイジー・チェーンで備えているメモリ・システムと前記メモリ・システムにリンクを介して電気的に接続されたメモリ・コントローラとの間のデータ・チャネルの利用率を高めるための方法を実行するためにプロセッサが実行し得る命令を実装するコンピュータ・プログラムであって、前記プロセッサに、請求項6〜10のいずれか一項に記載の方法の各ステップを実行させる、前記コンピュータ・プログラム。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/744,546 US9021482B2 (en) | 2007-05-04 | 2007-05-04 | Reordering data responses using ordered indicia in a linked list |
US11/744546 | 2007-05-04 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2008276783A JP2008276783A (ja) | 2008-11-13 |
JP5576030B2 true JP5576030B2 (ja) | 2014-08-20 |
Family
ID=39940500
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2008120193A Expired - Fee Related JP5576030B2 (ja) | 2007-05-04 | 2008-05-02 | データ応答を順序変更するためのシステム |
Country Status (3)
Country | Link |
---|---|
US (1) | US9021482B2 (ja) |
JP (1) | JP5576030B2 (ja) |
TW (1) | TW200910096A (ja) |
Families Citing this family (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7962706B2 (en) * | 2008-02-14 | 2011-06-14 | Quantum Corporation | Methods and systems for improving read performance in data de-duplication storage |
US20100211714A1 (en) * | 2009-02-13 | 2010-08-19 | Unisys Corporation | Method, system, and apparatus for transferring data between system memory and input/output busses |
US8090892B2 (en) * | 2009-06-12 | 2012-01-03 | Freescale Semiconductor, Inc. | Ordered queue and methods therefor |
JP5613517B2 (ja) * | 2010-09-30 | 2014-10-22 | 京セラドキュメントソリューションズ株式会社 | 情報処理装置 |
JP5659817B2 (ja) * | 2011-01-21 | 2015-01-28 | ソニー株式会社 | 相互接続装置 |
US8880819B2 (en) | 2011-12-13 | 2014-11-04 | Micron Technology, Inc. | Memory apparatuses, computer systems and methods for ordering memory responses |
US9032177B2 (en) | 2012-12-04 | 2015-05-12 | HGST Netherlands B.V. | Host read command return reordering based on time estimation of flash read command completion |
CN104657222B (zh) * | 2015-03-13 | 2017-11-21 | 浪潮集团有限公司 | 一种面向smp调度系统的优化方法 |
JP2017033612A (ja) * | 2015-07-29 | 2017-02-09 | 淳生 越塚 | 半導体記憶装置及びその制御方法 |
US10628340B2 (en) | 2018-01-18 | 2020-04-21 | Nxp Usa, Inc. | Method for reordering out of order responses from decomposed requests in bridge IP |
US11874782B1 (en) * | 2018-07-20 | 2024-01-16 | Robert Gezelter | Fast mass storage access for digital computers |
US11775467B2 (en) * | 2021-01-14 | 2023-10-03 | Nxp Usa, Inc. | System and method for ordering transactions in system-on-chips |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2632093B1 (fr) | 1988-05-25 | 1990-08-10 | Bull Sa | Memoire modulaire |
US6006343A (en) * | 1993-07-30 | 1999-12-21 | Texas Instruments Incorporated | Method and apparatus for streamlined testing of electrical circuits |
US6286011B1 (en) * | 1997-04-30 | 2001-09-04 | Bellsouth Corporation | System and method for recording transactions using a chronological list superimposed on an indexed list |
US6385708B1 (en) | 1998-11-16 | 2002-05-07 | Infineon Technologies Ag | Using a timing-look-up-table and page timers to determine the time between two consecutive memory accesses |
US6345353B2 (en) * | 1999-07-20 | 2002-02-05 | Microchip Technology Incorporated | Stack pointer with post increment/decrement allowing selection from parallel read/write address outputs |
US6571332B1 (en) * | 2000-04-11 | 2003-05-27 | Advanced Micro Devices, Inc. | Method and apparatus for combined transaction reordering and buffer management |
US8781873B2 (en) * | 2001-04-02 | 2014-07-15 | Siebel Systems, Inc. | Method and system for scheduling activities |
TWI308011B (en) * | 2002-08-09 | 2009-03-21 | Interdigital Tech Corp | Efficient memory allocation in a wireless transmit/receiver unit |
US7570634B2 (en) * | 2005-08-30 | 2009-08-04 | Freescale Semiconductor, Inc. | Priority queuing of frames in a TDMA network |
US7577773B1 (en) * | 2005-09-09 | 2009-08-18 | Qlogic, Corporation | Method and system for DMA optimization |
-
2007
- 2007-05-04 US US11/744,546 patent/US9021482B2/en not_active Expired - Fee Related
-
2008
- 2008-05-02 JP JP2008120193A patent/JP5576030B2/ja not_active Expired - Fee Related
- 2008-05-02 TW TW97116355A patent/TW200910096A/zh unknown
Also Published As
Publication number | Publication date |
---|---|
TW200910096A (en) | 2009-03-01 |
US9021482B2 (en) | 2015-04-28 |
JP2008276783A (ja) | 2008-11-13 |
US20080276240A1 (en) | 2008-11-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5576030B2 (ja) | データ応答を順序変更するためのシステム | |
US7181598B2 (en) | Prediction of load-store dependencies in a processing agent | |
US7644204B2 (en) | SCSI I/O coordinator | |
US20110119426A1 (en) | List based prefetch | |
US8281103B2 (en) | Method and apparatus for allocating storage addresses | |
US9304952B2 (en) | Memory control device, storage device, and memory control method | |
US20070288694A1 (en) | Data processing system, processor and method of data processing having controllable store gather windows | |
US8166246B2 (en) | Chaining multiple smaller store queue entries for more efficient store queue usage | |
WO2024036985A1 (zh) | 存储系统及其计算存储处理器、固体硬盘和数据读写方法 | |
CN112955876A (zh) | 具有对写入操作的改进处理的用于数据处理网络的i/o相干请求节点 | |
US7769954B2 (en) | Data processing system and method for processing data | |
CN116361232A (zh) | 片上缓存的处理方法、装置、芯片及存储介质 | |
CN113791892B (zh) | 数据通路仲裁方法、数据通路仲裁装置及芯片 | |
CN112015527A (zh) | 管理从提交队列获取和执行命令 | |
US20060253662A1 (en) | Retry cancellation mechanism to enhance system performance | |
CN118295710A (zh) | 多端口发射的空间回收方法、装置、设备和介质 | |
US8990473B2 (en) | Managing requests to open and closed banks in a memory system | |
US20220091986A1 (en) | Method and apparatus for reducing the latency of long latency memory requests | |
JP2005339299A (ja) | ストレージ装置のキャッシュ制御方法 | |
US8452920B1 (en) | System and method for controlling a dynamic random access memory | |
EP4064062A1 (en) | System, apparatus, and method for scheduling metadata requests | |
JP2001109662A (ja) | キャッシュ装置及び制御方法 | |
US20140013148A1 (en) | Barrier synchronization method, barrier synchronization apparatus and arithmetic processing unit | |
CN114153756B (zh) | 面向多核处理器目录协议的可配置微操作机制 | |
EP1115065B1 (en) | Effective channel priority processing for transfer controller with hub and ports |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20110124 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20121025 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20121106 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20130111 Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20130111 |
|
RD12 | Notification of acceptance of power of sub attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7432 Effective date: 20130111 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20130111 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20130314 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20130430 Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20130430 |
|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20130614 |
|
A912 | Re-examination (zenchi) completed and case transferred to appeal board |
Free format text: JAPANESE INTERMEDIATE CODE: A912 Effective date: 20130705 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20131128 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20140617 |
|
RD14 | Notification of resignation of power of sub attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7434 Effective date: 20140617 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20140703 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 5576030 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
LAPS | Cancellation because of no payment of annual fees |