Adder circuit using lookup tables

US11960857B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11960857-B2
Application numberUS-202318144609-A
CountryUS
Kind codeB2
Filing dateMay 8, 2023
Priority dateDec 28, 2020
Publication dateApr 16, 2024
Grant dateApr 16, 2024

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A four-input lookup table (“LUT4”) is modified to operate in a first mode as an ordinary LUT4 and in a second mode as a 1-bit adder providing a sum output and a carry output. A six-input lookup table (“LUT6”) is modified to operate in a first mode as an ordinary LUT6 with a single output and in a second mode as a 2-bit adder providing a sum output and a carry output. Both possible results for the two different possible carry inputs can be determined and selected between when the carry input is available, implementing a 2-bit carry-select adder when in the second mode and retaining the ability to operate as an ordinary LUT6 in the first mode. Using the novel LUT6 design in a circuit chip fabric allows a 2-bit adder slice to be built that efficiently makes use of the LUT6 without requiring additional logic blocks.

First claim

Opening claim text (preview).

What is claimed is: 1. A circuit comprising: a first arithmetic logic unit (ALU) slice comprising: a plurality of lookup tables (LUTs) including a first LUT and a second LUT; input connections configured to receive as input a portion of a first operand, a portion of a second operand, a first carry-in bit from a second ALU slice, and a second carry-in bit from a third ALU slice; a multiplexer controlled by the second carry-in bit; and output connections configured to provide, as output, a set of sum bits and a carry-out bit, the sum bits containing the sum of the input portion of the first operand, the input portion of the second operand, and the first carry-in bit; wherein each of the plurality of LUTs receives the portion of the first operand and portion of the second operand as inputs. 2. The circuit of claim 1 , wherein the plurality of LUTs is four LUTs. 3. The circuit of claim 2 , wherein the four LUTs are implemented as components of a single larger LUT. 4. The circuit of claim 1 , wherein a high order bit of the sum bits is an XOR of the output of the second LUT with the output of the multiplexer. 5. The circuit of claim 1 , wherein the second LUT of the plurality of LUTs is configured to generate an output that is an XOR of a high bit of the first operand with a high bit of the second operand. 6. The circuit of claim 5 , wherein a third LUT of the plurality of LUTs is configured to generate an output that is an AND of a low bit of the first operand with a low bit of the second operand. 7. The circuit of claim 6 , wherein a fourth LUT of the plurality of LUTs is configured to generate an output that is an OR of: an AND of the high bit of the first operand with the high bit of the second operand; and an AND of: the XOR of the high bit of the first operand with the high bit of the second operand; and the AND of the low bit of the first operand with the low bit of the second operand. 8. The circuit of claim 1 , wherein the second LUT of the plurality of LUTs is configured to generate an output that is an AND of: the binary XOR of a low bit of the first operand with a low bit of the second operand; and an XOR of a high bit of the first operand with a high bit of the second operand. 9. The circuit of claim 8 , wherein a third LUT of the plurality of LUTs is configured to generate an output that is an exclusive or (XOR) of: an AND of the low bit of the first operand with the low bit of the second operand; and the XOR of the high bit of the first operand with the high bit of the second operand. 10. The circuit of claim 9 , wherein a fourth LUT of the plurality of LUTs is configured to generate an output that is an OR of: an AND of the high bit of the first operand with the high bit of the second operand; and an AND of: the XOR of the high bit of the first operand with the high bit of the second operand; and the AND of the low bit of the first operand with the low bit of the second operand. 11. The circuit of claim 1 , wherein a low order bit of the sum bits is an XOR of the output of the first LUT with the first carry-in bit. 12. The circuit of claim 1 , wherein the input connections of the first ALU slice are further configured to receive: a first input bit from the second ALU slice, the first input bit representing the carry-out bit of the second ALU slice if a carry input to the second ALU slice is zero; and a second input bit from the second ALU slice, the second input bit representing the carry-out bit of the second ALU slice if the carry input to the second ALU slice is one. 13. The circuit of claim 12 , wherein the first input bit and the second input bit are received by the first ALU slice before the second ALU slice receives the carry input to the second ALU slice. 14. The circuit of claim 1 , wherein: the first ALU slice is configured to provide, as the output, the set of sum bits and the carry-out bit, in a first mode of operations; and in a second mode of operation, the first ALU slice is configured to: provide, as output, a first output bit based on the input portion of the first operand, the input portion of the second operand, and an assumed value of zero for the first carry-in bit, the first output bit being provided before the first carry-in bit is received as input; provide, as output, a second output bit based on the input portion of the first operand, the input portion of the second operand, and an assumed value of one for the first carry-in bit, the second output bit being provided before the first carry-in bit is received as input. 15. The circuit of claim 14 , comprising one or more additional ALU slices including a highest-order ALU slice, such that the circuit generates, as an output of the highest-order ALU slice in the second mode of operation, one of the following values: a one-bit value that is active if and only if any pair of corresponding bits in the first operand the second operand are active; a one-bit value that is active if and only if any bit in the first operand or the second operand is active; a one-bit value that is active if and only if no pairs of corresponding bits in the first operand and the second operand are both active; a one-bit value that is active if and only if every bit in the first operand and the second operand is not active; a one-bit value that is active if and only if any pair of corresponding bits in the first operand and the second operand are different; or a one-bit value that is active if and only if the first operand and the second operand are identical. 16. A computer-readable medium containing instructions that when executed by a machine, cause the machine to program a field programmable gate array (FPGA) to generate a circuit comprising: a first arithmetic logic unit (ALU) slice comprising: a plurality of lookup tables (LUTs) including a first LUT and a second LUT; input connections configured to receive as input a portion of a first operand, a portion of a second operand, a first carry-in bit from a second ALU slice, and a second carry-in bit from a third ALU slice; a multiplexer controlled by the second carry-in bit; and output connections configured to provide, as output, a set of sum bits and a carry-out bit, the sum bits containing the sum of the input portion of the first operand, the input portion of the second operand, and the first carry-in bit; wherein each of the plurality of LUTs receives the portion of the first operand and the portion of the second operand as inputs. 17. The computer-readable medium of claim 16 , wherein the plurality of LUTs is four LUTs. 18. The computer-readable medium of claim 16 , wherein: the first ALU slice is configured to provide, as the output, the sum bits and the carry-out bit, in a first mode of operations; and in a second mode of operation, the first ALU slice is configured to: provide, as output, a first output bit based on the input portion of the first operand, the input portion of the second operand, and an assumed value of zero for the first carry-in bit, the first output bit being provided before the first carry-in bit is received as input; provide, as output, a second output bit based on the input portion of the first operand, the input portion of the second operand, and an assumed value of one for the first carry-in bit, the second output bit being provided before the first carry-in bit is received as input. 19. The computer-readable medium of claim 18 , wherein the circuit further comprises one or more additional ALU slices including a highest-order ALU

Assignees

Inventors

Classifications

  • using table look-up; using programmable logic arrays (G06F7/509 takes precedence) · CPC title

  • using selection between two conditionally calculated carry or sum values · CPC title

  • G06F7/575Primary

    Basic arithmetic logic units, i.e. devices selectable to perform either addition, subtraction or one of several logical operations, using, at least partially, the same circuitry · CPC title

  • working, at least partly, by table look-up (G06F1/025 takes precedence) · CPC title

  • for multiple operands · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US11960857B2 cover?
A four-input lookup table (“LUT4”) is modified to operate in a first mode as an ordinary LUT4 and in a second mode as a 1-bit adder providing a sum output and a carry output. A six-input lookup table (“LUT6”) is modified to operate in a first mode as an ordinary LUT6 with a single output and in a second mode as a 2-bit adder providing a sum output and a carry output. Both possible results for t…
Who is the assignee on this patent?
Achronix Semiconductor Corp
What technology area does this patent fall under?
Primary CPC classification G06F7/575. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Apr 16 2024 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 3 related publications on this page (citations in our corpus or others sharing the same primary CPC).