# ATT3000 Series Field-Programmable Gate Arrays #### **FEATURES** - High Performance-up to 150 MHz Toggle Rates - User-Programmable Gate Array - I/O functions - · Digital logic functions - Interconnections - · Flexible array architecture - Compatible arrays, 2000 to 9000 gate logic complexity - Extensive register and I/O capabilities - · High fan-out signal distribution - · Internal three-state bus capabilities - TTL or CMOS input thresholds - · On-chip oscillator amplifier - · Standard product availability - · Low power, CMOS, static memory technology - · Pin-for-Pin to Xilinx XC3000 Family - · 100% factory pre-tested - · Selectable configuration modes - Complete XACT development system - · Schematic Capture - · Automatic Place/Route - · Logic and Timing Simulation - · Design Editor - · Library and User Macros - · Timing Calculator - Standard PROM File Interface # DESCRIPTION The CMOS ATT3000 series Field-Programmable Gate Array (FPGA) family provides a group of high-performance, high-density, digital, integrated circuits. Their regular, extendable, flexible, user-programmable array architecture is composed of a configuration program store plus three types of configurable elements: a perimeter of I/O Blocks, a core array of Logic Blocks and resources for interconnection. The general structure of a FPGA is shown in Figure 1 on the next page. The XACT development system provides schematic capture and auto place-and-route for design entry. Logic and timing simulation, and in-circuit emulation are available as design verification alternatives. The de- sign editor is used for interactive design optimization, and to compile the data pattern which represents the configuration program. The FPGA's user logic functions and interconnections are determined by the configuration program data stored in internal static memory cells. The program can be loaded in any of several modes to accommodate various system requirements. The program data resides externally in an EEPROM, EPROM or ROM on the application circuit board, or on a floppy disk or hard disk. On-chip initialization logic provides for optional automatic loading of program data at power-up. A serial configuration PROM can provide a very simple serial configuration program storage. | Basic<br>Array | Logic<br>Capacity<br>(usable<br>gates) | Config-<br>urable<br>Logic<br>Blocks | User<br>I/Os | Program<br>Data<br>(bits) | |----------------|----------------------------------------|--------------------------------------|--------------|---------------------------| | ATT3020 | 2000 | 64 | 64 | 14779 | | ATT3030 | 3000 | 100 | 80 | 22176 | | ATT3042 | 4200 | 144 | 96 | 30784 | | ATT3064 | 6400 | 224 | 120 | 46064 | | ATT3090 | 9000 | 320 | 144 | 64160 | The ATT3000 series FPGAs are an enhanced family of Field Programmable Gate Arrays, which provide a variety of logic capacities, package styles, temperature ranges and speed grades. # ARCHITECTURE The perimeter of configurable I/O Blocks (IOBs) provides a programmable interface between the internal logic array and the device package pins. The array of Configurable Logic Blocks (CLBs) performs user-specified logic functions. The interconnect resources are programmed to form networks, carrying logic signals among blocks, analogous to printed circuit board traces connecting MSI/SSI packages. The blocks' logic functions are implemented by programmed look-up tables. Functional options are implemented by program-controlled multiplexers. Interconnecting networks between blocks are implemented with metal segments joined by program-controlled pass transistors. These functions of the FPGA are established by a configuration program which is loaded into an internal, distributed array of configuration memory cells. The configuration program is loaded into the FPGA at power-up and may be reloaded on command. The FPGA includes logic and control signals to implement automatic or passive configuration. Program data may be either bit serial or byte parallel. The XACT development system generates the configuration program bit-stream used to configure the FPGA. The memory loading process is independent of the user logic functions. # **CONFIGURATION MEMORY** The static memory cell used for the configuration memory in the FPGA has been designed specifically for high reliability and noise immunity. Integrity of the FPGA configuration memory based on this design is assured even under various adverse conditions. Com- pared with other programming alternatives, static memory is believed to provide the best combination of high density, high performance, high reliability and comprehensive testability. As shown in Figure 2, the basic memory cell consists of two CMOS inverters plus a pass transistor used for writing and reading cell data. The cell is only written during configuration and only read during readback. During normal operation the cell provides continuous control and the pass transistor is "off" and does not affect cell stability. This is quite different from the operation of conventional memory devices, in which the cells are frequently read and re-written. Figure 2. A static configuration memory cell is loaded with one bit of configuration program and controls one program selection in the FPGA. Figure 1. The structure of the Field-Programmable Gate Array consists of a perimeter of programmable I/O blocks, a core of configurable logic blocks and their interconnect resources. These are all controlled by the distributed array of configuration program memory cells. The memory cell outputs Q and Q use full Ground and Vcc levels and provide continuous, direct control. The additional capacitive load together with the absence of address decoding and sense amplifiers provide high stability to the cell. Due to the structure of the configuration memory cells, they are not affected by extreme power supply excursions or very high levels of alpha particle radiation. In reliability testing no soft errors have been observed, even in the presence of very high doses of alpha radiation. The method of loading the configuration data is selectable. Two methods use serial data, while three use byte wide data. The internal configuration logic utilizes framing information, embedded in the program data by the *XACT* development system, to direct mem- ory cell loading. The serial data framing and length count preamble provide programming compatibility for mixes of various AT&T programmable gate arrays in a synchronous, serial, daisy-chain fashion. #### I/O BLOCK Each user-configurable I/O Block (IOB), shown in Figure 3, provides an interface between the external package pin of the device and the internal user logic. Each I/O Block includes both registered and direct input paths. Each IOB provides a programmable three-state output buffer which may be driven by a registered or direct output signal. Configuration options allow each IOB an inversion, a controlled slew rate and a high impedance pull-up. Each input circuit also pro- Figure 3. The Input/Output Block includes input and output storage elements and I/O options selected by configuration memory cells. A choice of two clocks is available on each die edge. The polarity of each clock line (not each flip-flop or latch) is programmable. A clock line that triggers the flip-flop on the rising edge is an active Low Latch Enable (Latch transparent) signal and vice versa. Passive Pull-up can only be enabled on inputs, not on outputs. All user inputs are programmed for TTL or CMOS thresholds. vides input clamping diodes to provide electro-static protection, and circuits to inhibit latch-up produced by input currents. The input buffer portion of each I/O Block provides threshold detection to translate external signals applied to the package pin to internal logic levels. The global input-buffer threshold of the I/O Blocks can be programmed to be compatible with either TTL or CMOS levels. The buffered input signal drives the data input of a storage element which may be configured as a positive edge-triggered "D" flip-flop or a low level-transparent latch. The sense of the clock can be inverted (negative edge/high transparent) as long as all IOBs on the same clock net use the same clock sense. Clock/load signals (I/O Block pins .ik and .ok) can be selected from either of two die edge metal lines. I/O storage elements are reset during configuration or by the active low chip RESET input. Both direct input [from I/O Block pin ./] and registered input [from I/O Block pin .q] signals are available for interconnect. For reliable operation inputs should have transition times of less than 100 ns and should not be left floating. Floating CMOS input-pin circuits might be at threshold and produce oscillations. This can produce additional power dissipation and system noise. A typical hysteresis of about 200 mV reduces sensitivity to input noise. Each user I/O Block includes a programmable high impedance pull-up resistor which may be selected by the program to provide a constant HIGH for otherwise undriven package pins. Although the FPGA provides circuitry to provide input protection for electrostatic discharge, normal CMOS handling precautions should be observed. Flip-flop loop delays for the I/O Block and logic block flip-flops are about 3 nanoseconds. This short delay provides good performance under asynchronous clock and data conditions. Short loop delays minimize the probability of a metastable condition which can result from assertion of the clock during data transitions. Because of the short loop delay characteristic in the FPGA, the I/O Block flip-flops can be used to synchronize external signals applied to the device. Once synchronized in the I/O Block, the signals can be used internally without further consideration of their clock relative timing, except as it applies to the internal logic and routing path delays. Output buffers of the I/O Blocks provide CMOS-compatible 4 mA source-or-sink drive for high fan-out CMOS or TTL compatible signal levels. The network driving I/O Block pin .o becomes the registered or direct data source for the output buffer. The three-state control signal [I/O Block pin .f] can control output activity. An open-drain type output may be obtained by using the same signal for driving the output and three-state signal nets so that the buffer output is enabled only for a LOW. Configuration program bits for each I/O Block control features such as optional output register, logical signal inversion, and three-state and slew rate control of the output. The program-controlled memory cells of Figure 3 control the following options: - Logical Inversion of the output is controlled by one configuration program bit per I/O Block. - Logical three-state control of each I/O Block output buffer is determined by the states of configuration program bits which turn the buffer on, or off, or select the output buffer three-state control interconnection [I/O Block pin .f]. When this I/O Block output control signal is HIGH, a logic "1", the buffer is dlsabled and the package pin is high impedance. When this I/O block output control signal is LOW, a logic "0", the buffer is enabled and the package pin is active. Inversion of the buffer three-state control logic sense (output enable) is controlled by an additional configuration program bit. - Direct or registered output is selectable for each I/O block. The register uses a positive-edge, clocked flip-flop. The clock source may be supplied [I/O Block pin .ok] by either of two metal lines available along each die edge. Each of these lines is driven by an invertible buffer. - Increased output transition speed can be selected to improve critical timing. Slower transitions reduce capacitive load peak currents of non-critical outputs and minimize system noise. - A high impedance pull-up resistor may be used to prevent unused inputs from floating. # Summary of I/O Options - Inputs - Direct - · Flip-flop/latch - · CMOS/TTL threshold (chip inputs) - Pull-up resistor/open circuit - Outputs - · Direct/registered - Inverted/not - Three-state/on/off - · Full speed/slew limited - · Three-state/output enable (inverse) # **CONFIGURABLE LOGIC BLOCK** The array of Configurable Logic Blocks (CLBs) provides the functional elements from which the user's logic is constructed. The logic blocks are arranged in a matrix within the perimeter of I/O Blocks. The ATT3020 has 64 such blocks arranged in 8 rows and 8 columns. The *XACT* development system is used to compile the configuration data which are to be loaded into the internal configuration memory to define the operation and interconnection of each block. User definition of configurable logic blocks and their interconnecting networks may be done by automatic translation from a schematic capture logic diagram or optionally by installing library or user macros. Each configurable logic block has a combinatorial logic section, two flip-flops, and an internal control section. See Figure 4. There are: five logic inputs [.a, .b, .c, .d and .e]; a common clock input [.k]; an asynchronous direct reset input [.rd]; and an enable clock [.ec]. All may be driven from the interconnect resources adjacent to the blocks. Each CLB also has two outputs [.x and .y] which may drive interconnect networks. Figure 4. Each Configurable Logic Block includes a combinatorial logic section, two flip-flops and a program memory controlled multiplexer selection of function. It has: five logic variable inputs .a, .b, .c, .d and .e. a direct data in .di an enable clock .ec a clock (invertible) .k an asynchronous reset .rd two outputs .x and .y - Figure 5 - 5a. Combinatorial Logic Option 1 generates two functions of four variables each. One variable, A, must be common to both functions. The second and third variable can be any choice of of B, C, Qx and Qy. The fourth variable can be any choice of D or E. - **5b.** Combinatorial Logic Option 2 generates any function of five variables: A, D, E and and two choices out of B, C, Qx, Qy. - 5c. Combinatorial Logic Option 3 allows variable E to select between two functions of four variables: Both have common inputs A and D and any choice out of B, C, Qx and Qy for the remaining two variables. Option 3 can then implement some functions of six or seven variables. Figure 6. The C8BCP macro (modulo 8 binary counter with parallel enable and clock enable) uses one combinatorial logic block of each option. Data input for either flip-flop within a CLB is supplied from the function F or G outputs of the combinatorial logic, or the block input, data-in [.di]. Both flip-flops in each CLB share the asynchronous reset [.rd] which, when enabled and HIGH, is dominant over clocked inputs. All flip-flops are reset by the active low chip input, RESET, or during the configuration process. The flip-flops share the enable clock [.ec] which, when LOW, recirculates the flip-flops' present states and inhibits response to the data-in or combinatorial function inputs on a CLB. The user may enable these control inputs and select their sources. The user may also select the clock net input [.k], as well as its active sense within each logic block. This programmable inversion eliminates the need to route both phases of a clock signal throughout the device. Flexible routing allows use of common or individual CLB clocking. The combinatorial logic portion of the logic block uses a 32 by 1 look-up table to implement Boolean functions. Variables selected from the five logic inputs and two internal block flip-flops are used as table address inputs. The combinatorial propagation delay through the network is independent of the logic function generated and is spike free for single input variable changes. This technique can generate two independent logic functions of up to four variables each as shown in Figure 5a, or a single function of five variables as shown in Figure 5b, or some functions of seven variables as shown in Figure 5c. Figure 6 shows a modulo 8 binary counter with parallel enable. It uses one CLB of each type. The partial functions of six or seven variables are implemented using the input variable [.e] to dynamically select between two functions of four different variables. For the two functions of four variables each, the independent results (F and G) may be used as data inputs to either flip-flop or either logic block output. For the single function of five variables and merged functions of six or seven variables, the F and G outputs are identical. Symmetry of the F and G functions and the flip-flops allows the interchange of CLB outputs to optimize routing efficiencies of the networks interconnecting the logic blocks and I/O Blocks. # PROGRAMMABLE INTERCONNECT Programmable Interconnection resources in the FPGA provide routing paths to connect inputs and outputs of the I/O and logic blocks into logical networks. Interconnections between blocks are composed from a two-layer grid of metal segments. Specially designed pass transistors, each controlled by a configuration bit, form programmable interconnect points (PIPs) and switching matrices used to implement the necessary connections between selected metal segments and block pins. Figure 7 is an example of a routed net. The XACT development system provides automatic routing of these interconnections. Interactive routing (Editnet) is also available for design optimization. The inputs of the logic or I/O Blocks are multiplexers which can be programmed to select an input network from the adjacent interconnect segments. As the switch connections to block inputs are undirectional (as are block outputs) they are usable only for block input connection and not routing. Figure 8 illustrates routing access to logic block input variables, control inputs and block outputs. Three types of metal resources are provided to accommodate various network interconnect requirements: - · General Purpose Interconnect - Direct Connection - Long Lines (multiplexed busses and wide AND gates) #### **General Purpose Interconnect** General purpose interconnect, as shown in Figure 9, consists of a grid of five horizontal and five vertical metal segments located between the rows and columns of logic and I/O Blocks. Each segment is the "height" or "width" of a logic block. Switching matrices join the ends of these segments and allow pro- Figure 7. An XACT view of routing resources used to form a typical interconnection network from CLB GA. Figure 8. The AT&T XACT Development System view of the locations of interconnect access, CLB control inputs, logic inputs and outputs. The dot pattern represents the available programmable interconnection points (PIPs). Some of the interconnect "PIPs" are directional. This is indicated on the XACT design editor status line: ND is a nondirectional interconnection. D:H->V is a PIP which drives from a horizontal to a vertical line. D:V->H is a PIP which drives from a vertical to a horizontal line. D:C->T is a "T" PIP which drives from a cross of a T to the tail. D:CW is a corner PIP which drives in the clockwise direction. P0 indicates the PIP is non-conducting, P1 is "on." grammed interconnections between the metal grid segments of adjoining rows and columns. The switches of an unprogrammed device are all non-conducting. The connections through the switch matrix may be established by the automatic routing or by using "Editnet" to select the desired pairs of matrix pins to be connected or disconnected. The legitimate switching matrix combinations for each pin are indicated in Figure 10 and may be highlighted by the use of the show matrix command in *XACT*. Special buffers within the general interconnect areas provide periodic signal isolation and restoration for improved performance of lengthy nets. The interconnect buffers are available to propagate signals in either direction on a given general interconnect segment. These bi-directional (bidi) buffers are found adjacent to the switching matricies, above and to the right and may be highlighted by the use of the "Show BIDI" command in XACT. The other PIPs adjacent to the matrices are access to or from long lines. The development system automatically defines the buffer direction based on the location of the interconnection network source. The delay calculator of the XACT development system automatically calculates and displays the block, interconnect and buffer delays for any paths selected. Generation of the simulation netlist with a worst-case delay model is provided by an XACT option. Figure 9. FPGA general-purpose interconnect is composed of a grid of metal segments which may be interconnected through switch matrices to form networks for CLB and I/O block inputs and outputs. ## **Direct Interconnect** Direct interconnect, shown in Figure 11, provides the most efficient implementation of networks between adjacent logic or I/O Blocks. Signals routed from block to Figure 10. Switch matrix interconnection options for each "pin." Switch matrices on the edges are different. Use "Show Matrix" menu option in XACT. Figure 11. The .x and .y outputs of each CLB have single contact, direct access to inputs of adjacent CLBs. Figure 12. ATT3020 die edge I/O blocks are provided with direct access to adjacent CLBs. block using the direct interconnect exhibit minimum interconnect propagation and use no general interconnect resources. For each Configurable Logic Block, the .x output may be connected directly to the .b input of the CLB immediately to its right and to the .c input of the CLB to its left. The .y output can use direct interconnect to drive the .d input of the block immediately above and the .a input of the block below. Direct interconnect should be used to maximize the speed of high performance portions of logic. Where logic blocks are adjacent to I/O Blocks, direct connect is provided alternately to the I/O Block inputs [.i] and outputs [.o] on all four edges of the die. The right edge provides additional direct connects from CLB outputs to adjacent IOBs. Direct interconnections of I/O Blocks with CLBs are shown in Figure 12. ## Long Lines The long lines bypass the switch matrices and are intended primarily for signals which must travel a long distance, or must have minimum skew among multiple destinations. Long Lines, shown in Figure 13, run vertically and horizontally the height or width of the interconnect area. Each interconnection column has three vertical long lines, and each interconnection row has two horizontal long lines. An additional two long lines are located adjacent to the outer sets of switching matrices. Two vertical long lines in each column are connectible half-length lines, except on the ATT3020, where only the outer long lines serve that function. Long lines can be driven by a logic block or I/O block output on a column by column basis. This capability provides a common low skew control or clock line within each column of logic blocks. Interconnections of these long lines are shown in Figure 14. Isolation buffers are provided at each input to a long line and are enabled automatically by the development system when a connection is made. A buffer in the upper left corner of the FPGA chip drives a global net which is available to all .k inputs of logic blocks. Using the global buffer for a clock signal provides a skew-free, high fan-out, synchronized clock for use at any or all of the I/O and logic blocks. Configuration bits for the .k input to each logic block can select this global line or another routing resource as the clock source for its flip-flops. This net may also be programmed to drive the die edge clock lines for I/O Block use. An enhanced speed, CMOS threshold, direct access to this buffer is available at the second pad from the top of the left die edge. A buffer in the lower right corner of the array drives a horizontal long line that can drive programmed connections to a vertical long line in each interconnection column. This alternate buffer also has low skew and high fan-out. The network formed by this alternate buffer's long lines can be selected to drive the .k inputs of the logic blocks. CMOS threshold, high speed access to this buffer is available from the third pad from the bottom of the right die edge. Figure 13. Horizontal and vertical long lines provide high fan-out, low-skew signal distribution in each row and column. The global buffer in the upper left die corner drives a common line throughout the FPGA. # Internal Busses A pair of three-state buffers is located adjacent to each configurable logic block. These buffers allow logic to drive the horizontal long lines. Logical operation of the three-state buffer controls allows them to implement wide multiplexing functions. Any three-state buffer input can be selected as drive for the horizontal long line bus by applying a low logic level on its three-state control line. See Figure 15a. The user is required to avoid contention which can result from multiple drivers with opposing logic levels. Control of the three-state input by the same signal that drives the buffer input. creates an 'open drain' wired-AND function. A logical HIGH on both buffer inputs creates a high impedance which represents no contention. A logical LOW enables the buffer to drive the long line low. See Figure 15b. Pull-up resistors are available at each end of the long line to provide a HIGH output when all connected buffers are non-conducting. This forms fast, wide gating functions. When data drives the inputs, and separate signals drive the three-state control lines, these buffers form multiplexers (three-state buses). In this case care must be used to prevent contention through multiple active buffers of conflicting levels on a common line. Figure 16 shows three state buffers, long lines and pull-up resistors. #### Crystal Oscillator Figure 16 also shows the location of an internal high speed inverting amplifier which may be used to implement an on-chip crystal oscillator. It is associated with the auxiliary buffer in the lower right corner of the die. When the oscillator is configured by "MAKEBITS" and connected as a signal source, two special user I/O Blocks are also configured to connect the oscillator amplifier with external crystal oscillator components as shown in Figure 17. A divide by two option is available to assure symmetry. The oscillator circuit becomes active before configuration is complete in order to allow the oscillator to stabilize. Actual internal connection is delayed until completion of configuration. In Figure 17 the feedback resistor, R1, between output and input biases the amplifier at threshold. The value should be as large as practical to minimize loading of the crystal. The inversion of the amplifier, together with the R-C networks and an AT cut series resonant crystal, produce the 360 degree phase shift of the Pierce oscillator. A series resistor, R2, may be included to add to the amplifier output impedance when needed for phase shift control, crystal resistance matching, or to limit the amplifier input swing to control clipping at large amplitudes. Excess feedback voltage may be corrected by the ratio of C2/C1. The amplifier Figure 14. Programmable interconnection of long lines is provided at the edges of the routing area. Three-state buffers allow the use of horizontal long lines to form on-chip wired-AND and multiplexed buses. The left two vertical long lines per column (except ATT3020) and the outer perimeter long lines may be programmed as connectible half-length. Figure 15a. Three-state buffers implement a Wired-AND function. When all the buffer three state lines are HIGH, (high impedance), the pull-up resistor(s) provide the HIGH output. The buffer inputs are driven by the control signals or a LOW. 2271 07 2271 08 Figure 15b. Three-state buffers implement a Multiplexer where the selection is accomplished by the buffer three-state signal. Figure 16. An XACT Development System extra large view of possible interconnections in the lower right corner of the ATT3020. is designed to be used from 1 MHz to one-half the specified CLB toggle frequency. Use at frequencies below 1 MHz may require individual characterization with respect to a series resistance. Crystal oscillators above 20 MHz generally require a crystal which operates in a third overtone mode, where the fundamental frequency must be suppressed by the R-C networks. When the oscillator inverter is not used, these I/O Blocks and their package pins are available for general user I/O. ## **PROGRAMMING** ## Initialization Phase An internal power-on-reset circuit is triggered when power is applied. When Vcc reaches the voltage at which portions of the FPGA begin to operate (2.5 to 3 Volts), the programmable I/O output buffers are disabled and a high impedance pull-up resistor is provided for the user I/O pins. A time-out delay is initiated to allow the power supply voltage to stabilize. During this time the power-down mode is inhibited. The Initialization state time-out (about 11 to 33 ms) is determined by a 14-bit counter driven by a self-generated, internal timer. This nominal 1 MHz timer is subject to variations with process, temperature and power supply over the range of 0.5 to 1.5 MHz. As shown in Table 1, five configuration mode choices are available as determined by the input levels of three mode pins; M0, M1 and M2. In Master configuration modes the FPGA becomes the source of Configuration Clock (CCLK). The beginning of configuration of devices using Peripheral or Slave modes must be delayed long enough for their initialization to be completed. An FPGA with mode lines se- Table 1 | МО | <b>M</b> 1 | M2 | Clock | Mode | Data | |----|------------|----|---------|------------|-----------------------------| | 0 | 0 | 0 | active | Master | Bit Serial | | 0 | 0 | 1 | active | Master | Byte Wide Addr. = 0000 up | | 0 | 1 | 0 | _ | reserved | _ | | 0 | 1 | 1 | active | Master | Byte Wide Addr. = FFFF down | | 1 | 0 | 0 | _ | reserved | _ | | 1 | 0 | 1 | passive | Peripheral | Byte Wide | | 1 | 1 | 0 | _ | reserved | _ | | 1 | 1 | 1 | passive | Slave | Bit Serial | Figure 17. When activated in the "MAKEBITS" program and by selecting an output network for its buffer, the crystal oscillator inverter uses two unconfigured package pins and external components to implement an oscillator. An optional divide-by-two mode is available to assure symmetry. lecting a Master configuration mode extends its initialization state using four times the delay (43 to 130 ms) to assure that all daisy-chained slave devices which it may be driving will be ready even if the master is very fast, and the slave(s) very slow. Figure 18 shows the state sequences. At the end of Initialization the FPGA enters the Clear state where it clears the configuration memory. The active low, open-drain initialization signal INIT indicates when the Initialization and Clear states are complete. The FPGA tests for the absence of an external active low RESET before it makes a final sample of the mode lines and enters the Configuration state. An external wired-AND of one or more INIT pins can be used to control configuration by the assertion of the active low RESET of a master mode device or to signal a processor that the FPGAs are not yet initialized. If a configuration has begun, a re-assertion of RESET for a minimum of three internal timer cycles will be recognized and the FPGA will initiate an abort, returning to the Clear state to clear the partially loaded configuration memory words. The FPGA will then re-sample RESET and the mode lines before re-entering the Configuration state. A re-program is initiated when a configured FPGA senses a HIGH to LOW transition on the DONE/PROG package pin. The FPGA returns to the Clear state where the configuration memory is cleared and mode lines re-sampled, as for an aborted configuration. The complete configuration program is cleared and loaded during each configuration program cycle. Length count control allows a system of multiple FPGAs, of assorted sizes, to begin operation in a syn- chronized fashion. The configuration program generated by the MakePROM program of the XACT development system begins with a preamble of 111111110010 followed by a 24-bit 'length count' representing the total number of configuration clocks needed to complete loading of the configuration program(s). The data framing is shown in Figure 19. All FPGAs connected in series read and shift preamble and length count in on positive and out on negative configuration clock edges. An FPGA which has received the preamble and length count then presents a HIGH Data Out until it has intercepted the appropriate number of data frames. When the configuration program memory of an FPGA is full and the length count does not compare, the FPGA shifts any additional data through, as it did for preamble and length count. When the FPGA configuration memory is full and the length count compares, the FPGA will execute a synchronous start-up sequence and become operational. See Figure 20. Three CCLK cycles after the completion of loading configuration data the user I/O pins are enabled as configured. As selected in MAKEBITS, the internal user-logic reset is released either one clock cycle before or after the I/O pins become active. A similar timing selection is programmable for the DONE/PROG output signal. DONE/PROG may also be programmed to be an open drain or include a pullup resistor to accommodate wired ANDing. The High During Configuration (HDC) and Low During Configuration (LDC) are two user I/O pins which are driven active when an FPGA is in its Initialization, Clear or Configure states. They and DONE/PROG provide signals for control of external logic signals such as reset, bus enable or PROM enable during configuration. For Figure 18. A state diagram of the configuration process for power-up and reprogram. parallel Master configuration modes these signals provide PROM enable control and allow the data pins to be shared with user logic signals. User I/O inputs can be programmed to be either TTL or CMOS compatible thresholds. At power-up, all inputs have TTL thresholds and can change to CMOS thresholds at the completion of configuration if the user has selected CMOS thresholds. The threshold of PW-RDWN and the direct clock inputs are fixed at a CMOS level. If the crystal oscillator is used it will begin operation before configuration is complete to allow time for stabilization before it is connected to the internal circuitry. #### **Configuration Data** Configuration data to define the function and interconnection within a FPGA are loaded from an external storage at power-up and on a re-program signal. Several methods of automatic and controlled loading of the required data are available. Logic levels applied to \*The FPGA Devices Require 4 Dummy Bits Min., XACT 3.0 Generates 8 Dummy Bits 2271 11 | Device | ATT3020 | ATT3030 | ATT3042 | ATT3064 | ATT3090 | |----------------------------------------------------------|---------------|------------------|------------------|------------------|------------------| | Gates | 2000 | 3000 | 4200 | 6400 | 9000 | | CLBs<br>Row X Col | 64<br>(8 X 8) | 100<br>(10 X 10) | 144<br>(12 X 12) | 224<br>(16 X 14) | 320<br>(20 X 16) | | IOBs | 64 | 80 | 96 | 120 | 144 | | Flip-flops | 256 | 360 | 480 | 688 | 928 | | Bits per frame<br>(w/ 1 start 3 stop) | 75 | 92 | 108 | 140 | 172 | | Frames | 197 | 241 | 285 | 329 | 373 | | Program Data =<br>Bits * Frames + 4<br>(excludes header) | 14779 | 22176 | 30784 | 46064 | 64160 | | PROM size (bits) =<br>Program Data<br>+ 40 bit Headers | 14819 | 22216 | 30824 | 46104 | 64200 | Figure 19. The internal Configuration Data Structure for an FPGA shows the preamble, length count and data frames which are generated by the XACT Development System. The Length Count produced by the "MAKEBIT" program = [(40-bit preamble + sum of program data + 1 per daisy chain device) rounded up to multiple of 8] – $(2 \le K \le 4)$ where K is a function of DONE and RESET timing selected. An additional 8 is added if roundup increment is less than K. K additional clocks are needed to complete start-up after length count is reached. mode selection pins at the start of configuration time determine the method to be used. See Table 1. The data may be either bit-serial or byte-parallel, depending on the configuration mode. Various AT&T Programmable Gate Arrays have different sizes and numbers of data frames. For the ATT3020, configuration requires 14779 bits for each device, arranged in 197 data frames. An additional 40 bits are used in the header. See Figure 20. The specific data format for each device is produced by the MAKEBITS command of the development system and one or more of these files can then be combined and appended to a length count preamble and be transformed into a PROM format file by the 'MAKE PROM' command of the XACT development system. The "tie" option of the MAKE-BITS program defines output levels of unused blocks of a design and connects these to unused routing resources. This prevents indeterminant levels which might produce parasitic supply currents. If unused blocks are not sufficient to complete the 'tie,' the FLA-GNET command of EDITFPGA can be used to indicate nets which must not be used to drive the remaining unused routing, as that might affect timing of user nets. NORESTORE will retain the results of TIE for timing analysis with QUERYNET before RESTORE returns the design to the untied condition. TIE can be omitted for quick breadboard iterations where a few additional mA of lcc are acceptable. The configuration bit-stream begins with HIGH preamble bits, a four-bit preamble code and a 24-bit length count. When configuration is initiated, a counter in the FPGA is set to 0 and begins to count the total number of configuration clock cycles applied to the device. As each configuration data frame is supplied to the FPGA, it is internally assembled into a data word. As each data word is completely assembled, it is loaded in parallel into one word of the internal configuration memory array. The configuration loading process is complete when the current length count equals the loaded length count and the required configuration program data frames have been written. Internal user flip-flops are held reset during configuration. Two user programmable pins are defined in the unconfigured FPGA. High During Configuration (HDC) and Low During Configuration (LDC) as well as DONE/PROG may be used as external control signals during configuration. In Master mode configurations it is convenient to use LDC as an active-low EPROM Chip Enable. After the last configuration data-bit is loaded and the length count compares, the user I/O pins become active. Options in the MAKEBITS program allow timing choices of one clock earlier or later for the timing of the end of the internal logic reset and the assertion of the DONE signal. The open-drain DONE/PROG out- THE CONFIGURATION DATA CONSISTS OF A COMPOSITE 40-BIT PREAMBLE/LENGTH-COUNT, FOLLOWED BY ONE OR MORE CONCATENATED LCA PROGRAMS, SEPARATED BY 4-BIT POSTAMBLES. AN ADDITIONAL FINAL POSTAMBLE BIT IS ADDED FOR EACH SLAVE DEVICE AND THE RESULT ROUNDED UP TO A BYTE BOUNDRY. THE LENGTH COUNT IS TWO LESS THAN THE NUMBER OF RESULTING BITS. TIMING OF THE ASSERTION OF DONE AND TERMINATION OF THE INTERNAL RESET MAY EACH BE PROGRAMMED TO OCCUR ONE CYCLE BEFORE OR AFTER THE I/O OUTPUTS BECOME ACTIVE. Figure 20. Configuration and start-up of one or more FPGAs. put can be AND-tied with multiple FPGAs and used as an active high READY, an active low PROM enable or a RESET to other portions of the system. The state diagram of Figure 18 illustrates the configuration process. ## Master Mode In Master mode, the FPGA automatically loads configuration data from an external memory device. There are three Master modes which use the internal timing source to supply the configuration clock (CCLK) to time the incoming data. Serial Master mode uses serial configuration data supplied to data-in (DIN) from a synchronous serial source such as the serial configuration PROM shown in Figure 21. Parallel Master Low and Master High modes automatically use parallel data supplied to the D0-D7 pins in response to the 16-bit address generated by the FPGA. Figure 22 shows an example of the parallel Master mode connections required. The FPGA HEX starting address is 0000 and increments for Master Low mode and it is FFFF and decrements for Master High mode. These two modes provide address compatibility with microprocessors which begin execution from opposite ends of memory. For Master high or low, data bytes are Figure 21. Master Serial Mode. The serial configuration PROM supports automatic loading of configuration programs up to 36K/64K bits. Multiple devices can be cascaded to support additional FPGAs. An early DONE inhibits the data output a CCLK cycle before the FPGA I/O become active. read in parallel by each read clock (RCLK) and internally serialized by the configuration clock. As each data byte is read, the least significant bit of the next byte, D0, becomes the next bit in the internal serial configuration word. One Master mode FPGA can be used to interface the configuration program-store and pass additional concatenated configuration data to additional FPGAs in a serial daisy-chain fashion. CCLK is provided for the slaved devices and their serialized data is supplied from DOUT to DIN - DOUT to DIN etc. Figure 22. Master Parallel Mode. Configuration data are loaded automatically from an external byte wide PROM. An early DONE inhibits the PROM outputs a CCLK before the FPGA I/O become active. # Peripheral Mode Peripheral mode provides a simplified interface through which the device may be loaded byte-wide, as a processor peripheral. Figure 23 shows the peripheral mode connections. Processor write cycles are decoded from the common assertion of the active low Write Strobe (WS), and two active low and one active high Chip Selects (CS0, CS1, CS2). If all these signals are not available, the unused inputs should be driven to their respective active levels. The FPGA will accept one byte of configuration data on the D0–D7 inputs for each selected processor Write cycle. Each byte of data is loaded into a buffer register. The FPGA generates a configuration clock from the internal timing generator and serializes the parallel input data for internal framing or for succeeding slaves on Data Out (DOUT). A output HIGH on READY/BUSY pin indicates the completion of loading for each byte when the input register is ready for a new byte. As with Master modes, Peripheral mode may also be used as a lead device for a daisy-chain of slave devices. ## Slave Mode Slave mode provides a simple interface for loading the FPGA configuration as shown in Figure 24. Serial data are supplied in conjunction with a synchronizing input clock. Most Slave mode applications are in daisy-chain configurations in which the data input are supplied by the previous FPGA's data out, while the clock is supplied by a lead device in Master or Peripheral mode. Data may also be supplied by a processor or other special circuits. Figure 23. Peripheral Mode. Configuration data are loaded using a byte-wide data bus from a microprocessor. # Dalsy-Chain The XACT development system is used to create a composite configuration bit stream for selected FPGAs including: a preamble, a length count for the total bit-stream, multiple concatenated data programs and a postamble plus an additional fill bit per device in the serial chain. After loading and passing-on the preamble and length count to a possible daisy-chain, a lead device will load its configuration data frames while providing a HIGH DOUT to possible down-stream devices as shown in Figure 25. Loading continues while the lead device has received its configuration program and the current length count has not reached the full value. The additional data are passed through the lead device and appear on the Data Out (DOUT) pin in serial form. The lead device also generates the Configuration Clock (CCLK) to synchronize the serial output data and data in of down-stream FPGAs. Data are read in on DIN of slave devices by the positive edge of CCLK and shifted out the DOUT on the negative edge of CCLK. A parallel Master mode device uses its internal timing generator to produce an internal CCLK of 8 times its EPROM address rate, while a Peripheral mode device produces a burst of 8 CCLKs for each chip select and write-strobe cycle. The internal timing generator continues to operate for general timing and synchronization of inputs in all modes. Figure 24. Slave Mode. Bit-serial configuration data are read at rising edge of the CCLK. Data on DOUT are provided on the falling edge of CCLK. # **Special Configuration Functions** The configuration data include control over several special functions in addition to the normal user logic functions and interconnect: - · Input thresholds - · Readback enable - · DONE pull-up resistor - DONE timing - RESET timing - · Oscillator frequency divided by two Each of these functions is controlled by configuration data bits which are selected as part of the normal *XACT* development system bit-stream generation process. # **Input Thresholds** Prior to the completion of configuration all FPGA input thresholds are TTL compatible. Upon completion of configuration the input thresholds become either TTL or CMOS compatible as programmed. The use of the TTL threshold option requires some additional supply current for threshold shifting. The exception is the threshold of the PWRDWN input and direct clocks which always have a CMOS input. Prior to the completion of configuration the user I/O pins each have a high impedance pull-up. The configuration program can be used to enable the I/O Block pull-up resistors in the Operational mode to act either as an input load or to avoid a floating input on an otherwise unused pin. Figure 25. Master Mode configuration with daisy chained slave mode devices. All are configured from the common EPROM source. The Slave mode device $\overline{\text{INIT}}$ signals delay the Master device configuration until they are initialized. A well defined termination of SYSTEM RESET is needed when controlling multiple FPGAs. #### Readback The contents of a FPGA may be read back if it has been programmed with a bit-stream in which the Readback option has been enabled. Readback may be used for verification of configuration and as a method of determining the state of internal logic nodes during debugging with the Data I/O Mesa-I In-Circuit Verifier. There are three options in generating the configuration bit-stream: - · "Never" will inhibit the Readback capability. - "One-time," will inhibit Readback after one Readback has been executed to verify the configuration. - "On-command" will allow unrestricted use of Readback Readback is accomplished without the use of any of the user I/O pins; only M0, M1 and CCLK are used. The initiation of readback is produced by a LOW to HIGH transition of the M0/RTRIG (Read Trigger) pin. Once the readback command has been given, the input CCLK is driven by external logic to read back each data bit in a format similar to loading. After two dummy bits, the first data frame is shifted out, in inverted sense, on the M1/RDATA (Read Data) pin. All data frames must be read back to complete the process and return the mode select and CCLK pins to their normal functions. The readback data includes the current state of each internal logic block storage element, and the state of the [.i and .ri] connection pins on each I/O Block. These data are imbedded into unused configuration bit positions during readback. This state information is used by the FPGA development system In-Circuit Verifier to provide visibility into the internal operation of the logic while the system is operating. To readback a uniform time-sample of all storage elements it may be necessary to inhibit the system clock. # Re-program The FPGA configuration memory can re-written while the device is operating in the user's system. To initiate a re-programming cycle, the dual function package pin DONE/PROG must be given a HIGH to LOW transition. To reduce sensitivity to noise, the input signal is filtered for 2 cycles of the FPGA's internal timing generator. When re-program begins, the user programmable I/O output buffers are disabled and high impedance pull-ups are provided for the package pins. The device returns to the Clear state and clears the configuration memory before it indicates 'initialized'. Since this clear operation uses chip-individual internal timing, the master might complete the clear operation and then start configuration before the slave has completed the clear operation. To avoid this problem, wire-AND the slave INIT pins and use them to force a RESET on the master (see Figure 25). Reprogram control is often implemented using an external open collector driver which pulls DONE/PROG LOW. Once it recognizes a stable request, the FPGA will hold a LOW until the new configuration has been completed. Even if the re-program request is externally held LOW beyond the configuration period, the FPGA will begin operation upon completion of configuration. # **DONE Pull-up** DONE/PROG is an open drain I/O pin that indicates the FPGA is in the operational state. An optional internal pull-up resistor can be enabled by the user of the *XACT* development system when 'Make Bits' is executed. The DONE/PROG pins of multiple FPGAs in a daisy-chain may be connected together to indicate all are DONE or to direct them all to re-program. #### **DONE Timing** The timing of the DONE status signal can be controlled by a selection in the MAKEBITS program to occur a CCLK cycle before, or after, the timing of outputs being activated. See Figure 20. This facilitates control of external functions such as a PROM enable or holding a system in a wait state. # **RESET Timing** As with DONE timing, the timing of the release of the internal RESET can be controlled by a selection in the MAKEBITS program to occur a CCLK cycle before, or after, the timing of outputs being enabled. See Figure 20. This reset maintains all user programmable flipflops and latches in a 'zero' state during configuration. # **Crystal Oscillator Division** A selection in the MAKEBITS program allows the user to incorporate a dedicated divide-by-two flip-flop in the crystal oscillator function. This provides higher assurance of a symmetrical timing signal. Although the frequency stability of crystal oscillators is high, the symmetry of the waveform can be affected by bias or feedback drive. ## **PERFORMANCE** #### **Device Performance** The high performance of the FPGA is due in part to the manufacturing process, which is similar to that used for high speed CMOS static memories. Performance can be measured in terms of minimum propagation times for logic elements. The parameter which traditionally describes the overall performance of a gate array is the toggle frequency of a flip-flop. The configuration for determining the toggle performance of the FPGA is shown in Figure 26. The flip-flop output Q is fed back through the combinatorial logic as $\underline{Q}$ to form the toggle flip-flop. Actual FPGA performance is determined by the timing of critical paths, including both the fixed timing for the logic and storage elements in that path, and the timing associated with the routing of the network. Examples of internal worst case timing are included in the performance data to allow the user to make the best use of the capabilities of the device. The XACT development system timing calculator or XACT generated simulation models should be used to calculate worst case paths by using actual impedance and loading information. Figure 27 shows a variety of elements which are involved in determing system performance. Actual measurement of internal timing is not practical and often only the sum of component timing is relevant as in the case of input to output. The relationship between input and output timing is arbitrary and only the total determines performance. Timing components of internal functions may be determined by measurement of differences at the pins of the package. A synchronous logic function which involves a clock to block-output, and a block-input to clock set-up is capable of higher speed operation than a logic configuration of two synchronous blocks with an extra combinatorial block level between them. System clock rates to 60% of the toggle frequency are practical for logic in which an extra combinatorial level is located between synchronized blocks. This allows implementation of functions of up to 25 variables. The use of the wired-AND is also available for wide, high speed functions. # **Logic Block Performance** Logic block performance is expressed as the propagation time from the interconnect point at the input of the combinatorial logic to the output of the block in the interconnect area. Combinatorial performance is independent of the specific logic function because of the table look-up based implementation. Timing is different when the combinatorial logic is used in conjunction with the storage element. For the combinatorial logic function driving the data input of the storage element, the critical timing is data set-up relative to the clock edge provided to the flip-flop element. The delay from the clock source to the output of the logic block is critical in the timing of signals produced by storage elements. Loading of a Logic Block output is limited only by the resulting propagation delay of the larger interconnect network. Speed performance of the logic block is a function of supply voltage and temperature. See Figures 28 and 29. ## Interconnect Performance Interconnect performance depends on the routing resource used to implement the signal path. As discussed earlier, direct interconnect from block to block provides a fast path for a signal. The single metal segment used for Long lines exhibits low resistance from end to end, but relatively high capacitance. Signals driven through a programmable switch will have the additional impedance of the switch added to their normal drive impedance. General purpose interconnect performance depends on the number of switches and segments used, the presence of the bi-directional re-powering buffers and the overall loading on the signal path at all points along the path. In calculating the worst case timing for a general interconnect path the timing calculator portion of the XACT development system accounts for all of these elements. As an approximation, interconnect timing is proportional to the summation of totals of local metal segments beyond each programmable switch. In effect, the time is a sum of R-C time each approximated by an R times the total C it drives. The R of the switch and the C of the interconnect are functions of the particular device performance grade. For a string of three local interconnects, the approximate time at the first segment, after the first switch resistance would be three units; an additional two units after the next switch plus an additional unit after the last switch in the chain. The interconnect R-C chain terminates at each re-powering buffer. The capacitance of Figure 26. "Toggle" Flip-Flop used to characterize device performance. | | | Speed (4) | | 70 | <u> </u> | 100 | -1 | 25 | 15 | 50 | Unit | |-----------------------|----------------------------------------------------|----------------------|-----|-----|----------|-----|----------|-----|----------|-----|----------------| | Signal | Description | Symbol | Min | Мах | Min | Мах | Min | Max | Min | Max | | | Logic input to Output | Combinatorial | TILO | | 9 | | 7 | | 5.5 | | 4.6 | ns | | K Clock | To output<br>Logic-input setup<br>Logic-input hold | Тско<br>Тіск<br>Тскі | 8 | 6 | 7<br>0 | 5 | 5.5<br>0 | 4.5 | 4,6<br>0 | 4 | ns<br>ns<br>ns | | Input/Output | Pad to input (direct) | TPID | | 6 | | 4 | | 3 | | 2.8 | ns | | | Output to pad (fast) | Тор | | 9 | | 6 | | 5 | | 4.5 | ns | | | I/O clock to pad (fast) | Токро | | 13 | | 10 | | 9 | | 7 | ns | | FF toggle frequency | | Fc∟k | | 70 | | 100 | | 125 | | 150 | MHz | = Preliminary. **Figure 27.** Examples of Primary Block Speed Factors. Actual timing is a function of various block factors combined with routing factors. Overall performance can be evaluated with the *XACT* timing calculator or by an optional simulation. Figure 29. The speed performance of a CMOS device increases with Vcc within the operating range. the actual block inputs is not significant; the capacitance is in the interconnect metal and switches. Figure 30 illustrates this. ## **POWER** #### **Power Distribution** Power for the FPGA is distributed through a grid to achieve high noise immunity and isolation between logic and I/O. Inside the FPGA, a dedicated Vcc and ground ring surrounding the logic array provides power to the I/O drivers. See Figure 31. An independent matrix of Vcc and ground lines supplies the interior logic of the device. This power distribution grid provides a stable supply and ground for all internal logic, providing the external package power pins are all connected and appropriately decoupled. Typically a 0.1 µF capacitor connected near the Vcc and ground pins of the package will provide adequate decoupling. Output buffers capable of driving the specified 4 mA loads under worst-case conditions. Noise can be reduced by minimizing external load capacitance and reducing simultaneous output transitions in the same direction. It may also be beneficial to locate heavily loaded output buffers near the ground pads. The I/O Block output buffers have a slew limited mode which should be used where output rise and fall times are not speed critical. Slew-limited outputs maintain their DC drive capability, but generate less external reflections and internal noise. More than 32 fast outputs should not be switching in the same direction exactly simultaneously. A few ns of deliberate skew can alleviate this problem of "ground-bounce". # **Power Dissipation** The FPGA exhibits the low power consumption characteristic of CMOS ICs. For any design the user can use Figure 32 to calculate the total power requirement based on the sum of the capacitive and DC loads both external and internal. The configuration option of TTL chip input threshold requires power for the threshold reference. The power required by the static memory cells which hold the configuration data is very low and may be maintained in a power-down mode. Typically most of power dissipation is produced by external capacitive loads on the output buffers. This load and frequency dependent power is 25 $\mu$ W/pF/MHz per output. Another component of I/O power is the DC loading on each output pin by devices driven by the FPGA. Figure 30. Interconection timing example. Use of the XACT timing calculator or XACT-generated simulation model provide actual worstcase performance information. Internal power dissipation is a function of the number and size of the nodes, and the frequency at which they change. In an FPGA the fraction of nodes changing on a given clock is typically low (10–20%). For example, in a large binary counter, the average clock cycle produces changes equal to one CLB output at the clock frequency. Typical global clock buffer power is between 1.7 mW/MHz for the ATT3020 and 3.6 mW/MHz for the ATT3090. The internal capacitive load is more a function of interconnect than fan-out. With a "typical" load of three general interconnect segments, each Configurable Logic Block output requires about 0.4 mW per MHz of its output frequency. Total Power = Vcc • Icco + external (DC + capacitive) + internal (CLB + IOB + Long Line + pull-up) Because the control storage of the FPGA is CMOS static memory, its cells require a very low standby current for data retention. In some systems, this low data retention current characteristic can be used as a method of preserving configurations in the event of a primary power loss. The FPGA has built in powerdown logic which, when activated, will disable normal operation of the device and retain only the configuration data. All internal operation is suspended and output buffers are placed in their high impedance state with no pull-ups. Power-down data retention is possible with a simple battery-backup circuit because the power requirement is extremely low. For retention at 2.4 volts the required current is typically on the order of 50 nanoamps. To force the FPGA into the Power-Down state, the user must pull the PWRDWN pin low and continue to supply a retention voltage to the Vcc pins of the package. When normal power is restored, Vcc is elevated to its normal operating voltage and PWRDWN is returned to a HIGH. The FPGA resumes operation with the same internal sequence that occurs at the conclusion of configuration. Internal I/O and logic block storage elements will be reset, the outputs will become enabled and the DONE/PROG pin will be released. No configuration programming is involved. When the power supply is removed from a CMOS device it is possible to supply some power from an input signal. The conventional electro-static input protection is implemented with diodes to the supply and ground. A positive voltage applied to an input (or output) will cause the positive protection diode to conduct and drive the power pin. This condition can produce invalid power conditions and should be avoided. A large series resistor might be used to limit the current or a bi-polar buffer may be used to isolate the input signal. Figure 31. FPGA Power Distribution. Figure 32. FPGA Power Consumption by Element. Total chip power is the sum of Voc-Icco plus effective internal and external values of frequency dependent capacitive charging currents and duty factor dependent resistive loads. #### PIN DESCRIPTIONS ## 1. Permanently Dedicated Pins. #### Vcc Two to eight (depending on package type) connections to the nominal +5 V supply voltage. All must be connected. ## **GND** Two to eight (depending on package type) connections to ground. All must be connected. ## **PWRDWN** A LOW on this CMOS compatible input stops all internal activity to minimize Vcc power, and puts all output buffers in a high impedance state, but configuration is retained. When the PWRDWN pin returns HIGH, the device returns to operation with the same sequence of buffer enable and DONE/PROGRAM as at the completion of configuration. All internal storage elements are reset. If not used, PWRDWN must be tied to Vcc. ## RESET This is an active low input which has three functions. Prior to the start of configuration, a LOW input will delay the start of the configuration process. An internal circuit senses the application of power and begins a minimal time-out cycle. When the time-out and RESET are complete, the levels of the "M" lines are sampled and configuration begins. If RESET is asserted during a configuration, the FPGA is re-initialized and will restart the configuration at the termination of RESET. If RESET is asserted after configuration is complete it will provide an asynchronous reset of all IOB and CLB storage elements of the FPGA. # CCLK During configuration, Configuration Clock is an output of an FPGA in Master mode or Peripheral mode. FPGAs in Slave mode use it as a clock input. During a Readback operation it is a clock input for the configuration data being shifted out. #### DONE The DONE output is configurable as open drain with or without an internal pull-up resistor. At the completion of configuration, the circuitry of the FPGA becomes active in a synchronous order, and DONE may be programmed to occur one cycle before or after that. #### PROG Once configuration is done, a HIGH to LOW transition of this pin will cause an initialization of the FPGA and start a reconfiguration. #### MO As Mode 0, this input and M1, M2 are sampled before the start of configuration to establish the configuration mode to be used. ## **RTRIG** As a Read Trigger, a LOW-to-HIGH input transition, after configuration is complete, will initiate a Readback of configuration and storage element data by CCLK. This operation may be limited to a single request, or be inhibited altogether, by selecting the appropriate readback option when generating the bit stream. # M1 As Mode 1, this input and M0, M2 are sampled before the start of configuration to establish the configuration mode to be used. If Readback is to be used, a 5 $\mbox{K}\Omega$ resistor should be used to define mode level inputs. #### RDATA As an active low Read Data, after configuration is complete, this pin is the output of the readback data. ## 2. User I/O Pins that can have special functions. #### M2 As Mode 2 this input has a passive pullup during configuration. Together with M0 and M1 it is sampled before the start of configuration to establish the configuration mode to be used. After configuration this pin becomes a user programmable I/O pin. #### HDC High During Configuration is held at a HIGH level by the FPGA until after configuration. It is available as a control output indicating that configuration is not yet completed. After configuration this pin is a user I/O pin. # LDC Low During Configuration is held at a LOW level by the FPGA until after configuration. It is available as a control output indicating that configuration is not yet completed. It is particularly useful in Master mode as a LOW enable for an EPROM. After configuration this pin is a user I/O pin. If used as a LOW EPROM enable, it must be programmed as a HIGH after configuration. #### INIT This is an active low open drain output which is held LOW during the power stabilization and internal clearing of the configuration memory. It can be used to indicate status to a configuring microprocessor or, as a wired AND of several slave mode devices, a hold-off signal for a master mode device. After configuration this pin becomes a user programmable I/O pin. #### **BCLKIN** This is a direct CMOS level input to the alternate clock buffer (Auxiliary Buffer) in the lower right corner. #### XTL1 This user I/O pin can be used to operate as the output of an amplifier driving an external crystal and bias circuitry. # XTL2 This user I/O pin can be used as the input of an amplifier connected to an external crystal and bias circuitry. The I/O Block is left unconfigured. The oscillator configuration is activated by routing a net from the oscillator buffer symbol output and by the MAKEBITS program. # CSO, CS1, CS2, WS These four inputs represent a set of signals, three active low and one active high, which are used in the Peripheral mode to control configuration data entry. The assertion of all 4 generates a write to the internal data buffer. The removal of any assertion, clocks in the D0–D7 data present. #### RCLK During Master parallel mode configuration RCLK represents a "read" of an external dynamic memory device (normally not used). #### RDY/BUSY During Peripheral parallel mode configuration this pin indicates when the chip is ready for another byte of data to be written to it. After configuration is complete, this pin becomes a user programmed I/O pin. #### D0--D7 This set of 8 pins represent the parallel configuration byte for the parallel Master and Peripheral modes. After configuration is complete they are user programmed I/O pin. #### A0-A15 This set of 16 pins present an address output for a configuration EPROM during Master parallel mode. After configuration is complete they are user programmed I/O pin. #### DIN This user I/O pin is used as serial Data input during Slave or Master Serial configuration. This pin is Data 0 input in Master or Peripheral configuration mode. #### DOUT This user I/O pin is used during configuration to output serial configuration data for daisy-chained slaves' Data In. #### **TCLKIN** This is a direct CMOS level input to the global clock buffer. # 3. Unrestricted User I/O Pins. #### I/C A pin which may be programmed by the user to be Input and/or Output pin following configuration. Some of these pins present a high impedance pull-up (see next page) or perform other functions before configuration is complete (see above). Table 2a. ATT3000 Family Configuration Pin Assignments | Siave | Master-SER | uration Mode: <m2:< th=""><th>Master-High</th><th>Master-Low</th><th>ا ₄₄</th><th>68</th><th>84</th><th>R4</th><th>100</th><th>100</th><th>User<br/>Operation</th></m2:<> | Master-High | Master-Low | ا ₄₄ | 68 | 84 | R4 | 100 | 100 | User<br>Operation | |---------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|--------------|------|------|----------|----------|------|-------------------| | <1:1:1> | <0:0:0> | <1:0:1> | <1:1:0> | <1:0:0> | PLCC | PLCC | PLCC | PGA | POFP | COFP | Оролили | | PWR DWN (I) | PWR DWN (I) | PWR DWN (I) | PWR DWN (I) | PWR DWN (I) | 7 | 10 | 12 | 82 | 29 | 14 | PWR DWN | | VCC | vcc | vcc | VCC | VCC | 12 | 18 | 22 | F3 | 41 | 26 | VCC | | M1 (HIGH) (I) | M1 (LOW) (I) | M1 (LOW) (l) | M1 (HIGH) (I) | M1 (LOW) (I) | 16 | 25 | 31 | J2 | 52 | 37 | RDATA | | MO (HIGH) (I) | Mo (LOW) (I) | M0 (HIGH) (I) | MO (LOW) (I) | M0 (LOW) (I) | 17 | 26 | 32 | L1 | 54 | 39 | RTRIG (I) | | M2 (HIGH) (i) | M2 (LOW) (I) | M2 (HIGH) (I) | M2 (HIGH) (I) | M2 (HIGH) (I) | 18 | 27 | 33 | K2 | 56 | 41 | VO | | HDC(HIGH) | HDC(HIGH) | HDC(HIGH) | HDC(HIGH) | HDC(HIGH) | 19 | 28 | 34 | КЗ | 57 | 42 | VO | | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | 20 | 30 | 36 | L3 | 59 | 44 | vo | | TINIT | INIT • | INIT · | INIT . | INIT • | 22 | 34 | 42 | K6 | 65 | 50 | vo | | GND | GND | GND | GND | GND | 23 | 35 | 43 | J6 | 66 | 51 | GND | | | | | | | 26 | 43 | 53 | L11 | 76 | 61 | XTL2 - VO | | RESET (1) | RESET (I) | RESET (I) | RESET (I) | RESET (I) | 27 | 44 | 54 | K10 | 78 | 63 | RESET (I | | DONE | DONE | DONE | DONE | DONE | 28 | 45 | 55 | J10 | 80 | 65 | PROG (i | | | | DATA 7 (I) | DATA 7 (i) | DATA 7 (I) | | 46 | 56 | K11 | 81 | 66 | Ю | | | | | | | 30 | 47 | 57 | J11 | 82 | 67 | XTL1 -VO | | | | DATA 6 (I) | DATA 6 (I) | DATA 6 (I) | | 48 | 58 | H10 | 83 | 68 | VO | | | | DATA 5 (I) | DATA 5 (I) | DATA 5 (I) | | 49 | 60 | F10 | 87 | 72 | vo | | | | CSO (I) | | | | 50 | 61 | G10 | 88 | 73 | νo | | | | DATA 4 (I) | DATA 4 (I) | DATA 4 (I) | | 51 | 62 | G11 | 89 | 74 | 1/0 | | VCC | VCC | VCC | vcc | vcc | 34 | 52 | 64 | F9 | 91 | 76 | VCC | | | | DATA 3 (I) | DATA 3 (I) | DATA 3 (I) | | 53 | 65 | F11 | 92 | 77 | NO | | | | CS1 (l) | | | | 54 | 66 | E11 | 93 | 78 | vo | | | | DATA 2 (I) | DATA 2 (I) | DATA 2 (I) | | 55 | 67 | E10 | 94 | 79 | vo | | | | DATA 1 (I) | DATA 1 (I) | DATA 1 (I) | | 56 | 70 | D10 | 98 | 83 | VO | | | | RDY/ BUSY | RCLK | RCLK | | 57 | 71 | C11 | 99 | 84 | vo | | DIN (I) | DIN (I) | DATA 0 (I) | DATA O (I) | DATA 0 (I) | 38 | 58 | 72 | B11 | 100 | 85 | VO | | DOUT (I) | DOUT (I) | DOUT (I) | DOUT (I) | DOUT (I) | 39 | 59 | 73 | C10 | 1 | 86 | VO | | CCLK (I) | CCLK | CCLK | CCLK | CCLK | 40 | 60 | 74 | A11 | 2 | 87 | CCLK (I) | | | | WS (I) | A0 | AO | | 61 | 75 | B10 | 5 | 90 | νo | | | | CS2 (I) | A1 | <b>A</b> 1 | 1 | 62 | 76 | 89 | 6 | 91 | VO | | | | | A2 | A2 | 1 | 63 | 77 | A10 | 8 | 93 | ΙO | | | | | A3 | A3 | | 64 | 78 | A9 | 9 | 94 | vo | | | | | A15 | <b>A</b> 15 | l | 65 | 81 | B6 | 12 | 97 | vo | | | | | A4 | <b>A4</b> | | 66 | 82 | B7 | 13 | 98 | . vo | | | | | A14 | A14 | L | 67 | 83 | A7 | 14 | 99 | νo | | | | | A5 | A5 | <u> </u> | 68 | 84 | C7 | 15 | 100 | NO NO | | GND | GND | GND | GND<br>A13 | GND<br>A13 | 1 | 2 | 2 | C6<br>A6 | 16<br>17 | 1 2 | GND | | | | | A6 | A13 | | 3 | 3 | A5 | 18 | 3 | VO. | | | | | A12 | A12 | 1 | 4 | 4 | B5 | 19 | 4 | νo | | | | | A7 | A7 | | 5 | 5 | C5 | 20 | 5 | VO. | | | | | A11 | A11 | <del> </del> | 6 | 8 | A3 | 23 | 8 | VO | | | | | A8 | A8 | 1 | 7 | 9 | A2 | 24 | 9 | ИО | | | | | A10 | A10 | 1 | В | 10 | В3 | 25 | 10 | Ю | | | | | A9 | A9 | <del> </del> | 9 | 11 | A1 | 26 | 11 | Ю | | | | | | | 1 | X | × | × | × | х | ATT3020 | | DEDDESS | NITS A SO LO | ΓΟ 100 kΩ PUL | L.HD | | х | × | × | x | X | 1 | ATT3030 | | | | OUTPUT DUR | | RATION | | | Х | X | X. | Х | ATT3042 | | | NTS AN INPU | | iii ta oo ta lad | MINION. | | | х" | | | | ATT3064 | | | | | 1/ATT3090 DIF | | | | X₩ | | I | | ATT3090 | Note: Pin assignments of "PGA Footprint" PLCC sockets and PGA packages are not electrically identical. Generic I/O pins are not shown. PIN ASSIGNMENTS FOR THE ATT3064/ATT3090 DIFFER FROM THOSE SHOWN, SEE PAGE 35. PERIPHERAL MODE AND MASTER PARALLEL MODE ARE NOT SUPPORTED IN THE 44 PLCC PACKAGE, SEE PAGE 33. Table 2a. ATT3000 Family Configuration Pin Assignments (continued) | | Con | figuration Mode: <m2:n< th=""><th>A1:M0&gt;</th><th></th><th></th><th></th><th></th><th><u> </u></th><th></th><th></th><th>User</th></m2:n<> | A1:M0> | | | | | <u> </u> | | | User | |------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------|-------------|--------------|-----------------------------------------|-------------|------------|------------|--------------------| | Slave<br><1:1:1> | Master-SER<br><0:0:0> | Peripheral<br><1:0:1> | Master-High<br><1:1:0> | Master-Low<br><1:0:0> | 100<br>SQFP | 132<br>PGA | 160<br>PQFP | 164<br>CQFP | 175<br>PGA | 208<br>QFP | Operation | | PWR DWN (I) | PWR DWN (I) | PWR DWN (I) | PWR DWN (i) | PWR DWN (I) | 26 | A1 | 159 | 20 | B2 | 3 | PWR DWN (I) | | vcc | vcc | vcc | VCC | VCC | 38 | C8 | 20 | 42 | D9 | 26 | VCC | | M1 (HIGH) (I) | M1 (LOW) (I) | M1 (LOW) (I) | M1 (HIGH) (I) | M1 (LOW) (I) | 49 | 813 | 40 | 62 | B14 | 48 | RDATA | | M0 (HIGH) (I) | M0 (LOW) (I) | MD (HIGH) (I) | Mo (LOW) (I) | MO (LOW) (I) | 51 | A14 | 42 | 64 | B15 | 50 | RTRIG (I) | | M2 (HIGH) (I) | M2 (LOW) (I) | M2 (HIGH) (I) | M2 (HIGH) (I) | M2 (HIGH) (I) | 53 | C13 | 44 | 66 | C15 | 56 | Ю | | HDC(HIGH) | HDC(HIGH) | HDC(HIGH) | HDC(HIGH) | HDC(HIGH) | 54 | B14 | 45 | 67 | E14 | 57 | Ю | | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | LDC (LOW) | 56 | D14 | 49 | 71 | D16 | 61 | vo | | INIT * | INIT * | INIT * | INIT * | INIT * | 62 | G14 | 59 | 81 | H15 | 77 | VO | | GND | GND | GND | GND | GND | 63 | H12 | 19 | 83 | J14 | 25 | GND | | | | | | | 73 | M13 | 76 | 99 | P15 | 100 | XTL2 - I/O | | RESET (f) | RESET (I) | RESET (I) | RESET (I) | RESET (I) | 75 | P14 | 78 | 101 | R15 | 102 | RESET (I) | | DONE | DONE | DONE | DONE | DONE | 77 | N13 | 80 | 103 | R14 | 107 | PROG (i) | | | | DATA 7 (I) | DATA 7 (I) | DATA 7 (I) | 78 | M12 | 81 | 104 | N13 | 109 | VO | | | | | | | 79 | P13 | 82 | 105 | T14 | 110 | XTL1 - VO | | | | DATA 6 (I) | DATA 6 (I) | DATA 6 (I) | 80 | N11 | 86 | 109 | P12 | 115 | VO | | | | DATA 5 (I) | DATA 5 (I) | DATA 5 (I) | 84 | M9 | 92 | 115 | T11 | 122 | νo | | | | CS0 (I) | | | 85 | N9 | 93 | 116 | R10 | 123 | vo | | | | DATA 4 (I) | DATA 4 (I) | DATA 4 (I) | 86 | N8 | 98 | 121 | R9 | 128 | VO | | vcc | VCC | VCC | vcc | VCC | 88 | MB | 100 | 123 | N9 | 130 | vcc | | | | DATA 3 (I) | DATA 3 (I) | DATA 3 (I) | 89 | N7 | 102 | 125 | P8 | 132 | vo | | | | CS1 (I) | | | 90 | P6 | 103 | 126 | R8 | 133 | νo | | | | DATA 2 (I) | DATA 2 (i) | DATA 2 (I) | 91 | M6 | 108 | 131 | R7 | 138 | vo | | | | DATA 1 (I) | DATA 1 (I) | DATA 1 (I) | 95 | M5 | 114 | 137 | R5 | 145 | VO | | | | RDY/ BUSY | RCLK | RCLK | 96 | N4 | 115 | 138 | P5 | 146 | VO. | | DIN (I) | DIN (I) | DATA 0 (I) | DATA 0 (I) | DATA O (I) | 97 | N2 | 119 | 143 | R3 | 151 | w | | DOUT (I) | DOUT (I) | DOUT (I) | DOUT (I) | DOUT (I) | 98 | M3 | 120 | 144 | N4 | 152 | Ю | | CCLK (I) | CCLK | CCLK | CCLK | CCLK | 99 | P1 | 121 | 145 | R2 | 153 | CCLK (I) | | | | WS (I) | <b>A</b> 0 | A0 | 2 | M2 | 124 | 148 | P2 | 161 | NO | | | | CS2 (i) | A1 | A1 | 3 | N1 | 125 | 149 | M3 | 162 | NO | | | | | A2 | A2 | 5 | L2 | 128 | 152 | P1 | 165 | νo | | | | | A3 | A3 | 6 | L1 | 129 | 153 | N1 | 166 | Ю | | | | | A15 | A15 | 9 | K1 | 132 | 156 | M1 | 172 | Ю | | | | | A4<br>A14 | A4<br>A14 | 10 | J2<br>H1 | 133<br>136 | 157<br>160 | L2<br>K2 | 173<br>178 | VO. | | | | | A5 | A14 | 12 | H2 | 136 | 161 | K2 | 179 | vo<br>vo | | GND | GND | GND | GND | GND | 13 | H3 | 139 | 164 | J3 | 182 | GND | | | | | A13 | A13 | 14 | G2 | 141 | 2 | H2 | 184 | VO | | | | | A6 | A6 | 15 | G1 | 142 | 3 | H1 | 185 | νo | | | | | A12 | A12 | 16 | F2 | 147 | 8 | F2 | 192 | VO | | | | | A7 | <b>A</b> 7 | 17 | E1 | 148 | 9 | E1 | 193 | VO | | | | | A11 | A11 | 20 | D1 | 151 | 12 | D1 | 199 | Ю | | | | | 8A | A8 | 21 | D2 | 152 | 13 | C1 | 200 | VO | | | | | A10 | A10 | 22 | B1 | 155 | 16 | E3 | 203 | VO | | | | | <b>A</b> 9 | A9 | 23 | C2 | 156 | 17 | C2 | 204 | vo | | ******* | | | | | J | | | | | | ATT3020 | | REPRES | SENTS A 50 kΩ T | O 100 kΩ PULL-L | JP. | | X | <del></del> | | | | | ATT3030 | | | N OPEN DRAIN | | | ON. I | X | X | х | | | | ATT3042<br>ATT3064 | | (I) REPRES | SENTS AN INPUT | = | | | | <del>^</del> | ······································· | х | х | х | ATT3090 | | | | | | | | | | | ^ | _ ^ | A 1 1 0 0 0 0 0 | Note: Pin assignments of "PGA Footprint" PLCC sockets and PGA packages are not electrically identical. Generic I/O pins are not shown. Table 2b. ATT3000 44-Pin PLCC Pinout | 44 PLCC | ATT3030 | |---------|------------| | 1 | GND | | 2 | I/O | | 3 | I/O | | 4 | 1/0 | | 5 | 1/0 | | 6 | | | 7 | PWRDWN | | 8 | TCLKIN-I/O | | 9 | 1/0 | | 10 | 1/0 | | 11 | 1/0 | | 12 | Vcc | | 13 | I/O | | 14 | | | 15 | 1/0 | | 16 | M1- RDATA | | 17 | Mo-RTRIG | | 18 | M2-I/O | | 19 | HDC-I/O | | 20 | LDC -1/O | | 21 | i/O | | 22 | INIT -I/O | | 44 PLCC | ATT3030 | |---------|------------------| | 23 | GND | | 24 | 1/0 | | 25 | 1/0 | | 26 | XTL2(IN)-I/O | | 27 | RESET | | 28 | DONE- PROG | | 29 | 1/0 | | 30 | XTL1(OUT)-BCLKIN | | 31 | 1/0 | | 32 | 1/0 | | 33 | 1/0 | | 34 | Vcc | | 35 | VO VO | | 36 | VO | | 37 | 1/0 | | 38 | DIN-I/O | | 39 | DOUT-I/O | | 40 | CCLK | | 41 | I/O | | 42 | 1/0 | | 43 | 1/0 | | 44 | VO | # Notes: Peripheral Mode and Master Parallel Mode are not supported in the M44 Package. Parallel address and data pins are not assigned. Table 2c. ATT3000 Family 68-Pin PLCC, 84-Pin PLCC Pinouts, and 84-Pin PGA Pinouts | 68<br>PLCC | ATT3020<br>ATT3030, ATT3042 | 84<br>PLCC | 84<br>PGA | |------------|-----------------------------|------------|-----------| | 10 | PWRDN | 12 | B2 | | 11 | TCLKIN-I/O | 13 | C2 | | _ | I/O* | 14 | B1 | | 12 | 1/0 | 15 | C1 | | 13 | I/O_ | 16 | D2 | | | <u> </u> | 17 | D1 | | 14 | <u> </u> | 18 | E3 | | 15 | 1/0 | 19 | E2 | | 16 | 1/0 | 20 | E1 | | 17 | 1/0 | 21 | F2 | | 18 | Vcc | 22 | F3 | | 19 | 1/0 | 23 | G3 | | - | 1/0 | 24 | G1 | | 20 | I/O | 25 | G2 | | 21 | 1/0 | 26 | F1 | | 22 | 1/0 | 27 | H1 | | | 1/0 | 28 | H2 | | 23 | I/O | 29 | J1 | | 24 | 1/0 | 30 | K1 | | 25 | M1- RDATA | 31 | J2 | | 26 | M0-RTRIG | 32 | L1 | | 27 | M2-I/O | 33 | K2 | | 28 | HDC-I/O | 34 | КЗ | | 29 | 1/0 | 35 | L2 | | 30 | LDC -I/O | 36 | L3 | | 31 | 1/0 | 37 | K4 | | | I/O* | 38 | L4 | | 32 | 1/0 | 39 | J5 | | 33 | I/O | 40 | K5 | | | I/O* | 41 | L5 | | 34 | INIT -I/O | 42 | K6 | | 35 | GND | 43 | J6 | | 36 | I/O | 44 | J7 | | 37 | 1/0 | 45 | L7 | | 38 | 1/0 | 46 | K7 | | 39 | I/O | 47 | L6 | | 40 | I/O | 48 | L8 | | 41 | 1/0 | 49 | K8 | | | I/O* | 50 | L9 | | _ = | I/O* | _51 | L10 | | 42 | I/O | 52 | K9 | | 43 | XTL2(IN)-I/O | 53 | L11 | | 68<br>PLCC | ATT3020<br>ATT3030, ATT3042 | 84<br>PLCC | 84<br>PGA | |------------|-----------------------------|------------|------------| | 44 | RESET | 54 | K10 | | 45 | DONE- PROG | 55 | J10 | | 46 | D7-I/O | 56 | K11 | | 47 | XTL1(OUT)-BCLKIN-I/O | 57 | J11 | | 48 | D6-I/O | 58 | H10 | | 1 | 1/0 | 59 | H11 | | 49 | D5-I/O | 60 | F10 | | 50 | CS0 -I/O | 61 | G10 | | 51 | D4-I/O | 62 | G11 | | | 1/0 | 63 | G9 | | 52 | Vcc | 64 | F9 | | 53 | D3-1/O | 65 | F11 | | 54 | CS1 -I/O | 66 | E11 | | 55 | D2-I/O | 67 | E10 | | | I/O | 68 | E9 | | _ | I/O* | 69 | D11 | | 56 | D1-I/O | 70 | D10 | | 57 | RDY/ BUSY - RCLK -I/O | 71 | C11 | | 58 | D0-DIN-I/O | 72 | B11 | | 59 | DOUT-I/O | 73 | C10 | | 60 | CCLK | 74 | A11 | | 61 | A0- WS -I/O | 75 | B10 | | 62 | A1-CS2-I/O | 76 | B9 | | 63 | A2-I/O | 77 | A10 | | 64 | A3-I/O | 78 | A9 | | | 1/0* | 79 | B8 | | _ | | 80 | 8A | | 65 | A15-I/O | 81 | B6 | | 66 | A4-I/O | 82 | B7 | | 67 | A14-I/O | 83 | A7 | | 68 | A5-I/O | 84 | C7 | | 1 | GND | 1 | C6 | | 2 | A13-I/O | 2 | A6 | | 3 | A6-I/O | 3 | A5 | | _4 | A12-I/O | 4 | B5 | | 5 | A7-I/O | 5 | C5 | | | VO* | 6 | A4 | | | I/O* | 7 | B4 | | 6 | A11-I/O | 8 | A3 | | 7 | A8-I/O | 9 | A2 | | 8 | A10-I/O | 10 | B3 | | 9 | A9-I/O | 11 | <b>A</b> 1 | <sup>\*</sup> Indicates unconnected package pins for the ATT3020. Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. Table 2d. ATT3064 /ATT3090 84-Pin PLCC Pinouts | PLCC | ATT3064 | |------------|--------------| | Pin Number | ATT3090 | | 12 | PWRDN | | 13 | TCLKIN-I/O | | 14 | I/O | | 15 | 1/0 | | 16 | 1/0 | | 17 | 1/0 | | 18 | 1/0 | | 19 | 1/0 | | 20 | 1/0 | | 21 | GND* | | 22 | Vcc | | 23 | 1/0 | | 24 | 1/0 | | 25 | I/O | | 26 | 1/0 | | 27 | I/O | | 28 | 1/0 | | 29 | 1/0 | | 30 | 1/0 | | 31 | M1- RDATA | | 32 | M0-RTRIG | | 33 | M2-I/O | | 34 | HDC-I/O | | 35 | 1/0 | | 36 | LDC -I/O | | 37 | 1/0 | | 38 | I/O | | 39 | 1/0 | | 40 | 1/0 | | 41 | INIT/I/O* | | 42 | Vcc* | | 43 | GND | | 44 | 1/0 | | 45 | 1/0 | | 46 | 1/0 | | 47 | 1/0 | | 48 | 1/0 | | 49 | 1/0 | | 50 | 1/0 | | 51 | 1/0 | | 52 | 1/0 | | 53 | XTL2(IN)-I/O | | PLCC | ATT3064 | |------------|-----------------------| | Pin Number | ATT3090 | | 54 | RESET | | 55 | DONE- PROG | | 56 | D7-I/O | | 57 | XTL1(OUT)-BCLKIN-I/O | | 58 | D6-I/O | | 59 | I/O | | 60 | D5-I/O | | 61 | CS0 -I/O | | 62 | D4-I/O | | 63 | I/O | | 64 | Vcc | | 65 | GND* | | 66 | D3 -I/O* | | 67 | CS1-I/O* | | 68 | D2-I/O* | | 69 | I/O | | 70 | D1-I/O | | 71 | RDY/ BUSY - RCLK -I/O | | 72 | D0-DIN-I/O | | 73 | DOUT-I/O | | 74 | CCLK | | 75 | A0- WS -I/O | | 76 | A1-CS2-I/O | | 77 | A2-I/O | | 78 | A3-I/O | | 76 | I/O | | 80 | I/O | | . 81 | A15-I/O | | 82 | A4-I/O | | 83 | A14-I/O | | 84 | A5-I/O | | 1 | GND | | 2 | Vcc* | | 3 | A13-I/O* | | 4 | A6-I/O* | | 5 | A12-I/O* | | 6 | A7-I/O* | | 7 | I/O | | 8 | A11-I/O | | 9 | A8-I/O | | 10 | A10-I/O | | 11 | A9-I/O | <sup>\*</sup> Different pin definition than 3020/3030/3042 PC84 package. Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. DEVICE POWER MUST BE LESS THAN 1 WATT. in QFP Pinouts | | | | Tabl | e 2e. Aī | T3000 Family 100-Pi | |---------------|------|--------------------|---------------|----------|---------------------| | Pin<br>Number | | ATT3020<br>ATT3030 | Pin<br>Number | | ATT3020<br>ATT3030 | | CQFP | PQFP | ATT3042 | CQFP | PQFP | ATT3042 | | 1 | 16 | GND | 35* | 50* | VO | | 2 | 17 | A13-I/O | 36* | 51* | VO | | 3 | 18 | A6-I/O | 37 | 52 | M1- RD | | 4 | 19 | A12-I/O | 38 | 53* | GND | | 5 | 20 | A7-I/O | 39 | 54 | M0-RT | | 6* | 21* | I/O | 40 | 55* | Vcc | | 7* | 22* | VΟ | 41 | 56 | M2-I/O | | 8 | 23 | A11-I/O | 42 | 57 | HDC-I/O | | 9 | 24 | A8-I/O | 43 | 58 | 1/0 | | 10 | 25 | A10-I/O | 44 | 59 | LDC -I/O | | 11 | 26 | A9-I/O | 45* | 60* | VO | | 12 | 27* | Vcc | 46* | 61* | VO | | 13 | 28* | GND | 47 | 62 | <i>V</i> O | | 14 | 29 | PWRDN | 48 | 63 | VO . | | 15 | 30 | TCLKIN-I/O | 49 | 64 | 1/0 | | 16* | 31* | ľΟ | 50 | 65 | INIT -I/O | | 17* | 32* | 1/0 | 51 | 66 | GND | | 18* | 33* | I/O | 52 | 67 | 1/0 | | 19 | 34 | 1/0 | 53 | 68 | 1/0 | | 20 | 35 | I/O | 54 | 69 | I/O | | 21 | 36 | 1/0 | 55 | 70 | 1/0 | | 22 | 37 | 2 | 56 | 71 | 1/0 | | 23 | 38 | I/O | 57 | 72 | VO | | 24 | 39 | 1/0 | 58 | 73 | 1/0 | | 25 | 40 | 1/0 | 59* | 74* | VO | | 26 | 41 | Vcc | 60* | 75* | I/O | | 27 | 42 | VO | 61 | 76 | XTAL2-I/O | | 28 | 43 | 1/0 | 62 | 77* | GND | | 29 | 44 | 1/0 | 63 | 78 | RESET | | 30 | 45 | 1/0 | 64 | 79* | Vcc | | 31 | 46 | 1/0 | 65 | 80 | DONE- PG | | 32 | 47 | 1/0 | 66 | 81 | D7-I/O | | 33 | 48 | I/O | 67 | 82 | XTAL1-BCLKIN-I/O | | 34 | 49 | 1/0 | 68 | 83 | D6-I/O | | | in | ATT3020 | |--------|------|----------------------| | Number | | ATT3030 | | COFP | PQFP | ATT3042 | | 69* | 84* | <u> </u> | | 70* | 85* | VO | | 71 | 86 | <u> </u> | | 72 | 87 | D5-I/O | | 73 | 88 | CSO -I/O | | 74 | 89 | D4-I/O | | 75 | 90 | 1/0 | | 76 | 91 | Vcc | | 77 | 92 | D3-I/O | | 78 | 93 | CS1 -I/O | | 79 | 94 | D2-I/O | | 80 | 95 | <i>V</i> O | | 81* | 96* | VO | | 82* | 97* | VO | | 83 | 98 | D1-I/O | | 84 | 99 | RCLK - BUSY /RDY-I/O | | 85 | 100 | D0-DIN-I/O | | 86 | 1 | DOUT-I/O | | 87 | 2 | CCLK | | 88 | 3* | Vcc | | 89 | 4* | GND | | 90 | 5_ | A0- WS -I/O | | 91 | 6 | A1-CS2-I/O | | 92* | 7*_ | VO | | 93 | 8 | A2-I/O | | 94 | 9 | A3-I/O | | 95* | 10* | I/O | | 96* | 11*_ | I/O | | 97 | 12 | A15-I/O | | 98 | 13 | A4-I/O | | 99 | 14 | A14-I/O | | 100 | 15 | A5-I/O | <sup>\*</sup> This table describes the pinouts of three different chips in two different packages. The third column lists 100 of the 118 pads on the ATT3042 that are connected to the 100 package pins. Two pads, indicated by double asterisks, do not exist on the ATT3030, which has 98 pads; therefore the corresponding pins have no connections. Twenty-six pads, indicated by single or double asterisks, do not exist on the ATT3020, which has 74 pads; therefore, the corresponding pins have no connections. (See Table 2c.) Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. The 3030 is not available in a 100-pin CQFP. Table 2f. ATT3000 Family 100-Pin SQFP Pinouts | Pin<br>Number<br>SQFP | ATT3020<br>ATT3030<br>ATT3042 | |-----------------------|-------------------------------| | 16 | GND | | 17 | A13-I/O | | 18 | A6-I/O | | 19 | A12-I/O | | 20 | A7-I/O | | 21 | VO | | 22 | NO | | 23 | A11-I/O | | 24 | A8-I/O | | 25 | A10-I/O | | 26 | A9-I/O | | 27 | Vcc | | 28 | GND | | 29 | PWRDN | | 30 | TCLKIN-I/O | | 31 | VO | | 32 | VO | | 33 | VO | | 34 | Ō | | 35 | 10 | | 36 | VO | | 37 | 1/0 | | 38 | 1/0 | | 39 | 1/0 | | 40 | 1/0 | | 41 | Vcc | | 42 | VO. | | 43 | NO. | | 44 | I/O | | 45 | I/O | | 46 | I/O | | 47 | VO | | 48 | VO | | 49 | I/O | | Pin<br>Number<br>SQFP | ATT3020<br>ATT3030<br>ATT3042 | |-----------------------|-------------------------------| | 50 | VO | | 51 | 1/0 | | 52 | M1-RD | | 53 | GND | | 54 | Mo-RT | | 55 | Vcc | | 56 | M2-I/O | | 57 | HDC-I/O | | 58 | 1/0 | | 59 | LDC -I/O | | 60 | VO | | 61 | 1/0 | | 62 | 1/0 | | 63 | 1/0 | | 64 | 1/0 | | 65 | INIT -I/O | | 66 | GND | | 67 | 1/0 | | 68 | 1/0 | | 69 | VO . | | 70 | vo | | 71 | _I/O | | 72 | 1/0 | | 73 | VO. | | 74 | VO | | 75 | 1/0 | | 76 | XTAL2-I/O | | 77 | GND | | 78 | RESET | | 79 | Vcc | | 80 | DONE- PG | | 81 | D7-I/O | | 82 | XTAL1-BCLKIN-I/O | | 83 | D6-I/O | | Pin<br>Number<br>SQFP | ATT3020<br>ATT3030<br>ATT3042 | |-----------------------|-------------------------------| | 84 | 1/0 | | 85 | I/O | | 86 | 1/0 | | 87 | D5-I/O | | 88 | CSO -I/O | | 89 | D4-I/O | | 90 | 1/0 | | 91 | Vcc | | 92 | D3-I/O | | 93 | CS1 -I/O | | 94 | D2-I/O | | 95 | I/O | | 96* | 1/0 | | 97 | 1/0 | | 98 | D1-I/O | | 99 | RCLK - BUSY /RDY-I/O | | 100 | D0-DIN-I/O | | 1 | DOUT-I/O | | 2 | CCLK | | 3 | Vcc | | 4 | GND | | 5 | A0- WS -I/O | | 6 | A1-CS2-I/O | | 7 | NO. | | 8 | A2-I/O | | 9 | A3-I/O | | 10 | 10 | | 11 | I/O | | 12 | A15-I/O | | 13 | A4-I/O | | 14 | A14-I/O | | | A5-I/O | = Preliminary. Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. Table 2g. ATT3000 Family 132-Pin PGA Pinouts | PGA Pin<br>Number | ATT3042<br>ATT3064 | PGA Pin<br>Number | ATT3042<br>ATT3064 | PGA Pin<br>Number | ATT3042<br>ATT3064 | PGA Pin<br>Number | ATT3042<br>ATT3064 | |-------------------|--------------------|-------------------|--------------------|-------------------|----------------------|-------------------|--------------------| | C4 | GND | B13 | M1- RD | P14 | RESET | M3 | DOUT-I/O | | A1 | PWRDN | C11 | GND | M11 | Vcc | P1 | CCLK | | СЗ | TCLKIN-I/O | A14 | M0-RT | N13 | DONE- PG | M4 | Vcc | | B2 | 1/0 | D12 | Vcc | M12 | D7-I/O | L3 | GND | | B3 | 1/0 | C13 | M2-I/O | P13 | XTAL1-BCLKIN-I/O | M2 | A0- WS -I/O | | A2 | 1/0• | B14 | HDC-I/O | N12 | 1/0 | N1 | A1-CS2-I/O | | B4 | 1/0 | C14 | 1/0 | P12 | 1/0 | M1 | 1/0 | | C5 | 1/0 | E12 | 1/0 | N11 | D6-I/O | КЗ | 1/0 | | A3 | I/O* | D13 | 1/0 | M10 | 1/0 | L2 | A2-I/O | | A4 | 1/0 | D14 | LDC -I/O | P11 | 1/0* | L1 | A3-I/O | | B5 | 1/0 | E13 | I/O* | N10 | 1/0 | K2 | 1/0 | | C6 | 1/0 | F12 | 1/0 | P10 | 1/0 | J3 | 1/0 | | A5 | 1/0 | E14 | VO | M9 | D5-I/O | K1 | A15-I/O | | B6 | 1/0 | F13 | 1/0 | N9 | CSO -I/O | J2 | A4-I/O | | A6 | 1/0 | F14 | 1/0 | P9 | I/O* | J1 | I/O* | | B7 | 1/0 | G13 | I/O | P8 | I/O* | H1 | A14-I/O | | C7 | GND | G14 | INIT -I/O | N8 | D4-I/O | H2 | A5-I/O | | C8 | Vcc | G12 | Vcc | P7 | 1/0 | H3 | GND | | A7 | 1/0 | H12 | GND | M8 | Vcc | G3 | Vcc | | B8 | 1/0 | H14 | 1/0 | M7 | GND | G2 | A13-I/O | | A8 | 1/0 | H13 | 1/0 | N7 | D3-I/O | G1 | A6-I/O | | A9 | 1/0 | J14 | 1/0 | P6 | CS1 -I/O | F1 | 1/0* | | B9 | 1/0 | J13 | 1/0 | N6 | I/O* | F2 | A12-I/O | | C9 | 1/0 | K14 | 1/0 | P5 | I/O* | E1 | A7-I/O | | A10 | I/O | J12 | 1/0 | M6 | D2-I/O | F3 | 1/0 | | B10 | 1/0 | K13 | 1/0 | N5 | 1/0 | E2 | 1/0 | | A11 | I/O* | L14 | ľO* | P4 | 1/0 | D1 | A11-I/O | | C10 | 1/0 | L13 | I/O | P3 | | D2 | A8-I/O | | B11 | I/O | K12 | I/O | M5 | D1-I/O | E3 | 1/0 | | A12 | I/O* | M14 | 1/0 | N4 | RCLK - BUSY /RDY-I/O | C1 | 1/0 | | B12 | 1/0 | N14 | 1/0 | P2 | 1/0 | B1 | A10-I/O | | A13 | I/O* | M13 | XTAL2(IN)-I/O | N3 | 1/0 | C2 | A9-I/O | | C12 | 1/0 | L12 | GND | N2 | D0-DIN-I/O | D3 | Vcc | <sup>\*</sup> Indicates unconnected package pins for the ATT3042. Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. Table 2h. ATT3000 Family 160-Pin PQFP Pinout | PQFP<br>Pin No. | ATT3064<br>ATT3090 | PQFP<br>Pin No. | ATT3064<br>ATT3090 | PQFP<br>Pin No. | ATT3064<br>ATT3090 | PQFP<br>Pin No. | ATT3064<br>ATT3090 | |-----------------|--------------------|-----------------|--------------------|-----------------|----------------------|-----------------|--------------------| | 1 | I/O* | 41 | GND | 81 | D7-I/O | 121 | CCLK | | 2 | I/O* | 42 | M0-RTRIG | 82 | XTAL1-BCLKIN-I/O | 122 | Vcc | | 3 | 1/0* | 43 | VCC | 83 | VO* | 123 | GND | | 4 | 1/0 | 44 | M2-I/O | 84 | I/O | 124 | A0- WS -I/O | | 5 | VO | 45 | HDC-I/O | 85 | I/O | 125 | A1-CS2-I/O | | 6 | 1/0 | 46 | VO | 86 | D6-I/O | 126 | 10 | | 7 | 1/0 | 47 | 1/0 | 87 | I/O | _127 | I/O | | 8 | 1/0 | 48 | 1/0 | 88 | | 128 | A2-I/O | | 9 | 1/0 | 49 | LDC -I/O | 89 | 1/0 | 129 | A3-I/O | | 10 | 1/0 | 50 | I/O* | 90 | 1/0 | 130 | 1/0 | | 11 | 1/0 | 51 | VO* | 91 | 1/0 | 131 | 1/0 | | 12 | 1/0 | 52 | 1/0 | 92 | D5-I/O | 132 | A15-I/O | | 13 | 1/0 | 53 | 1/0 | 93 | CS0 -1/O | 133 | A4-I/O | | 14 | I/O | 54 | I/O | 94 | I/O* | 134 | 1/0 | | 15 | 1/0 | 55 | I/O | 95 | I/O* | 135 | 1/0 | | 16 | 1/0 | 56 | 1/0 | 96 | 1/0 | 136 | A14-I/O | | 17 | 1/0 | 57 | 1/0 | 97 | 1/0 | 137 | A5-I/O | | 18 | 1/0 | 58 | 1/0 | 98 | D4-I/O | 138 | I/O* | | 19 | GND | 59 | INIT -I/O | 99 | I/O | 139 | GND | | 20 | Vcc | 60 | Vcc | 100 | Vcc | 140 | Vcc | | 21 | I/O* | 61 | GND | 101 | GND | 141 | A13-I/O | | 22 | 1/0 | 62 | 1/0 | 102 | D3-I/O | 142 | A6-I/O | | 23 | 1/0 | 63 | 1/0 | 103 | CS1 -I/O | 143 | I/O* | | 24 | 1/0 | 64 | _1/0 | 104 | I/O | 144 | /O* | | 25 | 1/0 | 65 | 1/0 | 105 | 1/0 | 145 | 1/0 | | 26 | 1/0 | 66 | I/O | 106 | I/O* | 146 | 1/0 | | 27 | 1/0_ | 67 | 1/0 | 107 | 1/0* | 147 | A12-I/O | | 28 | 1/0 | 68 | 1/0 | 108 | D2-1/O | 148 | A7-I/O | | 29 | 1/0 | 69 | 1/0 | 109 | 1/0 | 149 | 1/0 | | 30 | 1/0 | 70 | 1/0 | 110 | VO | 150 | 1/0 | | 31 | 1/0 | 71 | 1/0 | 111 | VO | 151 | A11-I/O | | 32 | 1/0 | 72 | 1/0 | 112 | 1/0 | 152 | A8-I/O | | 33 | 1/0 | 73 | 1/0 | 113 | 1/0 | 153 | 1/0 | | 34 | 1/0 | 74 | 1/0 | 114 | D1-I/O | 154 | 1/0 | | 35 | 1/0 | 75 | I/O* | 115 | RDY- BSY / RCLK -I/O | 155 | A10-I/O | | 36 | VO. | 76 | XTAL2-I/O | 116 | I/O | 156 | A9-I/O | | 37 | VO | 77 | GND | 117 | 1/0 | 157 | Vcc | | 38 | 1/0* | 78 | RESET | 118 | I/O* | 158 | GND | | 39 | I/O* | 79 | Vcc | 119 | D0-DIN-I/O | 159 | PWRDWN | | 40 | M1- RDATA | 80 | DONE -PROG | 120 | DOUT-I/O | 160 | TCLKIN-I/O | <sup>\*</sup> Not connected on ATT3064. Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. DEVICE POWER MUST BE LESS THAN 1 WATT FOR COMMERCIAL TEMPERATURE RANGE, AND LESS THAN 0.8 WATTS FOR INDUSTRIAL TEMPERATURE RANGE. Table 2l. ATT3000 Family 164-Pin CQFP Pinouts | CQFP<br>Pin No. | ATT3090 | CQFP<br>Pin No. | ATT3090 | CQFP<br>Pin No. | ATT3090 | CQFP<br>Pin No. | ATT3090 | |-----------------|-------------|-----------------|---------------|-----------------|-----------------------|-----------------|-------------| | 20 | PWRDWN | 61 | I/O | 103 | DONE- PROG | 143 | D0-DIN-I/O | | 21 | TCLKIN-VO | 62 | M1- RDATA | 104 | D7-1/O | 144 | DOUT-I/O | | 22 | 1021111 110 | 63 | GND | 105 | XTAL1(OUT)-BCLKIN-I/O | 145 | CCLK | | 23 | 1/0 | 64 | Mo-RTRIG | 106 | 1/0 | 146 | Vcc | | 24 | 1/0 | 65 | Vcc | 107 | 1/0 | 147 | GND | | 25 | 1/0 | 66 | M2-I/O | 108 | I/O | 148 | A0- WS -I/O | | 26 | 1/0 | 67 | HDC-I/O | 109 | D6-I/O | 149 | A1-CS2-I/O | | 27 | 1/0 | 68 | 1/0 | 110 | 1/0 | 150 | I/O | | 28 | 1/0 | 69 | 1/0 | 111 | 1/0 | 151 | 1/0 | | 29 | I/O | 70 | 1/0 | 112 | 1/0 | 152 | A2-I/O | | 30 | <i>V</i> O | 71 | LDC -1/O | 113 | 1/0 | 153 | A3-I/O | | 31 | 1/0 | 72 | 1/0 | 114 | 1/0 | 154 | 1/0 | | 32 | 1/0 | 73 | 1/0 | 115 | D5-I/O | 155 | 1/0 | | 33 | 1/0 | 74 | 1/0 | 116 | CS0 -I/O | 156 | A15-I/O | | 34 | I/O | 75 | 1/0 | 117 | 1/0 | 157 | A4-I/O | | 35 | 1/0 | 76 | 1/0 | 118 | 1/0 | 158 | 1/0 | | 36 | 1/0 | 77 | 1/0 | 119 | 1/0 | 159 | | | 37 | 1/0 | 78 | 1/0 | 120 | I/O | 160 | A14-I/O_ | | 38 | 1/0 | 79 | 1/0 | 121 | D4-I/O | 161 | A5-I/O | | 39 | 1/0 | 80 | 1/0 | 122 | | 162 | 1/0 | | 40 | 1/0 | 81 | INIT -I/O | 123 | Vcc | 163 | I/O | | 41 | GND | 82 | Vcc | 124 | GND | 164 | GND | | 42 | Vcc | 83 | GND | 125 | D3-I/O | 1 | Vcc | | 43 | 1/0 | 84 | I/O | 126 | CS1 -I/O | 2 | A13-I/O | | 44 | I/O | 85 | 1/0 | 127 | 1/0 | _ 3 | A6-I/O | | 45 | 1/0 | 86 | 1/0 | 128 | 1/0 | 4 | 1/0 | | 46 | 1/0 | 87 | 1/0 | 129 | 1/0 | 5 | 1/0 | | 47 | 1/0 | 88 | 1/0 | 130 | 1/0 | 6 | 1/0 | | 48 | 1/0 | 89 | <u>I/O</u> | 131 | D2-I/O | 7 | 1/0 | | 49 | 1/0 | 90 | 1/0 | 132 | 1/0 | 8 | A12-I/O | | 50 | 1/0 | 91 | 1/0 | 133 | 1/0 | 9 | A7-I/O | | 51 | 1/0 | 92 | 1/0 | 134 | 1/0 | 10 | 1/0 | | 52 | 1/0 | 93 | 1/0 | 135 | 1/0 | 11 | <u> </u> | | 53 | 1/0 | 94 | 1/0 | 136 | 1/0 | 12 | A11-I/O | | 54 | 1/0 | 95 | 1/0 | 137 | D1-I/O | 13 | A8-I/O | | 55 | 1/0 | 96 | 1/0 | 138 | RDY- BUSY - RCLK -I/O | 14 | | | 56 | 1/0 | 97 | 1/0 | 139 | 1/0 | 15 | 1/0 | | 57 | 1/0 | 98 | 1/0 | 140 | 1/0 | 16 | A10-I/O | | 58 | 1/0 | 99 | XTAL2(IN)-I/O | 141 | 1/0 | 17 | A9-I/O | | 59 | 1/0 | 100 | GND | 142 | 1/0 | 18 | Vcc | | 60 | 1/0 | 101 | RESET | | | 19 | GND | | | | 102 | Vcc | | | | | Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. Table 2j. ATT3000 Family 175-Pin PGA Pinouts | PGA<br>Pin No. | ATT3090 | PGA<br>Pin No. | ATT3090 | PGA<br>Pin No. | ATT3090 | PGA<br>Pin No. | ATT3090 | |----------------|------------|----------------|---------------|----------------|-----------------------|----------------|-------------| | B2 | PWRDWN | D13 | 1/0 | R14 | DONE- PROG | R3 | D0-DIN-I/O | | D4 | TCLKIN-I/O | B14 | M1- RDATA | N13 | D7-I/O | N4 | DOUT-I/O | | B3 | 1/0 | C14 | GND | T14 | XTAL1(OUT)-BCLKIN-I/O | R2 | CCLK | | C4 | 1/0 | B15 | Mo-RTRIG | P13 | 1/0 | P3 | Vcc | | B4 | 1/0 | D14 | Vcc | R13 | 1/0 | N3 | GND | | A4 | 1/0 | C15 | M2-I/O | T13 | 1/0 | P2 | A0- WS -I/O | | D5 | 1/0 | E14 | HDC-I/O | N12 | 1/0 | M3 | A1-CS2-I/O | | C5 | 1/0 | B16 | 1/0 | P12 | D6-I/O | R1 | 1/0 | | B5 | 1/0 | D15 | 1/0 | R12 | I/O | N2 | 1/0 | | A5 | 1/0 | C16 | 1/0 | T12 | 1/0 | P <u>1</u> | A2-I/O | | C6 | 1/0 | D16 | LDC -I/O | P11 | 1/0 | N1 | A3-I/O | | D6 | 1/0 | F14 | 1/0 | N11 | I/O | L3 | 1/0 | | B6 | VO | E15 | 1/0 | R11 | 1/0 | M2 | 1/0 | | _A6 | <i>V</i> O | E16 | 1/0 | T11 | D5-I/O | M1 | A15-I/O | | B7 | 1/0 | F15 | 1/0 | R10 | CSO -I/O | L2 | A4-I/O | | <b>C</b> 7 | 1/0 | F16 | VO | P10 | 1/0 | L1 | 1/0 | | D7 | 1/0 | G14 | 1/0 | N10 | I/O | КЗ | 1/0 | | Α7 | 1/0 | G15 | 1/O | T10 | 1/0 | K2 | A14-I/O | | A8 | 1/0 | G16 | 1/0 | T9 | 1/0 | K1 | A5-I/O | | B8 | 1/0 | H16 | 1/0 | R9 | D4-I/O | J1 | 9 | | C8 | 1/0 | H15 | INIT -I/O | P9 | 1/0 | J2 | 1/0 | | D8 | GND | H14 | Vcc | N9 | Vcc | JЗ | GND | | D9 | Vcc | J14 | GND | N8 | GND | НЗ | Vcc | | C9 | 1/0 | J15 | 1/0 | P8 | D3-I/O | H2 | A13-I/O | | В9 | 1/0 | J16 | 1/0 | R8 | CS1 -I/O | H1 | A6-I/O | | A9 | 1/0 | K16 | 1/0 | T8 | 1/0 | G1 | 1/0 | | A10 | VO | K15 | 1/0 | T7 | 1/0 | G2 | 1/0 | | D10 | 1/0 | K14 | 1/0 | N7 | 1/0 | G3 | 1/0 | | C10 | 1/0 | L16 | 1/0 | P7 | 1/0 | F1 | 1/0 | | B10 | 1/0 | L15 | 1/0 | R7 | D2-I/O | F2 | A12-I/O | | A11 | 1/0 | M16 | 1/0 | T6 | 1/0 | E1 | A7-I/O | | B11 | 1/0 | M15 | 1/0 | R6 | I/O | E2 | 1/0 | | D11 | 1/0 | L14 | 1/0 | N6 | 1/0 | F3 | 1/0 | | C11 | 1/0 | N16 | 1/0 | P6 | I/O | D1 | A11-I/O | | A12 | 1/0 | P16 | 1/0 | T5 | 1/0 | <u>C1</u> | A8-I/O | | B12 | 1/0 | N15 | 1/0 | R5 | <u>D1-I/O</u> | D2 | 1/0 | | C12 | I/O | R16 | 1/0 | P5 | RDY/ BUSY - RCLK -I/O | B1 | 1/0 | | D12 | 1/0 | M14 | 1/0 | N5 | 1/0 | E3 | A10-I/O | | A13 | 1/0 | P15 | XTAL2(IN)-I/O | T4 | 1/0 | C2 | A9-I/O | | B13 | 1/0 | _ N14 | GND | R4 | 1/0 | D3 | Vcc | | C13 | 1/0 | R15 | RESET | P4 | I/O | C3 | GND | | A14 | 1/0 | P14 | Vcc | | | | | Notes: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. Pins A2, A3, A15, A16, T1, T2, T3, T15, and T16 are not connected. Pin A1 does not exist. Table 2k. ATT3000 Family 208-Pin QFP Pinouts | QFP<br>Pin No. | ATT3090 | QFP<br>Pin No. | ATT3090 | QFP<br>Pin No. | ATT3090 | QFP<br>Pin No. | ATT3090 | |----------------|------------|----------------|-------------------|----------------|----------------------|----------------|-------------| | | | 53 | | 105 | | 157 | | | 2 | GND | 54 | | 106 | Vcc | 158 | | | 3 | POWERDOWN | 55 | Vcc | 107 | DONE- PG | 159 | | | 4 | TCLKIN-I/O | 56 | M2-I/O | 108 | | 160 | GND | | 5 | VO | 57 | HDC-I/O | 109 | I/O-D7 | 161 | I/O- WS -A0 | | 6 | 1/0 | 58 | 1/0 | 110 | I/O-XTAL-BCLKIN | 162 | I/O-CS2-A1 | | 7 | 1/0 | 59 | 1/0 | 111 | I/O | 163 | I/O | | 8 | I/O | 60 | 1/0 | 112 | 1/0 | 164 | 1/0 | | 9 | 1/0 | 61 | LDC -I/O | 113 | 1/0 | 165 | I/O-A2 | | 10 | 1/0 | 62 | 1/0 | 114 | I/O | 166 | I/O-A3 | | 11 | 1/0 | 63 | 1/0 | 115 | VO-D6 | 167 | 1/0 | | 12 | I/O | 64 | | 116 | 1/0 | 168 | 1/0 | | 13 | I/O. | 65 | | 117 | I/O | 169 | | | 14 | VO | 66 | | 118 | 1/0 | 170 | | | 15 | | 67 | | 119 | | 171 | | | 16 | 1/0 | 68 | 1/0 | 120 | 1/0 | 172 | I/O-A15 | | 17 | 1/0 | 69 | 1/0 | 121 | I/O | 173 | VO-A4 | | 18 | 1/0 | 70 | 1/0 | 122 | I/O-D5 | 174 | VO | | 19 | 1/0 | 71 | 1/0 | 123 | 1/O- CS0 | 175 | 1/0 | | 20 | 1/0 | 72 | | 124 | 1/0 | 176 | | | 21 | 1/0 | 73 | | 125 | 1/0 | 177 | | | 22 | 1/0 | 74 | 1/0 | 126 | I/O | 178 | I/O-A14 | | 23 | VO | 75 | 1/0 | 127 | I/O | 179 | I/O-A5 | | 24 | 1/0 | 76 | 1/0 | 128 | I/O-D4 | 180 | VO | | 25 | GND | 77 | INIT -I/O | 129 | 1/0 | 181 | 1/0 | | 26 | Vcc | 78 | Vcc | 130 | Vcc | 182 | GND | | 27 | 1/0 | 79 | GND | 131 | GND | 183 | Vcc | | 28 | 1/0 | 80 | 1/0 | 132 | I/O-D3 | 184 | I/O-A13 | | 29 | VO | 81 | 1/0 | 133 | VO- CS1 | 185 | I/O-A6 | | 30 | VO | 82 | 1/0 | 134 | 1/0 | 186 | VO. | | 31 | 1/0 | 83 | W 90 12 0 1 1 1 1 | 135 | 1/0 | 187 | VO | | 32 | 1/0 | 84 | | 136 | 1/0 | 188 | | | 33 | 1/0 | 85 | 1/0 | 137 | 1/0 | 189 | | | 34 | 1/0 | 86 | 1/0 | 138 | I/O-D2 | 190 | VO | | 35 | 1/0 | 87 | I/O | 139 | 1/0 | 191 | 10 | | 36 | 1/0 | 88 | 1/0 | 140 | VO | 192 | I/O-A12 | | 37 | | 89 | 1/0 | 141 | 1/0 | 193 | I/O-A7 | | 38 | 1/0 | 90 | | 142 | | 194 | | | 39 | 1/0 | 91 | | 143 | 1/0 | 195 | | | 40 | VO | 92 | | 144 | I/O | 196 | | | 41 | 1/0 | 93 | 1/0 | 145 | I/O-D1 | 197 | VO | | 42 | 1/0 | 94 | 1/0 | 146 | I/O- BUSY /RDY- RCLK | 198 | 1/0 | | 43 | 1/0 | 95 | 1/0 | 147 | <u> </u> | 199 | I/O-A11 | | 44 | 1/0 | 96 | 1/0 | 148 | I/O | 200 | I/O-A8 | | 45 | 1/0 | 97 | 1/0 | 149 | 1/0 | 201 | 1/0 | | 46 | 1/0 | 98 | 1/0 | 150 | VO. | 202 | NO. | | 47 | 1/0 | 99 | 1/0 | 151 | I/O-DIN-D0 | 203 | I/O-A10 | | 48 | M1- RDATA | 100 | XTAL2-I/O | 152 | I/O-DOUT | 204 | I/O-A9 | | 49 | GND | 101 | GND | 153 | CCLK | 205 | Vcc | | 50 | Mo-RTRIG | 102 | RESET | 154 | Vcc | 206 | | | 51 | | 103 | | 155 | | 207 | | | 52 | | 104 | | 156 | | 208 | | = Preliminary. Note: Unprogrammed IOBs have a default pull-up. This prevents an undefined pad level for unbonded or unused IOBs. Programmed outputs are default slew-limited. # **PARAMETRICS** #### **Absolute Maximum Ratings** Stresses in excess of the Absolute Maximum Ratings can cause permanent damage to the device. These are absolute stress ratings only. Functional operation of the device is not implied at these or any other conditions in excess of those given in the operational sections of the data sheet. Exposure to Absolute Maximum Ratings for extended periods canadversely affect device reliability. | Symbol | Parameter | Limit | Units | |--------|---------------------------------------------------|-------------------|-------| | Vcc | Supply voltage relative to GND | -0.5 to 7.0 | V | | VIN | Input voltage with respect to GND | -0.5 to Vcc + 0.5 | V | | VTS | Voltage applied to three-state output | -0.5 to Vcc + 0.5 | V | | Tstg | Storage temperature (ambient) | -65 to + 150 | °C | | Tsol | Maximum soldering temperature (10 sec @ 1/16 in.) | + 260 | °C | | | Junction temperature plastic | + 125 | °C | | TJ | Junction temperature ceramic | + 150 | °C | ## **Recommended Operating Conditions** | Symbol | Parameter | | Min | Max | Units | |--------|-----------------------------------------------|------------|------|------|-------| | Vcc | Supply voltage relative to GND | Commercial | 4.75 | 5.25 | ٧ | | | | Industrial | 4.5 | 5.5 | ٧ | | VIHT | High-level input voltage — TTL configuration | | 2.0 | Vcc | ٧ | | VILT | Low-level input voltage — TTL configuration | | 0 | 8.0 | ٧ | | VIHC | High-level input voltage — CMOS configuration | | 70% | 100% | Vcc | | VILC | Low-level input voltage — CMOS configuration | | 0 | 20% | Vcc | | Tin | Input signal transition time | | | 250 | ns | | Ta | Ambient Temperature Range | Commercial | 0 | +70 | ŷ | | | | Industrial | -40 | +85 | ∘C | # **Electrical Characteristics Over Operating Conditions** | Symbol | Parameter/Conditions | | Min | Мах | Units | |--------|---------------------------------------------------------------------------------------------------------------------|------------|------|----------|----------| | Vон | High-level output voltage (@ IOH = -4.0 mA, Vcc min) | 3.86 | | ٧ | | | Vol | Low-level output voltage (@ IOL = 4.0 mA, Vcc min) | | | 0.32 | > | | Vон | High-level output voltage (@ IOL = -4.0 mA, Vcc min) | Industrial | 3.76 | | ٧ | | VOL | Low-level output voltage (@ IOL = 4.0 mA, Vcc min) | | | 0.37 | ٧ | | VCCPD | Power-down supply voltage ( PWRDWN must be Low) | | 2.3 | | ٧ | | ICCPD | Power-down supply current (Vcc = 5.0 V @ 70 °C) | ATT3020 | | 50 | μΑ | | | | ATT3030 | | 80 | μА | | | | ATT3042 | | 120 | μА | | ŀ | | ATT3064 | | 170 | μА | | | | ATT3090 | | 250 | μА | | Icco | Quiescent FPGA supply current in addition to ICCPC | | | | | | | Chip thresholds programmed as CMOS levels | | _ | 500 | μА | | | Chip thresholds programmed as TTL levels | | | 10 | mA | | liL | Leakage Current | | -10 | +10 | μΑ | | CIN | Input capacitance, all packages except PGA 175<br>(sample tested)<br>All Pins except XTL1 and XTL2<br>XTL1 and XTL2 | | | 10<br>15 | pf<br>pf | | | Input capacitance, PGA 175<br>(sample tested)<br>All Pins except XTL1 and XTL2<br>XTL1 and XTL2 | | | 15<br>20 | pf<br>pf | | IRIN | Pad pull-up (when selected) @ VIN = 0 V (sample tested) | | 0.02 | 0.17 | mA | | IRLL | Horizontal long line pull-up (when selected) @ logic LOW | | 0.2 | 2.5 | mA | Note: With no output current loads, no active input or long line pull-up resistors, all package pins at Vcc or GND, and the FPGA configured with a MAKEBITS tie option. See FPGA power chart for additional activity-dependent operating component. ## **GENERAL FPGA SWITCHING CHARACTERISTICS** | | | Speed (4) | | Speed (4) -70 | | | 100 | -125 | | 150 | | Unit | |------------|-----------------------------------------------------------------------------------------------|-------------|--------------------|---------------|-----|-------------|-----|-------------|-----|-------------|-----|----------------| | Signal | Description | S | ymbol | Min | Max | Min | Мах | Min | Max | Min | Max | | | RESET (2) | M0, M1, M2 setup time required M0, M1, M2 hold time required RESET Width (Low) req. for Abort | 2<br>3<br>4 | TMR<br>TRM<br>TMRW | 1<br>1<br>6 | | 1<br>1<br>6 | | 0<br>1<br>6 | | 0<br>1<br>6 | | μs<br>μs<br>μs | | DONE/ PROG | Width (Low0 required for Re-config. INIT response after D/ P is pulled Low | 5 | TPGW<br>TPGI | 6 | 7 | 6 | 7 | 6 | 7 | 6 | 7 | μs<br>μs | | PWRDWN (3) | Powerdown VCC | | Vссро | 2.3 | | 2.3 | | 2.3 | | 2.3 | | ٧ | = Preliminary. #### Notes: At power-up, Vcc must rise from 2.0 V to Vcc minimum in less than 25 ms. If this is not possible, configuration can be delayed by holding RESET Low until Vcc has reached 4.0 V. A very long Vcc rise time of >1 00 ms, or a non-monotonically rising Vcc may require a >1 μs High level on RESET, followed by a >6 μs Low level on RESET and D/P after Vcc has reached 4.0 V. <sup>2.</sup> RESET timing relative to valid mode lines (M0, M1, M2) is relevant when RESET is used to delay configuration. <sup>3.</sup> PWRDWN transitions must occur while Vcc > 4.0 V. # **BUFFER (Internal) SWITCHING CHARACTERISTIC GUIDELINES** | | Speed Grade | -70 | -100 | -125 | 150 | Units | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----|------|------|-----|-------| | Description | Symbol | Max | Max | Max | Max | L | | Global and Alternate Clock Distribution* Either: Normal IOB input pad to clock buffer input Or: Fast (CMOS only) input pad to clock buffer input | TPID | 8 | 7.5 | 7 | 6.7 | ns | | | TPIDC | 6.5 | 6 | 5.7 | 5.5 | ns | | TBUF driving a Horizontal Long line (L.L.)* I to L.L. while T is Low (buffer active) T↓ to L.L. active and valid with single pull-up resistor T↓ to L.L. active and valid with pair of pull-up resistors | TIO | 5 | 4.7 | 4.5 | 4.3 | ns | | | TON | 11 | 10 | 9 | 8 | ns | | | TON | 12 | 11 | 10 | 9 | ns | | T↑to L.L. High with single pull-up resistor T↑ to L.L. High with pair of pull-up resistors | Tpus | 24 | 22 | 17 | 16 | ns | | | Tpuf | 17 | 15 | 12 | 11 | ns | | BIDI<br>Bidirectional buffer delay | Твілі | 2 | 1.8 | 1.7 | 1.6 | ns | <sup>\*</sup> Timing is based on the ATT3042; for other devices, see XACT timing calculator. ## **CLB SWITCHING CHARACTERISTIC GUIDELINES** <sup>=</sup> Preliminary. ## **CLB SWITCHING CHARACTERISTIC GUIDELINES (continued)** Testing of the switching characteristic guidelines is modeled after testing specified by MIL-M-38510/605. Devices are 100% functionally tested. Benchmark timing patterns are used to provide correlation to the switching characteristic guideline values. Actual worst-case timing is provided by the *XACT* Timing calculator or Simulation modeling. | | Spee | d Grade | -7 | 70 | -1 | 00 | -1 | 25 | 15 | 50 | Units | |-----------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------|------------------|-----|------------------|---------|----------------------|----------|--------------------|----------|-----------------| | Description | Sy | mbol | Min | Max | Min | Max | Min | Max | Min | Max | İ | | Combinatorial Delay Logic Variables a, b, c, d, e, to outputs x, y | 1 | Tilo | | 9 | | 7 | | 5.5 | | 4.6 | ns | | Sequential delay clock k to outputs x, y clock k outputs x, y when Q is returned through function generators F or G to drive x, y | 8 | Тско<br>Тскоо | | 6 | | 5<br>10 | | 4.5<br>8 | | 4<br>6.7 | ns<br>ns | | Set-up time before clock K Logic Variables a, b, c, d, e Data In di Enable Clock ec Reset Direct inactive rd | 2<br>4<br>6 | TICK<br>TDICK<br>TECCK<br>TROCK | 8<br>5<br>7<br>1 | | 7<br>4<br>5<br>1 | | 5.5<br>3<br>4.5<br>1 | | 4.6<br>2<br>4<br>1 | | ns<br>ns<br>ns | | Hold Time after clock k Logic Variables a, b, c, d, e Data In di Enable Clock ec | 3<br>5<br>7 | TCKI<br>TCKDI<br>TCKEC | 0<br>4<br>0 | | 0<br>2<br>0 | | 0<br>1.5<br>0 | | 0<br>1.2<br>0 | | ns<br>ns<br>ns | | Clock Clock High time* Clock Low time* Max. flip-flop toggle rate* | 11<br>12 | TCH<br>TCL<br>FCLK | 5<br>5<br>70 | | 4<br>4<br>100 | | 3<br>3<br>125 | | 2.5<br>2.5<br>150 | | ns<br>ns<br>MHz | | Reset Direct (rd) rd width delay from rd to outputs x, y | 13<br>9 | Trpw<br>Trio | 8 | 8 | 7 | 7 | 6 | 6 | 5 | 5 | ns<br>ns | | Master Reset (MR) MR width delay from MR to outputs x, y | | TMRW<br>TMRQ | 25 | 23 | 21 | 19 | 20 | _17 | 19 | 17 | ns<br>ns | <sup>\*</sup> Timing is based on the ATT3042, for other devices see the XACT timing calculation. = Preliminary. Note: The CLB K to Q output delay (TCKO, #8) of any CLB, plus the shortest possible interconnect delay, is always longer than the Data In hold time requirement (TCKDI, #5) of any CLB on the same die. # **IOB SWITCHING CHARACTERISTIC GUIDELINES** 2271 28 2271 29 ## IOB SWITCHING CHARACTERISTIC GUIDELINES (continued) Testing of the switching characteristic guidelines is modeled after testing specified by MIL-M-38510/605. Devices are 100% functionally tested. Benchmark timing patterns are used to provide correlation to the switching characteristic guideline values. Actual worst-case timing is provided by the *XACT* Timing calculator or Simulation modeling. | | | Spee | d Grade | | 70 | -1 | 00 | -1 | 25 | 1 | 50 | Units | |---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------|-------------|--------------------------------------------|---------------|--------------------------------------------|---------------|-------------------------------------------|-------------------|---------------------------------------------|----------------------------------| | Description | | Sy | /mbol | Min | Max | Min | Max | Min | Max | Min | Мах | | | | | | | | 6<br>21<br>5.5 | | 4<br>17<br>4 | | 3<br>16<br>3 | | 2.8<br>15<br>2.8 | ns<br>ns<br>ns | | Set-up Time (Input) Pad to Clock (ik) set-up time | | | TPICK | 20 | | 17 | | 16 | | 14.5 | | ns | | Propagation Delays (Output<br>Clock (ok) to Pad<br>same<br>Output (o) to Pad<br>same<br>3-state to Pad begin hi-Z<br>same<br>3-state to Pad and valid<br>same | t) (fast) (slew-rate limited) (fast) (slew-rate limited) (fast) (slew-rate limited) (fast) (fast) (slew-rate limited) | 7<br>7<br>10<br>10<br>9<br>9<br>8<br>8 | TOKPO<br>TOKPO<br>TOPF<br>TOPS<br>TTSHZ<br>TTSHZ<br>TTSON<br>TTSON | | 13<br>33<br>9<br>29<br>8<br>28<br>14<br>34 | | 10<br>27<br>6<br>23<br>8<br>25<br>12<br>29 | | 9<br>24<br>5<br>20<br>7<br>24<br>11<br>27 | | 7<br>22<br>4.5<br>15<br>7<br>22<br>11<br>26 | ns<br>ns<br>ns<br>ns<br>ns<br>ns | | Set-up and Hold Times (Ou<br>Output (o) to clock (ok) set<br>Output (o) to clock (ok) hol | -up time | 5<br>6 | Тоск<br>Токо | 10<br>0 | | 9 | | 8 | | 7<br>0 | | ns<br>ns | | Clock Clock High time* Clock Low time* Max. flip-flop toggle rate | | 11<br>12 | Tch<br>Tcl<br>Fclk | 5<br>5<br>0 | | 4<br>4<br>100 | | 3<br>3<br>125 | | 2.5<br>2.5<br>150 | | ns<br>ns<br><b>M</b> Hz | | RESET Pad to Registered In (q) RESET Pad to output pad (fast) (slew-rate limited) | | 13<br>15<br>15 | TRRI<br>TRPO<br>TRPO | | 25<br>35<br>53 | | 24<br>33<br>45 | | 23<br>29<br>42 | | 20<br>25<br>40 | ns<br>ns<br>ns | = Preliminary. #### Notes: Timing is measured at pin threshold, with 50 pF external capacitive loads (incl. test fixture). Typical fast mode output rise/fall times are 2 ns and will increase approximately 2%/pF of additional load. Typical slew-rate limited output rise/fall times are approximately 4 times longer. A maximum total external capacitive load for simultaneous fast mode switching in the same direction is 200 pF per power/ground pin pair. For slew-rate limited outputs this total is 4 times larger. Voltage levels of unused (bonded and unbonded) pads must be valid logic levels. Each can be configured with the internal pull-up resistor or alternatively configured as a driven output or driven from an external source. Input pad set up time is specified with respect to the internal clock (.ik). In order to calculate system set up time, subtract clock delay (pad to ik) from the input pad set up time value. Input pad holdtime with respect to the internal clock (ik) is negative. This means that pad level changes immediately before the internal clock edge (ik) will not be recognized. # MASTER SERIAL MODE SWITCHING CHARACTERISTICS GUIDELINES | | | Speed | | -7 | 70 | -100 | | -125 | | 1 | Unit | | |--------|-------------------------------|--------|----------------|---------|-----|---------|-----|---------|-----|---------|------|----------| | Signal | Description | Sy | mbol | Min | Мах | Min | Мах | Min | Max | Min | Мах | | | CCLK | Data In setup<br>Data in hold | 1<br>2 | Tosck<br>Tokos | 60<br>0 | | 60<br>0 | | 60<br>0 | | 60<br>0 | | ns<br>ns | #### Notes: - At power-up, Vcc must rise from 2.0 V to Vcc minimum in less than 25 ms. If this is not possible, configuration can be delayed by holding RESET Low until Vcc has reached 4.0 V. A very long Vcc rise time of >100 ms, or a non-monotonically rising Vcc may require a >1 μs High level on RESET, followed by a >6 μs Low level on RESET and D/P after Vcc has reached 4.0 V. - Configuration can be controlled by holding RESET Low with or until after the INIT of all daisy-chain slave-mode devices is High. - 3. Master-serial-mode timing is based on slave-mode testing. # MASTER PARALLEL MODE PROGRAMMING SWITCHING CHARACTERISTIC GUIDELINES Testing of the switching characteristic guidelines is modeled after testing specified by MIL-M-38510/605. Devices are 100% functionally tested. Benchmark timing patterns are used to provide correlation to the switching characteristic guideline values. Actual worst-case timing is provided by the *XACT* Timing calculator or Simulation modeling. 2271 32 Note: This timing diagram shows that the EPROM requirements are extremely relaxed: EPROM access time can be longer than 4000 ns. EPROM data output has no hold time requirements. | | | S | oeed | -7 | 70 | -1 | 00 | -125 | | 15 | 150 | | |--------|----------------------------------------------------------------------------|-------------|--------------------------------------|----------------------------|-----|----------------------------|-----|----------------------------|-----|----------------------------|-----|----------------------------| | Signal | Description | Sy | mbol | Min | Max | Min | Max | Min | Мах | Min | Мах | | | RCLK | To address valid<br>To data setup<br>To data hold<br>RCLK high<br>RCLK low | 1<br>2<br>3 | TRAC<br>TDRC<br>TRCD<br>TRCH<br>TRCL | 0<br>60<br>0<br>600<br>4.0 | 200 | 0<br>60<br>0<br>600<br>4.0 | 200 | 0<br>60<br>0<br>600<br>4.0 | 200 | 0<br>60<br>0<br>600<br>4.0 | 200 | ns<br>ns<br>ns<br>ns<br>ns | #### Notes - At power-up, Vcc must rise from 2.0 V to Vcc minimum in less than 25 ms. If this is not possible, configuration can be delayed by holding RESET Low until Vcc has reached 4.0 V. A very long Vcc rise time of >100 ms, or a non-monotonically rising Vcc may require a >1 μs High level on RESET, followed by a >6 μs Low level on RESET and D/P after Vcc has reached 4.0 V. - 2. Configuration can be controlled by holding RESET Low with or until after the INIT of all daisy-chain slave-mode devices is High. # PERIPHERAL MODE PROGRAMMING SWITCHING CHARACTERISTICS Note: This timing diagram shows very relaxed requirements: Data need not be held beyond the rising edge of WS. BUSY will go active within 60 ns after the end of WS. BUSY will stay active for several microseconds. WS may be asserted immediately after the end of BUSY. | | | Si | peed | | 70 | -1 | 00 | 1 | 25 | 1: | Unit | | |--------|------------------------------------------------------|----|------------------------------------|---------|-----|---------|-----|---------|-----|---------|------|-----------------| | Signal | Description | Sy | mbol | Min | Max | Min | Max | Min | Max | Min | Max | | | Write | Effective write time required (CS0 x CS1 x CS2 x WS | 1 | Tca | 100 | | 100 | | 100 | | 100 | | ns | | | DIN setup time<br>required<br>DIN hold time required | 2 | T <sub>DC</sub><br>T <sub>CD</sub> | 60<br>0 | | 60<br>0 | | 60<br>0 | | 60<br>O | | ns<br>ns | | | RDY/ BUSY delay after end of WS | 4 | Тwтяв | | 60 | | 60 | | 60 | | 60 | ns | | RDY | Earliest next WS after end of BUSY | 5 | TRBWT | 0 | | 0 | | 0 | | 0 | | ns | | | BUSY Low time generated | 6 | TBUSY | 2 | 9 | 2 | 9 | 2 | 9 | 2 | 9 | CCLK<br>Periods | #### Notes: - At power-up, Vcc must rise from 2.0 V to Vcc minimum in less than 25 ms. If this is not possible, configuration can be delayed by holding RESET Low until Vcc has reached 4.0 V. A very long Vcc rise time of >100 ms, or a non-monotonically rising Vcc may require a >1 μs High level on RESET, followed by a >6 μs Low level on RESET and D/P after Vcc has reached 4.0 V. - 2. Configuration must be delayed until the INIT of all LCAs is High. - Time from end of WS to CCLK cycle for the new byte of data depends on completion of previous byte processing and the phase of the internal timing generator for CCLK. - 4. CCLK and DOUT timing is tested in slave mode. # **SLAVE MODE PROGRAMMING SWITCHING CHARACTERISTICS** | | | Speed | | -70 | | -100 | | -125 | | 15 | Unit | | |--------|---------------------------------------------------------|-----------------------|---------------------------------------------|-------------------------|-----------|-------------------------|-----------|-------------------------|-----------|-------------------------|-----------|----------------------------------------| | Signal | Description | Sy | mbol | Min | Мах | Min | Мах | Min | Max | Min | Max | | | CCLK | To DOUT DIN setup DIN hold High time Low time Frequency | 3<br>1<br>2<br>4<br>5 | Toco<br>Toco<br>Toco<br>Toch<br>Tocl<br>Foc | 60<br>0<br>0.05<br>0.05 | 5.0<br>10 | 60<br>0<br>0.05<br>0.05 | 5.0<br>10 | 60<br>0<br>0.05<br>0.05 | 5.0<br>10 | 60<br>0<br>0.05<br>0.05 | 5.0<br>10 | ម ខ ខ ជ ជ <u>ក</u><br>ក្នុង ក្នុង ក្នុ | #### Notes - 1. The max limit of CCLK Low time is caused by dynamic circuitry inside the LCA device. - Confingration must be delayed until the INIT of all LCAs is High. - At power-up, Vcc must rise from 2.0 V to Vcc minimum in less than 25 ms. If this is not possible, configuration can be delayed by holding RESET Low until Vcc has reached 4.0 V. A very long Vcc rise time of >100 ms, or a non-monotonically rising Vcc may require a >1 μs High level on RESET, followed by a >6 μs Low level on RESET and D/P after Vcc has reached 4.0 V. ## PROGRAM READBACK SWITCHING CHARACTERISTICS | | | | | | | | | | | | 22/1 35 | | |--------|-----------------------|--------|--------------|------------|-----|------------|-----|------------|-----|------------|---------|----------| | | | | Speed | | 70 | -100 | | -1 | 25 | 1: | 50 | Unit | | Signal | Description | Sy | mbol | Min | Мах | Min | Мах | Min | Мах | Min | Мах | | | RTRIG | RTRIG high | 1 | TRTH | 250 | | 250 | | 250 | | 250 | | ns | | CCLK | RTRIG setup | 2 | Тятсс | 200 | | 200 | | 200 | | 200 | | ns | | | RDATA delay | 3 | TCCRD | | 100 | | 100 | | 100 | | 100 | ns | | | High Time<br>Low time | 5<br>4 | Тссн<br>Тссь | 0.5<br>0.5 | 5 | 0.5<br>0.5 | 5 | 0.5<br>0.5 | 5 | 0.5<br>0.5 | 5 | μs<br>μs | ## Notes: - 1. During Readback, CCLK frequency may not exceed 1 MHz. - 2. RETRIG (M0 positive transition) shall not be done until after one clock following active I/O pins. - 3. Readback should not be initiated until configuration is complete. 2271 34