[go: up one dir, main page]

EP1988463A1 - Memory control apparatus and memory control method - Google Patents

Memory control apparatus and memory control method Download PDF

Info

Publication number
EP1988463A1
EP1988463A1 EP06714636A EP06714636A EP1988463A1 EP 1988463 A1 EP1988463 A1 EP 1988463A1 EP 06714636 A EP06714636 A EP 06714636A EP 06714636 A EP06714636 A EP 06714636A EP 1988463 A1 EP1988463 A1 EP 1988463A1
Authority
EP
European Patent Office
Prior art keywords
memory
buffer memory
instruction
security
use packet
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
EP06714636A
Other languages
German (de)
French (fr)
Other versions
EP1988463B1 (en
EP1988463A4 (en
Inventor
Shinichi Iwasaki
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.)
Fujitsu Ltd
Original Assignee
Fujitsu Ltd
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
Application filed by Fujitsu Ltd filed Critical Fujitsu Ltd
Publication of EP1988463A1 publication Critical patent/EP1988463A1/en
Publication of EP1988463A4 publication Critical patent/EP1988463A4/en
Application granted granted Critical
Publication of EP1988463B1 publication Critical patent/EP1988463B1/en
Ceased legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • G06F13/1673Details of memory controller using buffers

Definitions

  • the present invention relates to a technique for transferring data between processing units attaining one function or a plurality thereof and in particular to a memory control apparatus and a memory control method utilizing buffer memory effectively in a system LSI comprising a large number of processing units.
  • a conventional system LSI has a configuration of incorporating, on a single chip, plural pieces of functional blocks, which are configured to achieve one function or a plurality thereof.
  • These functional blocks can be regarded as a single processing unit such as a central processing unit (CPU), memory and a dedicated circuit, and a process progresses in the system LSI by exchanging signals or data between the processing units.
  • Fig. 1 is a diagram showing the configuration of a system LSI.
  • system board 10 SB#0
  • 20 SB#1
  • 30 SB#2
  • the system board 30 comprises plural system controllers 31 (SC#0) and 32 (SC#1).
  • system board 10 SB#0
  • SC#0 system controllers 11
  • SC#1 system controllers 21
  • SC#0 system controllers 21
  • the system controller 31 controls a read from, and a write to, memory (DIMM) 81, 82, 83 or 84 by way of MAC71 (MAC#0), 72 (MAC#1), 73 (MAC#3) or 74 (MAC#4) in accordance with an instruction from a CPU (not shown in a drawing herein) connected to either of plural CPUs 51 (CPU#0), 52 (CPU#1), and so on, or either of plural system controllers 32 (SC#1), 11 (SC#0), 21 (SC#0), and so on.
  • a CPU not shown in a drawing herein
  • buffer memory 61 M0
  • 62 M1
  • 62 M3
  • 64 M4
  • Fig. 2 is a diagram for describing a phenomenon in which many instructions converge into the same buffer memory.
  • BUSY control technique for issuing a BUSY signal inhibiting the transmission of an instruction or the like from a buffer memory 61 (M0) or the like when the buffer memory 61 (M0) or the like no longer has room to receive an instruction and/or data, that is, when the buffer memory 61 (M0) or the like becomes full or nearly full.
  • the BUSY control technique makes it possible to reduce the possibility of the buffer memory 61 (M0) overflowing with instructions and the like.
  • Another method is to provide each of the CPUs 51 (CPU#0), 52 (CPU#1) and the like, which hand instructions to a single system controller 31 (SC#0), with plural pieces of buffer memory, thereby making it possible to reduce the possibility of causing the buffer memory 61 (M0) to overflow with instructions and the like.
  • Fig. 3 is a diagram for describing a phenomenon called "slippage" generated between the instruction and a BUSY signal.
  • a first instruction issued from the CPU (CPU#0) of the system board 10 (SB#0) in step (1) is handed over to the system controller 31 (SC#0) of the system board 30 (SB#2) by way of the crossbar switch 40 (XB#0) in step (3), under the control of the system controller 11 (SC#0) (in step (2)).
  • one of the BUSY signals inhibiting the transmission of an instruction or the like from the buffer memory 61 (M0) (in step (5)) is handed over to the system controller 11 (SC#0) of the system board 10 (SB#0) by way of the crossbar switch 40 (XB#0) (in step (6)) under the control of the system controller 31 (SC#0) of the system board 30 (SB#2).
  • the BUSY signal is returned to the CPU (CPU#0) of the system board 10 (SB#0), which initially issued the first instruction, under the control of the system controller 11 (SC#0) (in step (7)).
  • the system controller 31 (SC#0) of the system board 30 (SB#2) returns a response corresponding to the first instruction from the memory (DIMM) 81 by way of the MAC 71 (MAC#0) (in step (11)) and the response is handed over to the system controller 11 (SC#0) of the system board 10 (SB#0) by way of the crossbar switch 40 (XB#0) (in step (13)) under the control of the system controller 31 (SC#0) of the system board 30 (SB#2) (i.e., step (12)). Then, under the control of the system controller 11 (SC#0), the response to the first instruction is returned to the CPU (CPU#0) of the system board 10 (SB#0), which issued the first instruction (in step (14)).
  • a configuration is such as to generate a BUSY signal with sufficient time so as to avoid the occurrence of "slippage"
  • the configuration is such as to issue a BUSY signal inhibiting the transmission of an instruction or the like from a buffer memory 61 (M0) and the like at the timing when the buffer memory 61 (M0) or the like becomes close to full instead of completely full, a problem is generated in which the capacity of the buffer memory 61 (M0) or the like is partially wasted.
  • Fig. 4 is a diagram for describing the problem in the case of comprising pieces of buffer memory corresponding to all CPUs.
  • the number of pieces of buffer memory comprised by each system controller increases from four pieces corresponding to the conventional number of CPUs to sixteen pieces corresponding to sixteen CPUs, that is, between the zeroth and fifteenth. That is, the number of required pieces of buffer memory quadruples from four to sixteen.
  • the present invention aims at providing a memory control apparatus and a memory control method that enable an effective utilization of buffer memory in a system LSI.
  • the present invention is contrived to adopt a configuration as follows in order to solve the above described problem.
  • a memory control apparatus of the present invention used for controlling access to memory comprises: buffer memory for temporarily storing data stored in the memory; an instruction reception means for receiving an instruction to the memory; a buffer memory security-dedicated use packet transmission means for transmitting a buffer memory security-dedicated use packet for securing the capacity of memory in the buffer memory that is required by an instruction on the basis of the instruction received by the instruction reception unit; a buffer memory validation signal reception means for receiving a buffer memory validation signal corresponding to a buffer memory security-dedicated use packet transmitted by the buffer memory security-dedicated use packet transmission means; and an instruction execution means for executing an instruction received by the instruction reception means on the basis of a buffer memory validation signal received by the buffer memory validation signal reception means.
  • the memory control apparatus is desirably configured such that the instruction is generated by a central processing unit (CPU), and the memory control apparatus is a system controller.
  • CPU central processing unit
  • the memory control apparatus is desirably a large-scale integration (LSI) for use in a system LSI comprising a plurality of memory control apparatuses.
  • LSI large-scale integration
  • a memory control method of the present invention is a method that is used for controlling an access to memory and carried out in a memory control apparatus comprising buffer memory for temporarily storing data stored in the memory, comprising: receiving an instruction to the memory; transmitting a buffer memory security-dedicated use packet for securing the capacity of memory in the buffer memory that is required by the instruction on the basis of the received instruction; receiving a buffer memory validation signal corresponding to the transmitted buffer memory security-dedicated use packet; and executing the received instruction on the basis of the received buffer memory validation signal.
  • the present invention is contrived to pre-transmit a buffer memory security-dedicated use packet and pre-secure a storage zone of buffer memory and then carry out an actual accessing.
  • This configuration makes it possible to perform a memory control while reducing the occurrence of "slippage" drastically without increasing the quantity of buffer memory.
  • Fig. 5 is a diagram for describing the flow of a memory control to which the present invention is applied.
  • the CPU (CPU#0) of a system board 10 (SB#0) issues a first buffer memory security-dedicated use packet corresponding to the first instruction (in step (1)).
  • Fig. 6 is a diagram showing an example of a buffer memory security-dedicated use packet.
  • the buffer memory security-dedicated use packet is made of 32 bits (0 through 31), in which the zeroth through eleventh -bit fields store a reserve ID (RSVID); the twelfth through fifteenth -bit fields store the system board number (TARGET) of the addressee, that is, a target; of the sixteenth through eighteenth -bit fields, the sixteenth-bit field stores BANK-ID and the seventeenth to eighteenth -bit fields store MAC-ID; and the twenty-fourth through thirtieth -bit fields store an operation code (OPC).
  • RVID reserve ID
  • TARGET system board number
  • MAC-ID seventeenth to eighteenth -bit fields
  • OPC operation code
  • the first buffer memory security-dedicated use packet issued from the CPU (CPU#0) of a system board 10 (SB#0) is handed to the system controller 31 (SC#0) of a system board 30 (SB#2) by way of a crossbar switch 40 (XB#0) (in step (3)) under the control of the system controller 11 (SC#0) (step (2)).
  • the buffer memory security signal is returned to the CPU (CPU#0) of the system board 10 (SB#0), which originally issued the first buffer memory security-dedicated use packet, under the control of the system controller 11 (SC#0) (in step (6)).
  • the first instruction is issued from the CPU (CPU#0) of the system board 10 (SB#0) (in step (7)) and is handed to system controller 31 (SC#0) of the system board 30 (SB#2) by way of the crossbar switch 40 (XB#0) (in step (9)) under the control of the system controller 11 (SC#0) (step (8)).
  • This prompts the system controller 31 (SC#0) to validate that the first instruction is the instruction corresponding to the first buffer memory security-dedicated use packet and to access memory (DIMM) 81 by way of a MAC 71 (MAC#0) (in step (10)).
  • the system controller 31 (SC#0) of the system board 30 (SB#2) returns a response corresponding to the first instruction from the memory (DIMM) 81 by way of the MAC 71 (MAC#0) and also decrements the counter (in step (11)); the response corresponding to the first instruction is handed to the system controller 11 (SC#0) of the system board 10 (SB#0) by way of the crossbar switch 40 (XB#0) (in step (13)) under the control of system controller 31 (SC#0) of the system board 30 (SB#2) (in step (12)); and the response corresponding to the first instruction is returned to the CPU (CPU#0) of the system board 10 (SB#0) under the control of the system controller 11 (SC#0) (step (14)).
  • a preferred embodiment of the present invention has so far been described.
  • the above described embodiment of the present invention can be implemented, as one function of the memory control apparatus, by using hardware, firmware such as a digital signal processing (DSP) board or a CPU board, or using software.
  • DSP digital signal processing
  • the memory control apparatus to which the present invention is applied may be a single apparatus, a system or integrated apparatus consisting of a plurality of apparatuses, or a system in which the processing is carried out by way of a network such as a local area network (LAN) or a wide area network (WAN), provided that the function of the memory control apparatus is carried out, in lieu of the present invention being limited by the above described embodiment.
  • LAN local area network
  • WAN wide area network
  • the present invention may be implemented by employing a system comprising a CPU, memory such as read only memory (ROM) and random access memory (RAM), an input apparatus, an output apparatus, an external recording apparatus, a media drive apparatus, and a network connection apparatus, all of which are interconnected by a bus. That is, it is obvious that the present invention can also be implemented by providing the memory control apparatus with memory, such as ROM and RAM, an external recording apparatus, and a portable recording medium, all of which store the program code of the software implementing the system according to the above described embodiment, so that the computer of the memory control apparatus reads and executes the program code.
  • ROM read only memory
  • RAM random access memory
  • the program code read from the portable recording medium and the like is regarded as implementing the new function of the present invention, and the portable recording medium and the like recording the program code are regarded as the constituent of the present invention.
  • the portable recording medium for supplying the program code can use, for example, a flexible disk, a hard disk, an optical disk, a magneto optical disk, a CD-ROM, a CD-R, a DVD-ROM, a DVD-RAM, a magnetic tape, a nonvolatile memory card, a ROM card, and various recording media recorded by way of a network connection apparatus (i.e., a telecommunications line in other words) such as electronic mail and personal computer (PC) communications.
  • a network connection apparatus i.e., a telecommunications line in other words
  • PC personal computer
  • the function of the above described embodiment is implemented by a computer (i.e., an information processing apparatus) executing the program code read onto the memory and, in addition, the function of the above described embodiment is also implemented by the processing resulting from the operating system (OS) and the like working in the computer carrying out a portion of the actual processing or the entirety thereof on the basis of the instruction of the program code.
  • OS operating system
  • a program code read from a portable recording medium and/or a program (and data) provided by a program (and data) provider(s) are (or, is) written to memory comprised by a function extension board inserted into a computer, or by a function extension unit connected to the computer, and then a portion of the actual processing or the entirety thereof is executed by the CPU and the like comprised by the function extension board or a function extension unit on the basis of the instruction of the program code, and thereby the function of the above described embodiment can be implemented.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Transfer Systems (AREA)

Abstract

A memory control apparatus and a memory control method are provided to enable an effective utilization of buffer memory in a system LSI by comprising buffer memory for temporarily storing data stored in memory, and comprising the processes of: receiving an instruction to the memory; transmitting a buffer memory security-dedicated use packet for securing the capacity of memory in the buffer memory required by the instruction on the basis of the received instruction; receiving a buffer memory validation signal corresponding to the transmitted buffer memory security-dedicated use packet; and executing the received instruction on the basis of the received buffer memory validation signal.

Description

    Technical Field
  • The present invention relates to a technique for transferring data between processing units attaining one function or a plurality thereof and in particular to a memory control apparatus and a memory control method utilizing buffer memory effectively in a system LSI comprising a large number of processing units.
  • Background Art
  • A conventional system LSI has a configuration of incorporating, on a single chip, plural pieces of functional blocks, which are configured to achieve one function or a plurality thereof. These functional blocks can be regarded as a single processing unit such as a central processing unit (CPU), memory and a dedicated circuit, and a process progresses in the system LSI by exchanging signals or data between the processing units.
  • As the scale of such a system LSI grows, a problem emerges in exchanging signals between functional blocks, that is, the processing units.
  • Fig. 1 is a diagram showing the configuration of a system LSI.
  • Referring to Fig. 1, in the system LSI performing data processing, plural system boards 10 (SB#0), 20 (SB#1) and 30 (SB#2) are interconnected by way of a crossbar switch 40 (XB#0). The system board 30 (SB#2) comprises plural system controllers 31 (SC#0) and 32 (SC#1). Likewise the system board 10 (SB#0) comprises a plurality of system controllers 11 (SC#0) and the like, while the system board 20 (SB#1) comprises a plurality of system controllers 21 (SC#0) and the like.
  • The system controller 31 (SC#0) controls a read from, and a write to, memory (DIMM) 81, 82, 83 or 84 by way of MAC71 (MAC#0), 72 (MAC#1), 73 (MAC#3) or 74 (MAC#4) in accordance with an instruction from a CPU (not shown in a drawing herein) connected to either of plural CPUs 51 (CPU#0), 52 (CPU#1), and so on, or either of plural system controllers 32 (SC#1), 11 (SC#0), 21 (SC#0), and so on. Further, when reading from, and writing to, the memory (DIMM) 81, 82, 83 or 84, which is controlled by the system controller 31 (SC#0), buffer memory 61 (M0), 62 (M1), 62 (M3) or 64 (M4), which temporarily stores data corresponding to the memory (DIMM) 81, 82, 83 or 84, is utilized.
  • As the system LSI becomes very large, however, a large number of instructions and/or many pieces of data (i.e., data packets) sometimes converge into the same buffer memory 61 (M0), 62 (M1), 62 (M3) or 64 (M4).
  • Fig. 2 is a diagram for describing a phenomenon in which many instructions converge into the same buffer memory.
  • If a plurality of instructions (i.e., requests) from either CPU require data stored in the memory (DIMM) 81, many instructions are converged into the buffer memory 61 (M0), causing it to overflow with instructions, as shown in Fig. 2.
  • In order to improve such a situation, the capacity of all the buffer memories 62 (M1), 63 (M3) and 64 (M4), not only the buffer memory 61 (M0), must be increased, and there is a resultant cost increase that makes the method impractical , and therefore the present memory 61 (M0) needs to be used more effectively.
  • There is accordingly a technique (i.e., BUSY control technique) for issuing a BUSY signal inhibiting the transmission of an instruction or the like from a buffer memory 61 (M0) or the like when the buffer memory 61 (M0) or the like no longer has room to receive an instruction and/or data, that is, when the buffer memory 61 (M0) or the like becomes full or nearly full. The BUSY control technique makes it possible to reduce the possibility of the buffer memory 61 (M0) overflowing with instructions and the like. Another method is to provide each of the CPUs 51 (CPU#0), 52 (CPU#1) and the like, which hand instructions to a single system controller 31 (SC#0), with plural pieces of buffer memory, thereby making it possible to reduce the possibility of causing the buffer memory 61 (M0) to overflow with instructions and the like.
  • Disclosure of Invention
  • However, although the above described BUSY control technique does not generate a big practical problem when a system LSI is relatively small, the distances between various LSIs, such as the distance between the system boards 10 (SB#0) and 30 (SB#2) and the distance between the system controllers 11 (SC#0) and 32 (SC#1), become longer as the system LSI becomes larger, thus elongating the transmission time between them. As a result, a "slippage" is generated between the instruction and the BUSY signal, causing a problem in which an instruction is issued to a buffer memory 61 (M0) or the like that is actually unable to receive the instruction.
  • Fig. 3 is a diagram for describing a phenomenon called "slippage" generated between the instruction and a BUSY signal.
  • Referring to Fig. 3, first, a first instruction issued from the CPU (CPU#0) of the system board 10 (SB#0) in step (1) (shown in the drawing; the numbers in parentheses, through (14), mean the same hereinafter), is handed over to the system controller 31 (SC#0) of the system board 30 (SB#2) by way of the crossbar switch 40 (XB#0) in step (3), under the control of the system controller 11 (SC#0) (in step (2)). This prompts the system controller 31 (SC#0) to access the memory (DIMM) 81 by way of the MAC 71 (MAC#0) (in step (4)).
  • If the buffer memory 61 (M0) becomes full at this time, one of the BUSY signals inhibiting the transmission of an instruction or the like from the buffer memory 61 (M0) (in step (5)) is handed over to the system controller 11 (SC#0) of the system board 10 (SB#0) by way of the crossbar switch 40 (XB#0) (in step (6)) under the control of the system controller 31 (SC#0) of the system board 30 (SB#2). Then, the BUSY signal is returned to the CPU (CPU#0) of the system board 10 (SB#0), which initially issued the first instruction, under the control of the system controller 11 (SC#0) (in step (7)).
  • If, however, a second instruction is issued from the CPU (CPU#0) of the system board 10 (SB#0) and if the second instruction is handed over to the system controller 31 (SC#0) of the system board 30 (SB#2) by way of the crossbar switch 40 (XB#0) (in step (10)) under the control of the system controller 11 (SC#0) (i.e., step (9)), between the transmission of the first instruction (in step (1)) and the receiving of the BUSY signal (in step (7)), then the buffer memory 61 (M0) is already full and the system controller 31 (SC#0) is unable to receive the second instruction. This state is defined as "slippage".
  • Note that, even if such a "slippage" occurs, the system controller 31 (SC#0) of the system board 30 (SB#2) returns a response corresponding to the first instruction from the memory (DIMM) 81 by way of the MAC 71 (MAC#0) (in step (11)) and the response is handed over to the system controller 11 (SC#0) of the system board 10 (SB#0) by way of the crossbar switch 40 (XB#0) (in step (13)) under the control of the system controller 31 (SC#0) of the system board 30 (SB#2) (i.e., step (12)). Then, under the control of the system controller 11 (SC#0), the response to the first instruction is returned to the CPU (CPU#0) of the system board 10 (SB#0), which issued the first instruction (in step (14)).
  • Further, if a configuration is such as to generate a BUSY signal with sufficient time so as to avoid the occurrence of "slippage", that is, if the configuration is such as to issue a BUSY signal inhibiting the transmission of an instruction or the like from a buffer memory 61 (M0) and the like at the timing when the buffer memory 61 (M0) or the like becomes close to full instead of completely full, a problem is generated in which the capacity of the buffer memory 61 (M0) or the like is partially wasted.
  • Further, if a configuration is such as to provide all the CPUs with corresponding pieces of buffer memory, the required number of pieces of buffer memory increases with the size of a system LSI, thus giving rise to the problem of cost increase.
  • Fig. 4 is a diagram for describing the problem in the case of comprising pieces of buffer memory corresponding to all CPUs.
  • For example, if a single system board comprises four system controllers, with each system controller respectively comprising four CPUs, the number of pieces of buffer memory comprised by each system controller increases from four pieces corresponding to the conventional number of CPUs to sixteen pieces corresponding to sixteen CPUs, that is, between the zeroth and fifteenth. That is, the number of required pieces of buffer memory quadruples from four to sixteen.
  • In consideration of the situation described above, the present invention aims at providing a memory control apparatus and a memory control method that enable an effective utilization of buffer memory in a system LSI.
  • The present invention is contrived to adopt a configuration as follows in order to solve the above described problem.
  • That is, according to one aspect of the present invention, a memory control apparatus of the present invention used for controlling access to memory comprises: buffer memory for temporarily storing data stored in the memory; an instruction reception means for receiving an instruction to the memory; a buffer memory security-dedicated use packet transmission means for transmitting a buffer memory security-dedicated use packet for securing the capacity of memory in the buffer memory that is required by an instruction on the basis of the instruction received by the instruction reception unit; a buffer memory validation signal reception means for receiving a buffer memory validation signal corresponding to a buffer memory security-dedicated use packet transmitted by the buffer memory security-dedicated use packet transmission means; and an instruction execution means for executing an instruction received by the instruction reception means on the basis of a buffer memory validation signal received by the buffer memory validation signal reception means.
  • Further, the memory control apparatus according to the present invention is desirably configured such that the instruction is generated by a central processing unit (CPU), and the memory control apparatus is a system controller.
  • Further, the memory control apparatus according to the present invention is desirably a large-scale integration (LSI) for use in a system LSI comprising a plurality of memory control apparatuses.
  • Further, according to one aspect of the present invention, a memory control method of the present invention is a method that is used for controlling an access to memory and carried out in a memory control apparatus comprising buffer memory for temporarily storing data stored in the memory, comprising: receiving an instruction to the memory; transmitting a buffer memory security-dedicated use packet for securing the capacity of memory in the buffer memory that is required by the instruction on the basis of the received instruction; receiving a buffer memory validation signal corresponding to the transmitted buffer memory security-dedicated use packet; and executing the received instruction on the basis of the received buffer memory validation signal.
  • Brief Description of Drawings
    • Fig. 1 is a diagram showing the configuration of a system LSI;
    • Fig. 2 is a diagram for describing a phenomenon of many instructions converging into the same buffer memory;
    • Fig. 3 is a diagram for describing a phenomenon called "slippage" generated between the instruction and a BUSY signal;
    • Fig. 4 is a diagram for describing the problem in the case of comprising pieces of buffer memory corresponding to all CPUs;
    • Fig. 5 is a diagram for describing the flow of a memory control to which the present invention is applied; and
    • Fig. 6 is a diagram showing an example of a buffer memory security-dedicated use packet.
    Best Mode for Carrying Out the Invention
  • The following is a description of the preferred embodiment of the present invention by referring to the accompanying drawings.
  • First is an outline of the present invention.
  • That is, the present invention is contrived to pre-transmit a buffer memory security-dedicated use packet and pre-secure a storage zone of buffer memory and then carry out an actual accessing.
  • This configuration makes it possible to perform a memory control while reducing the occurrence of "slippage" drastically without increasing the quantity of buffer memory.
  • Fig. 5 is a diagram for describing the flow of a memory control to which the present invention is applied.
  • Referring to Fig. 5, first, the CPU (CPU#0) of a system board 10 (SB#0) issues a first buffer memory security-dedicated use packet corresponding to the first instruction (in step (1)).
  • Fig. 6 is a diagram showing an example of a buffer memory security-dedicated use packet.
  • Referring to Fig. 6, the buffer memory security-dedicated use packet is made of 32 bits (0 through 31), in which the zeroth through eleventh -bit fields store a reserve ID (RSVID); the twelfth through fifteenth -bit fields store the system board number (TARGET) of the addressee, that is, a target; of the sixteenth through eighteenth -bit fields, the sixteenth-bit field stores BANK-ID and the seventeenth to eighteenth -bit fields store MAC-ID; and the twenty-fourth through thirtieth -bit fields store an operation code (OPC).
  • Returning the description to Fig. 5, the first buffer memory security-dedicated use packet issued from the CPU (CPU#0) of a system board 10 (SB#0) is handed to the system controller 31 (SC#0) of a system board 30 (SB#2) by way of a crossbar switch 40 (XB#0) (in step (3)) under the control of the system controller 11 (SC#0) (step (2)).
  • This prompts a system controller 31 (SC#0), having received the first buffer memory security-dedicated use packet, to secure the capacity of memory in buffer memory 61 (M0) that is required by the first instruction and also to increment a counter. Then, if the fact that the buffer memory 61 (M0) becomes full is validated on the basis of the information stored in the first buffer memory security-dedicated use packet, one of the buffer memory security signals indicating that the buffer memory 61 (M0) is likely to be full is handed to the system controller 11 (SC#0) of a system board 10 (SB#0) as the ACK (i.e., acknowledge) for receiving the first buffer memory security-dedicated use packet (in step (4)) by way of the crossbar switch 40 (XB#0) (step (5)) under the control of the system controller 31 (SC#0) of the system board 30 (SB#2). Then, the buffer memory security signal is returned to the CPU (CPU#0) of the system board 10 (SB#0), which originally issued the first buffer memory security-dedicated use packet, under the control of the system controller 11 (SC#0) (in step (6)).
  • Then, the first instruction is issued from the CPU (CPU#0) of the system board 10 (SB#0) (in step (7)) and is handed to system controller 31 (SC#0) of the system board 30 (SB#2) by way of the crossbar switch 40 (XB#0) (in step (9)) under the control of the system controller 11 (SC#0) (step (8)). This prompts the system controller 31 (SC#0) to validate that the first instruction is the instruction corresponding to the first buffer memory security-dedicated use packet and to access memory (DIMM) 81 by way of a MAC 71 (MAC#0) (in step (10)).
  • Then, the system controller 31 (SC#0) of the system board 30 (SB#2) returns a response corresponding to the first instruction from the memory (DIMM) 81 by way of the MAC 71 (MAC#0) and also decrements the counter (in step (11)); the response corresponding to the first instruction is handed to the system controller 11 (SC#0) of the system board 10 (SB#0) by way of the crossbar switch 40 (XB#0) (in step (13)) under the control of system controller 31 (SC#0) of the system board 30 (SB#2) (in step (12)); and the response corresponding to the first instruction is returned to the CPU (CPU#0) of the system board 10 (SB#0) under the control of the system controller 11 (SC#0) (step (14)).
  • Meanwhile, after issuing the first buffer memory security-dedicated use packet in the above described step (1), when a second buffer memory security-dedicated use packet corresponding to a second instruction is issued from the CPU (CPU#0) of the system board 10 (SB#0) (in step (15)) and the second buffer memory security-dedicated use packet is handed to the system controller 31 (SC#0) of the system board 30 (SB#2) by way of the crossbar switch 40 (XB#0) (in step (17)) under the control of the system controller 11 (SC#0) (step (16)), it is possible to validate that the capacity of memory in the buffer memory 61 (M0) is going to be full due to receiving the first buffer memory security-dedicated use packet even if the buffer memory 61 (M0) is not yet full.
  • A preferred embodiment of the present invention has so far been described. The above described embodiment of the present invention can be implemented, as one function of the memory control apparatus, by using hardware, firmware such as a digital signal processing (DSP) board or a CPU board, or using software.
  • Further, the memory control apparatus to which the present invention is applied may be a single apparatus, a system or integrated apparatus consisting of a plurality of apparatuses, or a system in which the processing is carried out by way of a network such as a local area network (LAN) or a wide area network (WAN), provided that the function of the memory control apparatus is carried out, in lieu of the present invention being limited by the above described embodiment.
  • The present invention may be implemented by employing a system comprising a CPU, memory such as read only memory (ROM) and random access memory (RAM), an input apparatus, an output apparatus, an external recording apparatus, a media drive apparatus, and a network connection apparatus, all of which are interconnected by a bus. That is, it is obvious that the present invention can also be implemented by providing the memory control apparatus with memory, such as ROM and RAM, an external recording apparatus, and a portable recording medium, all of which store the program code of the software implementing the system according to the above described embodiment, so that the computer of the memory control apparatus reads and executes the program code.
  • In such a case, the program code read from the portable recording medium and the like is regarded as implementing the new function of the present invention, and the portable recording medium and the like recording the program code are regarded as the constituent of the present invention.
  • The portable recording medium for supplying the program code can use, for example, a flexible disk, a hard disk, an optical disk, a magneto optical disk, a CD-ROM, a CD-R, a DVD-ROM, a DVD-RAM, a magnetic tape, a nonvolatile memory card, a ROM card, and various recording media recorded by way of a network connection apparatus (i.e., a telecommunications line in other words) such as electronic mail and personal computer (PC) communications.
  • Further, the function of the above described embodiment is implemented by a computer (i.e., an information processing apparatus) executing the program code read onto the memory and, in addition, the function of the above described embodiment is also implemented by the processing resulting from the operating system (OS) and the like working in the computer carrying out a portion of the actual processing or the entirety thereof on the basis of the instruction of the program code.
  • Furthermore, a program code read from a portable recording medium and/or a program (and data) provided by a program (and data) provider(s) are (or, is) written to memory comprised by a function extension board inserted into a computer, or by a function extension unit connected to the computer, and then a portion of the actual processing or the entirety thereof is executed by the CPU and the like comprised by the function extension board or a function extension unit on the basis of the instruction of the program code, and thereby the function of the above described embodiment can be implemented.
  • That is, the present invention may adopt various configurations or forms within the scope thereof, in lieu of being limited to the above described embodiment.

Claims (4)

  1. A memory control apparatus controlling access to memory, comprising:
    buffer memory for temporarily storing data stored in the memory;
    an instruction reception means for receiving an instruction to the memory;
    a buffer memory security-dedicated use packet transmission means for transmitting a buffer memory security-dedicated use packet for securing a capacity of memory in the buffer memory that is required by an instruction on the basis of the instruction received by the instruction reception means;
    a buffer memory validation signal reception means for receiving a buffer memory validation signal corresponding to the buffer memory security-dedicated use packet transmitted by the buffer memory security-dedicated use packet transmission means; and
    an instruction execution means for executing the instruction received by the instruction reception means on the basis of the buffer memory validation signal received by the buffer memory validation signal reception means.
  2. The memory control apparatus according to claim 1, wherein
    said instruction is generated by a central processing unit (CPU), and
    the memory control apparatus is a system controller.
  3. The memory control apparatus according to claim 1 is a LSI for use in a system LSI comprising a plurality of the memory control apparatuses.
  4. A memory control method which is used for controlling an access to memory and which is carried out in a memory control apparatus comprising buffer memory for temporarily storing data stored in the memory, comprising:
    receiving an instruction to the memory;
    transmitting a buffer memory security-dedicated use packet for securing, in the buffer memory, a capacity of memory in the buffer memory required by the instruction on the basis of the received instruction;
    receiving a buffer memory validation signal corresponding to the transmitted buffer memory security-dedicated use packet; and
    executing the received instruction on the basis of the received buffer memory validation signal.
EP06714636A 2006-02-24 2006-02-24 Memory control apparatus and memory control method Ceased EP1988463B1 (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/JP2006/303497 WO2007097007A1 (en) 2006-02-24 2006-02-24 Memory control apparatus and memory control method

Publications (3)

Publication Number Publication Date
EP1988463A1 true EP1988463A1 (en) 2008-11-05
EP1988463A4 EP1988463A4 (en) 2010-11-24
EP1988463B1 EP1988463B1 (en) 2012-01-04

Family

ID=38437067

Family Applications (1)

Application Number Title Priority Date Filing Date
EP06714636A Ceased EP1988463B1 (en) 2006-02-24 2006-02-24 Memory control apparatus and memory control method

Country Status (4)

Country Link
US (1) US7984234B2 (en)
EP (1) EP1988463B1 (en)
JP (1) JP4768806B2 (en)
WO (1) WO2007097007A1 (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5349515B2 (en) * 2011-03-14 2013-11-20 株式会社東芝 Buffer management device, buffer management method, and storage device
US10725297B2 (en) 2015-01-28 2020-07-28 CCP hf. Method and system for implementing a virtual representation of a physical environment using a virtual reality environment
US10726625B2 (en) * 2015-01-28 2020-07-28 CCP hf. Method and system for improving the transmission and processing of data regarding a multi-user virtual environment

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4972315A (en) * 1987-03-10 1990-11-20 Mitsubishi Denki Kabushiki Kaisha Data flow machine
JP2593883B2 (en) 1987-09-07 1997-03-26 岩尾磁器工業株式会社 Method for producing alumina-zirconia composite powder and sintered body thereof
JP3138945B2 (en) * 1992-07-30 2001-02-26 日本電信電話株式会社 Data transfer method
JP2747258B2 (en) * 1995-10-20 1998-05-06 甲府日本電気株式会社 Write buffer busy control method
US5926458A (en) * 1997-01-31 1999-07-20 Bay Networks Method and apparatus for servicing multiple queues
US5974571A (en) * 1997-09-30 1999-10-26 Intel Corporation Method and apparatus for avoiding deadlock in the issuance of commands that are reordered and require data movement according to an original command order
US6202101B1 (en) * 1998-09-30 2001-03-13 Compaq Computer Corporation System and method for concurrently requesting input/output and memory address space while maintaining order of data sent and returned therefrom
JP2000183995A (en) * 1998-12-14 2000-06-30 Sony Corp Data processing circuit
JP3327900B2 (en) * 1999-07-12 2002-09-24 松下電器産業株式会社 Data processing device
US6584529B1 (en) * 2000-09-08 2003-06-24 Koninklijke Philips Electronics N.V. Intermediate buffer control for improving throughput of split transaction interconnect
US6820194B1 (en) * 2001-04-10 2004-11-16 Mindspeed Technologies, Inc. Method for reducing power when fetching instructions in a processor and related apparatus
US7069373B2 (en) * 2002-11-07 2006-06-27 Nec Electronics America, Inc. USB endpoint controller flexible memory management
JP4748641B2 (en) * 2004-12-06 2011-08-17 ルネサスエレクトロニクス株式会社 Information processing system

Also Published As

Publication number Publication date
JP4768806B2 (en) 2011-09-07
EP1988463B1 (en) 2012-01-04
US20080313386A1 (en) 2008-12-18
EP1988463A4 (en) 2010-11-24
JPWO2007097007A1 (en) 2009-07-09
WO2007097007A1 (en) 2007-08-30
US7984234B2 (en) 2011-07-19

Similar Documents

Publication Publication Date Title
US7774559B2 (en) Method and system for terminating write commands in a hub-based memory system
US11010094B2 (en) Task management method and host for electronic storage device
US8516214B2 (en) Memory access control device, command issuing device, and method
CN113900974B (en) Storage device, data storage method and related equipment
JP2008009817A (en) Semiconductor device and data transfer method
US20080301381A1 (en) Device and method for controlling commands used for flash memory
US7984234B2 (en) Memory control apparatus and memory control method
EP1513071B1 (en) Memory bandwidth control device
US7127530B2 (en) Command issuing apparatus for high-speed serial interface
EP1366421B1 (en) Digital signal processor interrupt accelerator
CN117008843B (en) Control page linked list construction device and electronic equipment
CN102385555A (en) Caching system and method of data caching
CN117116323A (en) Method for reading and writing single-port SRAM, FIFO module and chip
CN100390766C (en) Universal serial bus device and method for exchanging data with same
US7383360B2 (en) Electronic data storage system divides command requiring data transfer into subcommands, in accordance with performance of devices
KR20050004157A (en) Data transfer unit with support for multiple coherency granules
JPH11110342A (en) Bus connection method and device
US20060026310A1 (en) Computer system having an I/O module directly connected to a main storage for DMA transfer
JP4343244B2 (en) Microcomputer
JP2008009804A (en) Information processor and information processing method, information processing system, program and recording medium
JP2007079942A (en) Data recording / reproducing device
JPS6047628B2 (en) shared storage
JPH0535640A (en) Channel priority deciding circuit

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 20080917

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): DE FR GB

RBV Designated contracting states (corrected)

Designated state(s): DE FR GB

A4 Supplementary search report drawn up and despatched

Effective date: 20101021

RIC1 Information provided on ipc code assigned before grant

Ipc: G06F 12/00 20060101AFI20070926BHEP

Ipc: G06F 13/16 20060101ALI20101015BHEP

GRAP Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOSNIGR1

RIC1 Information provided on ipc code assigned before grant

Ipc: G06F 13/16 20060101ALI20110630BHEP

Ipc: G06F 12/00 20060101AFI20110630BHEP

GRAS Grant fee paid

Free format text: ORIGINAL CODE: EPIDOSNIGR3

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

DAX Request for extension of the european patent (deleted)
AK Designated contracting states

Kind code of ref document: B1

Designated state(s): DE FR GB

REG Reference to a national code

Ref country code: GB

Ref legal event code: FG4D

REG Reference to a national code

Ref country code: DE

Ref legal event code: R096

Ref document number: 602006026809

Country of ref document: DE

Effective date: 20120301

PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

26N No opposition filed

Effective date: 20121005

REG Reference to a national code

Ref country code: DE

Ref legal event code: R097

Ref document number: 602006026809

Country of ref document: DE

Effective date: 20121005

REG Reference to a national code

Ref country code: FR

Ref legal event code: PLFP

Year of fee payment: 11

REG Reference to a national code

Ref country code: FR

Ref legal event code: PLFP

Year of fee payment: 12

REG Reference to a national code

Ref country code: FR

Ref legal event code: PLFP

Year of fee payment: 13

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 20210113

Year of fee payment: 16

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20210217

Year of fee payment: 16

Ref country code: DE

Payment date: 20210209

Year of fee payment: 16

REG Reference to a national code

Ref country code: DE

Ref legal event code: R119

Ref document number: 602006026809

Country of ref document: DE

GBPC Gb: european patent ceased through non-payment of renewal fee

Effective date: 20220224

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: FR

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220228

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220224

Ref country code: DE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220901