A certain aspect of the embodiments is related to a data writing control device, a data writing control method, and an information processing device.
In general, as systems in which a memory control circuit writes data in a memory, there are known a full-write system for writing data of all bytes (full line), and a partial-write system in which data is read out from a memory and a part of the readout data is rewritten by write data from a CPU.
Moreover, there has been conventionally known a memory control circuit including an address register for partial-write and a memory data register (e.g., see Japanese Laid-open Patent Publication No. 6-119238 (hereinafter referred to as “Patent Document 1”)).
Here,
First, the memory control circuit determines whether a memory write mode is the partial-write based on information from the CPU (step S10). When the memory write mode is not the partial-write, i.e., the memory write mode is the full-write (NO in step S10), the memory control circuit determines whether the address of write data is identical with an address used for previous partial-write which is stored into the address register for partial-write (step S11).
When the address of the write data is identical with the address used for previous partial-write (YES in step S11), the memory control circuit holds the write data in the memory data register (step S12), and performs write operation to a memory (step S13). When the address of the write data is not identical with the address used for previous partial-write (NO in step S11), the procedure of step S13 is performed.
On the other hand, when the memory write mode is the partial-write (YES in step S10), the memory control circuit receives a request for the partial-write (step S14), and determines whether the address of write data included in the request for the partial-write is identical with an address used for previous partial-write which is stored into the address register for partial-write (step S15). When the address of the write data is identical with the address used for previous partial-write (YES in step S15), the memory control circuit merges the data held in the memory data register and the write data (step S16). Since data identical with data in the memory corresponding to the address on which the partial-write is performed is already stored into the memory data register, memory read operation is not performed in step S16. In addition, the memory control circuit holds the merged data in the memory data register, and performs the write operation to the memory (step S17).
On the other hand, when the address of the write data is not identical with the address used for previous partial-write (NO in step S15), the memory control circuit outputs a read request to the CPU (step S18). The memory control circuit determines whether the memory control circuit has received read data (step S19). When the memory control circuit has not received the read data (NO in step S19), the determination of step S19 is repeated. On the other hand, when the memory control circuit has received the read data (YES in step S19), the memory control circuit holds the read data in the memory data register (step S20), and the procedure proceeds to step S16.
Thus, at the time of access of the partial-write, the memory control circuit of Patent Document 1 stores the address and the data into the address register for partial-write and the memory data register, respectively. When a next partial-write address is identical with the address held in the address register for partial-write, the memory control circuit reads out the data from the memory data register instead of the memory, and merges the read-out data and the write data (see steps S15 and S16). Therefore, when the partial-write is continuously performed to the same address, the memory read operation does not need to be performed, and hence the partial-write access can be made high-speed.
According to an aspect of the present invention, there is provided a data writing control device including: a determination unit that determines whether a request from a requestor is a partial-write request for data and the partial-write is continuously performed to the same address; a transmission unit that, when the request from the requestor is the partial-write request for data and the partial-write is performed to an address different from an address of the previous partial-write, transmits a read request for data to the requestor; and a hold unit that holds write data included in the partial-write request and data indicating a rewritten location of the write data until read data corresponding to the read request for the data is received.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
In the memory control circuit of above-mentioned Patent Document 1, when the partial-write is not continuously performed to the same address, the memory read operation needs to be performed in a conventional manner. Particularly, in a device equipped with two or more requesters such as CPUs which issue the write or the read request, the request for the partial-write is increased, and the case where the partial-write is not continuously performed to the same address is increased. In this case, the memory control circuit has a problem that high-speed operation cannot be performed by the memory read operation with long access time and the throughput of data writing reduces.
A description will be given of embodiments of the invention, with reference to drawings.
In
The control circuit 2 receives a write request from the CPU 11. The write request includes: a full-write request for writing data of full lines in a memory; and a partial-write request in which a part of held data is rewritten by write data from a CPU, and the rewritten data is written in the memory. When the control circuit 2 receives the partial-write request from the CPU 11, the control circuit 2 transmits a read request to the CPU 11, and receives read data corresponding to the read request from the CPU 11. The detailed configuration of the control device 2 is described later. In
The data RAM 3 holds write data or merge data selected by the selector 8. Here, the merge data is data generated by merging a plurality of pieces of data using the merge circuit 5 or 6 as described later. The mask RAM 4 holds mask data. The mask data is data received from the CPU 11 by the partial-write request, and indicates a location of data to be rewritten partially.
The merge circuit 5 merges the write data and data held in the data RAM 3, based on the mask data. The merge circuit 6 merges the read data and the data held in the data RAM 3, based on the mask data. The selector 7 selects the merge data from any one of the merge circuits 5 and 6, and outputs the control circuit 2 and the selector 8. When the partial-write is continuously performed to the same address, the selector 7 selects the merge data from the merge circuit 5. When the partial-write is not continuously performed to the same address, the selector 7 selects the merge data from the merge circuit 6. The selector 8 selects any one of the write data and the merge data, and outputs the selected data to the data RAM 3 and the memory 12.
Next, a description will be given of the operation of the data writing control device 1.
When the control circuit 2 receives the full-write request from the CPU 11, the control circuit 2 outputs a data selection signal for selecting the write data to the selector 8. The selector 8 selects the write data based on the data selection signal, and outputs the write data to the data RAM 3 and the memory 12. When there is data of the same address in the data RAM 3, the data of the same address is updated by the write data.
When the control circuit 2 receives the partial-write request in which the partial-write is continuously performed to the same address as the previous partial-write, from the CPU 11, data corresponding to the address is read out from the data RAM 3, and the merge circuit 5 merges the read-out data and the write data. The merge data output from the merge circuit 5 is output to the data RAM 3 and the memory 12 via the selectors 7 and 8. The data held in the data RAM 3 is updated by the merge data output from the merge circuit 5.
When the control circuit 2 receives the partial-write request in which the partial-write is performed to the address different from the previous partial-write, from the CPU 11, the control circuit 2 outputs the read request to the CPU 11. Moreover, the control circuit 2 holds the write data and the mask data received by this partial-write request, in the data RAM 3 and the mask RAM 4, respectively. Thereby, until the data writing control device 1 receives the read data corresponding to the read request from the CPU 11, the data writing control device 1 can perform another operation. That is, until the control circuit 2 receives the read data corresponding to the read request from the CPU 11, the control circuit 2, the data RAM 3, the mask RAM 4, the merge circuits 5 and 6, and the selectors 7 and 8 can perform a process concerning another request.
When the control circuit 2 receives the read data corresponding to the read request from the CPU 11, priority is given to processing of the read data in the control circuit 2. That is, the write data held in the data RAM 3, the mask data held in the mask RAM 4 and the read data are output to the merge circuit 6, and the write data and the read data are merged based on the mask data. The merge data output from the merge circuit 6 is output to the data RAM 3 and the memory 12 via the selectors 7 and 8. The data held in the data RAM 3 is updated by the merge data output from the merge circuit 6.
In
The request determiner/address comparator 22 holds the address corresponding to the data held in the data RAM 3 for every data or every request selected by the request arbiter 21. This address is held in a flip-flop (FF) circuit 23, for example. The request determiner/address comparator 22 compares the held address with the address of data selected by the request arbiter 21 or data included in the request selected by the request arbiter 21, and outputs a given signal and data.
For example, when the merge data is input to the request arbiter 21, the request arbiter 21 notifies the request determiner/address comparator 22 of the input of the merge data, and the request determiner/address comparator 22 outputs a data selector signal to the selector 8, and outputs a data RAM WE (Write Enable) signal for writing the merge data to the data RAM 3. Thereby, the merge data is written in the data RAM 3 via the selector 8.
When the read data is input to the request arbiter 21, the request arbiter 21 notifies the request determiner/address comparator 22 of the input of the read data. The request determiner/address comparator 22 outputs a data RAM RE (Read Enable) signal for reading out data to be merged with the read data to the data RAM 3. Moreover, the request determiner/address comparator 22 outputs a mask RAM RE signal for reading out the mask data to the mask RAM 4, and outputs the read data to the merge circuit 6. Thereby, data held in the data RAM 3, the mask data held in the mask RAM 4, and the read data are output to the merge circuit 6. Then, a rewritten part of the data held in the data RAM 3 is specified by the mask data, and the data held in the data RAM 3 and the read data are merged.
When the full-write request is input to the request arbiter 21, the request arbiter 21 notifies the request determiner/address comparator 22 of the input of the full-write request. The request determiner/address comparator 22 compares an address of the write data included in the full-write request with an address of the write data included in the previous full-write request which is held in the flip-flop circuit 23. When the address of the write data included in the full-write request is identical with the address of the write data included in the previous full-write request which is held in the flip-flop circuit 23, the request determiner/address comparator 22 outputs the data selection signal and the write data to the selector 8, and outputs the data RAM WE (Write Enable) signal to the data RAM 3. Thereby, the write data is overwritten into the RAM 3 via the selector 8, and is output to the memory 12. On the other hand, when the address of the write data included in the full-write request is not identical with the address of the write data included in the previous full-write request which is held in the flip-flop circuit 23, the request determiner/address comparator 22 outputs the data selection signal and the write data to the selector 8. Thereby, the write data is output to the memory 12.
When the partial-write request is input to the request arbiter 21, the request arbiter 21 notifies the request determiner/address comparator 22 of the input of the partial-write request. The request determiner/address comparator 22 compares an address of the write data included in the partial-write request with an address of the write data included in the previous partial-write request which is held in the flip-flop circuit 23. When the address of the write data included in the partial-write request is identical with the address of the write data included in the previous partial-write request which is held in the flip-flop circuit 23, the request determiner/address comparator 22 outputs the write data and the mask data to the merge circuit 5, and outputs the data RAM RE signal to the data RAM 3. Thereby, a rewritten part of the data held in the data RAM 3 is specified by the mask data, and the data held in the data RAM 3 and the write data are merged. In this case, in the partial-write, the memory read operation does not need to be performed, and hence the throughput of memory writing can be improved.
On the other hand, when the address of the write data included in the partial-write request is not identical with the address of the write data included in the previous partial-write request which is held in the flip-flop circuit 23, the request determiner/address comparator 22 outputs the read request to the CPU 11, outputs the data selection signal and the write data to the selector 8, outputs the data RAM WE signal to the data RAM 3, and outputs the mask data and the mask RAM WE signal to the mask RAM 4. Thereby, until the control circuit 2 receives the read data corresponding to the read request, the write data is held in the data RAM 3 and the mask data is held in the mask RAM 4. In this case, the control circuit 2 can process another request during waiting time of the read data, so that the throughput of data writing can be improved.
First, the control circuit 2 determines whether the control circuit 2 has received the merge data (step S21). When the control circuit 2 has received the merge data (YES in step S21), the control circuit 2 outputs the data selection signal for selecting the merge data to the selector 8, outputs the data RAM WE (Write Enable) signal to the data RAM 3, and writes the merge data into the data RAM 3 and the memory 12 (step S22).
On the other hand, when the control circuit 2 has not received the merge data (NO in step S21), the control circuit 2 determines whether the control circuit 2 has received the read data (step S23). When the control circuit 2 has received the read data (YES in step S23), the control circuit 2 outputs the data RAM RE (Read Enable) signal for reading out the write data to be merged with the read data to the data RAM 3, outputs the mask RAM RE signal for reading out the mask data to the mask RAM 4, and outputs the read data to the merge circuit 6. Thereby, the write data held in the data RAM 3, the mask data held in the mask RAM 4, and the read data are output to the merge circuit 6. Then, a rewritten part of the data held in the data RAM 3 is specified by the mask data, and the data held in the data RAM 3 and the read data are merged (step S24). Then, the procedure returns to step S21.
When the control circuit 2 has not received the read data (NO in step S23), the control circuit 2 performs processing of a request (step S25). Specifically, the request arbiter 21 selects a request to be processed. Next, the control circuit 2 determines whether the request to be processed is the partial-write request (step S26). When the request to be processed is the partial-write request (YES in step S26), the request determiner/address comparator 22 in the control circuit 2 receives the partial-write request (step S27). Then, the request determiner/address comparator 22 in the control circuit 2 compares the address of the write data included in the partial-write request with the address of the write data included in the previous partial-write request which is held in the flip-flop circuit 23 (step S28).
When the address of the write data included in the partial-write request is identical with the address of the write data included in the previous partial-write request which is held in the flip-flop circuit 23 (YES in step S28), the request determiner/address comparator 22 outputs the write data and the mask data to the merge circuit 5, and outputs the data RAM RE signal to the data RAM 3. The merge circuit 5 specifies a rewritten part of the data held in the data RAM 3 by using the mask data, and merges the data held in the data RAM 3 and the write data (step S29). Then, the procedure returns to step S21.
On the other hand, when the address of the write data included in the partial-write request is not identical with the address of the write data included in the previous partial-write request which is held in the flip-flop circuit 23 (NO in step S28), the request determiner/address comparator 22 outputs the data selection signal and the write data to the selector 8, outputs the data RAM WE signal to the data RAM 3, and outputs the mask data and the mask RAM WE signal to the mask RAM 4. As a result, the data RAM 3 holds the write data, and the mask RAM 4 holds the mask data (step S30). The request determiner/address comparator 22 outputs the read request to the CPU 11 (step S31). Then, the procedure returns to step S21.
When the request to be processed is not the partial-write request in step S26, i.e., the request to be processed is the full-write request (NO in step S26), the request determiner/address comparator 22 compares the address of the write data included in the full-write request with the address of the write data included in the previous full-write request which is held in the flip-flop circuit 23 (step S32).
When the address of the write data included in the full-write request is identical with the address of the write data included in the previous full-write request which is held in the flip-flop circuit 23 (YES in step S32), the request determiner/address comparator 22 outputs the data selection signal and the write data to the selector 8, and outputs the data RAM WE (Write Enable) signal to the data RAM 3. Thereby, the write data is overwritten in the data RAM3 (step S33). The write data is written into the memory 12 (step S34). On the other hand, when the address of the write data included in the full-write request is not identical with the address of the write data included in the previous full-write request which is held in the flip-flop circuit 23 (NO in step S32), the request determiner/address comparator 22 outputs the data selection signal and the write data to the selector 8. Thereby, the write data is written into the memory 12 (step S34).
As described above, according to the present embodiment, when the partial-write is not continuously performed to the same address (NO in step S28 and step S30), the write data is held in the data RAM 3 and the mask data is held in the mask RAM 4 until the control circuit 2 receives the read data corresponding to the read request. Therefore, although in the conventional partial-write of
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present invention have been described in detail, it should be understood that the various change, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
This application is a continuation application of International Application PCT/JP2011/050888 filed on Jan. 19, 2011 and designated the U.S., the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2011/050888 | Jan 2011 | US |
Child | 13927140 | US |