Data is communicated through two separate circuits or circuit groups, each having clock and mode inputs, by sequentially reversing the role of the clock and mode inputs. The data communication circuits have data inputs, data outputs, a clock input for timing or synchronizing the data input and/or output communication, and a mode input for controlling the data input and/or output communication. A clock/mode signal connects to the clock input of one circuit and to the mode input of the other circuit. A mode/clock signal connects to the mode input of the one circuit and to the clock input of the other circuit. The role of the mode and clock signals on the mode/clock and clock/mode signals, or their reversal, selects one or the other of the data communication circuits.
|
1. A process of selecting first and second test access port circuits with first and second signals that each can be in first and second states, comprising:
A. placing the first circuit in a communication state and placing the second circuit in an idle state;
B. maintaining the first signal in the first state to maintain the first circuit in the communication state while clocking the second signal from the second state to the first state and back to the second state to operate the first circuit in the communication state;
B. then changing the first signal to and maintaining the first signal in the second state while the second signal is in the second state and clocking the second signal from the second state to the first state and back to the second state at least once to move the first circuit into an idle state;
C. then changing the second signal to and maintaining the second signal in the first state while the first signal is in the second state and clocking the first signal from the second state to the first state and back to the second state at least once to move the second circuit into a communication state; and
D. then maintaining the second signal in the first state to maintain the second circuit in the communication state while clocking the second signal from the second state to the first state and back to the second state to operate the second circuit in the communication state.
2. The process of
3. The process of
|
This application is a divisional of prior application Ser. No. 10/114,572, filed Apr. 2, 2002, now U.S. Pat. No. 6,944,247, issued Sep. 13, 2005;
Which was a divisional of prior application Ser. No. 09/443,186, filed Nov. 19, 1999, now U.S. Pat. No. 6,393,081, granted May 21, 2002;
Which claimed priority from Provisional Application Ser. No. 60/109,880, filed Nov. 25, 1998.
1. Field of the Invention
Circuits that communicate data may have data inputs for inputting data, data outputs for outputting data, a clock input for timing or synchronizing the data input and/or output communication, and a mode input for controlling the data input and/or output communication.
2. Description of the Related Art
In
While the circuit example in
In
In the idle state, no data communication occurs in the circuit from the data input and/or data output. In the communicate state, data communication occurs in the circuit 110 from the data input and/or data output. It should be understood that the state diagram of
In
The communicate state could operate a circuit as shown in
In this specification, the mode input is evaluated on the rising edge of the clock input to determine state transitions. Also, the clock input will operate as a low to high and high to low pulse that occurs during times when the mode input is in a steady state one or zero logic condition. While a rising edge clock pulse convention is used in this description, a falling edge clock pulse convention could be used as well. Also the mode inputs may be inverted from what is shown in
The present invention provides a way to communicate data through two separate circuits or circuit groups, each having clock and mode inputs, by sharing and reversing the role of the clock and mode inputs.
A first advantage of the present invention is that it provides a method of augmenting a second data communication protocol on a pair of control signals, clock and mode, originally designed to use only a first data communication protocol. A second advantage of the present invention is that it provides a method of designing new circuits to utilize first and second data communication protocols on the same control signal wiring. A third advantage of the present invention is that it reduces the wiring required for communicating data through separate circuits, since the clock and mode input wiring, as well as the data input and data output wiring, may be shared between the separate circuits.
A fourth advantage of the present invention is that it provides a method of accessing backup or redundant circuitry in a fault tolerant system environment by reuse of the same control bussing for accessing either the primary or backup circuitry. A fifth advantage of the present invention is that it provides a method of accessing shadow circuitry, i.e. special circuitry used by the manufacturer or end user for test, debug, diagnostics, emulation, or software development, by reuse of the same control bussing for accessing either the functional or shadow circuitry.
The circuits described herein could represent; (1) a printed circuit board, (2) an integrated circuit, or (3) individual sub-circuits within an integrated circuit.
In
The naming convention given to the clock/mode signal on connection 403 and the mode/clock signal on connection 404 is used to indicate that each signal is shared for providing two input functions. During the first input function, the clock/mode and mode/clock signals form a signal pair used to operate circuit 1's clock and mode inputs, respectively, according to the example state and timing diagrams of
The data input 101 connections and data output 102 connections of circuit 1 and circuit 2 may also be shared, as indicated by the dotted lines 405 and 406. Sharing data input and data output connections further reduces wiring area overhead. If the connections are shared, the operating circuit will input and/or output data via the shared connections. The non-operating circuit will remain idle and will disable its data outputs to avoid contention with the data outputs from the operating circuit.
If the data inputs and/or outputs of the circuits differ in that, for example, circuit 1 inputs analog signal data and circuit 2 inputs digital data, separate data inputs to the circuits will be maintained, as indicated by dotted line 407. Similarly, separate outputs will be maintained as indicated by dotted line 408 if, for example, circuit 1 outputs digital data and circuit 2 outputs analog signal data.
In
The first role reversal of the mode/clock and clock/mode signal pair between operating circuit 1 and operating circuit 2 is seen to occur between times B and C. The second role reversal of the mode/clock and clock/mode signal pair between operating circuit 2 and operating circuit 1 is seen to occur between times D and E. While the example of
During access of circuit 1, between points A and B, the clock/mode signal acts as a clock input and the mode/clock signal acts as a data input. During access of circuit 2, between points C and D, the clock/mode signal acts as a data input and the mode/clock signal acts as a clock input. From this it is seen that both of the signals are being used as both a clock input to one circuit and a data input to the other circuit. The timing between the two signals needs to be designed such that when one circuit is being accessed, the other circuit remains idle.
For example, at the beginning of a circuit 1 access, i.e. transition between idle 1 and communicate 1 states, the mode/clock signal transitions from low to high while the clock/mode signal is low. The low to high transition on mode/clock is received by circuit 2 as a clock input transition, but since clock/mode is low during the low to high transition of mode/clock, circuit 2 remains in the idle 2 state, as shown in the
Similarly, at the beginning of a circuit 2 access, i.e. transition between idle 2 and communicate 2 states, the clock/mode signal goes from low to high while the mode/clock signal is low. The low to high transition on clock/mode is received by circuit 1 as a clock input transition, but since mode/clock is low during the low to high transition of clock/mode, circuit 1 remains in the idle 1 state. Thus, as circuit 2 is accessed, circuit 1 remains idle
In general, this role reversal timing works on any type of circuit 1 and circuit 2 arranged as shown in
The example of
The example of
In the timing diagram of
In
In
In
In
In
The clock/mode signal bus 403 is connected to the clock input of selection circuit 910, one input of And gate 940, and to one input of And gate 950. The mode/clock signal bus 404 is connected to the mode input of selection circuit 910, the clock input of circuit 1, and the clock input of circuit 2. The other input of And gate 940 is connected to an enable circuit 1 (EC1) signal output from selection circuit 910. The other input of And gate 950 is connected to an enable circuit 2 (EC2) signal output from selection circuit 910. The output of And gate 940 is connected to the mode input of circuit 1, and the output of And gate 950 is connected to the mode input of circuit 2.
Circuits 1 901 and circuit 2 902 operate according to the state diagrams previously described in regard to
The circuit arrangement 900 operates, using the role reversal technique described previously in regard to
Following data communication to selection circuit 910, either the EC1 signal will be set high and EC2 signal will be set low to allow access of circuit 1 via And gate 940, or the EC2 signal will be set high and the EC1 signal will be set low to allow access of circuit 2 via And gate 950. When EC1 is high, and a role reversal of the clock/mode and mode/clock signals occurs, from accessing select circuit 910 to accessing circuit 1 or 2, the clock/mode signal will pass through And gate 940 to the mode input of circuit 1, to enable its access. Similarly, when EC2 is high, and a role reversal of the clock/mode and mode/clock signals occurs, from accessing select circuit 910 to accessing circuit 1 or 2, the clock/mode signal will pass through And gate 950 to the mode input of circuit 2, to enable its access.
When circuit 1 is being accessed, circuit 2 will be forced to remain idle by the low EC2 input to And gate 950. Likewise, when circuit 2 is being accessed, circuit 1 will be forced to remain idle by the low EC1 input to And gate 940. The data outputs of select circuit 910, circuit 1, and circuit 2 are disabled when the circuits are idle and are enabled when they are accessed. Thus only the accessed circuit drives the data output buss 102.
From the above it is seen that during a first role of the clock/mode and mode/clock signals, communication with the selection circuit 910 occurs, and during a second role of the clock/mode and mode/clock signals, communication to either circuit 1 or circuit 2 occurs, depending on the settings of EC1 and EC2. The selection circuit 910 serves to amplify the number of circuits that can be accessed using the role reversing control input technique. While two circuits, i.e. circuit 1 and 2, are shown to be selectively enabled to operate in response to a role reversal of clock/mode and mode/clock, any number of circuits could be selectively enabled to operate as well.
For example, selectively accessing one of twenty circuits, like circuits 1 and 2, would simply require twenty EC signal outputs (EC1–EC20) from the selection circuit 910, each EC signal enabling or disabling access to each of the twenty circuits via an And gate as shown in arrangement 900.
Further, the arrangement 900 could be altered to where a group of serially connected circuits, such as a group of serially connected circuit is, could be selected by a single EC signal and accessed at the same time. A group of serially connected circuit is would be connected such that the data output of a leading circuit 1 feeds the data input of trailing circuit 1. Also, the first circuit 1 of the group would input from the data input bus 101 while the last circuit 1 of the group would output onto the data output bus 102. Such a group of serially connected circuit is would have a common first connection at their clock inputs and a common second connection at their mode inputs. It should be clear that other circuit 1 and/or circuit 2 selection and access arrangements are possible as well.
In
The 1-bit update register 1015 is connected to the output bus 1060 and to the control input bus 1050. The update register 1015 outputs the EC2 signal on bus 1070 to the input of inverter 1040 and to the capture input of the shift register 1010. Inverter 1040 outputs the EC1 signal. The state machine 1020 has a clock input from clock/mode bus 403 and a mode input from mode/clock bus 404. The state machine 1020 outputs control to the shift register 1010, update register 1015, and 3-state buffer 1030. When enabled, the 3-state buffer 1030 outputs data onto data output bus 102. Circuits 1 and 2 of arrangement 900 are assumed to also contain 3-state output buffers that can be enabled to output data onto data output bus 102 when they are accessed.
In
The state machine returns to the idle state following the update state. The data loaded into the update register is output from selection circuit 910 on the EC1 and EC2 outputs. If a logic zero was shifted in and updated, EC1 is high to enable circuit 1 of arrangement 900 and EC2 is low to disable circuit 2 of arrangement 900. If a logic one was shifted in and updated, EC1 is low to disable circuit 1 and EC2 is high to enable circuit 2. The update register 1015 prevents data transitions on the EC1 and EC2 outputs as data shifts through the shift register 1010 during the shift state.
In
In regard to
In
The differences between the arrangements 1200 and 900 include; (1) a test data input (TDI) signal is connected to input serial data on data input bus 101, (2) a test data output (TDO) signal is connected to output serial data on data output bus 102, (3) a role reversing test clock/test mode select (TCK/TMS) signal is connected to input on control bus 403, (4) a role reversing test mode select/test clock (TMS/TCK) signal is connected to input on control bus 404, (5) a TAP 1 1220 is substituted for circuit 1 901, and (6) a TAP 2 1220 is substituted for circuit 2 902.
The IEEE 1149.1 standard defines the TAP circuit 1220 and the way the TAP operates in response to its local TMS 1240, TCK 1242, TDI 1241, and TDO 1243 signals. To the invention, the TAP 1 and TAP 2 are viewed as just another type of circuit that can be selected and accessed as previously described in regard to
The simplicity of using the role reversing control input technique to either access the selection circuit 910 to select a TAP, or to access the TAP selected is an important aspect of the present invention. Implementers of this invention will appreciate this simplicity. The low overhead of using the role reversing control input technique in combination with the selection circuit 910 will also be appreciated, since the silicon overhead for the selection circuit 910 is very small, and no additional busing wires, beyond the TDI bus 101, TDO bus 102, TCK/TMS bus 403, and TMS/TCK bus 404, are required to interface a TAP controller up to any number of TAPs 1220.
In
The control output on bus 1320 from the selection circuit comes from the update register 1015 which is loaded following a shift operation through the shift register 1010 as previously described in regard to selection circuit 910. The control can be either decoded locally within the selection circuit 910, as previously described, or it can be output directly from the update register 1015 and decoded within the programmable TAP connection circuitry 1310.
In response to control output from the selection circuit 910, the programmable TAP connection circuitry 1310 can connect any TAP to TDI bus 101, TDO bus 102, TCK/TMS bus 403, and TMS/TCK bus 404 as previously described in
The operation of the circuit arrangement 1300 is very similar to that described in
While TAPs 1220 were shown in
In
When the first chain of TAPs is accessed, the second chain of TAPs remain idle. When the second chain of TAPs is accessed, the first chain of TAPs remain idle. The two chains may contain other types of circuits 1-N and 1-M, instead of TAP circuits. Also, the data input and output width of chains containing other circuit types may differ, as previously mentioned.
In
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
5745742, | Dec 19 1995 | Bull HN Information Systems Inc. | Apparatus for coordinating clock distribution in a fully redundant computer system |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Aug 05 2005 | Texas Instruments Incorporated | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Jul 02 2010 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jul 25 2014 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jul 16 2018 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Feb 20 2010 | 4 years fee payment window open |
Aug 20 2010 | 6 months grace period start (w surcharge) |
Feb 20 2011 | patent expiry (for year 4) |
Feb 20 2013 | 2 years to revive unintentionally abandoned end. (for year 4) |
Feb 20 2014 | 8 years fee payment window open |
Aug 20 2014 | 6 months grace period start (w surcharge) |
Feb 20 2015 | patent expiry (for year 8) |
Feb 20 2017 | 2 years to revive unintentionally abandoned end. (for year 8) |
Feb 20 2018 | 12 years fee payment window open |
Aug 20 2018 | 6 months grace period start (w surcharge) |
Feb 20 2019 | patent expiry (for year 12) |
Feb 20 2021 | 2 years to revive unintentionally abandoned end. (for year 12) |