USRE31153E - Mass memory access method and apparatus - Google Patents

Mass memory access method and apparatus Download PDF

Info

Publication number
USRE31153E
USRE31153E US06/183,352 US18335280A USRE31153E US RE31153 E USRE31153 E US RE31153E US 18335280 A US18335280 A US 18335280A US RE31153 E USRE31153 E US RE31153E
Authority
US
United States
Prior art keywords
loop
data
memory
random access
counter
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 - Lifetime
Application number
US06/183,352
Inventor
Richard W. Caddell
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Kearney and Trecker Corp
Original Assignee
Kearney and Trecker Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Priority claimed from US06/016,149 external-priority patent/US4198699A/en
Application filed by Kearney and Trecker Corp filed Critical Kearney and Trecker Corp
Priority to US06/183,352 priority Critical patent/USRE31153E/en
Application granted granted Critical
Publication of USRE31153E publication Critical patent/USRE31153E/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/007Digital input from or digital output to memories of the shift register type
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F5/00Methods or arrangements for data conversion without changing the order or content of the data handled
    • G06F5/06Methods or arrangements for data conversion without changing the order or content of the data handled for changing the speed of data flow, i.e. speed regularising or timing, e.g. delay lines, FIFO buffers; over- or underrun control therefor

Definitions

  • Mass memories contain a plurality of loops or tracks which are each composed of a closed sequence of memory cells. Each memory cell contains one bit of binary data.
  • the cells of each loop circulate one at a time past a corresponding read/write device which either outputs data from the memory cells or inputs data to the memory cells.
  • Each cell is identified by an address that specifies its place in the loop sequence starting from a reference cell.
  • a loop position counter is set at zero when the reference cell is at the read/write device and the loop counter is advanced by one count each time a new memory cell is moved into operative relationship with the read/write device.
  • the loop position counter contains the same number of steps in its counting cycle as there are memory cells in the memory loop. Thus, the number that is in the loop position counter at any time is the address of the memory cell that is in operative relationship with the read/write device at the same time.
  • the latency time The time delay from the moment that the desired loop and cell number are specified to the time when the desired cell moves into operative relationship with the read/write device.
  • the latency time for any given memory cell can range from zero, if the desired cell is in operative relation with the read/write device immediately after the desired cell is specified, to the time that it takes a cell to circulate completely around the loop.
  • the principle object of this invention is to provide a mass memory access method and apparatus which completly eliminates latency time and makes it possible to transfer digital data into and out of a mass memory without waiting for the desired cell to circulate into operative relationship the read/write device.
  • the first step in the transfer of data between a mass memory and a random access memory is to select the desired loop in the mass memory.
  • the address counter of the random access memory is set to the same state as the loop position counter of the mass memory regardless of whether or not the desired memory cell is in operative relationship with the read/write device.
  • the transfer of data between the mass memory and the random access memory commences immediately, the loop position counter and random access address being advanced by one count each time a new memory cell moves into operative relationship with the read/write device of the mass memory.
  • the data transfer process is terminated. At that time, all of the data in the loop will have been transferred into the random access memory, or the loop will have been filled with data from the random access memory.
  • the random access address counter has the same number of steps in its counting cycle as the loop position counter of the mass memory. Therefore, there will always be a one-to-one correspondence between the addresses of data in the mass memory and in the random access memory.
  • the apparatus of this invention includes a transfer counter which has the same number of steps in its counting cycle as the number of memory cells in each loop of the mass memory.
  • the transfer counter is set to zero at the start of the data transfer operation and is advanced by one step each time a bit of data is transferred between the mass memory and the random access memory. When the transfer counter reaches the end of its count, the data transfer process is terminated.
  • FIG. 1 is a block diagram of a first embodiment of the invention
  • FIG. 2 is a block diagram of a second embodiment of the invention.
  • FIG. 3 is a flow chart of the read sequence and write sequence for the embodiments of FIGS. 1 and 2.
  • a general purpose digital computer 10 has at least one random access memory (RAM) 12 along with a RAM address counter 14, a transfer counter 16, control circuits 18, and a control program 20.
  • Computer 10 can be any suitable general purpose digital computer such as the PDP-8E computer manufactured by the Digital Equipment Corporation of Maynard, Mass.
  • Computer 10 includes suitable input/output (I/O) circuits 22 which connect the various computer circuits with peripheral devices (not shown) and with the data transfer apparatus of this invention.
  • I/O input/output
  • data is transferred between RAM 12 and a mass memory 24 which can be magnetic disc memory, charge coupled device memory, magnetic bubble memory, or any other suitable mass memory which has a plurality of memory loops which each contain a closed sequence of memory cells.
  • each loop of mass memory 24 has 256 memory cells which are numbered in sequence from 0 to 255. Any desired loop can be selected by applying a digital number which signifies the desired loop to a LOOP SELECT input of mass memory 24.
  • the memory cells of the selected loop are circulated past the read/write device therefor (not shown) in response to clock signals applied to an ADVANCE LOOP CLOCK input.
  • the clock signals applied to the ADVANCE LOOP CLOCK input are also applied to a loop position counter 26 so as to advance counter 26 by one count each time a new memory cell is advanced into operative relationship with the read/write device for the selected loop.
  • Loop position counter 26 has the same number of steps in its counting cycle as there are memory cells in the memory loops. Loop position counter 26 is set to zero when memory cell number zero is at the read/write device. Therefore the state of loop position counter 26 at any given time corresponds to the address of the memory cell which is in operative relationship with the read/write device.
  • Mass memory 24 also has a WRITE CLOCK, WRITE ENABLE, READ ENABLE, and DATA IN input and a DATA OUT output. These functions are well-known and will not be described further.
  • the arrows beside the ADVANCE LOOP CLOCK, WRITE CLOCK and LOOP POSITION COUNTER inputs signify that the circuit is triggered by the rising edge of the clock pulse, i.e. the 0 to 1 transition.
  • the conductors which are coupled between computer 10 and the apparatus of this invention include a DATA BUS OUT 28, which consists of a plurality of conductors (one for each bit of data, DATA BUS IN 30, also a plurality of conductors, an ADDRESS BUS 32, another plurality of conductors, a READ conductor 34, a WRITE conductor 36, and a READY conductor 38.
  • the ADDRESS BUS conductors 32 are coupled to an address decoder circuit 40 which receives a two bit address word from computer 10 and decodes the address word to produce one of three output signals: LOOP, DATA and POSITION.
  • LOOP address which signifies LOOP
  • DATA DATA
  • POSITION POSITION
  • the address which signifies LOOP is applied to ADDRESS BUS 32 by control program 20.
  • the resulting LOOP signal is applied to AND gate 42 which also receives a WRITE signal input and a CLOCK input.
  • LOOP, WRITE and CLOCK are simultaneously in the high state, the output of gate 42 goes high and clocks the input of a latch 44 which is coupled between the DATA BUS OUT 28 and the LOOP SELECT input of mass memory 24.
  • latch 44 is clocked it applies the loop number which is then present on DATA BUS OUT 28 to the LOOP SELECT input.
  • the POSITION signal output of decoder 40 is applied to AND gate 46 which also receives a READ signal input.
  • AND gate 46 When POSITION and READ are simultaneously high, the output of AND gate 46 enables a set of tri-state transmission gates 48, only one of which is shown in FIG. 1.
  • gates 48 When gates 48 are enabled, the state of loop position counter 26 is applied to DATA BUS IN 30. This number is utilized by control program 20 to set RAM address counter 14 to the same state as loop position counter 26. RAM address counter 14 has the same number of steps in its counting cycle as loop position counter 26.
  • the DATA output signal of address decoder 40 is applied to AND gates 50 and 52, which also receives READ and WRITE inputs, respectively.
  • the output of gate 50 is coupled to the READ ENABLE input of mass memory 24 and the output of gate 52 is coupled to the WRITE ENABLE thereof.
  • the DATA and READ signals are also applied to AND gate 54 whose output is coupled to the enable input of a set of tri-state transmission gates 56, only one of which is shown in FIG. 1.
  • gates 56 When gates 56 are enabled, they couple the DATA OUT of mass memory 24 to the DATA BUS IN conductors 30 for transmission to computer 10.
  • the addresses for the LOOP, DATA and POSITION signals and the READ and WRITE signals are generated by computer control circuits 18.
  • FIG. 1 is clocked by a conventional clock circuit 58 whose output is coupled to the WRITE CLOCK input of mass memory 24 and is coupled via inverter 60 to the ADVANCE LOOP CLOCK input thereof.
  • the output of clock 58 is also applied to the trigger input of a one-shot multivibrator 62.
  • One-shot multivibrator 62 is enabled by the output of AND gate 64.
  • One input of AND gate 64 is coupled to the output of OR gate 66, which receives READ and WRITE inputs from conductors 34 and 36, and the other input of AND gate 64 is coupled to the output of OR gate 68, which receives DATA, POSITION and LOOP input signals.
  • the output of one-shot multivibrator 62 is applied through inverter 70 to READY conductor 38.
  • Increment transfer counter 16 which has the same number of steps in its counting cycle as loop position counter 26 and RAM address counter 14.
  • step 22 If transfer counter 16 has not overflowed, go to step 11. If transfer counter 16 has overflowed, go to step 23.
  • step 19 If transfer counter 16 has not overflowed, go to step 11. If transfer counter 16 has overflowed, go to step 20.
  • the foregoing sequences are implemented by a combination of hardware and software, the hardware being the gates, counter, latch, decoder and one-shot multivibrator shown in FIG. 1, and the software being included in control program 20.
  • steps 1 to 4, 7 and 8 are included in control program 20.
  • steps 1 to 4, 7, 8, 10 to 13, 16, 17 and 19 to 23 are included in control program 20.
  • steps 1 to 4, 7, 8, 10 to 13 and 17 to 20 are included in control program 20.
  • the timing of the data transfer operation is controlled by clock 58. This works well if the clock for computer 10 is close to the frequency of clock 58, but if the computer's clock is slower than clock 58 it can lose synch, and if the computer's clock is faster than clock 58, the computer will be waiting part of the time. In these cases, it is better to utilize the modified timing circuit illustrated in FIG. 2.
  • the output of clock 58 is coupled to one input of a two-to-one multiplexer 72 whose other input is coupled to the output of AND gate 64.
  • the switching of multiplexer 72 is controlled by a D type flip-flop 74 whose Q output is coupled to the S input of multiplexer 72.
  • Flip-flop 74 is clocked by clock 58 and has its D and CLEAR inputs coupled to the output of retriggerable one-shot multivibrator 76 through an inverter 78.
  • the trigger input of retriggerable one-shot multivibrator 76 is coupled to the output of one-shot multivibrator 72.
  • RW STROBE substitutes the output of gate 64
  • the time period of retriggerable one-shot multivibrator 76 is longer than the time lapse between transfer of individual bits of data from the selected loop.
  • retriggerable one-shot multivibrator 76 will time out and reset flip-flop 74, thus switching clock 58 back in the circuit.
  • the only timing restraint on the asynchronous embodiment of FIG. 2 is that READ line 34 and WRITE line 36 stay high and low for the minimum high and low time of mass memory 24 and that retriggerable one-shot multivibrator 76 times out before the maximum refresh period of mass memory 24.
  • I/O 22 can be a DKCB-AA (option board #1) Module No. M8360 which has 12 bits of data input (D IN) and 12 bits of data output (D OUT).
  • D IN data input
  • D OUT data output
  • RAM 12 has the same capacity as the loops of mass memory 24. However, the capacity of RAM 12 can be larger than that of mass memory 24 if desired.
  • a base register is appended to RAM address counter 14 to provide a larger address. For example, suppose data from a 256 position mass memory loop is to be transferred to 256 locations in a 65,536 location RAM, startin at location (1000) 16 and ending at location (10FF) 16 .
  • an eight bit base register is appended to eight bit RAM address counter 14 to provide a sixteen bit address. By changing the base address, the data from mass memory 24 can be transferred to any desired 256 location block of RAM 12.
  • Another advantage of this method is that interleaving data to keep latency to a minimum when transferring more than one loop is not necessary.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Dram (AREA)

Abstract

A method and apparatus for transferring digital data between a mass memory and a random access memory. The mass memory has a plurality of memory loops, each having a plurality of memory cells, and a read/write device which either outputs data from the memory cells or inputs data to the memory cells. Each memory cell is identified by an address that specifies its place in the loop sequence starting from a reference cell. A loop position counter is set at zero when the reference cell of the selected memory loop is at the read/write device. The loop position counter is advanced by one count each time the next memory cell in the sequence is moved into operative relationship with the read/write device. Transfer of data between the mass memory and the random access memory is accomplished without any delay under the control of a random access memory address counter which is synchronized with the loop position counter. A transfer counter terminates the data transfer when an entire data loop has been transferred into or out of the mass memory. Since the loop position counter and random access memory address counter are synchronized, the transferred data will be written into the correct memory cells in either memory regardless of which mass memory cell is in operative relationship with the read/write device at the time the data transfer is initiated. Thus, this invention eliminates latency time in the transfer of data between a mass memory and a random access memory.

Description

BACKGROUND OF THE INVENTION
This invention relates to a method and apparatus for transferring digital data between a mass memory, such as a magnetic disc, charge coupled device, or magnetic bubble memory, and a random access memory. Mass memories contain a plurality of loops or tracks which are each composed of a closed sequence of memory cells. Each memory cell contains one bit of binary data. The cells of each loop circulate one at a time past a corresponding read/write device which either outputs data from the memory cells or inputs data to the memory cells. Each cell is identified by an address that specifies its place in the loop sequence starting from a reference cell. A loop position counter is set at zero when the reference cell is at the read/write device and the loop counter is advanced by one count each time a new memory cell is moved into operative relationship with the read/write device. The loop position counter contains the same number of steps in its counting cycle as there are memory cells in the memory loop. Thus, the number that is in the loop position counter at any time is the address of the memory cell that is in operative relationship with the read/write device at the same time.
In the past, to read data from the mass memory or write data into the mass memory, it was necessary to specify the desired loop and cell number (or numbers) and then to wait until the specified cell or cells moved into operative relationship with the read/write device. The time delay from the moment that the desired loop and cell number are specified to the time when the desired cell moves into operative relationship with the read/write device is called the latency time. The latency time for any given memory cell can range from zero, if the desired cell is in operative relation with the read/write device immediately after the desired cell is specified, to the time that it takes a cell to circulate completely around the loop.
The principle object of this invention is to provide a mass memory access method and apparatus which completly eliminates latency time and makes it possible to transfer digital data into and out of a mass memory without waiting for the desired cell to circulate into operative relationship the read/write device.
SUMMARY OF THE INVENTION
In accordance with this invention, the first step in the transfer of data between a mass memory and a random access memory is to select the desired loop in the mass memory. Next, the address counter of the random access memory is set to the same state as the loop position counter of the mass memory regardless of whether or not the desired memory cell is in operative relationship with the read/write device. Then, the transfer of data between the mass memory and the random access memory commences immediately, the loop position counter and random access address being advanced by one count each time a new memory cell moves into operative relationship with the read/write device of the mass memory. When the entire loop has circulated past the read/write device, the data transfer process is terminated. At that time, all of the data in the loop will have been transferred into the random access memory, or the loop will have been filled with data from the random access memory.
In the apparatus of this invention, the random access address counter has the same number of steps in its counting cycle as the loop position counter of the mass memory. Therefore, there will always be a one-to-one correspondence between the addresses of data in the mass memory and in the random access memory.
The apparatus of this invention includes a transfer counter which has the same number of steps in its counting cycle as the number of memory cells in each loop of the mass memory. The transfer counter is set to zero at the start of the data transfer operation and is advanced by one step each time a bit of data is transferred between the mass memory and the random access memory. When the transfer counter reaches the end of its count, the data transfer process is terminated.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of a first embodiment of the invention;
FIG. 2 is a block diagram of a second embodiment of the invention; and
FIG. 3 is a flow chart of the read sequence and write sequence for the embodiments of FIGS. 1 and 2.
DETAILED DESCRIPTION OF THE INVENTION
Referring to FIG. 1, a general purpose digital computer 10 has at least one random access memory (RAM) 12 along with a RAM address counter 14, a transfer counter 16, control circuits 18, and a control program 20. Computer 10 can be any suitable general purpose digital computer such as the PDP-8E computer manufactured by the Digital Equipment Corporation of Maynard, Mass. Computer 10 includes suitable input/output (I/O) circuits 22 which connect the various computer circuits with peripheral devices (not shown) and with the data transfer apparatus of this invention.
In this embodiment of the invention, data is transferred between RAM 12 and a mass memory 24 which can be magnetic disc memory, charge coupled device memory, magnetic bubble memory, or any other suitable mass memory which has a plurality of memory loops which each contain a closed sequence of memory cells. In this particular example, each loop of mass memory 24 has 256 memory cells which are numbered in sequence from 0 to 255. Any desired loop can be selected by applying a digital number which signifies the desired loop to a LOOP SELECT input of mass memory 24. The memory cells of the selected loop are circulated past the read/write device therefor (not shown) in response to clock signals applied to an ADVANCE LOOP CLOCK input. The clock signals applied to the ADVANCE LOOP CLOCK input are also applied to a loop position counter 26 so as to advance counter 26 by one count each time a new memory cell is advanced into operative relationship with the read/write device for the selected loop. Loop position counter 26 has the same number of steps in its counting cycle as there are memory cells in the memory loops. Loop position counter 26 is set to zero when memory cell number zero is at the read/write device. Therefore the state of loop position counter 26 at any given time corresponds to the address of the memory cell which is in operative relationship with the read/write device.
Mass memory 24 also has a WRITE CLOCK, WRITE ENABLE, READ ENABLE, and DATA IN input and a DATA OUT output. These functions are well-known and will not be described further.
The arrows beside the ADVANCE LOOP CLOCK, WRITE CLOCK and LOOP POSITION COUNTER inputs signify that the circuit is triggered by the rising edge of the clock pulse, i.e. the 0 to 1 transition.
The conductors which are coupled between computer 10 and the apparatus of this invention include a DATA BUS OUT 28, which consists of a plurality of conductors (one for each bit of data, DATA BUS IN 30, also a plurality of conductors, an ADDRESS BUS 32, another plurality of conductors, a READ conductor 34, a WRITE conductor 36, and a READY conductor 38.
The ADDRESS BUS conductors 32 are coupled to an address decoder circuit 40 which receives a two bit address word from computer 10 and decodes the address word to produce one of three output signals: LOOP, DATA and POSITION. When a loop is to be selected in mass memory 24, the address which signifies LOOP is applied to ADDRESS BUS 32 by control program 20. The resulting LOOP signal is applied to AND gate 42 which also receives a WRITE signal input and a CLOCK input. When LOOP, WRITE and CLOCK are simultaneously in the high state, the output of gate 42 goes high and clocks the input of a latch 44 which is coupled between the DATA BUS OUT 28 and the LOOP SELECT input of mass memory 24. When latch 44 is clocked it applies the loop number which is then present on DATA BUS OUT 28 to the LOOP SELECT input.
The POSITION signal output of decoder 40 is applied to AND gate 46 which also receives a READ signal input. When POSITION and READ are simultaneously high, the output of AND gate 46 enables a set of tri-state transmission gates 48, only one of which is shown in FIG. 1. When gates 48 are enabled, the state of loop position counter 26 is applied to DATA BUS IN 30. This number is utilized by control program 20 to set RAM address counter 14 to the same state as loop position counter 26. RAM address counter 14 has the same number of steps in its counting cycle as loop position counter 26.
The DATA output signal of address decoder 40 is applied to AND gates 50 and 52, which also receives READ and WRITE inputs, respectively. The output of gate 50 is coupled to the READ ENABLE input of mass memory 24 and the output of gate 52 is coupled to the WRITE ENABLE thereof.
The DATA and READ signals are also applied to AND gate 54 whose output is coupled to the enable input of a set of tri-state transmission gates 56, only one of which is shown in FIG. 1. When gates 56 are enabled, they couple the DATA OUT of mass memory 24 to the DATA BUS IN conductors 30 for transmission to computer 10.
The addresses for the LOOP, DATA and POSITION signals and the READ and WRITE signals are generated by computer control circuits 18.
The embodiments of FIG. 1 is clocked by a conventional clock circuit 58 whose output is coupled to the WRITE CLOCK input of mass memory 24 and is coupled via inverter 60 to the ADVANCE LOOP CLOCK input thereof. The output of clock 58 is also applied to the trigger input of a one-shot multivibrator 62.
One-shot multivibrator 62 is enabled by the output of AND gate 64. One input of AND gate 64 is coupled to the output of OR gate 66, which receives READ and WRITE inputs from conductors 34 and 36, and the other input of AND gate 64 is coupled to the output of OR gate 68, which receives DATA, POSITION and LOOP input signals. The output of one-shot multivibrator 62 is applied through inverter 70 to READY conductor 38.
The operation of this embodiment of the invention will be explained by detailing the sequence of operation required to select a loop in mass memory 24, to transfer data from the selected loop to RAM 12, and to transfer data from RAM 12 to the selected loop. The loop selection sequence in as follows:
1. Put the loop number to be selected on the DATA BUS OUT 28.
2. Put the LOOP strobe address on ADDRESS BUS 32.
3. Put WRITE line 36 high.
4. Wait for READY line 38 to go low.
5. Clock the loop number on DATA BUS OUT 28 into loop select latch 44.
6. On the next high transition of the clock, send the READY pulse.
7. Put WRITE line 36 low.
8. Done.
The sequence for transferring data from mass memory 24 to RAM 12 is as follows:
1. Reset transfer counter 16.
2. Put the POSITION strobe address on ADDRESS BUS 32.
3. Put READ line 34 high.
4. Wait for READY line 38 to go low.
5. Put the loop position counter number on DATA BUS IN 30.
6. On next high transition of the clock, send READY pulse.
7. Input the loop position number from DATA BUS IN 30.
8. Put READ line 34 low.
9. Take loop position number off DATA BUS IN 30.
10. Set RAM address counter 14 equal to the loop position number.
1. Put DATA strobe address on ADDRESS BUS 32.
12. Put READ line 34 high.
13. Wait for READY line 38 to go low.
14. Put loop data on DATA BUS IN 30.
15. On next high transition of the clock send READY pulse.
16. Input loop data from DATA IN BUS 30.
17. Put READ line 34 low.
18. Take loop data off DATA BUS IN 30.
19. Write loop data into RAM 12 at current address of RAM address counter 14.
20. Increment RAM address counter 14.
21. Increment transfer counter 16, which has the same number of steps in its counting cycle as loop position counter 26 and RAM address counter 14.
22. If transfer counter 16 has not overflowed, go to step 11. If transfer counter 16 has overflowed, go to step 23.
23. Done.
The sequence for transferring data from RAM 12 to mass memory 24 is as follows:
1. Reset transfer counter 16.
2. Put the POSITION strobe address on ADDRESS BUS 32.
3. Put READ line 34 high.
4. Wait for READY line 38 to go low.
5. Put the loop position number on DATA BUS IN 30.
6. On next high transition of the clock, send READY pulse,
7. Input the loop position number from DATA BUS IN 30.
8. Put READ line 34 low.
9. Take the loop position number off DATA BUS IN 30.
10. Set RAM address counter 14 equal to the loop position number.
11. Read data from RAM 12 at address of RAM address counter 14.
12. Put RAM data read in step 11 on DATA BUS OUT 28.
13. Put DATA strobe address on ADDRESS BUS 32.
14. Put WRITE line 36 high.
15. Wait for READY line 38 to go low.
16. On the next high transition of the clock, write RAM data on DATA BUS OUT 28 into loop and send READY pulse on line 38.
17. Increment RAM address counter 14.
18. Increment transfer counter 16.
19. If transfer counter 16 has not overflowed, go to step 11. If transfer counter 16 has overflowed, go to step 20.
20. Done.
In the embodiment of FIG. 1, the foregoing sequences are implemented by a combination of hardware and software, the hardware being the gates, counter, latch, decoder and one-shot multivibrator shown in FIG. 1, and the software being included in control program 20. In the loop selection sequence, steps 1 to 4, 7 and 8 are included in control program 20. In the transfer of data from mass memory 24 to RAM 12, steps 1 to 4, 7, 8, 10 to 13, 16, 17 and 19 to 23 are included in control program 20. In the transfer of data from RAM 12 to mass memory 24, steps 1 to 4, 7, 8, 10 to 13 and 17 to 20 are included in control program 20. Flow charts for the steps which constitute part of control program 20 are shown in FIG. 3 and can be written in machine language for the PDP-8E computer with reference to the PDP-8 handbook entitled: "INTRODUCTION TO PROGRAMMING", published by the Digital Equipment Corporation of Maynard, Mass., in May, 1972. The entire contents of the above-noted handbook are hereby incorporated herein by reference.
In the embodiment of FIG. 1, the timing of the data transfer operation is controlled by clock 58. This works well if the clock for computer 10 is close to the frequency of clock 58, but if the computer's clock is slower than clock 58 it can lose synch, and if the computer's clock is faster than clock 58, the computer will be waiting part of the time. In these cases, it is better to utilize the modified timing circuit illustrated in FIG. 2.
Referring to FIG. 2, the output of clock 58 is coupled to one input of a two-to-one multiplexer 72 whose other input is coupled to the output of AND gate 64. In the S=1 state of multiplexer 72, the output of clock 58 appears on the output thereof, while in the S=0 state of multiplexer 72, the output of gate 64 (called the RW STROBE) appears on the output of multiplexer 72. The switching of multiplexer 72 is controlled by a D type flip-flop 74 whose Q output is coupled to the S input of multiplexer 72. Flip-flop 74 is clocked by clock 58 and has its D and CLEAR inputs coupled to the output of retriggerable one-shot multivibrator 76 through an inverter 78. The trigger input of retriggerable one-shot multivibrator 76 is coupled to the output of one-shot multivibrator 72.
When there is no data transfer in progress, flip-flop 74 is set and multiplexer 72 is in the S=1 state which couples the output of clock 58 to mass memory 24, loop position counter 26, and one-shot multivibrator 62. When one-shot multivibrator 62 is triggered, it triggers one-shot multivibrator 76 which resets flip-flop 74 and switches multiplexer 72 to the S=0 condition, which substitutes the output of gate 64 (RW STROBE) for clock 58. As long as the data transfers occur often enough to keep retriggerable one-shot multivibrator 76 fired, mass memory 24 will stay in synch with computer 10. The time period of retriggerable one-shot multivibrator 76 is longer than the time lapse between transfer of individual bits of data from the selected loop. When the data transfer operation is terminated, retriggerable one-shot multivibrator 76 will time out and reset flip-flop 74, thus switching clock 58 back in the circuit.
The only timing restraint on the asynchronous embodiment of FIG. 2 is that READ line 34 and WRITE line 36 stay high and low for the minimum high and low time of mass memory 24 and that retriggerable one-shot multivibrator 76 times out before the maximum refresh period of mass memory 24.
When a Digital Equipment Corporation PDP-8E is used for computer 10, I/O 22 can be a DKCB-AA (option board #1) Module No. M8360 which has 12 bits of data input (D IN) and 12 bits of data output (D OUT). The following assignments are made for the 12 bits of data input: bit 0=READY, bits 1 to 3=SPARE, and bits 4 to 11=DATA BUS IN. The following assignments are made for the 12 bits of data output: Bit 0=READ, bit 1=WRITE, bits 2 and 3=ADDRESS, and bits 4 to 11=DATA BUS OUT.
Although the foregoing description describes data transfers involving a single memory loop in mass memory 24, it will be obvious to those skilled in the art that memory loops can be put in parallel for different word sizes. For example, with the PDP-8E data in and data out bit assignments noted above, eight loops could be paralleled to provide an eight bit word, every transfer to be written into or read out of 256 by eight bit RAM.
In the foregoing description, RAM 12 has the same capacity as the loops of mass memory 24. However, the capacity of RAM 12 can be larger than that of mass memory 24 if desired. In this case, a base register is appended to RAM address counter 14 to provide a larger address. For example, suppose data from a 256 position mass memory loop is to be transferred to 256 locations in a 65,536 location RAM, startin at location (1000)16 and ending at location (10FF)16. For this purpose an eight bit base register is appended to eight bit RAM address counter 14 to provide a sixteen bit address. By changing the base address, the data from mass memory 24 can be transferred to any desired 256 location block of RAM 12. Another advantage of this method is that interleaving data to keep latency to a minimum when transferring more than one loop is not necessary.
Although the illustrative embodiments of the invention have been described in considerable detail for the purpose of fully disclosing a practical operative structure incorporating the invention, it is be understood that the particular apparatus shown and described is intended to be illustrative only and that the various novel features of the invention may be incorporated in other structural forms without departing from the spirit and scope of the invention as defined in the sub-joined claims.

Claims (3)

The principles of this invention having now been fully explained in connection with the foregoing, I hereby claim as my invention:
1. A method of transferring digital data between a mass memory having a plurality of storage loops and having a loop position counter associated therewith and a random access memory having an address counter associated therewith, each of said storage loops having a capacity to store N bits of digital data, and both of said counters having N steps in their counting cycle, said method comprising the steps of:
(A) selecting at least one storage loop in said mass memory which contains the data to be transferred to said random access memory or which is the destination for data to be transferred from said random access memory;
(B) setting said random access address counter to the same state as said loop position counter regardless of which step said loop position counter is at in its counting cycle;
(C) transferring the bit of digital data which corresponds to the current state of both counters from one memory to the other;
(D) advancing both counters by one step in their counting cycle; and
(E) repeating steps (C) and (D) until N bits of digital data have been transferred from one memory to the other. .[.2. Apparatus for transferring digital data between a mass memory having a plurality of storage loops and having a loop position counter associated therewith and a random access memory having an address counter associated therewith, each of said storage loops having a capacity to store N bits of digital data, and both of said counters having N steps in their counting cycle, said apparatus comprising:
a transfer counter having N steps in its counting cycle;
a clock coupled to the clock input of said mass memory and to said loop position counter;
means for generating a READ signal indicating that data is to be read out of said mass memory;
means for generating a WRITE signal indicating that data is to be written into said mass memory;
means for generating a LOOP signal indicating that a loop is to be selected in said mass memory;
means for generating a DATA signal indicating that data is to be transferred between said mass memory and said random access memory;
means for generating a POSITION signal indicating that the output of said loop position counter is to be read;
a one-shot multivibrator having an enable input and a trigger input and an output; and
means for applying a trigger input to said one-shot multivibrator when one of said READ or WRITE signals is true and one of said DATA, LOOP or
POSITION signals is true..]. .[.3. The apparatus according to claim 2 wherein said mass memory has a READ ENABLE input and a WRITE ENABLE input, and also comprising:
means for triggering said READ ENABLE input when said READ and said DATA signals are ture; and
means for triggering said WRITE ENABLE input when said WRITE and said DATA signals are true..]. .[.4. The apparatus according to claim 2 and also comprising:
a two-to-one multiplexer having two signal inputs;
a control input and an output, the output of said multiplexer being coupled to the clock input of said mass memory, one signal input of said multiplexer being coupled to the output of said clock, said trigger input of said one-shot multivibrator being coupled to the other signal input of said multiplexer, and the output of said one-shot multivibrator being coupled to the control input of said multiplexer..]. .Iadd. 5. Apparatus for transferring digital data between a mass memory having a plurality of storage loops, with each storage loop having "N" cells each accepting a data bit; and
having a loop position counter for indicating which cell in said loop is operative to receive or transmit data; and
a random access memory having an address counter therewith having "N" steps in the counting cycle, said apparatus comprising:
a transfer counter means having "N" counting steps in its counting cycle;
first circuit means coupled to said random access memory and to said mass memory for (a) selecting a unique one of said plurality of mass memory loops, (b) determining the cell position in said selected loop, and (c) indicating the data that is to be transferred between said random access memory and said selected loop of said mass memory;
second circuit means coupled to said transfer counter, to said random access memory address counter, and to said first circuit means for resetting said transfer counter and for adjusting said random access memory address counter in accordance with the loop cell position determined by said first circuit means; and
third circuit means coupled to said first circuit means, to said random access memory, and to said mass memory for repetitively (a) advancing the loop position (b) advancing the count of said transfer counter means, and (c) transferring data between said selected loop of said mass memory and said random access memory each time said first circuit means indicates that data is to be transferred between said random access memory and said mass memory until said transfer counter means overflows. .Iaddend..Iadd. 6. The invention according to claim 5, wherein said first circuit means comprises:
data processing means for producing a two bit address word to initiate loop selection and producing a WRITE command to initiate transfer of data from said random access memory indicative of a desired loop to said mass memory;
address decoder means coupled to said data processing means for decoding said two bit address word to produce a LOOP command to initiate transfer of data stored in said random access memory indicative of said selected loop; and
latch means coupled to said random access memory and responsive to LOOP commands from said data processing means for latching said address
indicative of said selected loop to said mass memory. .Iaddend..Iadd. 7. The apparatus according to claim 6, wherein said data processing means further produces a READ command to initiate transfer of data from said mass memory to said random access memory and to said transfer counter,
wherein said address decoder decodes said two bit address work to produce POSITION command to initiate examination of said loop counter to ascertain loop position, and
wherein said second circuit means comprises a logic circuit for resetting said transfer counter and for adjusting said random access memory address counter in accordance with the count of said loop position counter outputted in response to a POSITION command from said address decoder and a READ command from said data processing means. .Iaddend..Iadd. 8. The apparatus according to claim 7, wherein third circuit means comprises:
a clock coupled to said mass memory for producing an output pulse at periodic intervals;
a logic gate coupled to said data processing apparatus and to said address decoder for producing an output signal in accordance with a predetermined combination of commands from said address decoder and said data processing apparatus; and a one shot multi-vibrator having an enable input coupled to said logic circuit and a trigger input coupled to said clock for supplying an output signal to said data processing apparatus to cause said data processing apparatus to generate subsequent READ and WRITE commands. .Iaddend..Iadd. 9. The apparatus according to claim 8, and also comprising a two to one multiplexer having a first and second signal input, a control input and an output, the output of said multiplexer coupled to the clock input of said mass memory, said first input of said multiplexer coupled to the output of said clock, said trigger input of said one shot multi-vibrator being coupled to the second signal input of said multiplexer and the output of said one shot multi-vibrator being coupled to the control input of said multiplexer. .Iaddend.
US06/183,352 1979-03-01 1980-09-02 Mass memory access method and apparatus Expired - Lifetime USRE31153E (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US06/183,352 USRE31153E (en) 1979-03-01 1980-09-02 Mass memory access method and apparatus

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US06/016,149 US4198699A (en) 1979-03-01 1979-03-01 Mass memory access method and apparatus
US06/183,352 USRE31153E (en) 1979-03-01 1980-09-02 Mass memory access method and apparatus

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US06/016,149 Reissue US4198699A (en) 1979-03-01 1979-03-01 Mass memory access method and apparatus

Publications (1)

Publication Number Publication Date
USRE31153E true USRE31153E (en) 1983-02-15

Family

ID=26688235

Family Applications (1)

Application Number Title Priority Date Filing Date
US06/183,352 Expired - Lifetime USRE31153E (en) 1979-03-01 1980-09-02 Mass memory access method and apparatus

Country Status (1)

Country Link
US (1) USRE31153E (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5537916A (en) * 1995-05-19 1996-07-23 Metalquimia, S.A. Automatic machine for sterilization and aseptic packing of pasteurized meat products
US5745709A (en) * 1994-07-05 1998-04-28 Matsushita Electric Industrial C., Ltd. Data transfer apparatus and system providing high speed switching to allow for high speed data transfer between one device and multiple devices
US5867686A (en) * 1993-11-09 1999-02-02 Conner; Kenneth H. High speed real-time information storage system

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3064241A (en) * 1958-11-10 1962-11-13 Bell Telephone Labor Inc Data storage system
US4130894A (en) * 1977-11-21 1978-12-19 International Business Machines Corporation Loop organized serial-parallel-serial memory storage system
US4156287A (en) * 1976-10-20 1979-05-22 Burroughs Corporation Fast access charge coupled device memory organizations for a semiconductor chip
US4158236A (en) * 1976-09-13 1979-06-12 Lexicon Corporation Electronic dictionary and language interpreter
US4161788A (en) * 1977-04-21 1979-07-17 Texas Instruments Incorporated Bubble memory controller with multipage data handling
US4165541A (en) * 1977-12-12 1979-08-21 Fairchild Camera And Instrument Corporation Serial-parallel-serial charge-coupled device memory having interlacing and ripple clocking of the parallel shift registers

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3064241A (en) * 1958-11-10 1962-11-13 Bell Telephone Labor Inc Data storage system
US4158236A (en) * 1976-09-13 1979-06-12 Lexicon Corporation Electronic dictionary and language interpreter
US4156287A (en) * 1976-10-20 1979-05-22 Burroughs Corporation Fast access charge coupled device memory organizations for a semiconductor chip
US4161788A (en) * 1977-04-21 1979-07-17 Texas Instruments Incorporated Bubble memory controller with multipage data handling
US4130894A (en) * 1977-11-21 1978-12-19 International Business Machines Corporation Loop organized serial-parallel-serial memory storage system
US4165541A (en) * 1977-12-12 1979-08-21 Fairchild Camera And Instrument Corporation Serial-parallel-serial charge-coupled device memory having interlacing and ripple clocking of the parallel shift registers

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5867686A (en) * 1993-11-09 1999-02-02 Conner; Kenneth H. High speed real-time information storage system
US5745709A (en) * 1994-07-05 1998-04-28 Matsushita Electric Industrial C., Ltd. Data transfer apparatus and system providing high speed switching to allow for high speed data transfer between one device and multiple devices
US5537916A (en) * 1995-05-19 1996-07-23 Metalquimia, S.A. Automatic machine for sterilization and aseptic packing of pasteurized meat products

Similar Documents

Publication Publication Date Title
US4156905A (en) Method and apparatus for improving access speed in a random access memory
US4825411A (en) Dual-port memory with asynchronous control of serial data memory transfer
US4099231A (en) Memory control system for transferring selected words in a multiple memory word exchange during one memory cycle
US3470542A (en) Modular system design
US4712190A (en) Self-timed random access memory chip
US4402081A (en) Semiconductor memory test pattern generating apparatus
US4276609A (en) CCD memory retrieval system
EP0218830A2 (en) A memory test apparatus
EP0432575B1 (en) Data processor having wait state control unit
US4586181A (en) Test pattern generating apparatus
GB2026218A (en) Refresh timing in memory system
US4216533A (en) Pattern generator
JPH0784863A (en) Information processor and semiconductor storage device suitable to the same
EP0228332B1 (en) Automatic test system having a "true tester-per-pin" architecture
JPH0731627B2 (en) Memory-device
US3740728A (en) Input/output controller
US3755788A (en) Data recirculator
EP0048810B1 (en) Recirculating loop memory array with a shift register buffer
US5033001A (en) Dual mode memory read cycle time reduction system which generates read data clock signals from shifted and synchronized trigger signals
US3662348A (en) Message assembly and response system
US4198699A (en) Mass memory access method and apparatus
US4218753A (en) Microcode-controlled memory refresh apparatus for a data processing system
USRE31153E (en) Mass memory access method and apparatus
US3564507A (en) Asynchronous interface for use between a main memory and a central processing unit
US3701984A (en) Memory subsystem array