Information
-
Patent Application
-
20030198287
-
Publication Number
20030198287
-
Date Filed
March 20, 200321 years ago
-
Date Published
October 23, 200321 years ago
-
Inventors
-
Original Assignees
-
CPC
-
US Classifications
-
International Classifications
Abstract
A converter circuit for performing transfer of control logic signals between a first device and a second device in connection with an interconnection bus, the first device operating at the frequency of a first clock signal and the second device operating at the frequency of a second clock signal. The clock frequencies may be in a first ratio to one another corresponding to unity, as well as in a second and a third ratio. The converter circuit includes manipulation circuit elements which define respective propagation paths through the converter circuit for control signals. A logic network may assume three states, corresponding, respectively, to the first, second and third ratios between the frequencies of the clock signals, selectively interposing the manipulation elements in the propagation paths.
Description
FIELD OF THE INVENTION
[0001] The present invention relates to frequency converters, and more particularly to frequency converters for interconnect bus Systems.
BACKGROUND OF THE INVENTION
[0002] Complex digital systems are normally made up of a certain number of devices (cores, peripheral memories, etc.), which exchange information. Frequently, such devices operate at different clock frequencies, with frequencies that may be defined as semi-synchronous, in the sense that they refer to clocks of different value but with certain given phase relations between them. For example, the interconnection system developed by the present Assignee under the commercial name STBus Interconnect can be used in conjunction with the CPU known as ST40, also produced by the present Assignee.
[0003] Such a CPU needs to be able to operate on the basis of different frequency ratios, namely in conditions in which the clock of the interconnection system has a ratio of 2/3, one half, or equal to the clock of the CPU. Under such conditions, there exists the need to have available a synchronization mechanism that is able to adequately synchronize the two clock domains (i.e. that of the CPU and that of the interconnection bus), at the same time reducing occupation of space on the chip and preventing latency phenomena from arising.
[0004] No currently known approach is able to provide a satisfactory synchronization. For example, the approach known as “asynchronous bridge” corresponds to a frequency converter of altogether general application. This approach, however, involves intrinsic drawbacks, linked, for instance, to the control circuitry (which is somewhat complex), to the occupation of space (which is, in turn, linked both to the complexity of the control logic and to the use of memory elements), as well as to latency phenomena (due to the use of stages that carry out a re-timing function).
[0005] Another known approach is the one known as “dual-port memory”. This is simply a memory that implements a queue of a first-in first-out (FIFO) type, with the use of two distinct pointers, one for loading the data and the other for reading the data. However, also this approach presents intrinsic drawbacks linked to the use of memory elements and latency.
[0006] There are then known devices that are generically referred to as synchronizers, which include networks of specific flip-flops appropriately connected together. This approach entails a smaller occupation of area on the chip, but is not exempt from the drawback of latency associated to the presence of re-timing stages.
SUMMARY OF THE INVENTION
[0007] The present invention provides a frequency converter that is able to meet the requirement of ensuring synchronization between two clock domains, to overcome the difficulties and drawbacks outlined above.
[0008] According to the present invention, it is possible to achieve the a relatively high level of throughput without introducing undesired latency. The circuit is very simple and does not occupy an extensive area on the silicon. It has a reduced effect on the critical path-timing functions and may be used or re-used at any point of interaction between different clock domains.
[0009] In particular, the approach according to the invention includes, in the currently preferred embodiment, just two clock domains in phase with respect to one another, with the possibility of obtaining the frequency ratios 1/1, 1/2, 2/3. The maximum throughput possible is achieved (that of the slowest clock), with a minimal effect on the area of chip used. This prevents any latency from arising in the generation of all the control signals coming from a given clock domain prior to their being sent to the other clock domain.
BRIEF DESCRIPTION OF THE DRAWINGS
[0010] The present invention will now be described, purely by way of non-limiting example, with reference to the attached drawings, in which:
[0011]
FIG. 1 is a general block diagram which illustrates the context of application of the approach according to the invention.
[0012] FIGS. 2 to 8 show various timing diagrams which illustrate the approach according to the invention.
[0013]
FIG. 9 is a block diagram of an embodiment of a frequency converter according to the invention.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
[0014] As a foreword to the following description of some examples of an embodiment of the invention, it may be useful, for reasons of clarity, to recall the definitions of some terms used in the following. As already mentioned in the introductory part of the present description, the approach according to the invention has been developed with particular regard to its possible use in the framework of the system developed by the present Assignee under the commercial name STBus. The STBus system is a set of protocols, interfaces, primitives, and architectures that specify an interconnection subsystem that is versatile in terms of performance features, architecture and implementation. Defined as STBus node is an interconnection system based on the STBus protocol, to which certain given ports are connected. An STBus node is made up of two main blocks: the control block and the datapath block. The first block performs the arbitration function (i.e., the process whereby it is decided which initiator can assume control of the system buses according to the priority of the initiator and the arbitration scheme implemented or selected), whereas the second block is the routing network, through which the data flow.
[0015] It should be recalled that, according to current terminology, an “initiator” is defined as any device that accesses the system resources through the bus. This occurs typically via a port of the initiator, which sends request packets and receives response packets. Defined, instead, as “target” is a resource of the system, to which the initiators gain access through the bus. Generally this occurs via a target port, which receives request packets and sends response packets. To connect two different nodes of the STBus system together, it is possible to use buffer elements or buffer modules, which include re-timing blocks that are able to function as targets for the first node and as initiators for the second node. When the need arises, a buffer can also be used as a generic re-timing stage.
[0016] As far as the conversion function proper is concerned, defined as “size converter” is a block that can act as adaptor between two environments (such as, for example, two STBus nodes) having different bus data dimensions. The type converter is instead a block that can act as an adaptor between two blocks that follow two different types of STBus protocol, such as an initiator and a node, or else a node and a target. The protocol converter is, instead, a block that can act as an adaptor between two blocks that follow different protocols, for example, the AMBA protocol and the STBus protocol. It should be recalled that a protocol is a set of rules that the initiators and targets must follow during a transaction, the rules being expressed in terms of signal management—assertion and de-assertion—during a transaction, identified essentially by a request packet and by the respective response packet.
[0017] A “packet”, in the present context, is a set of cells, where the cell identifies the database quantity that can be transferred onto the bus during a single clock cycle. The dimensions of the cell identify the size of the data bus. The last cell of the packet is characterized in that the end-of-packet (EOP) signal assumes a given logic level, such as a high logic level. Finally, a “message” is a set of packets with the last packet characterized by a corresponding logic level, for example, the fact that a signal called “not-end-of-message”, is at the low logic level. A “port” or “programming port” is the entity IP which enables access to the internal registers of the bus to program the arbitration scheme of the programmable arbitrator elements. In this context, a “frequency converter” is therefore a block that is able to act as an adaptor between two blocks that operate at different clock frequencies.
[0018] Hence, in the block diagram of FIG. 1, the reference number 1 designates as a whole the context of the bus (such as, for example, the STBus) in which the subsequent transactions are carried out between devices functioning as initiators and targets. As is well-known to persons skilled in the art, the same element can function perfectly well at different instants, both as an initiator and as a target in the framework of the bus.
[0019] The diagram represented in FIG. 1 refers to an element functioning as an initiator, and designated by 2; this consists, for instance, of a CPU, such as a CPU ST40, timed by a first clock signal (cpu_clock) designated as clock_1. The diagram of FIG. 1 then illustrates an element functioning as a target, this being designated by 3 and including, in the example illustrated (which, it is emphasized, is purely an example), of an STBus Interconnect system timed by a second clock signal (Interconnect_clock) designated as clock_2. It is likewise assumed that, between the two elements 2 and 3, a transaction is performed that corresponds to the exchange of data, designated as a whole by D.
[0020] To be able to carry out the transaction properly (assuming that, in general, the frequencies of the two signals clock_1 and clock_2 can be different from one another), it is necessary to perform a frequency-conversion function between the two clocks in question. The above is achieved via a block functioning as frequency converter and designated as a whole by 4. To operate in this way, the block 4 receives (in general, from the outside world) information regarding the following entities:
[0021] the frequency of one of the clocks in question: in the example illustrated, the signal clock_1 is assumed;
[0022] the ratio existing between the frequencies of the two signals clock_1 and clock_2 (information supplied to the converter 4 through the signal speed_sel); and
[0023] a general synchronization signal designated as synch.
[0024] The aforesaid signals are generated and supplied according to criteria in themselves known, which do not call for any description herein, also because they are not important for the purposes of understanding the present invention.
[0025] Specifically, the information regarding the frequency ratio is vehicled by the signal speed_sel on the basis of the following table:
1|
|
speed—speed—
sel (1)sel (0)clock_2
|
00clock_1
10⅔ clock_1
01⅓ clock_1
11NOT
ALLOWED
|
[0026] The signal synch carries, instead, the information regarding the phase relation between the two clock signals.
[0027] In fact, even though the two clock signals are mutually in phase, they may have a frequency ratio different from 1 (clock_1=clock_2). This means, for example, that according to the faster clock (for example, clock_1) the second clock (clock_2) can present—according to the relation existing between the frequencies of the two clocks—rising edges that coincide with the rising edges of the faster clock. In this case, it is necessary to know the clock period (referred, in general, to the faster clock, here assumed as being clock_1), in which the rising edges coincide.
[0028] The information is carried precisely by the synch signal, which is set at “1” when the rising edges of the two clocks coincide and remains at level “1” only for one clock cycle referred to the faster clock, on the basis of the diagrams represented in FIGS. 2 and 4, to which we shall return later. In this connection, it will be noted that what has been said with reference to the rising edges is given purely by way of example and corresponds to a preferred embodiment of the present invention. The same ideas set forth herein likewise apply in an identical way also to the falling edges.
[0029] The situation represented in FIG. 2 corresponds to the situation in which the two signals clock_1 and clock_2, in addition to presenting the same frequency, are also exactly in phase with one another. In this case, the two signals in question are identical to each other (in practice, they are the same signal), and the synch signal is, in practice, meaningless. Since the two clock signals form exactly the same signal, the signals generated starting from one of the clock signals can be sampled through the other clock signal, without this giving rise to any problems. In this case, the synch signal remains constantly at level “0”.
[0030]
FIG. 3 represents, instead, a situation in which the second signal clock_2 presents a frequency exactly equal to one half of the frequency of the signal clock_1. In this case, the synch signal is at level “1” for a period of the signal clock_1 and at level “0” for the subsequent period of the same signal clock_1. In practice, in this case the synch signal has the same pattern as the signal clock_2.
[0031] The example in FIG. 4 refers, instead, to the situation in which the signal clock_2 has a frequency equal to 2/3 of the frequency of the signal clock_1. In this case, the synch signal remains at level “1” for a period of the signal clock_1 and then passes to “0” in the next two periods. In other words, in the situation represented in FIG. 4, the synch signal is at the logic level “1” for one period out of three of the signal clock_1. This situation proves critical in that, as presented in FIG. 4, there may occur violations of the set-up time in the case of data generated on the rising edge of the signal clock_1 and latched in the target block with the rising edge of the signal clock_2 that immediately follows.
[0032] There now follows a description of the interventions that block 4 of FIG. 1 must make, via the initiator interface II and the target interface TI so as to send corresponding control signals CSI and CST to the initiator 2 and to the target 3. In the case represented in FIG. 2, i.e., when the two signals clock_1 and clock_2 have the same frequency, the conversion block 4 does not need to carry out any intervention of manipulation on the control signals in question in these conditions; i.e., the converter 4 proves to be in effect “transparent” to the signals.
[0033] In what follows, the conditions of FIGS. 3 and 4 are considered, i.e., the conditions in which the two clock signals have different frequencies. For reasons of simplicity of treatment, we shall first deal with the case in which the frequency of the signal clock_2 is equal to 2/3 of the frequency of the signal clock_1, it being understood that all the signals in which the suffix “_1” appears refer to the signal clock_1 (which will be assumed as being the faster), while the signals with suffix “_2” refer to the signal clock_2.
[0034] This situation is represented in detail in FIG. 5, which refers to a transaction forwarded by the initiator 2, which sends to the target 3 a request signal req_1, assumed to be active when it is high. Specifically, FIG. 5 illustrates the control signals exchanged between the two blocks on the direct communication path. The hypothesis is that the target 3 is always ready to receive any action whatsoever activated by the initiator block 2, this being indicated by the transition of the signal gnt_2 to the logic level “1”. If the signal req_1 is generated at instant A (period 1), the frequency converter 4 transfers this request to the target 3 (signal req_2 high, hence active), without any manipulation.
[0035] Availability of the target block 3 (given by the signal gnt_2, which is active and hence at a high level) is masked by the frequency converter for one clock cycle of the signal clock_1 (period 1), before it is sent to the initiator block (gnt_1). This is due to the fact that the initiator block 2 considers the action activated previously to be completed at the start of period 2 (rising edge of clock_1), all the information being removed from the bus, and the target block 3 being set in conditions of not receiving the action (in fact, the target block 3 takes into consideration the action activated by the initiator block 2 only at point B).
[0036] Thus, to guarantee a correct exchange of information, the signal gnt_1 is supplied to the initiator block 2 in period 2 of the signal clock_1, just as is illustrated in FIG. 5. If the signal req_1 is generated at the starting point C, the frequency converter blocks it for one cycle of clock_1 before sending it to the target block 3. In this case, the signal req_1 is sent to the target block 3 in period 6, this being due to the fact that the target block 3 takes the signal req_1 into account at the rising edge of the signal clock_2, i.e., at point E. The distance between the rising edges of the two clock signals is, in this case, critical in so far as there may occur a violation of the set-up time in target block 3.
[0037] To obtain a quantitative idea, the distance between the rising edges of the two clocks can be evaluated, in this particular case, with reference to a case in which the signal clock_1 has a frequency of 166 MHz (corresponding to a period of approximately 6 nanoseconds) and the signal clock_2 has a frequency of 110 MHz (corresponding to a period of approximately 9 nanoseconds). In this case, the value of the difference is equal to 3 nanoseconds. Regarding the signal gnt_1, this is treated as described in the previous case.
[0038] The diagram of FIG. 6 refers to the control signals exchanged between the two blocks on the response path. In this case, the target block 3 responds to an action activated by the initiator block 2 (signal req_2 active, since it is high) at the starting instant A. This response is sent directly to the initiator block 2 (r_req_1) without any action of translation whatsoever (i.e., it is simply appropriately cut). The initiator block 2 takes this response into account at the rising edge of the signal clock_1, correlated to the start of period 2. The target block 3 de-activates the signal r_req_2 at point B. If the signal r_req_2 is generated at the starting point E (see again FIG. 6), it cannot be supplied directly to the initiator block 2 (r_req_1), since the initiator block 2 would seek to sample this response signal at point F (according to its clock frequency), clearly violating the set-up time, as already described with reference to FIG. 5. Thus the signal r_req_2 is masked for one half of a cycle of the signal clock_1, so making it available to the initiator block 2 at instant G (period 6).
[0039] The same considerations apply with reference to the situations represented in FIGS. 7 and 8. In the specific case, FIG. 7 refers to a situation in which the frequency of the signal clock_2 is equal to 2/3 of the frequency of the signal clock_1, with consecutive accesses. FIG. 7 represents the control signals exchanged between the two blocks 2 and 3 on the direct path and on the response path. In this case, the same considerations made with reference to FIG. 6 also apply here, taking into account the behavior of the frequency converter 4 for preventing the critical period (i.e., the one in which there may be a violation of the set-up time). It is important to note that, in all these cases, it is the frequency converter 4 that guarantees operation of the system at the maximum possible frequency (frequency of clock_2) without any latency.
[0040]
FIG. 8 refers, instead, to the control signals exchanged between the two blocks 2 and 3 on the direct path and on the response path in the case where the frequency of the signal clock_2 is equal to one half of the frequency of the signal clock_1, with a single access. This case is simpler as compared to the cases in which the ratio between the clock frequencies is equal to 2/3. Using the information of the synch signal, the transaction grant signal and the r_req signal coming from the target block 2 are appropriately cut in such a way as to prevent them from being sampled twice by the initiator 2. Also in this case, the frequency converter 4 guarantees operation of the system at the maximum frequency possible (the frequency of the signal clock_2), without any latency.
[0041] The block diagram of FIG. 9 illustrates the internal structure of the frequency converter 4. In the diagram in question, the reference numbers 10 and 12 designate the lines on which the signal speed_sel and the signal synch reach the converter 4. The reference numbers 14 to 24 indicate, instead, in order, the lines on which the following signals reach the converter 4 or else are emitted by the converter 4:
[0042] req_1, coming from the initiator 2;
[0043] gnt_1, sent to the initiator 2;
[0044] r_req_1, sent to the initiator 2;
[0045] req_2, sent to the target 3;
[0046] gnt_2, coming from the target 3; and
[0047] r_req_2, also coming from the target 3.
[0048] The lines 14, 16 and 18 belong to the domain of the signal clock_1, which functions as master, while the lines 20, 22 and 24 belong to the domain of the signal clock_2, which acts as slave.
[0049] Timing of the converter 4 is ensured by a timing input 26 on which the signal clock_1 is supplied (this having the higher frequency) designed to be distributed to three flip-flops designated by 28, 30 and 32. The reference numbers 34, 36 and 38 designate, instead, three AND gates, whereas the symbol “o” represents the operation of logic complementation. Finally, the reference numbers 40 and 42 designate two mux components associated to the flip-flops 28 and 30, which transfer one or other of the signals brought to their input to their output according to the logic level of the signal present on the respective control lines 40a and 42a.
[0050] In practice, when the lines 40a and 42a are at the logic level “0”, the flip-flops are by-passed, being excluded from the circuit. When the ratio between the frequencies of the signals clock_1 and clock_2 is equal to 1 (i.e., the synch signal set to “0”), the converter circuit 4 is practically transparent to the signals that traverse it, in the sense that the signal req_1 is copied into the signal req_2, the signal gnt_2 is copied into the signal gnt_1, and the signal r_req_2 is copied into the signal r_req_1.
[0051] In the case where the frequency of the signal clock_2 is equal to one half of the frequency of the signal clock_1, the synch signal practically copies the pattern of the signal clock_2, and the signal req_2 is, in effect, copied into the signal req_2 in so far as the signal present on line 42a is kept at the logic level “0”. The converter 4 intervenes, instead, on the signal gnt_2, causing the signal to be shifted, so to speak, on the rising edge into the signal gnt_1 downstream of the coinciding rising edges and falling edges of the signals clock_1 and clock_2. The same function is performed, this time in the case of the falling edge, in relation to the signal r_req_2 when this is transferred as r_req_1 to the initiator module 2.
[0052] In the case, instead, where the frequency of the signal clock_2 is equal to 2/3 of the frequency of the signal clock_1, the circuit of FIG. 9 provides, in the single access case and in the consecutive access case respectively, the timing charts represented in FIGS. 5 to 7, namely:
[0053] by masking the signal of availability of the target block 3 for one cycle of the signal clock_1 (see the delay imposed on the rising edge of the signal gnt_1 with respect to the rising edge of the signal gnt_2);
[0054] by masking, in a similar way, the signal req_1, blocking it for one cycle of the signal clock_1 if this is generated at point C; and
[0055] by cutting the signal r_req_2 or by masking it for one half of the cycle of the signal clock_1, if this is generated at point F, prior to forwarding it to the initiator block 2 as r_req_1.
[0056] From the block diagram illustrated in FIG. 9, it will be noted that the aforesaid cutting/delaying functions of one cycle of the signal clock_1 are ensured by the flip-flops 28, 30 and 32, while the logic gates 34, 36 and 38, as well as the mux elements 40 and 42, perform the dual function of:
[0057] configuration of the converter 4 for the different operating states described (ratio between the frequencies of the signals clock_2 and clock_1 equal to 1, 2/3 and 1/2); and
[0058] entry/de-entry of the manipulation elements represented by the flip-flops 28, 30 and 32 into/from the path of the various signals that traverse the converter 4.
[0059] Generally, the approach according to the invention is implemented in a converter circuit for performing transfer of control signals between a first device 2 and a second device coming under an interconnection bus, this being in conditions whereby the first device operates according to a first clock signal clock_1 at a first frequency and the second device operates according to a second clock signal clock_2 at a second frequency. These clock frequencies may be in a first ratio to one another corresponding to unity, as well as in a second and a third ratio, usually corresponding to 2/3 and 1/2, respectively.
[0060] The control signals comprise:
[0061] an access-request signal req_1, req_2 to be transferred from the first device to the second device;
[0062] a grant signal gnt_1, gnt_2 to be transferred from the second device to the first device; and
[0063] a response-to-request signal r_req_1, r_req_2 to be transferred from the second device to the first device.
[0064] The converter circuit comprises:
[0065] manipulation circuit elements (i.e., the flip-flops 28, 30 and 32) which identify respective propagation paths through the converter circuit for the access-request signal req_1, req_2, the grant signal gnt_1, gnt_1, and the response-to-request signal r_req_1, r_req_2; and
[0066] a logic network (including, in the example illustrated, of the elements 34 to 42), which can assume three states, corresponding, respectively, to the aforesaid first, second and third ratios between the frequencies of the clock signals clock_1 and clock_2, interposing selectively manipulation elements in the aforesaid propagation paths.
[0067] When the logic network is in the first state corresponding to the ratio of unity between the frequencies, the manipulation elements are uncommitted by the propagation paths, so that the access-request signal req_1, req_2, the grant signal gnt_1, gnt_2, and the response-to-request signal r_req_1, r_req_2 propagate through the converter circuit 4 in the substantial absence of manipulation.
[0068] When the logic network comes to be in the second state corresponding to the second ratio between the frequencies, the manipulation elements are interposed in the aforesaid propagation paths, in such a way that:
[0069] the request signal req_1, req_2 is selectively delayed in the transfer through the converter circuit 4 according to the logic levels assumed by the first clock signal and by the second clock signal at the instant of the request A, C;
[0070] the grant signal gnt_1, gnt_2 is delayed in traversing the converter circuit 4 according to the logic levels assumed by the first clock signal and by the second clock signal at the instant of grant signalling A, C, D1, D3; and
[0071] the response-to-request signal r_req_1, r_req_2 is delayed in traversing the converter circuit 4 according to the logic levels assumed by the first clock signal and by the second clock signal at the instant of response, so as to prevent a violation of the set-up time, the response-to-request signal r_req_1, r_req_2 being likewise shortened in time.
[0072] When the logic network comes to be in the aforesaid third state corresponding to the third ratio between the frequencies, the manipulation elements are uncommitted by the propagation path of the request signal req_1, req_2, so that the request signal propagates through the converter circuit 4 in substantial absence of manipulation. The aforesaid grant signal gnt_1, gnt_2 is, instead, subjected to delay in propagation through the converter circuit 4, while the response-to-request signal r_req_1, r_req_2 is shortened in time in traversing the converter circuit, to prevent double sampling by the first device. The arrangement is such that the converter operates at the maximum possible frequency in the absence of latency.
[0073] Of course, without prejudice to the principle of the invention, the details of construction and the embodiments may vary widely with respect to what is described and illustrated herein, without thereby departing from the scope of the present invention as defined in the attached claims.
Claims
- 1. A converter circuit for performing transfer of control signals between one first device (2) and one second device (3) coming under an interconnection bus, said first device (2) operating according to a first clock signal (clock_1) at a first frequency and said second device (3) operating according to a second clock signal (clock_2) at a second frequency, said clock frequencies being possibly in a first ratio to one another corresponding to unity, as well as in a second and a third ratio, and in which said control signals comprise:
an access-request signal (req_1, req_2) to be transferred from said first device (2) to said second device (3); a grant signal (gnt_1, gnt_2) to be transferred from said second device (3) to said first device (2); and a response-to-request signal (r_req_1, r_req_2) to be transferred from said second device (3) to said first device (2), characterized in that the converter circuit comprises:
manipulation circuit elements (28, 30 and 32) which identify respective propagation paths through the converter circuit (4) for said access-request signal (req_1, req_2), said grant signal (gnt_1, gnt_1), and said response-to-request signal (r_req_1, r_req_2); and a logic network (34 to 42) which can assume three states, corresponding, respectively, to said first, second and third ratios between the frequencies of said clock signals (clock_1, clock_2), interposing selectively manipulation elements (28, 30, 32) in said propagation paths, the arrangement being such that:
a) when the logic network is in the first state corresponding to said ratio of unity between the frequencies, said manipulation elements (28, 30 and 32) are uncommitted by said propagation paths, so that said access-request signal (req_1, req_2), said grant signal (gnt_1, gnt_2), and said response-to-request signal (r_req_1, r_req_2) propagate through the converter circuit (4) in substantial absence of manipulation. b) when said logic network comes to be in said second state corresponding to said second ratio between the frequencies, the manipulation elements (28, 30 and 32) are interposed in said propagation paths, in such a way that:
said request signal (req_1, req_2) is selectively delayed in the transfer through the converter circuit (4) according to the logic levels assumed by said first clock signal (clock_1) and by said second clock signal (clock_2) at the instant of the request (A, C); said grant signal (gnt_1, gnt_2) is delayed in traversing the converter circuit (4) according to the logic levels assumed by said first clock signal (clock_1) and by said second clock signal (clock_2) at the instant of grant signalling (A, C, D1, D3); and the response-to-request signal (r_req_1, r_req_2) is delayed in traversing the converter circuit (4) according to the logic levels assumed by said first clock signal (clock_1) and by said second clock signal (clock_2) at the instant of response (A, F; D1, D3) so as to prevent a violation of the set-up time, said response-to-request signal (r_req_1, r_req_2) being likewise shortened in time; and c) when said logic network (34 to 42) comes to be in said third state corresponding to said third ratio between the frequencies, said manipulation elements (28 to 32) are uncommitted by the propagation path of said request signal (req_1, req_2), so that said request signal propagates through the converter circuit (4) in substantial absence of manipulation;
said grant signal (gnt_1, gnt_2) is subjected to delay in propagation through the converter circuit (4); and said response-to-request signal (r_req_1, r_req_2) is shortened in time in traversing the converter circuit (4) in order to prevent its double sampling by said first device (2); the arrangement being such that the converter operates at the maximum possible frequency in the absence of latency.
- 2. The converter circuit according to claim 1, characterized in that said second ratio corresponds to a situation in which the frequency of said second clock signal (clock_2) is equal to 2/3 of the frequency of said first clock signal (clock_1).
- 3. The converter circuit according to claim 1 or claim 2, characterized in that said third ratio corresponds to a situation in which the frequency of said second clock signal (clock_2) is equal to one half of the frequency of said first clock signal (clock_1).
- 4. The circuit according to any one of the preceding claims, characterized in that said manipulation elements comprise delay elements (28, 30 and 32) that can apply, on the signals subject to them, a delay equal to one cycle of said first clock signal (clock_1).
- 5. The circuit according to any one of the preceding claims, characterized in that said manipulation elements are essentially constituted by flip-flops (28, 30, 32).
- 6. The circuit according to claim 5, characterized in that said flip-flops are timed with the frequency of said first clock signal (clock_1).
- 7. The circuit according to any one of the preceding claims, characterized in that said logic network comprises logic gates (34, 36 and 38) that are rendered sensitive to at least one signal chosen in the group consisting of:
a first signal (speed_sel) indicating said ratio between the frequency of said first clock signal (clock_1) and the frequency of said second clock signal (clock_2); a second signal (synch) indicating the phase relation between said first clock frequency (clock_1) and said second clock frequency (clock_2).
- 8. The circuit according to any one of the preceding claims, characterized in that said logic network comprises at least one mux element (40, 42), which is able to insert a respective manipulation element (28, 30) from the converter circuit.
Priority Claims (1)
Number |
Date |
Country |
Kind |
02425182.9 |
Mar 2002 |
EP |
|