To understand the FinFET architecture, designers should fi rst compare the channels to a planar architecture, as shown in Figure 2 . The left image shows a planar transistor. The major process motivation for switching to FinFET is what process engineers call "short-channel effects" and what design engineers call "leakage." When the channel under the gate is too short and too deep for the gate to control it properly, even with it is "off" it is still partially "on" and leakage current fl ows, leading to very high static power dissipation.
The middle image shows a FinFET. The fi n (grey) is thin and the gate wraps completely around it. All parts of the channel, where the fi n passes through the gate, are well-controlled and leakage is much lower. In process-speak, the channel is fully depleted of carriers. Typically, the architecture uses multiple fi ns (two or three), but future processes may use more. Using multiple fi ns offers better control than just a single fi n.
The use of multiple fi ns highlights a substantial difference between FinFET and planar architectures. Planar processes use a two-dimensional interface with dimensions of the transistor width and length. In FinFETs, the size of the fi n is fi xed and the thickness of the gate (that defi nes the channel length) is also fi xed. The only parameter for varying a FinFET is the number of fi ns, and that has to be an integral number. For example: it is not possible to have 2½ fi ns. FinFETs offer more effi cient transistors that enable lower operating voltages, which has positive effects on both static power (linear) and dynamic power (quadratic). The power savings can be as high as 50%. The performance is higher as well-at 0.7V, performance (throughput) is 37% better than planar technology.
FinFET Complexity Leads to Manufacturing Challenges
The complexity of a FinFET compared to planar typically leads to a more expensive manufacturing process, at least initially. As foundries gain more experience and better control of the process, these costs will probably decline but for the time being there is an increase in moving from planar processes.
FinFETs also have thermal challenges. As the fi ns stick up, the body (substrate) of the die does not act as a heatsink and this can result in degradation and aging. The thermal challenges also have implications for repair because in some circumstances, memories need to be repaired not just at manufacturing test, but also later in the fi eld.
Foundries need to take these challenges into account when making the process yield, ramping it to volume and so on. Typically, the foundries are also responsible for the memory bit cells which require thorough analysis (through simulation) and qualifi cation (through running wafers). The IP providers, whether for memories, standard cells, or interfaces, also need to build their layout while taking these issues into account.
The impact on the SoC designers is less, at least for digital fl ows. Designers typically will never see a fi n any more than they ever saw a transistor before, unless they look inside the standard cells that their place-and-route tool was using to connect with the metal fabric.
STAR Memory System
The Synopsys ecosystem (Figure 3 ) includes all the tools required to create the layout, perform extraction, simulation and so forth. The internal Synopsys IP groups are able to leverage the complete Synopsys tool suite to design, validate, and test Synopsys IP, including memories. Self-test and repair has been used for many process generations, not just with FinFET. With constant investments, Synopsys has improved STAR Memory System. In Figure 4 , the STAR Memory System is represented by the purple boxes. These contain RTL blocks that are generated from the STAR Memory System IP compilers to deal with individual memories: SRAM, dual port, single port, register files and so on. The wrappers are all tied together through the STAR Memory System processors, which report back to the overall manager of the whole system, the STAR Memory System server which in turn provides all the required schedules and handshakes. The external interface is through the JTAG test access port (TAP) controller. Starting in 2012, Synopsys has worked with an ecosystem of memory designers who have early access to process parameters. Working with multiple FinFET manufacturers, Synopsys analyzed their bit cells and also examined their models, validated them, created test chips, and analyzed the silicon directly in Synopsys' internal labs. This process gave Synopsys a deep understanding of defect issues with FinFETs and enabled Synopsys to optimize the STAR Memory System to address them.
HSPICE
As a result, today the STAR Memory System is used in multiple capacities:
`For process development: Using STAR Memory System to characterize and understand the foundry process for manufacturing `For IP qualification: Characterizing and qualifying the memory IP itself `For SoC design: Incorporating the STAR Memory System into the design for SoC analysis, including manufacturing test and repair `For managing field reliability and aging: Handling the thermal issues inherent in FinFET processes due to the fin protruding, thermally isolated from the underlying base. Issues that can arise through the life of the SoC can be as minor as soft errors, which are automatically corrected through error correcting code (ECC). But aging in high-reliability systems may require the STAR Memory System to be used periodically, or at power-on to fix faults that develop in the field long after manufacturing test is completed.
Of course the memory is not the only part of the chip that needs to be tested. There will also be logic blocks, interface IP blocks, analog mixed-signal (AMS) blocks and so on. Synopsys provides a comprehensive set of test and IP solutions that integrate smoothly with the STAR Memory System ( Figure 5 
Understanding FinFET Memory Failures and Defects
Before understanding how to test and repair memories, designers must understand the ways in which they can fail. For example, resistive faults have been revealed as a performance problem in logic, where the logic passes the test but does not work at full speed. In memories, resistive faults can manifest in a more subtle way. The faults might cause a detectable error only after multiple operations (a write followed by several reads) instead of the more standard single operation (a read).
Designers must also ascertain which errors can realistically occur by looking at the layout. In digital logic testing, big increases in coverage can be obtained by analyzing which metals are adjacent and might short together. The same can be done in a memory by analyzing potential resistive shorts, where signal lines may fail and so on. This requires a mixture of looking at the layout and spinning and analyzing test chips to identify possible faults. The requirement for deep analysis is one of the reasons that Synopsys has run more than 50 FinFET test chips at multiple foundries. Information from these tests is used to improve the STAR Memory System.
Figure 6 illustrates several different defect types possible with FinFET processes. It illustrates just one fi n per transistor, but there is typically more than one fi n per transistor. Of course opens and shorts can occur but in FinFETs they can cause different behavior: fi n opens, gate opens, fi n stuck-ons, in-gate fi n shorts and so on. Each of these can be a hard open or short or can be resistive, with a resistance value varying from low to high producing different behavior.
Gate-Fin Short
Figure 6: Potential FinFET defect types
After analyzing the layout, designers must look at the topology to see if faults can realistically occur, based on the physical structure of the transistor.
The next step for designers is to go up a level from the pure transistor. An SRAM cell contains six transistors so the cell needs to be analyzed for opens in internal nodes, and how that might occur, and what would be the result. At the next level, the cell layout is the target. For example, Figure 7 shows all the possible open defects that can occur in the six transistor SRAM cell. Third, designers analyze the entire memory array for faults such as opens in bit-lines, shorts between word lines and so on. Finally, at the block level, the entire memory including surrounding blocks such as the address decoder need to be examined, as do the sense-amps.
The actual analysis proceeds through defect injection. This is based on the GDS (layout) itself. Defect injection is done on the layout and on the SPICE models, using a defect library for each of the libraries and then seeing how they behave. Defect injection is done on transistors for all providers of 14/16nm FinFET whether they are IDMs or foundries. Defect injection is also done for planar technologies at higher nodes such as 45nm and 28nm.
Considered locations of open defects in 6T FinFET SRAM-cell
All transistor fins and nodes in SRAM cells Defect injection demonstrates how each defect is behaving. The next action is to fi nd a test sequence that detects the defect, through Test Sequence Identifi cation (TSI). For each one of the potential defects, one or more test sequences are identifi ed, as well as the conditions under which it would be detected and the fault model that it corresponds to. Lots of test sequences, stress corners and simulation setups are used until a sequence is found that exhibits an observable difference from the defect-free version of the cell.
In some cases, these defects will be fault models that have previously been seen in planar technology but FinFET memories have some additional failure modes. For example, Figure 8 shows a subtle failure mode. A resistive fi n open in a pull-down transistor results in a dynamic deceptive read destructive fault (dDRDF). Here, a write, followed by 7 reads, results in the bit value of the memory cell fl ipping. This can then be examined in more detail since it turns out to be frequency dependent. At 1.2MHz it just takes 4 reads but at 4MHz it takes 18. The temperature and voltage also impact these values. Some broad conclusions from Synopsys' fault modeling on FinFET technologies are:
`FinFET-based memories are more prone to dynamic faults than planar memories `FinFET-based memories are more stable against process variation faults `Static single-cell and coupling faults are common in both types of memories `Stress corners (voltage, temperature, frequency) are important for detecting FinFET-specifi c faults using only nominal corners misses some issues.
Generating Test Sequences
Once the fault modeling background is complete, designers understand the voltage, temperature and frequencies requirements for tests. The sequences for a given corner are combined with an engine known as the Test Algorithm Generator (TAG). The TAG will combine together small test sequences for individual fault types and create a minimum test algorithm to minimize the test time and so the test cost. Figure 9 shows the TAG for FinFETs. The processes in the fi gure are all automated, from injection of the fault to test sequence identifi cation to the TAG itself. Different pieces of algorithms can be partitioned for different corners and different levels of fault detections. Partitioning creates a pool of test sequences for different conditions, as different users and applications will have different requirements. For example, during manufacturing test, designers must identify failures so that they can be corrected, but a complete analysis on every failure to identify the root cause can be too time-consuming. However, if an error occurs often, designers will run more complex and expensive tests to narrow down exactly what is happening so they can take corrective action. These processes and tests are all implemented in the STAR Memory System, taking into account failures from most FinFET providers, who share a wide commonality between them even though the bit cells are very different from each other.
The STAR Memory System includes programmability in it. Through the JTAG port and the TAP controller, the algorithm can be updated to modify the test sequence itself or upgrade the algorithm for debug and diagnosis purposes or simply to upgrade it, even in the field.
Detecting & Repairing Faults Using the STAR Memory System
Synopsys' deep and thorough analysis of failures and defect potentials in FinFETs is built into enabling the STAR Memory System to work at many levels, as shown in Figure 10 . The highest level is just knowing which memory instance is failing, which for manufacturing test and correct may be enough. Next is the logical address of the failure and the physical address of the failure. The STAR Memory System can then identify the physical X,Y coordinates of the failing bit. The defect can be classified (single bit, paired bit, whole column, etc.), the fault classified and finally localized to the precise site of the failure. Note that all this has been identified by the STAR Memory System sitting outside the chip, not by using electron microscopy or other more intensive/ expensive approaches. The development of tools and IP that yields high quality of results to the SoC users (or memory IP designers) is a long and ongoing process. Starting with in-depth memory design knowledge, early access to process parameters from multiple foundries, extensive fault injection simulations, silicon characterization and accurate behavioral and structural models, the process can take more than three years. Deep understanding of unique FinFET defects has resulted in optimized test algorithms for lower area impact and lower test time, plus understanding the stress conditions to exercise the defects. Finally, all that knowledge was incorporated into the STAR Memory System to create automatic insertion, fast test bring up, and maximum yield.
FinFETs offer more possibilities to optimize timing with a pre-inserted group of memories with scheduling. The BIST multiplexers can be already in place with a shared test bus. These test buses can be reused by custom datapath creators and by processor cores. Synopsys created the Multi-Memory Bus (MMB) processor to take advantage of the possibilities offered by FinFETs. The MMB shares the BIST/BISR logic with all caches mapped to the bus, eliminating the need for memory wrappers, leading to smaller area and power consumption (Figure 11 ). Figure 12 shows an SoC example where some memories use the STAR Memory System conventionally while the memories in the CPU core are accessed by the MMB processors. The MMB processor does not deal with the wrappers directly, but instead accesses the bus ports which are represented by the red boxes in Figure  12 . The MMB processor reads the information from the CPU RTL to understand the memory specifi cs and the confi guration of the write bus, resulting in an immediate handshake. 
Repairing Faults
Modern memories have both row and column redundancy (Figure 13 ). When failures are detected, the redundant columns can be confi gured by recording the problems and the repair solutions in non-volatile memory. The STAR Memory System automatically handles the repair by narrowing down the location of the fault and determining how to swap it out. The process can be optimized for all stress corners so that faults are detected at one corner and augmented to the next corner and so on. Since the STAR Memory System is so automated, diagnosis and repair can be repeated in the fi eld at predetermined intervals, such as whenever the system is powered on or some pre-specifi ed duration. The repetition allows faults that result from aging to be eliminated using built-in redundancy.
FinFETs suffer from one particular aging problem that planar does not: negative bias temperature instability (NBTI). NBTI is mostly temperature based but results in gradual deterioration depending on the temperature range under which the FinFET is operating.
Single Event Effects and Error Correction
Not only do predictable errors occur, but intermittent soft errors can also occur. Intermittent soft errors do not need to be fi xed with built-in redundancy. They are usually caused by high energy particles. As the bit cells become closer and closer together in smaller process nodes, single-event-effects (SEE) can affect more than a single bit, and the multi-bit defects need to be detected and corrected.
To combat these types of errors, the STAR Memory System contains an ECC compiler. The compiler provides more than the "classic" memory ECC, which typically permits multi-bit error detection but can only handle singlebit correction. The ECC compiler, on the other hand, can handle multi-bit correction. The STAR Memory System ECC Compiler defi nes the appropriate memory confi guration, replaces the memory with a memory with ECC (which will be wider than the required data, of course: a 32 bit memory will be ~40 bits wide). The memory is then wrapped with all the system test and repair logic. External DRAM, or memory-on-logic, presents a new set of challenges. Using through-silicon vias (TSVs) or other techniques, the DRAM physically sits on top of the chip, as shown in Figure 14 . However, the memories are not directly accessible to the outside world, or at least not with the performance required to test them. Testing vehicles can't easily intercept signals between the memories and the logic if they are using a high-speed interface such as DDR4, JEDEC Wide I/O or Micron's Hybrid Memory Cube. Instead, an engine that sits on the SoC but can interact with the DRAM that is external to the chip can drive the interfaces at the necessary high speed. Just as with onchip memory, SoCs using external DRAM must fi nd out which memory, bit, or interconnect in the stack is failing and why. The STAR Memory System can handle this requirement and often repair it.
3D SoCs/ICs

STAR Hierarchical System
All FinFET SoCs include more than just memories. They will have other mixed signal IP such as PCIe, USB, DDR, PLLs and more. Each of these interfaces requires self-testing and, in many cases, faults need to be detected and repaired. For fast I/O interfaces, repair means tuning, calibration and framing. To further complicate test and repair, some interface IP will itself contain memories. This complex system requires a thorough test and repair infrastructure like the STAR Hierarchical System shown in Figure 15 . The STAR Hierarchical System compliments the STAR Memory System to enable test, debug and correction of mixed-signal non-memory IP. As a hierarchical solution, the STAR Hierarchical System can take an IP with its patterns from the sub-chip level up to the entire SoC, creating the access and interface, building up the patterns at the next level.
Summary
Today Synopsys has full support for a wide range of process nodes, including 14nm and 16nm FinFET, and work is progressing on 10nm and 7nm technologies. Using the knowledge gained from the test chips in these process nodes, the innovations in STAR Memory System will continue to improve test and diagnostics capabilities for embedded memories while adding functionality to optimize SoC yield.
Synopsys also offers the STAR Hierarchical System to comprehensively test range of other mixed-signal and interface IP by leveraging any existing standard based interconnect like IEEE 1500 as well as TAP controller.
