TW201508743A - Spin transfer torque based memory elements for programmable device arrays - Google Patents

Spin transfer torque based memory elements for programmable device arrays Download PDF

Info

Publication number
TW201508743A
TW201508743A TW102130612A TW102130612A TW201508743A TW 201508743 A TW201508743 A TW 201508743A TW 102130612 A TW102130612 A TW 102130612A TW 102130612 A TW102130612 A TW 102130612A TW 201508743 A TW201508743 A TW 201508743A
Authority
TW
Taiwan
Prior art keywords
sttram
array
configuration data
elements
configuration
Prior art date
Application number
TW102130612A
Other languages
Chinese (zh)
Other versions
TWI527029B (en
Inventor
Arijit Raychowdhury
James W Tschanz
Vivek De
Original Assignee
Intel 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
Application filed by Intel Corp filed Critical Intel Corp
Priority to TW102130612A priority Critical patent/TWI527029B/en
Publication of TW201508743A publication Critical patent/TW201508743A/en
Application granted granted Critical
Publication of TWI527029B publication Critical patent/TWI527029B/en

Links

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/02Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using magnetic elements
    • G11C11/16Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using magnetic elements using elements in which the storage effect is based on magnetic spin effect
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/02Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using magnetic elements
    • G11C11/16Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using magnetic elements using elements in which the storage effect is based on magnetic spin effect
    • G11C11/165Auxiliary circuits
    • G11C11/1673Reading or sensing circuits or methods
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/02Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using magnetic elements
    • G11C11/16Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using magnetic elements using elements in which the storage effect is based on magnetic spin effect
    • G11C11/165Auxiliary circuits
    • G11C11/1675Writing or programming circuits or methods

Abstract

Disclosed herein are semiconductor device arrays, such as, Field Programmable Gate Arrays (FPGAs) and Complex Programmable Logic Arrays (CPLAs) that use high-density Spin Transfer Torque (STT)-based memory elements. STT-based memory elements can either be stand-alone FPGAs/CPLAs, or can be embedded in microprocessors and/or digital signal processing (DSP) system-on-chip (SoC) to provide design flexibility for implementing low power, scalable, secure and reconfigurable hardware architecture. Because the configuration is stored on the FPGA/CPLA die itself, the need for loading the configuration from external storage every time is eliminated when the device is powered on. In addition to instant startup, eliminating configuration I/O traffic results in power savings and possible pin count reduction. Security is greatly improved by eliminating the need to store configuration data in an external memory.

Description

用於可程式化裝置陣列之以自旋轉移扭矩為基礎的記憶體元件 Memory component based on spin transfer torque for a programmable array of devices

本發明大致是關於用在大容量電腦架構以及包括晶片系統(SoC)之可重新組態系統中的積體電路之領域,特別是關於使用自旋轉移扭矩(STT)效應的非易失性記憶體裝置和系統。 The present invention relates generally to the field of integrated circuits used in high-capacity computer architectures and reconfigurable systems including wafer systems (SoCs), and more particularly to non-volatile memories using spin transfer torque (STT) effects. Body devices and systems.

可程式化裝置陣列為用於電腦系統中之可組態邏輯電路的基本構建塊。可程式化裝置陣列的範例包括場可程式化閘極陣列(FPGA)、複合可程式化邏輯陣列(CPLA)等。 The programmable device array is the basic building block for configurable logic circuits in a computer system. Examples of programmable device arrays include Field Programmable Gate Arrays (FPGAs), Composite Programmable Logic Arrays (CPLAs), and the like.

目前的FPGA使用靜態隨機存取記憶體(SRAM)胞元或抗熔絲來將邏輯胞元和縱橫式開關(亦即將多個輸入連接至多個輸出的矩陣開關)程式化。以抗熔絲為基礎的FPGA僅可單次程式化,因此其用途有限。以SRAM為基礎的FPGA亦遭受到幾個已知問題。舉例來說,邏輯胞 元通常具有高漏功率。此外,雖然SRAM使用雙穩態鎖存電路來儲存各位元,但就若未從外部對記憶體裝置供電則資料終究會流失的意義上來說,其仍為易失性類型之記憶體。因此,每當FPGA被通電時,整個SRAM必須被重新載入組態資料。這使得外部非易失性儲存器(例如:快閃儲存器)和組態專用的輸入/輸出(I/O)為必要,並在起動時導致相當長的程式化時間。另外的缺點是,可能會有與儲存組態資料於晶片外記憶體陣列相關的安全性問題,而需要額外的複雜加密方案。 Current FPGAs use static random access memory (SRAM) cells or anti-fuse to program logic cells and crossbar switches (ie, matrix switches that connect multiple inputs to multiple outputs). Fuse-based FPGAs can only be single-programmed, so their use is limited. SRAM-based FPGAs have also suffered several known problems. For example, a logical cell The element usually has a high leakage power. In addition, although the SRAM uses a bistable latch circuit to store the bits, it is still a volatile type of memory in the sense that the data will eventually be lost if the memory device is not externally powered. Therefore, whenever the FPGA is powered up, the entire SRAM must be reloaded with configuration data. This makes external non-volatile memory (eg flash memory) and configuration-specific input/output (I/O) necessary and leads to considerable programming time at startup. A further disadvantage is that there may be security issues associated with storing configuration data on the off-chip memory array, requiring additional complex encryption schemes.

非易失性類型的RAM具有適於嵌入高速高密度邏輯電路的特性。自旋轉移扭矩隨機存取記憶體(STTRAM)為一種非易失性RAM,其通常被用於較為習知的記憶體電路,諸如:快取、輔助儲存器等。目前的高速高密度邏輯電路,像是FPGA/CPLA,通常不採用STTRAM或其他以STT為基礎的元件。某些研究人員提議了將習知以互補金氧半導體(CMOS)為基礎的FPGA設計和STTRAM混合,來實現CMOS-STTRAM非易失性FPGA組態。舉例來說,見2008年IEEE/ACM國際電腦輔助設計研討會,第589-592頁,由Paul等人所著之標題為「Hybrid CMOS-STTRAM Non-Volatile FPGA:Design Challenges and Optimization Approaches」的文章。然而,仍有空間使STTRAM更接近邏輯等級,以及將非易失性記憶體位元嵌入將被用於大容量電腦架構及介面的可重新組態邏輯。本發明藉由提出使用以STT為基礎之元件的裝置及 其相關製程,來因應目前可得之解決方法的缺點。 The non-volatile type of RAM has characteristics suitable for embedding high speed high density logic circuits. Spin Transfer Torque Random Access Memory (STTRAM) is a non-volatile RAM that is commonly used in more conventional memory circuits such as caches, auxiliary storage, and the like. Current high-speed, high-density logic circuits, such as FPGA/CPLA, typically do not use STTRAM or other STT-based components. Some researchers have proposed to implement a CMOS-STTRAM non-volatile FPGA configuration with a complementary metal oxide semiconductor (CMOS)-based FPGA design and STTRAM hybrid. For example, see the 2008 IEEE/ACM International Computer-Aided Design Seminar, pp. 589-592, titled "Hybrid CMOS-STTRAM Non-Volatile FPGA: Design Challenges and Optimization Approaches" by Paul et al. . However, there is still room to bring the STTRAM closer to the logic level and embed the non-volatile memory bits into the reconfigurable logic that will be used for the high-capacity computer architecture and interface. The present invention proposes an apparatus using an STT-based component and Its related processes, in response to the shortcomings of the currently available solutions.

10‧‧‧系統 10‧‧‧System

20‧‧‧微處理器 20‧‧‧Microprocessor

25‧‧‧快取 25‧‧‧Cache

27‧‧‧邏輯模組 27‧‧‧Logic Module

30‧‧‧記憶體控制器 30‧‧‧ memory controller

40‧‧‧記憶體 40‧‧‧ memory

50‧‧‧週邊組件 50‧‧‧ peripheral components

102‧‧‧邏輯胞元 102‧‧‧ Logical cells

104‧‧‧週邊I/O墊 104‧‧‧ Peripheral I/O pads

106、108‧‧‧路由通道 106, 108‧‧‧ routing channels

202‧‧‧電阻元件 202‧‧‧Resistive components

204‧‧‧電晶體 204‧‧‧Optoelectronics

206‧‧‧字線 206‧‧‧ word line

208‧‧‧源極線 208‧‧‧ source line

210‧‧‧位元線 210‧‧‧ bit line

402、404‧‧‧邏輯塊,邏輯元件,邏輯胞元 402, 404‧‧‧ logical blocks, logic elements, logical cells

406‧‧‧STTRAM儲存器 406‧‧‧STTRAM storage

408‧‧‧開關盒(或路由器) 408‧‧‧Switch box (or router)

412‧‧‧邏輯胞元 412‧‧‧ Logical cells

414‧‧‧多工器(MUX) 414‧‧‧Multiplexer (MUX)

500‧‧‧邏輯胞元 500‧‧‧ logical cells

501‧‧‧輸入 501‧‧‧ input

502‧‧‧LUT結構 502‧‧‧LUT structure

504‧‧‧正反器元件 504‧‧‧Factor elements

506‧‧‧時脈信號 506‧‧‧ clock signal

508‧‧‧1位元STTRAM元件 508‧‧1 bit STTRAM component

510‧‧‧多工器(MUX) 510‧‧‧Multiplexer (MUX)

512‧‧‧MUX輸出信號 512‧‧‧MUX output signal

514‧‧‧輸出信號 514‧‧‧ Output signal

602‧‧‧無選擇器STTRAM胞元 602‧‧‧No selector STTRAM cell

604‧‧‧電阻器 604‧‧‧Resistors

606‧‧‧垂直通道 606‧‧‧Vertical channel

608‧‧‧水平通道 608‧‧‧ horizontal channel

本發明的實施例被解說來作為範例,而非用來加以限縮,且在所附圖式中,同樣的元件符號表示類似的元件。 The embodiments of the present invention are illustrated by way of example and not limitation.

第1A圖根據本發明的實施例來描述解說系統之所選態樣的高階方塊圖。 FIG. 1A depicts a high level block diagram of selected aspects of the elaboration system in accordance with an embodiment of the present invention.

第1B圖根據本發明的實施例來描述包括邏輯胞元和互連之CPLA或FPGA的基本架構。 FIG. 1B depicts a basic architecture of a CPLA or FPGA including logical cells and interconnects in accordance with an embodiment of the present invention.

第2A圖-第2B圖描述顯示位元線(BL)、字元線(WL)及源極線(SL)之典型一個電晶體一個電阻器(1T1R)裝置的示意圖。 2A-B2B depict a schematic diagram of a typical one transistor (1T1R) device showing a bit line (BL), a word line (WL), and a source line (SL).

第3圖根據本發明的各種態樣來描述顯示以STTRAM為基礎的裝置之效能改善的模擬結果。 Figure 3 depicts simulation results showing the performance improvement of an STTRAM based device in accordance with various aspects of the present invention.

第4A圖-第4B圖根據本發明的態樣來描述以STTRAM為基礎之邏輯電路的兩個不同實施例。 4A-4B depict two different embodiments of an STTRAM-based logic circuit in accordance with aspects of the present invention.

第5圖根據本發明的各種態樣來描述採用查找表(LUT)的FPGA版本。 Figure 5 depicts an FPGA version using a lookup table (LUT) in accordance with various aspects of the present invention.

第6圖根據本發明的態樣來描述以縱橫式組態顯示STTRAM元件的開關盒佈局。 Figure 6 depicts a switch box layout for displaying STTRAM elements in a crossbar configuration in accordance with aspects of the present invention.

第7圖根據本發明的態樣來描述顯示STTRAM裝置之電阻隨著所施加電壓而變化的額外模擬結果。 Figure 7 depicts an additional simulation result showing the resistance of the STTRAM device as a function of applied voltage, in accordance with aspects of the present invention.

在以下敘述中,對類似的組件給予相同的元件符號,不論其是否被顯示於不同的實施例中。為了以清楚且簡潔的方式來說明本發明的實施例,圖式未必為等比例,且某些特徵可能是以稍微概要的形式來加以顯示。可以相同或類似方式,將針對一實施例所敘述及/或解說之特徵用於一個或一個以上的其他實施例中,及/或結合或取代其他實施例之特徵。 In the following description, like components are given the same element symbols, whether or not they are shown in different embodiments. The embodiments of the invention are illustrated in a clear and concise manner, and the drawings are not necessarily to scale, and some features may be shown in a somewhat schematic form. Features described and/or illustrated with respect to one embodiment may be used in one or more other embodiments, and/or in combination with or in place of other embodiments.

根據本發明的各種實施例,所提出的是使用以高密度自旋轉移扭矩(STT)為基礎之記憶體元件的半導體裝置陣列,諸如:FPGA和CPLA。 In accordance with various embodiments of the present invention, an array of semiconductor devices using memory elements based on high density spin transfer torque (STT), such as FPGAs and CPLAs, is proposed.

STT為一種效應,其中可使用自旋極化電流來修改磁穿隧接面(MTJ)裝置中的磁性層之定向。在以STT為基礎的MJT中,裝置電阻可高或低,取決於穿隧接面兩側上的磁極化方向之間的相對角差。 STT is an effect in which a spin-polarized current can be used to modify the orientation of the magnetic layer in a magnetic tunnel junction (MTJ) device. In an STT-based MJT, the device resistance can be high or low depending on the relative angular difference between the magnetic polarization directions on both sides of the tunnel junction.

以STT為基礎的記憶體元件可被用於獨立FPGA/CPLA,或可被嵌入微處理器及/或數位信號處理器(DSP)中,以提供設計靈活性來實現低功率、可擴充且可重新組態的硬體架構。熟習該項技藝者將可了解到,微處理器和晶片系統(SoC)逐漸為嵌入可重新組態之結構,以加強客製化和可組態性。本發明的實施例使嵌入式FPGA/CPLA為自含式、安全、效能較高、且功率較低。 STT-based memory components can be used in stand-alone FPGA/CPLA, or can be embedded in microprocessors and/or digital signal processors (DSPs) to provide design flexibility for low power, scalable, and Reconfigured hardware architecture. Those skilled in the art will appreciate that microprocessors and wafer systems (SoCs) are increasingly embedded in reconfigurable structures to enhance customization and configurability. Embodiments of the present invention make the embedded FPGA/CPLA self-contained, secure, high performance, and low power.

另外,注意到,雖然主要是參照解說性範例 中的FPGA/CPLA來描述系統與程序,但將了解到鑒於此處之揭示,本發明的某些態樣、架構、及原理同樣適用於其他類型的裝置記憶體和邏輯陣列。 In addition, note that although mainly referring to the illustrative paradigm The FPGA/CPLA is used to describe systems and procedures, but it will be appreciated that certain aspects, architectures, and principles of the present invention are equally applicable to other types of device memory and logic arrays in view of the disclosure herein.

參照圖式,根據本發明的實施例,第1A圖為解說所實行之系統的所選形態之高階方塊圖。系統10可代表數種電子及/或計算裝置之任一者,其可包括記憶體裝置。此類電子及/或計算裝置可包括伺服器、桌上型電腦、膝上型電腦、行動裝置、智慧型手機、遊戲裝置、平板電腦、網路裝置等。在替代實施例中,系統10可包括較多元件、較少元件、及/或不同元件。此外,雖然可將系統10描述為包含單獨的元件,但將可了解到,此等元件可被整合於一平台上,諸如SoC。在解說性範例中,系統10包含微處理器20、記憶體控制器30、記憶體40及週邊組件50。微處理器20包括可為部份記憶體階層的快取25,以儲存指令和資料,而系統記憶體40亦可為部份該記憶體階層。快取25可包含SRAM裝置。可藉由記憶體控制器(或晶片組)30來促進微處理器20和記憶體40之間的通信,該記憶體控制器(或晶片組)30亦可促進與週邊組件50的通信。微處理器20亦可包括一個或一個以上的邏輯模組27。邏輯模組27可包含FPGA/CPLA。 Referring to the drawings, FIG. 1A is a high level block diagram illustrating selected aspects of a system being implemented, in accordance with an embodiment of the present invention. System 10 can represent any of a number of electronic and/or computing devices, which can include a memory device. Such electronic and/or computing devices may include servers, desktops, laptops, mobile devices, smart phones, gaming devices, tablets, network devices, and the like. In an alternate embodiment, system 10 may include more components, fewer components, and/or different components. Moreover, while system 10 can be described as including separate components, it will be appreciated that such components can be integrated on a platform, such as a SoC. In an illustrative example, system 10 includes a microprocessor 20, a memory controller 30, a memory 40, and a peripheral component 50. The microprocessor 20 includes a cache 25 that can be part of the memory hierarchy to store instructions and data, and the system memory 40 can also be part of the memory hierarchy. The cache 25 can include an SRAM device. Communication between the microprocessor 20 and the memory 40 can be facilitated by a memory controller (or chipset) 30 that can also facilitate communication with the peripheral components 50. Microprocessor 20 may also include one or more logic modules 27. Logic module 27 can include an FPGA/CPLA.

該SRAM裝置包括記憶體胞元的陣列(M列和N行)。該SRAM裝置亦可包括列解碼器、計時器裝置和I/O裝置(或I/O輸出)。為了有效率的I/O設計,可將相同記憶體字元的位元彼此分開。在讀取操作期間,可使用多 工器(MUX)來將各行連接至所需電路。在寫入操作期間,可使用另一個MUX來將各行連接至寫入驅動器。 The SRAM device includes an array of memory cells (M columns and N rows). The SRAM device can also include a column decoder, a timer device, and an I/O device (or I/O output). For efficient I/O design, the bits of the same memory character can be separated from each other. Can be used during read operations A device (MUX) to connect the lines to the desired circuit. During a write operation, another MUX can be used to connect the rows to the write driver.

第1B圖解說FPGA和CPLA的基本架構。如上所探討,FPGA和CPLA提供具有低程式化負擔的可重組態性。FPGA的基本結構包括個別邏輯胞元102之陣列,且在週邊I/O墊104之間以格柵狀方式配置有路由通道(106和108),藉此提供從一胞元至另一者的可重新組態連結。注意到,在相關技藝中,CPLA有時被稱為CPLD(複合可程式化邏輯裝置)。 Section 1B illustrates the basic architecture of FPGA and CPLA. As discussed above, FPGAs and CPLAs provide reconfigurability with a low stylized burden. The basic structure of the FPGA includes an array of individual logical cells 102, and routing channels (106 and 108) are arranged in a grid-like manner between the peripheral I/O pads 104, thereby providing a cell from one cell to the other. The link can be reconfigured. It is noted that in related art, CPLA is sometimes referred to as CPLD (Composite Programmable Logic Device).

在習知FPGA/CPLA中,邏輯胞元之操作和路由的組態資料被儲存在局部記憶體中。此主要是以習知的易失性SRAM為基礎。需要額外的構裝(on package)或機載(on board)非易失性儲存器(主要為快閃)來儲存重新組態資料的複本。當FPGA/CPLD通電時,局部SRAM儲存器被載入該組態資料。此習知方案遭受到各種問題,諸如:(a)來自SRAM位元胞元的高漏功率;(c)長啟動時間,期間在SRAM陣列中載入組態設定,以及(d)關於將專屬組態資料儲存在晶片外之外部記憶體中的可能安全性問題。為了避開這些問題,本案發明人提議使用STTRAM來局部地儲存組態位元。STTRAM元件儲存兩個二元狀態來作為兩個不同的電阻值,且在電源被移除時仍維持所儲存之資料。 In the conventional FPGA/CPLA, the configuration data of the operation and routing of the logical cells is stored in the local memory. This is primarily based on the conventional volatile SRAM. Additional packages (on package) or onboard non-volatile storage (primarily flash) are required to store copies of the reconfigured material. When the FPGA/CPLD is powered up, the local SRAM memory is loaded into the configuration data. This conventional solution suffers from various problems such as: (a) high leakage power from SRAM bit cells; (c) long boot time, loading of configuration settings in the SRAM array, and (d) Possible safety issues with configuration data stored in external memory outside the chip. In order to circumvent these problems, the inventor of the present invention proposed to use STTRAM to locally store configuration bits. The STTRAM component stores two binary states as two different resistance values and maintains the stored data when the power supply is removed.

STTRAM使用特別的寫入機制,該寫入機制是依據自旋極化電流誘發之磁化切換,其藉由降低寫入 所消耗的電力而大大地增強其可調性。第2A圖-第2B圖顯示STTRAM胞元之基本元件的示意圖,包含電晶體204和可變電阻元件Rmem(元件202)。組合之結構被稱為1T1R(一個電晶體一個電阻器)胞元。在第2B圖中以更醒目的方式來顯示該胞元的位元線(BL,元件210)、字線(WL,元件206)、和源極線(SL,元件208),以及分別對應之電壓VBL、VWL、和VSL。電晶體204作用如選擇器開關,而電阻元件202為磁穿隧接面(MTJ)裝置,包含由接面層所分隔的兩個鐵磁層,一層具有固定的「參考」磁化方向,另一層具有可變磁化方向。第2B圖顯示雖然只有一個讀取方向(標有RD的箭頭),但寫入操作可為雙向的(標有WR的雙頭箭頭)。因此,此1T1R結構可被描述為具有單極「讀取」和雙極「寫入」的1T-1STT MTJ記憶體胞元。 STTRAM uses a special write mechanism that is based on spin-polarized current induced magnetization switching, which greatly enhances its adjustability by reducing the power consumed by the write. 2A-B2B show schematic diagrams of the basic elements of the STTRAM cell, including a transistor 204 and a variable resistance element Rmem (element 202). The combined structure is called 1T1R (one transistor and one resistor) cell. The bit line (BL, element 210), word line (WL, element 206), and source line (SL, element 208) of the cell are displayed in a more conspicuous manner in FIG. 2B, and correspondingly Voltages V BL , V WL , and V SL . The transistor 204 acts as a selector switch, and the resistive element 202 is a magnetic tunnel junction (MTJ) device comprising two ferromagnetic layers separated by a junction layer, one layer having a fixed "reference" magnetization direction and the other layer Has a variable magnetization direction. Figure 2B shows that although there is only one read direction (arrow marked with RD), the write operation can be bidirectional (double-headed arrow labeled WR). Thus, this 1T1R structure can be described as a 1T-1STT MTJ memory cell with unipolar "read" and bipolar "write".

第3圖顯示模擬結果300,其中顯示平均寫入時間「Avg TWR」如何隨著電流密度提高而下降。第3圖解說STTRAM位元胞元的廣操作範圍。藉由提高電流密度JC,位元胞元的切換時間減少,從而允許不同的操作電流和次數,如系統等級規格所要求的。 Figure 3 shows a simulation result 300 showing how the average write time "Avg T WR " decreases as the current density increases. The third diagram shows the wide operating range of the STTRAM bit cells. By increasing the current density J C , the switching time of the bit cells is reduced, allowing for different operating currents and times, as required by system level specifications.

可藉由以各種方式排列基本1T1R胞元(參照第2A圖-第2B圖所述)來達成FPGA/CPLD架構。兩個解說性範例實施例被顯示於第4A圖和第4B圖。在實施例400A和400B兩者中,組態資料(或路由表)被局部地儲存在STTRAM中。此兩實施例皆允許路由表的低功率、非 易失性實作。可局部地將整個組態資料儲存在各開關盒內,或是在STTRAM位元胞元(被顯示為元件406)的中央陣列中。在實施例400A中,各開關盒包含局部嵌入式STTRAM,該STTRAM儲存路由組態並在各種邏輯方塊(例如:402和404)之間路由資料。可將許多此種元件組合在一陣列中,以實現大型可重新組態之邏輯電路。在實施例400B中,將整個電路的路由表儲存在中央STTRAM陣列,並將必要的組態資料路由至局部開關盒。在該開關盒中,此被用來作為多工器(MUX)選擇信號,以將資料從一邏輯方塊路由至另一者。在兩者情況中,每次該FPGA/CPLD通電時,適當的組態即已就位。此會導致更快啟動。 The FPGA/CPLD architecture can be achieved by arranging the basic 1T1R cells in various ways (see Figure 2A - Figure 2B). Two illustrative example embodiments are shown in Figures 4A and 4B. In both embodiments 400A and 400B, the configuration data (or routing table) is stored locally in the STTRAM. Both embodiments allow low power, non-routing of the routing table. Volatile implementation. The entire configuration data can be stored locally in each switch box or in a central array of STTRAM bit cells (shown as element 406). In an embodiment 400A, each switch box includes a partially embedded STTRAM that stores a routing configuration and routes data between various logical blocks (e.g., 402 and 404). Many such components can be combined in an array to implement large reconfigurable logic circuits. In an embodiment 400B, the routing table for the entire circuit is stored in a central STTRAM array and the necessary configuration data is routed to the local switch box. In the switch box, this is used as a multiplexer (MUX) selection signal to route data from one logical block to another. In both cases, the appropriate configuration is in place each time the FPGA/CPLD is powered up. This will result in a faster start.

在實施例400A中,用於在邏輯元件402和404之間路由的組態資料可在開關盒(或路由器)408將開關連結打開或關閉。在替代性實施例400B中,STTRAM儲存器406可儲存用於路由器的MUX選擇資料,且邏輯胞元412是由正確的信號所驅動。元件414為該MUX。 In an embodiment 400A, configuration data for routing between logic elements 402 and 404 can open or close a switch connection at a switch box (or router) 408. In an alternative embodiment 400B, the STTRAM store 406 can store the MUX selection material for the router, and the logical cell 412 is driven by the correct signal. Element 414 is the MUX.

某些版本的FPGA採用查找表(LUT)來儲存組態資料。如先前所述,習知具有LUT之以SRAM為基礎的FPGA亦遭受高漏電、需要構裝之非易失性外部儲存器、高啟動時間等已知問題。目前的發明人們提議在邏輯胞元中使用以STTRAM為基礎的LUT而提供低功率、非易失性儲存組態資料。此係採用儲存組態資料的1T1R胞元之STTRAM陣列。每當需要在兩個或兩個以上的邏 輯方塊之間建立連結時,STTRAM陣列被讀取,且依據所讀取之值,在LUT中建立連結。第5圖顯示邏輯胞元500,其包括LUT結構502與N個輸入501。LUT 502是藉由1位元STTRAM元件508來加以實行。如插圖500A中的分解圖所示,N輸入LUT 502中的1b-STTRAM元件508是連接至MUX 510。正反器元件504接收時脈信號506及MUX輸出信號512來處理邏輯胞元500的輸出信號514。 Some versions of the FPGA use a lookup table (LUT) to store configuration data. As mentioned previously, conventional SRAM-based FPGAs with LUTs also suffer from known problems such as high leakage, non-volatile external storage that requires construction, high startup time, and the like. Current inventors propose to provide low power, non-volatile storage configuration data using STTRAM-based LUTs in logical cells. This is an STTRAM array of 1T1R cells that store configuration data. Whenever you need two or more logic When a link is established between the tiles, the STTRAM array is read and a link is established in the LUT based on the value read. FIG. 5 shows a logical cell 500 that includes an LUT structure 502 and N inputs 501. LUT 502 is implemented by a 1-bit STTRAM element 508. As shown in the exploded view in FIG. 500A, the 1b-STTRAM element 508 in the N-input LUT 502 is coupled to the MUX 510. The flip flop element 504 receives the clock signal 506 and the MUX output signal 512 to process the output signal 514 of the logic cell 500.

如先前所述,STTRAM元件顯示具有兩個不同電阻值-低和高-的兩個狀態,取決於磁極化為平行(P)或反平行(AP)。若STTRAM元件的兩個狀態之間的電阻差夠大,則可去除選擇器開關,開放較高密度裝置封裝的機率。在此情況中,可使用縱橫式結構來局部地儲存路由組態,而非在單獨的記憶體方塊中,如圖所示。此無選擇器組態600,被稱為開關盒組態,可被見於第6圖。使用無選擇器STTRAM胞元602來將垂直及水平通道606及608重新組態。如插圖600A所示,該胞元中的唯一元件為電阻器604,其中去除了第2A圖-第2B圖中的示意圖所示之用來作為選擇器開關的電晶體。這會導致積體密度提高,但仍提供非易失性及低功率。 As previously described, the STTRAM element shows two states with two different resistance values - low and high - depending on whether the magnetic polarization is parallel (P) or anti-parallel (AP). If the difference in resistance between the two states of the STTRAM component is large enough, the selector switch can be removed, opening up the probability of a higher density device package. In this case, the crossbar structure can be used to locally store the routing configuration, rather than in a separate memory block, as shown. This no selector configuration 600, referred to as a switch box configuration, can be seen in Figure 6. The no-selector STTRAM cell 602 is used to reconfigure the vertical and horizontal channels 606 and 608. As shown in inset 600A, the only element in the cell is resistor 604, in which the transistor used as the selector switch shown in the schematic diagrams of Figures 2A-2B is removed. This leads to an increase in the bulk density, but still provides non-volatility and low power.

第7圖顯示來自依照變電壓而預測裝置電阻之變化的數值解法之模擬結果。由圖面可輕易地注意到該電阻的兩個不同狀態(亦即AP(180°)和P(0°)情況)。該模擬方法論涉及藉由以非平衡格林函數(NEGF)為基礎之傳輸 來自相容地解開磁動力學的Landau-Lifshitz-Gilbert(LLG)方程式。為供參考,見2007年12月之IEDM技術文摘,第121-124頁,由S.Salahuddin等人所著之標題為「Quantum Transport Simulation of Tunneling Based Spin Torque Transfer(STT)Devices:Design Tradeoffs and Torque Efficiency」的文章。在針對各種經校正之物理參數,如第7圖所示之費米能階能量(EF)、鐵磁體的帶分裂(△)、鐵磁體和氧化物的電子質量(mFM和mOX)、以及Ub(氧化物障高)的模擬之一特例中,標明大於2X的電阻變化。對於AP(180°)和P(0°)情況,模擬結果與從2008年1月之自然物理學第四卷第一號第67-71頁,由Sankey等人所著之標題為「Measurements of the Spin-Transfer-Torque Vector in Magnetic Tunnel Junctions」的文章所獲得之實驗數據相符合。 Figure 7 shows the simulation results from a numerical solution predicting the change in device resistance in accordance with the varying voltage. Two different states of the resistor (i.e., AP (180°) and P (0°) cases) can be easily noted from the drawing. The simulation methodology involves a Landau-Lifshitz-Gilbert (LLG) equation from a compatible uncoupling dynamics by transmission based on a non-equilibrium Green's function (NEGF). For reference, see the December 2007 IEDM Technical Digest, pages 121-124, entitled "Quantum Transport Simulation of Tunneling Based Spin Torque Transfer (STT) Devices: Design Tradeoffs and Torque" by S. Salahuddin et al. "Efficient" article. For various corrected physical parameters, such as the Fermi energy energy (E F ) shown in Figure 7, the splitting (△) of ferromagnets, the electron mass of ferromagnets and oxides (m FM and m OX ) And a special case of Ub (oxide barrier high) simulation, indicating a resistance change greater than 2X. For AP (180°) and P (0°) cases, the simulation results are the same as those from Sankey et al., Vol. 4, No. 1, 67-71, January 2008, by Sankey et al. The experimental data obtained by the article "The Spin-Transfer-Torque Vector in Magnetic Tunnel Junctions" is consistent.

因此,總結來說,本發明的實施例係解決對現存以SRAM為基礎之FPGA/CPLA造成困擾的數個問題,並根據STTRAM而使低功率及高密度FPGA/CPLA為可能。提供晶片上STTRAM非易失性儲存器係至少在現存架構上允許以下某些好處: Thus, in summary, embodiments of the present invention address several issues that plague existing SRAM-based FPGA/CPLA and enable low power and high density FPGA/CPLA based on STTRAM. Providing on-wafer STTRAM non-volatile memory allows for at least some of the following benefits in existing architectures:

.對外部快閃記憶體(構裝或機載)的需求被消除,而使成本降低並節省電路板上的空間。 . The need for external flash memory (construction or onboard) is eliminated, reducing costs and saving space on the board.

.即時起動被允許。因組態被儲存在FPGA/CPLA晶片本身,所以不需要在每次將裝置通電時從外部儲存器載入組態。除了即時起動之外,消除組態I/O流量亦導致 省電及可能的接腳數減少。 . Instant start is allowed. Since the configuration is stored in the FPGA/CPLA wafer itself, there is no need to load the configuration from the external storage each time the device is powered up. Eliminating configuration I/O traffic in addition to instant start Power saving and possible pin counts are reduced.

.藉由消除將組態資料儲存在外部記憶體中的需求,大大地改善了安全性。因組態資料從未離開晶片,所以無法透過外部手段來觀察或修改該組態資料。 . Security is greatly improved by eliminating the need to store configuration data in external memory. Since the configuration data never leaves the wafer, the configuration data cannot be observed or modified by external means.

如此敘述了以STTRAM為基礎之記憶體和邏輯電路的新穎概念及原理,熟習該項技藝者在研讀本詳細說明後,應明白前述詳細說明僅用以作為範例而非限制。即使未特別在此陳述,熟習該項技藝者仍可預期將有各種變更、改良、及修正。該等變更、改良、及修正應由本發明所提示,且不脫離本發明之示範形態的精神及範圍。另外,處理元件或序列的列舉順序,或是數字、字母、或其他名稱的使用因而不應限制所請求之程序和方法的任何順序,除非可在申請專利範圍中加以指明。雖然以上說明是透過各種範例來討論本說明目前被視為有用的各種形態,但應了解這種細節僅供該用途,且所附申請專利範圍不應限於所揭示之形態,反而應涵蓋不脫離所揭示之形態的精神及範圍之修正及等效配置。 Having described the novel concepts and principles of the STTRAM-based memory and logic circuits, those skilled in the art will understand that the foregoing detailed description is intended to be illustrative and not limiting. Even if not specifically stated herein, those skilled in the art will recognize various modifications, improvements, and alterations. Such changes, modifications, and modifications are intended to be within the spirit and scope of the exemplary embodiments of the invention. In addition, the order in which the processing elements or sequences are recited, or the use of numbers, letters, or other names, should not limit the order of the claimed procedures and methods unless otherwise indicated in the scope of the claims. While the above description is by way of example, the various aspects of the present description are considered to be useful, but it should be understood that such details are only for that purpose, and the scope of the appended claims should not be limited to the disclosed form. Modifications and equivalent configurations of the spirit and scope of the disclosed forms.

102‧‧‧邏輯胞元 102‧‧‧ Logical cells

104‧‧‧週邊I/O墊 104‧‧‧ Peripheral I/O pads

106、108‧‧‧路由通道 106, 108‧‧‧ routing channels

Claims (20)

一種系統,包含:可程式化裝置陣列,該可程式化裝置陣列包括:非易失性記憶體部份,用以將組態資料局部地儲存在使用自旋轉移扭矩(STT)效應的複數個記憶體元件中;複數個邏輯胞元;路由通道,該等路由通道將該複數個邏輯胞元的各邏輯胞元耦合於儲存該組態資料的對應記憶體元件;以及電路,該電路控制相關局部地儲存之組態資料對該複數個邏輯胞元的路由。 A system comprising: an array of programmable devices, the programmable device array comprising: a non-volatile memory portion for locally storing configuration data in a plurality of uses of spin transfer torque (STT) effects a plurality of logical cells; a routing channel that couples each logical cell of the plurality of logical cells to a corresponding memory component storing the configuration data; and a circuit that controls the correlation The locally stored configuration data is routed to the plurality of logical cells. 如申請專利範圍第1項的系統,其中該可程式化裝置陣列包含場可程式化閘極陣列(FPGA)和複合可程式化邏輯陣列(CPLA)的其中一者。 A system as claimed in claim 1, wherein the programmable device array comprises one of a field programmable gate array (FPGA) and a composite programmable logic array (CPLA). 如申請專利範圍第1項的系統,其中該非易失性記憶體部份包含STT隨機存取記憶體(STTRAM)元件的中央陣列。 The system of claim 1, wherein the non-volatile memory portion comprises a central array of STT random access memory (STTRAM) elements. 如申請專利範圍第1項的系統,其中該非易失性記憶體部份包含與對應邏輯胞元共置之STTRAM元件的分散式陣列。 A system as claimed in claim 1, wherein the non-volatile memory portion comprises a decentralized array of STTRAM elements co-located with corresponding logical cells. 如申請專利範圍第3項的系統,其中控制相關組態資料之路由的該電路包含查找表(LUT)。 A system as claimed in claim 3, wherein the circuit for controlling the routing of the associated configuration data comprises a lookup table (LUT). 如申請專利範圍第5項的系統,其中該LUT包含:N個輸入,用以從N個1位元STTRAM記憶體元件之陣列接收組態資料;以及 多工器(MUX)電路,該MUX電路藉由讀取接收到之組態資料而在該LUT內的所欲埠之間建立連結,並將所欲資料輸出至對應邏輯胞元。 A system as claimed in claim 5, wherein the LUT comprises: N inputs for receiving configuration data from an array of N 1-bit STTRAM memory elements; A multiplexer (MUX) circuit that establishes a connection between the desired bits in the LUT by reading the received configuration data and outputs the desired data to the corresponding logical cell. 如申請專利範圍第1項的系統,其中個別STTRAM元件的兩個電阻值之間的差夠大,因此不需要與該STTRAM元件整合的選擇器開關。 The system of claim 1, wherein the difference between the two resistance values of the individual STTRAM elements is sufficiently large that a selector switch integrated with the STTRAM element is not required. 如申請專利範圍第7項的系統,其中個別STTRAM元件是以採用縱橫式結構之路由通道的開關盒組態來加以耦合。 A system as claimed in claim 7 wherein the individual STTRAM elements are coupled in a switch box configuration using a routing channel of a crossbar structure. 如申請專利範圍第1項的系統,其中該陣列為以下其中一者:可被耦合於邏輯電路的獨立STTRAM陣列;以及與邏輯電路整合的嵌入式STTRAM陣列。 A system as claimed in claim 1, wherein the array is one of: an independent STTRAM array that can be coupled to the logic circuit; and an embedded STTRAM array integrated with the logic circuit. 一種在電子系統中實行可程式化裝置陣列的方法,該方法包含:將組態資料局部地儲存在被包括於非易失性記憶體部份的複數個記憶體元件中,該等記憶體元件使用自旋轉移扭矩(STT)效應;提供路由通道,該等路由通道將複數個邏輯胞元的各邏輯胞元耦合於儲存該組態資料的對應記憶體元件;以及控制相關局部地儲存之組態資料對該複數個邏輯胞元的路由。 A method of implementing a programmable device array in an electronic system, the method comprising: locally storing configuration data in a plurality of memory components included in a non-volatile memory portion, the memory components Using a spin transfer torque (STT) effect; providing routing channels that couple logical cells of a plurality of logical cells to corresponding memory elements storing the configuration data; and controlling groups associated with local storage The routing of the data to the plurality of logical cells. 如申請專利範圍第10項的方法,其中該可程式化裝置陣列包含場可程式化閘極陣列(FPGA)和複合可程式化邏輯陣列(CPLA)的其中一者。 The method of claim 10, wherein the programmable device array comprises one of a field programmable gate array (FPGA) and a composite programmable logic array (CPLA). 如申請專利範圍第10項的方法,其中該非易失性記憶體部份包含STT隨機存取記憶體(STTRAM)元件的中央陣列。 The method of claim 10, wherein the non-volatile memory portion comprises a central array of STT random access memory (STTRAM) elements. 如申請專利範圍第10項的方法,其中該非易失性記憶體部份包含與對應邏輯胞元共置之STTRAM元件的分散式陣列。 The method of claim 10, wherein the non-volatile memory portion comprises a decentralized array of STTRAM elements co-located with corresponding logical cells. 如申請專利範圍第12項的方法,其中控制相關局部地儲存之組態資料的路由係包含提供查找表(LUT)。 The method of claim 12, wherein the routing of the associated locally stored configuration data comprises providing a lookup table (LUT). 如申請專利範圍第14項的方法,其中該LUT包含:從N個1位元STTRAM記憶體元件之陣列接收組態資料;以及藉由讀取接收到之組態資料而在該LUT內的所欲埠之間建立連結,並將所欲資料輸出至對應邏輯胞元。 The method of claim 14, wherein the LUT comprises: receiving configuration data from an array of N 1-bit STTRAM memory elements; and installing the received configuration data in the LUT Create a link between the desires and output the desired data to the corresponding logical cell. 如申請專利範圍第10項的方法,其中該方法更包含:使個別STTRAM元件的兩個電阻值之間的差夠大,因此不需要與該STTRAM元件整合的選擇器開關。 The method of claim 10, wherein the method further comprises: making the difference between the two resistance values of the individual STTRAM elements large enough that a selector switch integrated with the STTRAM element is not required. 如申請專利範圍第16項的方法,其中該方法更包含:以開關盒組態來配置個別STTRAM元件;以及以耦合該等個別STTRAM元件的縱橫式結構來配置該等路由通道。 The method of claim 16, wherein the method further comprises: configuring the individual STTRAM elements in a switch box configuration; and configuring the routing channels in a crossbar configuration coupling the individual STTRAM elements. 如申請專利範圍第10項的方法,其中該陣列為以 下其中一者:可被耦合於邏輯電路的獨立STTRAM陣列;以及與邏輯電路整合的嵌入式STTRAM陣列。 The method of claim 10, wherein the array is One of the following: an independent STTRAM array that can be coupled to a logic circuit; and an embedded STTRAM array integrated with the logic circuit. 一種在晶片系統(SoC)中藉由嵌入式自旋轉移扭矩隨機存取記憶體(STTRAM)來實行可程式化裝置陣列的方法,該方法包含:將組態資料局部地儲存在複數個STTRAM元件中,該複數個STTRAM元件與一個或一個以上的對應邏輯胞元實體接近;以及以縱橫式結構配置路由通道,將各邏輯胞元耦合於儲存該組態資料的對應STTRAM元件。 A method for implementing a programmable device array in a wafer system (SoC) by embedded spin transfer torque random access memory (STTRAM), the method comprising: locally storing configuration data in a plurality of STTRAM components The plurality of STTRAM elements are in proximity to one or more corresponding logical cell entities; and the routing channels are configured in a crossbar configuration to couple the logical cells to corresponding STTRAM elements storing the configuration data. 如申請專利範圍第19項的方法,其中該可程式化裝置陣列包含場可程式化閘極陣列(FPGA)和複合可程式化邏輯陣列(CPLA)的其中一者。 The method of claim 19, wherein the programmable device array comprises one of a field programmable gate array (FPGA) and a composite programmable logic array (CPLA).
TW102130612A 2013-08-27 2013-08-27 Spin transfer torque based memory elements for programmable device arrays TWI527029B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
TW102130612A TWI527029B (en) 2013-08-27 2013-08-27 Spin transfer torque based memory elements for programmable device arrays

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
TW102130612A TWI527029B (en) 2013-08-27 2013-08-27 Spin transfer torque based memory elements for programmable device arrays

Publications (2)

Publication Number Publication Date
TW201508743A true TW201508743A (en) 2015-03-01
TWI527029B TWI527029B (en) 2016-03-21

Family

ID=53186310

Family Applications (1)

Application Number Title Priority Date Filing Date
TW102130612A TWI527029B (en) 2013-08-27 2013-08-27 Spin transfer torque based memory elements for programmable device arrays

Country Status (1)

Country Link
TW (1) TWI527029B (en)

Also Published As

Publication number Publication date
TWI527029B (en) 2016-03-21

Similar Documents

Publication Publication Date Title
US9577641B2 (en) Spin transfer torque based memory elements for programmable device arrays
JP5893685B2 (en) Software programmable logic using spin transfer torque magnetoresistive devices
JP5735091B2 (en) Gate-level reconfigurable magnetic logic
Amirany et al. A task-schedulable nonvolatile spintronic field-programmable gate array
US9659650B2 (en) Multistate register having a flip flop and multiple memristive devices
Mahmoudi et al. Design and applications of magnetic tunnel junction based logic circuits
TWI527029B (en) Spin transfer torque based memory elements for programmable device arrays
TWI592929B (en) Spin transfer torque based memory elements for programmable device arrays
Chaudhuri et al. High density asynchronous LUT based on non-volatile MRAM technology
Zhao et al. Spintronic memory-based reconfigurable computing
Jovanović et al. Logic circuits design based on MRAM: From single to multi-states cells storage
JP4792093B2 (en) Switching box circuit, switching block circuit, and FPGA circuit