Programmable logic device with fine-grained disaggregation
A programmable device may have logic circuitry formed in a top die and memory and specialized processing blocks formed in a bottom die, where the top die is stacked directly on top of the bottom die in a face-to-face configuration. The logic circuitry may include logic sectors, logic array blocks, logic elements, and other types of logic regions. The memory blocks may include large banks of multiport memory for storing data. The specialized processing blocks may include multipliers, adders, and other arithmetic components. The logic circuitry may access the memory and specialized processing blocks via an address encoded scheme. Configured in this way, the maximum operating frequency of the programmable device can be optimized such that critical paths will no longer need to traverse any unused memory and specialized processing blocks.
Latest Intel Patents:
- USE OF A PLACEHOLDER FOR BACKSIDE CONTACT FORMATION FOR TRANSISTOR ARRANGEMENTS
- METHODS AND APPARATUS TO ENABLE SECURE MULTI-COHERENT AND POOLED MEMORY IN AN EDGE NETWORK
- DATA TRANSFER OVER AN INTERCONNECT BETWEEN DIES OF A THREE-DIMENSIONAL DIE STACK
- METHODS, SYSTEMS, ARTICLES OF MANUFACTURE AND APPARATUS TO GENERATE DYNAMIC COMPUTING RESOURCE SCHEDULES
- METHODS AND APPARATUS FOR EDGE PROTECTED GLASS CORES
This relates generally to integrated circuits and more particularly, to programmable integrated circuits.
Programmable integrated circuits are a type of integrated circuit that can be programmed by a user to implement a desired custom logic function. In a typical scenario, a logic designer uses computer-aided design tools to design a custom logic circuit. When the design process is complete, the computer-aided design tools generate configuration data. The configuration data is loaded into memory elements on a programmable integrated circuit to configure the device to perform the functions of the custom logic circuit. Such types of programmable integrated circuits are sometimes referred to as a field-programmable gate array (FPGA).
An FPGA typically includes logic circuitry having lookup tables (LUTs), adders, and registers that are configurable to allow a user to customize the logic circuitry according to the user's particular needs. The logic circuitry is organized into an array of logic regions sometimes referred to as logic array blocks (LABs). In addition to the logic circuitry, an FPGA also includes large memory blocks for storing user data and digital signal processing (DSP) blocks that are partly or fully hardwired to perform one or more specific tasks such as a mathematical operation. In addition to the configurable logic, memory, and DSP blocks, an FPGA also includes programmable routing fabric that is used to interconnect the LABs with the memory and DSP blocks. The combination of the programmable logic and routing fabric is sometimes referred to as “soft” logic. The DSP blocks are sometimes referred to as “hard” logic.
The performance of an FPGA is limited by the longest signal propagation delay through a combinational logic path between two sequential digital flip-flop circuits. Conventionally, an FPGA is implemented as a single integrated circuit die. In such scenarios, there will often be a long combinational logic path that starts in a first LAB, traverses an unused memory block or DSP block, and ends in a second LAB, which sets the critical path for the FPGA. This particular architecture can substantially limit the performance of the FPGA.
It is within this context that the embodiments described herein arise.
The present embodiments relate to ways for improving the performance of a programmable integrated circuit. A programmable integrated circuit device may include logic circuitry, memory blocks, specialized processing blocks, and programmable routing fabric interconnecting the various components on the programmable device. Combinational paths that need to traverse the memory blocks and/or the specialized processing blocks from one logic region to another can add substantial wire delay and limit the performance of the programmable device.
In accordance with an embodiment, the programmable device may be disaggregated into separate integrated circuit dies, where all of the memory blocks and specialized processing blocks are formed in a first integrated circuit die and where all of the logic circuitry is formed separately in a second integrated circuit die that is stacked on top of the first integrated circuit die. Configured in this way, combinational paths connecting different logic regions would no longer traverse the memory blocks and specialized procession blocks. As a result, the capacitive loading of the interconnect paths is reduced, which lowers interconnect latency as well as power consumption. Moreover, feedthrough paths are eliminated, which results in better wire utilization and routing efficiency for routing fabric. All of these technical improvements can help increase the maximum operating speed (or fmax) of the programmable device.
It will be recognized by one skilled in the art, that the present exemplary embodiments may be practiced without some or all of these specific details. In other instances, well-known operations have not been described in detail in order not to unnecessarily obscure the present embodiments.
An illustrative embodiment of a programmable integrated circuit such as programmable logic device (PLD) 100 that may be configured to implement a circuit design is shown in
Programmable logic device 100 may contain programmable memory elements. Memory elements may be loaded with configuration data (also called programming data). Once loaded, the memory elements each provide a corresponding static control signal that controls the operation of an associated functional block (e.g., LABs 110, DSP 120, RAM 130, etc.).
In a typical scenario, the outputs of the loaded memory elements are applied to the gates of metal-oxide-semiconductor transistors in a functional block to turn certain transistors on or off and thereby configure the logic in the functional block including the routing paths. Programmable logic circuit elements that may be controlled in this way include parts of multiplexers (e.g., multiplexers used for forming routing paths in interconnect circuits), look-up tables, logic arrays, AND, OR, NAND, and NOR logic gates, pass gates, etc.
The memory elements may use any suitable volatile and/or non-volatile memory structures such as random-access-memory (RAM) cells, fuses, antifuses, programmable read-only-memory memory cells, mask-programmed and laser-programmed structures, combinations of these structures, etc. Because the memory elements are loaded with configuration data during programming, the memory elements are sometimes referred to as configuration memory, configuration random-access memory (CRAM), or programmable memory elements. Programmable logic device (PLD) 100 may be configured to implement a custom circuit design. For example, the configuration RAM may be programmed such that LABs 110, DSP 120, and RAM 130, and programmable interconnect circuitry (i.e., vertical channels 140 and horizontal channels 150) form the circuit design implementation.
In addition, the programmable logic device may further include input-output (I/O) elements (not shown) for driving signals off of PLD 100 and for receiving signals from other devices. The input-output elements may include parallel input-output circuitry, serial data transceiver circuitry, differential receiver and transmitter circuitry, or other circuitry used to connect one integrated circuit device to another.
As described above, device 100 may also include programmable interconnect circuitry in the form of vertical routing channels 140 (i.e., interconnects formed along a vertical axis of PLD 100) and horizontal routing channels 150 (i.e., interconnects formed along a horizontal axis of PLD 100), each routing channel including at least one track to route at least one wire. If desired, the interconnect circuitry may include pipeline elements, and the contents stored in these pipeline elements may be accessed during operation. For example, a programming circuit may provide read and write access to a pipeline element.
Note that other routing topologies, besides the topology of the interconnect circuitry depicted in
As described above in connection with
The combinational logic is mostly formed in the LABs 304. In the example of
To help increase the speed at which configuration can occur on a programmable logic device, as well as to better control power consumption, reduce manufacturing costs, among other things, a programmable logic device may be formed as a first die that contains primarily programmable logic fabric and a second die that contains fabric support circuitry for supporting the operation of the programmable logic fabric in the first die. An arrangement of this type is described in detail in Gutala et al. (a commonly owned U.S. patent application Ser. No. 15/855,419, filed on Dec. 27, 2017), which is incorporated herein by reference.
In accordance with an embodiment, a programmable logic device may be implemented using a split or “disaggregated” architecture, where the logic circuitry such as the logic array blocks (LABs), logic elements (LEs), adaptive logic modules (ALMs), configurable logic blocks (CLBs), and other logic regions are formed in a first die 402-1 and where the other embedded functional blocks such as the RAM blocks and the DSP blocks are formed in a second die 402-2 (see, e.g.,
Microbumps 412 may be formed between dies 402-1 and 402-2 to help couple circuitry 406 to circuitry 410. Bumps such as controlled collapse chip connection (C4) bumps 414 may be formed at the bottom surface of substrate 408. Bumps 414 may be coupled to circuitry 410 using through-silicon vias (TSVs) 416. Generally, C4 bumps 414 (e.g., bumps used for interfacing with off-package components) are substantially larger in size compared to microbumps 412 (e.g., bumps used for interfacing with other dies within the same package). The number of microbumps 412 is also much greater than the number of bumps 414 (e.g., the ratio of the number of microbumps to the number of C4 bumps may be greater than 2:1, 5:1, 10:1, etc.). This arrangement in which circuitry 406 of die 402-1 directly faces circuitry 410 of die 402-2 is sometimes referred to as a “face-to-face” configuration.
The control circuitry in 410 may generally include memory address decoding logic, clocking logic such as phase-locked loops (PLLs), calibration logic for managing die-to-die variations, debugging logic for detecting and correct defects on device 400, and/or other infrastructure-related circuits. The control circuitry in 410 may also include input-output (I/O) elements for driving signals off of device 400 and for receiving signals from other devices such as other memory devices and logic devices that are not contained within top die 402-1. The input-output elements may include parallel input-output circuitry, serial data transceiver circuitry, differential receiver and transmitter circuitry, or other circuitry used to connect one integrated circuit device to another.
Forming the control circuitry in the bottom die 402-2 can help reduce the number of microbumps 412 that are needed. The RAM blocks are also generally considered the colder part of device 400. Hence, moving memories and the DSP blocks to the bottom die has no thermal impact. A heat dissipation structure such as heat sink 490 may be formed on top of die 402-1 to help dissipate the heat generated by device 400. If desired, die 402-1 and die 402-2 may be fabricated using different technology or process nodes. As an example, die 402-1 may be manufactured using a more advanced or newer process technology node while die 402-1 is manufactured using a less advanced or older process technology node. In this example, die 402-2 may be configured as an interposer or some other intermediary substrate with some active circuitry. As another example, die 402-2 may be manufactured using a more advanced or newer process technology node while die 402-1 is manufactured using a less advanced or older process technology node.
As shown in
Input signals IN may be received by lookup table circuitry 42 (e.g., from the input selection circuitry described in connection with
Register circuitry 44 may include one or more registers that store output signals from look-up table circuitry 42 based on one or more clock and control signals. The clock and control signals may be received from interconnects such as interconnects 140 and/or 150 of
The logic circuitry of the type shown in
RAM blocks 130 (sometimes also referred to as “block RAMs”) may be single-port or multi-port memory blocks configured to store large amounts of data (e.g., to store at least 10K bits, 20K bits, 20-40K bits, 40-100K bits, or any suitable number of bits).
In yet another suitable arrangement, RAM block 130 may also be configured as a first-in first-out (FIFO) buffer circuit (see, e.g.,
The examples of
DSP blocks 120 (sometimes referred to as “specialized processing blocks” or multiply-accumulate blocks) may include a concentration of circuitry that has been partially or fully hardwired to perform one or more specific tasks, such as a logical or a mathematical operation (e.g., a multiply operation, an add operation, a sum-of-products operation, a dot-vector operation, etc.). A DSP block may also contain one or more specialized structures such as an array of configurable storage elements.
Examples of structures that may be implemented in DSP blocks 120 include: multipliers, adders, accumulators, arithmetic logic units (ALUs), barrel-shifters, various memory elements (such as FIFO/LIFO/SIPO/RAM/ROM/CAM blocks and register files), logic AND/NAND/OR/NOR arrays, etc., or combinations thereof. Storage elements within DSP block 120 may serve different purposes than configuration memory. For instance, storage elements within DSP block 120 may store coefficients for implementing FIR filters, Fourier transforms (e.g., fast Fourier transforms), or other polynomial functions. Alternatively, storage elements within DSP block 120 may be used to pipeline a critical path or to synchronize data before it is processed.
In the example of
Multiplexer 56 may have a first (1) input that receives the product output from multiplier 50, a second (2) input that directly receives input signal In2 via bypass path 70, a third (3) input that receives a third input signal In3, which can be fed directly from an adjacent multiply-accumulate circuit 700 or specialized processing block 120 via a hardwired direct-connection path 66, and an output. Adder 52 has a first input coupled to the output of multiplexer 56, a second input coupled to the output of multiplexer 58, and an output that feeds into output register 54. Multiplexer 58 may have a first (1) input that receives output signal Out1 from output register 54 and a second (2) input that directly receives signal In3 via path 66.
Multiplexer 680 may have a first (1) input that is directly connected to the output of multiplier 50, a second (2) input that receives Out1 from output register 54 via path 64, and an output at which output signal Out2 is provided. When circuits 700 are connected in series, output signal Out2 may be fed directly to a succeeding circuit 700 or DSP block 120 via hardwired path 68 and shall serve as input signal In3 for the block. The use of fixed direct-connection paths such as paths 66 and 68 between adjacent circuits 700 or DSP blocks 120 helps to reduce routing complexity for external programmable interconnection routing resources that would otherwise be needed to route output signals from one MAC/DSP block to inputs of another MAC/DSP block when multiple blocks are connected in a chain.
The multiply-accumulate circuit 700 of the type shown in
Configured in this way, combinational paths such as path 850 conveying a signal from one logic region to another will not need to traverse through the length/width of an unused RAM or DSP block, which can reduce critical path delay and dramatically optimize the performance of programmable device 400. In other words, the combinational paths interconnecting the various logic regions 110 will see interconnect latency that is reduced as a function of the linear dimensions of blocks 120 and 130. Reduction of interconnect lengths reduces capacitive loading, which improves performance by increasing fmax as well as lower power consumption.
The microbump array 412 interposed between circuitry 406 in the top die and circuitry 410 in the bottom die may not have sufficient density to provide 1:1 access to each individual memory bit in the memory blocks of the bottom die. Thus, it may be desirable to use an address encoded scheme to access the bits in RAM blocks 130.
Accessing the bottom die in this way will incur latency penalty of the RC delay path between the top die and the bottom die. This delay is currently estimated to be only a single clock cycle. The performance benefit that is gained by this split architecture will be much larger than the performance degradation that is caused because of an additional cycle of latency to access the bottom die.
In some arrangements, DSP accesses are assumed to be always registered. Moreover, DSP blocks 120 might also be fed by RAM blocks 120 as shown by path 950 in
In other suitable arrangements, an encoded scheme may also be provided to access individual multipliers in the DSP blocks 120 (see, e.g.,
At step 1002, an address encoder in the top die (e.g., address encoder 900 or 910) may be used to encode the memory bit address or multiplier address. At step 1004, the encoded address may be sent to the bottom die.
At step 1006, an address decoder in the bottom die (e.g., address decoder 902 or 912) may be used to decode the received address. At step 1008, the memory request may be executed by accessing the selected memory byte location or multiplier using the decoded address. At step 1010, data may be optionally fetched from the selected memory bit or multiplier back to the top die.
These steps are merely illustrative and are not intended to limit the present embodiments. At least some of the existing steps may be modified or omitted; some of the steps may be performed in parallel; additional steps may be added or inserted; and the order of certain steps may be reversed or altered.
The foregoing embodiments may be made part of a larger system.
System 92 may be a digital system or a hybrid system that includes both digital and analog subsystems. System 92 may be used in a wide variety of applications as part of a larger computing system, which may include but is not limited to: a data center, a computer networking system, a data networking system, a digital signal processing system, a graphics processing system, a video processing system, a computer vision processing system, a cellular base station, a virtual reality or augmented reality system, a network functions virtualization platform, an artificial neural network, an autonomous driving system, a combination of at least some of these systems, and/or other suitable types of computing systems.
The embodiments thus far have been described with respect to integrated circuits. The methods and apparatuses described herein may be incorporated into any suitable circuit. For example, they may be incorporated into numerous types of devices such as programmable logic devices, application specific standard products (ASSPs), and application specific integrated circuits (ASICs), microcontrollers, microprocessors, central processing units (CPUs), graphics processing units (GPUs), etc. Examples of programmable logic devices include programmable arrays logic (PALs), programmable logic arrays (PLAs), field programmable logic arrays (FPLAs), electrically programmable logic devices (EPLDs), electrically erasable programmable logic devices (EEPLDs), logic cell arrays (LCAs), complex programmable logic devices (CPLDs), and field programmable gate arrays (FPGAs), just to name a few.
EXAMPLESThe following examples pertain to further embodiments.
Example 1 is a device, comprising: a first integrated circuit die that primarily includes logic circuitry; and a second integrated circuit die that primarily includes embedded functional blocks different than the logic circuitry, wherein the first integrated circuit die is stacked vertically with respect to the second integrated circuit die, and wherein the first integrated circuit die is configured to communicate with the second integrated circuit die to perform a custom logic function.
Example 2 is the device of example 1, wherein the second integrated circuit die generates less heat than the first integrated circuit die.
Example 3 is the device of example 2, wherein the first integrated circuit die is stacked on top of the second integrated circuit die, and wherein the first die and the second die are fabricated using different technology nodes.
Example 4 is the device of any one of examples 1-3, wherein the logic circuitry comprises a plurality of logic array blocks.
Example 5 is the device of example 4, wherein the plurality of logic array blocks comprises lookup table and register circuitry.
Example 6 is the device of any one of examples 4-5, wherein the embedded function blocks comprises a plurality of random-access memory blocks.
Example 7 is the device of example 6, wherein the embedded function blocks further comprises a plurality of specialized processing blocks, and wherein the plurality of specialized processing blocks comprises multiplier circuits.
Example 8 is the device of example 7, wherein the first integrated circuit die does not include any random-access memory blocks or specialized processing blocks, and wherein the second integrated circuit die does not include any logic array blocks.
Example 9 is the device of any one of examples 1-8, wherein the first integrated circuit die further comprises an address encoder configured to produce address bits for addressing the embedded functional blocks in the second integrated circuit die.
Example 10 is the device of any one of examples 1-9, wherein the second integrated circuit die further comprises control circuitry, wherein the control circuitry comprises circuits selected from the group consisting of: address decoding logic, clocking logic, calibration logic, and debugging logic, and wherein the first integrated circuit die does not include any such type of control circuitry.
Example 11 is the device of any one of examples 1-10, wherein the second integrated circuit die further comprises input-output elements configured to communicate with devices that are not part of the first integrated circuit die.
Example 12 is a method of operating a device that includes a top die stacked on a bottom die, the method comprising: with an address encoder in the top die, encoding address bits; sending the encoded address bits to the bottom die; and using the encoded address bits to access embedded functional blocks within the bottom die.
Example 13 is the method of example 12, wherein the embedded function blocks comprise random-access memory blocks and specialized processing blocks, and wherein the top die does not include any random-access memory blocks and specialized processing blocks.
Example 14 is the method of example 13, further comprising: with an address decoder in the bottom die, decoding the encoded address bits.
Example 15 is the method of example 14, further comprising: using the decoded address bits to select a memory byte location in one of the random-access memory blocks or to select a multiplier in one of the specialized processing blocks.
Example 16 is the method of example 15, further comprising using microbumps to send the encoded address bits to the random-access memory blocks, wherein there are no microbumps for directly accessing the specialized processing blocks, and wherein the specialized processing blocks are only accessed via the random-access memory blocks.
Example 17 is a system, comprising: a top die having logic array blocks; and a bottom die having memory blocks, wherein the bottom die does not include any logic array blocks, and wherein at least first and second logic array blocks in the top die directly overlaps with one of the memory blocks in the bottom die.
Example 18 is the system of example 17, wherein the top and bottom dies form a programmable device that is are part of a selected one of: a datacenter, a computer networking system, a data networking system, a digital signal processing system, a graphics processing system, a video processing system, a computer vision processing system, a cellular base station, a virtual reality system, an augmented reality system, a network functions virtualization platform, an artificial neural network, and an autonomous driving system.
Example 19 is the system of any one of examples 17-18, wherein the bottom die further comprises digital signal processing (DSP) blocks, and wherein the top die does not include any DSP blocks.
Example 20 is the system of example 19, wherein at least third and fourth logic array blocks in the top die directly overlaps with one of the DSP blocks in the bottom die.
Example 21 is the system of any one of examples 19-20, wherein the bottom die further includes control circuitry, wherein the control circuitry comprises circuits selected from the group consisting of: address decoding logic, clocking logic, calibration logic, and debugging logic, and wherein at least a fifth logic array block in the top die at least partially directly overlaps the control circuitry in the bottom die.
For instance, all optional features of the apparatus described above may also be implemented with respect to the method or process described herein. The foregoing is merely illustrative of the principles of this disclosure and various modifications can be made by those skilled in the art. The foregoing embodiments may be implemented individually or in any combination.
Claims
1. A device, comprising:
- a first integrated circuit die that primarily includes logic circuitry but does not include any random-access memory blocks; and
- a second integrated circuit die that primarily includes embedded functional blocks different than the logic circuitry, wherein the first integrated circuit die is stacked vertically with respect to the second integrated circuit die, and wherein the first integrated circuit die is configured to communicate with the second integrated circuit die to perform a custom logic function.
2. The device of claim 1, wherein the second integrated circuit die generates less heat than the first integrated circuit die.
3. The device of claim 2, wherein the first integrated circuit die is stacked on top of the second integrated circuit die, and wherein the first die and the second die are fabricated using different technology nodes.
4. The device of claim 1, wherein the logic circuitry comprises a plurality of logic array blocks.
5. The device of claim 4, wherein the plurality of logic array blocks comprises lookup table and register circuitry.
6. The device of claim 4, wherein the embedded function blocks comprises a plurality of random-access memory blocks.
7. The device of claim 6, wherein the embedded function blocks further comprises a plurality of specialized processing blocks, and wherein the plurality of specialized processing blocks comprises multiplier circuits.
8. The device of claim 7, wherein the first integrated circuit die does not include any specialized processing blocks, and wherein the second integrated circuit die does not include any logic array blocks.
9. The device of claim 1, wherein the first integrated circuit die further comprises an address encoder configured to produce address bits for addressing the embedded functional blocks in the second integrated circuit die.
10. The device of claim 1, wherein the second integrated circuit die further comprises control circuitry, wherein the control circuitry comprises circuits selected from the group consisting of: address decoding logic, clocking logic, calibration logic, and debugging logic, and wherein the first integrated circuit die does not include any such type of control circuitry.
11. The device of claim 1, wherein the second integrated circuit die further comprises input-output elements configured to communicate with devices that are not part of the first integrated circuit die.
12. A method of operating a device that includes a top die stacked on a bottom die, the method comprising:
- with an address encoder in the top die, encoding address bits;
- sending the encoded address bits to the bottom die; and
- using the encoded address bits to access embedded functional blocks within the bottom die.
13. The method of claim 12, wherein the embedded function blocks comprise random-access memory blocks and specialized processing blocks, and wherein the top die does not include any random-access memory blocks and specialized processing blocks.
14. The method of claim 13, further comprising:
- with an address decoder in the bottom die, decoding the encoded address bits.
15. The method of claim 14, further comprising:
- using the decoded address bits to select a memory byte location in one of the random-access memory blocks or to select a multiplier in one of the specialized processing blocks.
16. The method of claim 15, further comprising:
- using microbumps to send the encoded address bits to the random-access memory blocks, wherein there are no microbumps for directly accessing the specialized processing blocks, and wherein the specialized processing blocks are only accessed via the random-access memory blocks.
17. A system, comprising:
- a top die having logic array blocks; and
- a bottom die having memory blocks, wherein the bottom die does not include any logic array blocks, and wherein at least first and second logic array blocks in the top die directly overlaps with one of the memory blocks in the bottom die.
18. The system of claim 17, wherein the top and bottom dies form a programmable device that is are part of a selected one of: a datacenter, a computer networking system, a data networking system, a digital signal processing system, a graphics processing system, a video processing system, a computer vision processing system, a cellular base station, a virtual reality system, an augmented reality system, a network functions virtualization platform, an artificial neural network, and an autonomous driving system.
19. The system of claim 17, wherein the bottom die further comprises digital signal processing (DSP) blocks, and wherein the top die does not include any DSP blocks.
20. The system of claim 19, wherein at least third and fourth logic array blocks in the top die directly overlaps with one of the DSP blocks in the bottom die.
21. The system of claim 19, wherein the bottom die further includes control circuitry, wherein the control circuitry comprises circuits selected from the group consisting of: address decoding logic, clocking logic, calibration logic, and debugging logic, and wherein at least a fifth logic array block in the top die at least partially directly overlaps the control circuitry in the bottom die.
5550782 | August 27, 1996 | Cliff |
5787007 | July 28, 1998 | Bauer |
8922243 | December 30, 2014 | Jayasena et al. |
9106229 | August 11, 2015 | Hutton et al. |
9294092 | March 22, 2016 | Hutton |
9344091 | May 17, 2016 | Jayasena et al. |
9633872 | April 25, 2017 | Chen et al. |
9935052 | April 3, 2018 | Liu et al. |
20030102495 | June 5, 2003 | Huppenthal |
20040178819 | September 16, 2004 | New |
20140181458 | June 26, 2014 | Loh et al. |
20180176006 | June 21, 2018 | McElheny et al. |
- Gutala et al., U.S. Appl. No. 15/855,419, filed Dec. 27, 2017.
Type: Grant
Filed: Sep 6, 2018
Date of Patent: Mar 24, 2020
Assignee: Intel Corporation (San Jose, CA)
Inventors: Dheeraj Subbareddy (Portland, OR), Md Altaf Hossain (Portland, OR), Ankireddy Nalamalpu (Portland, OR), Robert Sankman (Phoenix, AZ), Ravindranath Mahajan (Chandler, AZ), Gregg William Baeckler (San Jose, CA)
Primary Examiner: Daniel D Chang
Application Number: 16/123,765
International Classification: H03K 19/177 (20060101); H03K 19/1776 (20200101); H01L 25/18 (20060101); H01L 23/367 (20060101);