Programmable High-Speed I/O Interface
Methods and apparatus for providing either high-speed, Or lower-speed, flexible inputs and outputs. An input and output structure having a high-speed input, a high-speed output, a low or moderate speed input, and an low or moderate speed output is provided. One of the input and output circuits are selected and the others are deselected. The high-speed input and output circuits are comparatively simple, in one example having only a clear signal for a control line input, and are able to interface to lower speed circuitry inside the core of an integrated circuit. The low or moderate speed input and output circuits are more flexible, for example, having preset, enable, and clear as control line inputs, and are able to support JTAG boundary testing. These parallel high and lower speed circuits are user selectable such that the input Output structure is optimized between speed and functionality depending on the requirements of the application.
This application is a continuation of U.S. patent application Ser. No. 14/449,521, filed Aug. 1, 2014, which is a division of U.S. patent application Ser. No. 13/925,482, filed on Jun. 24, 2013 (now U.S. Pat. No. 8,829,948), which is a division of U.S. patent application Ser. No. 13/149,168, filed on May 31, 2011 (now U.S. Pat. No. 8,487,665), which is a division of U.S. patent application Ser. No. 12/539,606, filed on Aug. 11, 2009 (now abandoned), which is a continuation of U.S. patent application Ser. No. 11/830,831, filed on Jul. 30, 2007 (now U.S. Pat. No. 7,586,341), which is a continuation of U.S. patent application Ser. No. 11/446,483, filed on Jun. 2, 2006 (now U.S. Pat. No. 7,315,188), which is a continuation of U.S. patent application Ser. No. 10/886,015, filed on Jul. 6, 2004 (now U.S. Pat. No. 7,116,135), which is a continuation of U.S. patent application Ser. No. 10/229,342, filed on Aug. 26, 2002 (now U.S. Pat. No. 6,825,698) which claims priority from provisional application Ser. No. 60/315,904, filed on Aug. 29, 2001, each of which are incorporated herein by reference in their entirety.
BACKGROUND OF THE INVENTIONThe present invention relates to input and output interfaces for integrated circuits, and more particularly to high performance interfaces that have a high degree of flexibility and configurability.
Electronic systems are becoming more complex as they handle increasingly difficult tasks. Accordingly, the amount of data transferred between integrated circuits in these systems continues to climb. At the same time, system designers want smaller, lower pin-count packages that consume less space on the system's printed circuit boards. Thus, very high data rates are desirable at integrated circuit input and output pins.
But it is also desirable for the circuits that form the input and output structures at these pins to be highly flexible. For example, sets, presets, and enables at registered inputs and outputs can ease the implementation of complicated logic functions, and JTAG boundary test access can simplify system diagnostics.
Unfortunately, increased flexibility results in slower circuits. The same transistors that add functions and increase multiplexing insert parasitic capacitances and resistances, slowing device performance. Increasing the configurability of an input and output interface decreases the maximum rate that the interface can process data. Also, to save power, integrated circuit designers want to use lower speed circuitry inside the integrated circuit.
Thus, what is needed is a highly flexible input and output interface that can also operate at high speed. For maximum utility, the interface should also be able to communicate efficiently with lower speed circuitry inside the integrated circuit.
SUMMARYAccordingly, embodiments of the present invention provide methods and apparatus for providing either high-speed, or lower-speed inputs and outputs. An input and output structure having a high-speed input, a high-speed output, a low or moderate speed input, and an low or moderate speed output is provided. One of the input and output circuits are selected and the others are deselected. The high-speed input and output circuits are comparatively simple, in one example having only a clear signal for a control line input, and are able to interface to lower speed circuitry inside the core of an integrated circuit. The low or moderate speed input and output circuits are more flexible, for example, having preset, enable, and clear as control line inputs, and are able to support JTAG boundary testing. These parallel high and lower speed circuits are user selectable such that the input output structure is optimized between speed and functionality depending on the requirements of the application.
One exemplary embodiment of the present invention provides an integrated circuit including a pad, a high-speed output buffer connected to the pad, and a low-speed output buffer also connected to the pad. The high-speed output buffer and the low-speed output buffer are selectably activated. When the high-speed output buffer is active, the low-speed output buffer is inactive, and when the low-speed output buffer is active, the high-speed output buffer is inactive.
This embodiment may further provide a first flip-flop connected to the high-speed output buffer, and a second flip-flop connected to the low-speed output buffer. The first flip-flop is configured to receive a first number of control signals and the second flip-flop is configured to receive a second number of control signals, the second number greater than the first number.
Another exemplary embodiment of the present invention provides an integrated circuit including a pad, a high-speed input buffer connected to the pad, and a low-speed input buffer also connected to the pad. The high-speed input buffer and the low-speed input buffer are selectably activated. When the high-speed input buffer is active, the low-speed input buffer is inactive, and when the low-speed input buffer is active, the high-speed input buffer is inactive.
This embodiment may further provide a first flip-flop connected to the high-speed input buffer, and a second flip-flop connected to the low-speed input buffer. The first flip-flop is configured to receive a first number of control signals and the second flip-flop is configured to receive a second number of control signals, the second number greater than the first number.
A further embodiment provides an integrated circuit including a high-speed output path. This path includes a first double-data rate register connected to a first output buffer. This integrated circuit also includes a low-speed output path having a second double-data register connected to a second output buffer, a high-speed input path having a third double-data rate register connected to a first input buffer, and a low-speed input path having a fourth double-data register connected to a second input buffer. The first output buffer, the second output buffer, the first input buffer, and the second input buffer are connected to a pad.
A better understanding of the nature and advantages of the present invention may be gained with reference to the following detailed description and the accompanying drawings.
In the particular embodiment of
Processing unit 101 may direct data to an appropriate system component for processing or storage, execute a program stored in memory 105 or input using I/O 111, or other similar function. Processing unit 101 may be a central processing unit (CPU), microprocessor, floating point coprocessor, graphics coprocessor, hardware controller, microcontroller, programmable logic device programmed for use as a controller, network controller, or other processing unit. Furthermore, in many embodiments, there is often no need for a CPU. For example, instead of a CPU, one or more PLDs 121 may control the logical operations of the system. In an embodiment, PLD 121 acts as a reconfigurable processor, which can be reprogrammed as needed to handle a particular computing task. Alternately, programmable logic device 121 may include a processor. In some embodiments, processing unit 101 may even be a computer system. Memory 105 may be a random access memory (RAM), read only memory (ROM), fixed or flexible disk media, PC Card flash disk memory, tape, or any other storage retrieval means, or any combination of these storage retrieval means. PLD 121 may serve many different purposes within the system in
LAB 200 has inputs and outputs (not shown), some of which may be consistent with the present invention, and which may or may not be programmably connected to a global interconnect structure, comprising an array of global horizontal interconnects (GHs) 210 and global vertical interconnects (GVs) 220. Although shown as single lines in
In one embodiment, GH 210 and GV 220 conductors may or may not be programmably connectable at intersections 225 of these conductors. Moreover, GH 210 and GV 220 conductors may make multiple connections to other GH 210 and GV 220 conductors. Various GH 210 and GV 220 conductors may be programmably connected together to create a signal path from a LAB 200 at one location of PLD portion 154 to another LAB 200 at another location of PLD portion 154. A signal may pass through a plurality of intersections 225. Furthermore, an output signal from one LAB 200 can be directed into the inputs of one or more LABs 200. Also, using the global interconnect, signals from a LAB 200 can be fed back into the same LAB 200. In specific embodiments of the present invention, only selected GH 210 conductors are programmably connectable to a selection of GV 220 conductors. Furthermore, in still further embodiments, GH 210 and GV 220 conductors may be specifically used for passing signal in a specific direction, such as input or output, but not both.
In other embodiments, the programmable logic integrated circuit may include special or segmented interconnect that is connected to a specific number of LABs and not necessarily an entire row or column of LABs. For example, the segmented interconnect may programmably connect two, three, four, five, or more LABs.
The programmable logic architecture in
A general overview of LE 300 is presented here, sufficient to provide a basic understanding of the present invention. LE 300 is the smallest logical building block of a PLD. Signals external to the LAB, such as from GHs 210 and GVs 220, are programmably connected to LE 300 through local interconnect structure 310. In one embodiment, LE 300 of the present invention incorporates a function generator that is configurable to provide a logical function of a number of variables, such a four-variable Boolean operation. As well as combinatorial functions, LE 300 also provides support for sequential and registered functions using, for example, D flip-flops.
LE 300 provides combinatorial and registered outputs that are connectable to the GHs 210 and GVs 220, outside LAB 200. Furthermore, the outputs from LE 300 may be internally fed back into local interconnect structure 310; through local interconnect structure 310, an output from one LE 300 may be programmably connected to the inputs of other LEs 300, without using the global interconnect structure's GHs 210 and GVs 220. Local interconnect structure 310 allows short-distance interconnection of LEs, without utilizing the limited global resources, GHs 210 and GVs 220.
Low-speed input buffer 560 and low-speed input circuit 540 form a low-speed input path for receiving signals on pads P1 510 and providing outputs to the core circuitry. A high-speed input path is provided by high-speed input buffer 565 and high-speed input circuit 545. This path receives differential inputs on pads P1 510 and P2 520 and provides signals to FIFOs or other circuits in the core.
Additionally, multiplexer 570 provides a low-speed path including the low-speed output circuit 530 and high-speed differential output buffer 555. In this way, low-speed signals from the core circuits may be provided as differential output signals. Similarly, differential input signals may be received by high-speed input buffer 565 and provided through multiplexer 575 to the low-speed input circuit 540. In this way, a low-speed differential input signal may be received and output to the core circuits.
In a specific embodiment of the present invention, the low-speed output circuit 530, the high-speed output circuit 535, low-speed input circuit 540, and high-speed input circuit 545 are double data rate registers. The labels high speed and low speed are relative terms, and are not descriptive of any specific data rate.
Included are pads P1 610 and P2 620, input block IN1 650, output block OUT1 670, high-speed output block HSOUT 680, high-speed input block HSIN 690, output block OUT2 675, and input block IN2 655. Also included are output enable blocks OE1 660 and OE2 665.
Each input, output, and output enable block may be synchronous or asynchronous. In one embodiment, global (GCLKs) and local (LCLKs) clock lines 630, and high-speed clock lines (HCLKs) 640 are provided. In a specific embodiments of the present invention, several low or moderate speed global clock lines are available to circuits throughout the integrated circuit. Additionally, several low or moderate speed local clocks are available. These local clocks are available and routed to only a portion of the integrated circuit, for example, one-quarter of the integrated circuit.
In addition to these low and moderate speed clocks, several high-speed clocks, HCLKs 640, are also available. These clocks, as with the local and global clock lines, may be single-ended or differential. The use of the terms low, moderate, and high speed are meant to be relative terms—one skilled in the art appreciates that what is now high speed will soon be moderate speed.
Input and output lines to and from the input and output blocks may be provided directly to and from logic gates or logic array blocks in the core of the integrated circuit. Alternately, these input and output signals may be provided to and from first-in-first-out (FIFO) memories that can serve as data buffers or frequency translators.
These input and output circuits are selectable such that pads P1 610 and P2 620 can provide:
- One high-speed differential output;
- one high-speed differential input;
- one moderate or low-speed differential output;
- one moderate or low-speed differential input;
- two single-ended inputs;
- two single-ended outputs; or
- one single-ended input and one single-ended output.
Signal paths are selectable by multiplexing signals, opening and shorting pass devices, or by using other selecting structures. A specific embodiment uses multiplexers to either couple or disconnect circuits from the input and output pads. The input and output circuits of other embodiments may be selectable such that they provide more, different, or fewer types of inputs and outputs than the above list.
When the circuitry in
When the circuitry in
This circuitry may also be configured such that each pad provides a moderate or low-speed single-ended output. For example, output block OUT1 670 may be selected, while the high-speed output block HSOUT 680 and input block IN1 650 are deselected, Output block OUT1 670 provides an output signal on line 612 to output pad P1 610. Input signal DO1 is received on line 674, again from either core circuitry or a translation FIFO. A low or moderate speed clock signal is received on line 672 from one of global or local clocks 630 by pass device 634. Output block OUT1 may be enabled and disabled by output enable circuitry OE1 660. In this particular example, the output enable circuit 660 and output circuit 670 received the same clocks signal on line 672. In other embodiments, these blocks may receive individual clock signals. The output enable block OE1 660 receives an output enable signal 664 from the core of the integrated circuit and provides an enable signal on line 661 to output block OUT1 670. Similar circuitry is provided by output block OUT2 675 and output enable blocked OE2 665, which are coupled to pad P2 620.
The circuitry of
Additionally, other signal lines are provided, such as signal line 693, which provides a path allowing for this circuitry to be configured as a moderate or low-speed differential input where a differential input received on pads P1 610 and P2 620 is provided as an output DI1 on line 654. Additionally, signal path 673 is provided such that a moderate or low-speed output signal DO1 674 received by output block OUT1 670 is provided as a differential output to pads P1 610 and P2 620.
The more flexible, lower-speed input and output circuits provide additional configurability. For example, the lower speed circuitry may selectively couple to a larger selection of clock lines operating a different frequencies and different phases. Also, JTAG boundary testing may be supported. In a specific embodiment, a more precisely tuned output enable signal is available on the lower speed output buffer or driver, and the lower speed circuits may coupled to either a FIFO or directly to the core logic array blocks, while the higher speed input and output circuits typically require the frequency translation capabilities of a FIFO. Also, the lower speed circuits include presets, clear, and enable functions, as opposed to only a clear function in the high-speed circuit. Moreover, since the lower speed circuits are single-ended, two pads may be used as two output pads, two input pads, or 1 input and 1 output pad for the lower speed circuits, whereas two pads are required for just one high-speed input or output, because of their differential nature.
The input and output registers may each be a double-data rate register. Alternately, each register may be a single flip-flop. Accordingly, each input and output line from the register to the FIFOs 715 and 725 may be one or more data lines. For example, if an output register is a double-data rate register, the input line shown may be made up of two data lines. Each data line may be one line for single-ended, or two lines for differential signaling. When a double-data rate register is coupled to a FIFO, each FIFO shown may be a single FIFO with two outputs, or two separate FIFOs.
A high-speed differential output path is provided by the FIFO 715, output register 780, multiplexer 781, and differential output buffer or driver 782. When the circuitry of
The FIFO 715 receives an input signal (not shown) from the core circuits and provides an output coupled to the input of the high-speed output register 780. Often, the FIFO 715 acts as a buffer and frequency translator between the lower frequency core circuits and the high frequency differential output. The high-speed output register 780 is clocked by one of the high-speed clock lines 740. The output of the high-speed register is provided to multiplexer 781, which in turn drives output buffer 782. Output buffer 782 provides inverting and noninverting output signals to pads P2 720 and P1 710. The differential output buffer 782 can provide output signals that are selectively compatible with one or more standards or conventions. For example, the output buffer 782 may provide output signals that are compatible with one or more of the following: LVDS, LVPECL, Hypertransport, and PCML. These high-frequency input and output standards and conventions are typically specify differential signaling. Accordingly, the high-speed input and output circuits often require the use of two pads.
A high-speed differential input path is provided by differential input buffer or driver 791, high-speed input register 790, multiplexer 793, and FIFO 725. When the input and output circuitry of
A single-ended output signal may be provided on pad P1 710 by the output. register 770 and output buffer or driver 771. When a single-ended output signal is provided on pad P1 710, typically these circuits are active, while the other associated circuits in the input and output circuits 701, such as the input register 750, input buffer 751, high-speed output register 780, and high-speed input register 790, are inactive. Signals are received by the output register 770 from core circuits 702 or the FIFO 715. The output register 770 provides output signals to the single-ended output buffer 771, which in turn drives pad P1 710. The output buffer 771 may be enabled and disabled by the output enable register 760. The output register 770 and output enable register 760 may be clocked by true or complementary versions of one of the global or local clocks 730. In this specific example, clock multiplexers 763 and 773, which clock output enable register 760 and output register 770 respectively, are coupled to the same clock line. In other embodiments, these multiplexers may be coupled to separate clock lines. The output buffer 771 may provide outputs that are in compliance with one or more standards or conventions. For example, the output buffer 771 may provide signals which are compliance with one or more of the following: LVTTL, LVCMOS, SSTL, and TTL. Similarly, single-ended output signals may be provided to pad P2 720 by the output register 775 and output buffer 776, which is enabled by output enable register 765.
Single-ended input signals may be received from pad P1 710 using input buffer 751 and input register 750. When single-ended input signals are received on pad P1, typically these circuits are active, while other associated circuits, such as output register 770, output buffer 771, output enable register 760, high-speed output register 780, and high-speed input register 790, are inactive. Signals received on pad P1 710 are routed on line 712 to input buffer 751. Input buffer 751 may be compliant with one or more specifications or conventions. For example input buffer 751 may be compliant with one or more of the following: LVTTL, LVCMOS, SSTL, and TTL. Input buffer 751 provides an input signal to the input register 750 which may in turn drive FIFO 725 or other circuits in the core 702. Input register 750 is clocked by true or complementary versions of a clock signal from one of the global or local clock lines 730 by multiplexer 753. Similarly, single-ended input signals may be received from pad P2 720 by buffer 756, which drives input register 755.
These input and output circuits 701 may be selectively enabled in other configurations. For example, the differential input buffer 791 may have its output routed through multiplexer 752 to the input register 750. Also, the output register 770 may have its output routed through multiplexer 781 to the differential output buffer 782. In other embodiments of the present invention, other combinations of inputs and output circuits 701 may be selectively enabled, and selectively coupled to FIFOs 715 and 725, and core circuits 702.
The FIFOs 715 and 725 provide a frequency translation between the high-speed input and output circuits and the lower speed core logic array blocks. Specifically, each FIFO may be formed from a small embedded array block (SEAB) or another embedded memory block. A SEAB is a type of embedded memory blocks found on the Altera Stratix devices. When the circuit of
Input signals are received on lines DIN1 821 and DIN2 822 by FIFOs 825a and 825b. In this example, the input signals are clocked into the FIFOs by global or local clocks 830 selected by pass devices 834 and 832. The FIFO 825a provides an output that is received by flip-flop 880a. The FIFO 825b provides an output that is received by flip-flop 880b. The output signals of the FIFOs 825a and 825b are clocked by high-speed clock lines 840 selected by pass devices 846 and 844. The flip-flops 880a and 880b are also clocked by one of the high-speed clock lines 840, selected by pass devices 842. The output of the flip-flops 880a and 880b are provided as inputs to multiplexer 850, the output of which is selected by the same clock signal as received by the flip-flops. The output of multiplexer 850 is provided to the differential high-speed output buffer 882, which in turn drives pads P1 810 and P2 820.
By multiplexing between flip-flops 880a and 880b during each clock cycle, the data rate of the output signal is twice that of the flip-flop outputs Q1 811 and Q2 812. Furthermore, data may be received in parallel at the FIFO inputs DIN1 821 and DIN2 822. For example, four bits of data may be received by FIFO 825a at input DIN1 821, and four bits may be received by FIFO 825b at input DIN2 822. Four bits from each FIFO may be clocked into the flip-flops 880a and 880b at four times the data rate of the data transfer at DIN1 821 and DIN2 822. By multiplexing the outputs of flip-flops 880a and 880b with multiplexer 850, the data rate is effectively doubled again, an increase of a factor of eight in the data rate of VOUT as compared to DIN1 821 and DIN2 822. In other embodiments, more or less than four bits may be received in parallel by the FIFOs, resulting in higher or lower data translation rates.
If the output of FIFO 825a is held high and the output of FIFO 825b is held low, the resulting output signal is a high-speed clock comprising alternating zeros and ones. Specifically, if DIN1 on line 821 is held high and DIN2 on line 822 is held low, the output of FIFO 825a, and thus Q1 on line 811 are high, while the output of FIFO 825b and thus Q2 on line 812 are low. The multiplexer 850 alternately selects between the high signal Q1 on line 811 and the low signal Q2 on line 812, thus generating a clock signal. Alternately, the inputs to the flip-flops 880a and 880b may couple to multiplexers having as selectable inputs logic high or logic low levels.
A clear line is provided to flip-flops 880a and 880b on line 885. To achieve the highest speed possible, it is desirable to limit the functionality of flip-flops 880a and 880b. Accordingly, these flip-flops do not include preset or enable lines. In other embodiments, these lines may be included. In other embodiments a clear tine 885 may not be included thereby simplifying the structure of flip-flops 880a and 880b even further.
The flip-flops 1090b and 1090c, and latch 1090a form a double-data rate input register. The latch 1090a may alternately be a third flip-flop. Multiplexers or pass devices may be inserted in the CLK 1043, Q1 1062, Q2 1061, or register data input paths to deactivate this high-speed input path and save power. It will be appreciated by one skilled and the art that other modifications may be made to this circuitry consistent with the present invention.
Input signals are received on pads P1 1010 and P2 1020 by the input buffer 1091. Input buffer 1091 provides inputs to flip-flops 1090b and 1090c. A high-speed clock signal is selected from one of the HCLKs clock lines 1040 by pass devices 1042. The clock signal is applied on line 1043 to flip-flop 1090c and latch 1090a, and is inverted by inverter 1050 and sent to flip-flop 1090b. Data from the input buffer 1091 is latched on rising edges of the clock by flip-flop 1090c and by falling edges of the clocked by flip-flop 1090b. Data stored by the flip-flop 1090b is retired by latch 1090a, such that signals Q2 1061 and Q3 1062 are sent to the FIFOs 1025a and 1025b on rising edges of the clock. FIFOs 1025a and 1025b buffer the data and provide it at a lower frequency on lines DOUT1 1026 and DOUT2 1027 to the core circuits.
Since the signal Vin 1012 is latched on rising edges of the clock by flip-flop 11090c and on falling edges of the clock by flip-flop 1090b, the resulting data rate at Q3 1062 and Q2 1061 are half that of Vin 1012. In other words, the flip-flops 1090a and 1090b perform a two bit serial-to-parallel conversion of the input data. This concept may be further expanded at FIFOs 1025a and 1025b. For example, four bits received serially may be output in parallel at FIFO outputs DOUT1 1026 and DOUT2 1027. In this way, a frequency translation by a factor of eight from the input signal Vin 1012 and DOUT1 1026 and DOUT2 1027 is achieved. In other embodiments, more or less than 4 bits may be converted from serial to parallel data by the FIFOs 11025a and 1025b, thereby achieving a different overall frequency translation.
Data signals are received on lines 1274a and 1274b from the core circuits or FIFOs. A clock signal on line 1277 is selected from one of the global or local clocks 1230 by pass devices 1232. The clock multiplexer 1273 selects true or complementary versions of this clock signal and drives the clock inputs of the flip-flops 1270a and 1270b and the select input of the data multiplexer 1260. Outputs are provided by the flip-flops 1270a and 1270b to the multiplexer 1260 where they are interleaved and used to drive either of the output buffers 1271 or 1282. If the output buffer 1271 is selected, it drives a single-ended output onto pad P1 1210. If the differential output buffer 1282 is active, it drives a differential output onto pads P1 1210 and P2 1220.
Output buffer 1271 is enabled by the OR gate 1295, which is driven by enable registers 1250a and 1250b. Specifically, an output enable signal on line 1254 is received by flip-flop 1250a which drives flip-flop 1250b. The outputs of flip-flops 1250a and 1250b are ORed by OR gate 1290, which drives the enable input of the output buffer 1271. This configuration allows the enable registers to enable and disable the output buffer 1271 on consecutive rising and falling edges (or consecutive falling and rising edges). In this way, the output buffer 1271 may be dynamically tristated or enabled. Alternately, multiplexer 1290 may select a logic high (or VCC), thus clearing the flip-flop 1250b. This allows flip-flop 1250a to enable and disable the output buffer 1271 on consecutive rising edges of the CLK1 signal on line 1257. Also, in each of these eases, there may be one or more intermediate clocks between enables and disables (or disables and enables).
Since this signal path is generally expected to be used for low or moderate frequency signals, flip-flaps 1270a and 1270b, and output buffer 1271 can support a higher level of functionality than the flip-flops and output buffer is used in the higher speeds signal path. In this example, each flip-flop has preset, clear, and enable signal inputs associated with it, while the output buffer has an enable input such that it can provide a high impedance output. In this example, separate preset, enable, and clear lines are provided to the data output flip-flops and the output enable flip-flops. In other embodiments, the signal lines may be coupled together, or some of these functions may be omitted. Alternately, each flip-flop and may have a separate signal line for one or more of these functions. Also, other signals may be supported by these circuits.
Single-ended signals are received on pad P1 1310 by input buffer 1351 which provides an input to flip-flops 1350b and 1350c. Differential inputs are received on pads P1 1310 and P2 1320 by differential input buffer 1391. The inputs of the flip-flops 1350b and 1350c are stored on alternate edges of the clock. The output of flip-flop 1350b is retimed by the latch 1350a. The clock signal is selected from one of the global or local clocks 1330 by pass devices 1332. True or complementary versions of the selected clock signal are provided by multiplexer 1353 to flip-flop 1350c and latch 1350a. This signal is inverted by inverter 1360, which in turn drives flip-flop 1350b. The outputs of the latch 1350a and flip-flop 1350c, Q3 1361 and Q2 1363, are provided to FIFOs or core circuitry. As before, since this circuitry is intended for low or moderate frequency input signals, flip-flops and latches having higher levels of functionality may be used. In the specific example shown, each flip-flop and latch has preset, clear, and enable input signal lines. In other embodiments, other inputs signal lines may be used, or some of the shown inputs may be omitted. In the specific example, one preset 1365, 1 clear 1366, and enabled 1367 are shown as being connected to each flip-flop and latch. In other embodiments of the present invention, some or all of these circuits may be connected to separate lines.
VCO 1525 may be a ring oscillator or similar structure such that clock signals having the various phases may be provided to the multiplexers 1540, 1550, and 1560. In a specific embodiments, the VCO comprises four differential stages. In other embodiments, the number of stages may vary. In this embodiment, clocks having phases shifted by 0, 45, 90, 135, 180, 225, 270, and 315 degrees are available. In other embodiments of the present invention, a different number of lines, and lines having different phases may be available from the VCO. Multiplexers 1540, 1550, and 1560 select one of the available inputs and drive dividers 1545, 1555 and 1565. Dividers 1545, 1555, and 1565 divide their input frequencies by K, V, and L. In a specific embodiment, K, V, and L are programmable integer values between 1 and 16. In other embodiments, these may be fixed values, or they may be variable along a different range, or different ranges of values. Multiplexer 1570 selects between the output of divider 1565 and the output of the input buffer 1515. In various embodiments, the outputs of the dividers 1545 and 1555, and the output of multiplexer 1570 may be selectable as high-speed, local, or global clock signals. An example of this is shown in
The foregoing description of specific embodiments of the invention has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise limn described, and many modifications and variations are possible in light of the teaching above. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications to thereby enable others skilled in the art to best utilize the invention in various embodiments and with various modifications as are suited to the particular use contemplated.
Claims
1. A selectively-configurable I/O interface, comprising:
- a plurality of buffers;
- first and second pads;
- means for selectively-coupling the first pad to at least one buffer from among the plurality of buffers;
- means for selectively-coupling the second pad to at least one buffer from among the plurality of buffers; and
- means for enabling the selectively-configurable I/O interface to be configured in first and second configurations,
- wherein when in the first configuration the selectively-configurable I/O interface is configured to receive a single-ended signal at the first pad and buffer the signal in a buffer from among the plurality of buffers coupled to the first pad, and
- wherein when in the second configuration the selectively-configurable I/O interface is configured to receive a differential signal at the first and second pads and buffer the differential signal in a buffer from among the plurality of buffers that is coupled to the first and second pads.
Type: Application
Filed: Sep 16, 2016
Publication Date: Jan 5, 2017
Inventors: Bonnie I. Wang (Cupertino, CA), Chiakang Sung (Milpitas, CA), Joseph Huang (Morgan Hill, CA), Khai Q. Nguyen (San Jose, CA), Philip Y. Pan (Fremont, CA)
Application Number: 15/268,101