# Configuration Bitstream Mapping with Programmable Resources on Spartan-3A FPGA using XDL and FAR

Pravin N. Matte<sup>#1</sup>, Dr. Dilip D. Shah<sup>\*2</sup>

<sup>#</sup> Department of Electronics and Telecommunication,
 G.H. Raisoni College of Engineering and Management, Wagholi, Pune, India
 <sup>\*</sup>Department of Electronics and Telecommunication Engineering,
 JSPMs Imperial College of Engineering and Research, Wagholi, Pune, India.
 <sup>1</sup> pravin.matte@raisoni.net; <sup>2</sup>dilip.d.shah@gmail.com

*Abstract*— Configuration bitstream in FPGA is specific to vendor. It is difficult to understand bitstream format and eventually impossible to know how bits are placed in LUTs, flip flop, multiplexer, input and output interconnection network in FPGA. Normally user is not interested in knowing internals of FPGA, however it is believed that by opening the internals of FPGA, development would become very fast as it is achieved by open source community. In this paper we have proposed a simplified methodology to map configuration bitstream to its programmable resources targeting Spartan-3A FPGA. A simple AND gate design implemented in VHDL under different constraints. Correlation between different locations of AND gate is established with frame address register, XDL file report, FPGA editor and device view in PlanAhead.

Keyword - Bitstream, Configuration memory, FPGA, FAR, NCD, XDL

# I. INTRODUCTION

It is widely believed that the analysis of bitstream format is a tedious task. Increase in the complexity of digital circuit design demand for FPGA with more resources is increasing. FPGA has applications in wide variety of domains like space, telecommunications, networking, handheld devices etc. FPGA based industries demand CAD tools for design and development to meet time-to-market design metric. Like in open source communities, FPGAs development techniques are not open and certain things are vendor specific. Hence third party tools development has limited scope. If bitstream format would have been opened to users then possibility of cloning the device and IPs would have increased. Development on design tool side demands FPGAs internal details. Knowing FPGA bitstream definitely helps further development. Beside this, research communities and academicians are interested in knowing bitstream details. Limited work has been done in this direction.

A bitstream is a file that contains programming information for an FPGA. FPGAs bitstream is generated by CAD tools and configures (reconfigures) resources on FPGA fabrics to implement desired design. Fig. 1 depicts general structure of bitstream file during configuration. Bitstream file is viewed as file containing header for device name, architecture, and date information. After the start header it has synchronization word, device identification along with various device initialization commands. Most of the data is for actual configuration of FPGA. Last part of bitstream again contains command registers like CRC, DESYNC etc. and then FPGA goes into start sequence operation. These details are contains in bitstream file. Each FPGA device has its own bitstream format to configure itself.



Fig. 1 General structure of bitstream file

Though fair amount of work is done to know bitstream format, this paper presents simple approach to understand FPGA bitstream and its mapping with resources on FPGA. Section II focused on related work done. FPGA generic architecture, design flow and bitstream format is described in section III. Preparation of background information is presented in section IV. A simple approach to analyze FPGA bitstream is elaborated in section V targeting Spartan-3A Xilinx FPGA. Results are discussed in section VI. At the end paper is concluded with conclusion in section VII.

#### **II. RELATED WORK**

FPGAs configuration bitstream is the final output of any VLSI CAD tool design methodology. In [1] database of mapping bitstream to their functional role is prepared using theoretical algorithm. This database is utilized to produce net list from any bitstream. The work shown in [1] is for Xilinx Virtex-II devices. Documentation on Xilinx Design Language (XDL) is scare. XDL provide access to almost all features of Xilinx devices. Various use cases and elaborated documentation provided in [2]. In [3], a method is presented to generate NCD from bitstream file.

Due to availability of official documents on internal architecture and configuration, it was possible for researchers to build development tools for FPGA. Alex and Clifford reversed engineered Lattice Semiconductor's iCE40 FPGA. This was first step towards the source tool chain for single FPGA [4]. "Bil" a reverse engineering tool presented in [5] retrieves netlist from bitstream for certain section of bitstream. VPR [6] performs packing, placement and routing. It maps technology mapped netlist to hypothetical FPGA specified by user. A low level bitstream manipulation tools BitMAT [7] and "BITMAN" [8] targeted Virtex- II FPGAs. A Java library named "abit" for direct manipulation of Atmel FPSLIC series bitstream and partial reconfiguration found in [9]. In [10] an open source tool based on library of micro-bitstream created for primitives and merged for creating larger design with simple merging operations. An open source tool set for reconfigurable computing presented in [11] is based on C++. Torc infrastructure can read, write, and manipulate EDIF and XDL netlist as well as Xilinx bitstream packets (but not configuration frame internals). Currently supported devices include all Virtex, VirtexE, Virtex2 pro, Virtex5, Virtex6, Virtex6L devices. PARBIT a tool in [12] extracts and relocates Virtex partial bitstream. The RapidSmith project [13] provide exclusive platform for implementing experimental idea, algorithms on Xilinx FPGAs.

Knowing bitstream format opens innovative approach for development in FPGA technology. Mostly, such type of work depends upon available documentation from vendor. But the vendor does open fair amount of information for end users and keeps certain information closed to avoid cloning of their devices. In this paper we have proposed a simple approach to map configuration bitstream to FPGA resources.

## III. FPGA GENERIC ARCHITECTURE AND DESIGN FLOW

FPGA means field programmable gate array. Any arbitrary digital function is implemented in FPGA. It can be programmed to implement desired hardware on it. Basic building blocks of FPGAs are configuration logic blocks (CLBs), I/O blocks, switch blocks, routing resources, memory blocks, and other dedicated functional block. The Fig. 2 gives general architecture of FPGA and Spartan -3A FPGA layout as viewed in PlanAhead design tool.



Fig. 2 (a) General architecture of FPGA

Fig. 2 (b) Spartan-3A layout in Plan Ahead

Fig. 2 FPGA architecture and PlanAhead view of Spartan-3A layout

A typical FPGA design flow consists of different stages like design entry, synthesis, mapping, place and route and bitstream generation. Fig. 3 depicts FPGA design flow. Three main stages of design are design entry and synthesis, design implementation and design verification [14]. Design entry is made either in schematic capture or in hardware design languages or with both. Synthesis is the process by which a given design is converted to logical design format (EDIF) or NGC file (by using Xilinx Synthesis Technology GUI). Design implementation converts the logical design format into Native Circuit Description (NCD) file. NCD file contains the physical information of FPGAs. The bitstream file generated after this stage is used to program the FPGA. In the last stage designer verifies whether the circuit meets timing and functionality requirements



#### Fig. 3 Typical FPGA design flow

#### IV. BACKGROUND: HDL-NCD-XDL

Listing 1 shows VHDL codes for two input AND gate. DPI1 and DIP2 are the two input ports and LED1 is the output port. Fig. 4 represents RTL schematic and Fig. 5 shows schematic of AND gate generated after VHDL codes compiled on Xilinx ISE Design Suite 14.7. Device utilization summary is given in Table 1. Other relevant information is generated by the tool. Here we gathered information necessary for mapping of FPGA configuration bitstream to its resources. "andGate.ncd" file is located in project folder directory. It is Native Circuit Description file which contains how HDL codes are mapped to physical resources like LUTs, flip flops, I/Os, routing etc. on FPGA. But it is not in human readable format. Xilinx Design Language is used to convert NCD file into human readable format. A command like "xdl –ncd2xdl andGate.ncd" converts NCD to XDL file. and Gate.xdc contains human readable information. A brief introduction of XDL is given by illustrating "andGate" example.

Listing 1. VHDL code of AND gate





Fig.4 RTL schematic



Fig. 5 Schematic of AND gate

| Logic Utilization                              | used | Available | Utilization |
|------------------------------------------------|------|-----------|-------------|
| Number of 4 input LUTs                         | 1    | 1,408     | 1%          |
| Number of occupied Slices                      | 1    | 704       | 1%          |
| Number of Slices containing only related logic | 1    | 1         | 100%        |
| Number of Slices containing unrelated logic    | 0    | 1         | 0%          |
| Total Number of 4 input LUTs                   | 1    | 1,408     | 1%          |
| Number of bonded <u>IOBs</u>                   | 3    | 108       | 2%          |
| Average Fanout of Non-Clock Nets               | 1.00 |           |             |

#### Table 1. Device Utilization Summary

### Xilinx Design Languages (XDL)

The NCD file contains all necessary information to implement the design on FPGA. But the NCD file format is Xilinx specific and it is not possible to analyze it. However, Xilinx has provided Xilinx Design Language in Xilinx ISE Design suite. It converts NCD file into XDL file which is human readable. Less information is available on XDL documentation.

#### XDL File Format

An XDL file is a text file contains information about the name of the design, intended Xilinx FPGA device and cfg attribute which allows user to configure the certain aspects of the design. It also lists logical slices, nets for routing design. The keyword "inst" is used to begin the instance statement. Instance is the instance of FPGA primitive. After the instance keyword the name of the instance is mentioned. It is followed by instance type. Placement of the slice is described by the keyword "placed" or "unplaced" after the instance type. A string beginning with "cfg" keyword used to configure the LUT contents and other functionality. Instance statement for DIP1 in case of AND gate example is given below.

inst "DIP1" "IBUF", placed RIOIS\_X17Y1 P78

```
cfg " DELAY_ADJ_ATTRBOX::FIXED GTSATTRBOX::#OFF IBUF_DELAY_VALUE::DLY0
```

ICEINV::#OFF ICLK1INV::#OFF ICLK2INV::#OFF IDDRIN\_MUX::#OFF IFD\_DELAY\_VALUE::DLY0 IFF1::#OFF IFF1\_INIT\_ATTR::#OFF IFF1\_SR\_ATTR::#OFF IFF2::#OFF IFF2\_INIT\_ATTR::#OFF IFF2\_SR\_ATTR::#OFF IFFATTRBOX::#OFF IFFDMUX::#OFF IMUX::1 IOATTRBOX::LVCMOS25 IREV\_USED::#OFF ISR\_USED::#OFF MISRATTRBOX::#OFF MISR\_CLK\_SELECT::#OFF O1INV::#OFF 01\_DDRMUX::#OFF 02INV::#OFF 02\_DDRMUX::#OFF OCEINV::#OFF ODDROUT1\_MUX::#OFF ODDROUT2\_MUX::#OFF OFF1::#OFF OFF1\_INIT\_ATTR::#OFF OFF1\_SR\_ATTR::#OFF OFF2::#OFF OFF2\_INIT\_ATTR::#OFF OFF2\_SR\_ATTR::#OFF OFFATTRBOX::#OFF OMUX::#OFF OREV\_USED::#OFF OSR\_USED::#OFF OTCLK1INV::#OFF OTCLK2INV::#OFF PCICE\_MUX::#OFF PCIRDY\_MUX::#OFF T2INV::#OFF TCEINV::#OFF TFF1::#OFF TFF1\_INIT\_ATTR::#OFF TFF1\_SR\_ATTR::#OFF TFF2\_INIT\_ATTR::#OFF TFF2\_SR\_ATTR::#OFF TFFATTRBOX::#OFF TMUX::#OFF TREV\_USED::#OFF TSMUX::#OFF TSR\_USED::#OFF T\_USED::#OFF DELAY\_ADJ\_BBOX:DIP1.DELAY\_ADJ: INBUF:DIP1\_IBUF: PAD:DIP1: "

;

The logic blocks are interconnected by the nets. FPGA fabric contains the static wires. The nets are used for routing purpose. A net has "outpin" as one starting point and "inpin" as endpoints (it can be multiple). The configuration in FPGAs routing structure is the connection between these nets. In Xilinx terminology these are called pips (programmable interconnect points). The inpin and outpin are connected by pip declaration. A set of pips declarations constitutes a single net. Pip is declared as "pip LOC S -> E" where pip is keyword, LOC is the location of pip, S is the starting point and E is the endpoint of the wire. Finally summary statements give statics of modules, instances and nets used in the design. Listing 2 summaries the description of XDL file format for "andGate" example compiled for XC3S50A Spartan-3A FPGA. Latter in the paper this design is named as "default" as it is compiled without any constraint.

Listing 2. XDL file from NCD file for AND gate default design example.

```
net "DIP2", cfg "_BELSIG:PAD,PAD,DIP2:DIP2",
                                                   ____
     # XDL NCD CONVERSION MODE $Revision: 1.01$
                                                                net "DIP2_IBUF",
     # time: Sat Jan 27 00:55:22 2018
                                                                 outpin "DIP2" I,
     # ----
                                                                 inpin "LED1_OBUF" G4.
     # The syntax for the design statement is:
                                                                 pip BIOIS_X16Y0 I1_PINWIRE -> IOIS_Y1,
     design "andGate" xc3s50atq144-5 v3.2,
                                                                 pip BIOIS_X16Y0 IOIS_Y1 -> OMUX15,
                                                                 pip CLB_X16Y1 G4_B1 -> G4_B_PINWIRE1,
     cfg
     _DESIGN_PROP::PK_NGMTIMESTAMP:1516987046"
                                                                 pip CLB_X16Y1 OMUX_N15 -> G4_B1,
                                                                net "LED1", cfg "_BELSIG:PAD,PAD,LED1:LED1",
     # ==
inst "DIP1" "IBUF", placed RIOIS_X17Y1 P78
inst "DIP2" "IBUF",placed BIOIS_X16Y0 P72
                                                                net "LED1_OBUF"
inst "LED1" "IOB",placed RIOIS_X17Y1 P76
inst "LED1_OBUF" "SLICEL",placed CLB_X16Y1
                                                                 outpin "LED1_OBUF" Y,
                                                                 inpin "LED1" O1,
                                                                 pip CLB_X16Y1 Y1 -> E2BEG4,
SLICE_X23Y0
                                                            pip RIOIS_X17Y1 E2MID4 -> IOIS_G3_B0, ;
     net "DIP1 IBUF",
                                                                # =
                                                                # SUMMARY
      outpin "DIP1" I.
      inpin "LED1_OBUF" G1,
                                                                # Number of Module Defs: 0
     pip CLB_X16Y1 G1_B1 -> G1_B_PINWIRE1,
                                                                # Number of Module Insts: 0
      pip CLB_X16Y1 OMUX_W1 \rightarrow G1_B1,
                                                                # Number of Primitive Insts: 4
      pip RIOIS_X17Y1 I1_PINWIRE -> IOIS_Y1,
                                                                # Number of Nets: 6
      pip RIOIS_X17Y1 IOIS_Y1 -> OMUX1,
```

Note: In the above listing "cfg" keyword and its listing is not included.

# V. METHODOLOGY AND IMPLEMENTATION

Initially an AND gate was designed and implemented in VHDL hardware description language without any constraints. Latter same VHDL codes were used to implement AND gate design with different constraints so that AND gate will map to different location. The pblock is used for restricting AND gate on FPGA layout along with defined I/O pins location is mentioned in the Table 2. In each case, design is compiled on Xilinx ISE 14.7 Design Suite [15]. Ensure that generate debug is enabled in process properties dialog box. This is shown in Fig. 6. This will generate FAR address for each configuration frame.

Fig. 7 shows location of CLBs on FPGA layout selected for experimentation for default, const\_1 and const\_2. After compiling same AND gate design with different constraints of slices and I/O pins assignment, a bit file database is prepared. Each "andGate.bit" file is analysed separately. Configuration bitstream file is opened in Hex Editor Neo. A frame containing all zero in bitstream file is selected. After that with the help of hex editor all such frames containing zeros are found out. An observation of starting portion and ending portion of the frame is noted. The important part of bitstream is the configuration data and its addresses. For all the designs, FAR addresses containing configuration information are tabulated. Frame addresses which points to zero configuration information are neglected. This process will separate out bitstream information portion is pointed by FAR register addresses. PlanAhead tool is used to observe device view for mapped resources on Spartan-3A in FPGA layout. An FPGA editor [16] is used to view how resources are placed and routed.

| Table 2. | Floor planning | of AND gat | e and constraints |
|----------|----------------|------------|-------------------|
|----------|----------------|------------|-------------------|

| Const. No. | Pblock Range              | CLB        | DIP1           | DIP2           | LED1           |
|------------|---------------------------|------------|----------------|----------------|----------------|
| Default    | NIA                       | CLP VIEVI  | RIOSIS_X17Y1   | BIOIS_X16Y0    | RIOIS_X17Y1    |
| Default    | NA                        | CLD_A1011  | P78            | P72            | P76            |
| Const 1    | SLICE V20V28-SLICE V21V20 | CLP V15V15 | RIOSIS_X17Y15  | RIOSIS_X17Y15  | RIOSIS_X17Y14  |
| Collst_1   | SLICE_A20128.SLICE_A21129 | CLB_AIJ11J | P101           | P103           | P104           |
| Const 2    |                           | CLD VIVIC  | TOIOIB_X1Y17   | TOIOIB_X1Y17   | TOIOIB_X1Y17   |
| Collst_2   | SLICE_A0130:SLICE_A1131   | CLD_ATTIO  | P141           | P140           | P143           |
| Const 2    |                           | CLD VIVI   | BIOIB_X1Y0     | BIOIB_X1Y0     | BIOIS_X2Y0 P39 |
| Collst_5   | SLICE_A010.SLICE_A111     | CLD_ATTI   | P37            | P38            | P39            |
| Const 4    |                           | CLP V6V11  | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Collst_4   | SLICE_X10120.SLICE_X11121 | CLB_A0111  | P12            | P13            | P10            |
| Const 5    | SLICE V2V20-SLICE V2V21   | CLP V2V11  | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Collst_5   | SLICE_A2120:SLICE_A3121   | CLD_A2111  | P12            | P13            | P10            |
| Const. 6   | SLICE VAV20.SLICE V5V21   | CLD V2V11  | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Collst_0   | SLICE_A4120:SLICE_A5121   | CLD_A3111  | P12            | P13            | P10            |
| Const. 7   | SLICE VEV20-SLICE V7V21   | CLD VAV11  | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Collst_/   | SLICE_A0120.SLICE_A/121   | CLD_A4111  | P12            | P13            | P10            |

| Const. No. | Pblock Range            | CLB         | DIP1           | DIP2           | LED1           |
|------------|-------------------------|-------------|----------------|----------------|----------------|
| Const 8    | SLICE VAV20-SLICE VOV21 | CLP V5V11   | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Collst_o   | SLICE_X8120.SLICE_X9121 | CLD_AJ111   | P12            | P13            | P10            |
| Comat 0    | STICE VOVOSSIICE VOVOS  | CLD V2V12   | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Collst_9   | SLICE_A2122:SLICE_A3125 | CLD_A2112   | P12            | P13            | P10            |
| Comot 10   | STICE VOVOGELICE VOVOT  |             | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 | LIOIS_PCIX0Y11 |
| Const_10   | SLICE_A2120:SLICE_A3127 | ULD_X2 Y 14 | P12            | P13            | P10            |

ाः Process Properties - General Options

| Category             | Switch Name        | Property Name                             |   |
|----------------------|--------------------|-------------------------------------------|---|
| General Options      | -d                 | Run Design Rules Checker (DRC)            | • |
|                      | -j                 | Create Bit File                           | • |
| Readback Options     | -g Binary:         | Create Binary Configuration File          | • |
| Suspend/Wake Options | -b                 | Create ASCII Configuration File           | • |
|                      | -g IEEE 1532:      | Create IEEE 1532 Configuration File       |   |
|                      | -g Compress        | Enable BitStream Compression              |   |
|                      | -g DebugBitstream: | Enable Debugging of Serial Mode BitStream | • |
|                      | -g CRC:            | Enable Cyclic Redundancy Checking (CRC)   | • |
|                      | -g reset_on_error: | Retry Configuration if CRC Error Occurs   |   |
|                      |                    | Other Bitgen Command Line Options         |   |
|                      | 5                  |                                           |   |

Fig. 6 Enable debugging of bitstream in process properties of generate Programming



B. Const\_1 on device layout

B. Const\_1 zoom view



Fig. 7 Different CLB location selections with constraints

### VI. RESULTS AND DISCUSSION

#### Analysis of Configuration Bitstream

Bitstream files consist of a start header (Fig. 8), configuration data, bitstream final command (Fig.10) and start-up sequence. The start header contains information like design name, target device, file modification time, dummy word, synchronization word, reset CRC, device ID code, etc. The packets contain configuration commands and configuration data. The small state machine in FPGA controls configuration of programmable resources on FPGA. The command register in FPGA is either read or written by configuration information in data frames in bitstream. Always action taken by state machines is as per the command registers data. The data frames are loaded with configuration data as pointed by the frame address register (FAR). Configuration data frames can be, single frame, set of frames or full configuration space. During continuous writing of configuration data into FPGA, the FAR is automatically incremented after every FDRI write [17]. In this case frame length register (FLR) contains the length of data frame. It is written before the initiation of command to load block of data. Finally START, CRC checksum DESYNCH command are executed towards the end of bitstream file as shown in Figure 10 and Figure 11. Figure 8 and Fig. 10 shows starting and ending part of the bitstream file of AND gate example. The interpretation of each word in the frame is explained in Fig. 9 and Fig.11.

| 00000000 | 00   | 01   | 02   | 03   | 04   | 05   | 06   | 07   | 80   | 09   | 0a   | 0b   | 0c   | 0d   | 0e   | Of   |
|----------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| 00000000 | ffff |
| 00000020 | aa99 | 3122 | 0000 | 0000 | 30a1 | 0007 | 2000 | 3161 | 09ee | 3321 | 3c0f | 31a1 | 0049 | 3141 | 2f00 | 31c2 |
| 00000040 | 0221 | 0093 | 30e1 | ffcf | 30c1 | 0081 | 3181 | 0881 | 3201 | 001f | 32c1 | 0005 | 32e1 | 0004 | 32a1 | 000e |
| 00000060 | 3261 | 0000 | 3281 | 0000 | 3341 | 18f2 | 3362 | 0000 | 0000 | 3022 | 0000 | 0000 | 30a1 | 0001 | 5060 | 0000 |
| 0800000  | 004a | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| 000000a0 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| 000000c0 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |

Fig 8 Start portion of bitstream file (AND Gate)

|                                   |             |                               |             |                               |             |                                 |             |                                        |                            |                                                       |                                |                            |                         |                             |                                       |                                 |             |                                            |                            |                            |                              |                                     | •           |
|-----------------------------------|-------------|-------------------------------|-------------|-------------------------------|-------------|---------------------------------|-------------|----------------------------------------|----------------------------|-------------------------------------------------------|--------------------------------|----------------------------|-------------------------|-----------------------------|---------------------------------------|---------------------------------|-------------|--------------------------------------------|----------------------------|----------------------------|------------------------------|-------------------------------------|-------------|
| Dummy word                        | Stine Word  | Type 1 Write 2 words to LOUT  |             | Data Word 0                   | Data Word 1 | Type 1 Write 1 word WCFG        | Data Word 0 | Type 1 NOOP                            | Type 1 Write 1word to COR2 | Data Word 0<br>Tyne 1 Write 1 word to                 | CCLK_FREQ<br>Data Word 0       | Type 1 Write 1 word to FLR | Data Word 0             | Type 1 Write 1 word to COR1 | Data Word 0<br>Type 1 Write 2 word to | IDCODE                          | Data Word 0 | Data Word 1<br>Type 1 Write 1 word to MASK | Data Word 0                | Type 1 Write 1 word to CTL | Data Word 0                  | Type 1 Write 1 word to<br>PWRDN_REG | Data Word 0 |
| HHH                               | 00 V V      | 3122                          |             | 0                             | 0           | 30A1                            | ٢           | 2000                                   | 3161                       | 09EE                                                  | 3321<br>3C0F                   | 31A1                       | 49                      | 3141                        | 2F00                                  | 31C2                            | 221         | 93<br>30E1                                 | FFCF                       | 30C1                       | 81                           | 3181                                | 881         |
| Type 1 write 1 word to HC_OPT_REG | Data word 0 | Type 1 write 1 word to PU_GWE | Data word 0 | Type 1 write 1 word to PU_GTS | Data word 0 | Type 1 write 1 word to MODE_REG | Data word 0 | Type 1 write 1 word to<br>GENERALL REG | Data word 0                | Type 1 write 1 word to<br>GENERAL2 REG<br>Data word 0 | Type 1 write 1 word to SEU_OPT | Data word 0                | Type 1 write 2 words to | EXP_SIGN_KEG                | Data word 0<br>Data word 1            | Type 1 write 2 words to FAR MAJ |             | FAR_MAJ<br>FAR_MIN                         | Type 1 write 1 word to CMD | WCFG command               | Type 2 write 0 words to FDRI | Data Word 0                         | Data Word 1 |
| 3201                              | 001F        | 32C1                          | S           | 320                           | 4           | 32A1                            | 000E        | 3261                                   | 0                          | 3281                                                  | 3341                           | 18F2                       | 3362                    | C                           | 0 0                                   | 3022                            | c           | 0 0                                        | 30A1                       | 1                          | 5060                         | 0                                   | 004A        |
|                                   |             |                               |             |                               |             |                                 | F           | ig.9 D                                 | ecodii                     | ng of st                                              | art port                       | ion of                     | bitst                   | ream                        | file                                  |                                 |             |                                            |                            |                            |                              |                                     | •           |
| 0000-0                            | -           | 0000                          |             |                               |             |                                 |             |                                        | 0000                       | 0000                                                  |                                |                            | 000                     | 000                         |                                       |                                 |             | 0.00                                       |                            |                            |                              |                                     |             |
| 0000e6                            | 20          | 0000                          | 000         | 0                             | 0000        | 000                             | 0           | 0000                                   | 0000                       | 0000                                                  |                                | 0                          | 000                     | 0000                        |                                       | 0 00                            | 000         | 0000                                       |                            | 0                          | 000                          | 0000                                |             |
| 0000e6                            | 60          | 0000                          | 000         | 0                             | 0000        | 000                             | 0           | 0000                                   | 0000                       | 000                                                   |                                | 0                          | 000                     | 0000                        |                                       | 00 3                            | 000         | 001:                                       | 3 77e7                     | 30                         | )a1                          | 000a                                |             |
| 0000e6                            | 80          | 30a1                          | 000         | 3                             | 2000        | 200                             | 0.          | 2000                                   | 2000                       | 30a                                                   | 1 0005                         | 3                          | 0e1                     | 0081                        | 1 300                                 | c1 0                            | 081         | 300                                        | 2 000e                     | 7                          | 9c7                          | 30a1                                |             |
| 0000e6                            | a0          | 000d                          | 200         | 0                             | 2000        | 200                             | 0           | 2000                                   | 2000                       | 200                                                   | 2000                           | 2                          | 000                     | 2000                        | 20                                    | 00 2                            | 000         | 200                                        | 2000                       | 2                          | 000                          | 2000                                |             |
| 0000e6                            | c0          | 2000                          |             |                               |             |                                 |             |                                        |                            |                                                       |                                |                            |                         |                             |                                       |                                 |             |                                            |                            |                            |                              |                                     |             |
| 0000e6                            | e0          |                               |             |                               |             |                                 |             |                                        |                            |                                                       |                                |                            |                         |                             |                                       |                                 |             |                                            |                            |                            | •••                          |                                     |             |
|                                   |             |                               |             |                               |             |                                 |             |                                        |                            |                                                       |                                |                            |                         |                             |                                       |                                 |             |                                            |                            |                            |                              |                                     |             |

| Fig.10 End portion of bitstream file |
|--------------------------------------|
|--------------------------------------|

| Explanation   | CRC Register uses<br>a 22-bit CRC checksum | Data word 0 | Data word 1 | Type 1 write 1 word to CMD | LFRM command | Type 1 NOOP | Type 1 NOOP | Type 1 NOOP | Type 1 NOOP | Type 1 write 1 word to CMD | START command | Masking Register for CTL | Data Word 0 | CRC Register uses a 22-bit<br>CRC checksum | Data word 0 | Data word 1 | Type 1 write 1 word to CMD | Type 1 NOOP (9 NOOP) | DESYNC command | Type 1 NOOP |
|---------------|--------------------------------------------|-------------|-------------|----------------------------|--------------|-------------|-------------|-------------|-------------|----------------------------|---------------|--------------------------|-------------|--------------------------------------------|-------------|-------------|----------------------------|----------------------|----------------|-------------|
| Conf.<br>Data | 3002                                       | 13          | 77E7        | 30A1                       | 3            | 2000        | 2000        | 2000        | 2000        | 30A1                       | S             | 30E1                     | 81          | 3002                                       | 000E        | 79C7        | 30A1                       | 2000                 | 000D           | 2000        |

Fig. 11 Decoding of end portion of bitstream file

#### Decoding of Frame Address Register (FAR)

Frame addresses decoded for each of the design is shown in Table 3. All designs belongs to block type 0 containing CLBs, IOBs information. Major address selects major column and minor address selects memorycell address line within a major column. Column labelled with "M" indicates major address whereas "m" indicates minor address of frames. The addressing scheme gives the idea of the columns where the design lies vertically. Frame addresses and total number of frames required for implementation of design varies according to design type.

|        | defau | lt | Con | st_1 | Cons | st_2 | Cons | t_3 | Cons | t_4 | Cons | t_5 | Cons | st_6 | Cons | t_7 | Cons | st_8 | Cor | nst_9 | Con | st_10 |
|--------|-------|----|-----|------|------|------|------|-----|------|-----|------|-----|------|------|------|-----|------|------|-----|-------|-----|-------|
| S<br>N | М     | m  | М   | m    | М    | m    | М    | m   | М    | m   | М    | М   | М    | m    | М    | m   | М    | m    | М   | m     | М   | m     |
| 1      | 1     | 0  | 1   | 0    | 1    | 0    | 1    | 0   | 1    | 0   | 1    | 0   | 1    | 0    | 1    | 0   | 1    | 0    | 1   | 0     | 1   | 0     |
| 2      | 1     | 1  | 1   | 1    | 1    | 1    | 1    | 1   | 1    | 1   | 1    | 1   | 1    | 1    | 1    | 1   | 1    | 1    | 1   | 1     | 1   | 1     |
| 3      | 14    | 3  | 13  | 0    | 3    | 0    | 3    | 3   | 2    | 0   | 2    | 0   | 2    | 0    | 2    | 0   | 2    | 0    | 2   | 0     | 2   | 0     |
| 4      | 14    | 4  | 13  | 1    | 3    | 1    | 3    | 5   | 2    | 1   | 2    | 1   | 2    | 1    | 2    | 1   | 2    | 1    | 2   | 1     | 2   | 1     |
| 5      | 14    | 5  | 13  | 7    | 3    | 4    | 3    | 6   | 2    | 10  | 2    | 9   | 2    | 10   | 2    | 9   | 2    | 9    | 2   | 10    | 2   | 6     |
| 6      | 14    | 6  | 13  | 9    | 3    | 5    | 3    | 7   | 2    | 14  | 2    | 13  | 2    | 13   | 2    | 11  | 2    | 17   | 2   | 14    | 2   | 7     |
| 7      | 14    | 7  | 13  | 11   | 3    | 6    | 3    | 8   | 2    | 15  | 2    | 15  | 2    | 14   | 2    | 12  | 2    | 18   | 2   | 15    | 2   | 9     |
| 8      | 14    | 8  | 14  | 14   | 3    | 7    | 3    | 9   | 2    | 17  | 3    | 13  | 2    | 15   | 3    | 13  | 4    | 13   | 2   | 17    | 3   | 13    |
| 9      | 14    | 10 | 14  | 15   | 3    | 8    | 3    | 10  | 2    | 18  | 3    | 14  | 4    | 13   | 3    | 14  | 4    | 14   | 2   | 18    | 4   | 0     |
| 10     | 14    | 11 | 15  | 0    | 3    | 9    | 3    | 11  | 8    | 0   | 4    | 0   | 4    | 15   | 5    | 13  | 6    | 13   | 8   | 0     | 4   | 1     |
| 11     | 14    | 12 | 15  | 1    | 3    | 10   | 3    | 12  | 8    | 1   | 4    | 1   | 5    | 0    | 5    | 14  | 6    | 14   | 8   | 1     | 4   | 6     |
| 12     | 14    | 13 | 15  | 9    | 3    | 11   | 3    | 13  | 8    | 8   | 4    | 6   | 5    | 1    | 6    | 0   | 7    | 0    | 8   | 8     | 4   | 8     |
| 13     | 15    | 0  | 15  | 14   | 3    | 12   | 3    | 14  | 8    | 9   | 4    | 8   | 5    | 8    | 6    | 1   | 7    | 1    | 8   | 9     | 4   | 9     |
| 14     | 15    | 1  | 16  | 0    | 3    | 13   | 4    | 0   | 8    | 11  | 4    | 9   | 5    | 9    | 6    | 6   | 7    | 6    | 8   | 11    | 4   | 11    |
| 15     | 15    | 7  | 16  | 1    | 3    | 15   | 4    | 1   | 8    | 12  | 4    | 11  | 5    | 11   | 6    | 9   | 7    | 9    | 8   | 12    | 4   | 12    |
| 16     | 15    | 11 |     |      | 3    | 16   | 4    | 8   | 8    | 13  | 4    | 12  | 5    | 12   | 6    | 12  | 7    | 10   | 8   | 13    |     |       |
| 17     | 15    | 12 |     |      | 3    | 17   | 4    | 10  | 8    | 17  |      |     | 5    | 17   |      |     | 7    | 11   | 8   | 17    |     |       |
| 18     | 16    | 0  |     |      | 3    | 18   | 4    | 11  |      |     |      |     |      |      |      |     | 7    | 12   |     |       |     |       |
| 19     | 16    | 1  |     |      | 4    | 18   | 4    | 12  |      |     |      |     |      |      |      |     | 8    | 14   |     |       |     |       |
| 20     |       |    |     |      |      |      | 4    | 14  |      |     |      |     |      |      |      |     |      |      |     |       |     |       |
| 21     |       |    |     |      |      |      | 4    | 15  |      |     |      |     |      |      |      |     |      |      |     |       |     |       |

| Table 3. | Decoding | of frame | address | register |
|----------|----------|----------|---------|----------|
|----------|----------|----------|---------|----------|

Note: "M" indicates Major Address and "m" indicates minor address.

## Matching and Mismatching Patterns in Configuration Bitstream

Extended Spartan-3A device, XC3S50A has 367 device frames. Result of match and mismatch pattern in configuration bitstream shown in Fig. 12.



Fig.12 Match and mismatch patterns in configuration bitstream

Table 4 indicated the count of match and mismatch patterns as observed in each bitstream file. Also, it gives total count of combined pattern. The frame address for which mismatch pattern were observed are mentioned in Table 3. The mismatch pattern in bitstream file contains information about the implemented designs.

| Constraint No | Pattern Match Found | Pattern Mismatch | Total Pattern |
|---------------|---------------------|------------------|---------------|
| Default       | 349                 | 19               | 368           |
| Const_1       | 353                 | 15               | 368           |
| Const_2       | 349                 | 19               | 368           |
| Const_3       | 347                 | 21               | 368           |
| Const_4       | 351                 | 17               | 368           |
| Const_5       | 352                 | 16               | 368           |
| Const_6       | 351                 | 17               | 368           |
| Const_7       | 351                 | 16               | 368           |
| Const_8       | 349                 | 19               | 368           |
| Const_9       | 353                 | 15               | 368           |
| Const_10      | 353                 | 15               | 368           |

| Table 4   | Match and | Mismatch  | Patterns in | n Confi | ouration | Bitstream |
|-----------|-----------|-----------|-------------|---------|----------|-----------|
| T able 4. | match and | winsmatch | 1 atterns n | n com   | guianon  | Ditoticum |

Though the HDL codes are same for each design, the location of each design is different on FPGA tiles. For each of the design the mismatch patterns count is different. This is because the routing structure is different for each design. Routing of designs viewed in FPGA editor. Fig. 13 (a) depicts routing structure for default design. Three switch boxes are used for routing. Default design is located by placement and routing tool at bottom right corner of the layout. Fig. 13(b) depicts routing structure for design with const\_4. This design resides in middle portion of the layout.

For the default design LUT belongs to SLICE\_X23Y0 of CLB\_X16Y1. This is also included in statement, "inst "LED1\_OBUF" "SLICEL", placed CLB\_X16Y1 SLICE\_X23Y0" in XDL file generated from NCD file. Also the instance statement for instances DIP1, DIP2 and LED1 are : inst "DIP1" "IBUF", placed RIOIS\_X17Y1 P78 , inst "DIP2" "IBUF", placed BIOIS\_X16Y0 P72, inst "LED1" "IOB", placed RIOIS\_X17Y1 P76 respectively. The instance view shown in Fig. 14



Fig. 13 (a) Default Design



Fig. 13 (b) Design with Const\_4 Fig. 13 The routing structure



Fig. 14 (a) Location on FPGA layout

Fig. 14 (b) Zoom view of design

Fig. 14 Location of default design on FPGA

The detail view of SLICE\_X23Y0 as viewed in FPGA editor is depicted Fig. 15. Likewise view for other instances generated and routing of nets related with XDL file obtained in listing 2.



Fig. 15 LUT mapped on slice

#### VII. CONCLUSION

A simplified straight approach to map FPGAs resources to its HDL description is demonstrated in this paper. We found that information in XDL file derived from NCD file is in human readable form and helps to develop the understanding of FPGA design layout. Xilinx ISE Design suite and PlanAhead tool played vital role in analysis. Though we are able to locate FPGA design location vertically with addresses information in FAR\_MAJ register, configuration information pointed by FAR\_MIN address register is yet not decoded for Spartan-3A FPGA by our approach. We observed that as we move any design from bottom-left position to top-left position to top-bottom position, the configuration information in bitstream goes away and away form starting position of bitstream file. The addition of "Match Pattern" and the "Mismatch Pattern" in configuration bitstream file equals 368 for all design under study.

#### REFERENCES

- [1] J.-B. Note and Eric Rannaud, "From the bitstream to the netlist", in Proceedings of the 2008 ACM/SIGDA 16th Annual International Symposium on Field-Programmable Gate Arrays, FPGA 2008 (Monterey, California), pp. 264-264, February 24-26, 2008,
- [2] C. Beckhoff, D. Koch, and J. Torresen, "The xilinx design language (xdl): Tutorial and use cases," in Reconfigurable Communicationcentric Systems-on-Chip (ReCoSoC), 6th International Workshop, pp. 1-8, 2011.
- [3] Z. Ding, Q.Wu, Y. Zhang, and L. Zhu, "Deriving an NCD file from an FPGA bitstream: Methodology, architecture and evaluation", Microprocessors and Microsystems, vol 37, pp. 299-312, May 2013,
- Joushua Vasquez, "Reverse Engineering Lattice's ICE40 FPGA Bitstream," https://hackaday.com/2015/03/29/reverse-engineeringlattices-ice40-fpga-bitstream/
- [5] F. Benz, A. Seffrin, and S. Huss, "Bil: A tool-chain for bitstream reverse-engineering,", in Field Programmable Logic and Applications (FPL), 22nd International Conference, 2012, pp. 735-738.
- [6] Vaughn Betz and Jonathan Rose, "VPR: A new packing, placement and routing tool for FPGA research," International Workshop on Field Programmable Logic and Applications, 1997.
- [7] Casey J Morford, "BitMaT Bitstream Manipulation Tool for Xilinx FPGAs," Master thesis. December 15<sup>th</sup>, 2005 Bradley Department of Electrical and Computer Engineering Blacksburg, Virginia.
- [8] Khoa Dang Pham, Edson Horta and Dirk Koch, "BITMAN: A Tool and API for FPGA Bitstream Manipulations," Design, Automation & Test in Europe Conference & Exhibition (DATE), 27-31 March 2017.
- [9] Adam Megacz, "A Library and Platform for FPGA Bitstream Manipulation," 15th Annual IEEE Symposium on Field-Programmable Custom Computing Machines (FCCM 2007), 23-25 April 2006, PP 45-54.
- [10] R. Soni, N. Steiner, and M. French, "Open-source bitstream generation," in Field-Programmable Custom Computing Machines" (FCCM), IEEE 21st Annual International Symposium, 2013, pp. 105-112.
- [11] N. Steiner, A. Wood, H. Shojaei, J. Couch, P. Athanas, and M. French, "Torc: Towards an open-source tool flow", 19th International Symposium on Field-Programmable Gate Arrays (FPGA 2011), February 27-March 1, 2011.

- [12] Edson L. Horta, John W. Lockwood, "PARBIT: A Tool to transform bitfiles to implement partial reconfiguration of Field Programmable Gate Arrays (FPGAs)," Report Number: WUCS-01-13, Computer Science and Engineering, Washington University in St. Louis, 2001.
- [13] C. Lavin, M. Padilla, P. Lundrigan, B. Nelson, and B. Hutchings, "Rapid prototyping tools for FPGA designs: RapidSmith," International Conference on Field-Programmable Technology (FPT'10), December 2010.
- [14] Xilinx, "Command Line Tool User Guide, UG628 (v 14.7), October 2, 2013," https://www.xilinx.com/support/documentation/sw\_manuals/xilinx14\_7/devref.pdf
- [15] Xilinx, "ISE Design Suite 14: Release Notes, Installation, and Licensing.UG631 (v14.7) October 2, 2013," https://www.xilinx.com/support/documentation/sw\_manuals/xilinx14\_7/irn.pdf

 [17] Xilinx, "Spartan-3 Generation Configuration User Guide (UG332 (v1.7) January 27, 2015 2.1)," https://www.xilinx.com/support/documentation/user\_guides/ug332.pdf.

<sup>[16]</sup> Xilinx, "FPGA Editor Guide – 2.1i," http://ebook.pldworld.com/\_semiconductors/Xilinx/Foundation/ISE/3.3i/Documentation/fpedit.pdf