JPS58115677A - Dma data transfer system for transfer in the same memory - Google Patents
Dma data transfer system for transfer in the same memoryInfo
- Publication number
- JPS58115677A JPS58115677A JP21550181A JP21550181A JPS58115677A JP S58115677 A JPS58115677 A JP S58115677A JP 21550181 A JP21550181 A JP 21550181A JP 21550181 A JP21550181 A JP 21550181A JP S58115677 A JPS58115677 A JP S58115677A
- Authority
- JP
- Japan
- Prior art keywords
- dma
- memory
- data
- data transfer
- transfer
- 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.)
- Pending
Links
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/14—Handling requests for interconnection or transfer
- G06F13/20—Handling requests for interconnection or transfer for access to input/output bus
- G06F13/28—Handling requests for interconnection or transfer for access to input/output bus using burst mode transfer, e.g. direct memory access DMA, cycle steal
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Bus Control (AREA)
Abstract
Description
【発明の詳細な説明】
(1)発明の技術分野
本発明は、計算機システムにおいて、同一メモリ内での
DMAデータ転送を、中間バッファを経由し2て行なう
ようにしたDMAデータ転送方式に関する。DETAILED DESCRIPTION OF THE INVENTION (1) Technical Field of the Invention The present invention relates to a DMA data transfer method in a computer system in which DMA data transfer within the same memory is performed twice via an intermediate buffer.
(2)技術の背景
D M A (Direct Memory Acc
ess)は、プログラム転送によっては殆んど不可能な
、メモリとI10装置間での大量のデータ転送を、専用
のDMA装置を用いて高速に行なう方式である。このた
約、従来のDMA装置は、メモリとI10ボート間での
DMAデータ転送だけを目的とするように設計されてお
ゆ、同一メモリ内でのデータ転送に使用することができ
なかった。(2) Technical background DMA (Direct Memory Acc)
ess) is a method that uses a dedicated DMA device to transfer a large amount of data between a memory and an I10 device at high speed, which is almost impossible by program transfer. Due to this limitation, conventional DMA devices were designed only for DMA data transfer between a memory and an I10 board, and could not be used for data transfer within the same memory.
しかし、近年、メモリの超LSI化が進み、多くの計算
機システムが、大容量の内部メモリを備えるようになっ
てきている。そのため、同一メモリ内でのデータの移[
7替えの量も多くなり、CPUがそれに占有される時間
も無視できないものとなっている。However, in recent years, the use of ultra-LSI memories has progressed, and many computer systems are now equipped with large-capacity internal memories. Therefore, data movement within the same memory [
The number of changes has also increased, and the amount of time that the CPU is occupied with it has become non-negligible.
(3)発明の目的
本発明の目的は、従来不可能であった同一メモリ内での
DMAデータ転送を、比較的簡単な手段で実現すること
にある。(3) Purpose of the Invention The purpose of the present invention is to realize DMA data transfer within the same memory, which was previously impossible, by relatively simple means.
(4)発明の構成
本発明は、メモリ内の異なる領域間でのDMAデータ転
送を実現するために、中間にバッファを設け、このバッ
ファをDMAデータ転送の中継点として利用するもので
ある。(4) Structure of the Invention According to the present invention, in order to realize DMA data transfer between different areas in a memory, a buffer is provided in the middle, and this buffer is used as a relay point for DMA data transfer.
第1図は、本発明の概念を示す説明図である。FIG. 1 is an explanatory diagram showing the concept of the present invention.
メモリ・マツプ上の領域Aのデータを、領域Bへ転送す
る場合、ソース(発イg地)アドレスからディストネー
ション(着信地)アドレスへ、1アドレス分ずつデータ
を転送するのに、一旦、メモリ領域Aのソース・アドレ
スから、1アドレス分のデータを中間バッファへDMA
転送I7、次に中間バッファからメモリ領域Bのディス
トネーション―
・アドレスへ、データを再びDMA転送するというよう
に、1アドレス分のデータ転送を、2ステツプのDMA
処理で実行し、これを必要アドレス分だけ繰り返すもの
である。When transferring data from area A on the memory map to area B, the data is transferred from the source address to the destination address one address at a time, but once the memory DMA one address worth of data from the source address of area A to the intermediate buffer
Transfer I7, then DMA transfer the data from the intermediate buffer to the destination address in memory area B again, and so on, data transfer for one address is performed by two-step DMA transfer.
This is executed as a process, and this process is repeated as many times as necessary.
そ]〜で、本発明は、そのための構成として計算機シス
テムにおいて、メモリと、第1および第■のDMAチャ
ネルを有するDMA制御回路と、中間バッファとを備オ
、−ヒ8eメモリ内の異なる2つの領域間でのデータ転
送を、上F第1のDMAチャネルを用いてメモリから中
間バッファにDMAデータ転送する動作と、上記第■の
DMAチャネルを用いて中間バッファからメモリにDM
Aデータ転送を行なう動作との組合せにより実行するこ
とを特徴とする本のである。Therefore, the present invention provides a computer system with a configuration for that purpose, which includes a memory, a DMA control circuit having a first and a DMA channel, and an intermediate buffer. DMA data transfer between the two areas is performed using the upper F first DMA channel to transfer DMA data from the memory to the intermediate buffer, and the above F first DMA channel to transfer the DMA data from the intermediate buffer to the memory.
This book is characterized in that it is executed in combination with the operation of A data transfer.
(5)発明の実施例
’f42図*、本発明の実施例のyj戦の概略構成を示
すブロック図である。同図において、1はメモリ、2は
DMA装置のチャネル(1)の回路9素、3けそのDM
Aアドレス・カウンタ(1)、4はバイト・カウント・
レジスタ(I)、5は同様にDMA装置のチャネル■の
回路要素、6はDMAアドレス・カウンタ(u)、7は
バイト・カウント・レジスタ(II)、8はマルチプレ
クサMPX、9Fi中間バッファ、10はデータバスを
示す。(5) Embodiment of the Invention 'F42 Diagram* is a block diagram showing the schematic configuration of the YJ game according to the embodiment of the invention. In the figure, 1 is a memory, 2 is a 9-element circuit of channel (1) of a DMA device, and 3-digit DM
A address counter (1), 4 is byte count
Similarly, register (I), 5 is the circuit element of channel 2 of the DMA device, 6 is the DMA address counter (u), 7 is the byte count register (II), 8 is the multiplexer MPX, 9 is the intermediate buffer, 10 is the Shows data bus.
DMA装置は、図示のように2チヤンネルが使用される
。1つはメモリ1から申出1バッファ9へのDMAデー
タ転送に使用され、他の1っは中間バッファ9からメモ
リ1へのDMAデータ転送に使用される。マルチプレク
サ8は、メモリのソースアドレスと、テイストネーショ
ンOアドレスとを切替えるために使用される。The DMA device uses two channels as shown. One is used for DMA data transfer from memory 1 to offer 1 buffer 9, and the other one is used for DMA data transfer from intermediate buffer 9 to memory 1. Multiplexer 8 is used to switch between the memory source address and the tastenation O address.
メモIJ l内の2つの領域間で、DMAデータ転送を
行うときには、まずDMAアドレス・カウンタ(1)に
ソース・アドレスを、DMAアドレスeカウンタ(Il
lにはディストネーション・アドレスをセットし、そ1
.てバイト・カウント・レジスタ(1)、(lN)には
、データ長をセットする。When performing DMA data transfer between two areas in memo IJl, first input the source address into the DMA address counter (1) and write the source address into the DMA address e counter (Il).
Set the destination address in l, and
.. Then, set the data length in the byte count registers (1) and (IN).
最初にDMAチャネル(1)を起動し、メモリ1から中
間バッファ9へDMAデータ転送し、中間バッファ9に
データを一旦格納する。次にDMAチャネル(If)
f起動し、中間バッファ9からメモリ1へのDMAデー
タ転送を行なう。この繰り返しによってメモリからメモ
リへのデータのDt4A転送を実埃する。First, the DMA channel (1) is activated, DMA data is transferred from the memory 1 to the intermediate buffer 9, and the data is temporarily stored in the intermediate buffer 9. Then the DMA channel (If)
f starts up and performs DMA data transfer from the intermediate buffer 9 to the memory 1. This repetition completes the Dt4A transfer of data from memory to memory.
第3図は、本発明実施例のより詳細な構成図でおる。な
お説明の便宜上、!10制御回路部分については省略し
である。同図において、11はメモリ、12はCPU、
13はDMA回路、14はチャネル(1)のアドレスe
カウンタ、15はチャネル(II)のアドレス・カウン
タ、16はチャネル(I)のノ(イト拳カウント・レジ
スタ、17はチャネル(II)のノくイト・カウント・
レジスタ、18は中間バッファ、19は制御部、20は
DMAチャネルを切替えるためのレジスタ・セレクタ、
21けアドレス・バス、22はデータ・ノ(ス、23は
制御バス、を示す。FIG. 3 is a more detailed configuration diagram of an embodiment of the present invention. For convenience of explanation,! The 10 control circuit portion is omitted. In the figure, 11 is a memory, 12 is a CPU,
13 is the DMA circuit, 14 is the address e of channel (1)
15 is the channel (II) address counter, 16 is the channel (I) no-kite count register, and 17 is the channel (II) no-kite count register.
18 is a register, 19 is an intermediate buffer, 19 is a control unit, 20 is a register selector for switching the DMA channel,
21 address buses, 22 data nodes, and 23 control buses.
アドレス・カウンタ14.15、バイト・カウント−レ
ジスタ16.17、および中間バッファ18は、第2図
において説明したものと同じ機能を果す亀のである。Address counter 14.15, byte count register 16.17, and intermediate buffer 18 are turtles that perform the same functions as described in FIG.
制御部19は、CPU、メモリ、I10チャネル装置(
説明の便宜上省略) 、DMAの内部回路畔と連絡して
、CPUへのバス開放要求、メモリへのリード/ライ)
(R/W)制御、本実施例では省略されているIl
oからの転送要求受信と転送要求許可、あるいは内部の
レジスタ、カウンタ、バッファ等の動作制御を行なう。The control unit 19 includes a CPU, memory, I10 channel device (
(omitted for convenience of explanation), communicates with the internal circuit of the DMA, requests the CPU to open the bus, reads/writes to the memory)
(R/W) control, Il omitted in this example
It receives the transfer request from o, grants the transfer request, or controls the operations of internal registers, counters, buffers, etc.
レジスタ会セレクタ20は、メモリと中間ノ(ツフ7間
でのDM人転送方向切替えに対応して、DMAチャネル
を(1)と(II)との間で切替える。レジスターセレ
クタ加はまた、CPU12が、DMA動作前に、アドレ
ス會カウンタ、バイトeカウント自レジスタ、その他図
示しない各種レジスタを任意に選択して、それぞれにメ
モリーアドレス、転送バイト数、その他の制御情報をセ
ットし、管だ必要に応じてこれらのレジスタの内容を読
み出すためにも使用される。The register selector 20 switches the DMA channel between (1) and (II) in response to the switching of the DM transfer direction between the memory and the intermediate node 7.The register selector also switches the DMA channel between (1) and (II). , before the DMA operation, arbitrarily select the address counter, byte e count own register, and other various registers (not shown), set the memory address, number of transferred bytes, and other control information for each, and set the control information as necessary. It is also used to read the contents of these registers.
動作において、CPUは、データ・バスから、アドレス
・カウンタ(1)、(IDに、それぞれメモリ内で転送
が行なわれる2つの領域の各先頭アドレスである、ソー
ス・アドレスと、ディストネーション・アドレスとをセ
ットし、またバイト・カウント・レジスタ<1)、(1
)に、同じ転送データの語数をセットする。In operation, the CPU inputs from the data bus into the address counter (1) (ID) a source address and a destination address, respectively, which are the starting addresses of the two areas to be transferred in memory. and byte count register <1), (1
), set the number of words of the same transfer data.
次に、制御部19は、レジスタ・セレクタ加によす、D
MAチャネル(1)を起動し、またCPUt?DMA可
能状態にする。これによ松、アドレス・カウンタ(1)
のソース−アドレスが、アドレス・バスを介してメモリ
に与えらnlまた、制御部19から、リード信号(R/
W)が、制御バス詔を介してメモリttC与えられる。Next, the control unit 19 adds register selector D.
Start MA channel (1) and restart CPUt? Enable DMA. This is Matsu, Address Counter (1)
The source address of nl is applied to the memory via the address bus.The control unit 19 also sends a read signal (R/
W) is provided to the memory ttC via the control bus.
そのため、メモリのソース・アドレスからデータが、デ
ータ・バス上に読み出される。このとき、制御部19に
より、中間バッファ18が能動化され、データは、この
中間バッファ上に格納される。Data is therefore read from the source address of the memory onto the data bus. At this time, the control unit 19 activates the intermediate buffer 18, and the data is stored on this intermediate buffer.
メ七りから中間バッファへの1アドレス分のデータ転送
が終了すると、アドレス・カウンタ(1)の内容は+1
.進され、他方、バイト・カウント。When data transfer for one address from the main buffer to the intermediate buffer is completed, the contents of the address counter (1) will be +1.
.. on the other hand, the byte count.
レジスタ(I)の内容からは1だけ減算される0ζこで
、制御部19は、レジスタ・セレクタ加に指令して、D
MAチャネル(It)を起動する。0ζ is subtracted by 1 from the contents of the register (I).The control unit 19 then instructs the register selector to add D.
Activate the MA channel (It).
DMA?ヤネル([の起動時においては、メJfニジに
1アドレス・カウンタ(II)のディストネーション・
アドレスが与えられ、また制御1119がら、ライト信
号(R/W)が与えられる。同時に、中間バッファ18
中に先に書き込まれていたデータが、制御部19によっ
て読み出され、そのデータはデータ・バスを介して、ア
ドレス会カウンタ(IOKよって指示されたメモリのデ
ィジ4トネーシヨンーアドレスに書き込まれる。書き込
みが終了すると、アドレス・カウンタ(n)は+1され
、バイト・カウント・レジスタ(If)は−1される。DMA? Janel (When starting up, the destination of 1 address counter (II) is displayed in the main Jf page.
An address is given, and a write signal (R/W) is given under control 1119. At the same time, the intermediate buffer 18
The data previously written therein is read out by the control unit 19 and written via the data bus to the digitization address of the memory indicated by the address counter (IOK). When writing is completed, the address counter (n) is incremented by 1 and the byte count register (If) is incremented by 1.
以上の動作は、バイト拳カウント・レジスタ(I)、(
II)の内容が、共に零になるまで繰り返され、零にな
ったとき、DMAデータ転送動作は終了される。The above operation is performed by the Byteken count register (I), (
The contents of II) are repeated until both become zero, and when they become zero, the DMA data transfer operation is terminated.
なお、第3図において、中間バッファ18はDMA装置
13のブロック内に示されているが、外部に独立して設
けるようにしてもよい。この場合には、従来のDMA回
路を殆んど変更せずに使用することができる。これは、
中間バッファ18を、データqバスに結合可能にし、別
にメモリ内DMAデータ転送モードを表示する信号を作
成17て、その結合を制御すればよい。また、リード/
ライト信号は、制御部19がメモリ11に対し7て出力
するリード/ライト信号(R/W)を制御バスから取り
出し、反転して使用すればよい。Although the intermediate buffer 18 is shown in the block of the DMA device 13 in FIG. 3, it may be provided independently outside. In this case, conventional DMA circuits can be used with little modification. this is,
The intermediate buffer 18 may be coupled to the data q bus, and a signal indicating the in-memory DMA data transfer mode may be created 17 to control the coupling. Also, lead/
As the write signal, a read/write signal (R/W) output from the control section 19 to the memory 11 may be taken out from the control bus, inverted, and used.
(6)発明の効果
本発明の方式によれば、従来不可能であった同一メモリ
内でのDMAデータ転送が、僅かなハードウェアの付加
により、容易に実現することができ、計算機システムの
処理効率の改善に大きな効果が得られる。(6) Effects of the Invention According to the method of the present invention, DMA data transfer within the same memory, which was previously impossible, can be easily achieved with the addition of a small amount of hardware, and the computer system processing This can have a significant effect on improving efficiency.
IDI図は本発明の概念説明図、第2図は本発明実施例
の概略構成図、第3図は本発明実施例の詳細な構成図で
ある。
図において、1はメモリ、2はDMA装置のDMAチャ
ネル!要素、3はDMAアドレスeカウンタL 4はバ
イト・カウント・レジスタ1,5はDMAチャネル■要
素、6はDMAアドレス参カウンタ「、7はバイトのカ
ウント−レジスタz18はマルチプレクサ、9は中間バ
ッファ、1oFiデータ・バスを示す。
特許出願人富士通株式会社The IDI diagram is a conceptual explanatory diagram of the present invention, FIG. 2 is a schematic configuration diagram of an embodiment of the present invention, and FIG. 3 is a detailed diagram of the configuration of an embodiment of the present invention. In the figure, 1 is the memory and 2 is the DMA channel of the DMA device! element, 3 is DMA address e counter L 4 is byte count register 1, 5 is DMA channel element, 6 is DMA address reference counter ', 7 is byte count - register z18 is multiplexer, 9 is intermediate buffer, 1oFi The data bus is shown. Patent applicant Fujitsu Limited
Claims (1)
Iおよび第■のDMAチャネルを有するDMA制御回路
と、中間バッファとを備え、上記メモリ内の異なる2つ
の領域間でのデータ転送を上記第■のDMAチャネルを
用いてメモリから中間バッファにDMAデータ転送する
動作と、上記第…のDMAチャネルを用いて中間バッフ
ァからメモリにDMAデータ転送を行なう動作との組合
せにより実行することを特徴とする同一メモリ内でのD
MAデータ転送方式。1! t) In the 4m system, memo! 7. ! :, #!
The device includes a DMA control circuit having I and II-th DMA channels, and an intermediate buffer, and transfers data between two different areas in the memory by using the II-th DMA channel to transfer DMA data from the memory to the intermediate buffer. DMA data transfer within the same memory is performed by a combination of an operation of transferring data and an operation of transferring DMA data from the intermediate buffer to the memory using the above-mentioned first DMA channel.
MA data transfer method.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP21550181A JPS58115677A (en) | 1981-12-28 | 1981-12-28 | Dma data transfer system for transfer in the same memory |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP21550181A JPS58115677A (en) | 1981-12-28 | 1981-12-28 | Dma data transfer system for transfer in the same memory |
Publications (1)
Publication Number | Publication Date |
---|---|
JPS58115677A true JPS58115677A (en) | 1983-07-09 |
Family
ID=16673434
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP21550181A Pending JPS58115677A (en) | 1981-12-28 | 1981-12-28 | Dma data transfer system for transfer in the same memory |
Country Status (1)
Country | Link |
---|---|
JP (1) | JPS58115677A (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS61269760A (en) * | 1985-05-24 | 1986-11-29 | Fujitsu Ltd | Direct memory access control system |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS5180135A (en) * | 1975-01-10 | 1976-07-13 | Tokyo Shibaura Electric Co | |
JPS5587359A (en) * | 1978-12-25 | 1980-07-02 | Fujitsu Ltd | Information transfer device |
JPS55150032A (en) * | 1979-05-14 | 1980-11-21 | Fujitsu Ltd | Data transfer system |
-
1981
- 1981-12-28 JP JP21550181A patent/JPS58115677A/en active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS5180135A (en) * | 1975-01-10 | 1976-07-13 | Tokyo Shibaura Electric Co | |
JPS5587359A (en) * | 1978-12-25 | 1980-07-02 | Fujitsu Ltd | Information transfer device |
JPS55150032A (en) * | 1979-05-14 | 1980-11-21 | Fujitsu Ltd | Data transfer system |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS61269760A (en) * | 1985-05-24 | 1986-11-29 | Fujitsu Ltd | Direct memory access control system |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JPH1196072A (en) | Memory access control circuit | |
JPH01224857A (en) | Data transfer control system | |
JPS58115677A (en) | Dma data transfer system for transfer in the same memory | |
JPS61217858A (en) | Data transmitting device | |
JPS607529A (en) | Buffer memory device | |
JP3201439B2 (en) | Direct memory access control circuit | |
JP2699482B2 (en) | Data transfer control device | |
JPH0222748A (en) | Non-volatile memory control circuit | |
JP3266610B2 (en) | DMA transfer method | |
JPH0370816B2 (en) | ||
JPS6217879Y2 (en) | ||
JPS6145343A (en) | Swapping control system | |
JPS61161560A (en) | Memory device | |
JPH10254817A (en) | Dma transfer control system | |
JPS63217460A (en) | Buffer control circuit | |
JPH01250163A (en) | Bus controller | |
JPS6086635A (en) | Main storage control device | |
JPS61262870A (en) | Bus controlling system | |
JPH0330899B2 (en) | ||
JPH07120309B2 (en) | Page data transfer control method between storage devices | |
JPH02307149A (en) | Direct memory access control system | |
JPH03167648A (en) | Direct memory access controller | |
JPS58101358A (en) | Memory controlling system | |
JPS6324349A (en) | Memory access device | |
JPS6325717A (en) | Data transfer circuit |