## **Spartan and SpartanXL Families Field Programmable Gate Arrays** January 6, 1999 (Version 1.4) Preliminary Product Specification ## Introduction The Spartan<sup>TM</sup> Series is the first high-volume production FPGA solution to deliver all the key requirements for ASIC replacement up to 40,000 gates. These requirements include high performance, on-chip RAM, Core Solutions and prices that, in high volume, approach and in many cases are equivalent to mask programmed ASIC devices. The Spartan Series is the result of more than thirteen years of FPGA design experience and feedback from thousands of customers. By streamlining the Spartan feature set, leveraging advanced hybrid process technologies and focusing on total cost management, the Spartan Series delivers the key features required by ASIC and other high volume logic users while avoiding the initial cost, long development cycles and inherent risk of conventional ASICs. The Spartan Series currently has 10 members, as shown in Table 1. ## **Spartan Series Features** Note: The Spartan Series devices described in this data sheet include the 5 V Spartan family of devices and the $3.3~V~SpartanXL^{TM}$ family of devices. - Next generation ASIC replacement technology - First ASIC replacement FPGA for high-volume production with on-chip RAM - Advanced process technology - Density up to 1862 logic cells or 40,000 system gates - Streamlined feature set based on XC4000 architecture - System performance beyond 80 MHz - Broad set of AllianceCORE<sup>™</sup> and LogiCORE<sup>™</sup> pre-defined solutions available - Unlimited reprogrammability - Low cost - · System level features - Available in both 5.0 Volt and 3.3 Volt versions - On-chip SelectRAM™ memory - Fully PCI compliant - Low power segmented routing architecture - Full readback capability for program verification and internal node observability - Dedicated high-speed carry logic - Internal 3-state bus capability - 8 global low-skew clock or signal networks - IEEE 1149.1-compatible boundary scan logic - Versatile I/O and packaging - Low cost plastic packages available in all densities - Footprint compatibility in common packages - Individually programmable output slew-rate control maximizes performance and reduces noise - Zero input register hold time simplifies system timing - Fully supported by powerful Xilinx development system - Foundation series: Integrated, shrink-wrap software - Alliance series: Over 100 PC and workstation 3<sup>RD</sup> party development systems supported - Fully automatic mapping, placement and routing - Interactive design editor for design optimization ## Additional SpartanXL Features - 3.3V supply for low power with 5V tolerant I/Os - Power down input - · Higher performance - · Faster carry logic - More flexible high-speed clock network - Latch capability in Configurable Logic Blocks - Input fast capture latch - Optional mux or 2-input function generator on outputs - 12 mA or 24 mA output drive - 5V/3.3V PCI compatible - · Enhanced Boundary Scan - · Express Mode configuration Table 1: Spartan and SpartanXL Series Field Programmable Gate Arrays | Device | Logic<br>Cells | Max<br>System<br>Gates | Typical<br>Gate Range<br>(Logic and RAM)* | CLB<br>Matrix | Total<br>CLBs | Number<br>of<br>Flip-Flops | Max.<br>Available<br>User I/O | |-----------------|----------------|------------------------|-------------------------------------------|---------------|---------------|----------------------------|-------------------------------| | XCS05 & XCS05XL | 238 | 5,000 | 2,000 - 5,000 | 10 x 10 | 100 | 360 | 77 | | XCS10 & XCS10XL | 466 | 10,000 | 3,000 - 10,000 | 14 x 14 | 196 | 616 | 112 | | XCS20 & XCS20XL | 950 | 20,000 | 7,000 - 20,000 | 20 x 20 | 400 | 1,120 | 160 | | XCS30 & XCS30XL | 1368 | 30,000 | 10,000 - 30,000 | 24 x 24 | 576 | 1,536 | 192 | | XCS40 & XCS40XL | 1862 | 40,000 | 13,000 - 40,000 | 28 x 28 | 784 | 2,016 | 205 | <sup>\*</sup> Max values of Typical Gate Range include 20-30% of CLBs used as RAM. ## **General Overview** Spartan Series FPGAs are implemented with a regular, flexible, programmable architecture of Configurable Logic Blocks (CLBs), interconnected by a powerful hierarchy of versatile routing resources (routing channels), and surrounded by a perimeter of programmable Input/Output Blocks (IOBs), as seen in Figure 1. They have generous routing resources to accommodate the most complex interconnect patterns. The devices are customized by loading configuration data into internal static memory cells. Re-programming is possible an unlimited number of times. The values stored in these memory cells determine the logic functions and interconnections implemented in the FPGA. The FPGA can either actively read its configuration data from an external serial PROM (Master Serial mode), or the configuration data can be written into the FPGA from an external device (Slave Serial mode). Spartan FPGAs can be used where hardware must be adapted to different user applications. FPGAs are ideal for shortening design and development cycles, and also offer a cost-effective solution for production rates well beyond 50,000 systems per month. Spartan Series devices achieve high-performance, low-cost operation through the use of an advanced architecture and semiconductor technology. Spartan and SpartanXL devices provide system clock rates exceeding 80 MHz and internal performance in excess of 150 MHz. In contrast to other FPGA devices, Spartan FPGAs offer the most cost-effective solution while maintaining leading-edge performance. In addition to the conventional benefit of high volume programmable logic solutions Spartan FPGAs also offer on-chip edge-triggered single-port and dual-port RAM, clock enables on all flip-flops, fast carry logic, and many other features. The Spartan Series leverages the highly successful XC4000 architecture with many of that family's features and benefits. Technology advancements have been derived from the XC4000XLA and XC4000XV process developments. Figure 1: Basic FPGA Block Diagram ## **Logic Functional Description** The Spartan Series uses a standard FPGA structure as shown in Figure 1 on page 4. The FPGA consists of an array of configurable logic blocks (CLBs) placed in a matrix of routing channels. The input and output of signals is achieved through a set of input/output blocks (IOBs) forming a ring around the CLBs and routing channels. - CLBs provide the functional elements for implementing the user's logic. - IOBs provide the interface between the package pins and internal signal lines. - Routing channels provide paths to interconnect the inputs and outputs of the CLBs and IOBs. The functionality of each circuit block is customized during configuration by programming internal static memory cells. The values stored in these memory cells determine the logic functions and interconnections implemented in the FPGA. ## **Configurable Logic Blocks (CLBs)** The CLBs are used to implement most of the logic in an FPGA. The principal CLB elements are shown in the simpli- fied block diagram in Figure 2. There are three look-up tables (LUT) which are used as logic function generators, two flip-flops and two groups of signal steering multiplexers. There are also some more advanced features provided by the CLB which will be covered in the "Advanced Features Description" on page 15. ## **Function Generators** Two 16x1 memory look-up tables (F-LUT and G-LUT) are used to implement 4-input function generators, each offering unrestricted logic implementation of any Boolean function of up to four independent input signals (F1 to F4 or G1 to G4). Using memory look-up tables the propagation delay is independent of the function implemented. A third 3-input function generator (H-LUT) can implement any Boolean function of its three inputs. Two of these inputs are controlled by programmable multiplexers (see box "A" of Figure 2). These inputs can come from the F-LUT or G-LUT outputs or from CLB inputs. The third input always comes from a CLB input. The CLB can, therefore, implement certain functions of up to nine inputs, like parity checking. The three LUTs in the CLB can also be combined to do any arbitrarily defined Boolean function of five inputs. Figure 2: Spartan Simplified CLB Logic Diagram (some features not shown) A CLB can implement any of the following functions: - Any function of up to four variables, plus any second function of up to four unrelated variables, plus any third function of up to three unrelated variables<sup>1</sup> - · Any single function of five variables - Any function of four variables together with some functions of six variables - Some functions of up to nine variables. Implementing wide functions in a single block reduces both the number of blocks required and the delay in the signal path, achieving both increased capacity and speed. The versatility of the CLB function generators significantly improves system speed. In addition, the design-software tools can deal with each function generator independently. This flexibility improves cell usage. ## Flip-Flops Each CLB contains two flip-flops that can be used to register (store) the function generator outputs. The flip-flops and function generators can also be used independently (see Figure 2 on page 5). The CLB input DIN can be used as a direct input to either of the two flip-flops. H1 can also drive either flip-flop via the H-LUT with a slight additional delay. The two flip-flops have common clock (CK), clock enable (EC) and set/reset (SR) inputs. Internally both flip-flops are also controlled by a global initialization signal (GSR) which is described in detail in "Global Signals: GSR and GTS" on page 21. ## Latches (SpartanXL only) The SpartanXL CLB storage elements can also be configured as latches. The two latches have common clock (K) and clock enable (EC) inputs. Functionality of the storage element is described in Table 2. **Table 2: CLB Storage Element Functionality** | Mode | СК | EC | SR | D | Q | |------------------------|----|----|----|---|----| | Power-Up or<br>GSR | Х | X | Х | Х | SR | | Clip Clap | Х | Х | 1 | Х | SR | | Flip-Flop<br>Operation | /_ | 1* | 0* | D | D | | Operation | 0 | Х | 0* | Х | Q | | Latch Operation | 1 | 1* | 0* | Х | Q | | (SpartanXL) | 0 | 1* | 0* | D | D | | Both | Х | 0 | 0* | Х | Q | Legend: Don't care SR Set or Reset value. Reset is default. 0\* Input is Low or unconnected (default value) 1\* Input is High or unconnected (default value) Figure 3: CLB Flip-Flop Functional Block Diagram #### **Clock Input** Each flip-flop can be triggered on either the rising or falling clock edge. The CLB clock line is shared by both flip-flops. However, the clock is individually invertible for each flip-flop (see CK path in Figure 3). Any inverter placed on the clock line in the design is automatically absorbed into the CLB. #### Clock Enable The clock enable line (EC) is active High. The EC line is shared by both flip-flops in a CLB. If either one is left disconnected, the clock enable for that flip-flop defaults to the active state. EC is not invertible within the CLB. The clock enable is synchronous to the clock and must satisfy the setup and hold timing specified for the device. #### Set/Reset The set/reset line (SR) is an asynchronous active High control of the flip-flop. SR can be configured as either set or reset at each flip-flop. This configuration option determines the state in which each flip-flop becomes operational after configuration. It also determines the effect of a GSR pulse during normal operation, and the effect of a pulse on the SR line of the CLB. The SR line is shared by both flip-flops. If SR is not specified for a flip-flop the set/reset for that flip-flop defaults to the inactive state. SR is not invertible within the CLB. <sup>1.</sup> When three separate functions are generated, one of the function outputs must be captured in a flip-flop internal to the CLB. Only two unregistered function generator outputs are available from the CLB. ## **CLB Signal Flow Control** In addition to the H-LUT input control multiplexers (shown in box "A" of Figure 2 on page 5) there are signal flow control multiplexers (shown in box "B" of Figure 2) which select the signals which drive the flip-flop inputs and the combinatorial CLB outputs (X and Y). Each flip-flop input is driven from a 4:1 multiplexer which selects among the three LUT outputs and DIN as the data source. Each combinatorial output is driven from a 2:1 multiplexer which selects between two of the LUT outputs. The X output can be driven from the F-LUT or H-LUT, the Y output from G-LUT or H-LUT. ## **Control Signals** There are four signal control multiplexers on the input of the CLB. These multiplexers allow the internal CLB control signals (H1, DIN, SR, and EC in Figure 2 and Figure 4) to be driven from any of the four general control inputs (C1 - C4 in Figure 4) into the CLB. Any of these inputs can drive any of the four internal control signals. The four internal control signals are: - · EC Enable Clock - SR Asynchronous Set/Reset or H function generator Input 0 - DIN Direct In or H function generator Input 2 - H1 H function generator Input 1. Figure 4: CLB Control Signal Interface ## Input/Output Blocks (IOBs) User-configurable input/output blocks (IOBs) provide the interface between external package pins and the internal logic. Each IOB controls one package pin and can be configured for input, output, or bidirectional signals. Figure 5 on page 8 shows a simplified functional block diagram of the Spartan IOB. ## IOB Input Signal Path The input signal to the IOB can be configured to either go directly to the routing channels (via I1 and I2 in Figure 5) or to the input register. The input register can be programmed as either an edge-triggered flip-flop or a level-sensitive latch. The functionality of this register is shown in Table 3, and a simplified block diagram of the register can be seen in Figure 6. **Table 3: Input Register Functionality** | Mode | СК | EC | D | Q | |--------------------|----|----|---|----| | Power-Up or<br>GSR | Х | Х | Х | SR | | Flip-Flop | | 1* | D | D | | | 0 | Х | Х | Q | | Latch | 1 | 1* | Х | Q | | | 0 | 1* | D | D | | Both | Х | 0 | Х | Q | Legend: X Don't care \_\_/ Rising edge (clock not inverted) SR Set or Reset value. Reset is default. 0\* Input is Low or unconnected (default value) 1\* Input is High or unconnected (default value) Figure 6: IOB Flip-Flop/Latch Functional Block Diagram The register choice is made by placing the appropriate library symbol. For example, IFD is the basic input flip-flop (rising edge triggered), and ILD is the basic input latch (transparent-High). Variations with inverted clocks are also available. The clock signal inverter is also shown in Figure 6 on the CK line. The Spartan IOB data input path has a one-tap delay element: either the delay is inserted (default), or it is not. The SpartanXL IOB data input path has a two-tap delay element, with choices of a full delay, a partial delay, or no delay. The added delay guarantees a zero hold time with respect to clocks routed through the Spartan global clock buffers. (See "Global Nets and Buffers" on page 14 for a description of the global clock buffers in the Spartan Series.) For a shorter input register setup time, with positive hold-time, attach a NODELAY attribute or property to the flip-flop. The output of the input register goes to the routing channels (via I1 and I2 in Figure 5). The I1 and I2 signals that exit the IOB can each carry either the direct or registered input signal. The 5V Spartan input buffers can be globally configured for either TTL (1.2 V) or CMOS (Vcc/2) thresholds, using an option in the bitstream generation software. The Spartan output levels are also configurable; the two global adjustments of input threshold and output level are independent. The inputs of Spartan devices can be driven by the outputs of any 3.3 V device, if the Spartan inputs are in TTL mode. There is a slight input hysteresis of about 300 mV. SpartanXL inputs are TTL compatible and 3.3 V CMOS compatible. Supported sources for Spartan Series device inputs are shown in Table 4. SpartanXL I/Os are fully 5V tolerant even though the VCC is 3.3 Volts. This allows 5V signals to directly connect to the SpartanXL inputs without damage, as shown in Table 4. In addition, the 3.3 Volt VCC can be applied before or after 5V signals are applied to the I/Os. This makes the SpartanXL devices immune to power supply sequencing problems. Figure 5: Simplified Spartan IOB Block Diagram **Table 4: Supported Sources for Spartan Series Inputs** | | | rtan<br>uts | SpartanXL<br>Inputs | |-----------------------------------------------------|---------------|-------------------------|---------------------| | Source | 5.0 V,<br>TTL | 5.0 V,<br>CMOS | 3.3 V<br>CMOS | | Any device, Vcc = 3.3 V,<br>CMOS outputs | 1 | llmus!: | √ | | Spartan Series, Vcc = 5 V,<br>TTL outputs | 1 | Unreli-<br>able<br>Data | √ | | Any device, Vcc = 5 V,<br>TTL outputs (Voh ≤ 3.7 V) | 1 | Data | √ | | Any device, Vcc = 5 V,<br>CMOS outputs | 1 | <b>√</b> | √ (default<br>mode) | #### SpartanXL VCC Clamping SpartanXL FPGAs have an optional clamping diode connected from each I/O to VCC. When enabled they clamp ringing transients back to the 3.3 V supply rail. This clamping action is required in 3.3 V PCI applications. VCC clamping is a global option affecting all I/O pins. SpartanXL devices are fully 5V TTL I/O compatible if VCC clamping is not enabled. With VCC clamping enabled, the SpartanXL devices will begin to clamp input voltages to one diode voltage drop above VCC. If enabled, TTL I/O compatibility is maintained but full 5V I/O tolerance is sacrificed. The user may select either 5V tolerance (default) or 3.3 V PCI compatibility. In both cases negative voltage is clamped to one diode voltage drop below ground. SpartanXL devices are compatible with TTL, LVTTL, PCI 3V, PCI 5V and LVCMOS signalling. The various standards are illustrated in Table 5. Table 5: I/O Standards Supported by SpartanXL FPGAs | Signaling<br>Standard | VCC<br>Clamping | Output Drive | V <sub>IH MAX</sub> | V <sub>IH MIN</sub> | V <sub>IL MAX</sub> | V <sub>OH MIN</sub> | V <sub>OL MAX</sub> | |-----------------------|-----------------|------------------|---------------------|---------------------|---------------------|---------------------|---------------------| | TTL | Not allowed | 12/24 m <b>A</b> | 5.5 | 2.0 | 0.8 | 2.4 | 0.4 | | LVTTL | OK | 12/24 m <b>A</b> | 3.6 | 2.0 | 8.0 | 2.4 | 0.4 | | PCI5V | Not allowed | 24 m <b>A</b> | 5.5 | 2.0 | 0.8 | 2.4 | 0.4 | | PCI3V | Required | 12 mA | 3.6 | 50% of VCC | 30% of VCC | 90% of VCC | 10% of VCC | | LVCMOS 3V | OK | 12/24 m <b>A</b> | 3.6 | 50% of VCC | 30% of VCC | 90% of VCC | 10% of VCC | ## Additional Fast Capture Input Latch (SpartanXL only) The SpartanXL IOB has an additional optional latch on the input. This latch is clocked by the clock used for the output flip-flop rather than the input clock. Therefore, two different clocks can be used to clock the two input storage elements. This additional latch allows the fast capture of input data, which is then synchronized to the internal clock by the IOB flip-flop or latch. To place the Fast Capture latch in a design, use one of the special library symbols, ILFFX or ILFLX. ILFFX is a transparent-Low Fast Capture latch followed by an active-High input flip-flop. ILFLX is a transparent-Low Fast Capture latch followed by a Transparent-High input latch. Any of the clock inputs can be inverted before driving the library element, and the inverter is absorbed into the IOB. ## IOB Output Signal Path Output signals can be optionally inverted within the IOB, and can pass directly to the output buffer or be stored in an edge-triggered flip-flop and then to the output buffer. The functionality of this flip-flop is shown in Table 6. Table 6: Output Flip-Flop Functionality | | | Clock | | | | |--------------------|-------|--------|----|---|----| | Mode | Clock | Enable | Т | D | Q | | Power-Up<br>or GSR | Х | Х | 0* | Х | SR | | | Х | 0 | 0* | Х | Q | | Flip-Flop | /_ | 1* | 0* | D | D | | ' ' | Х | Χ | 1 | Х | Z | | | 0 | Х | 0* | Х | Q | Leaend: X Don't care \_\_/ Rising edge (clock not inverted) SR Set or Reset value. Reset is default. 0\* Input is Low or unconnected (default value) 1\* Input is High or unconnected (default value) Z 3-state ## Output Multiplexer/2-Input Function Generator (SpartanXL only) The output path in the SpartanXL IOB contains an additional multiplexer not available in the Spartan IOB. The multiplexer can also be configured as a 2-input function generator, implementing a pass gate, AND gate, OR gate, or XOR gate, with 0, 1, or 2 inverted inputs. When configured as a multiplexer, this feature allows two output signals to time-share the same output pad; effectively doubling the number of device outputs without requiring a larger, more expensive package. The select input is the pin used for the output flip-flop clock, OK. When the multiplexer is configured as a 2-input function generator, logic can be implemented within the IOB itself. Combined with a Global buffer, this arrangement allows very high-speed gating of a single signal. For example, a wide decoder can be implemented in CLBs, and its output gated with a Read or Write Strobe Driven by a Global buffer. The user can specify that the IOB function generator be used by placing special library symbols beginning with the letter "O." For example, a 2-input AND gate in the IOB function generator is called OAND2. Use the symbol input pin labelled "F" for the signal on the critical path. This signal is placed on the OK pin — the IOB input with the shortest delay to the function generator. Two examples are shown in Figure 7. Figure 7: AND & MUX Symbols in SpartanXL IOB Output Buffer An active-High 3-state signal can be used to place the output buffer in a high-impedance state, implementing 3-state outputs or bidirectional I/O. Under configuration control, the output (O) and output 3-state (T) signals can be inverted. The polarity of these signals is independently configured for each IOB (see Figure 5 on page 8). By default, a 5V Spartan device output buffer pull-up structure is configured as a TTL-like totem-pole. The High driver is an n-channel pull-up transistor, pulling to a voltage one transistor threshold below Vcc. Alternatively, the outputs can be globally configured as CMOS drivers, with additional p-channel pull-up transistors pulling to Vcc. This option, applied using the bitstream generation software, applies to all outputs on the device. It is not individually programmable. All SpartanXL device outputs are configured as CMOS drivers, therefore driving rail-to-rail. The SpartanXL outputs are individually programmable for 12 mA or 24 mA output drive. Any 5V Spartan device with its outputs configured in TTL mode can drive the inputs of any typical 3.3 V device. (For a detailed discussion of how to interface between 5.0 V and 3.3 V devices, see the 3V Products section of *The Programmable Logic Data Book.*) Supported destinations for Spartan Series device outputs are shown in Table 7. ## **Output Slew Rate** The slew rate of each output buffer is, by default, reduced, to minimize power bus transients when switching non-critical signals. For critical signals, attach a FAST attribute or property to the output buffer or flip-flop. Table 7: Supported Destinations for Spartan Series Outputs | | SpartanXL<br>Outputs | | rtan<br>puts | |------------------------------------------------|----------------------|---------------|-------------------| | Destination | 3.3 V,<br>CMOS | 5.0 V,<br>TTL | 5.0 V,<br>CMOS | | Any device, Vcc = 3.3 V, CMOS-threshold inputs | 1 | <b>√</b> | Some <sup>1</sup> | | Any device, Vcc = 5.0 V, TTL-threshold inputs | 1 | 1 | √ | | Any device, Vcc = 5.0 V, CMOS-threshold inputs | | | √ | 1. Only if destination device has 5-V tolerant inputs Spartan Series devices have a feature called "Soft Start-up," designed to reduce ground bounce when all outputs are turned on simultaneously at the end of configuration. When the configuration process is finished and the device starts up, the first activation of the outputs is automatically slew-rate limited. Immediately following the initial activation of the I/O, the slew rate of the individual outputs is determined by the individual configuration option for each IOB. ## Pull-up and Pull-down Network Programmable pull-up and pull-down resistors are used for tying unused pins to Vcc or Ground to minimize power consumption and reduce noise sensitivity. The configurable pull-up resistor is a p-channel transistor that pulls to Vcc. The configurable pull-down resistor is an n-channel transistor that pulls to Ground. The value of these resistors is typically 20 k $\Omega-100$ k $\Omega$ (See "Spartan DC Characteristics Over Operating Conditions" on page 39.). This high value makes them unsuitable as wired-AND pull-up resistors. After configuration, voltage levels of unused pads, bonded or unbonded, must be valid logic levels, to reduce noise sensitivity and avoid excess current. Therefore, by default, unused pads are configured with the internal pull-up resistor active. Alternatively, they can be individually configured with the pull-down resistor, or as a driven output, or to be driven by an external source. To activate the internal pull-up, attach the PULLUP library component to the net attached to the pad. To activate the internal pull-down, attach the PULLDOWN library component to the net attached to the pad. #### Set/Reset As with the CLB registers, the GSR signal can be used to set or clear the input and output registers, depending on the value of the INIT attribute or property. The two flip-flops can be individually configured to set or clear on reset and after configuration. Other than the global GSR net, no user-controlled set/reset signal is available to the I/O flip-flops (Figure 6). The choice of set or reset applies to both the initial state of the flip-flop and the response to the GSR pulse. ## **Independent Clocks** Separate clock signals are provided for the input (IK) and output (OK) flip-flops. The clock can be independently inverted for each flip-flop within the IOB, generating either falling-edge or rising-edge triggered flip-flops. The clock inputs for each IOB are independent. ## **Common Clock Enables** The input and output flip-flops in each IOB have a common clock enable input (see EC signal in Figure 6), which through configuration, can be activated individually for the input or output flip-flop, or both. This clock enable operates exactly like the EC signal on the Spartan Series CLB. It cannot be inverted within the IOB. ## Three-State Register (SpartanXL Only) SpartanXL devices incorporate an optional register controlling the three-state enable in the IOBs. The use of the three-state control register can significantly improve output enable and disable time. ## **Routing Channel Description** All internal routing channels are composed of metal segments with programmable switching points and switching matrices to implement the desired routing. A structured, hierarchical matrix of routing channels is provided to achieve efficient automated routing. This section describes the routing channels available in Spartan Series devices. Figure 8 shows a general block diagram of the CLB routing channels. The implementation software automatically assigns the appropriate resources based on the density and timing requirements of the design. The following description of the routing channels is for information only and is simplified with some minor details omitted. For an exact interconnect description the designer should open a design in the EPIC design editor and review the actual connections in this tool. The routing channels will be discussed as follows; - CLB routing channels which run along each row and column of the CLB array. - IOB routing channels which form a ring (called a VersaRing) around the outside of the CLB array. It connects the I/O with the CLB routing channels. - Global routing consists of dedicated networks primarily designed to distribute clocks throughout the device with minimum delay and skew. Global routing can also be used for other high-fanout signals. Figure 8: Spartan Series CLB Routing Channels and Interface Block Diagram ## **CLB Routing Channels** The routing channels around the CLB are derived from three types of interconnects; single-length, double-length, and longlines. At the intersection of each vertical and horizontal routing channel is a signal steering matrix called a Programmable Switch Matrix (PSM). Figure 8 shows the basic routing channel configuration showing single-length lines, double-length lines and longlines as well as the CLBs and PSMs. The CLB to routing channel interface is shown as well as how the PSMs interface at the channel intersections. #### **CLB Interface** A block diagram of the CLB interface signals is shown in Figure 9. The input signals to the CLB are distributed evenly on all four sides providing maximum routing flexibility. In general, the entire architecture is symmetrical and regular. It is well suited to established placement and routing algorithms. Inputs, outputs, and function generators can freely swap positions within a CLB to avoid routing congestion during the placement and routing operation. The exceptions are the clock (K) input and CIN/COUT signals. The K input is routed to dedicated global vertical lines as well as 4 single-length lines and is on the left side of the CLB. The CIN/COUT signals are routed through dedicated interconnects which do not interfere with the general routing structure. The output signals from the CLB are available to drive both vertical and horizontal channels. ## **Programmable Switch Matrices** The horizontal and vertical single- and double-length lines intersect at a box called a programmable switch matrix (PSM). Each PSM consists of programmable pass transistors used to establish connections between the lines (see Figure 10). Figure 9: CLB Interconnect Signals For example, a single-length signal entering on the right side of the switch matrix can be routed to a single-length line on the top, left, or bottom sides, or any combination thereof, if multiple branches are required. Similarly, a double-length signal can be routed to a double-length line on any or all of the other three edges of the programmable switch matrix. #### **Single-Length Lines** Single-length lines provide the greatest interconnect flexibility and offer fast routing between adjacent blocks. There are eight vertical and eight horizontal single-length lines associated with each CLB. These lines connect the switching matrices that are located in every row and column of CLBs. Figure 10: Programmable Switch Matrix Single-length lines are connected by way of the programmable switch matrices, as shown in Figure 10. Routing connectivity is shown in Figure 8. Single-length lines incur a delay whenever they go through a PSM. Therefore, they are not suitable for routing signals for long distances. They are normally used to conduct signals within a localized area and to provide the branching for nets with fanout greater than one. #### **Double-Length Lines** The double-length lines consist of a grid of metal segments, each twice as long as the single-length lines: they run past two CLBs before entering a PSM. Double-length lines are grouped in pairs with the PSMs staggered, so that each line goes through a PSM at every other row or column of CLBs (see Figure 8). There are four vertical and four horizontal double-length lines associated with each CLB. These lines provide faster signal routing over intermediate distances, while retaining routing flexibility. ## Longlines Longlines form a grid of metal interconnect segments that run the entire length or width of the array. Longlines are intended for high fan-out, time-critical signal nets, or nets that are distributed over long distances. Each Spartan Series longline has a programmable splitter switch at its center. This switch can separate the line into two independent routing channels, each running half the width or height of the array. Routing connectivity of the longlines is shown in Figure 8. The longlines also interface to some 3-state buffers which is described later in "3-State Long Line Drivers" on page 20. ## I/O Routing Spartan Series devices have additional routing around the IOB ring. This routing is called a VersaRing. The VersaRing facilitates pin-swapping and redesign without affecting board layout. Included are eight double-length lines, and four longlines. ## **Global Nets and Buffers** The Spartan Series devices have dedicated global networks. These networks are designed to distribute clocks and other high fanout control signals throughout the devices with minimal skew. Four vertical longlines in each CLB column are driven exclusively by special global buffers. These longlines are in addition to the vertical longlines used for standard interconnect. In the 5V Spartan devices, the four global lines can be driven by either of two types of global buffers; Primary Global buffers (BUFGP) or Secondary Global buffers (BUFGS). Each of these lines can be accessed by one particular Primary Global buffer, or by any of the Secondary Global buffers, as shown in Figure 11. In the 3V SpartanXL devices, the four global lines can be driven by any of the eight Global Low-Skew Buffers (BUFGLS). The clock pins of every CLB and IOB can also be sourced from local interconnect. Figure 11: 5V Spartan Series Global Net Distribution The four Primary Global buffers offer the shortest delay and negligible skew. Four Secondary Global buffers have slightly longer delay and slightly more skew due to potentially heavier loading, but offer greater flexibility when used to drive non-clock CLB inputs. The eight Global Low-Skew buffers in the SpartanXL devices combine short delay, negligible skew, and flexibility. The Primary Global buffers must be driven by the semi-dedicated pads (PGCK1-4). The Secondary Global buffers can be sourced by either semi-dedicated pads (SGCK1-4) or internal nets. Each corner of the device has one Primary buffer and one Secondary buffer. The SpartanXL family has eight global low-skew buffers, two in each corner. All can be sourced by either semi-dedicated pads (GCK1-8) or internal nets. Using the library symbol called BUFG results in the software choosing the appropriate clock buffer, based on the timing requirements of the design. A global buffer should be specified for all timing-sensitive global signal distribution. To use a global buffer, place a BUFGP (primary buffer), BUFGS (secondary buffer), BUFGLS (SpartanXL global low-skew buffer), or BUFG (any buffer type) element in a schematic or in HDL code. # Advanced Features Description Distributed RAM Optional modes for each CLB allow the function generators (F-LUT and G-LUT) to be used as Random Access Memory (RAM). Read and write operations are significantly faster for this on-chip RAM than for off-chip implementations. This speed advantage is due to the relatively short signal propagation delays within the FPGA. ## **Memory Configuration Overview** There are two available memory configuration modes: single-port RAM and dual-port RAM. For both these modes, write operations are synchronous (edge-triggered), while read operations are asynchronous. In the Single-Port Mode, a single CLB can be configured as either a 16 x 1, (16 x 1) x 2 or 32 x 1 RAM array. In the Dual-Port mode, a single CLB can be configured only as one 16 x 1 RAM array. The different CLB memory configurations are summarized in Table 8. Any of these possibilities can be individually programmed into a Spartan Series CLB. - The 16 x 1 Single-Port configuration contains a RAM array with 16 locations, each one-bit wide. One 4-bit address decoder determines the RAM location for write and read operations. There is one input for writing data and one output for reading data, all at the selected address. - The (16 x 1) x 2 Single-Port configuration combines two 16 x 1 Single Port configurations (each according to the - preceding description). There is one data input, one data output and one address decoder for each array. These arrays can be addressed independently. - The 32 x 1 Single-Port configuration contains a RAM array with 32 locations, each one-bit wide. There is one data input, one data output, and one 5-bit address decoder. - The Dual-Port mode 16 x 1 configuration contains a RAM array with 16 locations, each one-bit wide. There are two 4-bit address decoders, one for each port. One port consists of an input for writing and an output for reading, all at a selected address. The other port consists of one output for reading from an independently selected address. **Table 8: CLB Memory Configurations** | Mode | 16 x 1 | (16 x 1) x 2 | 32 x 1 | |-------------|--------|--------------|--------| | Single-Port | √ | √ | √ | | Dual-Port | √ | | | The appropriate choice of RAM configuration mode for a given design should be based on timing and resource requirements, desired functionality, and the simplicity of the design process. Selection criteria include the following: Whereas the 32 x 1 Single-Port, the (16 x 1) x 2 Single-Port and the 16 x 1 Dual-Port configurations each use one entire CLB, the 16 x 1 Single-Port configuration uses only one half of a CLB. Due to its simultaneous read/write capability, the Dual-Port RAM can transfer twice as much data as the Single-Port RAM, which permits only one data operation at any given time. CLB memory configuration options are selected by using the appropriate library symbol in the design entry. ## Single-Port Mode There are three CLB memory configurations for the Single-Port RAM: 16 x 1, (16 x 1) x 2, and 32 x 1, the functional organization of which is shown in Figure 12. The Single-Port RAM signals and the CLB signals (Figure 2 on page 5) from which they are originally derived are shown in Table 9. Table 9: Single-Port RAM Signals | RAM Signal | Function | CLB Signal | |------------------------------|-------------------------------|------------------------------------------------------------------| | D | Data In | DIN or H <sub>1</sub> | | A[3:0] | Address | F <sub>1</sub> -F <sub>4</sub> or G <sub>1</sub> -G <sub>4</sub> | | A <sub>4</sub> (32 x 1 only) | Address | H <sub>1</sub> | | WE | Write Enable | SR | | WCLK | Clock | K | | SPO | Single Port Out<br>(Data Out) | F <sub>OUT</sub> or G <sub>OUT</sub> | Figure 12: Logic Diagram for the Single-Port RAM NOTE: 1. The (16 x 1) x 2 configuration combines two 16 x 1 Single Port RAMs, each with its own independent address bus and data input. The same WE and WCLK signals are connected to both RAMs. 2. n = 4 for the 16 x 1 and (16 x 1) x 2 configurations. n = 5 for the 32 x 1 configuration. Writing data to the Single-Port RAM is essentially the same as writing to a data register. It is an edge-triggered (synchronous) operation performed by applying an address to the A inputs and data to the D input during the active edge of WCLK while WE is High. The timing relationships are shown in Figure 13. The High logic level on WE enables the input data register for writing. The active edge of WCLK latches the address, input data, and WE signals. Then, an internal write pulse is generated that loads the data into the memory cell. Figure 13: Data Write and Access Timing for RAM WCLK can be configured as active on either the rising edge (default) or the falling edge. While the WCLK input to the RAM accepts the same signal as the clock input to the associated CLB's flip-flops, the sense of this WCLK input can be inverted with respect to the sense of the flip-flop clock inputs. Consequently, within the same CLB, data at the RAM's SPO line can be stored in a flip-flop with either the same or the inverse clock polarity used to write data to the RAM. The WE input is active-High and cannot be inverted within the CLB. Allowing for settling time, the data on the SPO output reflects the contents of the RAM location currently addressed. When the address changes, following the asynchronous delay $T_{ILO}$ , the data stored at the new address location will appear on SPO. If the data at a particular RAM address is overwritten, after the delay $T_{WOS}$ , the new data will appear on SPO. ### **Dual-Port Mode** In dual-port mode, the function generators (F-LUT and G-LUT) are used to create a 16 x 1 Dual-Port memory. Of the two data ports available, one permits read and write operations at the address specified by A[3:0] while the second provides only for read operations at the address specified independently by DPRA[3:0]. As a result, simultaneous read/write operations at different addresses (or even at the same address) are supported. The functional organization of the 16 $\times$ 1 Dual-Port RAM is shown in Figure 14. Figure 14: Logic Diagram for the Dual-Port RAM The Dual-Port RAM signals and the CLB signals from which they are originally derived are shown in Table 10. Table 10: Dual-Port RAM Signals | RAM Signal | Function | CLB<br>Signal | |------------|-------------------------------|--------------------------------| | D | Data In | DIN | | A[3:0] | Read Address for Single-Port. | F <sub>1</sub> -F <sub>4</sub> | | | Write Address for Single-Port | | | | and Dual-Port. | | | DPRA[3:0] | Read Address for Dual-Port | G <sub>1</sub> -G <sub>4</sub> | | WE | Write Enable | SR | | WCLK | Clock | K | | SPO | Single Port Out | Fout | | | (addressed by A[3:0]) | | | DPO | Dual Port Out | G <sub>OUT</sub> | | | (addressed by DPRA[3:0]) | | The RAM16X1D primitive used to instantiate the Dual-Port RAM consists of an upper and a lower 16 x 1 memory array. The address port labeled A[3:0] supplies both the read and write addresses for the lower memory array, which behaves the same as the 16 x 1 Single-Port RAM array described previously. Single Port Out (SPO) serves as the data output for the lower memory. Therefore, SPO reflects the data at address A[3:0]. The other address port, labeled DPRA[3:0] for Dual Port Read Address, supplies the read address for the upper memory. The write address for this memory, however, comes from the address A[3:0]. Dual Port Out (DPO) serves as the data output for the upper memory. Therefore, DPO reflects the data at address DPRA[3:0]. By using A[3:0] for the write address and DPRA[3:0] for the read address, and reading only the DPO output, a FIFO that can read and write simultaneously is easily generated. The simultaneous read/write capability possible with the Dual-Port RAM can provide twice the effective data throughput of a Single-Port RAM alternating read and write operations. The timing relationships for the Dual-Port RAM mode are shown in Figure 13. Note that write operations to RAM are synchronous (edge-triggered); however, data access is asynchronous. ## Initializing RAM at FPGA Configuration Both RAM and ROM implementations of the Spartan Series are initialized during device configuration. The initial contents are defined via an INIT attribute or property attached to the RAM or ROM symbol, as described in the schematic library guide. If not defined, all RAM contents are initialized to zeros, by default. RAM initialization occurs only during device configuration. The RAM content is not affected by GSR. #### More Information on using RAM inside CLBs Three application notes are available from Xilinx that discuss synchronous (edge-triggered) RAM: "Xilinx Edge-Triggered and Dual-Port RAM Capability," "Implementing FIFOs in Xilinx RAM," and "Synchronous and Asynchronous FIFO Designs." All three application notes apply to both the Spartan and the SpartanXL Series. ## **Fast Carry Logic** Each CLB F-LUT and G-LUT contains dedicated arithmetic logic for the fast generation of carry and borrow signals. This extra output is passed on to the function generator in the adjacent CLB. The carry chain is independent of normal routing resources. (See Figure 15.) Dedicated fast carry logic greatly increases the efficiency and performance of adders, subtractors, accumulators, comparators and counters. It also opens the door to many new applications involving arithmetic operation, where the previous generations of FPGAs were not fast enough or too inefficient. High-speed address offset calculations in microprocessor or graphics systems, and high-speed addition in digital signal processing are two typical applications. The two 4-input function generators can be configured as a 2-bit adder with built-in hidden carry that can be expanded to any length. This dedicated carry circuitry is so fast and efficient that conventional speed-up methods like carry generate/propagate are meaningless even at the 16-bit level, and of marginal benefit at the 32-bit level. This fast carry logic is one of the more significant features of the Spartan Series, speeding up arithmetic and counting functions. Figure 15: Available Spartan Carry Propagation Paths The carry chain in Spartan devices can run either up or down. At the top and bottom of the columns where there are no CLBs above and below, the carry is propagated to the right. The default is always to propagate up the column, as shown in the figures. The carry chain in SpartanXL devices can only run up the column, providing even higher speed. Figure 16 on page 19 shows a Spartan Series CLB with dedicated fast carry logic. The carry logic shares operand and control inputs with the function generators. The carry outputs connect to the function generators, where they are combined with the operands to form the sums. Figure 17 on page 20 shows the details of the Spartan carry logic. This diagram shows the contents of the box labeled "CARRY LOGIC" in Figure 16. The fast carry logic can be accessed by placing special library symbols, or by using Xilinx Relationally Placed Macros (RPMs) that already include these symbols. Figure 16: Fast Carry Logic in Spartan CLB Figure 17: Detail of Spartan Dedicated Carry Logic ## **3-State Long Line Drivers** A pair of 3-state buffers is associated with each CLB in the array. These 3-state buffers (BUFT) can be used to drive signals onto the nearest horizontal longlines above and below the CLB. They can therefore be used to implement multiplexed or bidirectional buses on the horizontal longlines, saving logic resources. There is a weak keeper at each end of these two horizontal longlines. This circuit prevents undefined floating levels. However, it is overridden by any driver. The buffer enable is an active-High 3-state (i.e. an active-Low enable), as shown in Table 11. ## Three-State Buffer Example Figure 18 shows how to use the 3-state buffers to implement a multiplexer. The selection is accomplished by the buffer 3-state signal. Pay particular attention to the polarity of the T pin when using these buffers in a design. Active-High 3-state (T) is identical to an active-Low output enable, as shown in Table 11. Table 11: Three-State Buffer Functionality | IN | Т | OUT | |----|---|-----| | X | 1 | Z | | IN | 0 | IN | Figure 18: 3-State Buffers Implement a Multiplexer ## **On-Chip Oscillator** Spartan Series devices include an internal oscillator. This oscillator is used to clock the power-on time-out, for configuration memory clearing, and as the source of CCLK in Master configuration mode. The oscillator runs at a nominal 8 MHz frequency that varies with process, Vcc, and temperature. The output frequency falls between 4 MHz and 10 MHz. The oscillator output is optionally available after configuration. Any two of four resynchronized taps of a built-in divider are also available. These taps are at the fourth, ninth, fourteenth and nineteenth bits of the divider. Therefore, if the primary oscillator output is running at the nominal 8 MHz, the user has access to an 8 MHz clock, plus any two of 500 kHz, 16 kHz, 490 Hz and 15 Hz. These frequencies can vary by as much as -50% or +25%. These signals can be accessed by placing the OSC library element in a schematic or in HDL code. The oscillator is automatically disabled after configuration if the OSC symbol is not used in the design. ## Global Signals: GSR and GTS ## Global Set/Reset A separate Global Set/Reset line, as shown in Figure 3 on page 6 for the CLB and Figure 6 on page 7 for the IOB, sets or clears each flip-flop during power-up, reconfiguration, or when a dedicated Reset net is driven active. This global net (GSR) does not compete with other routing resources; it uses a dedicated distribution network. Each flip-flop is configured as either globally set or reset in the same way that the local set/reset (SR) is specified. Therefore, if a flip-flop is set by SR, it is also set by GSR. Similarly, if in reset mode, it is reset by both SR and GSR. GSR can be driven from any user-programmable pin as a global reset input. To use this global net, place an input pad and input buffer in the schematic or HDL code, driving the GSR pin of the STARTUP symbol. (See Figure 19.) A specific pin location can be assigned to this input using a LOC attribute or property, just as with any other user-programmable pad. An inverter can optionally be inserted after the input buffer to invert the sense of the GSR signal. Alternatively, GSR can be driven from any internal node. Figure 19: Schematic Symbols for Global Set/Reset #### Global 3-State A separate Global 3-State line (GTS) as shown in Figure 5 on page 8 forces all FPGA outputs to the high-impedance state, unless boundary scan is enabled and is executing an EXTEST instruction. GTS does not compete with other routing resources; it uses a dedicated distribution network. GTS can be driven from any user-programmable pin as a global 3-state input. To use this global net, place an input pad and input buffer in the schematic or HDL code, driving the GTS pin of the STARTUP symbol. This is similar to what is shown in Figure 19 for GSR except the IBUF would be connected to GTS. A specific pin location can be assigned to this input using a LOC attribute or property, just as with any other user-programmable pad. An inverter can optionally be inserted after the input buffer to invert the sense of the Global 3-State signal. Alternatively, GTS can be driven from any internal node. ## **Boundary Scan** The 'bed of nails' has been the traditional method of testing electronic assemblies. This approach has become less appropriate, due to closer pin spacing and more sophisticated assembly methods like surface-mount technology and multi-layer boards. The IEEE Boundary Scan Standard 1149.1 was developed to facilitate board-level testing of electronic assemblies. Design and test engineers can imbed a standard test logic structure in their device to achieve high fault coverage for I/O and internal logic. This structure is easily implemented with a four-pin interface on any boundary scan-compatible IC. IEEE 1149.1-compatible devices may be serial daisy-chained together, connected in parallel, or a combination of the two. The Spartan Series implements IEEE 1149.1-compatible BYPASS, PRELOAD/SAMPLE and EXTEST boundary scan instructions. When the boundary scan configuration option is selected, three normal user I/O pins become dedicated inputs for these functions. Another user output pin becomes the dedicated boundary scan output. The details of how to enable this circuitry are covered later in this section. By exercising these input signals, the user can serially load commands and data into these devices to control the driving of their outputs and to examine their inputs. This method is an improvement over bed-of-nails testing. It avoids the need to over-drive device outputs, and it reduces the user interface to four pins. An optional fifth pin, a reset for the control logic, is described in the standard but is not implemented in Xilinx devices. The dedicated on-chip logic implementing the IEEE 1149.1 functions includes a 16-state machine, an instruction register and a number of data registers. The functional details can be found in the IEEE 1149.1 specification and are also discussed in the Xilinx application note: "Boundary Scan in FPGA Devices." Figure 20 is a diagram of the Spartan Series boundary scan logic. It includes three bits of Data Register per IOB, the IEEE 1149.1 Test Access Port controller, and the Instruction Register with decodes. Spartan Series devices can also be configured through the boundary scan logic. See "Configuration Through the Boundary Scan Pins" on page 34. ## Data Registers The primary data register is the boundary scan register. For each IOB pin in the FPGA, bonded or not, it includes three bits for In, Out and 3-State Control. Non-IOB pins have appropriate partial bit population for In or Out only. PROGRAM, CCLK and DONE are not included in the boundary scan register. Each EXTEST CAPTURE-DR state captures all In, Out, and 3-state pins. The data register also includes the following non-pin bits: TDO.T, and TDO.O, which are always bits 0 and 1 of the data register, respectively, and BSCANT.UPD, which is always the last bit of the data register. These three boundary scan bits are special-purpose Xilinx test signals. The other standard data register is the single flip-flop BYPASS register. It synchronizes data being passed through the FPGA to the next downstream boundary scan device. The FPGA provides two additional data registers that can be specified using the BSCAN macro. The FPGA provides two user pins (BSCAN.SEL1 and BSCAN.SEL2) which are the decodes of two user instructions. For these instructions, two corresponding pins (BSCAN.TDO1 and BSCAN.TDO2) allow user scan data to be shifted out on TDO. The data register clock (BSCAN.DRCK) is available for control of test logic which the user may wish to implement with CLBs. The NAND of TCK and RUN-TEST-IDLE is also provided (BSCAN.IDLE). ## Instruction Set The Spartan Series boundary scan instruction set also includes instructions to configure the device and read back the configuration data. The instruction set is coded as shown in Table 12. Figure 20: Spartan Series Boundary Scan Logic **Table 12: Boundary Scan Instructions** | Ins | truct | ion | Test | TDO Source | I/O Data | |-----|-------|-----|--------------------|-----------------|------------| | 12 | l1 | 10 | Selected | 1DO Source | Source | | 0 | 0 | 0 | EXTEST | DR | DR | | 0 | 0 | 1 | SAMPLE/PR<br>ELOAD | DR | Pin/Logic | | 0 | 1 | 0 | USER 1 | BSCAN.<br>TDO1 | User Logic | | 0 | 1 | 1 | USER 2 | BSCAN.<br>TDO2 | User Logic | | 1 | 0 | 0 | READBACK | Readback Data | Pin/Logic | | 1 | 0 | 1 | CONFIGURE | DOUT | Disabled | | 1 | 1 | 0 | Reserved | _ | _ | | 1 | 1 | 1 | BYPASS | Bypass Register | _ | ### Bit Seauence The bit sequence within each IOB is: In, Out, 3-State. The input-only pins contribute only the In bit to the boundary scan I/O data register, while the output-only pins contributes all three bits. The first two bits in the I/O data register are TDO.T and TDO.O, which can be used for the capture of internal signals. The final bit is BSCANT.UPD, which can be used to drive an internal net. These locations are primarily used by Xilinx for internal testing. From a cavity-up view of the chip (as shown in EPIC), starting in the upper right chip corner, the boundary scan data-register bits are ordered as shown in Figure 21. The device-specific pinout tables for the Spartan Series include the boundary scan locations for each IOB pin. Figure 21: Boundary Scan Bit Sequence BSDL (Boundary Scan Description Language) files for Spartan Series devices are available on the Xilinx web site in the File Download area. Note that the 5V Spartan devices and 3V SpartanXL devices have different BSDL files. ## Including Boundary Scan in a Design If boundary scan is only to be used during configuration, no special schematic elements need be included in the schematic or HDL code. In this case, the special boundary scan pins TDI, TMS, TCK and TDO can be used for user functions after configuration. To indicate that boundary scan remain enabled after configuration, place the BSCAN library symbol and connect the TDI, TMS, TCK and TDO pad symbols to the appropriate pins, as shown in Figure 22. Even if the boundary scan symbol is used in a schematic, the input pins TMS, TCK, and TDI can still be used as inputs to be routed to internal logic. Care must be taken not to force the chip into an undesired boundary scan state by inadvertently applying boundary scan input patterns to these pins. The simplest way to prevent this is to keep TMS High, and then apply whatever signal is desired to TDI and TCK. ## **Avoiding Inadvertent Boundary Scan** If TMS or TCK is used as user I/O, care must be taken to ensure that at least one of these pins is held constant during configuration. In some applications, a situation may occur where TMS or TCK is driven during configuration. This may cause the device to go into boundary scan mode and disrupt the configuration process. To prevent activation of boundary scan during configuration, do either of the following: - TMS: Tie High to put the Test Access Port controller in a benign RESET state - TCK: Tie High or Low-do not toggle this clock input. For more information regarding boundary scan, refer to the Xilinx Application Note, "Boundary Scan in FPGA Devices." Figure 22: Boundary Scan Schematic Example ## Boundary Scan Enhancements (SpartanXL only) SpartanXL devices have improved boundary scan functionality and performance in the following areas: IDCODE: The IDCODE register is now supported. By using the IDCODE, the device connected to the JTAG port can be determined. The use of the IDCODE enables selective configuration dependent on the FPGA found. The IDCODE register has the following binary format: vvvv:ffff:fffa:aaaa:aaaa:cccc:cccc1 #### where c = the company code (49h for Xilinx) a = the array dimension in CLBs (ranges from 0Ah for XCS05XL to 1Ch for XCS40XL) f = the family code (02h for SpartanXL family) v = the die version number (currently 0h) Table 13: IDCODEs Assigned to SpartanXL FPGAs | FPGA | IDCODE | |---------|--------------------| | XCS05XL | 0040 <b>A</b> 093h | | XCS10XL | 0040E093h | | XCS20XL | 00414093h | | XCS30XL | 00418093h | | XCS40XL | 0041C093h | Configuration State: The configuration state is available to JTAG controllers. Configuration Disable: The JTAG port can be prevented from configuring the FPGA. TCK Startup: TCK can now be used to clock the start-up block in addition to other user clocks CCLK Holdoff: Changed the requirement for Boundary Scan Configure or EXTEST to be issued prior to the release of INIT pin and CCLK cycling. Reissue Configure: The Boundary Scan Configure can be reissued to recover from an unfinished attempt to configure the device. Bypass FF: Bypass FF and IOB is modified to provide DRCLOCK only during BYPASS for the bypass flip-flop, and during EXTEST or SAMPLE/PRELOAD for the IOB register. ## Power Down (SpartanXL Only) All Spartan Series devices use a combination of efficient segmented routing and advanced process technology to provide low power consumption under all conditions. The 3.3V SpartanXL family adds a dedicated active-Low Power Down pin ( $\overline{PWRDWN}$ ) to reduce supply current to 100 $\mu A$ typical. The $\overline{PWRDWN}$ pin takes advantage of one of the unused Don't Connect locations on the 5V Spartan. The user must de-select the "5V Tolerant I/Os" option in the Configuration Options to achieve the specified Power Down current. The $\overline{PWRDWN}$ pin has a default internal pull-up resistor, allowing it to be left unconnected if unused. VCC must continue to be supplied during Power Down, and configuration data is maintained. When the PWRDWN pin is pulled Low, the input and output buffers are disabled. The inputs are internally forced to a logic Low level, including the MODE pins, DONE, CCLK, and TDO, and all internal pull-up resistors are turned off. The PROGRAM pin is not affected by Power Down. The GSR net is asserted during Power Down, initializing all the flip-flops to their start-up state. PWRDWN has a minimum pulse width of 50 ns. On entering the Power Down state, the inputs will be disabled and the flip-flops set/reset, and then the outputs are disabled about 10 ns later. The user may prefer to assert the GTS or GSR signals before PWRDWN to affect the order of events. When the PWRDWN signal is returned High, the inputs will be enabled first, followed immediately by the release of the GSR signal initializing the flip-flops. About 10 ns later, the outputs will be enabled. Allow 50 ns after the release of PWRDWN before using the device. Power Down retains the configuration, but loses all data stored in the device. All inputs are interpreted as Low, but the internal combinatorial logic is fully functional. Make sure that the combination of all inputs Low and all flip-flops set or reset in your design will not generate internal oscillations, or create permanent bus contention by activating internal bus drivers with conflicting data onto the same long line. During configuration, the PWRDWN pin must be High. If the Power Down state is entered before or during configuration, the device will re-start configuration once the PWRDWN signal is removed. Note that the configuration pins are affected by Power Down and may not reflect their normal function. If there is an external pull-up resistor on the DONE pin, it will be High during Power Down even if the device is not yet configured. Similarly, if PWRDWN is asserted before configuration is completed, the INIT pin will not indicate status information. Note that the PWRDWN pin is not part of the Boundary Scan chain. Therefore, the SpartanXL family has a separate set of BSDL files than the 5V Spartan family. Boundary scan logic is not usable during Power Down. ## **Configuration and Test** Configuration is the process of loading design-specific programming data into one or more FPGAs to define the functional operation of the internal blocks and their interconnections. This is somewhat like loading the command registers of a programmable peripheral chip. Spartan Series devices use several hundred bits of configuration data per CLB and its associated interconnects. Each configuration bit defines the state of a static memory cell that controls either a function look-up table bit, a multiplexer input, or an interconnect pass transistor. The Xilinx development system translates the design into a netlist file. It automatically partitions, places and routes the logic and generates the configuration data in PROM format. ## **Configuration Mode Control** 5V Spartan Series devices have two configuration modes. - MODE = 1 sets Slave Serial mode - MODE = 0 sets Master Serial mode 3V SpartanXL Series devices have three configuration modes. - M1/M0 = 11 sets Slave Serial mode - M1/M0 = 10 sets Master Serial mode - M1/M0 = 0X sets Express mode In addition to these modes, the device can be configured through the Boundary Scan logic (See "Configuration Through the Boundary Scan Pins" on page 34.). The Mode pins are sampled prior to starting configuration to determine the configuration mode. After configuration, these pin are unused. The Mode pins have a weak pull-up resistor of 20 k $\Omega$ to 100 k $\Omega$ turned on during configuration. With the Mode pins High, Slave Serial mode is selected, which is the most popular configuration mode. Therefore, for the most common configuration mode, the Mode pins can be left unconnected. If the Master Serial mode is desired, the MODE/M0 pin should be connected directly to GND, or through a pull-down resistor of 1 K $\Omega$ or less. During configuration, some of the I/O pins are used temporarily for the configuration process. All pins used during configuration are shown in Table 14 and Table 15. Table 14: Pin Functions During Configuration (Spartan only) | CONFIGURA<br><mode< th=""><th></th><th></th></mode<> | | | |------------------------------------------------------|---------------------------------|-------------------| | SLAVE<br>SERIAL<br><high></high> | MASTER<br>SERIAL<br><low></low> | USER<br>OPERATION | | MODE (I) | MODE (I) | MODE | | HDC (HIGH) | HDC (HIGH) | I/O | | LDC (LOW) | LDC (LOW) | I/O | | ĪNIT | ĪNIT | I/O | | DONE | DONE | DONE | | PROGRAM (I) | PROGRAM (I) | PROGRAM | | CCLK (I) | CCLK (O) | CCLK (I) | | DIN (I) | DIN (I) | I/O | | DOUT | DOUT | SGCK4-I/O | | TDI | TDI | TDI-I/O | | TCK | TCK | TCK-I/O | | TMS | TMS | TMS-I/O | | TDO | TDO | TDO-(O) | | | | ALL OTHERS | Notes - A shaded table cell represents the internal pull-up used before and during configuration. - 2. (I) represents an input; (O) represents an output. - 3. INIT is an open-drain output during configuration. Table 15: Pin Functions During Configuration (SpartanXL only) | CONFIGU | JRATION MODE | <m1:m0></m1:m0> | | |--------------------------|---------------------------|------------------|-------------------| | SLAVE<br>SERIAL<br><1:1> | MASTER<br>SERIAL<br><1:0> | EXPRESS<br><0:X> | USER<br>OPERATION | | M1(HIGH) (I) | M1(HIGH) (I) | M1(LOW) (I) | M1 | | M0(HIGH) (I) | M0(LOW) (I) | M0 (I) | M0 | | HDC (HIGH) | HDC (HIGH) | HDC (HIGH) | 1/0 | | LDC (LOW) | LDC (LOW) | LDC (LOW) | 1/0 | | ĪNIT | ĪNIT | ĪNIT | 1/0 | | DONE | DONE | DONE | DONE | | PROGRAM (I) | PROGRAM (I) | PROGRAM (I) | PROGRAM | | CCLK (I) | CCLK (O) | CCLK (I) | CCLK (I) | | | | DATA 7 (I) | 1/0 | | | | DATA 6 (I) | 1/0 | | | | DATA 5 (I) | 1/0 | | | | DATA 4 (I) | 1/0 | | | | DATA 3 (I) | 1/0 | | | | DATA 2 (I) | 1/0 | | | | DATA 1 (I) | 1/0 | | DIN (I) | DIN (I) | DATA 0 (I) | 1/0 | | DOUT | DOUT | DOUT | SGCK4-I/O | | TDI | TDI | TDI | TDI-I/O | | TCK | TCK | TCK | TCK-I/O | | TMS | TMS | TMS | TMS-I/O | | TDO | TDO | TDO | TDO-(O) | | | | CS1 | 1/0 | | | | | ALL OTHERS | Notes - A shaded table cell represents the internal pull-up used before and during configuration. - 2. (I) represents an input; (O) represents an output. - 3. INIT is an open-drain output during configuration. ## **Master Serial Mode** The Master serial mode uses an internal oscillator to generate a Configuration Clock (CCLK) for driving potential slave devices and the Xilinx serial-configuration PROM (SPROM). The CCLK speed is selectable as either 1 MHz (default) or 8 MHz. Configuration always starts at the default slow frequency, then can switch to the higher frequency during the first frame. Frequency tolerance is -50% to +25%. In Master Serial mode, the CCLK output of the device drives a Xilinx SPROM that feeds the FPGA DIN input. Each rising edge of the CCLK output increments the Serial PROM internal address counter. The next data bit is put on the SPROM data output, connected to the FPGA DIN pin. The FPGA accepts this data on the subsequent rising CCLK edge. When used in a daisy-chain configuration the Master Serial FPGA is placed as the first device in the chain and is referred to as the lead FPGA. The lead FPGA presents the preamble data, and all data that overflows the lead device, on its DOUT pin. There is an internal pipeline delay of 1.5 CCLK periods, which means that DOUT changes on the falling CCLK edge, and the next FPGA in the daisy chain accepts data on the subsequent rising CCLK edge. See the timing diagram in Figure 23. In the bitstream generation software, the user can specify Fast Configuration Rate, which, starting several bits into the first frame, increases the CCLK frequency by a factor of eight. For actual timing values please refer to the specification section. Be sure that the serial PROM and slaves are fast enough to support this data rate. Devices such as XC3000A and XC3100A do not support the Fast Configuration Rate option. The SPROM CE input can be driven from either \(\overline{LDC}\) or DONE. Using \(\overline{LDC}\) avoids potential contention on the DIN pin, if this pin is configured as user-I/O, but \(\overline{LDC}\) is then restricted to be a permanently High user output after configuration. Using DONE can also avoid contention on DIN, provided the early DONE option is invoked. Figure 24 shows a full master/slave system. The leftmost device is in Master Serial mode, all other devices in the chain are in Slave Serial mode. | | Description | Symbol | | Min | Max | Units | |------|-------------|--------|-------------------|-----|-----|-------| | | DIN setup | 1 | T <sub>DSCK</sub> | 20 | | ns | | CCLK | DIN hold | 2 | T <sub>CKDS</sub> | 0 | | ns | Notes: 1. At power-up, Vcc must rise from 2.0 V to Vcc min in less than 25 ms, otherwise delay configuration by pulling PROGRAM Low until Vcc is valid. 2. Master Serial mode timing is based on testing in slave mode. Figure 23: Master Serial Mode Programming Switching Characteristics #### Slave Serial Mode In Slave Serial mode, the FPGA receives serial configuration data on the rising edge of CCLK and, after loading its configuration, passes additional data out, resynchronized on the next falling edge of CCLK. In this mode, an external signal drives the CCLK input of the FPGA (most often from a Master Serial device). The serial configuration bitstream must be available at the DIN input of the lead FPGA a short setup time before each rising CCLK edge. The lead FPGA then presents the preamble data—and all data that overflows the lead device—on its DOUT pin. There is an internal delay of 0.5 CCLK periods, which means that DOUT changes on the falling CCLK edge, and the next FPGA in the daisy chain accepts data on the subsequent rising CCLK edge. Figure 24 shows a full master/slave system. A Spartan Series device in Slave Serial mode should be connected as shown in the third device from the left. Slave Serial is the default mode if the Mode pins are left unconnected, as they have weak pull-up resistors during configuration. Multiple slave devices with identical configurations can be wired with parallel DIN inputs. In this way, multiple devices can be configured simultaneously. ## **Serial Daisy Chain** Multiple devices with different configurations can be connected together in a "daisy chain," and a single combined bitstream used to configure the chain of slave devices. To configure a daisy chain of devices, wire the CCLK pins of all devices in parallel, as shown in Figure 24. Connect the DOUT of each device to the DIN of the next. The lead or master FPGA and following slaves each passes resynchronized configuration data coming from a single source. The header data, including the length count, is passed through and is captured by each FPGA when it recognizes the 0010 preamble. Following the length-count data, each FPGA outputs a High on DOUT until it has received its required number of data frames. After an FPGA has received its configuration data, it passes on any additional frame start bits and configuration data on DOUT. When the total number of configuration clocks applied after memory initialization equals the value of the 24-bit length count, the FPGAs begin the start-up sequence and become operational together. FPGA I/O are normally released two CCLK cycles after the last configuration bit is received. The daisy-chained bitstream is not simply a concatenation of the individual bitstreams. The PROM file formatter must be used to combine the bitstreams for a daisy-chained configuration. Figure 24: Master/Slave Serial Mode Circuit Diagram | | Description | Symbol | | Min | Max | Units | |------|-------------|--------|------------------|-----|-----|-------| | | DIN setup | 1 | T <sub>DCC</sub> | 20 | | ns | | | DIN hold | 2 | T <sub>CCD</sub> | 0 | | ns | | CCLK | DIN to DOUT | 3 | T <sub>CCO</sub> | | 30 | ns | | COLK | High time | 4 | T <sub>CCH</sub> | 45 | | ns | | | Low time | 5 | T <sub>CCL</sub> | 45 | | ns | | | Frequency | | F <sub>CC</sub> | | 10 | MHz | Note: Configuration must be delayed until the INIT pins of all daisy-chained FPGAs are High. Figure 25: Slave Serial Mode Programming Switching Characteristics ## **Express Mode (SpartanXL only)** Express mode is similar to Slave Serial mode, except that data is processed one byte per CCLK cycle instead of one bit per CCLK cycle. An external source is used to drive CCLK, while byte-wide data is loaded directly into the configuration data shift registers (Figure 26). A CCLK frequency of 1 MHz is equivalent to a 8 MHz serial rate, because eight bits of configuration data are loaded per CCLK cycle. Express mode does not support CRC error checking, but does support constant-field error checking. A length count is not used in Express mode. Express mode must be specified as an option to the BitGen program, which generates the bitstream. The Express mode bitstream is not compatible with the other configuration modes. (See Table 16 on page 31.) Express mode is selected by a <0X> on the mode pins (M1, M0). The first byte of parallel configuration data must be available at the D inputs of the FPGA a short setup time before the second rising CCLK edge. Subsequent data bytes are clocked in on each consecutive rising CCLK edge (Figure 27). ## Pseudo Daisy Chain Multiple devices with different configurations can be configured in a pseudo daisy chain provided that all of the devices are in Express mode. A single combined bitstream is used to configure the chain of Express mode devices. CCLK pins are tied together and D0-D7 pins are tied together for all devices along the chain. A status signal is passed from DOUT to CS1 of successive devices along the chain. Frame data is accepted only when CS1 is High and the device's configuration memory is not already full. The lead device in the chain has its CS1 input tied High (or floating, since there is an internal pullup). The status pin DOUT is pulled Low after the header is received by all devices, and remains Low until the device's configuration memory is full. DOUT is then pulled High to signal the next device in the chain to accept the configuration data on the D0-D7 bus. The DONE pins of all devices in the chain should be tied together, with one or more active internal pull-ups. If a large number of devices are included in the chain, deactivate some of the internal pull-ups, since the Low-driving DONE pin of the last device in the chain must sink the current from all pull-ups in the chain. The DONE pull-up is activated by default. It can be deactivated using a BitGen option. The requirement that all DONE pins in a daisy chain be wired together applies only to Express mode, and only if all devices in the chain are to become active simultaneously. All SpartanXL devices in Express mode are synchronized to the DONE pin. User I/Os for each device become active after the DONE pin for that device goes High. (The exact timing is determined by BitGen options.) Since the DONE pin is open-drain and does not drive a High value, tying the DONE pins of all devices together prevents all devices in the chain from going High until the last device in the chain has completed its configuration cycle. If the DONE pin of a device is left unconnected, the device becomes active as soon as that device has been configured. Because only SpartanXL, XC4000XLA/XV, and XC5200 devices support Express mode, only these devices can be used to form an Express mode daisy chain. Figure 26: Express Mode Circuit Diagram X6611\_b | | Description | | Symbol | Min | Max | Units | |------|------------------------|---|------------------|-----|-----|-------| | | INIT (High) setup time | 1 | T <sub>IC</sub> | 5 | | μs | | | D0 - D7 setup time | 2 | T <sub>DC</sub> | 20 | | ns | | CCLK | D0 - D7 hold time | 3 | T <sub>CD</sub> | 0 | | ns | | COLK | CCLK High time | | Тссн | 45 | | ns | | | CCLK Low time | | T <sub>CCL</sub> | 45 | | ns | | | CCLK Frequency | | F <sub>CC</sub> | | 10 | MHz | Note: If not driven by the preceding DOUT, CS1 must remain High until the device is fully configured. Figure 27: Express Mode Programming Switching Characteristics ## **Setting CCLK Frequency** In Master mode, CCLK can be generated in either of two frequencies. In the default slow mode, the frequency ranges from 0.5 MHz to 1.25 MHz for Spartan Series devices. In fast CCLK mode, the frequency ranges from 4 MHz to 10 MHz for Spartan Series devices. The frequency is changed to fast by an option when running the bitstream generation software. ## **Data Stream Format** The data stream ("bitstream") format is identical for both serial configuration modes, but different for the SpartanXL Express mode. In Express mode, the device becomes active when DONE goes High, therefore no length count is required. Additionally, CRC error checking is not supported in Express mode. The data stream format is shown in Table 16. Bit-serial data is read from left to right. Express mode data is shown with D0 at the left and D7 at the right. The configuration data stream begins with a string of eight ones, a preamble code, followed by a 24-bit length count and a separator field of ones (or 24 fill bits, in SpartanXL Express mode). This header is followed by the actual configuration data in frames. The length and number of frames depends on the device type (see Table 17). Each frame begins with a start field and ends with an error check. In serial modes, a postamble code is required to signal the end of data for a single device. In all cases, additional start-up bytes of data are required to provide four clocks for the startup sequence at the end of configuration. Long daisy chains require additional startup bytes to shift the last data through the chain. All startup bytes are don't-cares. **Table 16: Spartan Series Data Stream Formats** | Data Type | Serial Modes<br>(D0) | Express Mode<br>(D0-D7)<br>(SpartanXL only) | | | |--------------------------------|------------------------|---------------------------------------------|--|--| | Fill Byte | 11111111b | FFFFh | | | | Preamble Code | 0010b | 11110010b | | | | Length Count | COUNT(23:0) | COUNT(23:0) <sup>1</sup> | | | | Fill Bits | 1111b | _ | | | | Field Check Code | _ | 11010010b | | | | Start Field | 0b | 11111110b | | | | Data Frame | DATA(n-1:0) | DATA(n-1:0) | | | | CRC or Constant<br>Field Check | xxxx (CRC)<br>or 0110b | 11010010b | | | | Extend Write Cycle | | FFFFFFFFh | | | | Postamble | 01111111b | _ | | | | Start-Up Bytes | FFh | FFFFFFFFFFFF | | | #### LEGEND: | Unshaded | Once per bitstream | |----------|---------------------| | Light | Once per data frame | | Dark | Once per device | Note 1: Not used by configuration logic. Note 2: Development system may add more start-up bytes. A selection of CRC or non-CRC error checking is allowed by the bitstream generation software. The SpartanXL Express mode only supports non-CRC error checking. The non-CRC error checking tests for a designated end-of-frame field for each frame. For CRC error checking, the software calculates a running CRC and inserts a unique four-bit partial check at the end of each frame. The 11-bit CRC check of the last frame of an FPGA includes the last seven data bits. Detection of an error results in the suspension of data loading before DONE goes High, and the pulling down of the $\overline{\text{INIT}}$ pin. In Master serial mode, CCLK continues to operate externally. The user must detect $\overline{\text{INIT}}$ and initialize a new configuration by pulsing the $\overline{\text{PROGRAM}}$ pin Low or cycling Vcc. ## Cyclic Redundancy Check (CRC) for Configuration and Readback The Cyclic Redundancy Check is a method of error detection in data transmission applications. Generally, the transmitting system performs a calculation on the serial bitstream. The result of this calculation is tagged onto the data stream as additional check bits. The receiving system performs an identical calculation on the bitstream and compares the result with the received checksum. Each data frame of the configuration bitstream has four error bits at the end, as shown in Table 16. If a frame data error is detected during the loading of the FPGA, the configuration process with a potentially corrupted bitstream is terminated. The FPGA pulls the $\overline{\text{INIT}}$ pin Low and goes into a Wait state. **Table 17: Spartan Program Data** | Device | ХС | S05 | XC | S10 | XC | S20 | XCS30 | | XCS40 | | |----------------|--------|---------|--------|---------|---------|---------|-----------|---------|-----------|---------| | Max System | 5,0 | 000 | 10,000 | | 20,000 | | 30,000 | | 40,000 | | | Gates | | | | | | | | | | | | CLBs | 1 | 00 | 19 | 96 | 400 | | 5 | 76 | 784 | | | (Row x Col.) | (10 | x 10) | (14) | x 14) | (20 : | x 20) | (24 x 24) | | (28 x 28) | | | IOBs | 8 | 0 | 1 | 12 | 16 | 30 | 19 | 92 | 224 | | | Part Number | XCS05 | XCS05XL | XCS10 | XCS10XL | XCS20 | XCS20XL | XCS30 | XCS30XL | XCS40 | XCS40XL | | Supply Voltage | 5 V | 3.3 V | 5 V | 3.3 V | 5 V | 3.3 V | 5 V | 3.3 V | 5 V | 3.3 V | | Bits per Frame | 126 | 127 | 166 | 167 | 226 | 227 | 266 | 267 | 306 | 307 | | Frames | 428 | 429 | 572 | 573 | 788 | 789 | 932 | 933 | 1,076 | 1,077 | | Program Data | 53,936 | 54,491 | 94,960 | 95,699 | 178,096 | 179,111 | 247,920 | 249,119 | 329,264 | 330,647 | | PROM Size | 53,984 | 54,536 | 95,008 | 95,744 | 178,144 | 179,160 | 247,968 | 249,168 | 329,312 | 330,696 | | (bits) | | | | | | | | | | | | Serial PROM | 17S05 | 17S05XL | 17S10 | 17S10XL | 17S20 | 17S20XL | 17S30 | 17S30XL | 17S40 | 17S40XL | | Express Mode | | 79,040 | | 128,456 | | 221,024 | | 298,664 | | 387,824 | | PROM Size | | | | | | | | | | | | (bits) | | | | | | | | | | | Notes: 1.Bits per Frame = (10 x number of rows) + 7 for the top + 13 for the bottom + 1 + 1 start bit + 4 error check bits (+ 1 for SpartanXL device) Number of Frames = (36 x number of columns) + 26 for the left edge + 41 for the right edge + 1 (+ 1 for SpartanXL device) Program Data = (Bits per Frame x Number of Frames) + 8 postamble bits PROM Size = Program Data + 40 (header) + 8, rounded up to the nearest byte 3. Express mode adds 57 (XCS05XL, XCS10XL), or 53 (XCS20XL, XCS30XL, XCS40XL) bits per frame. During Readback, 11 bits of the 16-bit checksum are added to the end of the Readback data stream. The checksum is computed using the CRC-16 CCITT polynomial, as shown in Figure 28. The checksum consists of the 11 most significant bits of the 16-bit code. A change in the checksum indicates a change in the Readback bitstream. A comparison to a previous checksum is meaningful only if the readback data is independent of the current device state. CLB outputs should not be included (Readback Capture option not used), and if RAM is present, the RAM content must be unchanged. Statistically, one error out of 2048 might go undetected. ## **Configuration Sequence** There are four major steps in the Spartan Series power-up configuration sequence. - Configuration Memory Clear - Initialization - Configuration - Start-Up The full process is illustrated in Figure 29. ## Configuration Memory Clear When power is first applied or is reapplied to an FPGA, an internal circuit forces initialization of the configuration logic. When Vcc reaches an operational level, and the circuit passes the write and read test of a sample pair of configuration bits, a time delay is started. This time delay is nominally 16 ms. The delay is four times as long when in Master Serial Mode to allow ample time for all slaves to reach a stable Vcc. When all $\overline{\text{INIT}}$ pins are tied together, as recommended, the longest delay takes precedence. Therefore, devices with different time delays can easily be mixed and matched in a daisy chain. This delay is applied only on power-up. It is not applied when reconfiguring an FPGA by pulsing the PROGRAM pin Figure 28: Circuit for Generating CRC-16 <sup>2.</sup>The user can add more "one" bits as leading dummy bits in the header, or, if CRC = off, as trailing dummy bits at the end of any frame, following the four error check bits. However, the Length Count value **must** be adjusted for all such extra "one" bits, even for extra leading ones at the beginning of the header. Figure 29: Power-up Configuration Sequence Low. During this time delay, or as long as the PROGRAM input is asserted, the configuration logic is held in a Configuration Memory Clear state. The configuration-memory frames are consecutively initialized, using the internal oscillator. At the end of each complete pass through the frame addressing, the power-on time-out delay circuitry and the level of the $\overline{PROGRAM}$ pin are tested. If neither is asserted, the logic initiates one additional clearing of the configuration frames and then tests the $\overline{INIT}$ input. #### Initialization During initialization and configuration, user pins HDC, $\overline{\text{LDC}}$ , $\overline{\text{INIT}}$ and DONE provide status outputs for the system interface. The outputs $\overline{\text{LDC}}$ , $\overline{\text{INIT}}$ and DONE are held Low and HDC is held High starting at the initial application of power. The open drain $\overline{\text{INIT}}$ pin is released after the final initialization pass through the frame addresses. There is a deliberate delay before a Master-mode device recognizes an inactive $\overline{\text{INIT}}$ . Two internal clocks after the $\overline{\text{INIT}}$ pin is recognized as High, the device samples the MODE pin to determine the configuration mode. The appropriate interface lines become active and the configuration preamble and data can be loaded. ## Configuration The 0010 preamble code indicates that the following 24 bits represent the length count for serial modes. The length count is the total number of configuration clocks needed to load the complete configuration data. (Four additional configuration clocks are required to complete the configuration process, as discussed below.) After the preamble and the length count have been passed through to any device in the daisy chain, its DOUT is held High to prevent frame start bits from reaching any daisy-chained devices. In SpartanXL Express mode, the length count bits are ignored, and DOUT is held Low, to disable the next device in the pseudo daisy chain. A specific configuration bit, early in the first frame of a master device, controls the configuration-clock rate and can increase it by a factor of eight. Therefore, if a fast configuration clock is selected by the bitstream, the slower clock rate is used until this configuration bit is detected. Each frame has a start field followed by the frame-configuration data bits and a frame error field. If a frame data error is detected, the FPGA halts loading, and signals the error by pulling the open-drain $\overline{\text{INIT}}$ pin Low. After all configuration frames have been loaded into an FPGA using a serial mode, DOUT again follows the input data so that the remaining data is passed on to the next device. In SpartanXL Express mode, when the first device is fully programmed, DOUT goes High to enable the next device in the chain. ## Delaying Configuration After Power-Up There are two methods of delaying configuration after power-up: put a logic Low on the PROGRAM input, or pull the bidirectional INIT pin Low, using an open-collector (open-drain) driver. (See Figure 29 on page 33.) A Low on the $\overline{PROGRAM}$ input is the more radical approach, and is recommended when the power-supply rise time is excessive or poorly defined. As long as $\overline{PROGRAM}$ is Low, the FPGA keeps clearing its configuration memory. When $\overline{PROGRAM}$ goes High, the configuration memory is cleared one more time, followed by the beginning of configuration, provided the $\overline{INIT}$ input is not externally held Low. Note that a Low on the $\overline{PROGRAM}$ input automatically forces a Low on the $\overline{INIT}$ output. The Spartan Series $\overline{PROGRAM}$ pin has a permanent weak pull-up. Using an open-collector or open-drain driver to hold $\overline{\text{INIT}}$ Low before the beginning of configuration causes the FPGA to wait after completing the configuration memory clear operation. When $\overline{\text{INIT}}$ is no longer held Low externally, the device determines its configuration mode by capturing the state of the MODE pin, and is ready to start the configuration process. A master device waits up to an additional 300 $\mu s$ to make sure that any slaves in the optional daisy chain have seen that $\overline{\text{INIT}}$ is High. ## Configuration Through the Boundary Scan Pins Spartan Series devices can be configured through the boundary scan pins. The basic procedure is as follows: - Power up the FPGA with INIT held Low (or drive the PROGRAM pin Low for more than 300 ns followed by a High while holding INIT Low). Holding INIT Low allows enough time to issue the CONFIG command to the FPGA. The pin can be used as I/O after configuration if a resistor is used to hold INIT Low. - Issue the CONFIG command to the TMS input - Wait for INIT to go High - Sequence the boundary scan Test Access Port to the SHIFT-DR state - Toggle TCK to clock data into TDI pin. The user must account for all TCK clock cycles after INIT goes High, as all of these cycles affect the Length Count compare. For more detailed information, refer to the Xilinx application note, "Boundary Scan in FPGA Devices." This application note applies to Spartan and SpartanXL devices. Figure 30: Readback Schematic Example #### Readback The user can read back the content of configuration memory and the level of certain internal nodes without interfering with the normal operation of the device. Readback not only reports the downloaded configuration bits, but can also include the present state of the device, represented by the content of all flip-flops and latches in CLBs and IOBs, as well as the content of function generators used as RAMs. Readback of SpartanXL Express mode bitstreams results in data that does not resemble the original bitstream, because the bitstream format differs from other modes. Spartan Series Readback does not use any dedicated pins, but uses four internal nets (RDBK.TRIG, RDBK.DATA, RDBK.RIP and RDBK.CLK) that can be routed to any IOB. To access the internal Readback signals, place the READ-BACK library symbol and attach the appropriate pad symbols, as shown in Figure 30. After Readback has been initiated by a Low-to-High transition on RDBK.TRIG, the RDBK.RIP (Read In Progress) output goes High on the next rising edge of RDBK.CLK. Subsequent rising edges of this clock shift out Readback data on the RDBK.DATA net. Readback data does not include the preamble, but starts with five dummy bits (all High) followed by the Start bit (Low) of the first frame. The first two data bits of the first frame are always High. Each frame ends with four error check bits. They are read back as High. The last seven bits of the last frame are also read back as High. An additional Start bit (Low) and an 11-bit Cyclic Redundancy Check (CRC) signature follow, before RDBK.RIP returns Low. ## Readback Options Readback options are: Readback Capture, Readback Abort, and Clock Select. They are set with the bitstream generation software. #### Readback Capture When the Readback Capture option is selected, the readback data stream includes sampled values of CLB and IOB signals. The rising edge of RDBK.TRIG latches the inverted values of the four CLB outputs, the IOB output flip-flops and the input signals I1 and I2. Note that while the bits describing configuration (interconnect, function generators, and RAM content) are *not* inverted, the CLB and IOB output signals *are* inverted. RDBK.TRIG is located in the lower-left corner of the device. When the Readback Capture option is not selected, the values of the capture bits reflect the configuration data originally written to those memory locations. If the RAM capability of the CLBs is used, RAM data are available in readback, since they directly overwrite the F and G function-table configuration of the CLB. #### Readback Abort When the Readback Abort option is selected, a High-to-Low transition on RDBK.TRIG terminates the readback operation and prepares the logic to accept another trigger. After an aborted readback, additional clocks (up to one readback clock per configuration frame) may be required to re-initialize the control logic. The status of readback is indicated by the output control net RDBK.RIP. RDBK.RIP is High whenever a readback is in progress. #### **Clock Select** CCLK is the default clock. However, the user can insert another clock on RDBK.CLK. Readback control and data are clocked on rising edges of RDBK.CLK. If readback must be inhibited for security reasons, the readback control nets are simply not connected. RDBK.CLK is located in the lower right chip corner. ## Violating the Maximum High and Low Time Specification for the Readback Clock The readback clock has a maximum High and Low time specification. In some cases, this specification cannot be met. For example, if a processor is controlling readback, an interrupt may force it to stop in the middle of a readback. This necessitates stopping the clock, and thus violating the specification. The specification is mandatory only on clocking data at the end of a frame prior to the next start bit. The transfer mechanism will load the data to a shift register during the last six clock cycles of the frame, prior to the start bit of the following frame. This loading process is dynamic, and is the source of the maximum High and Low time requirements. Therefore, the specification only applies to the six clock cycles prior to and including any start bit, including the clocks before the first start bit in the readback data stream. At other times, the frame data is already in the register and the register is not dynamic. Thus, it can be shifted out just like a regular shift register. The user must precisely calculate the location of the readback data relative to the frame. The system must keep track of the position within a data frame, and disable interrupts before frame boundaries. Frame lengths and data formats are listed in Table 16 and Table 17. #### Readback with the XChecker Cable The XChecker Universal Download/Readback Cable and Logic Probe uses the readback feature for bitstream verification. It can also display selected internal signals on the computer screen, acting as a low-cost in-circuit emulator. ## Spartan Program Readback Switching Characteristic Guidelines Testing of the switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are not measured directly. They are derived from benchmark timing patterns that are taken at device introduction, prior to any process improvements. The following guidelines reflect worst-case values over the recommended operating conditions. ## Spartan and SpartanXL Readback | | Description | | Symbol | Min | Max | Units | |-----------|------------------------------------------------|---|-------------------|-----|-----|-------| | rdbk.TRIG | rdbk.TRIG setup to initiate and abort Readback | 1 | T <sub>RTRC</sub> | 200 | - | ns | | | rdbk.TRIG hold to initiate and abort Readback | 2 | T <sub>RCRT</sub> | 50 | - | ns | | rdclk.1 | rdbk.DATA delay | 7 | T <sub>RCRD</sub> | = | 250 | ns | | | rdbk.RIP delay | 6 | T <sub>RCRR</sub> | - | 250 | ns | | | High time | 5 | T <sub>RCH</sub> | 250 | 500 | ns | | | Low time | 4 | T <sub>RCL</sub> | 250 | 500 | ns | Note 1: Timing parameters apply to all speed grades. Note 2: If rdbk.TRIG is High prior to Finished, Finished will trigger the first Readback. ## **Configuration Switching Characteristics** ## **Master Mode** | Description | Symbol | Min | Max | Units | |----------------------------|-------------------|-----|------|----------------------| | Power-On Reset | T <sub>POR</sub> | 40 | 130 | ms | | Program Latency | T <sub>Pl</sub> | 30 | 200 | μs per<br>CLB column | | CCLK (output) Delay | T <sub>ICCK</sub> | 40 | 250 | μs | | CCLK (output) Period, slow | T <sub>CCLK</sub> | 640 | 2000 | ns | | CCLK (output) Period, fast | T <sub>CCLK</sub> | 80 | 250 | ns | ## **Slave Mode** | Description | Symbol | Min | Max | Units | |--------------------------------|-------------------|-----|-----|----------------------| | Power-On Reset | T <sub>POR</sub> | 10 | 33 | ms | | Program Latency | T <sub>PI</sub> | 30 | 200 | μs per<br>CLB column | | CCLK (input) Delay (required) | T <sub>ICCK</sub> | 4 | | μs | | CCLK (input) Period (required) | T <sub>CCLK</sub> | 100 | | ns | ## **Spartan Detailed Specifications** ## **Definition of Terms** In the following tables, some specifications may be designated as Advance or Preliminary. These terms are defined as follows: Advance: Initial estimates based on simulation and/or extrapolation from other speed grades, devices, or families. Values are subject to change. Use as estimates, not for production. **Preliminary:** Based on preliminary characterization. Further changes are not expected. **Unmarked:** Specifications not identified as either Advance or Preliminary are to be considered Final. Notwithstanding the definition of the above terms, all specifications are subject to change without notice. Except for pin-to-pin input and output parameters, the a.c. parameter delay specifications included in this document are derived from measuring internal test patterns. All specifications are representative of worst-case supply voltage and junction temperature conditions. The parameters included are common to popular designs and typical applications. ## Spartan Absolute Maximum Ratings<sup>1</sup> | Symbol | Description | | Value | Units | |------------------|----------------------------------------------------------|------------------------------|------------------------------|-------| | V <sub>CC</sub> | Supply voltage relative to GND | -0.5 to +7.0 | V | | | V <sub>IN</sub> | Input voltage relative to GND (Note 2, 3) | -0.5 to V <sub>CC</sub> +0.5 | V | | | V <sub>TS</sub> | Voltage applied to 3-state output (Note 2, 3) | | -0.5 to V <sub>CC</sub> +0.5 | V | | T <sub>STG</sub> | Storage temperature (ambient) | -65 to +150 | °C | | | T <sub>SOL</sub> | Maximum soldering temperature (10 s @ 1/16 in. = 1.5 mm) | | +260 | °C | | TJ | Junction temperature | Plastic packages | +125 | °C | Note 1: Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time may affect device reliability. ## **Spartan Recommended Operating Conditions** | Symbol | Description | | | Max | Units | |-----------------|------------------------------------------------------------------|-------------|------|-----------------|-----------------| | $V_{CC}$ | Supply voltage relative to GND, T <sub>J</sub> = 0°C to +85°C | Commercial | 4.75 | 5.25 | V | | | Supply voltage relative to GND, T <sub>J</sub> = -40°C to +100°C | Industrial | 4.5 | 5.5 | V | | V <sub>IH</sub> | High-level input voltage | TTL inputs | 2.0 | V <sub>CC</sub> | V | | | | CMOS inputs | 70% | 100% | V <sub>CC</sub> | | $V_{IL}$ | Low-level input voltage | TTL inputs | 0 | 0.8 | V | | | | CMOS inputs | 0 | 20% | V <sub>CC</sub> | | T <sub>IN</sub> | Input signal transition time | | | 250 | ns | Note 1: At junction temperatures above those listed as Recommended Operating Conditions, all delay parameters increase by 0.35% per °C. Note 2: Input and output Measurement thresholds are: 1.5 V for TTL and 2.5 V for CMOS. <sup>2:</sup> Maximum DC overshoot (above V<sub>CC</sub>) or undershoot (below GND) must be limited to either 0.5 V or 10 mA, whichever is easier to achieve. <sup>3:</sup> Maximum AC (during transitions) conditions are as follows; the device pins may undershoot to -2.0 V or overshoot to + 7.0 V, provided this overshoot or undershoot lasts no more than 11 ns with a forcing current no greater than 100 mA. #### **Spartan DC Characteristics Over Operating Conditions** | Symbol | Description | | Min | Max | Units | |------------------|---------------------------------------------------------------------------|--------------|---------------------------------------------------------------|------|-------| | V <sub>OH</sub> | High-level output voltage @ I <sub>OH</sub> = -4.0mA, V <sub>CC</sub> min | TTL outputs | 2.4 | | V | | | High-level output voltage @ I <sub>OH</sub> = -1.0mA, V <sub>CC</sub> min | CMOS outputs | V <sub>CC</sub> -0.5 | | V | | V <sub>OL</sub> | Low-level output voltage @ I <sub>OL</sub> = 12.0mA, V <sub>CC</sub> min | TTL outputs | | 0.4 | V | | | (Note 1) | CMOS outputs | | 0.4 | V | | Icco | Quiescent FPGA supply current (Note 2) | Commercial | | 3.0 | mA | | | | Industrial | V <sub>CC</sub> -0.5 0.4 0.4 3.0 6.0 -10 10 0.02 0.25 | mA | | | IL | Input or output leakage current | • | -10 | +10 | μΑ | | C <sub>IN</sub> | Input capacitance (sample tested) | | | 10 | pF | | I <sub>RPU</sub> | Pad pull-up (when selected) @ V <sub>IN</sub> = 0V (sample tested) | | | 0.25 | mA | | I <sub>RPD</sub> | Pad pull-down (when selected) @ V <sub>IN</sub> = 5V (sample tes | sted) | 0.02 | | mA | Note 1: With 50% of the outputs simultaneously sinking 12mA, up to a maximum of 64 pins. Note 2: With no output current loads, no active input pull-up resistors, all package pins at Vcc or GND, and the FPGA configured with a Tie option. #### **Spartan Global Buffer Switching Characteristic Guidelines** Testing of the switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net. When fewer vertical clock lines are connected, the clock distribution is faster; when multiple clock lines per column are driven from the same global clock, the delay is longer. For more specific, more precise, and worst-case guaranteed data, reflecting the actual routing structure, use the values provided by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). | | | Speed Grade | -4 | -3 | Units | |---------------------------------------------------|-----------------|-------------|-----|-----|----------| | Description | Symbol | Device | Max | Max | l Oilles | | From pad through Primary buffer, to any clock K | T <sub>PG</sub> | XCS05 | 2.0 | 4.0 | ns | | | | XCS10 | 2.4 | 4.3 | ns | | | | XCS20 | 2.8 | 5.4 | ns | | | | XCS30 | 3.2 | 5.8 | ns | | | | XCS40 | 3.5 | 6.4 | ns | | From pad through Secondary buffer, to any clock K | T <sub>SG</sub> | XCS05 | 2.5 | 4.4 | ns | | | | XCS10 | 2.9 | 4.7 | ns | | | | XCS20 | 3.3 | 5.8 | ns | | | | XCS30 | 3.6 | 6.2 | ns | | | | XCS40 | 3.9 | 6.7 | ns | #### **Spartan CLB Switching Characteristic Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Spartan devices and expressed in nanoseconds unless otherwise noted. | Spe | eed Grade | - | 4 | _ | 3 | 11 | |------------------------------------------------------------------|--------------------|--------|---------------------------|-----------|-----------|-------| | Description | Symbol | Min | Max | Min | Max | Units | | Clocks | | | | | | | | Clock High time | Тсн | 3.0 | | 4.0 | | ns | | Clock Low time | T <sub>CL</sub> | 3.0 | | 4.0 | | ns | | Combinatorial Delays | | | | | | | | F/G inputs to X/Y outputs | T <sub>ILO</sub> | | 1.2 | | 1.6 | ns | | F/G inputs via H to X/Y outputs | T <sub>IHO</sub> | | 2.0 | | 2.7 | ns | | C inputs via H1 via H to X/Y outputs | T <sub>HH1O</sub> | | 1.7 | | 2.2 | ns | | CLB Fast Carry Logic | | | | | | | | Operand inputs (F1, F2, G1, G4) to C <sub>OUT</sub> | T <sub>OPCY</sub> | | 1.7 | | 2.1 | ns | | Add/Subtract input (F3) to C <sub>OUT</sub> | T <sub>ASCY</sub> | | 2.8 | | 3.7 | ns | | Initialization inputs (F1, F3) to C <sub>OUT</sub> | T <sub>INCY</sub> | | 1.2 | | 1.4 | ns | | C <sub>IN</sub> through function generators to X/Y outputs | T <sub>SUM</sub> | | 2.0 | | 2.6 | ns | | $C_{\text{IN}}$ to $C_{\text{OUT}}$ , bypass function generators | T <sub>BYP</sub> | | 0.5 | | 0.6 | ns | | Sequential Delays | | | | | | | | Clock K to Flip-Flop outputs Q | Тско | | 2.1 | | 2.8 | ns | | Setup Time before Clock K | | | | | | | | F/G inputs | T <sub>ICK</sub> | 1.8 | | 2.4 | | ns | | F/G inputs via H | TIHCK | 2.9 | | 3.9 | | ns | | C inputs via H1 through H | T <sub>HH1CK</sub> | 2.3 | | 3.3 | | ns | | C inputs via DIN | TDICK | 1.3 | | 2.0 | | ns | | C inputs via EC | T <sub>ECCK</sub> | 2.0 | | 2.6 | | ns | | C inputs via S/R, going Low (inactive) | T <sub>RCK</sub> | 2.5 | | 4.0 | | ns | | Hold Time after Clock K | | | | | | | | All Hold times, all devices | | 0.0 | | 0.0 | | ns | | Set/Reset Direct | | | | | | | | Width (High) | T <sub>RPW</sub> | 3.0 | | 4.0 | | ns | | Delay from C inputs via S/R, going High to Q | T <sub>RIO</sub> | | 3.0 | | 4.0 | ns | | Global Set/Reset | | | | | | | | Minimum GSR Pulse Width | T <sub>MRW</sub> | 11.5 | | 13.5 | | ns | | Delay from GSR input to any Q | T <sub>MRQ</sub> | See pa | ge 45 for T <sub>RI</sub> | values pe | r device. | | | Toggle Frequency (MHz) (for export control purposes) | F <sub>TOG</sub> | | 166 | | 125 | MHz | #### Spartan CLB RAM Synchronous (Edge-Triggered) Write Operation Guidelines Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Spartan devices and are expressed in nanoseconds unless otherwise noted. | Single Bert BAM | Spee | ed Grade | - | 4 | - | 3 | l l m id m | |---------------------------------------------------|--------------|---------------------------------------|------------|------------|--------------|------------|------------| | Single Port RAM | Size | Symbol | Min | Max | Min | Max | Units | | Write Operation | | • | | | | | | | Address write cycle time (clock K period) | 16x2<br>32x1 | T <sub>WCS</sub> | 8.0<br>8.0 | | 11.6<br>11.6 | | ns<br>ns | | Clock K pulse width (active edge) | 16x2<br>32x1 | T <sub>WPS</sub> | 4.0<br>4.0 | | 5.8<br>5.8 | | ns<br>ns | | Address setup time before clock K | 16x2<br>32x1 | T <sub>ASS</sub><br>T <sub>ASTS</sub> | 1.5<br>1.5 | | 2.0<br>2.0 | | ns<br>ns | | Address hold time after clock K | 16x2<br>32x1 | T <sub>AHS</sub><br>T <sub>AHTS</sub> | 0.0<br>0.0 | | 0.0<br>0.0 | | ns<br>ns | | DIN setup time before clock K | 16x2<br>32x1 | T <sub>DSS</sub><br>T <sub>DSTS</sub> | 1.5<br>1.5 | | 2.7<br>1.7 | | ns<br>ns | | DIN hold time after clock K | 16x2<br>32x1 | T <sub>DHS</sub><br>T <sub>DHTS</sub> | 0.0<br>0.0 | | 0.0<br>0.0 | | ns<br>ns | | WE setup time before clock K | 16x2<br>32x1 | T <sub>WSS</sub><br>T <sub>WSTS</sub> | 1.5<br>1.5 | | 1.6<br>1.6 | | ns<br>ns | | WE hold time after clock K | 16x2<br>32x1 | T <sub>WHS</sub> | 0.0<br>0.0 | | 0.0<br>0.0 | | ns<br>ns | | Data valid after clock K | 16x2<br>32x1 | T <sub>WOS</sub> | | 6.5<br>7.0 | | 7.9<br>9.3 | ns<br>ns | | Read Operation | | 1 | | | | 1 | | | Address read cycle time | 16x2<br>32x1 | T <sub>RC</sub><br>T <sub>RCT</sub> | 2.6<br>3.8 | | 2.6<br>3.8 | | ns<br>ns | | Data Valid after address change (no Write Enable) | 16x2<br>32x1 | T <sub>ILO</sub><br>T <sub>IHO</sub> | | 1.2<br>2.0 | | 1.6<br>2.7 | ns<br>ns | | Address setup time before clock K | 16x2<br>32x1 | T <sub>ICK</sub><br>T <sub>IHCK</sub> | 1.8<br>2.9 | | 2.4<br>3.9 | | ns<br>ns | Note: Timing for 16 x 1 RAM option is identical to 16 x 2 RAM timing. ### Spartan CLB RAM Synchronous (Edge-Triggered) Write Operation Guidelines (continued) Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all Spartan devices and are expressed in nanoseconds unless otherwise noted. | Dual Port RAM | Spec | ed Grade | | -4 | -3 | | Units | | |-------------------------------------------|------|-------------------|-----|-----|------|-----|-------|--| | Dual Fort HAIW | Size | Symbol | Min | Max | Min | Max | Units | | | Write Operation | | | | | | | | | | Address write cycle time (clock K period) | 16x1 | T <sub>wcDs</sub> | 8.0 | | 11.6 | | ns | | | Clock K pulse width (active edge) | 16x1 | T <sub>WPDS</sub> | 4.0 | | 5.8 | | ns | | | Address setup time before clock K | 16x1 | T <sub>ASDS</sub> | 1.5 | | 2.1 | | ns | | | Address hold time after clock K | 16x1 | T <sub>AHDS</sub> | 0.0 | | 0.0 | | ns | | | DIN setup time before clock K | 16x1 | T <sub>DSDS</sub> | 1.5 | | 1.6 | | ns | | | DIN hold time after clock K | 16x1 | T <sub>DHDS</sub> | 0.0 | | 0.0 | | ns | | | WE setup time before clock K | 16x1 | Twsps | 1.5 | | 1.6 | | ns | | | WE hold time after clock K | 16x1 | T <sub>WHDS</sub> | 0.0 | | 0.0 | | ns | | | Data valid after clock K | 16x1 | T <sub>WODS</sub> | | 6.5 | | 7.0 | ns | | Note 1: Read Operation Timing for 16x1 dual-port RAM option is identical to 16x2 single-port RAM timing. ### Spartan CLB RAM Synchronous (Edge-Triggered) Write Timing Single Port Dual Port #### **Spartan Pin-to-Pin Output Parameter Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Pin-to-pin timing parameters are derived from measuring external and internal test patterns and are guaranteed over worst-case operating conditions (supply voltage and junction temperature). Listed below are representative values for typical pin locations and normal clock loading. For more specific, more precise, and worst-case guaranteed data, reflecting the actual routing structure, use the values provided by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. #### Spartan Output Flip-Flop, Clock-to-Out | | | Speed Grade | -4 | -3 | Units | |------------------------------------------------|---------------------|-------------|------|------|-------| | Description | Symbol | Device | Max | Max | | | Global Primary Clock to TTL Output using OFF | | | | | | | Fast | T <sub>ICKOF</sub> | XCS05 | 5.3 | 8.7 | ns | | | 10.00 | XCS10 | 5.7 | 9.1 | ns | | | | XCS20 | 6.1 | 9.3 | ns | | | | XCS30 | 6.5 | 9.4 | ns | | | | XCS40 | 6.8 | 10.2 | ns | | Slew-rate limited | T <sub>ICKO</sub> | XCS05 | 9.0 | 11.5 | ns | | | | XCS10 | 9.4 | 12.0 | ns | | | | XCS20 | 9.8 | 12.2 | ns | | | | XCS30 | 10.2 | 12.8 | ns | | | | XCS40 | 10.5 | 12.8 | ns | | Global Secondary Clock to TTL Output using OFF | | | | | • | | Fast | T <sub>ICKSOF</sub> | XCS05 | 5.8 | 9.2 | ns | | | | XCS10 | 6.2 | 9.6 | ns | | | | XCS20 | 6.6 | 9.8 | ns | | | | XCS30 | 7.0 | 9.9 | ns | | | | XCS40 | 7.3 | 10.7 | ns | | Slew-rate limited | T <sub>ICKSO</sub> | XCS05 | 9.5 | 12.0 | ns | | | | XCS10 | 9.9 | 12.5 | ns | | | | XCS20 | 10.3 | 12.7 | ns | | | | XCS30 | 10.7 | 13.2 | ns | | | | XCS40 | 11.0 | 14.3 | ns | | Delay Adder for CMOS Outputs Option | | | | | • | | Fast | T <sub>CMOSOF</sub> | All devices | 0.8 | 1.0 | ns | | Slew-rate Limited | T <sub>CMOSO</sub> | All devices | 1.5 | 2.0 | ns | OFF = Output Flip-Flop Note 1: Listed above are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net. Note 2: Output timing is measured at ~50% V<sub>CC</sub> threshold with 50 pF external capacitive load. For different loads, see Figure 31. #### **Capacitive Load Factor** Figure 31 shows the relationship between I/O output delay and load capacitance. It allows a user to adjust the specified output delay if the load capacitance is different than 50 pF. For example, if the actual load capacitance is 120 pF, add 2.5 ns to the specified delay. If the load capacitance is 20 pF, subtract 0.8 ns from the specified output delay. Figure 31 is usable over the specified operating conditions of voltage and temperature and is independent of the output slew rate control. Figure 31: Delay Factor at Various Capacitive Loads ### **Spartan Pin-to-Pin Input Parameter Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Pin-to-pin timing parameters are derived from measuring external and internal test patterns and are guaranteed over worst-case operating conditions (supply voltage and junction temperature). Listed below are representative values for typical pin locations and normal clock loading. #### Spartan Primary and Secondary Setup and Hold | | Spe | ed Grade | -4 | -3 | Units | |------------------------------------------------------|-------------------------------------|----------|-----------|-----------|--------| | Description | Symbol | Device | Min | Min | Uillis | | Input Setup/Hold Times Using Primary Clock and IFF | | | | | | | No Delay | T <sub>PSUF</sub> /T <sub>PHF</sub> | XCS05 | 1.2 / 1.7 | 1.8 / 2.5 | ns | | | | XCS10 | 1.0 / 2.3 | 1.5 / 3.4 | ns | | | | XCS20 | 0.8 / 2.7 | 1.2 / 4.0 | ns | | | | XCS30 | 0.6 / 3.0 | 0.9 / 4.5 | ns | | | | XCS40 | 0.4 / 3.5 | 0.6 / 5.2 | ns | | With Delay | T <sub>PSU</sub> /T <sub>PH</sub> | XCS05 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS10 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS20 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS30 | 4.3 / 0.0 | 6.0 / 0.0 | ns | | | | XCS40 | 5.3 / 0.0 | 6.8 / 0.0 | ns | | Input Setup/Hold Times Using Secondary Clock and IFF | | | | | | | No Delay | T <sub>SSUF</sub> /T <sub>SHF</sub> | XCS05 | 0.9 / 2.2 | 1.5 / 3.0 | ns | | | | XCS10 | 0.7 / 2.8 | 1.2 / 3.9 | ns | | | | XCS20 | 0.5 / 3.2 | 0.9 / 4.5 | ns | | | | XCS30 | 0.3 / 3.5 | 0.6 / 5.0 | ns | | | | XCS40 | 0.1 / 4.0 | 0.3 / 5.7 | ns | | With Delay | T <sub>SSU</sub> /T <sub>SH</sub> | XCS05 | 4.0 / 0.0 | 5.7 / 0.0 | ns | | | | XCS10 | 4.0 / 0.0 | 5.7 / 0.0 | ns | | | | XCS20 | 4.0 / 0.5 | 5.7 / 0.5 | ns | | | | XCS30 | 4.0 / 0.5 | 5.7 / 0.5 | ns | | | | XCS40 | 5.0 / 0.0 | 6.5 / 0.0 | ns | IFF = Input Flip-Flop or Latch Note 1: Setup time is measured with the fastest route and the lightest load. Hold time is measured using the furthest distance and a reference load of one clock pin per IOB/CLB. #### **Spartan IOB Input Switching Characteristic Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). | | S | peed Grade | - | 4 | _ | 3 | Units | |-------------------------------------------------------------|--------------------|-------------|------|------|------|------|-------| | Description | Symbol | Device | Min | Max | Min | Max | Units | | Setup Times - TTL Inputs (Note 1) | | | | | | | | | Clock Enable (EC) to Clock (IK), no delay | T <sub>ECIK</sub> | All devices | 1.6 | | 2.1 | | ns | | Pad to Clock (IK), no delay | T <sub>PICK</sub> | All devices | 1.5 | | 2.0 | | ns | | Hold Times | | | | | | | | | Clock Enable (EC) to Clock (IK), no delay | T <sub>IKEC</sub> | All devices | 0.0 | | 0.9 | | ns | | All Other Hold Times | | All devices | 0.0 | | 0.0 | | ns | | Propagation Delays - TTL Inputs (Note 1) | | | | | | | | | Pad to I1, I2 | T <sub>PID</sub> | All devices | | 1.5 | | 2.0 | ns | | Pad to I1, I2 via transparent input latch, no delay | T <sub>PLI</sub> | All devices | | 2.8 | | 3.6 | ns | | Clock (IK) to I1, I2 (flip-flop) | T <sub>IKRI</sub> | All devices | | 2.7 | | 2.8 | ns | | Clock (IK) to I1, I2 (latch enable, active Low) | T <sub>IKLI</sub> | All devices | | 3.2 | | 3.9 | ns | | Delay Adder for Input with Delay Option | | | | | | | | | T <sub>ECIKD</sub> = T <sub>ECIK</sub> + T <sub>Delay</sub> | T <sub>Delay</sub> | XCS05 | 3.6 | | 4.0 | | ns | | $T_{PICKD} = T_{PICK} + T_{Delay}$ | | XCS10 | 3.7 | | 4.1 | | ns | | $T_{PDLI} = T_{PLI} + T_{Delay}$ | | XCS20 | 3.8 | | 4.2 | | ns | | | | XCS30 | 4.5 | | 5.0 | | ns | | | | XCS40 | 5.5 | | 5.5 | | ns | | Global Set/Reset | | | | | | | | | Minimum GSR Pulse Width | T <sub>MRW</sub> | All devices | 11.5 | | 13.5 | | ns | | Delay from GSR input to any Q | T <sub>RRI</sub> | XCS05 | | 9.0 | | 11.3 | ns | | | | XCS10 | | 9.5 | | 11.9 | ns | | | | XCS20 | | 10.0 | | 12.5 | ns | | | | XCS30 | | 10.5 | | 13.1 | ns | | | | XCS40 | | 11.0 | | 13.8 | ns | Note 1: Delay adder for CMOS Inputs option: for -3 speed grade, add 0.4 ns; for -4 speed grade, add 0.2 ns. Note 2: Input pad setup and hold times are specified with respect to the internal clock (IK). For setup and hold times with respect to the clock input, see the pin-to-pin parameters in the Pin-to-Pin Input Parameters table. Note 3: Voltage levels of unused pads, bonded or unbonded, must be valid logic levels. Each can be configured with the internal pull-up (default) or pull-down resistor, or configured as a driven output, or can be driven from an external source. #### **Spartan IOB Output Switching Characteristic Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values are expressed in nanoseconds unless otherwise noted. | | | Speed Grade | -4 | | - | 3 | Units | |----------------------------------------------------|--------------------|-------------|------|------|------|------|--------| | Description | Symbol | Device | Min | Max | Min | Max | Ullits | | Clocks | | | | | 1 | | | | Clock High | Тсн | All devices | 3.0 | | 4.0 | | ns | | Clock Low | T <sub>CL</sub> | All devices | 3.0 | | 4.0 | | ns | | Propagation Delays - TTL Outputs (Notes 1, 2) | | | | | | | | | Clock (OK) to Pad, fast | T <sub>OKPOF</sub> | All devices | | 3.3 | | 4.5 | ns | | Clock (OK to Pad, slew-rate limited | Tokpos | All devices | | 6.9 | | 7.0 | ns | | Output (O) to Pad, fast | T <sub>OPF</sub> | All devices | | 3.6 | | 4.8 | ns | | Output (O) to Pad, slew-rate limited | T <sub>OPS</sub> | All devices | | 7.2 | | 7.3 | ns | | 3-state to Pad hi-Z (slew-rate independent) | T <sub>TSHZ</sub> | All devices | | 3.0 | | 3.8 | ns | | 3-state to Pad active and valid, fast | T <sub>TSONF</sub> | All devices | | 6.0 | | 7.3 | ns | | 3-state to Pad active and valid, slew-rate limited | T <sub>TSONS</sub> | All devices | | 9.6 | | 9.8 | ns | | Setup and Hold Times | | | | | | | | | Output (O) to clock (OK) setup time | T <sub>OOK</sub> | All devices | 2.5 | | 3.8 | | ns | | Output (O) to clock (OK) hold time | T <sub>OKO</sub> | All devices | 0.0 | | 0.0 | | ns | | Clock Enable (EC) to clock (OK) setup time | T <sub>ECOK</sub> | All devices | 2.0 | | 2.7 | | ns | | Clock Enable (EC) to clock (OK) hold time | TOKEC | All devices | 0.0 | | 0.5 | | ns | | Global Set/Reset | | | | | | | | | Minimum GSR pulse width | T <sub>MRW</sub> | All devices | 11.5 | | 13.5 | | ns | | Delay from GSR input to any Pad | T <sub>RPO</sub> | XCS05 | | 12.0 | | 15.0 | ns | | | ' | XCS10 | | 12.5 | | 15.7 | ns | | | | XCS20 | | 13.0 | | 16.2 | ns | | | | XCS30 | | 13.5 | | 16.9 | ns | | | | XCS40 | | 14.0 | | 17.5 | ns | Note 1: Delay adder for CMOS Outputs option (with fast slew rate option): for -3 speed grade, add 1.0 ns; for -4 speed grade, add 0.8 ns. Note 2: Delay adder for CMOS Outputs option (with slow slew rate option): for -3 speed grade, add 2.0 ns; for -4 speed grade, add 1.5 ns. Note 3: Output timing is measured at ~50% V<sub>CC</sub> threshold, with 50 pF external capacitive loads including test fixture. Slew-rate limited output rise/fall times are approximately two times longer than fast output rise/fall times. Note 4: Voltage levels of unused pads, bonded or unbonded, must be valid logic levels. Each can be configured with the internal pull-up (default) or pull-down resistor, or configured as a driven output, or can be driven from an external source. ### **SpartanXL Detailed Specifications** #### **Definition of Terms** In the following tables, some specifications may be designated as Advance or Preliminary. These terms are defined as follows: Advance: Initial estimates based on simulation and/or extrapolation from other speed grades, devices, or device families. Values are subject to change. Use as estimates, not for production. Preliminary: Based on preliminary characterization. Further changes are not expected. **Unmarked:** Specifications not identified as either Advance or Preliminary are to be considered Final. Notwithstanding the definition of the above terms, all specifications are subject to change without notice. #### SpartanXL Absolute Maximum Ratings<sup>1</sup> | Symbol | Description | | Value | Units | |------------------|---------------------------------------------------------------------|-----------------------------------------|-------------------------------|-------| | V <sub>CC</sub> | Supply voltage relative to GND | | -0.5 to 4.0 | V | | V | Input voltage relative to GND (Note 2, 3, 4, 5) | 5V Tolerant I/O Checked <sup>2, 3</sup> | -0.5 to 5.5 | V | | VIN | | Not 5V Tolerant I/Os <sup>4, 5</sup> | -0.5 to V <sub>CC</sub> + 0.5 | V | | V | Voltage applied to 2 state output (Note 2 2 4 5) | 5V Tolerant I/O Checked <sup>2, 3</sup> | -0.5 to 5.5 | V | | ۷TS | V <sub>TS</sub> Voltage applied to 3-state output (Note 2, 3, 4, 5) | Not 5V Tolerant I/Os <sup>4, 5</sup> | -0.5 to V <sub>CC</sub> + 0.5 | V | | V <sub>CCt</sub> | Longest Supply Voltage Rise Time from 1V to 3V | | 50 | ms | | T <sub>STG</sub> | Storage temperature (ambient) | | -65 to +150 | °C | | T <sub>SOL</sub> | Maximum soldering temperature (10 s @ 1/16 in. = | +260 | °C | | | TJ | Junction temperature | Plastic packages | +125 | °C | Note - Stresses beyond those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those listed under Operating Conditions is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods of time may affect device reliability. - 2: With 5V Tolerant I/Os Selected, the Maximum DC overshoot (above V<sub>CC</sub>) must be limited to either 5.5 V or 10 mA and undershoot (below GND) must be limited to either 0.5 V or 10 mA, whichever is easier to achieve. - 3: With 5V Tolerant I/Os Selected, the Maximum AC (during transitions) conditions are as follows; the device pins may undershoot to -2.0 V or overshoot to + 7.0 V, provided this overshoot or undershoot lasts no more than 11 ns with a forcing current no greater than 100 mA. - 4: Without 5V Tolerant I/Os Selected, the Maximum DC overshoot or undershoot must be limited to either 0.5 V or 10 mA, whichever is easier to achieve. - 5: Without 5V Tolerant I/Os Selected, the Maximum AC conditions are as follows; the device pins may undershoot to -2.0 V or overshoot to V<sub>CC</sub> + 2.0 V, provided this overshoot or undershoot lasts no more than 11 ns with a forcing current no greater than 100 mA. #### **SpartanXL Recommended Operating Conditions** | Symbol | Description | | Min | Max | Units | |-----------------|-------------------------------------------------------------|------------|------------------------|------------------------|-------| | | Supply voltage relative to GND, $T_J = 0$ °C to +85°C | Commercial | 3.0 | 3.6 | ٧ | | V <sub>CC</sub> | Supply voltage relative to GND, $T_J = -40$ °C to $+100$ °C | Industrial | 3.0 | 3.6 | ٧ | | V <sub>IH</sub> | High-level input voltage | | 50% of V <sub>CC</sub> | 5.5 | V | | V <sub>IL</sub> | Low-level input voltage | | 0 | 30% of V <sub>CC</sub> | V | | T <sub>IN</sub> | Input signal transition time | | | 250 | ns | Notes: At junction temperatures above those listed as Operating Conditions, all delay parameters increase by 0.35% per $^{\circ}$ C. Input and output measurement threshold is $\sim$ 50% of $V_{CC}$ . #### **SpartanXL DC Characteristics Over Operating Conditions** | Symbol | Description | Min | Max | Units | |-------------------|--------------------------------------------------------------------------------------------|---------------------|---------------------|-------| | V <sub>OH</sub> | High-level output voltage @ $I_{OH} = -4.0 \text{ mA}$ , $V_{CC} \text{ min (LVTTL)}$ | 2.4 | | V | | V OH | High-level output voltage @ $I_{OH}$ = -500 $\mu$ A, (LVCMOS) | 90% V <sub>CC</sub> | | V | | ., | Low-level output voltage @ I <sub>OL</sub> = 12.0 mA, V <sub>CC</sub> min (LVTTL) (Note 1) | | 0.4 | V | | V <sub>OL</sub> | Low-level output voltage @ I <sub>OL</sub> = 24.0 mA, V <sub>CC</sub> min (LVTTL) (Note 2) | | 0.4 | V | | | Low-level output voltage @ $I_{OL}$ = 1500 $\mu$ A, (LVCMOS) | | 10% V <sub>CC</sub> | V | | V <sub>DR</sub> | Data Retention Supply Voltage (below which configuration data may be lost) | 2.5 | | V | | Icco | Quiescent FPGA supply current (Note 3) | | 5 | mA | | I <sub>CCPD</sub> | Power Down FPGA supply current (Note 4) | 10 | 00 | μΑ | | ΙL | Input or output leakage current | -10 | +10 | μΑ | | C <sub>IN</sub> | Input capacitance (sample tested) | | 10 | рF | | I <sub>RPU</sub> | Pad pull-up (when selected) @ V <sub>in</sub> = 0V (sample tested) | 0.02 | 0.25 | mA | | I <sub>RPD</sub> | Pad pull-down (when selected) @ V <sub>in</sub> = 3.3V (sample tested) | 0.02 | | mA | Note 1: With up to 64 pins simultaneously sinking 12 mA (default mode). Note 2: With up to 64 pins simultaneously sinking 24mA (with 24 mA option selected). Note 3: With no output current loads, no active input pull-up resistors, all package pins at Vcc or GND, and the FPGA configured with the Lie option. Note 4: With PWRDWN active and 5V tolerance not selected. Typical value. #### **SpartanXL Global Buffer Switching Characteristic Guidelines** Testing of the switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net. When fewer vertical clock lines are connected, the clock distribution is faster; when multiple clock lines per column are driven from the same global clock, the delay is longer. For more specific, more precise, and worst-case guaranteed data, reflecting the actual routing structure, use the values provided by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). | | | Speed Grade | -5 | -4 | Units | |-----------------------------------------|------------------|-------------|---------|-------------|--------| | Description | Symbol | Device | Max | Max | Offics | | From pad through buffer, to any clock K | T <sub>GLS</sub> | XCS05XL | 1.1 | 1.5 | ns | | | | XCS10XL | 1.5 | 1.8 | ns | | | | XCS20XL | 1.8 | 2.1 | ns | | | | XCS30XL | 2.1 | 2.5 | ns | | | | XCS40XL | 2.4 | 2.8 | ns | | | • | | Advance | Preliminary | | #### **SpartanXL CLB Switching Characteristic Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all SpartanXL devices and expressed in nanoseconds unless otherwise noted. | Sp | eed Grade | - | 5 | - | 4 | Units | |-----------------------------------------------|-------------------|--------|---------------------------|--------------------------|---------|-------| | Description | Symbol | Min | Max | Min | Max | Units | | Clocks | | | | | | | | Clock High time | T <sub>CH</sub> | 2.0 | | 2.3 | | ns | | Clock Low time | T <sub>CL</sub> | 2.0 | | 2.3 | | ns | | Combinatorial Delays | | | | | | | | F/G inputs to X/Y outputs | T <sub>ILO</sub> | | 1.0 | | 1.1 | ns | | F/G inputs via H to X/Y outputs | T <sub>IHO</sub> | | 1.7 | | 2.0 | ns | | F/G inputs via transparent latch to Q outputs | T <sub>ITO</sub> | | 1.5 | | 1.8 | ns | | C inputs via H1 via H to X/Y outputs | T <sub>HH1O</sub> | | 1.5 | | 1.8 | ns | | Sequential Delays | | | | | | | | Clock K to Flip-Flop or latch outputs Q | Тско | | 1.2 | | 1.4 | ns | | Setup Time before Clock K | | | | | | | | F/G inputs | T <sub>ICK</sub> | 0.6 | | 0.7 | | ns | | F/G inputs via H | TIHCK | 1.3 | | 1.6 | | ns | | Hold Time after Clock K | | | | | • | | | All Hold times, all devices | | 0.0 | | 0.0 | | ns | | Set/Reset Direct | | | | I | 1 | | | Width (High) | T <sub>RPW</sub> | 2.5 | | 2.8 | | ns | | Delay from C inputs via S/R, going High to Q | T <sub>RIO</sub> | | 2.3 | | 2.7 | ns | | Global Set/Reset | | | | | | | | Minimum GSR Pulse Width | T <sub>MRW</sub> | 10.5 | | 11.5 | | ns | | Delay from GSR input to any Q | T <sub>MRQ</sub> | See pa | ge 54 for T <sub>RI</sub> | <sub>31</sub> values pei | device. | | | Toggle Frequency (MHz) | F <sub>TOG</sub> | • | 200 | i i | 179 | MHz | | (for export control purposes) | 100 | | | | | | | · | | Adv | ance | Prelin | ninary | | #### SpartanXL CLB RAM Synchronous (Edge-Triggered) Write Operation Guidelines Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all SpartanXL devices and are expressed in nanoseconds unless otherwise noted. | Single Dout DAM | Spee | ed Grade | | .5 | | ] | | |---------------------------------------------------|-------------------|---------------------------------------|------------|------------|------------|------------|----------| | Single Port RAM | Size <sup>1</sup> | Symbol | Min | Max | Min | Max | Units | | Write Operation | | | | | | | | | Address write cycle time (clock K period) | 16x2<br>32x1 | T <sub>WCS</sub><br>T <sub>WCTS</sub> | 7.7<br>7.7 | | 8.4<br>8.4 | | ns<br>ns | | Clock K pulse width (active edge) | 16x2<br>32x1 | T <sub>WPS</sub><br>T <sub>WPTS</sub> | 3.1<br>3.1 | | 3.6<br>3.6 | | ns<br>ns | | Address setup time before clock K | 16x2<br>32x1 | T <sub>ASS</sub><br>T <sub>ASTS</sub> | 1.3<br>1.5 | | 1.5<br>1.7 | | ns<br>ns | | DIN setup time before clock K | 16x2<br>32x1 | T <sub>DSS</sub><br>T <sub>DSTS</sub> | 1.5<br>1.8 | | 1.7<br>2.1 | | ns<br>ns | | WE setup time before clock K | 16x2<br>32x1 | T <sub>WSS</sub><br>T <sub>WSTS</sub> | 1.4<br>1.3 | | 1.6<br>1.5 | | ns<br>ns | | All hold times after clock K | | | 0.0 | | 0.0 | | ns | | Data valid after clock K | 16x2<br>32x1 | T <sub>wos</sub> | | 4.5<br>5.4 | | 5.3<br>6.3 | ns<br>ns | | Read Operation | | | | | | | | | Address read cycle time | 16x2<br>32x1 | T <sub>RC</sub><br>T <sub>RCT</sub> | 2.6<br>3.8 | | 3.1<br>5.5 | | ns<br>ns | | Data Valid after address change (no Write Enable) | 16x2<br>32x1 | T <sub>ILO</sub><br>T <sub>IHO</sub> | | 1.0<br>1.7 | | 1.1<br>2.0 | ns<br>ns | | Address setup time before clock K | 16x2<br>32x1 | T <sub>ICK</sub> | 0.6<br>1.3 | | 0.7<br>1.6 | | ns<br>ns | | | | - | Adv | ance | Prelir | ninary | | Note 1: Timing for 16 x 1 RAM option is identical to 16 x 2 RAM timing. #### SpartanXL CLB RAM Synchronous (Edge-Triggered) Write Operation Guidelines (cont.) Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values apply to all SpartanXL devices and are expressed in nanoseconds unless otherwise noted. | Dual Port RAM | Speed Grade | | -5 | | | Units | | |-------------------------------------------|-------------------|-------------------|---------|-----|-------------|-------|-------| | Dual Fort HAIW | Size <sup>1</sup> | Symbol | Min | Max | Min | Max | Units | | Write Operation | | | | | | | | | Address write cycle time (clock K period) | 16x1 | T <sub>WCDS</sub> | 7.7 | | 8.4 | | ns | | Clock K pulse width (active edge) | 16x1 | T <sub>WPDS</sub> | 3.9 | | 3.6 | | ns | | Address setup time before clock K | 16x1 | T <sub>ASDS</sub> | 1.3 | | 1.5 | | ns | | DIN setup time before clock K | 16x1 | T <sub>DSDS</sub> | 1.7 | | 2.0 | | ns | | WE setup time before clock K | 16x1 | T <sub>WSDS</sub> | 1.4 | | 1.6 | | ns | | All hold time after clock K | 16x1 | | 0.0 | | 0.0 | | ns | | Data valid after clock K | 16x1 | Twods | | 5.2 | | 6.1 | ns | | | • | , | Advance | | Preliminary | | | Note 1: Read Operation Timing for 16x1 dual-port RAM option is identical to 16x2 single-port RAM timing. ### Spartan CLB RAM Synchronous (Edge-Triggered) Write Timing Single Port Dual Port #### SpartanXL Pin-to-Pin Output Parameter Guidelines Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Pin-to-pin timing parameters are derived from measuring external and internal test patterns and are guaranteed over worst-case operating conditions (supply voltage and junction temperature). Listed below are representative values for typical pin locations and normal clock loading. #### SpartanXL Output Flip-Flop, Clock-to-Out | | | Speed Grade | -5 | -4 | Units | | |----------------------------------|--------------------|-------------|---------|--------|-------|--| | Description | Symbol | Device | Max | Max | Units | | | Global Clock to Output using OFF | | | | | | | | Fast | T <sub>ICKOF</sub> | XCS05XL | 4.4 | 5.2 | ns | | | | | XCS10XL | 4.7 | 5.5 | ns | | | | | XCS20XL | 5.0 | 5.8 | ns | | | | | XCS30XL | 5.3 | 6.2 | ns | | | | | XCS40XL | 5.6 | 6.5 | ns | | | Slew Rate Adjustment | | | | | | | | For output slow option add | T <sub>SLOW</sub> | All Devices | 1.5 | 1.7 | ns | | | OFF = Output Flip Flop | | | Advance | Prelim | | | Note 1: Output delays are representative values where one global clock input drives one vertical clock line in each accessible column, and where all accessible IOB and CLB flip-flops are clocked by the global clock net. #### SpartanXL Pin-to-Pin Input Parameter Guidelines Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Pin-to-pin timing parameters are derived from measuring external and internal test patterns and are guaranteed over worst-case operating conditions (supply voltage and junction temperature). Listed below are representative values for typical pin locations and normal clock loading. #### SpartanXL Setup and Hold | | Speed Grade | -5 | -4 | Units | | |---------------------------------------------------|-----------------------------------|---------|---------|---------|-------| | Description | Symbol | Device | Min | Min | Units | | Input Setup/Hold Times Using Global Clock and IFF | | | | | | | No Delay | T <sub>SUF</sub> /T <sub>HF</sub> | XCS05XL | 1.1/2.0 | 1.6/2.6 | ns | | | | XCS10XL | 1.0/2.2 | 1.5/2.8 | ns | | | | XCS20XL | 0.9/2.4 | 1.4/3.0 | ns | | | | XCS30XL | 0.8/2.6 | 1.3/3.2 | ns | | | | XCS40XL | 0.7/2.8 | 1.2/3.4 | ns | | Full Delay | T <sub>SU</sub> /T <sub>H</sub> | XCS05XL | 3.9/0.0 | 5.1/0.0 | ns | | | | XCS10XL | 4.1/0.0 | 5.3/0.0 | ns | | | | XCS20XL | 4.3/0.0 | 5.5/0.0 | ns | | | | XCS30XL | 4.5/0.0 | 5.7/0.0 | ns | | | | XCS40XL | 4.7/0.0 | 5.9/0.0 | ns | | IFF = Input Flip-Flop or Latch | | • | Advance | Prelim | | Note 3: Setup time is measured with the fastest route and the lightest load. Hold time is measured using the furthest distance and a reference load of one clock pin per IOB/CLB. Note 2: Output timing is measured at ~50% V<sub>CC</sub> threshold with 50 pF external capacitive load. #### **Capacitive Load Factor** Figure 32 shows the relationship between I/O output delay and load capacitance. It allows a user to adjust the specified output delay if the load capacitance is different than 50 pF. For example, if the actual load capacitance is 120 pF, add 2.5 ns to the specified delay. If the load capacitance is 20 pF, subtract 0.8 ns from the specified output delay. Figure 32 is usable over the specified operating conditions of voltage and temperature and is independent of the output slew rate control. Figure 32: Delay Factor at Various Capacitive Loads #### **SpartanXL IOB Input Switching Characteristic Guidelines** Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). | | Speed Grade | | | | -4 | | Units | |-----------------------------------------------------|--------------------|-------------|------|------|--------|--------|--------| | Description | Symbol | Device | Min | Max | Min | Max | Ullits | | Setup Times | | | | | | | | | Clock Enable (EC) to Clock (IK) | T <sub>ECIK</sub> | All devices | 0.0 | | 0.0 | | ns | | Pad to Clock (IK), no delay | T <sub>PICK</sub> | All devices | 1.0 | | 1.2 | | ns | | Pad to Fast Capture Latch Enable (OK), no delay | T <sub>POCK</sub> | All devices | 0.7 | | 0.8 | | ns | | Hold Times | | | | | | | | | All Hold Times | | All devices | 0.0 | | 0.0 | | ns | | Propagation Delays | | | | | | | | | Pad to I1, I2 | T <sub>PID</sub> | All devices | | 0.9 | | 1.1 | ns | | Pad to I1, I2 via transparent input latch, no delay | T <sub>PLI</sub> | All devices | | 2.1 | | 2.5 | ns | | Clock (IK) to I1, I2 (flip-flop) | T <sub>IKRI</sub> | All devices | | 1.0 | | 1.1 | ns | | Clock (IK) to I1, I2 (latch enable, active Low) | T <sub>IKLI</sub> | All devices | | 1.1 | | 1.2 | ns | | Delay Adder for Input with Delay Option | | | | | | | | | $T_{PICKD} = T_{PICK} + T_{Delay}$ | T <sub>Delay</sub> | XCS05XL | 4.0 | | 4.7 | | ns | | $T_{PDLI} = T_{PLI} + T_{Delay}$ | | XCS10XL | 4.8 | | 5.6 | | ns | | , | | XCS20XL | 5.0 | | 5.9 | | ns | | | | XCS30XL | 5.5 | | 6.5 | | ns | | | | XCS40XL | 6.5 | | 7.6 | | ns | | Global Set/Reset | | | | | | | | | Minimum GSR Pulse Width | T <sub>MRW</sub> | All devices | 10.5 | | 11.5 | | ns | | Delay from GSR input to any Q | T <sub>RRI</sub> | XCS05XL | | 9.0 | | 10.5 | ns | | | | XCS10XL | | 9.5 | | 11.0 | ns | | | | XCS20XL | | 10.0 | | 11.5 | ns | | | | XCS30XL | | 11.0 | | 12.5 | ns | | | | XCS40XL | | 12.0 | | 13.5 | ns | | | • | | Adv | ance | Prelin | ninary | | Note 1: Input pad setup and hold times are specified with respect to the internal clock (IK). For setup and hold times with respect to the clock input, see the pin-to-pin parameters in the Pin-to-Pin Input Parameters table. Note 2: Voltage levels of unused pads, bonded or unbonded, must be valid logic levels. Each can be configured with the internal pull-up (default) or pull-down resistor, or configured as a driven output, or can be driven from an external source. #### SpartanXL IOB Output Switching Characteristic Guidelines Testing of switching parameters is modeled after testing methods specified by MIL-M-38510/605. All devices are 100% functionally tested. Internal timing parameters are derived from measuring internal test patterns. Listed below are representative values. For more specific, more precise, and worst-case guaranteed data, use the values reported by the static timing analyzer (TRCE in the Xilinx Development System) and back-annotated to the simulation netlist. These path delays, provided as a guideline, have been extracted from the static timing analyzer report. All timing parameters assume worst-case operating conditions (supply voltage and junction temperature). Values are expressed in nanoseconds unless otherwise noted. | | | Speed Grade | | | _ | Units | | |---------------------------------------------|--------------------|-------------|------|------|--------|--------|-------| | Description | Symbol | Device | Min | Max | Min | Max | Units | | Clocks | | | | | | | | | Clock High | Тсн | All devices | 2.0 | | 2.3 | | ns | | Clock Low | T <sub>CL</sub> | All devices | 2.0 | | 2.3 | | ns | | Propagation Delays | | | | | | | | | Clock (OK) to Pad, fast | T <sub>OKPOF</sub> | All devices | | 3.2 | | 3.7 | ns | | Output (O) to Pad, fast | T <sub>OPF</sub> | All devices | | 2.5 | | 2.9 | ns | | 3-state to Pad hi-Z (slew-rate independent) | T <sub>TSHZ</sub> | All devices | | 2.8 | | 3.3 | ns | | 3-state to Pad active and valid, fast | T <sub>TSONF</sub> | All devices | | 2.6 | | 3.0 | ns | | Output (O) to Pad via Output Mux, fast | T <sub>OFPF</sub> | All devices | | 3.7 | | 4.4 | ns | | Select (OK) to Pad via Output Mux, fast | TOKFPF | All devices | | 3.3 | | 3.9 | ns | | For Output SLOW option add | T <sub>SLOW</sub> | All devices | | 1.5 | | 1.7 | ns | | Setup and Hold Times | | | | | | | | | Output (O) to clock (OK) setup time | Тоок | All devices | 0.5 | | 0.5 | | ns | | Output (O) to clock (OK) hold time | Токо | All devices | 0.0 | | 0.0 | | ns | | Clock Enable (EC) to clock (OK) setup time | TECOK | All devices | 0.0 | | 0.0 | | ns | | Clock Enable (EC) to clock (OK) hold time | TOKEC | All devices | 0.1 | | 0.1 | | ns | | Global Set/Reset | | | | | | | | | Minimum GSR pulse width | T <sub>MRW</sub> | All devices | 10.5 | | 11.5 | | ns | | Delay from GSR input to any Pad | T <sub>RPO</sub> | XCS05XL | | 11.9 | | 14.0 | ns | | . , | '" | XCS10XL | | 12.4 | | 14.5 | ns | | | | XCS20XL | | 12.9 | | 15.0 | ns | | | | XCS30XL | | 13.9 | | 16.0 | ns | | | | XCS40XL | | 14.9 | | 17.0 | ns | | | • | • | Adv | ance | Prelin | ninary | | Note 1: Output timing is measured at ~50% V<sub>CC</sub> threshold, with 50 pF external capacitive loads including test fixture. Slew-rate limited output rise/fall times are approximately two times longer than fast output rise/fall times. Note 2: Voltage levels of unused pads, bonded or unbonded, must be valid logic levels. Each can be configured with the internal pull-up (default) or pull-down resistor, or configured as a driven output, or can be driven from an external source. ### **Pin Descriptions** There are three types of pins in the Spartan Series devices: - · Permanently dedicated pins - User I/O pins that can have special functions - Unrestricted user-programmable I/O pins. Before and during configuration, all outputs not used for the configuration process are 3-stated with the I/O pull-up resistor network activated. After configuration, if an IOB is unused it is configured as an input with the I/O pull-up resistor network remaining activated. Any user I/O can be configured to drive the Global Set/Reset net GSR or the global three-state net, GTS. See "Global Signals: GSR and GTS" on page 21 for more information. Device pins for Spartan Series devices are described in Table 18. **Table 18: Pin Descriptions** | Pin Name | I/O<br>During<br>Config. | I/O<br>After<br>Config. | Pin Description | | | | | | | | |--------------------------------------------|--------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Permanently Dedicated Pins | | | | | | | | | | | | VCC | х | х | Eight or more (depending on package) connections to the nominal $+5$ V supply voltage ( $+3.3$ V for SpartanXL devices). All must be connected, and each must be decoupled with a $0.01$ - $0.1$ $\mu$ F capacitor to Ground. | | | | | | | | | GND | х | х | Eight or more (depending on package type) connections to Ground. All must be connected. | | | | | | | | | CCLK | l or O | I | During configuration, Configuration Clock (CCLK) is an output in Master mode and is an input in Slave mode. After configuration, CCLK has a weak pull-up resistor and can be selected as the Readback Clock. There is no CCLK High or Low time restriction on Spartan Series devices, except during Readback. See "Violating the Maximum High and Low Time Specification for the Readback Clock" on page 35 for an explanation of this exception. | | | | | | | | | DONE | I/O | 0 | DONE is a bidirectional signal with an optional internal pull-up resistor. As an output, it indicates the completion of the configuration process. As an input, a Low level on DONE can be configured to delay the global logic initialization and the enabling of outputs. The optional pull-up resistor is selected as an option in the program that creates the configuration bitstream. The resistor is included by default. | | | | | | | | | PROGRAM | I | I | PROGRAM is an active Low input that forces the FPGA to clear its configuration memory. It is used to initiate a configuration cycle. When PROGRAM goes High, the FPGA finishes the current clear cycle and executes another complete clear cycle, before it goes into a WAIT state and releases INIT. The PROGRAM pin has a permanent weak pull-up, so it need not be externally pulled up to Vcc. | | | | | | | | | MODE<br>(Spartan)<br>M0, M1<br>(SpartanXL) | I | x | The Mode input(s) are sampled after INIT goes High to determine the configuration mode to be used. During configuration, these pins have a weak pull-up resistor. For the most popular configuration mode, Slave Serial, the mode pins can be left unconnected. For Master Serial mode, connect the Mode/M0 pin directly to system ground. | | | | | | | | | PWRDWN | I | I | PWRDWN is an active Low input that forces the FPGA into the Power Down state and reduces power consumption. When PWRDWN is Low, the FPGA disables all I/O and initializes all flip-flops. All inputs are interpreted as Low independent of their actual level. VCC must be maintained, and the configuration data is maintained. PWRDWN halts configuration if asserted before or during configuration, and re-starts configuration when removed. When PWRDWN returns High, the FPGA becomes operational by first enabling the inputs and flip-flops and then enabling the outputs. PWRDWN has a default internal pull-up resistor. | | | | | | | | | Don't Connect<br>(Spartan) | х | х | Pins reserved for factory testing and possible future enhancements. Pins must be left floating. | | | | | | | | Table 18: Pin Descriptions (Continued) | | After Config. | | |-------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Config. | | | at Can i | | Pin Description | | | Have Spe | ecial Functions | | 0 | 0 | If boundary scan is used, this pin is the Test Data Output. If boundary scan is not used, this pin is a 3-state output without a register, after configuration is completed. To use this pin, place the library component TDO instead of the usual pad symbol. An output buffer must still be used. | | I | I/O<br>or I<br>(JTAG) | If boundary scan is used, these pins are Test Data In, Test Clock, and Test Mode Select inputs respectively. They come directly from the pads, bypassing the IOBs. These pins can also be used as inputs to the CLB logic after configuration is completed. If the BSCAN symbol is not placed in the design, all boundary scan functions are inhibited once configuration is completed, and these pins become user-programmable I/O. In this case, they must be called out by special library elements. To use these pins, place the library components TDI, TCK, and TMS instead of the usual pad symbols. Input or output buffers must still be used. | | 0 | I/O | High During Configuration (HDC) is driven High until the I/O go active. It is available as a control output indicating that configuration is not yet completed. After configuration, HDC is a user-programmable I/O pin. | | 0 | I/O | Low During Configuration (LDC) is driven Low until the I/O go active. It is available as a control output indicating that configuration is not yet completed. After configuration, LDC is a user-programmable I/O pin. | | 1/0 | 1/0 | Before and during configuration, $\overline{\text{INIT}}$ is a bidirectional signal. A 1 k $\Omega$ - 10 k $\Omega$ external pull-up resistor is recommended. As an active-Low open-drain output, $\overline{\text{INIT}}$ is held Low during the power stabilization and internal clearing of the configuration memory. As an active-Low input, it can be used to hold the FPGA in the internal WAIT state before the start of configuration. Master mode devices stay in a WAIT state an additional 30 to 300 $\mu$ s after $\overline{\text{INIT}}$ has gone High. During configuration, a Low on this output indicates that a configuration data error has occurred. After the I/O go active, $\overline{\text{INIT}}$ is a user-programmable I/O pin. | | <b>W</b> eak<br>Pull-up | l or I/O | Four Primary Global inputs each drive a dedicated internal global net with short delay and minimal skew. If not used to drive a global buffer, any of these pins is a user-programmable I/O. The PGCK1-PGCK4 pins drive the four Primary Global Buffers. Any input pad symbol connected directly to the input of a BUFGP symbol is automatically placed on one of these pins. | | <b>W</b> eak<br>Pull-up | l or I/O | Four Secondary Global inputs each drive a dedicated internal global net with short delay and minimal skew. These internal global nets can also be driven from internal logic. If not used to drive a global net, any of these pins is a user-programmable I/O pin. The SGCK1-SGCK4 pins provide the shortest path to the four Secondary Global Buffers. Any input pad symbol connected directly to the input of a BUFGS symbol is automatically placed on one of these pins. | | <b>W</b> eak<br>Pull-up | l or I/O | Eight Global inputs each drive a dedicated internal global net with short delay and minimal skew. These internal global nets can also be driven from internal logic. If not used to drive a global net, any of these pins is a user-programmable I/O pin. The GCK1-GCK8 pins provide the shortest path to the eight Global Low-Skew Buffers. Any input pad symbol connected directly to the input of a BUFGLS symbol is automatically placed on one of these pins. | | ı | I/O | During Express configuration, CS1 is used as a serial-enable signal for daisy-chaining. | | 1 | I/O | During Express configuration, these eight input pins receive configuration data. After configuration, they are user-programmable I/O pins. | | ^`\ | O O I/O Veak Jill-up | O O I/O O I/O I/O I/O I/O I O I/O I/O I/ | **Table 18: Pin Descriptions (Continued)** | | I/O<br>During | I/O<br>After | | |----------------|-----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | Config. | Config. | Pin Description | | DIN | I | 1/0 | During Slave Serial or Master Serial configuration, DIN is the serial configuration data input receiving data on the rising edge of CCLK. After configuration, DIN is a user-programmable I/O pin. | | DOUT | 0 | I/O | During Slave Serial or Master Serial configuration, DOUT is the serial configuration data output that can drive the DIN of daisy-chained slave FPGAs. DOUT data changes on the falling edge of CCLK, one-and-a-half CCLK periods after it was received at the DIN input. In SpartanXL Express mode, DOUT is the status output that can drive the CS1 of daisy-chained FPGAs, to enable and disable downstream devices. After configuration, DOUT is a user-programmable I/O pin. | | Unrestricted U | lser-Prog | rammabl | e I/O Pins | | 1/0 | Weak<br>Pull-up | I/O | These pins can be configured to be input and/or output after configuration is completed. Before configuration is completed, these pins have an internal high-value pull-up resistor network that defines the logic level as High. | # **Device-Specific Pinout Tables** Device-specific tables include all packages for each Spartan and SpartanXL device. They follow the pad locations around the die, and include boundary scan register locations. #### Pin Locations for XCS05 & XCS05XL Devices | XCS05/XL<br>Pad Name | PC84 | VQ100 | Bndry Scan | |------------------------|------|-------|------------| | VCC | P2 | P89 | - | | 1/0 | P3 | P90 | 32 | | 1/0 | P4 | P91 | 35 | | 1/0 | - | P92 | 38 | | 1/0 | - | P93 | 41 | | 1/0 | P5 | P94 | 44 | | 1/0 | P6 | P95 | 47 | | 1/0 | P7 | P96 | 50 | | 1/0 | P8 | P97 | 53 | | 1/0 | P9 | P98 | 56 | | I/O, SGCK1 †, GCK8 †† | P10 | P99 | 59 | | VCC | P11 | P100 | - | | GND | P12 | P1 | - | | I/O, PGCK1 +, GCK1 ++ | P13 | P2 | 62 | | 1/0 | P14 | P3 | 65 | | I/O, TDI | P15 | P4 | 68 | | I/O, TCK | P16 | P5 | 71 | | I/O, TMS | P17 | P6 | 74 | | 1/0 | P18 | P7 | 77 | | 1/0 | - | P8 | 83 | | 1/0 | P19 | P9 | 86 | | 1/0 | P20 | P10 | 89 | | GND | P21 | P11 | - | | VCC | P22 | P12 | - | | 1/0 | P23 | P13 | 92 | | 1/0 | P24 | P14 | 95 | | 1/0 | - | P15 | 98 | | 1/0 | P25 | P16 | 104 | | 1/0 | P26 | P17 | 107 | | 1/0 | P27 | P18 | 110 | | 1/0 | - | P19 | 113 | | 1/0 | P28 | P20 | 116 | | I/O, SGCK2 †, GCK2 †† | P29 | P21 | 119 | | Don't Connect †, M1 †† | P30 | P22 | 122 | | GND | P31 | P23 | - | | MODE †, M0 †† | P32 | P24 | 125 | | XCS05/XL<br>Pad Name | PC84 | VQ100 | Bndry Scan | |-------------------------------|------|-------|------------| | VCC | P33 | P25 | - | | Don't Connect †,<br>PWRDWN †† | P34 | P26 | 126 † | | I/O, PGCK2 †, GCK3 †† | P35 | P27 | 127 ‡ | | I/O (HDC) | P36 | P28 | 130 ‡ | | 1/0 | - | P29 | 133 ‡ | | I/O ( <u>LDC</u> ) | P37 | P30 | 136 ‡ | | 1/0 | P38 | P31 | 139 ‡ | | 1/0 | P39 | P32 | 142 ‡ | | 1/0 | - | P33 | 145 ‡ | | 1/0 | - | P34 | 148 ‡ | | 1/0 | P40 | P35 | 151 ‡ | | I/O (ĪNĪT) | P41 | P36 | 154 ‡ | | VCC | P42 | P37 | - | | GND | P43 | P38 | - | | 1/0 | P44 | P39 | 157 ‡ | | 1/0 | P45 | P40 | 160 ‡ | | 1/0 | - | P41 | 163 ‡ | | 1/0 | - | P42 | 166 ‡ | | 1/0 | P46 | P43 | 169 ‡ | | 1/0 | P47 | P44 | 172 ‡ | | 1/0 | P48 | P45 | 175 ‡ | | 1/0 | P49 | P46 | 178 ‡ | | 1/0 | P50 | P47 | 181 ‡ | | I/O, SGCK3 †, GCK4 †† | P51 | P48 | 184 ‡ | | GND | P52 | P49 | - | | DONE | P53 | P50 | - | | VCC | P54 | P51 | - | | PROGRAM | P55 | P52 | - | | I/O (D7 ††) | P56 | P53 | 187 ‡ | | I/O, PGCK3 †, GCK5 †† | P57 | P54 | 190 ‡ | | I/O (D6 ††) | P58 | P55 | 193 ‡ | | 1/0 | - | P56 | 196 ‡ | | I/O (D5 ††) | P59 | P57 | 199 ‡ | | 1/0 | P60 | P58 | 202 ‡ | | 1/0 | - | P59 | 205 ‡ | | 1/0 | - | P60 | 208 ‡ | | XCS05/XL<br>Pad Name | PC84 | VQ100 | Bndry Scan | |---------------------------------|------|-------|------------| | I/O (D4 ††) | P61 | P61 | 211 ‡ | | 1/0 | P62 | P62 | 214 ‡ | | VCC | P63 | P63 | - | | GND | P64 | P64 | - | | I/O (D3 ††) | P65 | P65 | 217 ‡ | | 1/0 | P66 | P66 | 220 ‡ | | 1/0 | - | P67 | 223 ‡ | | I/O (D2 ††) | P67 | P68 | 229 ‡ | | 1/0 | P68 | P69 | 232 ‡ | | I/O (D1 ††) | P69 | P70 | 235 ‡ | | 1/0 | P70 | P71 | 238 ‡ | | I/O (D0 ††, DIN) | P71 | P72 | 241 ‡ | | I/O, SGCK4 †, GCK6 ††<br>(DOUT) | P72 | P73 | 244 ‡ | | CCLK | P73 | P74 | - | | VCC | P74 | P75 | - | | O, TDO | P75 | P76 | 0 | | GND | P76 | P77 | - | | 1/0 | P77 | P78 | 2 | | XCS05/XL<br>Pad Name | PC84 | VQ100 | Bndry Scan | |-----------------------|------|-------|------------| | I/O, PGCK4 †, GCK7 †† | P78 | P79 | 5 | | I/O (CS1 ††) | P79 | P80 | 8 | | 1/0 | P80 | P81 | 11 | | 1/0 | P81 | P82 | 14 | | 1/0 | P82 | P83 | 17 | | 1/0 | - | P84 | 20 | | 1/0 | - | P85 | 23 | | 1/0 | P83 | P86 | 26 | | 1/0 | P84 | P87 | 29 | | GND | P1 | P88 | - | <sup>11/20/98</sup> ‡ The "PWRDWN" on the XCS05XL is not part of the Boundary Scan chain. For the XCS05XL, subtract 1 from all Boundary Scan numbers from GCK3 on (127 and higher). #### Pin Locations for XCS10 & XCS10XL Devices | XCS10/XL<br>Pad Name | PC84 | VQ100 | TQ144 | Bndry<br>Scan | |-----------------------|------|-------|-------|---------------| | VCC | P2 | P89 | P128 | - | | 1/0 | P3 | P90 | P129 | 44 | | 1/0 | P4 | P91 | P130 | 47 | | 1/0 | - | P92 | P131 | 50 | | 1/0 | - | P93 | P132 | 53 | | 1/0 | P5 | P94 | P133 | 56 | | 1/0 | P6 | P95 | P134 | 59 | | 1/0 | - | - | P135 | 62 | | 1/0 | - | - | P136 | 65 | | GND | - | - | P137 | - | | 1/0 | P7 | P96 | P138 | 68 | | 1/0 | P8 | P97 | P139 | 71 | | 1/0 | - | - | P140 | 74 | | 1/0 | - | - | P141 | 77 | | 1/0 | P9 | P98 | P142 | 80 | | I/O, SGCK1 +, GCK8 ++ | P10 | P99 | P143 | 83 | | vcc | P11 | P100 | P144 | - | | GND | P12 | P1 | P1 | - | | I/O, PGCK1 †, GCK1 †† | P13 | P2 | P2 | 86 | | 1/0 | P14 | P3 | P3 | 89 | | 1/0 | - | - | P4 | 92 | | 1/0 | - | - | P5 | 95 | | I/O, TDI | P15 | P4 | P6 | 98 | | I/O. TCK | P16 | P5 | P7 | 101 | | GND | | - | P8 | - | | 1/0 | - | - | P9 | 104 | | 1/0 | _ | _ | P10 | 107 | | I/O, TMS | P17 | P6 | P11 | 110 | | 1/0 | P18 | P7 | P12 | 113 | | 1/0 | - | | P13 | 116 | | 1/0 | | P8 | P14 | 119 | | 1/0 | P19 | P9 | P15 | 122 | | 1/0 | P20 | P10 | P16 | 125 | | GND | P21 | P11 | P17 | - | | VCC | P22 | P12 | P18 | + | | 1/0 | P23 | P13 | P19 | 128 | | 1/0 | P24 | P14 | P20 | 131 | | 1/0 | - | P15 | P21 | 134 | | 1/0 | - | - 113 | P22 | 137 | | 1/0 | P25 | P16 | P23 | 140 | | 1/0 | P26 | P17 | P24 | 143 | | 1/0 | - | | P25 | 143 | | 1/0 | | - | P26 | 149 | | 1/0 | | _ | I F20 | 149 | | XCS10/XL<br>Pad Name | PC84 | VQ100 | TQ144 | Bndry<br>Scan | |-------------------------------|------|------------------|-------|---------------| | | | | D07 | Scan | | GND | - | - | P27 | | | 1/0 | P27 | P18 | P28 | 152 | | 1/0 | - | P19 | P29 | 155 | | 1/0 | - | - | P30 | 158 | | I/O | - | - | P31 | 161 | | 1/0 | P28 | P20 | P32 | 164 | | I/O, SGCK2 †,<br>GCK2 †† | P29 | P21 | P33 | 167 | | Don't Connect †, M1 †† | P30 | P22 | P34 | 170 | | GND | P31 | P23 | P35 | - | | MODE †, M0 †† | P32 | P24 | P36 | 173 | | VCC | P33 | P25 | P37 | | | Don't Connect †,<br>PWRDWN †† | P34 | P26 | P38 | 174 † | | I/O, PGCK2 †, GCK3 †† | P35 | P27 | P39 | 175 ‡ | | I/O (HDC) | P36 | P28 | P40 | 178 ± | | 1/0 | - | - | P41 | 181 ± | | 1/0 | - | - | P42 | 184 ‡ | | 1/0 | - | P29 | P43 | 187 ‡ | | I/O (LDC) | P37 | P30 | P44 | 190 ± | | GND | - | - | P45 | - 1 | | 1/0 | - | - | P46 | 193 ± | | 1/0 | - | - | P47 | 196 ‡ | | 1/0 | P38 | P31 | P48 | 199 ‡ | | 1/0 | P39 | P32 | P49 | 202 ± | | 1/0 | - | P33 | P50 | 205 ± | | 1/0 | - | P34 | P51 | 208 ‡ | | 1/0 | P40 | P35 | P52 | 211 ‡ | | I/O (ĪNĪT) | P41 | P36 | P53 | 214 ‡ | | VCC | P42 | P37 | P54 | | | GND | P43 | P38 | P55 | <b>-</b> | | 1/0 | P44 | P39 | P56 | 217 ‡ | | 1/0 | P45 | P40 | P57 | 220 ± | | 1/0 | - | P41 | P58 | 223 ± | | 1/0 | - | P42 | P59 | 226 ‡ | | 1/0 | P46 | P43 | P60 | 229 ± | | 1/0 | P47 | P44 | P61 | 232 ± | | 1/0 | | <del> '.'</del> | P62 | 235 ‡ | | 1/0 | - | - | P63 | 238 ‡ | | GND | | | P64 | - 200 + | | 1/0 | P48 | P45 | P65 | 241 ‡ | | 1/0 | P49 | P46 | P66 | 244 ‡ | | 1/0 | - | - | P67 | 247 ‡ | | 1/0 | | - | P68 | 250 ‡ | | 1/0 | - | | L 200 | 200 ‡ | <sup>† = 5</sup>V Spartan only <sup>†† = 3</sup>V SpartanXL only | XCS10/XL<br>Pad Name | PC84 | VQ100 | TQ144 | Bndry<br>Scan | |-----------------------|------|-------|-------|---------------| | 1/0 | P50 | P47 | P69 | 253 ‡ | | I/O, SGCK3 †, GCK4 †† | P51 | P48 | P70 | 256 ‡ | | GND | P52 | P49 | P71 | - | | DONE | P53 | P50 | P72 | - | | VCC | P54 | P51 | P73 | - | | PROGRAM | P55 | P52 | P74 | - | | I/O (D7 ††) | P56 | P53 | P75 | 259 ‡ | | I/O, PGCK3 †, GCK5 †† | P57 | P54 | P76 | 262 ‡ | | 1/0 | - | - | P77 | 265 ‡ | | 1/0 | - | - | P78 | 268 ‡ | | I/O (D6 ††) | P58 | P55 | P79 | 271 ‡ | | 1/0 | - | P56 | P80 | 274 ‡ | | GND | - | - | P81 | - | | 1/0 | - | - | P82 | 277 ‡ | | 1/0 | - | - | P83 | 280 ‡ | | I/O (D5 ††) | P59 | P57 | P84 | 283 ‡ | | 1/0 | P60 | P58 | P85 | 286 ‡ | | I/O | - | P59 | P86 | 289 ‡ | | 1/0 | - | P60 | P87 | 292 ‡ | | I/O (D4 ††) | P61 | P61 | P88 | 295 ‡ | | 1/0 | P62 | P62 | P89 | 298 ‡ | | VCC | P63 | P63 | P90 | - | | GND | P64 | P64 | P91 | - | | I/O (D3 ††) | P65 | P65 | P92 | 301 ‡ | | 1/0 | P66 | P66 | P93 | 304 ‡ | | 1/0 | - | P67 | P94 | 307 ‡ | | 1/0 | - | - | P95 | 310 ‡ | | I/O (D2 ††) | P67 | P68 | P96 | 313 ‡ | | 1/0 | P68 | P69 | P97 | 316 ‡ | | 1/0 | - | - | P98 | 319 ‡ | | 1/0 | - | - | P99 | 322 ‡ | | GND | - | - | P100 | - 1 | | I/O (D1 ††) | P69 | P70 | P101 | 325 ‡ | | I/O | P70 | P71 | P102 | 328 ‡ | | 1/0 | - | - | P103 | 331 ‡ | | I/O | - | - | P104 | 334 ‡ | | I/O (D0 ††, DIN) | P71 | P72 | P105 | 337 ‡ | | XCS10/XL<br>Pad Name | PC84 | VQ100 | TQ144 | Bndry<br>Scan | |---------------------------------|------|-------|-------|---------------| | I/O, SGCK4 †, GCK6 ††<br>(DOUT) | P72 | P73 | P106 | 340 ‡ | | CCLK | P73 | P74 | P107 | - | | VCC | P74 | P75 | P108 | - | | O, TDO | P75 | P76 | P109 | 0 | | GND | P76 | P77 | P110 | - | | I/O | P77 | P78 | P111 | 2 | | I/O, PGCK4 †, GCK7 †† | P78 | P79 | P112 | 5 | | I/O | - | - | P113 | 8 | | I/O | - | - | P114 | 11 | | I/O (CS1 ++) | P79 | P80 | P115 | 14 | | I/O | P80 | P81 | P116 | 17 | | GND | - | - | P118 | - | | I/O | - | - | P119 | 20 | | I/O | - | - | P120 | 23 | | I/O | P81 | P82 | P121 | 26 | | I/O | P82 | P83 | P122 | 29 | | I/O | - | P84 | P123 | 32 | | I/O | - | P85 | P124 | 35 | | I/O | P83 | P86 | P125 | 38 | | 1/0 | P84 | P87 | P126 | 41 | | GND | P1 | P88 | P127 | - | <sup>11/20/98</sup> ‡ The "PWRDWN" on the XCS10XL is not part of the Boundary Scan chain. For the XCS10XL, subtract 1 from all Boundary Scan numbers from GCK3 on (175 and higher). #### Additional XCS10/XL Package Pins #### TQ144 | Not Connected Pins | | | | | | | |--------------------|---|---|---|---|---|--| | P117 | - | - | - | - | - | | | 5/5/97 | | | | | | | <sup>† = 5</sup>V Spartan only <sup>†† = 3</sup>V SpartanXL only ### Pin Locations for XCS20 & XCS20XL Devices | XCS20/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | Bndry<br>Scan | |-----------------------|----------|------------|------------|---------------| | VCC | P89 | P128 | P183 | - | | 1/0 | P90 | P129 | P184 | 62 | | 1/0 | P91 | P130 | P185 | 65 | | 1/0 | P92 | P131 | P186 | 68 | | 1/0 | P93 | P132 | P187 | 71 | | 1/0 | - | - | P188 | 74 | | 1/0 | _ | - | P189 | 77 | | 1/0 | P94 | P133 | P190 | 80 | | 1/0 | P95 | P134 | P191 | 83 | | VCC †† | - | - | P192 | - | | 1/0 | - | P135 | P193 | 86 | | 1/0 | _ | P136 | P194 | 89 | | GND | _ | P137 | P195 | - | | 1/0 | _ | - | P196 | 92 | | 1/0 | _ | - | P197 | 95 | | 1/0 | | - | P198 | 98 | | 1/0 | - | - | P199 | 101 | | 1/0 | P96 | P138 | P200 | 104 | | 1/0 | P97 | P139 | P200 | 107 | | 1/0 | P97<br>- | | | | | | - | P140 | P204 | 110 | | 1/0 | | P141 | P205 | 113 | | 1/0 | P98 | P142 | P206 | 116 | | I/O, SGCK1 †, GCK8 †† | P99 | P143 | P207 | 119 | | VCC | P100 | P144 | P208 | - | | GND | P1 | P1 | P1 | - | | I/O, PGCK1 †, GCK1 †† | P2 | P2 | P2 | 122 | | 1/0 | P3 | P3 | P3 | 125 | | I/O | - | P4 | P4 | 128 | | 1/0 | - | P5 | P5 | 131 | | I/O, TDI | P4 | P6 | P6 | 134 | | I/O, TCK | P5 | P7 | P7 | 137 | | 1/0 | - | - | P8 | 140 | | 1/0 | - | - | P9 | 143 | | 1/0 | - | - | P10 | 146 | | 1/0 | 1-1 | - | P11 | 149 | | GND | - | P8 | P13 | - | | 1/0 | - | P9 | P14 | 152 | | 1/0 | - | P10 | P15 | 155 | | I/O, TMS | P6 | P11 | P16 | 158 | | 1/0 | P7 | P12 | P17 | 161 | | VCC ++ | - | - | P18 | - | | 1/0 | - | - | P19 | 164 | | 1/0 | - | - | P20 | 167 | | 1/0 | 1-1 | P13 | P21 | 170 | | 1/0 | P8 | P14 | P22 | 173 | | 1/0 | P9 | P15 | P23 | 176 | | 1/0 | P10 | P16 | P24 | 179 | | GND | P11 | P17 | P25 | - | | VCC | P12 | P18 | P26 | - | | 1/0 | P13 | P19 | P27 | 182 | | 1/0 | P14 | P20 | P28 | 185 | | 1/0 | P15 | P21 | P29 | 188 | | 1/0 | - | P22 | P30 | 191 | | 1/0 | | - | P31 | 194 | | 1/0 | | | P32 | 197 | | VCC ++ | - | - | P33 | - | | 1/O | -<br>P16 | P23 | P34 | 200 | | 1/0 | P17 | P23 | P34 | 200 | | 1/0 | | P24<br>P25 | | | | | - | | P36 | 206 | | I/O | - | P26 | P37 | 209 | | GND | - | P27 | P38 | - 010 | | 1/0 | - | - | P40 | 212 | | 1/0 | - | - | P41 | 215 | | 1/0 | - | - | P42 | 218 | | | | | | | | I/O<br>I/O | -<br>P18 | -<br>P28 | P43<br>P44 | 221<br>224 | | XCS20/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | Bndry<br>Scan | |-------------------------|----------|------------|--------------|---------------| | 1/0 | P19 | P29 | P45 | 227 | | 1/0 | - | P30 | P46 | 230 | | 1/0 | - | P31 | P47 | 233 | | 1/0 | P20 | P32 | P48 | 236 | | I/O, SGCK2 †, GCK2 †† | P21 | P33 | P49 | 239 | | Don't Connect †, M1 †† | P22 | P34 | P50 | 242 | | GND | P23 | P35 | P51 | T - | | MODE †, M0 †† | P24 | P36 | P52 | 245 | | VCC | P25 | P37 | P53 | | | Don't Connect †, | P26 | P38 | P54 | 246 † | | PWRDWN ++ | | | | ' | | I/O, PGCK2 †, GCK3 †† | P27 | P39 | P55 | 247 ‡ | | I/O (HDC) | P28 | P40 | P56 | 250 ± | | 1/0 | - | P41 | P57 | 253 ‡ | | 1/0 | - | P42 | P58 | 256 ± | | 1/0 | P29 | P43 | P59 | 259 ± | | I/O (LDC) | P30 | P44 | P60 | 262 ‡ | | 1/0 | - | - | P61 | 265 ‡ | | 1/0 | _ | - | P62 | 268 ‡ | | 1/0 | - | _ | P63 | 271 ‡ | | 1/0 | - | _ | P64 | 274 ± | | GND | - | P45 | P66 | -/-+ | | 1/0 | - | P46 | P67 | 277 ‡ | | 1/0 | - | P47 | P68 | 280 ‡ | | 1/0 | P31 | P48 | P69 | 283 ‡ | | 1/0 | P32 | P49 | P70 | 286 ‡ | | VCC ++ | - | - | P71 | - 200 + | | 1/0 | - | - | P71 | | | 1/0 | | - | P73 | 289 ± | | 1/0 | P33 | -<br>P50 | P73 | | | | | | | 295 ‡ | | 1/0 | P34 | P51 | P75 | 298 ‡ | | I/O | P35 | P52 | P76 | 301 ‡ | | I/O ( <del>INIT</del> ) | P36 | P53 | P77 | 304 ‡ | | VCC | P37 | P54 | P78 | + - | | GND | P38 | P55 | P79 | | | 1/0 | P39 | P56 | P80 | 307 ‡ | | 1/0 | P40 | P57 | P81 | 310 ‡ | | 1/0 | P41 | P58 | P82 | 313 ‡ | | 1/0 | P42 | P59 | P83 | 316 ‡ | | 1/0 | - | - | P84 | 319 ‡ | | I/O | - | - | P85 | 322 ‡ | | VCC †† | - | - | P86 | ļ <u>-</u> . | | 1/0 | P43 | P60 | P87 | 325 ‡ | | 1/0 | P44 | P61 | P88 | 328 ‡ | | 1/0 | - | P62 | P89 | 331 ‡ | | 1/0 | - | P63 | P90 | 334 ‡ | | GND | - | P64 | P91 | 1 - | | 1/0 | - | - | P93 | 337 ‡ | | 1/0 | - | - | P94 | 340 ‡ | | 1/0 | - | - | P95 | 343 ‡ | | 1/0 | - | - | P96 | 346 ‡ | | 1/0 | P45 | P65 | P97 | 349 ‡ | | 1/0 | P46 | P66 | P98 | 352 ‡ | | I/O | - | P67 | P99 | 355 ‡ | | 1/0 | - | P68 | P100 | 358 ‡ | | 1/0 | P47 | P69 | P101 | 361 ‡ | | I/O, SGCK3 †, GCK4 †† | P48 | P70 | P102 | 364 ‡ | | GND | P49 | P71 | P103 | - | | DONE | P50 | P72 | P104 | - | | VCC | P51 | P73 | P105 | - | | PROGRAM | P52 | P74 | P106 | 1 - | | I/O (D7 ††) | P53 | P75 | P107 | 367 ± | | I/O, PGCK3 †, GCK5 †† | P54 | P76 | P108 | 370 ‡ | | 1/0 | - | P77 | P109 | 373 ‡ | | | | | | | | 1/0 | - | P78 | P110 | 376 ± | | I/O<br>I/O (D6 ††) | -<br>P55 | P78<br>P79 | P110<br>P112 | 376 ± | | XCS20/XL | V0100 | T0144 | PQ208 | Bndry | |---------------------------------|-------|-------|-------|-------| | Pad Name | VQ100 | TQ144 | PQ208 | Scan | | 1/0 | - | - | P114 | 385 ‡ | | 1/0 | - | - | P115 | 388 ‡ | | 1/0 | - | - | P116 | 391 ‡ | | 1/0 | - | - | P117 | 394 ‡ | | GND | - | P81 | P118 | - | | 1/0 | - | P82 | P119 | 397 ‡ | | 1/0 | - | P83 | P120 | 400 ‡ | | VCC ++ | - | - | P121 | - | | I/O (D5 ††) | P57 | P84 | P122 | 403 ‡ | | 1/0 | P58 | P85 | P123 | 406 ‡ | | 1/0 | - | - | P124 | 409 ‡ | | 1/0 | - | - | P125 | 412 ‡ | | 1/0 | P59 | P86 | P126 | 415 ‡ | | 1/0 | P60 | P87 | P127 | 418 ‡ | | I/O (D4 ††) | P61 | P88 | P128 | 421 ‡ | | 1/0 | P62 | P89 | P129 | 424 ‡ | | VCC | P63 | P90 | P130 | - | | GND | P64 | P91 | P131 | - | | I/O (D3 ††) | P65 | P92 | P132 | 427 ± | | I/O | P66 | P93 | P133 | 430 ‡ | | I/O | P67 | P94 | P134 | 433 ‡ | | I/O | - | P95 | P135 | 436 ‡ | | 1/0 | - | - | P136 | 439 ‡ | | 1/0 | - | - | P137 | 442 ‡ | | I/O (D2 ††) | P68 | P96 | P138 | 445 ‡ | | 1/0 | P69 | P97 | P139 | 448 ‡ | | VCC ++ | - | - | P140 | - | | I/O | - | P98 | P141 | 451 ‡ | | 1/0 | - | P99 | P142 | 454 ‡ | | GND | - | P100 | P143 | - | | 1/0 | - | - | P145 | 457 ‡ | | I/O | - | - | P146 | 460 ‡ | | 1/0 | - | - | P147 | 463 ‡ | | 1/0 | - | - | P148 | 466 ‡ | | I/O (D1 ††) | P70 | P101 | P149 | 469 ‡ | | 1/0 | P71 | P102 | P150 | 472 ‡ | | 1/0 | - | P103 | P151 | 475 ‡ | | 1/0 | - | P104 | P152 | 478 ‡ | | I/O (D0 ††, DIN) | P72 | P105 | P153 | 481 ‡ | | I/O, SGCK4 †, GCK6 ††<br>(DOUT) | P73 | P106 | P154 | 484 ‡ | | CCLK | P74 | P107 | P155 | - | | XCS20/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | Bndry<br>Scan | |-----------------------|-------|-------|-------|---------------| | VCC | P75 | P108 | P156 | - | | O, TDO | P76 | P109 | P157 | 0 | | GND | P77 | P110 | P158 | - | | 1/0 | P78 | P111 | P159 | 2 | | I/O, PGCK4 †, GCK7 †† | P79 | P112 | P160 | 5 | | 1/0 | - | P113 | P161 | 8 | | 1/0 | - | P114 | P162 | 11 | | I/O (CS1 ††) | P80 | P115 | P163 | 14 | | 1/0 | P81 | P116 | P164 | 17 | | I/O | - | P117 | P166 | 20 | | 1/0 | - | - | P167 | 23 | | I/O | - | - | P168 | 26 | | 1/0 | - | - | P169 | 29 | | GND | - | P118 | P170 | - | | 1/0 | - | P119 | P171 | 32 | | 1/0 | - | P120 | P172 | 35 | | VCC ++ | - | - | P173 | - | | 1/0 | P82 | P121 | P174 | 38 | | 1/0 | P83 | P122 | P175 | 41 | | 1/0 | - | - | P176 | 44 | | 1/0 | - | - | P177 | 47 | | 1/0 | P84 | P123 | P178 | 50 | | 1/0 | P85 | P124 | P179 | 53 | | 1/0 | P86 | P125 | P180 | 56 | | 1/0 | P87 | P126 | P181 | 59 | | GND | P88 | P127 | P182 | - | #### 11/20/9 ### Additional XCS20/XL Package Pins #### PQ208 | | Not Connected Pins | | | | | | | | | | |--------------------------------|---------------------------------|-------|-----|-----|-------|--|--|--|--|--| | P12 | P18 † | P33 † | P39 | P65 | P71 † | | | | | | | P86 † | P86 † P92 P111 P121 † P140 † P1 | | | | | | | | | | | P165 P173 † P192 † P202 P203 - | | | | | | | | | | | 9/16/98 † = 5V Spartan only †† = 3V SpartanXL only ‡ The "PWRDWN" on the XCS20XL is not part of the Boundary Scan chain. For the XCS20XL, subtract 1 from all Boundary Scan numbers from GCK3 on (247 and higher). #### Pin Locations for XCS30 & XCS30XL Devices | XCS30/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |----------------------|-------|-------|-------|-------|------------|---------------| | VCC | P89 | P128 | P183 | P212 | VCC* | - | | 1/0 | P90 | P129 | P184 | P213 | C10 | 74 | | 1/0 | P91 | P130 | P185 | P214 | D10 | 77 | | 1/0 | P92 | P131 | P186 | P215 | <b>A</b> 9 | 80 | | 1/0 | P93 | P132 | P187 | P216 | B9 | 83 | | 1/0 | - | - | P188 | P217 | C9 | 86 | | 1/0 | - | - | P189 | P218 | D9 | 89 | | 1/0 | P94 | P133 | P190 | P220 | <b>A</b> 8 | 92 | | 1/0 | P95 | P134 | P191 | P221 | B8 | 95 | | VCC | - | - | P192 | P222 | VCC* | - | | 1/0 | - | - | - | P223 | <b>A</b> 6 | 98 | | 1/0 | - | - | - | P224 | C7 | 101 | | 1/0 | - | P135 | P193 | P225 | B6 | 104 | | 1/0 | - | P136 | P194 | P226 | <b>A</b> 5 | 107 | | GND | - | P137 | P195 | P227 | GND* | - | | 1/0 | - | - | P196 | P228 | C6 | 110 | | 1/0 | - | - | P197 | P229 | B5 | 113 | | 1/0 | - | - | P198 | P230 | <b>A</b> 4 | 116 | | 1/0 | - | - | P199 | P231 | C5 | 119 | | 1/0 | P96 | P138 | P200 | P232 | B4 | 122 | | 1/0 | P97 | P139 | P201 | P233 | <b>A</b> 3 | 125 | | XCS30/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |--------------------------|-------|-------|-------|-------|------------|---------------| | 1/0 | - | - | P202 | P234 | D5 | 128 | | 1/0 | - | - | P203 | P235 | C4 | 131 | | 1/0 | - | P140 | P204 | P236 | B3 | 134 | | 1/0 | - | P141 | P205 | P237 | B2 | 137 | | 1/0 | P98 | P142 | P206 | P238 | <b>A</b> 2 | 140 | | I/O, SGCK1 †,<br>GCK8 †† | P99 | P143 | P207 | P239 | C3 | 143 | | VCC | P100 | P144 | P208 | P240 | VCC* | - | | GND | P1 | P1 | P1 | P1 | GND* | - | | I/O, PGCK1 †,<br>GCK1 †† | P2 | P2 | P2 | P2 | B1 | 146 | | 1/0 | P3 | P3 | P3 | P3 | C2 | 149 | | 1/0 | - | P4 | P4 | P4 | D2 | 152 | | 1/0 | - | P5 | P5 | P5 | D3 | 155 | | I/O, TDI | P4 | P6 | P6 | P6 | E4 | 158 | | I/O, TCK | P5 | P7 | P7 | P7 | C1 | 161 | | 1/0 | - | - | P8 | P8 | D1 | 164 | | 1/0 | - | - | P9 | P9 | E3 | 167 | | 1/0 | - | - | P10 | P10 | E2 | 170 | | 1/0 | - | - | P11 | P11 | E1 | 173 | | I/O | - | - | P12 | P12 | F3 | 176 | | XCS30/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |----------------------------|--------------------------------------------------|-------|----------|-------|------------|---------------| | 1/0 | <u> </u> | _ | _ | P13 | F2 | 179 | | GND | <u> </u> | P8 | P13 | P14 | GND* | - | | I/O | | P9 | P14 | P15 | G3 | 182 | | 1/0 | <u> </u> | P10 | P15 | P16 | G2 | 185 | | | | | | | | | | I/O, TMS | P6 | P11 | P16 | P17 | G1 | 188 | | 1/0 | P7 | P12 | P17 | P18 | H3 | 191 | | VCC | - | - | P18 | P19 | VCC* | - | | 1/0 | - | - | - | P20 | H2 | 194 | | 1/0 | - | - | - | P21 | H1 | 197 | | I/O | - | - | P19 | P23 | J2 | 200 | | 1/0 | <u> </u> | - | P20 | P24 | J1 | 203 | | I/O | <u> </u> | P13 | P21 | P25 | K2 | 206 | | I/O | P8 | P14 | P22 | P26 | K3 | 209 | | 1/0 | P9 | P15 | P23 | P27 | K1 | | | | | | | | | 212 | | 1/0 | P10 | P16 | P24 | P28 | L1 | 215 | | GND | P11 | P17 | P25 | P29 | GND* | - | | VCC | P12 | P18 | P26 | P30 | VCC* | - | | I/O | P13 | P19 | P27 | P31 | L2 | 218 | | I/O | P14 | P20 | P28 | P32 | L3 | 221 | | 1/0 | P15 | P21 | P29 | P33 | L4 | 224 | | 1/0 | <u> </u> | P22 | P30 | P34 | M1 | 227 | | 1/0 | 1 | | P31 | P35 | M2 | 230 | | | <del> </del> | - | | | | | | 1/0 | - | - | P32 | P36 | M3 | 233 | | 1/0 | <u> </u> | - | <u> </u> | P38 | N1 | 236 | | 1/0 | - | - | - | P39 | N2 | 239 | | VCC | | | P33 | P40 | VCC* | | | 1/0 | P16 | P23 | P34 | P41 | P1 | 242 | | 1/0 | P17 | P24 | P35 | P42 | P2 | 245 | | 1/0 | - | P25 | P36 | P43 | R1 | 248 | | 1/0 | <u> </u> | P26 | P37 | P44 | P3 | 251 | | GND | - | P27 | P38 | P45 | GND* | - | | | - | P27 | P38 | | | <u> </u> | | 1/0 | - | - | - | P46 | T1 | 254 | | 1/0 | - | - | P39 | P47 | R3 | 257 | | I/O | - | - | P40 | P48 | T2 | 260 | | 1/0 | - | - | P41 | P49 | U1 | 263 | | 1/0 | - | - | P42 | P50 | T3 | 266 | | 1/0 | - | - | P43 | P51 | U2 | 269 | | I/O | P18 | P28 | P44 | P52 | V1 | 272 | | I/O | P19 | P29 | P45 | P53 | T4 | 275 | | | FIB | | | | | | | 1/0 | ļ - | P30 | P46 | P54 | U3 | 278 | | 1/0 | - | P31 | P47 | P55 | V2 | 281 | | 1/0 | P20 | P32 | P48 | P56 | W1 | 284 | | I/O, SGCK2 †,<br>GCK2 †† | P21 | P33 | P49 | P57 | <b>V</b> 3 | 287 | | Don't Connect †,<br>M1 †† | P22 | P34 | P50 | P58 | <b>W</b> 2 | 290 | | GND | P23 | P35 | P51 | P59 | GND* | - | | | P24 | P36 | P52 | | | 293 | | MODE †, M0 †† | | | | P60 | Y1 | 293 | | VCC | P25 | P37 | P53 | P61 | VCC* | - | | Don't Connect †, PWRDWN †† | P26 | P38 | P54 | P62 | W3 | 294 † | | I/O, PGCK2 †,<br>GCK3 †† | P27 | P39 | P55 | P63 | Y2 | 295 ‡ | | I/O (HDC) | P28 | P40 | P56 | P64 | W4 | 298 ‡ | | 1/0 | - | P41 | P57 | P65 | V4 | 301 ‡ | | 1/0 | <u> </u> | P42 | P58 | P66 | U5 | 304 ‡ | | 1/0 | P29 | P43 | P59 | P67 | Y3 | 307 ‡ | | 1/O ( <u>LDC</u> ) | P30 | P44 | P60 | P68 | Y4 | 310 ± | | · , | | F44 | | | | | | 1/0 | - | - | P61 | P69 | V5 | 313 ‡ | | 1/0 | - | - | P62 | P70 | <b>W</b> 5 | 316 ‡ | | 1/0 | - | - | P63 | P71 | Y5 | 319 ‡ | | 1/0 | - | - | P64 | P72 | <b>V</b> 6 | 322 ‡ | | I/O | - | - | P65 | P73 | <b>W</b> 6 | 325 ‡ | | 1/0 | - | - | - | P74 | Y6 | 328 ‡ | | GND | t . | P45 | P66 | P75 | GND* | | | I/O | <del> </del> | | | P76 | | 331 ‡ | | | - | P46 | P67 | | W7 | | | 1/0 | | P47 | P68 | P77 | Y7 | 334 ‡ | | 1/0 | P31 | P48 | P69 | P78 | V8 | 337 ‡ | | 1/0 | P32 | P49 | P70 | P79 | <b>W</b> 8 | 340 ‡ | | VCC | | | P71 | P80 | VCC* | | | XCS30/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |--------------------------|--------------------------------------------------|----------|----------|-------|-------------|---------------| | 1/0 | + - | _ | P72 | P81 | Y8 | 343 ‡ | | 1/0 | <del> </del> - | | P73 | P82 | U9 | 346 ± | | 1/0 | <b>-</b> | _ | - | P84 | Y9 | 349 ‡ | | 1/0 | <del> </del> | | _ | P85 | W10 | 352 ± | | | -<br>D00 | - | D74 | | | | | 1/0 | P33 | P50 | P74 | P86 | V10 | 355 ‡ | | 1/0 | P34 | P51 | P75 | P87 | Y10 | 358 ‡ | | 1/0 | P35 | P52 | P76 | P88 | Y11 | 361 ‡ | | I/O ( <del>INIT</del> ) | P36 | P53 | P77 | P89 | W11 | 364 ‡ | | VCC | P37 | P54 | P78 | P90 | VCC* | - | | GND | P38 | P55 | P79 | P91 | GND* | - | | I/O | P39 | P56 | P80 | P92 | V11 | 367 ‡ | | 1/0 | P40 | P57 | P81 | P93 | U11 | 370 ‡ | | 1/0 | P41 | P58 | P82 | P94 | Y12 | 373 ± | | 1/0 | P42 | P59 | P83 | P95 | W12 | 376 ± | | I/O | _ | _ | P84 | P96 | V12 | 379 ± | | 1/0 | <del>-</del> | _ | P85 | P97 | U12 | 382 ± | | 1/0 | <b>-</b> | _ | 1 00 | P99 | V13 | 385 ‡ | | 1/0 | | _ | | | | · · | | | _ | | -<br>D00 | P100 | Y14 | 388 ‡ | | VCC | - | - | P86 | P101 | VCC* | - 001 | | 1/0 | P43 | P60 | P87 | P102 | Y15 | 391 ‡ | | 1/0 | P44 | P61 | P88 | P103 | V14 | 394 ‡ | | 1/0 | - | P62 | P89 | P104 | <b>W</b> 15 | 397 ‡ | | I/O | - | P63 | P90 | P105 | Y16 | 400 ‡ | | GND | - | P64 | P91 | P106 | GND* | - | | 1/0 | - | - | - | P107 | V15 | 403 ‡ | | I/O | - | - | P92 | P108 | <b>W</b> 16 | 406 ‡ | | 1/0 | <del>-</del> | - | P93 | P109 | Y17 | 409 ‡ | | 1/0 | + | _ | P94 | P110 | V16 | 412 ‡ | | 1/0 | - | - | P95 | P111 | W17 | 415 ‡ | | 1/0 | + - | | P96 | P112 | Y18 | 418 ‡ | | | - D45 | -<br>D05 | | | U16 | | | 1/0 | P45 | P65 | P97 | P113 | | 421 ‡ | | 1/0 | P46 | P66 | P98 | P114 | V17 | 424 ‡ | | 1/0 | - | P67 | P99 | P115 | W18 | 427 ‡ | | 1/0 | - | P68 | P100 | P116 | Y19 | 430 ‡ | | I/O | P47 | P69 | P101 | P117 | V18 | 433 ‡ | | I/O, SGCK3 †,<br>GCK4 †† | P48 | P70 | P102 | P118 | <b>W</b> 19 | 436 ‡ | | GND | P49 | P71 | P103 | P119 | GND* | - | | DONE | P50 | P72 | P104 | P120 | Y20 | - | | VCC | P51 | P73 | P105 | P121 | VCC* | - | | PROGRAM | P52 | P74 | P106 | P122 | V19 | - | | I/O (D7 ††) | P53 | P75 | P107 | P123 | U19 | 439 ‡ | | I/O, PGCK3 †, | P54 | P76 | P108 | P124 | U18 | 442 ± | | GCK5 †† | | | | | | · · | | 1/0 | - | P77 | P109 | P125 | T17 | 445 ‡ | | 1/0 | - | P78 | P110 | P126 | V20 | 448 ± | | 1/0 | 1 - | | - | P127 | U20 | 451 ‡ | | 1/0 | _ | <u> </u> | P111 | P128 | T18 | 454 ‡ | | I/O (D6 ††) | P55 | P79 | P112 | P129 | T19 | | | | | <b>-</b> | | | | 457 ‡ | | 1/0 | P56 | P80 | P113 | P130 | T20 | 460 ‡ | | 1/0 | - | - | P114 | P131 | R18 | 463 ‡ | | 1/0 | - | - | P115 | P132 | R19 | 466 ‡ | | 1/0 | - | - | P116 | P133 | R20 | 469 ‡ | | I/O | - | - | P117 | P134 | P18 | 472 ‡ | | GND | - | P81 | P118 | P135 | GND* | - | | 1/0 | - | - | - | P136 | P20 | 475 ‡ | | 1/0 | - | - | - | P137 | N18 | 478 ‡ | | 1/0 | - | P82 | P119 | P138 | N19 | 481 ± | | 1/0 | - | P83 | P120 | P139 | N20 | 484 ‡ | | VCC | <del>-</del> | - | P121 | P140 | VCC* | 707 + | | I/O (D5 ††) | P57 | | P121 | P140 | M17 | 487 ± | | | | P84 | | | | <del></del> | | 1/0 | P58 | P85 | P123 | P142 | M18 | 490 ‡ | | 1/0 | - | - | P124 | P144 | M20 | 493 ‡ | | 1/0 | - | - | P125 | P145 | L19 | 496 ‡ | | I/O | P59 | P86 | P126 | P146 | L18 | 499 ‡ | | I/O | P60 | P87 | P127 | P147 | L20 | 502 ‡ | | I/O (D4 ††) | P61 | P88 | P128 | P148 | K20 | 505 ‡ | | 1/0 | P62 | P89 | P129 | P149 | K19 | 508 ‡ | | VCC | P63 | P90 | P130 | P150 | VCC* | | | GND | P64 | P91 | P131 | P151 | GND* | - | | GIND | 1-04 | 1 191 | 1 131 | 1 101 | Land | | | XCS30/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |---------------------------------|----------------|--------------|-------|-------|-------------|---------------| | I/O (D3 ††) | P65 | P92 | P132 | P152 | K18 | 511 ‡ | | 1/0 | P66 | P93 | P133 | P153 | K17 | 514 ‡ | | I/O | P67 | P94 | P134 | P154 | J20 | 517 ± | | 1/0 | - | P95 | P135 | P155 | J19 | 520 ± | | 1/0 | - | - | P136 | P156 | J18 | 523 ± | | 1/0 | - | - | P137 | P157 | J17 | 526 ± | | I/O (D2 ††) | P68 | P96 | P138 | P159 | H19 | 529 ‡ | | 1/0 | P69 | P97 | P139 | P160 | H18 | 532 ± | | VCC | - | - | P140 | P161 | VCC* | - | | 1/0 | - | P98 | P141 | P162 | G19 | 535 ± | | 1/0 | _ | P99 | P142 | P163 | F20 | 538 ± | | 1/0 | <u> </u> | - | | P164 | G18 | 541 ‡ | | 1/0 | <u> </u> | _ | _ | P165 | F19 | 544 ‡ | | GND | _ | P100 | P143 | P166 | GND* | - | | 1/0 | <u> </u> | 1 100 | 1 170 | P167 | F18 | 547 ‡ | | 1/0 | _ | _ | P144 | P168 | E19 | 550 ‡ | | 1/0 | <u> </u> | <u> </u> | P145 | P169 | D20 | 553 ± | | 1/0 | - | <u> </u> | P145 | P170 | E18 | 556 ‡ | | 1/0 | <u> </u> | | P147 | P171 | D19 | 559 ± | | 1/0 | <del>-</del> - | - | P147 | P171 | C20 | 562 ± | | | -<br>P70 | -<br>D404 | P148 | P172 | | | | I/O (D1 ††) | | P101 | | | E17 | 565 ‡ | | 1/0 | P71 | P102 | P150 | P174 | D18 | 568 ‡ | | 1/0 | - | P103 | P151 | P175 | C19 | 571 ‡ | | 1/0 | | P104 | P152 | P176 | B20 | 574 ‡ | | I/O (D0 ††, DIN) | P72 | P105 | P153 | P177 | C18 | 577 ‡ | | I/O, SGCK4 †,<br>GCK6 †† (DOUT) | P73 | P106 | P154 | P178 | B19 | 580 ‡ | | CCLK | P74 | P107 | P155 | P179 | <b>A</b> 20 | - | | VCC | P75 | P108 | P156 | P180 | VCC* | - | | O, TDO | P76 | P109 | P157 | P181 | <b>A</b> 19 | 0 | | GND | P77 | P110 | P158 | P182 | GND* | - | | 1/0 | P78 | P111 | P159 | P183 | B18 | 2 | | I/O, PGCK4 †,<br>GCK7 †† | P79 | P112 | P160 | P184 | B17 | 5 | | 1/0 | - | P113 | P161 | P185 | C17 | 8 | | I/O | - | P114 | P162 | P186 | D16 | 11 | | I/O (CS1) †† | P80 | P115 | P163 | P187 | A18 | 14 | | 1/0 | P81 | P116 | P164 | P188 | A17 | 17 | | 1/0 | | - | P165 | P189 | C16 | 20 | | 1/0 | <u> </u> | _ | - | P190 | B16 | 23 | | 1/0 | _ | P117 | P166 | P191 | A16 | 26 | | 1/0 | <u> </u> | | P167 | P192 | C15 | 29 | | 1/0 | <u> </u> | | P168 | P193 | B15 | 32 | | 1/0 | - | <del>-</del> | P169 | P194 | A15 | 35 | | GND | <del> </del> | P118 | P170 | P194 | GND* | - 55 | | I/O | - | P118 | P170 | P196 | B14 | 38 | | 1/0 | - | P119 | P171 | P197 | A14 | | | | | P 120 | P1/2 | | | 41 | | I/O | - | - | - | P199 | C13 | 44 | | | <u> </u> | - | | P200 | B13 | 47 | | VCC | - | | P173 | P201 | VCC* | - | | 1/0 | P82 | P121 | P174 | P202 | C12 | 50 | | 1/0 | P83 | P122 | P175 | P203 | B12 | 53 | | 1/0 | - | - | P176 | P205 | A12 | 56 | | 1/0 | - | - | P177 | P206 | B11 | 59 | | 1/0 | P84 | P123 | P178 | P207 | C11 | 62 | | XCS30/XL<br>Pad Name | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |----------------------|-------|-------|-------|-------|-------------|---------------| | 1/0 | P85 | P124 | P179 | P208 | A11 | 65 | | 1/0 | P86 | P125 | P180 | P209 | <b>A</b> 10 | 68 | | 1/0 | P87 | P126 | P181 | P210 | B10 | 71 | | GND | P88 | P127 | P182 | P211 | GND* | - | #### † = 5V Spartan only #### †† = 3V SpartanXL only ‡ The "PWRDWN" on the XCS30XL is not part of the Boundary Scan chain. For the XCS30XL, subtract 1 from all Boundary Scan numbers from GCK3 on (295 and higher). #### Additional XCS30/XL Package Pins #### PQ240 | GND Pins | | | | | | | | | | |----------|--------------------|-----|-----|------|------|--|--|--|--| | P22 | P37 | P83 | P98 | P143 | P158 | | | | | | P204 | P219 | - | - | - | - | | | | | | | Not Connected Pins | | | | | | | | | | P195 | | | | | | | | | | #### 2/12/98 #### BG256 | VCC Pins | | | | | | | | | | |------------|------------|-------------|------------|------------|-----|--|--|--|--| | C14 | D6 | D7 | D11 | D14 | D15 | | | | | | E20 | F1 | F4 | F17 | G4 | G17 | | | | | | K4 | L17 | P4 | P17 | P19 | R2 | | | | | | R4 | R17 | U6 | U7 | U10 | U14 | | | | | | U15 | <b>V</b> 7 | <b>W</b> 20 | - | - | - | | | | | | | • | GND | Pins | | | | | | | | <b>A</b> 1 | B7 | D4 | D8 | D13 | D17 | | | | | | G20 | H4 | H17 | N3 | N4 | N17 | | | | | | U4 | U8 | U13 | U17 | W14 | - | | | | | | | • | Not Conne | ected Pins | | | | | | | | <b>A</b> 7 | A13 | C8 | D12 | H20 | J3 | | | | | | J4 | M4 | M19 | <b>V</b> 9 | <b>W</b> 9 | W13 | | | | | | Y13 | - | - | - | - | - | | | | | | 6/4/97 | | • | | | - | | | | | <sup>11/20/98 \*</sup> Pads labelled GND\* or VCC\* are internally bonded to Ground or VCC planes within the package. ### Pin Locations for XCS40 & XCS40XL Devices | XCS40/XL<br>Pad Name | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |----------------------|----------|------------|------------|---------------| | VCC | P183 | P212 | VCC* | - | | 1/0 | P184 | P213 | C10 | 86 | | 1/0 | P185 | P214 | D10 | 89 | | 1/0 | P186 | P215 | <b>A</b> 9 | 92 | | 1/0 | P187 | P216 | B9 | 95 | | 1/0 | P188 | P217 | C9 | 98 | | 1/0 | P189 | P218 | D9 | 101 | | 1/0 | P190 | P220 | A8 | 104 | | 1/0 | P191 | P221 | B8 | 107 | | I/O | - | - | C8 | 110 | | 1/0 | - | - | A7 | 113 | | VCC | P192 | P222 | VCC* | - | | 1/0 | - | P223 | <b>A</b> 6 | 116 | | 1/0 | - | P224 | C7 | 119 | | 1/0 | P193 | P225 | B6 | 122 | | 1/0 | P194 | P226 | <b>A</b> 5 | 125 | | GND | P195 | P227 | GND* | - | | 1/0 | P196 | P228 | C6 | 128 | | I/O | P197 | P229 | B5 | 131 | | 1/0 | P198 | P230 | A4 | 134 | | 1/0 | P199 | P231 | C5 | 137 | | I/O | P200 | P232 | B4 | 140 | | 1/0 | P201 | P233 | A3 | 143 | | 1/0 | P202 | P234 | D5 | 152 | | I/O | P203 | P235 | C4 | 155 | | I/O | P204 | P236 | B3 | 158 | | 1/0 | P205 | P237 | B2 | 161 | | I/O | P206 | P238 | A2 | 164 | | I/O, SGCK1 †, | P207 | P239 | C3 | 167 | | GCK8 †† | P207 | P239 | 53 | 167 | | VCC | P208 | P240 | VCC* | | | GND | P1 | P1 | GND* | - | | I/O, PGCK1 †, | P2 | P2 | B1 | 170 | | GCK1 <del> </del> | F2 | | D1 | 170 | | 1/0 | P3 | P3 | C2 | 173 | | 1/0 | P4 | P4 | D2 | 176 | | I/O | P5 | P5 | D3 | 179 | | 1/O, TDI | P6 | P6 | E4 | 182 | | I/O, TCK | P7 | P7 | C1 | 185 | | I/O | P8 | P8 | D1 | 194 | | 1/0 | P9 | P9 | E3 | 197 | | I/O | P10 | P10 | E2 | 200 | | | P11 | P11 | E1 | | | I/O<br>I/O | P11 | | | 203<br>206 | | 1/0 | P12<br>- | P12<br>P13 | F3 | | | | | | F2 | 209 | | GND | P13 | P14 | GND* | | | 1/0 | P14 | P15 | G3 | 212 | | I/O TMS | P15 | P16 | G2 | 215 | | I/O, TMS | P16 | P17 | G1 | 218 | | 1/0 | P17 | P18 | H3 | 221 | | VCC | P18 | P19 | VCC* | - | | 1/0 | - | P20 | H2 | 224 | | 1/0 | - | P21 | H1 | 227 | | 1/0 | - | - | J4 | 230 | | 1/0 | - | - | J3 | 233 | | 1/0 | P19 | P23 | J2 | 236 | | 1/0 | P20 | P24 | J1 | 239 | | 1/0 | P21 | P25 | K2 | 242 | | 1/0 | P22 | P26 | КЗ | 245 | | 1/0 | P23 | P27 | K1 | 248 | | 1/0 | P24 | P28 | L1 | 251 | | GND | P25 | P29 | GND* | - | | VCC | P26 | P30 | VCC* | - | | 1/0 | P27 | P31 | L2 | 254 | | 1/0 | | | | | | 1/0 | P28 | P32<br>P33 | L3 | 257 | | XCS40/XL | Docco. | DOC-10 | DOSES | Bndry | |--------------------------|--------|--------|------------|-------| | Pad Name | PQ208 | PQ240 | BG256 | Scan | | I/O | P30 | P34 | M1 | 263 | | I/O | P31 | P35 | M2 | 266 | | I/O | P32 | P36 | М3 | 269 | | 1/0 | - | - | M4 | 272 | | 1/0 | - | P38 | N1 | 278 | | 1/0 | - | P39 | N2 | 281 | | VCC | P33 | P40 | VCC* | - | | 1/0 | P34 | P41 | P1 | 284 | | I/O | P35 | P42 | P2 | 287 | | I/O | P36 | P43 | R1 | 290 | | I/O | P37 | P44 | P3 | 293 | | GND | P38 | P45 | GND* | | | 1/0 | - | P46 | T1 | 296 | | 1/0 | P39 | P47 | R3 | 299 | | 1/0 | P40 | P48 | T2 | 302 | | 1/0 | P41 | P49 | U1 | 305 | | 1/0 | P42 | P50 | T3 | 308 | | 1/0 | P43 | P51 | U2 | 311 | | 1/0 | P44 | P52 | V1 | 320 | | 1/0 | P45 | P53 | T4 | 323 | | 1/0 | P46 | P54 | U3 | 326 | | 1/0 | P47 | P55 | V2 | 329 | | 1/0 | P48 | P56 | W1 | 332 | | I/O, SGCK2 †, | P49 | P57 | V3 | 335 | | GCK2 †† Don't Connect †, | P50 | P58 | W2 | 338 | | M1 †† | F50 | F30 | VVZ | 330 | | GND | P51 | P59 | GND* | _ | | MODE †, M0 †† | P52 | P60 | Y1 | 341 | | VCC | P53 | P61 | VCC* | - | | Don't Connect †, | P54 | P62 | W3 | 342† | | PWRDWN †† | '0' | '02 | "" | O IL | | I/O, PGCK2 †, | P55 | P63 | Y2 | 343 ‡ | | GCK3 †† | | | | | | I/O (HDC) | P56 | P64 | W4 | 346 ‡ | | 1/0 | P57 | P65 | V4 | 349 ‡ | | 1/0 | P58 | P66 | U5 | 352 ‡ | | 1/0 | P59 | P67 | Y3 | 355 ‡ | | I/O ( <u>LDC</u> ) | P60 | P68 | Y4 | 358 ‡ | | 1/0 | P61 | P69 | <b>V</b> 5 | 367 ‡ | | 1/0 | P62 | P70 | <b>W</b> 5 | 370 ‡ | | 1/0 | P63 | P71 | Y5 | 373 ‡ | | 1/0 | P64 | P72 | <b>V</b> 6 | 376 ‡ | | 1/0 | P65 | P73 | W6 | 379 ‡ | | 1/0 | | P74 | Y6 | 382 ‡ | | GND | P66 | P75 | GND* | - | | 1/0 | P67 | P76 | W7 | 385 ‡ | | 1/0 | P68 | P77 | Y7 | 388 ‡ | | 1/0 | P69 | P78 | V8 | 391 ‡ | | 1/0 | P70 | P79 | W8 | 394 ‡ | | VCC | P71 | P80 | VCC* | - | | 1/0 | P72 | P81 | Y8 | 397 ‡ | | 1/0 | P73 | P82 | U9 | 400 ‡ | | 1/0 | - | - | V9 | 403 ‡ | | 1/0 | - | - | <b>W</b> 9 | 406 ‡ | | 1/0 | - | P84 | Y9 | 409 ‡ | | 1/0 | - | P85 | W10 | 412 ‡ | | 1/0 | P74 | P86 | V10 | 415 ‡ | | 1/0 | P75 | P87 | Y10 | 418 ‡ | | 1/0 | P76 | P88 | Y11 | 421 ‡ | | I/O (ĪNĪT) | P77 | P89 | W11 | 424 ‡ | | VCC | P78 | P90 | VCC* | - | | GND | P79 | P91 | GND* | - | | 1/0 | P80 | P92 | V11 | 427 ‡ | | 1/0 | P81 | P93 | U11 | 430 ‡ | | 1/0 | P82 | P94 | Y12 | 433 ‡ | | I/O | P83 | P95 | W12 | 436 ‡ | | XCS40/XL<br>Pad Name | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |----------------------|-------|-------|-------------|---------------| | I/O | P84 | P96 | V12 | 439 ± | | 1/0 | P85 | P97 | U12 | 442 ‡ | | 1/0 | | - | Y13 | 445 ‡ | | 1/0 | _ | - | W13 | 448 ± | | 1/0 | _ | P99 | V13 | 451 ‡ | | 1/0 | _ | P100 | Y14 | 454 ± | | VCC | P86 | P101 | VCC* | - | | 1/0 | P87 | P102 | Y15 | 457 ± | | 1/0 | P88 | P103 | V14 | 460 ‡ | | 1/0 | P89 | P104 | W15 | 463 ± | | 1/0 | P90 | P105 | Y16 | 466 ‡ | | GND | P91 | P106 | GND* | - | | 1/0 | - | P107 | V15 | 469 ‡ | | 1/0 | P92 | P108 | <b>W</b> 16 | 472 ‡ | | 1/0 | P93 | P109 | Y17 | 475 ‡ | | 1/0 | P94 | P110 | <b>V</b> 16 | 478 ‡ | | 1/0 | P95 | P111 | W17 | 481 ‡ | | 1/0 | P96 | P112 | Y18 | 484 ‡ | | 1/0 | P97 | P113 | U16 | 493 ‡ | | 1/0 | P98 | P114 | V17 | 496 ‡ | | 1/0 | P99 | P115 | <b>W</b> 18 | 499 ‡ | | 1/0 | P100 | P116 | Y19 | 502 ‡ | | 1/0 | P101 | P117 | V18 | 505 ‡ | | I/O, SGCK3 †, | P102 | P118 | <b>W</b> 19 | 508 ‡ | | GCK4 †† | 1 | | | | | GND | P103 | P119 | GND* | - | | DONE | P104 | P120 | Y20 | - | | VCC | P105 | P121 | VCC* | - | | PROGRAM | P106 | P122 | V19 | - | | I/O (D7 ††) | P107 | P123 | U19 | 511 ‡ | | I/O, PGCK3 †, | P108 | P124 | U18 | 514 ‡ | | GCK5 ††<br>I/O | P109 | P125 | T17 | 517 ± | | 1/0 | P1109 | P125 | V20 | 520 ‡ | | 1/0 | 1 110 | P127 | U20 | 523 ± | | 1/0 | P111 | P128 | T18 | 526 ‡ | | I/O (D6 ††) | P112 | P129 | T19 | 535 ‡ | | 1/0 | P113 | P130 | T20 | 538 ‡ | | 1/0 | P114 | P131 | R18 | 541 ‡ | | 1/0 | P115 | P132 | R19 | 544 ± | | 1/0 | P116 | P133 | R20 | 547 ± | | 1/0 | P117 | P134 | P18 | 550 ± | | GND | P118 | P135 | GND* | - ' | | 1/0 | - | P136 | P20 | 553 ‡ | | 1/0 | - | P137 | N18 | 556 ‡ | | 1/0 | P119 | P138 | N19 | 559 ‡ | | 1/0 | P120 | P139 | N20 | 562 ‡ | | VCC | P121 | P140 | VCC* | - | | I/O (D5 ††) | P122 | P141 | M17 | 565 ‡ | | 1/0 | P123 | P142 | M18 | 568 ‡ | | 1/0 | - | - | M19 | 574 ‡ | | 1/0 | P124 | P144 | M20 | 577 ‡ | | 1/0 | P125 | P145 | L19 | 580 ‡ | | 1/0 | P126 | P146 | L18 | 583 ‡ | | 1/0 | P127 | P147 | L20 | 586 ‡ | | I/O (D4 ††) | P128 | P148 | K20 | 589 ‡ | | 1/0 | P129 | P149 | K19 | 592 ‡ | | VCC | P130 | P150 | VCC* | - | | GND | P131 | P151 | GND* | - | | I/O (D3 ††) | P132 | P152 | K18 | 595 ‡ | | 1/0 | P133 | P153 | K17 | 598 ‡ | | 1/0 | P134 | P154 | J20 | 601 ‡ | | 1/0 | P135 | P155 | J19 | 604 ‡ | | 1/0 | P136 | P156 | J18 | 607 ‡ | | 1/0 | P137 | P157 | J17 | 610 ‡ | | 1/0 | - | - | H20 | 613 ‡ | | | XCS40/XL<br>Pad Name | PQ208 | PQ240 | BG256 | Bndry<br>Scan | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------|-------|-------------|---------------| | | | D138 | D150 | Hia | | | VCC P140 P161 VCC* - I/O P141 P162 G19 625 ± I/O P142 P163 F20 628 ± I/O - P164 G18 631 ± I/O - P165 F19 634 ± GND P143 P166 GND* - I/O - P167 F18 637 ± I/O P144 P168 E19 640 ± I/O P145 P169 D20 643 ± I/O P144 P168 E19 640 ± I/O P144 P168 D20 643 ± I/O P147 P171 D19 649 ± I/O P147 P171 D19 649 ± I/O P147 P171 D19 643 ± I/O P147 P171 D19 643 ± I/O P150 P173 D18 667 ± | , ,,, | | | | | | | | | | | | | | | | | | 625 ± | | | | | | | | | | | | | | | | GND | | - | | | | | | GND | P143 | | | | | | I/O | - | P167 | F18 | 637 ± | | | 1/0 | P144 | P168 | E19 | | | | I/O | P145 | P169 | D20 | 643 ± | | | I/O | P146 | P170 | E18 | 646 ± | | | 1/0 | P147 | P171 | D19 | 649 ‡ | | | I/O | P148 | P172 | C20 | 652 ± | | | I/O (D1 ††) | P149 | P173 | E17 | 655 ‡ | | | | P150 | P174 | D18 | | | | 1/0 | P151 | P175 | C19 | | | I/O, SGCK4 †, GCK6 †† (DOUT) | 1/0 | P152 | P176 | B20 | | | GCK6 †† (DOUT) P155 P179 A20 - VCC P156 P180 VCC* - O, TDO P157 P181 A19 0 GND P158 P182 GND* - I/O P159 P183 B18 2 I/O, PGCK4 †, GCK7 †† P160 P184 B17 5 GCK7 †† P160 P184 B17 5 I/O, PGCK4 †, GCK7 †† P160 P184 B17 5 I/O P161 P185 C17 8 I/O P162 P186 D16 11 I/O P163 P187 A18 14 I/O P164 P188 A17 17 I/O P165 P189 C16 26 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P191 A16 32 <td>I/O (D0 ††, DIN)</td> <td>P153</td> <td>P177</td> <td>C18</td> <td>673 ‡</td> | I/O (D0 ††, DIN) | P153 | P177 | C18 | 673 ‡ | | CCLK P155 P179 A20 - VCC P156 P180 VCC* - O, TDO P157 P181 A19 0 GND P158 P182 GND* - I/O P159 P183 B18 2 I/O, PGCK4+, GCK7+ P160 P184 B17 5 GCK7++ P160 P185 C17 8 I/O P161 P185 C17 8 I/O P162 P186 D16 11 I/O P163 P187 A18 14 I/O P164 P188 A17 17 I/O P165 P189 C16 26 I/O P-165 P189 C16 26 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O <td>I/O, SGCK4 †,</td> <td>P154</td> <td>P178</td> <td>B19</td> <td>676 ‡</td> | I/O, SGCK4 †, | P154 | P178 | B19 | 676 ‡ | | VCC P156 P180 VCC* - O, TDO P157 P181 A19 0 GND P158 P182 GND* - I/O P159 P183 B18 2 I/O, PGCK4 †, GCK7 †† P160 P184 B17 5 GCK7 †† P160 P184 B17 5 I/O P161 P185 C17 8 I/O P162 P186 D16 11 I/O P162 P186 D16 11 I/O P163 P187 A18 14 I/O P164 P188 A17 17 I/O P165 P189 C16 26 I/O P165 P189 C16 26 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O | GCK6 †† (DOUT) | | | | | | O, TDO P157 P181 A19 0 GND P158 P182 GND* - I/O P159 P183 B18 2 I/O PGCK4 †, P160 P184 B17 5 GCK7 †† P160 P184 B17 5 I/O P161 P185 C17 8 I/O P162 P186 D16 11 I/O P162 P186 D16 11 I/O P163 P187 A18 14 I/O P164 P188 A17 17 I/O P165 P189 C16 26 I/O P165 P189 C16 26 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O P169 P194 A15 41 | CCLK | P155 | P179 | <b>A</b> 20 | - | | GND | VCC | P156 | P180 | VCC* | - | | | O, TDO | P157 | P181 | A19 | 0 | | I/O, PGCK4 +, GCK7 + | GND | P158 | P182 | GND* | - | | GCK7 †† I/O P161 P185 C17 8 I/O P162 P186 D16 11 I/O P162 P186 D16 11 I/O P163 P187 A18 14 I/O P164 P188 A17 17 I/O P165 P189 C16 26 I/O P165 P189 C16 26 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O P168 P193 B15 38 I/O P169 P194 A15 41 GND P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P199 C13 50 <td< td=""><td>1/0</td><td>P159</td><td>P183</td><td>B18</td><td>2</td></td<> | 1/0 | P159 | P183 | B18 | 2 | | | | P160 | P184 | B17 | 5 | | | 1/0 | P161 | P185 | C17 | 8 | | | 1/0 | P162 | P186 | D16 | 11 | | I/O P165 P189 C16 26 I/O - P190 B16 29 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O P172 P198 C13 50 I/O P172 P199 C13 50 I/O P173 P200 B13 53 VCC P173 P201 VCC* - I/O P174 P202 C12 62 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176< | I/O (CS1 ††) | P163 | P187 | A18 | 14 | | I/O - P190 B16 29 I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O P172 P198 A14 47 I/O P172 P198 A14 47 I/O P172 P198 A14 47 I/O P172 P198 A14 47 I/O P173 P200 B13 53 VCC P173 P201 VCC* - I/O P174 P202 C12 62 I/O P174 P202 C12 62 I/O P175< | 1/0 | P164 | P188 | A17 | 17 | | I/O P166 P191 A16 32 I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O P172 P199 C13 50 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - A13 56 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P178 <t< td=""><td>9</td><td>P165</td><td>P189</td><td>C16</td><td>26</td></t<> | 9 | P165 | P189 | C16 | 26 | | I/O P167 P192 C15 35 I/O P168 P193 B15 38 I/O P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P178 P207 C11 74 I/O P178 P208 A11 77 I/O P180 <t< td=""><td>1/0</td><td></td><td>P190</td><td></td><td>29</td></t<> | 1/0 | | P190 | | 29 | | I/O P168 P193 B15 38 I/O P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - A13 56 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 <t< td=""><td>9</td><td>P166</td><td>P191</td><td><b>A</b>16</td><td>32</td></t<> | 9 | P166 | P191 | <b>A</b> 16 | 32 | | I/O P169 P194 A15 41 GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 <t< td=""><td></td><td></td><td></td><td></td><td>35</td></t<> | | | | | 35 | | GND P170 P196 GND* - I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | P168 | P193 | B15 | 38 | | I/O P171 P197 B14 44 I/O P172 P198 A14 47 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | | P194 | | 41 | | I/O P172 P198 A14 47 I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | | | GND* | - | | I/O - P199 C13 50 I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | | | | | | I/O - P200 B13 53 VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | P172 | | | | | VCC P173 P201 VCC* - I/O - - A13 56 I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | - | | | | | I/O - - A13 56 I/O - - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | - | | | 53 | | I/O - - D12 59 I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | P173 | P201 | | | | I/O P174 P202 C12 62 I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | - | - | | 56 | | I/O P175 P203 B12 65 I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | | - | | | | | I/O P176 P205 A12 68 I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | P174 | P202 | C12 | 62 | | I/O P177 P206 B11 71 I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | | | | | | I/O P178 P207 C11 74 I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | | | | | | I/O P179 P208 A11 77 I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | | | | | | I/O P180 P209 A10 80 I/O P181 P210 B10 83 | 1/0 | | | | | | I/O P181 P210 B10 83 | 1/0 | | | | | | | | | | | 80 | | GND P182 P211 GND* - | | | | | 83 | | | GND | P182 | P211 | GND* | - | <sup>\*</sup> Pads labelled GND\* or VCC\* are internally bonded to Ground or VCC planes within the package. <sup>† = 5</sup>V Spartan only <sup>†† = 3</sup>V SpartanXL only <sup>‡</sup> The "PWRDWN" on the XCS40XL is not part of the Boundary Scan chain. For the XCS40XL, subtract 1 from all Boundary Scan numbers from GCK3 on (343 and higher). ### Additional XCS40/XL Package Pins #### PQ240 | GND Pins | | | | | | | |--------------------|------|-----|-----|------|------|--| | P22 | P37 | P83 | P98 | P143 | P158 | | | P204 | P219 | - | | | | | | Not Connected Pins | | | | | | | | P195 | - | - | - | - | - | | | 2/12/98 | | | | | | | #### BG256 | VCC Pins | | | | | | | |----------|-----|-------------|-----|-----|-----|--| | C14 | D6 | D7 | D11 | D14 | D15 | | | E20 | F1 | F4 | F17 | G4 | G17 | | | K4 | L17 | P4 | P17 | P19 | R2 | | | R4 | R17 | U6 | U7 | U10 | U14 | | | U15 | V7 | <b>W</b> 20 | - | - | - | | | GND Pins | | | | | | | | A1 | B7 | D4 | D8 | D13 | D17 | | | G20 | H4 | H17 | N3 | N4 | N17 | | | U4 | U8 | U13 | U17 | W14 | - | | 6/17/97 ## **Product Availability** Table 19 shows the packages and speed grades for Spartan Series devices. Table 20 shows the number of user I/Os available for each device/package combination. Table 19: Component Availability Chart for Spartan Series FPGAs | | PINS | 84 | 100 | 144 | 208 | 240 | 256 | |----------|------|-------------|-------------|-------------|-------------|-------------|------------| | | TYPE | Plast. PLCC | Plast. VQFP | Plast. TQFP | Plast. PQFP | Plast. PQFP | Plast. BGA | | Device | CODE | PC84 | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | | XCS05 | -3 | С | С, І | | | | | | 70000 | -4 | С | С | | | | | | XCS10 | -3 | С | C, I | С | | | | | 7,0010 | -4 | С | С | С | | | | | XCS20 | -3 | | С | C, I | C, I | | | | 70020 | -4 | | С | С | С | | | | XCS30 | -3 | | С | C, I | C, I | С | С | | 7,0000 | -4 | | С | С | С | С | С | | XCS40 | -3 | | | | C, I | С | C | | 70040 | -4 | | | | С | С | С | | XCS05XL | -4 | С | C, I | | | | | | XO303XL | -5 | (C) | (C) | | | | | | XCS10XL | -4 | С | С, І | С | | | | | ACCIONE | -5 | (C) | (C) | (C) | | | | | XCS20XL | -4 | | С | C, I | C, I | | | | AUGZUAL | -5 | | (C) | (C) | (C) | | | | XCS30XL | -4 | | С | C, I | C, I | С | С | | | -5 | | (C) | (C) | (C) | (C) | (C) | | XCS40XL | -4 | | | | C, I | С | С | | 11/20/98 | -5 | | | | (C) | (C) | (C) | 11/20/98 C = Commercial $T_J = 0^{\circ}$ to +85°C I = Industrial $T_J$ = -40°C to +100°C () Parentheses indicate future product plans Table 20: User I/O Chart for Spartan Series FPGAs | | Max | Package Type | | | | | | |---------|-----|--------------|-------|-------|-------|-------|-------| | Device | I/O | PC84 | VQ100 | TQ144 | PQ208 | PQ240 | BG256 | | XCS05 | 80 | 61 | 77 | | | | | | XCS10 | 112 | 61 | 77 | 112 | | | | | XCS20 | 160 | | 77 | 113 | 160 | | | | XCS30 | 192 | | 77 | 113 | 169 | 192 | 192 | | XCS40 | 224 | | | | 169 | 192 | 205 | | XCS05XL | 80 | 61 | 77 | | | | | | XCS10XL | 112 | 61 | 77 | 112 | | | | | XCS20XL | 160 | | 77 | 113 | 160 | | | | XCS30XL | 192 | | 77 | 113 | 169 | 192 | 192 | | XCS40XL | 224 | | | | 169 | 192 | 205 | 11/20/98 # **Ordering Information** Table 21: Revisions | Version | Description | |----------|-----------------------------------------------------------------------------------------------------------------------| | 4/2/98 | Rev. 1.0 (Preliminary) Added timing specifications for 5V devices, updated PQ208 pinout tables, improved description. | | 5/31/98 | Rev. 1.1 (Preliminary) Updated all timing specifications. | | 9/28/98 | Rev. 1.2 (Preliminary) Added SpartanXL architecture description, changed speed grades to -4/-5 | | 11/20/98 | Rev. 1.3 (Preliminary) Added SpartanXL specs and Power Down | | 1/6/99 | Rev. 1.4 (Preliminary) All SpartanXL -4 specs designated Preliminary with no changes |