USRE37577E1 - High speed configuration independent programmable macrocell - Google Patents

High speed configuration independent programmable macrocell Download PDF

Info

Publication number
USRE37577E1
USRE37577E1 US09/047,314 US4731498A USRE37577E US RE37577 E1 USRE37577 E1 US RE37577E1 US 4731498 A US4731498 A US 4731498A US RE37577 E USRE37577 E US RE37577E
Authority
US
United States
Prior art keywords
circuit
logic
clock
function
data path
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US09/047,314
Inventor
Lin-Shih Liu
Syed Babar Raza
Hagop Nazarian
George M. Ansel
Stephen M. Douglass
Jeffrey Scott Hunt
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Cypress Semiconductor Corp
Original Assignee
Cypress Semiconductor Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US08/584,105 external-priority patent/US5621338A/en
Application filed by Cypress Semiconductor Corp filed Critical Cypress Semiconductor Corp
Priority to US09/047,314 priority Critical patent/USRE37577E1/en
Application granted granted Critical
Publication of USRE37577E1 publication Critical patent/USRE37577E1/en
Anticipated expiration legal-status Critical
Assigned to MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL AGENT reassignment MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL AGENT PATENT SECURITY AGREEMENT Assignors: CYPRESS SEMICONDUCTOR CORPORATION, SPANSION LLC
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03KPULSE TECHNIQUE
    • H03K19/00Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
    • H03K19/02Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
    • H03K19/173Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
    • H03K19/1733Controllable logic circuits
    • H03K19/1735Controllable logic circuits by wiring, e.g. uncommitted logic arrays
    • H03K19/1736Controllable logic circuits by wiring, e.g. uncommitted logic arrays in which the wiring can be modified

Definitions

  • the present invention relates to the field of programmable logic devices, and more particularly to a high speed programmable macro cell with a propagation delay independent of the configuration.
  • PLDs programmable logic devices
  • One type of PLDs has a programmable macro cell.
  • the programmable macro cell provides the capability of defining the architecture of each output individually.
  • Each of the potential outputs may be specified to be “registered” or “combinatorial”.
  • the polarity of each output may also be individually selected allowing complete flexibility of the output configuration.
  • further configurability is provided through “array” configurable “output enable” for each potential output. This feature allows the outputs to be reconfigured as inputs on an individual basis, or alternatively, used as a combinational I/O controlled by the programmable array.
  • An example of such a PLD device is manufactured by Cypress Semiconductor Corporation, the Assignee of the present invention.
  • FIG. 1 illustrates a user configurable macro cell configured in accordance with the prior art.
  • the user selects the configuration of the macro cell to operate as either a D-type flip-flop or a T-type flip-flop.
  • the user selects the polarity of the output data (e.g. whether the output of the circuit is selected from the register true (Q) or bar ( ⁇ overscore (Q) ⁇ )).
  • the user selects the configuration by programming user configurable bits.
  • a D-type, a T-type, a polarity, ⁇ overscore (Dtype) ⁇ , a ⁇ overscore (Ttype) ⁇ and ⁇ overscore (polarity) ⁇ select signals are generated.
  • a macrocell 100 receives the D-type, T-type, polarity, ⁇ overscore (Dtype) ⁇ , ⁇ overscore (Ttype) ⁇ and ⁇ overscore (polarity) ⁇ select signals.
  • the macro cell circuit 100 contains an exclusive OR gate (XOR) 102 , a register 120 , and a plurality of transmission gates 105 , 110 , 152 and 154 .
  • the XOR gate 102 implements the toggle function for the T-type flip-flop.
  • transmission gates 105 , 110 , 115 , 125 , 140 , 148 , 154 and 152 contain a p channel metal oxide semiconductor (MOS) transistor and an n channel MOS transistor.
  • the register 120 used to implement the D-type and the T-type flip-flops, contains a master latch, a slave latch and a transmission gate 140 used to couple the master latch and the slave latch.
  • the master latch includes inverters 130 and 135 , as well as transmission gate 125 .
  • the slave latch includes inverters 145 and 146 , as well as transmission gate 148 .
  • the “Data In” is input to the XOR 102 and a transmission gate 105 . If a D-type flip-flop is specified by the static control signals, then the transmission gate 105 conducts the “data in” signal to a transmission gate 115 . If the static control signals specify a T-type flip-flop, then the output of the XOR gate 102 is coupled to the transmission gate 115 via the transmission gate 110 .
  • the data input to transmission gate 115 is passed to the master latch. Also, during the high state to low logic state transition, the transmission gates 125 and 140 are closed disabled, and the transmission gate 148 is open enabled to latch or retain the state previously latched in the slave latch. When the clock cycle transitions to a high logic level, the transmission gate 140 and the transmission gate 125 are opened enabled to latch the data in the master latch, and to pass the data into the slave latch, inverters 145 and 146 . In addition, in the high clock cycle, the transmission gate 148 is closed disabled. The polarity and ⁇ overscore (polarity) ⁇ static signals select either the true or bar outputs of the register 120 to generate the “data out”.
  • the T-type configuration requires a longer set-up time than the D-type configuration due to the XOR gate 102 .
  • the data path for the D-type configuration includes transmission gate 105
  • the data path for the T-type configuration includes transmission gate 110 .
  • the data is further delayed by the transmission gates 152 and 154 utilized to select the polarity.
  • a circuit that contains clock logic, a switching element and a data path circuit.
  • Input data is received in the switching element, and the switching element and the data path circuit constitute the entire data path for the circuit.
  • a plurality of user configurable inputs are received to configure the circuit for a particular user application.
  • the clock logic and the switching element implement a logic function that is configurable by the user configurable inputs.
  • the logic function is pre-processed in the clock logic so that minimal delay occurs in the data path.
  • the propagation delay through the switching element and the data path circuit is independent of the user configurable inputs.
  • the clock logic receives the user configurable inputs and a clock input. In turn, the clock logic generates conditional clock signals to implement the logic function for the circuit based on the clock input and the user configurable inputs.
  • the switching element includes at least one transmission gate that is controlled by the conditional clock signals.
  • the transmission gate includes any type of pass gate, such as a three state inverter or a switching transistor.
  • the switching element generates a logic output, in accordance with the conditional clock signals, to implement the logic function by controlling propagation of the input signal through the transmission gate.
  • the data path circuit receives the logic output, and is also controlled by the conditional clock signals.
  • the circuit of the present invention has application for use as a macro cell for a programmable logic device.
  • the data path circuit is a storage element
  • the user configurable inputs include a D-type register select, a T-type resister select, a latch select, and a polarity select.
  • the logic functions implemented in the clock logic are a multiplexer function, for selecting among a D-type flip-flop, a T-type flip-flop and a latch, and a polarity function for generating a true or a bar output for the circuit.
  • the storage element is configured as a master/slave flip-flop, and includes a master latch, that receives the logic output, and a slave latch that couples the master latch to the circuit output.
  • FIG. 1 illustrates a user configurable macro cell configured in accordance with the prior art.
  • FIG. 2 is a high level block diagram illustrating the user configurable circuit of the present invention.
  • FIG. 3 is a block diagram illustrating a user configurable circuit configured in accordance with the present invention.
  • FIG. 4 illustrates one embodiment for implementing the user configurable circuit 300 illustrated in FIG. 3 .
  • FIG. 5 illustrates a programmable macro cell incorporating the user configurable circuit of the present invention.
  • FIG. 2 is a high level block diagram illustrating the user configurable circuit of the present invention.
  • a user configurable circuit 200 receives, as inputs, a plurality of user configurable inputs. For purposes of explanation, the user configurable circuit 200 receives “0 ⁇ n” user configurable inputs.
  • the user configurable circuit 200 contains clock logic 210 , a switching element 205 , and a data path circuit 215 .
  • the user configurable circuit 200 also receives a clock signal, at the “clock in” terminal, that provides timing for the circuit.
  • clock in at the “clock in” terminal.
  • Data is input to the switching element 205 at the “data in” terminal.
  • the clock logic 210 receives both the plurality of user configurable inputs, and the clock.
  • the user configurable inputs are set or programmed by the user in an initialization period.
  • the user configurable inputs are programmed into a non-volatile memory, thereby storing user configurable bits in a PLD application.
  • the user configurable bits are stored in an electrically erasable programmable read only memory (EEPROM).
  • EEPROM electrically erasable programmable read only memory
  • the user configurable inputs may be stored in a register, such as a serial shift register or a static random access memory (SRAM).
  • the circuitry utilized to set the user configurable input during the initialization period is well known in the art and will not be described further.
  • the clock logic 210 generates a conditional clock signals 205 , labeled as conditional clock signals 0 ⁇ m on FIG. 2 .
  • the switching element 205 receives the conditional clock signals “0 ⁇ m” and the data input.
  • the clock logic 210 and the switching element 205 implement at least one logic function for the user configurable circuit 200 .
  • the clock logic 210 and the switching element 205 may implement a multiplexing function to select among three configurations such as a D-Type flip flop, T-type flip-flop and latch.
  • the output of the switching element 205 is, coupled to the input of data path circuit 215 .
  • the data path circuit 215 may comprise any type of circuit, such as a registered or combinational, used to implement the user configurable circuit. One embodiment for the data path circuit 215 is described more fully below.
  • the output of data path circuit 215 is labeled “data output” on FIG. 2 .
  • the output of data path circuit 215 is also coupled to the clock logic 210 to provide implementation of certain flip flop functions.
  • the switching element 205 gates the data input with the clock to provide synchronous operation between the input data and the data path circuit 215 .
  • the switching element 205 contains at least one gating or pass gate element, such as a transmission gate.
  • the transmission gate may include any type of pass gate, such as a three state inverter or a switching transistor, without deviating from the spirit or scope of the invention.
  • One embodiment for gating the input data in the switching element 205 is described more fully below.
  • the conditional clock signals, generated in the clock logic 210 are utilized to gate the input data in the switching element 205 .
  • the switching element 205 and the data path circuit 215 constitute the data path for the user configurable circuit 200
  • the clock logic 210 provides the clock path for the user configurable circuit 200 . Consequently, the critical path for reducing delay of the user configurable circuit 200 lies in the data path (e.g. data being propagated through the switching element 205 and data path circuit 215 ) and the clock path.
  • the user configurable circuit 200 is constructed such that most of the processing to implement the logic function or logic functions are done prior to an active clock (e.g. in the clock logic 210 ). Because the user configurable inputs are available as pseudo DC signals after power-up, most of the processing for the logic function occurs prior to receiving data for input to the data path.
  • the operation of the data path circuit 215 requires gating the data, no additional delay is introduced to implement the logic function or logic functions in the switching element 205 . Because of the decrease in gates in the data path, propagation delay through the user configurable circuit 200 is reduced.
  • FIG. 3 is a block diagram illustrating a user configurable circuit configured in accordance with the present invention.
  • a user configurable circuit 300 permits a user to select among configuring the circuit as a D-type flip-flop, a T-type flip-flop or a latch.
  • the user configurable circuit 300 permits a user to select the polarity of the data output.
  • the user configurable circuit 300 contains clock logic 310 , D-type flip-flop/T-type flip-flop/latch logic (D/T/L) element 320 and a register 330 .
  • the clock logic 310 receives function select and polarity select signals as user configurable inputs.
  • the clock logic 310 generates conditional clock signals for the D/T/L element 320 and the register 330 .
  • the clock logic 310 and the D/T/L element 320 executes the toggle function, the polarity function, and a multiplexing function to select among the T-type flip-flop, the D-type flip-flop or latch configuration.
  • the data input is received in the D/T/L element 320 .
  • the D/T/L element 320 is coupled to the register 330 , and the data are output from the register 330 .
  • the data output are also input to the clock logic 310 in order to implement the T-type flip-flop function.
  • the function select and the polarity select signals are set.
  • the clock logic 310 After the user configurable circuit 300 is powered up, the clock logic 310 generates the conditional clock signals in accordance with the function select and polarity select signals and the clock signal.
  • the data input are gated in the D/T/L element 320 in accordance with the conditional clock signals.
  • the propagation delay in the D/T/L element 320 is equal to the propagation delay from one transmission gate.
  • data are latched in the register 330 .
  • the control of the data through the register 330 is also conducted by the conditional clock signals.
  • FIG. 4 illustrates one embodiment for implementing the user configurable circuit 300 illustrated in FIG. 3.
  • a user configurable circuit 400 implements the D/T/L element 320 with a D/T/L element 420 , the clock logic 310 with clock logic 410 , and the register 330 with register 430 .
  • the D/T/L element 420 contains a three state inverter 335 and a transmission gate 332 .
  • the three state inverter 335 includes a CMOS inverter comprising p channel transistor 336 and n channel transistor 338 .
  • the three state inverter 335 further includes p channel transistor 334 coupled between the source of p channel transistor 336 and Vcc, and an n channel transistor 340 coupled between the source of n channel transistor 338 and ground.
  • the register 430 contains a master latch 345 and a slave latch 355 .
  • the master latch 345 includes inverters 344 and 346 , and a transmission gate 342 .
  • the slave latch 355 comprises inverters 352 and 354 , and a transmission gate 350 .
  • the register 330 further includes a transmission gate 348 coupling the master latch with the slave latch.
  • the user configurable input defines the function selected, either the D-type flip-flop, T-type flip-flop or latch, and the polarity output from the circuit.
  • the clock logic 410 receives user configurable bits C 2 , C 3 , and C 4 .
  • the user configurable bits C 2 , C 3 , and C 4 are programmed during an initialization period, and are stored in non-volatile memory or registers.
  • the clock logic 410 also receives the clock input.
  • the clock logic 410 generates clock 1 (CLK 1 ), clock 1 bar ( ⁇ overscore (CLK1+L ) ⁇ ), clock 2 (CLK 2 ), clock 2 bar ( ⁇ overscore (CLK2+L ) ⁇ ), clock 3 (CLK 3 ), clock 3 bar ( ⁇ overscore (CLK3+L ) ⁇ ), clock 4 (CLK 4 ), clock 4 bar ( ⁇ overscore (CLK4+L ) ⁇ ), clock 5 (CLK 5 ), and clock 5 bar ( ⁇ overscore (CLK5+L ) ⁇ ) signals.
  • the CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals control the enabling of the three state inverter 335
  • the CLK 2 and ⁇ overscore (CLK2+L ) ⁇ signals control the transmission gate 332 .
  • the ⁇ overscore (CLK3+L ) ⁇ signal controls the p channel transistors in transmission gates 342 and 348
  • the CLK 3 signal controls the n channel transistors in transmission gates 342 and 348 .
  • the ⁇ overscore (CLK4+L ) ⁇ signal controls the p channel transistor in transmission gate 358
  • the CLK 4 signal controls the n channel transistor in transmission gate 358 .
  • the ⁇ overscore (CLK5+L ) ⁇ signal controls the n p channel transistor in transmission gate 350
  • the CLK 5 signal controls the p n channel transistor in transmission gate 350 .
  • data are input to the D/T/L element 420 on the ⁇ overscore (Data In) ⁇ line.
  • the configurable circuit 300 is operating in the D-type flip-flop mode, and the polarity select indicates a bar output, then the CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals disable the three state inverter 335 , and the CLK 2 and ⁇ overscore (CLK2+L ) ⁇ signals toggles the transmission gate 332 .
  • the bar output is Data Out.
  • the function select indicates a D-type flip-flop and the polarity select indicates a true output
  • the CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals toggles the three state inverter 335 to pass data from the ⁇ overscore (Data In) ⁇ to the output of the D/T/L element 420
  • the CLK 2 and ⁇ overscore (CLK2+L ) ⁇ signals disable the transmission gate 332 . Therefore, the D-type select and the polarity functions are primary implemented in the clock logic 310 . Consequently, only one gate delay occurs in the D/T/L element 420 (e.g. either through the three state inverter 335 or the transmission gate 332 ).
  • the output of the register 430 is coupled to the clock logic 410 to implement the T-type flip-flop function.
  • the data output is toggled when the ⁇ overscore (Data In) ⁇ is a low logic level, and the data output is not toggled when the ⁇ overscore (Data In) ⁇ is a high logic level. Consequently, knowledge of the current state stored in the slave latch 355 is required to implement the T-type flip-flop function.
  • T-type function select is active, Data In ⁇ overscore (Data In) ⁇ is “0”, and the slave latch 355 stores a “0”, then the CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals enable the three state inverter 335 , and the CLK 2 and ⁇ overscore (CLK2+L ) ⁇ signals disable the transmission gate 332 , thereby coupling the output of three state inverter 335 to the register 430 .
  • the ⁇ overscore (Data In) ⁇ is “1”, and the slave latch 355 stores a “0”, then the CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals enable the three state inverter 335 , and the CLK 2 and ⁇ overscore (CLK2+L ) ⁇ signals disable the transmission gate 332 .
  • the ⁇ overscore (Data In) ⁇ is passed directly to the register 430 . Therefore, for operation in the latch mode with bar output, the CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals disable the three state inverter 335 , and the CLK 2 and ⁇ overscore (CLK2+L ) ⁇ signals enable the transmission gate 332 independent of the clock signal. For latch mode with true output, CLK 2 and ⁇ overscore (CLK2+L ) ⁇ disable transmission gate 332 and CLK 1 and ⁇ overscore (CLK1+L ) ⁇ signals enable three state inverter 335 independent of clock signal. Regardless of the true or bar output, when operating in the latch mode, transmission gate 358 is enabled with the CLK 4 and ⁇ overscore (CLK4+L ) ⁇ signals to bypass the master latch.
  • the user configurable bits are C 2 , C 3 and C 4 , and define the configuration of the circuit (e.g. toggle mode, latch mode, and polarity select).
  • the user configurable bits C 2 , C 3 and C 4 define the operation of the user configurable circuit 400 as follows:
  • the clock logic 410 generates the conditional clock signals CLK 1 , ⁇ overscore (CLK1+L ) ⁇ , CLK 2 , ⁇ overscore (CLK2+L ) ⁇ , CLK 3 , ⁇ overscore (CLK3+L ) ⁇ , CLK 4 , ⁇ overscore (CLK4+L ) ⁇ , CLK 5 , ⁇ overscore (CLK5+L ) ⁇ .
  • the conditional clock signals are generated in the clock logic 410 based on the following relationships:
  • CLK 2 Y ⁇ overscore (Clk) ⁇ +Latch ⁇ overscore (C4+L ) ⁇
  • CLK 2 Y ⁇ overscore (Clk) ⁇ +Latch ⁇ overscore (C 4 ) ⁇
  • Table 1 provides a truth table corresponding to the equations above.
  • the user configurable circuit 300 contains set/reset logic.
  • the set/reset logic is modified. When the polarity select is set to true, and the set/reset logic is enabled, then the set/reset logic sets a high logic level in the slave latch 355 . When the polarity select is set to a bar, and the set/reset logic is enabled, then a low logic level is driven in the slave latch 355 .
  • FIG. 5 illustrates a programmable macro cell incorporating the user configurable circuit of the present invention.
  • a programmable macro cell 500 is configured in accordance with the user configurable circuit 200 shown in FIG. 2 .
  • the macro cell 500 may be configured as having combinatorial or registered outputs.
  • the programmable macro cell 500 is configured in accordance with the user configurable circuit 400 to permit a user to select a T-type flip-flop, a D-type flip-flop, or a latch configuration.
  • the T-type flip-flop and the D-type flip-flop configurations are specified as having equivalent propagation delay times.
  • the data path is reduced to provide shorter propagation delays for both the T-type flip-flop and the D-type flip-flop configurations.

Abstract

A user configurable circuit contains clock logic, a switching element and a data path circuit. Input data is received in the switching element, and the switching element and the data path circuit constitute the entire data path for the circuit. A plurality of user configurable inputs are received to configure the circuit for a particular user application. The clock logic and the switching element implement a logic function that is configurable by the user configurable inputs. The logic function is pre-processed in the clock logic so that minimal delay occurs in the data path. In addition, the propagation delay through the switching element and the register is independent of the user configurable inputs. The user configurable circuit of the present invention has application for use as a macro cell for a programmable logic device permitting the user to configure the circuit as a D-type flip-flop, a T-type flip-flop. In addition, the user selects the polarity for the output circuit.

Description

This is a continuation of application Ser. No. 08/360,469, filed Dec. 20, 1994, now U.S. Pat. No. 5,502,403.
FIELD OF THE INVENTION
The present invention relates to the field of programmable logic devices, and more particularly to a high speed programmable macro cell with a propagation delay independent of the configuration.
BACKGROUND OF THE INVENTION
In general, programmable logic devices (PLDs) permit a user to configure the PLD device to accommodate a wide spectrum of applications. One type of PLDs has a programmable macro cell. The programmable macro cell provides the capability of defining the architecture of each output individually. Each of the potential outputs may be specified to be “registered” or “combinatorial”. In addition, the polarity of each output may also be individually selected allowing complete flexibility of the output configuration. In addition, further configurability is provided through “array” configurable “output enable” for each potential output. This feature allows the outputs to be reconfigured as inputs on an individual basis, or alternatively, used as a combinational I/O controlled by the programmable array. An example of such a PLD device is manufactured by Cypress Semiconductor Corporation, the Assignee of the present invention.
FIG. 1 illustrates a user configurable macro cell configured in accordance with the prior art. For the circuit illustrated in FIG. 1, the user selects the configuration of the macro cell to operate as either a D-type flip-flop or a T-type flip-flop. In addition, the user selects the polarity of the output data (e.g. whether the output of the circuit is selected from the register true (Q) or bar ({overscore (Q)})). Typically, the user selects the configuration by programming user configurable bits. In response to the user configurable bits, a D-type, a T-type, a polarity, {overscore (Dtype)}, a {overscore (Ttype)} and {overscore (polarity)} select signals are generated. A macrocell 100 receives the D-type, T-type, polarity, {overscore (Dtype)}, {overscore (Ttype)} and {overscore (polarity)} select signals.
The macro cell circuit 100 contains an exclusive OR gate (XOR) 102, a register 120, and a plurality of transmission gates 105, 110, 152 and 154. The XOR gate 102 implements the toggle function for the T-type flip-flop. As is shown in FIG. 1, transmission gates 105, 110, 115, 125, 140, 148, 154 and 152 contain a p channel metal oxide semiconductor (MOS) transistor and an n channel MOS transistor. The register 120, used to implement the D-type and the T-type flip-flops, contains a master latch, a slave latch and a transmission gate 140 used to couple the master latch and the slave latch. The master latch includes inverters 130 and 135, as well as transmission gate 125. The slave latch includes inverters 145 and 146, as well as transmission gate 148.
The “Data In” is input to the XOR 102 and a transmission gate 105. If a D-type flip-flop is specified by the static control signals, then the transmission gate 105 conducts the “data in” signal to a transmission gate 115. If the static control signals specify a T-type flip-flop, then the output of the XOR gate 102 is coupled to the transmission gate 115 via the transmission gate 110.
During a clock transition from a high state to low logic state, the data input to transmission gate 115 is passed to the master latch. Also, during the high state to low logic state transition, the transmission gates 125 and 140 are closed disabled, and the transmission gate 148 is open enabled to latch or retain the state previously latched in the slave latch. When the clock cycle transitions to a high logic level, the transmission gate 140 and the transmission gate 125 are opened enabled to latch the data in the master latch, and to pass the data into the slave latch, inverters 145 and 146. In addition, in the high clock cycle, the transmission gate 148 is closed disabled. The polarity and {overscore (polarity)} static signals select either the true or bar outputs of the register 120 to generate the “data out”.
Although the macro cell circuit 100 provides selectable D-type or T-type configurations, the T-type configuration requires a longer set-up time than the D-type configuration due to the XOR gate 102. In addition, the data path for the D-type configuration includes transmission gate 105, and the data path for the T-type configuration includes transmission gate 110. Furthermore, whether the T-type or D-type configurations are selected, the data is further delayed by the transmission gates 152 and 154 utilized to select the polarity.
SUMMARY AND OBJECTS OF THE INVENTION
Therefore, it is an object of the present invention to reduce the propagation delay of the data path in a user configurable circuit.
It is another object of the present invention to provide a high speed user configurable circuit, wherein the propagation delays are independent of the configuration.
These and other objects are included in a circuit that contains clock logic, a switching element and a data path circuit. Input data is received in the switching element, and the switching element and the data path circuit constitute the entire data path for the circuit. A plurality of user configurable inputs are received to configure the circuit for a particular user application. The clock logic and the switching element implement a logic function that is configurable by the user configurable inputs. The logic function is pre-processed in the clock logic so that minimal delay occurs in the data path. In addition, the propagation delay through the switching element and the data path circuit is independent of the user configurable inputs.
The clock logic receives the user configurable inputs and a clock input. In turn, the clock logic generates conditional clock signals to implement the logic function for the circuit based on the clock input and the user configurable inputs. The switching element includes at least one transmission gate that is controlled by the conditional clock signals. The transmission gate includes any type of pass gate, such as a three state inverter or a switching transistor. The switching element generates a logic output, in accordance with the conditional clock signals, to implement the logic function by controlling propagation of the input signal through the transmission gate. The data path circuit receives the logic output, and is also controlled by the conditional clock signals.
The circuit of the present invention has application for use as a macro cell for a programmable logic device. In one embodiment, the data path circuit is a storage element, and the user configurable inputs include a D-type register select, a T-type resister select, a latch select, and a polarity select. The logic functions implemented in the clock logic are a multiplexer function, for selecting among a D-type flip-flop, a T-type flip-flop and a latch, and a polarity function for generating a true or a bar output for the circuit. The storage element is configured as a master/slave flip-flop, and includes a master latch, that receives the logic output, and a slave latch that couples the master latch to the circuit output.
Other objects, features and advantages of the present invention will be apparent from the accompanying drawings, and from the detailed description that follows below.
BRIEF DESCRIPTION OF THE DRAWINGS
The objects, features, and advantages of the present invention will be apparent from the following detailed description of the preferred embodiment of the invention with references to the following drawings.
FIG. 1 illustrates a user configurable macro cell configured in accordance with the prior art.
FIG. 2 is a high level block diagram illustrating the user configurable circuit of the present invention.
FIG. 3 is a block diagram illustrating a user configurable circuit configured in accordance with the present invention.
FIG. 4 illustrates one embodiment for implementing the user configurable circuit 300 illustrated in FIG. 3.
FIG. 5 illustrates a programmable macro cell incorporating the user configurable circuit of the present invention.
DETAILED DESCRIPTION
FIG. 2 is a high level block diagram illustrating the user configurable circuit of the present invention. A user configurable circuit 200 receives, as inputs, a plurality of user configurable inputs. For purposes of explanation, the user configurable circuit 200 receives “0−n” user configurable inputs. The user configurable circuit 200 contains clock logic 210, a switching element 205, and a data path circuit 215. The user configurable circuit 200 also receives a clock signal, at the “clock in” terminal, that provides timing for the circuit. Although the present invention is described in conjunction with a clock signal, any dynamic control signal used to gate input data may be used without deviating from the spirit and scope of the invention. Data is input to the switching element 205 at the “data in” terminal.
The clock logic 210 receives both the plurality of user configurable inputs, and the clock. In a preferred embodiment, the user configurable inputs are set or programmed by the user in an initialization period. Specifically, the user configurable inputs are programmed into a non-volatile memory, thereby storing user configurable bits in a PLD application. In the preferred embodiment, the user configurable bits are stored in an electrically erasable programmable read only memory (EEPROM). In an alternative embodiment, the user configurable inputs may be stored in a register, such as a serial shift register or a static random access memory (SRAM). After the initialization period, and upon powering of the user configurable circuit 200, the user configurable inputs do not change state, and therefore are characterized as pseudo DC signals. The circuitry utilized to set the user configurable input during the initialization period is well known in the art and will not be described further. The clock logic 210 generates a conditional clock signals205 , labeled as conditional clock signals 0−m on FIG. 2.
The switching element 205 receives the conditional clock signals “0−m” and the data input. In general, the clock logic 210 and the switching element 205 implement at least one logic function for the user configurable circuit 200. For example, the clock logic 210 and the switching element 205 may implement a multiplexing function to select among three configurations such as a D-Type flip flop, T-type flip-flop and latch. The output of the switching element 205 is, coupled to the input of data path circuit 215. The data path circuit 215 may comprise any type of circuit, such as a registered or combinational, used to implement the user configurable circuit. One embodiment for the data path circuit 215 is described more fully below. The output of data path circuit 215 is labeled “data output” on FIG. 2. The output of data path circuit 215 is also coupled to the clock logic 210 to provide implementation of certain flip flop functions.
In one embodiment, the switching element 205 gates the data input with the clock to provide synchronous operation between the input data and the data path circuit 215. In a preferred embodiment, the switching element 205 contains at least one gating or pass gate element, such as a transmission gate. However, the transmission gate may include any type of pass gate, such as a three state inverter or a switching transistor, without deviating from the spirit or scope of the invention. One embodiment for gating the input data in the switching element 205 is described more fully below. The conditional clock signals, generated in the clock logic 210, are utilized to gate the input data in the switching element 205.
The switching element 205 and the data path circuit 215 constitute the data path for the user configurable circuit 200, and the clock logic 210 provides the clock path for the user configurable circuit 200. Consequently, the critical path for reducing delay of the user configurable circuit 200 lies in the data path (e.g. data being propagated through the switching element 205 and data path circuit 215) and the clock path. In general, the user configurable circuit 200 is constructed such that most of the processing to implement the logic function or logic functions are done prior to an active clock (e.g. in the clock logic 210). Because the user configurable inputs are available as pseudo DC signals after power-up, most of the processing for the logic function occurs prior to receiving data for input to the data path. Also, because the operation of the data path circuit 215 requires gating the data, no additional delay is introduced to implement the logic function or logic functions in the switching element 205. Because of the decrease in gates in the data path, propagation delay through the user configurable circuit 200 is reduced.
FIG. 3 is a block diagram illustrating a user configurable circuit configured in accordance with the present invention. In general, a user configurable circuit 300 permits a user to select among configuring the circuit as a D-type flip-flop, a T-type flip-flop or a latch. In addition, the user configurable circuit 300 permits a user to select the polarity of the data output. The user configurable circuit 300 contains clock logic 310, D-type flip-flop/T-type flip-flop/latch logic (D/T/L) element 320 and a register 330. The clock logic 310 receives function select and polarity select signals as user configurable inputs. In turn, the clock logic 310 generates conditional clock signals for the D/T/L element 320 and the register 330.
In general, the clock logic 310 and the D/T/L element 320 executes the toggle function, the polarity function, and a multiplexing function to select among the T-type flip-flop, the D-type flip-flop or latch configuration. The data input is received in the D/T/L element 320. The D/T/L element 320 is coupled to the register 330, and the data are output from the register 330. The data output are also input to the clock logic 310 in order to implement the T-type flip-flop function.
During a configuration period for the user configurable circuit 300, the function select and the polarity select signals are set. After the user configurable circuit 300 is powered up, the clock logic 310 generates the conditional clock signals in accordance with the function select and polarity select signals and the clock signal. During the rising edge of the clock, the data input are gated in the D/T/L element 320 in accordance with the conditional clock signals. The propagation delay in the D/T/L element 320 is equal to the propagation delay from one transmission gate. During the falling edge of the clock, data are latched in the register 330. The control of the data through the register 330 is also conducted by the conditional clock signals.
FIG. 4 illustrates one embodiment for implementing the user configurable circuit 300 illustrated in FIG. 3. A user configurable circuit 400 implements the D/T/L element 320 with a D/T/L element 420, the clock logic 310 with clock logic 410, and the register 330 with register 430. The D/T/L element 420 contains a three state inverter 335 and a transmission gate 332. The three state inverter 335 includes a CMOS inverter comprising p channel transistor 336 and n channel transistor 338. The three state inverter 335 further includes p channel transistor 334 coupled between the source of p channel transistor 336 and Vcc, and an n channel transistor 340 coupled between the source of n channel transistor 338 and ground. The register 430 contains a master latch 345 and a slave latch 355. The master latch 345 includes inverters 344 and 346, and a transmission gate 342. The slave latch 355 comprises inverters 352 and 354, and a transmission gate 350. The register 330 further includes a transmission gate 348 coupling the master latch with the slave latch.
As discussed above in conjunction with FIG. 3, the user configurable input defines the function selected, either the D-type flip-flop, T-type flip-flop or latch, and the polarity output from the circuit. As shown in FIG. 4, the clock logic 410 receives user configurable bits C2, C3, and C4. As discussed above, the user configurable bits C2, C3, and C4 are programmed during an initialization period, and are stored in non-volatile memory or registers. The clock logic 410 also receives the clock input. The clock logic 410 generates clock 1 (CLK 1), clock 1 bar ({overscore (CLK1+L )}), clock 2 (CLK 2), clock 2 bar ({overscore (CLK2+L )}), clock 3 (CLK 3), clock 3 bar ({overscore (CLK3+L )}), clock 4 (CLK 4), clock 4 bar ({overscore (CLK4+L )}), clock 5 (CLK 5), and clock 5 bar ({overscore (CLK5+L )}) signals.
The CLK 1 and {overscore (CLK1+L )} signals control the enabling of the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals control the transmission gate 332. The {overscore (CLK3+L )} signal controls the p channel transistors in transmission gates 342 and 348, and the CLK 3 signal controls the n channel transistors in transmission gates 342 and 348. The {overscore (CLK4+L )} signal controls the p channel transistor in transmission gate 358, and the CLK 4 signal controls the n channel transistor in transmission gate 358. In addition, the {overscore (CLK5+L )} signal controls the n p channel transistor in transmission gate 350, and the CLK 5 signal controls the p n channel transistor in transmission gate 350.
In operation, data are input to the D/T/L element 420 on the {overscore (Data In)} line. If the configurable circuit 300 is operating in the D-type flip-flop mode, and the polarity select indicates a bar output, then the CLK 1 and {overscore (CLK1+L )} signals disable the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals toggles the transmission gate 332. For the embodiment illustrated in FIG. 4, the bar output is Data Out. If the function select indicates a D-type flip-flop and the polarity select indicates a true output, then the CLK 1 and {overscore (CLK1+L )} signals toggles the three state inverter 335 to pass data from the {overscore (Data In)} to the output of the D/T/L element 420, and the CLK 2 and {overscore (CLK2+L )} signals disable the transmission gate 332. Therefore, the D-type select and the polarity functions are primary implemented in the clock logic 310. Consequently, only one gate delay occurs in the D/T/L element 420 (e.g. either through the three state inverter 335 or the transmission gate 332).
As shown in FIG. 4, the output of the register 430 is coupled to the clock logic 410 to implement the T-type flip-flop function. In the T-type mode, the data output is toggled when the {overscore (Data In)} is a low logic level, and the data output is not toggled when the {overscore (Data In)} is a high logic level. Consequently, knowledge of the current state stored in the slave latch 355 is required to implement the T-type flip-flop function. If {overscore (Data In)} is “0”, and the slave latch 355 stores a “1”, and the T-type function select is active, then CLK 1 and {overscore (CLK1+L )} signals disable the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals enable the transmission gate 332 to pass a low logic level. If the T-type function select is active, Data In {overscore (Data In)} is “0”, and the slave latch 355 stores a “0”, then the CLK 1 and {overscore (CLK1+L )} signals enable the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals disable the transmission gate 332, thereby coupling the output of three state inverter 335 to the register 430.
If the T-type select function is active, the {overscore (Data In)} is “1”, and the slave latch 355 stores a “0”, then the CLK 1 and {overscore (CLK1+L )} signals enable the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals disable the transmission gate 332. However, if the T-type select is active, {overscore (Data In)} is “1”, and the slave latch 355 stores a “1”, then the CLK 1 and {overscore (CLK1+L )} signals disable the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals enable the transmission gate 332.
When the user configurable circuit 400 is operating in the latch mode, the {overscore (Data In)} is passed directly to the register 430. Therefore, for operation in the latch mode with bar output, the CLK 1 and {overscore (CLK1+L )} signals disable the three state inverter 335, and the CLK 2 and {overscore (CLK2+L )} signals enable the transmission gate 332 independent of the clock signal. For latch mode with true output, CLK2 and {overscore (CLK2+L )} disable transmission gate 332 and CLK1 and {overscore (CLK1+L )} signals enable three state inverter 335 independent of clock signal. Regardless of the true or bar output, when operating in the latch mode, transmission gate 358 is enabled with the CLK 4 and {overscore (CLK4+L )} signals to bypass the master latch.
In the rising edge of the clock, data is passed from the {overscore (DataIn)} to the output of the D/T/L element 420 as described above, and the data is latched in the master latch 345 when operating in both the T-type and D-type modes. When the user configurable circuit 400 is operating in the latch mode, the CLK 4 and {overscore (CLK4+L )} signals enable the transmission gate 358 to pass data from the output of the D/T/L element 420 to the slave latch 355. In all modes of operation, the data is latched in the slave latch 355 and the data is output from the master latch 345 during the falling edge of the clock.
For the user configurable circuit 400, the user configurable bits are C2, C3 and C4, and define the configuration of the circuit (e.g. toggle mode, latch mode, and polarity select). Specifically, the user configurable bits C2, C3 and C4 define the operation of the user configurable circuit 400 as follows:
Treg=TOGGLE MODE={overscore (C3+L )}C2Treg=TOGGLE MODE={overscore (C3)}·C2
 C4=POLARITY ACTIVE HIGH
Latch=LATCH MODE=C3{overscore (C2+L )} Latch=LATCH MODE=C3·{overscore (C2)}
As shown in FIG. 4, the clock logic 410 generates the conditional clock signals CLK 1, {overscore (CLK1+L )}, CLK 2, {overscore (CLK2+L )}, CLK 3, {overscore (CLK3+L )}, CLK 4, {overscore (CLK4+L )}, CLK 5, {overscore (CLK5+L )}. The conditional clock signals are generated in the clock logic 410 based on the following relationships:
CLK1=X{overscore (Clk)}+Latch C4CLK1=X·{overscore (Clk)}+Latch·C4
CLK2=Y{overscore (Clk)}+Latch {overscore (C4+L )} CLK2=Y·{overscore (Clk)}+Latch·{overscore (C4)}
CLK3=Clk{overscore (Latch)} CLK3=Clk·{overscore (Latch)}
CLK4=Clk Latch CLK4=Clk·Latch
CLK5={overscore (Clk)}
Where
Clk=CLOCK
Slave=FEEDBACK FROM THE SLAVE REGISTER 355
AND
X=Treg{overscore (Slave)}+{overscore (Treg)}C4X=Treg·{overscore (Slave)}+{overscore (Treg)}·C4
Y=SlaveTreg+{overscore (Treg C4+L )}Y=Slave·Treg+{overscore (Treg)}·{overscore (C4)}
The equations may be implemented using well known circuits. Table 1 below provides a truth table corresponding to the equations above.
TABLE 1
Clock {overscore (Clk)}
Cycle Slave C4 C3 C2 Clkb Clk1 Clk2 Clk3 Clk4 Clk5
 1 0 0 0 0 0 0 0 1 0 0
 1 0 0 0 0 0 0 0 1 0 0
 2 0 0 0 0 1 0 01 0 0 1
 3 0 0 0 1 0 0 0 1 0 0
 4 0 0 0 1 1 01 0 0 0 1
 5 0 0 1 0 0 0 01 0 1 0
 6 0 0 1 0 1 0 01 0 0 1
 7 0 0 1 1 0 0 0 1 0 0
 8 0 0 1 1 1 0 01 0 0 1
 9 0 1 0 0 0 0 0 1 0 0
10 0 1 0 0 1 01 0 0 0 1
11 0 1 0 1 0 0 0 1 0 0
12 0 1 0 1 1 01 0 0 0 1
13 0 1 1 0 0 01 0 0 1 0
14 0 1 1 0 1 01 0 0 0 1
15 0 1 1 1 0 0 0 1 0 0
16 0 1 1 1 1 01 0 0 0 1
17 1 0 0 0 0 0 0 1 0 0
18 1 0 0 0 1 0 01 0 0 1
19 1 0 0 1 0 0 0 1 0 0
20 1 0 0 1 1 0 01 0 0 1
21 1 0 1 0 0 0 01 0 1 0
22 1 0 1 0 1 0 01 0 0 1
23 1 0 1 1 0 0 0 1 0 0
24 1 0 1 1 1 0 01 0 0 1
25 1 1 0 0 0 0 0 1 0 0
26 1 1 0 0 1 01 0 0 0 1
27 1 1 0 1 0 0 0 1 0 0
28 1 1 0 1 1 0 01 0 0 1
29 1 1 1 0 0 01 0 0 1 0
30 1 1 1 0 1 01 0 0 0 1
31 1 1 1 1 0 0 0 1 0 0
32 1 1 1 1 1 01 0 0 0 1
In a preferred embodiment, in addition to the logic shown in FIG. 4, the user configurable circuit 300 contains set/reset logic. The operation of set/reset logic to set the slave latch 355 as is well known in the art. In order to implement the polarity function through the clock logic 410, the set/reset logic is modified. When the polarity select is set to true, and the set/reset logic is enabled, then the set/reset logic sets a high logic level in the slave latch 355. When the polarity select is set to a bar, and the set/reset logic is enabled, then a low logic level is driven in the slave latch 355.
The present invention has application for use in a programmable macro cell. FIG. 5 illustrates a programmable macro cell incorporating the user configurable circuit of the present invention. In general, a programmable macro cell 500 is configured in accordance with the user configurable circuit 200 shown in FIG. 2. The macro cell 500 may be configured as having combinatorial or registered outputs. In one embodiment for the registered outputs, the programmable macro cell 500 is configured in accordance with the user configurable circuit 400 to permit a user to select a T-type flip-flop, a D-type flip-flop, or a latch configuration. By using the user configurable circuit of the present invention as a programmable macro cell, the T-type flip-flop and the D-type flip-flop configurations are specified as having equivalent propagation delay times. In addition, the data path is reduced to provide shorter propagation delays for both the T-type flip-flop and the D-type flip-flop configurations.
Although the present invention has been described in terms of specific exemplary embodiments, it will be appreciated that various modifications and alterations might be made by those skilled in the art without departing from the spirit and scope of the invention as set forth in the following claims.

Claims (42)

What is claimed is:
1. A circuit comprising:
a plurality of user configurable inputs for configuring said circuit;
clock logic coupled to said user configurable inputs and coupled to receive a clock input, said clock logic for generating conditional clock signals to implement a logic function for said circuit based on said clock input and said user configurable inputs;
a switching element including at least one pass gate coupled to said clock logic to receive some of said conditional clock signals and coupled to receive an input signal for said circuit, said switching element for generating a logic output, in accordance with said conditional clock signals, to implement said logic function by controlling propagation of said input signal through said pass gate; and
a data path circuit coupled to receive said logic output and some of said conditional clock signals for providing additional functionality, wherein propagation delay through said switching element to said data path circuit is independent of said user configurable inputs.
2. The circuit as set forth in claim 1, wherein said data path circuit comprises a register.
3. The circuit as set forth in claim 1, wherein said data path circuit comprises a combinatorial circuit.
4. The circuit as set forth in claim 1, wherein said logic function implemented in said clock logic comprises a multiplexer function.
5. The circuit as set forth in claim 1, wherein said logic function implemented in said clock logic comprises a decoder function.
6. The circuit as set forth in claim 4, wherein said multiplexer function comprises multiplexing between a D-type register, T-type register and a latch.
7. The circuit as set forth in claim 1, wherein said logic function, implemented in said clock logic, comprises a polarity function for generating a true or a bar output for said circuit.
8. The circuit as set forth in claim 1, wherein:
said user configurable inputs comprise a D-type register select, a T-type resister select, a latch select and a polarity select;
said logic function implemented in said clock logic comprises a multiplexer function, for selecting among a D-type flip-flop, a T-type flip-flop and a latch, said logic function comprises a toggle function for implementing a T-type flip-flop, and said logic function comprises a polarity function for generating a true or a bar output for said circuit; and
said data path circuit comprises a master latch, coupled to receive said logic output, and a slave latch coupling said master latch and said circuit output.
9. The circuit as set forth in claim 8, wherein said switching element comprises:
a three state inverter coupled to said input signal and being controlled by said clock logic for inverting said input data in accordance with said D-type register select, said T-type resister select, and said polarity select; and
a transmission gate coupled to said input signal and being controlled by said clock logic for passing said input data in accordance with said D-type register select, said T-type resister select, and said polarity select.
10. A programmable logic device (PLD) comprising:
a plurality of user configurable inputs for configuring said PLD; at least one macrocell, coupled to receive said user configurable inputs, said macrocell comprising:
clock logic coupled to said user configurable inputs and coupled to receive a clock input, said clock logic for generating conditional clock signals to implement a logic function for said circuit based on said clock input and said user configurable inputs;
a switching element including at least one transmission gate coupled to said clock logic to receive some of said conditional clock signals and coupled to receive an input signal for said circuit, said switching element for generating a logic output, in accordance with said conditional clock signals, to implement said logic function by controlling propagation of said input signal through said transmission gate; and
a data path circuit coupled to receive said logic output and some of said conditional clock signals for providing additional functionality, wherein propagation delay through said switching element to said data path circuit is independent of said user configurable inputs.
11. The programmable logic device as set forth in claim 10, wherein said data path circuit comprises a register.
12. The programmable logic device as set forth in claim 10, wherein said data path circuit comprises a combinatorial circuit.
13. The programmable logic device as set forth in claim 10, wherein said logic function implemented in said clock logic comprises a multiplexer function.
14. The programmable logic device as set forth in claim 10, wherein said logic function implemented in said clock logic comprises a decoder function.
15. The programmable logic device as set forth in claim 11, wherein said multiplexer function comprises multiplexing between a D-type register, T-type register and a latch.
16. The programmable logic device as set forth in claim 10, wherein said logic function, implemented in said clock logic, comprises a polarity function for generating a true or a bar output for said circuit.
17. The programmable logic device as set forth in claim 10, wherein:
said user configurable inputs comprise a D-type register select, a T-type resister select, a latch select and a polarity select;
said logic function implemented in said clock logic comprises a multiplexer function, for selecting among a D-type flip-flop, a T-type flip-flop and a latch, said logic function comprises a toggle function for implementing a T-type flip-flop, and said logic function comprises a polarity function for generating a true or a bar output for said circuit; and
said data path circuit comprises a master latch, coupled to receive said logic output, and a slave latch coupling said master latch and said circuit output.
18. The programmable logic device as set forth in claim 17, wherein said switching element comprises:
a three state inverter coupled to said input signal and being controlled by said clock logic for inverting said input data in accordance with said D-type register select, said T-type resister select, and said polarity select; and
a transmission gate coupled to said input signal and being controlled by said clock logic for passing said input data in accordance with said D-type register select, said T-type resister select, and said polarity select.
19. A method for configuring a circuit comprising the steps of:
receiving a plurality of user configurable inputs for configuring said circuit;
receiving a clock input;
generating conditional clock signals to implement a logic function for said circuit based on said clock input and said user configurable inputs;
receiving an input signal for said circuit in a switching element including at least one pass gate;
receiving some of said conditional clock signals in said switching element;
generating a logic output from said switching element, in accordance with said conditional clock signals, to implement said logic function by controlling propagation of said input signal through said transmission gate; and
providing a data path circuit coupled to receive said logic output and some of said conditional clock signals for providing additional functionality, wherein propagation delay through said switching element to said data path circuit is independent of said user configurable inputs.
20. A circuit comprising:
a plurality of configurable inputs;
clock logic generating a plurality of conditional clock signals in response to a clock input and the configurable inputs, the conditional clock signals implementing a logic function;
a pass gate controlling propagation of an input signal and generating a logic output in accordance with at least one of the conditional clock signals; and
a data path circuit receiving (i) the logic output of the pass gate and (ii) at least one of the remaining conditional clock signals, the data path circuit providing additional functionality.
21. The circuit of claim 20, wherein the data path circuit comprises a register.
22. The circuit of claim 20, wherein the data path circuit comprises a D-type flip-flop, a T-type flip-flop or a latch.
23. The circuit of claim 22, further comprising set/reset logic having an output coupled to an input of the D-type flip-flop, the T-type flip-flop or the latch.
24. The circuit of claim 20, wherein the data path circuit comprises a D-type flip-flop.
25. The circuit of claim 24, further comprising set/reset logic having an output coupled to an input of the D-type flip-flop.
26. The circuit of claim 20, wherein the data path circuit comprises a combinatorial circuit.
27. The circuit of claim 20, wherein the data path circuit comprises a static random access memory cell.
28. The circuit of claim 20, wherein the data path circuit comprises a three state buffer.
29. The circuit of claim 20, wherein the logic function comprises a multiplexer function.
30. The circuit of claim 20, wherein the logic function comprises a decoder function.
31. The circuit of claim 30, wherein the configurable inputs comprise bits in a static random access memory.
32. The circuit of claim 30, wherein the configurable inputs comprise a polarity select bit.
33. The circuit of claim 30, wherein the configurable inputs comprise one or more function select bits.
34. The circuit of claim 20, wherein the logic function comprises a polarity function generating a true output and a complementary output.
35. The circuit of claim 20, wherein the configurable inputs comprise bits in a shift register, a static random access memory or an electrically erasable and programmable read only memory.
36. The circuit of claim 20, wherein the additional functionality comprises a flip-flop function.
37. The circuit of claim 20, further comprising a feedback loop connecting an output of said data path circuit to an input of said clock logic.
38. A programmable logic device, comprising:
a plurality of configurable inputs;
clock logic generating a plurality of conditional clock signals in response to a clock input and the configurable inputs, the conditional clock signals implementing a logic function;
a pass gate controlling propagation of an input signal and generating a logic output in accordance with at least one of the conditional clock signals; and
a data path circuit receiving (i) the logic output of the pass gate and (ii) at least one of the remaining conditional clock signals, the data path circuit providing additional functionality.
39. The device of claim 38, wherein the propagation is independent of the configurable inputs.
40. A method for configuring a circuit, comprising the steps of:
(a) generating a set of conditional clock signals in response to a clock input and a plurality of configurable inputs;
(b) implementing a logic function at a switch comprising at least one pass gate, said switch receiving an input signal;
(c) generating a logic output from the switch in accordance with at least one of the conditional clock signals; and
(d) controlling propagation of the input signal through the switch in accordance with at least one of the conditional clock signals.
41. The method of claim 40, wherein the propagation is independent of the configurable inputs.
42. The method of claim 41, further comprising providing additional functionality from a data path receiving (i) the logic output and (ii) at least one of the remaining conditional clock signals.
US09/047,314 1996-01-11 1998-03-24 High speed configuration independent programmable macrocell Expired - Lifetime USRE37577E1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US09/047,314 USRE37577E1 (en) 1996-01-11 1998-03-24 High speed configuration independent programmable macrocell

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/584,105 US5621338A (en) 1994-12-20 1996-01-11 High speed configuration independent programmable macrocell
US09/047,314 USRE37577E1 (en) 1996-01-11 1998-03-24 High speed configuration independent programmable macrocell

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US08/584,105 Reissue US5621338A (en) 1994-12-20 1996-01-11 High speed configuration independent programmable macrocell

Publications (1)

Publication Number Publication Date
USRE37577E1 true USRE37577E1 (en) 2002-03-12

Family

ID=26724876

Family Applications (1)

Application Number Title Priority Date Filing Date
US09/047,314 Expired - Lifetime USRE37577E1 (en) 1996-01-11 1998-03-24 High speed configuration independent programmable macrocell

Country Status (1)

Country Link
US (1) USRE37577E1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100192117A1 (en) * 2006-09-22 2010-07-29 Actel Corporation Architecture and method for compensating for disparate signal rise and fall times by using polarity selection to improve timing and power in an integrated circuit
US7816946B1 (en) 2008-01-31 2010-10-19 Actel Corporation Inverting flip-flop for use in field programmable gate arrays

Citations (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4593205A (en) 1983-07-01 1986-06-03 Motorola, Inc. Macrocell array having an on-chip clock generator
US4870302A (en) * 1984-03-12 1989-09-26 Xilinx, Inc. Configurable electrical circuit having configurable logic elements and configurable interconnects
US4903233A (en) 1986-06-20 1990-02-20 Sharp Kabushiki Kaisha Word processor having capability of continuously entering documents into a column or a block of an editing system
US4914322A (en) 1988-12-16 1990-04-03 Advanced Micro Devices, Inc. Polarity option control logic for use with a register of a programmable logic array macrocell
US5027315A (en) 1984-09-28 1991-06-25 Advanced Micro Devices, Inc. Programmable logic array using internally generated dynamic logic signals as selection signals for controlling its functions
US5121006A (en) 1991-04-22 1992-06-09 Altera Corporation Registered logic macrocell with product term allocation and adjacent product term stealing
US5159278A (en) 1991-04-02 1992-10-27 Vlsi Technology, Inc. State machine architecture providing increased resolution of output timing
US5164612A (en) 1992-04-16 1992-11-17 Kaplinsky Cecil H Programmable CMOS flip-flop emptying multiplexers
US5191243A (en) 1991-05-06 1993-03-02 Lattice Semiconductor Corporation Output logic macrocell with enhanced functional capabilities
US5225724A (en) * 1990-10-22 1993-07-06 Sgs-Thomson Microelectronics S.R.L. Operational analysis device of the scan path type having a single scanning clock and a single output phase for an integrated circuit
US5254886A (en) 1992-06-19 1993-10-19 Actel Corporation Clock distribution scheme for user-programmable logic array architecture
US5280203A (en) 1992-05-15 1994-01-18 Altera Corporation Look-ahead asynchronous register set/reset in programmable logic device
US5300830A (en) 1992-05-15 1994-04-05 Micron Semiconductor, Inc. Programmable logic device macrocell with an exclusive feedback and exclusive external input lines for registered and combinatorial modes using a dedicated product term for control
US5302866A (en) 1993-03-18 1994-04-12 Xilinx, Inc. Input circuit block and method for PLDs with register clock enable selection
US5332929A (en) 1993-04-08 1994-07-26 Xilinx, Inc. Power management for programmable logic devices
US5376849A (en) 1992-12-04 1994-12-27 International Business Machines Corporation High resolution programmable pulse generator employing controllable delay
US5424654A (en) 1994-09-22 1995-06-13 Kaplinsky; Cecil H. Programmable macrocell circuit
US5426380A (en) * 1994-09-30 1995-06-20 Sun Microsystems, Inc. High speed processing flip-flop
US5457409A (en) 1992-08-03 1995-10-10 Advanced Micro Devices, Inc. Architecture of a multiple array high density programmable logic device with a plurality of programmable switch matrices
US5473266A (en) 1993-04-19 1995-12-05 Altera Corporation Programmable logic device having fast programmable logic array blocks and a central global interconnect array
US5489857A (en) 1992-08-03 1996-02-06 Advanced Micro Devices, Inc. Flexible synchronous/asynchronous cell structure for a high density programmable logic device
US5502403A (en) * 1994-12-20 1996-03-26 Cypress Semiconductor Corp. High speed configuration independent programmable macrocell
US5506878A (en) 1994-07-18 1996-04-09 Xilinx, Inc. Programmable clock having programmable delay and duty cycle based on a user-supplied reference clock
US5512766A (en) 1990-10-10 1996-04-30 Hitachi, Ltd. Semiconductor integrated circuit device
US5528170A (en) 1992-11-04 1996-06-18 At&T Corp. Low-skew signal routing in a programmable array
US5532500A (en) 1993-09-01 1996-07-02 Nec Corporation Semiconductor integrated circuit device having clock signal wiring construction for suppressing clock skew
US5565792A (en) 1993-01-28 1996-10-15 Xilinx, Inc. Macrocell with product-term cascade and improved flip flop utilization

Patent Citations (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4593205A (en) 1983-07-01 1986-06-03 Motorola, Inc. Macrocell array having an on-chip clock generator
US4870302A (en) * 1984-03-12 1989-09-26 Xilinx, Inc. Configurable electrical circuit having configurable logic elements and configurable interconnects
US5027315A (en) 1984-09-28 1991-06-25 Advanced Micro Devices, Inc. Programmable logic array using internally generated dynamic logic signals as selection signals for controlling its functions
US4903233A (en) 1986-06-20 1990-02-20 Sharp Kabushiki Kaisha Word processor having capability of continuously entering documents into a column or a block of an editing system
US4914322A (en) 1988-12-16 1990-04-03 Advanced Micro Devices, Inc. Polarity option control logic for use with a register of a programmable logic array macrocell
US5512766A (en) 1990-10-10 1996-04-30 Hitachi, Ltd. Semiconductor integrated circuit device
US5225724A (en) * 1990-10-22 1993-07-06 Sgs-Thomson Microelectronics S.R.L. Operational analysis device of the scan path type having a single scanning clock and a single output phase for an integrated circuit
US5159278A (en) 1991-04-02 1992-10-27 Vlsi Technology, Inc. State machine architecture providing increased resolution of output timing
US5121006A (en) 1991-04-22 1992-06-09 Altera Corporation Registered logic macrocell with product term allocation and adjacent product term stealing
US5191243A (en) 1991-05-06 1993-03-02 Lattice Semiconductor Corporation Output logic macrocell with enhanced functional capabilities
US5164612A (en) 1992-04-16 1992-11-17 Kaplinsky Cecil H Programmable CMOS flip-flop emptying multiplexers
US5280203A (en) 1992-05-15 1994-01-18 Altera Corporation Look-ahead asynchronous register set/reset in programmable logic device
US5300830A (en) 1992-05-15 1994-04-05 Micron Semiconductor, Inc. Programmable logic device macrocell with an exclusive feedback and exclusive external input lines for registered and combinatorial modes using a dedicated product term for control
US5391942A (en) 1992-06-19 1995-02-21 Actel Corporation Clock distribution scheme for user-programmable logic array architecture
US5254886A (en) 1992-06-19 1993-10-19 Actel Corporation Clock distribution scheme for user-programmable logic array architecture
US5489857A (en) 1992-08-03 1996-02-06 Advanced Micro Devices, Inc. Flexible synchronous/asynchronous cell structure for a high density programmable logic device
US5457409A (en) 1992-08-03 1995-10-10 Advanced Micro Devices, Inc. Architecture of a multiple array high density programmable logic device with a plurality of programmable switch matrices
US5594365A (en) 1992-08-03 1997-01-14 Advanced Micro Devices, Inc. Flexible block clock generation circuit for providing clock signals to clocked elements in a multiple array high density programmable logic device
US5528170A (en) 1992-11-04 1996-06-18 At&T Corp. Low-skew signal routing in a programmable array
US5376849A (en) 1992-12-04 1994-12-27 International Business Machines Corporation High resolution programmable pulse generator employing controllable delay
US5565792A (en) 1993-01-28 1996-10-15 Xilinx, Inc. Macrocell with product-term cascade and improved flip flop utilization
US5570051A (en) 1993-01-28 1996-10-29 Xilinx, Inc. Multiplexed by-passable memory devices with increased speed and improved flip-flop utilization
US5302866A (en) 1993-03-18 1994-04-12 Xilinx, Inc. Input circuit block and method for PLDs with register clock enable selection
US5332929A (en) 1993-04-08 1994-07-26 Xilinx, Inc. Power management for programmable logic devices
US5473266A (en) 1993-04-19 1995-12-05 Altera Corporation Programmable logic device having fast programmable logic array blocks and a central global interconnect array
US5532500A (en) 1993-09-01 1996-07-02 Nec Corporation Semiconductor integrated circuit device having clock signal wiring construction for suppressing clock skew
US5506878A (en) 1994-07-18 1996-04-09 Xilinx, Inc. Programmable clock having programmable delay and duty cycle based on a user-supplied reference clock
US5424654A (en) 1994-09-22 1995-06-13 Kaplinsky; Cecil H. Programmable macrocell circuit
US5426380A (en) * 1994-09-30 1995-06-20 Sun Microsystems, Inc. High speed processing flip-flop
US5502403A (en) * 1994-12-20 1996-03-26 Cypress Semiconductor Corp. High speed configuration independent programmable macrocell
US5621338A (en) * 1994-12-20 1997-04-15 Cypress Semiconductor Corp. High speed configuration independent programmable macrocell

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
"64-Macrocell Flash PLD", Cypress data sheets, pp. 9-12, (avail. (presumably) in Dec. 1992).
"Advance Information", Intel iFX780 data sheet, pp. 6 & 21, (avail. on or before Jul. 30, 1993).
"High Performance 256-Macrocell Device", Altera EPM7256 EPLD data sheet, pp. 3-4, (avail. on or before Jul. 30, 1993).
"Lattice", Specifications pLSI 1032, pp. 2-2, 2-13 & 2-22, (Jan. 1992).
"The Programmable Logic Data Book", Xilinx, pp. 2-5-2-182 & 3-5-3-88 (1994).
AMD MACH110/12.15.20 data sheet, pp. 12, 6,28 & 13, (avail. on or before Jul. 30, 1993).

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100192117A1 (en) * 2006-09-22 2010-07-29 Actel Corporation Architecture and method for compensating for disparate signal rise and fall times by using polarity selection to improve timing and power in an integrated circuit
US8255854B2 (en) 2006-09-22 2012-08-28 Actel Corporation Architecture and method for compensating for disparate signal rise and fall times by using polarity selection to improve timing and power in an integrated circuit
US7816946B1 (en) 2008-01-31 2010-10-19 Actel Corporation Inverting flip-flop for use in field programmable gate arrays
US7932745B2 (en) 2008-01-31 2011-04-26 Actel Corporation Inverting flip-flop for use in field programmable gate arrays

Similar Documents

Publication Publication Date Title
US5621338A (en) High speed configuration independent programmable macrocell
US5589782A (en) Macrocell and clock signal allocation circuit for a programmable logic device (PLD) enabling PLD resources to provide multiple functions
US5500608A (en) Logic cell for field programmable gate array having optional internal feedback and optional cascade
US5744979A (en) FPGA having logic cells configured by SRAM memory cells and interconnect configured by antifuses
US4903223A (en) Programmable logic device with programmable word line connections
US5386154A (en) Compact logic cell for field programmable gate array chip
US7358786B2 (en) Control signal generator, latch circuit, flip flop and method for controlling operations of the flip-flop
US6525565B2 (en) Double data rate flip-flop
US5646558A (en) Plurality of distinct multiplexers that operate as a single multiplexer
US5023484A (en) Architecture of high speed synchronous state machine
US5291079A (en) Configuration control unit for programming a field programmable gate array and reading array status
US6753714B2 (en) Reducing power and area consumption of gated clock enabled flip flops
US5598114A (en) High speed reduced area multiplexer
US5719516A (en) Lock generator circuit for use with a dual edge register that provides a separate enable for each use of an input clock signal
US5319254A (en) Logic cell which can be configured as a latch without static one's problem
US5331226A (en) Logic cell for field programmable gate array having optional input inverters
US7635989B1 (en) Integrated circuits with bus-based programmable interconnect structures
US7605604B1 (en) Integrated circuits with novel handshake logic
US5625303A (en) Multiplexer having a plurality of internal data paths that operate at different speeds
US6265923B1 (en) Dual rail dynamic flip-flop with single evaluation path
JP2548301B2 (en) Programmable logic circuit device
JPH0440894B2 (en)
US4692634A (en) Selectable multi-input CMOS data register
US5642061A (en) Short circuit current free dynamic logic clock timing
US7746113B1 (en) Circuit structures utilizing multiple voltage level inputs

Legal Events

Date Code Title Description
FPAY Fee payment

Year of fee payment: 8

REMI Maintenance fee reminder mailed
FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FPAY Fee payment

Year of fee payment: 12

SULP Surcharge for late payment

Year of fee payment: 11

AS Assignment

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL

Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:CYPRESS SEMICONDUCTOR CORPORATION;SPANSION LLC;REEL/FRAME:042326/0396

Effective date: 20170421

Owner name: MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL AGENT, MARYLAND

Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:CYPRESS SEMICONDUCTOR CORPORATION;SPANSION LLC;REEL/FRAME:042326/0396

Effective date: 20170421