

#### ISLAMIC UNIVERSITY OF TECHNOLOGY

#### **REMOTE DATA ACQUISITION SYSTEM USING FPGA**

By Husnain Al Bustam (082405) Nafiz Ur Rahman (082427) Ferdous Ibna Idrish (082467)

> Supervised by Dr. Md. Fokhrul Islam Co-Supervised by Md. Shahzamal

## SUBMITTED IN PARTIAL FULFILLMENT OF THE REQUIREMENTS FOR THE DEGREE OF BACHELOR OF SCIENCE IN ELECTRICAL AND ELECTRONIC ENGINEERING

AT

ISLAMIC UNIVERSITY OF TECHNOLOGY DHAKA, BANGLADESH 12<sup>th</sup> SEPTEMBER, 2012



## ISLAMIC UNIVERSITY OF TECHNOLOGY DEPARTMENT OF ELECTRICAL AND ELECTRONIC ENGINEERING

The thesis entitled "**Remote Data Acquisition System Using FPGA**", by **Husnain Al Bustam, Nafiz Ur Rahman, Ferdous Ibna Idrish** has been accepted in partial fulfillment of the requirement for the degree of **Bachelor of Science in Electrical and Electronic Engineering** on 12.09.2012.

Approved by Dr. Md. Fokhrul Islam

**Dr. Md. Fokhrul Islam** Project Supervisor Department of Electrical & Electronic Engineering (EEE)

**Md. Shahzamal** Project Co-Supervisor Bangladesh Atomic Energy Commission, Bangladesh.

### Prof. Dr. Md. Shahid Ullah

Head of the department Electrical and Electronic Engineering (EEE)



## ISLAMIC UNIVERSITY OF TECHNOLOGY DEPARTMENT OF ELECTRICAL AND ELECTRONIC ENGINEERING

Date: 12th September, 2012

It is hereby declared that neither this thesis nor any part thereof has been submitted elsewhere for the award of any degree or diploma.

| Author 1      |                       |
|---------------|-----------------------|
|               | Husnain Al Bustam     |
| Author 2      |                       |
|               | Nafiz Ur Rahman       |
| Author 3      |                       |
|               | Ferdous Ibna Idrish   |
| Supervisor    |                       |
|               | Dr. Md. Fokhrul Islam |
| Co Supervisor |                       |
|               | Md. Shahzamal         |

## TO OUR PARENTS

## ABSTRACT

Single cost-efficient VLSI chip nowadays turns out to be a solution to microelectronic design problems. In these designs embedded system architectures are used which are comprised of software programmable components accompanied with dedicated hardware processing modules integrated into the VLSI chip [1]. Also emerging new designs which are based on heterogeneous embedded system architectures, offer flexible low-cost design in a short design cycle, integrating multiple software programmable components together with dedicated hardware components into a single cost-efficient VLSI chip. With the help of new technology it has now become possible not only to introduce programmability in these single chip architectures but also maintaining most of the advantages of customized VLSI solutions [1]. Once some applications which were too difficult for computing hardware, now with impressive advances in Very Large Scale Integration (VLSI) technology are becoming more feasible<sup>[2]</sup>. Utilizing the prebuilt logic blocks and programmable routing resources engineers and designers now configure FPGAs (FPGA stands for Field Programmable Gate Array) to implement custom hardware. The configuration of FPGA is specified with the help of hardware description language. FPGA technology is now adopting among the engineers scientists at all levels of expertise as higher level tools evolve to deliver the fruits of reprogrammable silicon [2]. The "Remote Data Acquisition System Using FPGA" has been entirely implemented on the FPGA of the Spartan-3E Starter Kit. DAQs are complex systems which are the basis for building and monitoring tools that enable the supervision of local and remote systems. Data is transferred from the data loggers via radio telemetry, cellular, serial ports, Ethernet, satellite peripherals etc. The mobility and flexibility of the data loggers and sensors make the applications of this technology limitless. In everywhere we can see the magical touch of science and engineering in the present world which enables human being to have the maximum comfort and security of life. In that contrast our developed data acquisition system is such a device that could be used for biomedical applications, nuclear research, or data acquisition from such a place where the presence of human being is risky as well as harmful, for the example in the radioactive areas. The

developed system will communicate through the SMSC LAN83C185 Ethernet PHY with remote pc via internet. Of course the Ethernet port of the Spartan-3E starter kit has to be interfaced with the personal computers as well as that pc should be connected with the remote pc through internet. The configuration of the PCs used in this R and D work- Intel® Desktop Board DG41WV mother board which has LAN support Gigabit (10/100/1000 Mbits/sec) LAN subsystem using the Realtek\* RTL8111D Gigabit Ethernet Controller and Intel® Core™2 Duo Processor. The data transfer rate of the Ethernet port of Spartan-3E starter kit is 10/100 Mbits/Sec. So our developed system could transfer data at the rate of 10/100 Mbits/Sec. National instrument DAQ interfaced with the ADC of the Spartan-3E starter kit to acquire analog signal from the outer world. The ADC process the digital data to FPGA, therefore those data is processed through the SMSC LAN83C185 Ethernet PHY to the personal computer of the concerned person who intended to acquire and send that data through internet in a remote place. The graphical control of the system has been developed using the LAB VIEW program.

## ACKNOWLEDGEMENTS

We would like to thank Dr. Md. Fokhrul Islam, our supervisor, for his many suggestions and constant support during this research. We are also thankful to Md. Shahzamal, our co supervisor for his guidance in the theoretical aspects of the research when we were in chaos and confusion. Mr. Tnaveer Ahmed Bhuiyan, an Alumni of AIUB currently researching in University of Texas, Dallas, shared with us his knowledge of speech enhancement and provided many useful references and friendly encouragement. Of course, we are grateful to our parents for their patience and love. Without them this work would never have come into existence (literally).

Finally, we wish to thank the following: Mr. Mahbubul Hoq (Director-IE,AERE), Dr. Carlos *Leitão* (Researcher, GoLP is a research unit, University of Lisbon, Portugal) and all the other friends who gave us love and support.

The Authors

IUT,OIC, Bangladesh September 2012

# **TABLE OF CONTENTS**

## Page

| ACKNOWLEDGEMENT                  | VII  |
|----------------------------------|------|
| LIST OF FIGURES                  | XII  |
| LIST OF TABLES                   | XVI  |
| LIST OF SYMBOLS AND ABBREVIATION | XVII |

#### CHAPTERS

| 1. | Introduction                                         |   |
|----|------------------------------------------------------|---|
|    | 1.1. Background02                                    | 2 |
|    | 1.2. Motivation02                                    | 2 |
|    | 1.3. The Research Goal03                             | ; |
| 2. | Data Acquisition System (DAQ)                        |   |
|    | 2.1. Introduction                                    | ) |
|    | 2.2. Types of DAQ08                                  |   |
|    | 2.2.1. Wireless Data Acquisition Systems09           | ) |
|    | 2.2.2. Serial Communication Data Acquisition Systems | ) |
|    | 2.2.3. USB Data Acquisition Systems09                | ) |
|    | 2.2.4. Ethernet Data Acquisition Systems10           | ) |
|    | 2.3. Data Acquisition Plug-in Boards10               | ) |
|    | 2.4. Switch Boxes11                                  | - |
|    | 2.5. Stand-alone Data Loggers11                      | - |
|    | 2.6. Application of DAQs12                           | 2 |
|    | 2.6.1. Wireless DAQ13                                | ; |
|    | 2.6.2. Ethernet DAQ14                                | • |
|    | 2.6.3. USB DAQ14                                     | ł |
|    | 2.7. Remote DAQ15                                    | 5 |
|    | 2.7.1. Available Remote DAQs16                       | 5 |
|    | 2.7.2. Retriever                                     | 6 |

|    | 2.7.3. Wireless Modem Models                               | 16 |
|----|------------------------------------------------------------|----|
| 3. | CISC Architecture                                          |    |
|    | 3.1. Introduction                                          | 20 |
|    | 3.2. History of CISC Architecture                          | 20 |
|    | 3.3. Attributes of CISC Architecture                       | 22 |
|    | 3.4. Recent Development of CISC Architecture               | 24 |
|    | 3.5. Advantages of CISC Architecture                       | 24 |
|    | 3.6. Disadvantages of CISC Architecture                    | 25 |
|    | 3.7. Application of CISC Architecture                      | 26 |
| 4. | FPGA                                                       |    |
|    | 4.1. Introduction                                          | 28 |
|    | 4.2. History                                               | 28 |
|    | 4.3. FPGA Structures                                       | 29 |
|    | 4.3.1. Basic Structure                                     | 29 |
|    | 4.4. Configuring a FPGA                                    |    |
|    | 4.5. Advantages of FPGA                                    |    |
|    | 4.6. Disadvantages of FPGA                                 |    |
| 5. | Hardware and Software                                      |    |
|    | 5.1. Introduction                                          | 33 |
|    | 5.2. Hardware                                              |    |
|    | 5.2.1. Spartan-3E-starter kit                              |    |
|    | 5.3. USB TO RS232 SERIAL Adapter CABLE DB9 PIN PL2303      | 42 |
|    | 5.3.1. USB TO RS232 SERIAL Adapter CABLE                   | 42 |
|    | 5.4. Software                                              |    |
|    | 5.4.1. VHDL                                                | 43 |
|    | 5.4.2. Lab VIEW                                            | 44 |
|    | 5.4.3. Xilinx 13.2 ISE                                     | 45 |
| 6. | Remote Data Acquisition System                             |    |
|    | 6.1. Interfacing the Peripherals of Spartan-3E Starter Kit | 47 |
|    | 6.1.1. DAC                                                 | 47 |
|    | 6.1.2. SPI Communication                                   |    |

| 6.1.3.      | Communication Protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6.1.4.      | Character LCD Screen                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.1.5.      | Rotary Push-Button Switch                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.2. Work   | ring Principle                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 52                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.3. ADC    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 56                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.4. Progr  | rammable Pre-Amplifier                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 58                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.4.1.      | Programmable Gain                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 58                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.4.2.      | Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 59                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.4.3.      | SPI Control Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 60                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.5. Analo  | og to Digital Converter (ADC)                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 61                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.5.1.      | Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 61                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.5.2.      | SPI Control Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 61                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.6. Interf | facing of the Ethernet Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.6.1.      | Design Strategy                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.6.2.      | Open Core Ethernet Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.6.3.      | Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.6.4.      | Host                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6.7. Remo   | ote Data Acquisition System                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 66                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Result An   | alysis and Discussion                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7.1. Resul  | lt Analysis                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 72                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.1.1.      | DAC Implementation on FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 72                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.1.2.      | Tables and Figures                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 72                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.1.3.      | Simulation Results                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 76                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.2. Meas   | ure Light Intensity using Photodiode                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 78                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.2.1.      | Photodiode BPW34 as light sensor                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 78                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.2.2.      | Build a Light Intensity Logger                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 79                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.3. Meas   | ure Distance using the Ultrasonic Sensor                                                                                                                                                                                                                                                                                                                                                                                                                                               | 80                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.4. Temp   | perature Simulation and Calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 82                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.5. Optic  | al Heart Rate Monitor                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 84                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7.6. Discu  | ission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7.6.1.      | DAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 86                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|             | <ul> <li>6.1.4.</li> <li>6.1.5.</li> <li>6.2. Work</li> <li>6.3. ADC.</li> <li>6.4. Programing</li> <li>6.4.1.</li> <li>6.4.2.</li> <li>6.4.3.</li> <li>6.5.1.</li> <li>6.5.2.</li> <li>6.6.1.</li> <li>6.6.2.</li> <li>6.6.3.</li> <li>6.6.4.</li> <li>6.7. Remonds</li> <li>7.1.1.</li> <li>7.1.2.</li> <li>7.1.3.</li> <li>7.2. Meass</li> <li>7.2.1.</li> <li>7.2.1.</li> <li>7.2.2.</li> <li>7.3. Meass</li> <li>7.4. Temp</li> <li>7.5. Option</li> <li>7.6. Disconds</li> </ul> | 6.1.3. Communication Protocol.         6.1.4. Character LCD Screen.         6.1.5. Rotary Push-Button Switch.         6.2. Working Principle.         6.3. ADC.         6.4. Programmable Pre-Amplifier         6.4.1. Programmable Gain.         6.4.2. Interface.         6.4.3. SPI Control Interface.         6.5. Analog to Digital Converter (ADC)         6.5.1. Interface.         6.5.2. SPI Control Interface.         6.6.1. Design Strategy.         6.6.2. Open Core Ethernet Controller.         6.6.3. Design.         6.6.4. Host.         6.7. Remote Data Acquisition System.         Result Analysis and Discussion         7.1. BAC Implementation on FPGA.         7.1.1. DAC Implementation on FPGA.         7.1.2. Tables and Figures.         7.1.3. Simulation Results.         7.2.1. Photodiode BPW34 as light sensor.         7.2.2. Build a Light Intensity Logger.         7.3. Measure Distance using the Ultrasonic Sensor.         7.4. Temperature Simulation and Calibration.         7.5. Optical Heart Rate Monitor.         7.6. Discussion         7.6.1. DAC |

| REFERENCES                            | 87  |
|---------------------------------------|-----|
| APPENDIX-I (XILINX-13.2 ISE TUTORIAL) | 94  |
| APPENDIX-II (VHDL TUTORIAL)           | 121 |
| APPENDIX-III (CODES)                  | 134 |

## **LIST OF FIGURES**

| Figure-2.1. Components of data acquisition system                                    | 07 |
|--------------------------------------------------------------------------------------|----|
| Figure-3.1. Intel 8086 Architecture, the 1st member of x86 family                    | 23 |
| Figure-4.1. Basic structure of FPGA                                                  | 30 |
| Figure-5.1. Spartan-3E Starter Kit Board                                             | 36 |
| Figure-5.2. Spartan-3E Starter Kit Board                                             | 36 |
| Figure-5.3. Standard USB Type A/Type B Cable                                         | 37 |
| Figure-5.4. Connect the USB Type B Connector to the Starter Kit Board Connector      | 37 |
| Figure-5.5. 10/100 Ethernet PHY with RJ-45 Connector                                 | 38 |
| Figure-5.6. Character LCD Interface                                                  | 38 |
| Figure-5.7. Four Slide Switches and Eight LEDs                                       | 39 |
| Figure-5.8. Push-Button Switches Require Internal Pull-up Resistor in FPGA Input Pin | 39 |
| Figure-5.9. RS-232 Serial Ports                                                      | 40 |
| Figure-5.10. Digital-to-Analog Converter and Associated Header                       | 40 |
| Figure-5.11. Analog to Digital Converter (Two-Channel Analog Capture Circuit)        | 41 |
| Figure-5.12. Connections to Intel StrataFlash Flash Memory                           | 41 |
| Figure-5.13. FPGA Interface to Micron 512 Mbit DDR SDRAM                             | 42 |
| Figure-5.14USB TO RS232 Serial cable adapter                                         | 43 |
| Figure-6.1. DAC connection schematics                                                | 47 |
| Figure-6.2. SPI communication waveform                                               | 48 |
| Figure-6.3. SPI communication protocol                                               | 49 |
| Figure-6.4. Character LCD interface                                                  | 50 |
| Figure-6.5. Rotary Switch Shaft Encoder Circuitry                                    | 51 |
| Figure-6.6. Output from Rotary Shaft Encoder Circuitry                               | 52 |
| Figure-6.7. Block Diagram of the Developed System                                    | 53 |
| Figure-6.8. Block diagram of the system (Software)                                   | 54 |
| Figure-6.9. State diagram of the DAC                                                 | 55 |
| Figure-6.10. State diagram of the dis_value component                                | 56 |

| Figure-6.11. Two-Channel Analog Capture Circuit                                   | 57      |
|-----------------------------------------------------------------------------------|---------|
| Figure-6.12. Detailed View of Analog Capture Circuit                              | 58      |
| Figure-6.13. SPI Serial Interface to Amplifier                                    | 60      |
| Figure-6.14. SPI Timing When Communicating with Amplifier                         | 60      |
| Figure-6.15. Analog-to-Digital Conversion Interface                               | 62      |
| Figure-6.16. Detailed SPI Timing to ADC                                           | 62      |
| Figure-6.17. Design Diagram                                                       | 64      |
| Figure-6.18. Remote High Speed Data Acquisition System                            | 67      |
| Figure-6.19. Network Architecture                                                 | 68      |
| Figure-6.20. Simulation Using the CISCO Packet Tracer-5.3                         | 70      |
| Figure-7.1. Experimental Setup                                                    | 72      |
| Figure-7.2. For 100mV                                                             | 74      |
| Figure-7.3. For 10mV                                                              | 75      |
| Figure-7.4. Simulation                                                            | 76      |
| Figure-7.5. Behavioral                                                            | 76      |
| Figure-7.6. RTL Schematic                                                         | 77      |
| Figure-7.7. Design Summary                                                        | 77      |
| Figure-7.8. Photodiode BPW34                                                      | 79      |
| Figure-7.9. Develop a LabVIEW VI that reads the voltage across the resistor and c | onverts |
| the voltage to lux                                                                | 79      |
| Figure-7.10. Front Panel View (Light Intensity Logger)                            | 80      |
| Figure-7.11. Front View (Ultrasonic Sensor)                                       | 81      |
| Figure-7.12. Block Diagram (Ultrasonic Sensor)                                    | 82      |
| Figure-7.13. Front Panel View (Temperature)                                       | 83      |
| Figure-7.14. Block Diagram (Temperature)                                          | 83      |
| Figure-7.15. Optical heart rate monitor schematic                                 | 84      |
| Figure-7.16. IR emitter and detector encased in Velcro                            | 85      |
| Figure-A1. ISE Project Navigator (0.61xd)                                         | 88      |
| Figure-A2. Project Navigator Window                                               |         |
| Figure-A3. Creating New Project                                                   | 90      |
| Figure-A4. Creating New Project (Cont.)                                           | 90      |

| Figure-A5. Creating New Project (Cont.)                                        | 91  |
|--------------------------------------------------------------------------------|-----|
| Figure-A6. Creating New Project (Completed)                                    | 92  |
| Figure-A7. Creating New Source                                                 | 92  |
| Figure-A8.New Source Wizard                                                    | 93  |
| Figure-A9.New Source Wizard (Continue)                                         | 93  |
| Figure-A10. Project Navigator Window for the Project "alarm"                   | 94  |
| Figure-A11. Checking Syntax (Successful)                                       | 97  |
| Figure-A12. New Source Wizard (Test Bench)                                     | 97  |
| Figure-A13. New Source Wizard (Test Bench)                                     | 98  |
| Figure-A14. Design (Simulation)                                                | 100 |
| Figure-A15. Simulation                                                         |     |
| Figure-A16. Isim Window                                                        | 101 |
| Figure-A17. Expanded User Constraints                                          | 102 |
| Figure-A18. Unconstrained Clocks                                               | 102 |
| Figure-A19. Profile Generated for Clock "CLK"                                  |     |
| Figure-A20. Profile Generated for Clock "REMOTE"                               | 103 |
| Figure-A21. Constrained Clocks                                                 | 104 |
| Figure-A22. Profile Generated After "I/O Planning (Plan Ahead) Post Synthesis" | 105 |
| Figure-A23. Planning I/O Ports constraints                                     |     |
| Figure-A24. ISE iMPACT Window                                                  |     |
| Figure-A25. ISE Design FlowFigure-A26. Process Window                          | 107 |
| Figure-A26. Process Window                                                     | 108 |
| Figure-A27. Set RTL/Tech Viewer Startup Mode                                   | 108 |
| Figure-A28. "Create RTL Schematic"-Wizard                                      | 109 |
| Figure-A29. "Create RTL Schematic"-Wizard (Continue)                           | 109 |
| Figure-A30. RTL Schematic                                                      | 110 |
| Figure-A31. Detail View of RTL Schematic                                       | 110 |
| Figure-A32. Set RTL/Tech Viewer Startup Mode                                   | 111 |
| Figure-A33. "Create Technology Schematic"-Wizard                               | 111 |
| Figure-A34. "Create Technology Schematic"-Wizard (Continue)                    | 112 |
| Figure-A35. Technology Schematic                                               | 112 |

| Figure-A36. View of Technology Schematic (Double) |     |
|---------------------------------------------------|-----|
| Figure-B1. DFF with Asynchronous Reset            | 115 |
| Figure-B2. When rst= '0', then q<=d               |     |
| Figure-B3. When rst = '1', then q <= '0'          | 119 |
| Figure-B4. Counter of Example-2                   | 119 |
| Figure-B5. Simulation Result                      |     |
| Figure-B6. 4-input Multiplexer                    |     |
| Figure-B7. Y <= A WHEN SEL = "00"                 |     |
| Figure-B8. Y <= A WHEN SEL = "01"                 |     |
| Figure-B9. Y <= A WHEN SEL = "10"                 |     |
| Figure-B10. Y <= A WHEN SEL = "11"                |     |

# **LIST OF TABLES**

| Table-1. Programmable Gain Settings for Pre-Amplifier | 59 |
|-------------------------------------------------------|----|
| Table-2. AMP Interface Signals                        | 59 |
| Table-3. ADC INTERFACE SIGNALS                        | 61 |
| Table.4. Network Design                               | 69 |
| TABLE -5. FOR 100mV Step                              | 72 |
| TABLE -6. FOR 10mV Step                               | 74 |

# LIST OF SYMBOLS AND ABBREVIATION

| ADC       | Analog to Digital Converter                         |
|-----------|-----------------------------------------------------|
| ASIC      | Application Specific Integrated Circuits.           |
| CISC      | Complex Instruction Set Computer.                   |
| CLBs      | Configurable Logic Blocks                           |
| СРІ       | Clock Per Instruction                               |
| CPLD      | Complex Programmable Logic Device                   |
| DAC       | Digital to Analog Converter                         |
| DAQ/DAS   | Data Acquisition System                             |
| DDS       | Direct Digital Synthesis                            |
|           | Double Data Rate Synchronous Dynamic Random Access  |
| DDR SDRAM | Memory                                              |
| DSP       | Digital Signal Processing                           |
| EEPROM    | Electrically Erasable Programmable Read-Only Memory |
| FSM       | Finite State Machine                                |
| FPGA      | Field Programmable Gate Array                       |
| HDL       | Hardware Description Language                       |
| ICON      | Integrated Controller                               |
| IEEE      | Institute of Electrical and Electronic Engineers    |
| ILA       | Integrated Logic Analyzer                           |
| IP Core   | Intellectual Property Core                          |
| ISE       | Integrated Software Environment                     |
| Lab VIEW  | Libratory Virtual Instrument Workbench.             |
| LAN       | Local Area Network                                  |
| LCD       | Liquid Crystal Display                              |
| LED       | Light Emitting Diode                                |
| LUT       | Lookup Table                                        |
|           |                                                     |

| PLD   | Programmable Logic Devices          |
|-------|-------------------------------------|
| RAM   | Random Access Memory                |
| ROM   | Read-Only Memory                    |
| RTL   | Resistor-Transistor logic           |
| SPI   | Serial Peripheral Interface         |
| SPLDs | Simple PLDs                         |
| SRAM  | Static Random Access Memory         |
| UCF   | User Constraints File               |
| VGA   | Video Graphics Array                |
| VHDL  | VHSIC Hardware Description Language |
| VHSIC | Very High Speed Integrated Circuits |
| VIO   | Virtual Input and Output            |

# CHAPTER 1 INTRODUCTION

#### 1.1. Background

Digital system which is also known by other name such as logic design, digital logic, switching circuits etc. can process only digital signal dealing with only a limited numbers of discreet values [3]. Digital system is characterized by its manipulation of discreet elements of information such as electric impulses, the decimal digits, arithmetic operation, punctuation marks or any other set of meaningful symbols [4]. The subject matter of digital design is the design of digital electronic circuits such as logic gates, flip-flops, shift registers, counters etc. The main application areas of digital design are the digital computers, control systems, data communications and many other applications that require electronic digital hardware. The HDL (Hardware Description Language) is used to describe the behavior of a digital system. As part of course work in "Digital Logic Design" we were given idea about the VHDL (A Hardware Description Language) that raises our interest to work in the field of digital system design on FPGA. While doing industrial training in Institute of Electronics, Bangladesh Atomic Energy Commission we came to know about the FPGA and how to program it. At the end of year, 2011 there was short course on "Digital System Designing on FPGA" in Bangladesh Atomic Energy Commission where for the first time we were introduced with the "Spartan-3E Starter Kit". Our first task was to interface the peripherals such as ADC, DAC, LCD, Rotary Switch, and Push-Button Switch of the Spartan-3E Starter Kit. After that we started thinking of a project and according to the advice of our supervisor and co-supervisor we undertook a project which is almost similar to this project that is, "Data Acquisition System Using FPGA". The main difference between this project and that DAQ is that medium of communication with Personal Computer (PC). This project concerned about the communication using the SMSC LAN 83C185 Ethernet PHY of Spartan-3E Starter Kit while that DAQ communicates via RS-232 Serial Ports.

#### 1.2. Motivation

The Nuclear Electronics Lab, Institute of Electronics (IE), AERE (Atomic Energy Research Establishment) is responsible for developing all electronic equipment for nuclear research. Nuclear research areas are always health threatening in some extents. So in that kind of environment for effective research if we use a data acquisition system it would be worthwhile. This is the primary motivation of our. Besides there are several projects are going on in Energy Institute, AERE which requires data acquisition remotely. There are facilities of Cancer Therapy and many radioactive tests for detection of diseases in AERE which most often require data acquisition. Recently IE has established a VLSI lab which is very first time in Bangladesh opens the new horizon in microelectronic research. So considering all these stated circumstances we have taken this as our undergraduate project. But the main challenge of this work is that we have make the system portable as well as the data communication should be fast. Again Bangladesh is third world country so we think that if we could make data acquisition system locally that will be beneficial for the people of country as well as huge amount money could be saved that we usually spend buying DAQs from outside.

#### **1.3.** The Research Goal

The demand of portable, flexible and high speed data communication DAQs are growing rapidly. In this era of science and engineering data transfer rate or how fast the data communication is the main concern of researchers and scientists. We have split up this project in to three parts. In the first part we have interfaced the necessary peripherals; in the second step we have implemented such a DQA that could exchange data at a rate 1 Mbits/Sec through RS232 serial ports of "Spartan-3E Starter Kit". But as we have stated earlier speed is the crucial issue, therefore there is Ethernet port in "Spartan-3E Starter Kit" over which data could be transferred at a rate 10/100 Mbits/Sec. Which is much faster than the earlier one. So in third steps we have implemented a DAQ which could transfer data using Ethernet port. The working principle of both the DAQs are same but the difference between them is the modes of communications. We have interfaced the

peripherals and RS232 serial ports with FPGA embedded in "Spartan-3E Starter Kit" using the VHDL language for both cases. The control of the system have been implemented using the LabVIEW program. Our implemented DAQs are the discretised systems in a sense as both of these have to acquire data from outer world in terms of analogue signal using the NI-DAQ which is processed to FPGA using the ADC embedded in starter kit. This kind of system could be on research level but the main concern of engineering design is the flexibility and sustainability of the products, moreover should be user friendly in nature. We can easily understand this fact why the Windows OS has the largest number of desktop users, this because of user friendliness. So our future goal regarding this project to make "Single Chip Solution" which will be flexible, reliable and user friendly in nature. As we have mentioned earlier, in AERE a VLSI lab is established recently with modern equipments. So our main target is to reduce the size of this DAQ into a single cost-effective VLSI chip.

# **CHAPTER 2**

# **DATA ACQUISITION SYSTEM (DAQ)**

#### 2.1. Introduction

Data acquisition system (DAQ) as the name implies is defined as the products or processes of collecting data or information on an electrical phenomenon such as voltage, current or physical phenomenon like pressure, temperature, sound into a computer for storage, processing, analysis, inspection or further data manipulation. With the advancement of technology, the type of data acquisition system has been simplified and made more accurate, versatile, and reliable through electronic equipment like PC, sensors, transducers, filters etc. Data acquisition systems equipments vary with the requirement of the specific field of its utilization. Basic equipments are

- Transducer
- Amplifier
- Active filter
- Analog multiplexer
- Sample hold
- Programmer sequencer
- A/D converter
- Computer

The input to the system is an electrical or physical parameter such as temperature, pressure, flow, acceleration, and position, which are analog quantities. If the input is physical parameter then it is first converted into an electrical signal by means of a transducer; further processing or manipulation of data is done by electrical circuits. Electrical signal does not need to be converted again with the transducers. Using an amplifier the output signal of transducer is magnified. This output signal of transducer is very small say in microvolt or millivolt level, magnified up to 1v or 10v level using the amplifier. In addition, the transducer output signal may be comprised of a signal with high impedance, a differential signal along with common-mode noise, a current signal, a signal superimposed on a high voltage, or a combination of the signals stated above. Several

specialized types of amplifier can be used for the amplification of the low level signals to the high level signals for desired operation [6,11].



Figure-2.1. Components of data acquisition system[5]

The magnified output is then transmitted to the low-pass active filter which get rid of the unwanted high frequency component or electrical component which give rise to the noise. Sometimes the high level output signal from the amplifier undergoes the operation of squiring, multiplication, log conversion, RMS conversion, division, linearization etc. with the help of special nonlinear analog function circuit. The processed analog signal is then followed by a analog multiplexer. What it does is to switch sequentially among a number of different analog input channel. The connection between each input and output for a specified time is controlled by the multiplexer switch. When the output is connected to the input in the meantime the sample hold circuit acquires the signal voltage level and the A/D

converter becomes operational, converting the analog values into digital values. The digitized values next transmitted to the data bus of the computer or used as a input the digital circuit. Time sharing is occurred with the A/D converter along with the analog multiplexer and sample hold circuit among a number of input channels. The timing and control of the complete DAQ is done by a digital circuit called a programmer sequencer, which in turn is under the control of the computer. The computer itself also used to control the overall data acquisition system sometimes. This is perhaps the most commonly used DAQ configuration, there are also other ones. Instead of multiplexing high-level signals, low-level multiplexing is sometimes used with the amplifier following the multiplexer. In such cases, just one amplifier is required, but its gain may have to be changed from one channel to the next another during multiplexing. Another method is to amplify and convert the signal into digital form at the transducer location and then send the digital information in serial form to the computer. In that case the parallel form of digital data is acquired by suitable conversion and then in the computer data bus these data are multiplexed[5,9,13]

#### 2.2. Types of DAQ

Now-a-days there are various types of data acquisition system available. Various novel technology is emerging, demands data acquisition systems capable of pleasant control, application of these technologies. Though each data acquisition system is a bit different from another due to its desired application but the main components of the data acquisition systems remain same. Some of the data acquisition systems are

- Wireless Data Acquisition Systems
- Serial Communication Data Acquisition Systems
- USB Data Acquisition Systems
- Ethernet Data Acquisition Systems
- Data Acquisition Plug-in Boards
- Switch Boxes

Stand-alone Data Loggers

#### 2.2.1. Wireless Data Acquisition Systems

Wireless data acquisition systems can be used to eliminate the costly and time consuming installation of cable runs for wiring of sensors and other instruments. These system consist of one or more wireless transmitters which sends data back to a wireless receiver connected to a remote computer. Now-a-days for the measurement of ambient temperature and relative humidity, barometric pressure, line pressure, infrared temperature, thermocouples, RTDs, pH, pulse output sensors and wireless transmitters are available. Also transmitters ranging from 4 to 20 mA and voltage output transducers are available from different brand in the market. Receivers which are to be connected to the USB or Ethernet port of the PC are also available [7].

#### 2.2.2. Serial Communication Data Acquisition Systems

Serial communication data acquisition systems are a good choice when the measurement needs to be made at a location which is remote from the computer. There are several different communication standards, RS232 is the most common but it only supports point to point communication and relatively short distances. RS485 supports transmission distances to 1500 meters with a single or 2-pair cable and also allows up to 32 devices to share the same bus[7].

#### 2.2.3. USB Data Acquisition Systems

The Universal Serial Bus (USB) is a new measure for connecting PCs to peripheral devices such as printers, monitors, modems, pen drives and data acquisition devices. USB offers several advantages over conventional serial and parallel connections, which include higher bandwidth (up to 12 MBits/s) and the ability to provide power to the peripheral device. For data acquisition application USB based DAQs are ideal. Since USB connections supply power, only one cable is required to establish the link between the data acquisition device to the PC, which most likely has at least one USB port[7,9].

#### 2.2.4. Ethernet Data Acquisition Systems

Ethernet based data acquisition systems are now-a-days a popular option for many users due to its specific advantages. Most industrial and commercial premises have Ethernet network cables installed, which allow a distributed data acquisition system to be integrated without the cost of additional wiring. One of the special kind of Ethernet devices employs a built in web server in which they transmit their acquired data for further processing or manipulation. This in turns provide with the facility that the user can check the system condition without installing any software just by simply browsing the web server with a standard browser. Even the data can be checked through the mobile or smart phones as almost all the smart phone has a built in standard browser supporting HTML5. So it offers flexibility and feasibility with control. Another advantage of using Ethernet is that the data can easily be shared among users on the local network and also via the Internet to authorized users around the world [7,9,11].

#### 2.3. Data Acquisition Plug-in Boards

These kind of data acquisition boards can be plugged directly into the computer data bus. Advantages of using boards are they offer speed (because they are connected directly to the bus) and lower cost (because the overhead of packaging and power is provided by the computer). Generally for IBM pc and available computers of modern days boards are offered. Features provided by the cards may vary due to number and type of inputs (voltage, thermocouple, digital), outputs, speed and other functions provided. Each board installed, is addressed at a unique Input/Output map location in the computer. The I/O map in the computer provides the address locations which are used by the processor to gain access to the specific device as required by its program[13].

#### 2.4. Switch Boxes

Due to various design verification and product testing applications, switch boxes are included as a type of data acquisition system. Mainly a switch box is a intermediary between the testing device and other instrumentation such as oscilloscope, counter, digital multimeters, power supplies etc. They route the signals between device and instrumentations. Switch boxes are available that can switch signal levels from a few micro volts to several hundred volts, and from DC to several gigahertz. In addition to basic switching, some switchboxes add simple control measures. For example, some manufacturers have added digital input/output capabilities, analogue output control, and isolated actuators for controlling high-power devices.

#### 2.5. Stand-alone Data Loggers

Data loggers are initially used to monitor signals over a period of time in order to identify if there are irregularities that may require attention. Most data loggers also provide with a way to graph and analyze the data, which is further collected through a PC connection. Although it is used primarily in the up-front design verification stage of product development, data loggers also are used in-house for environmental chamber monitoring, component inspection, bench top testing, and process trouble-shooting. Since they are typically used in single-instrument applications, data loggers also make great portable field-testing instruments. They are some data loggers which are capable of performing mathematical operation on the acquired data and to compare the data with the appropriate limit defined by the user for suitable control operation. For instance, in case of measurement of temperature before using the acquired data, signal conditioning or linearization must be applied. The data loggers capable of performing such operation mentioned above can be a replacement of computer sometimes. To transfer the measured data in a PC most data loggers have a communication interface like GPIB, USB or LAN. Some of the applications require the acquired data to be downloaded on the PC in that case the continuous monitoring is needed which is not feasible. Because in that case the stand-alone benefit of data loggers will be lost. [8] If the data logger has its own internal data storage capability, or access to an external storage device such as a disk drive, then one can download the measurements for analysis at a later time. For general application a data logger with 20 channel or fewer with a low scan rate is decent. For greater flexibility and functionality, one should select a data logger that can operate as a standalone instrument, can be easily upgraded, and can be connected to a PC. A data logger should also have plugin slots and the ability to measure different types of input signals without external signal conditioning[9].

#### 2.6. Application of DAQs

Applications of DAQs are very wide spread. Starting from small control system for car, DAQs are widely used for communication purpose, controlling sophisticated research system, telemetry, space technology, radar and positioning system, robotics, life science, many fields of engineering like electrical, mechanical, civil, computer science, geological etc. Some applications are discussed here.

#### 2.6.1. Wireless DAQ

Wireless data acquisition systems are basically used when the user or monitoring system is distant from the environment form where data is gathered. It's also used to avoid extra cost and complexity for wiring. Here the wireless data acquisition system for testing rocket engines is discussed. This is a prototype wireless data-acquisition system which is developed for a potential replacement of a wired data-acquisition system to be used in testing rocket engines. The traditional use of wires to connect sensors, signal-conditioning circuits, and data acquisition circuitry is time-consuming and prone to error, especially when there are many sensors used in a test. In this system there is one master node with several slave nodes. Communication with the master node via pc is done by an Ethernet connection. Rechargeable batteries supply power to the slave nodes. These batteries are enclosed in such an enclosure so that the changing weather will not affect them. A time modulated ultra-wide-band radio transceiver is used in the master unit and also in each of the slave unit. What it does is by means of transmitting extremely low power of pulses with narrow width, it spread its RF energy over several Giga-hertz. Out of six sensors connected to each slave nodes two of them are connected directly to ADC and the other four is connected to ADC via signal conditioner indirectly. Each sensor has the maximum sampling rate of 5 kHz for streaming data. To accommodate the data collecting from the sensors in the five slave node the bandwidth of one channel of the communication system should be adequate. Comparing traditional sinusoidal wave based radios TM-UWB radios offer much higher spatial capacity. Also with existing wireless transmission TM-UWB radios works fine without any interference[15,16]. For this system, approximately 50ft (15m) is the maximum radio communication range between the master and the slave node. Small dipole antennas are used in this case. By using larger antenna or greater transmission power the range can be increased. Batteries for the slave nodes are used in such a way so that they can serve the desired operation. Operational lifetime can be increased by using extra batteries. Power consumption is controlled by radio transceiver.

The software performs the following operations:

- Controlling the operating schedule of the slave nodes.
- In order to maximize the utilization of the system to manage the sampling rate and latencies of the readings.
- To ensure synchronization among all operational nodes.[17]

#### 2.6.2. Ethernet DAQ

Ethernet data acquisition systems are used widely now-a-days for industrial, commercial and may other purposes. Here an Ethernet IO data acquisition system is discussed. The industrial Ethernet I/O data acquisition systems discussed here is developed by Intelligent Instrument. They are using open architecture standards for easy development and deployment into existing and future systems. By using the efficiencies of standard technology, it offers a lower total cost of ownership for monitoring and control applications. With the help Ethernet Data Acquisition System EDAS CE, one can take advantage of the existing network infrastructure, lower cost network components. Also the development of networking and application is possible. Isolated digital and analog I/O, 100BaseT Ethernet, Windows CE development tools, all in an industrial modular package, make EDAS CE the ideal solution for a wide range of monitoring and control applications[9].

#### 2.6.3. USB DAQ

USB Data Acquisition Systems are used both for remote purpose as well as stand-alone purpose. There are many type of USB Data Acquisition System available. One is NI USB-6009 [6].Its applications are

• Robot Specific Uses

- Loop refinement of PID
- Measurement of frame strain
- Diagnostics of electrical system
- Simulation of sensors
- Non-Robot Specific Uses
  - Dynamometer
  - Ball velocity measurement
  - Understanding FRC Electronics

#### 2.7. Remote DAQ

Remote data acquisition is defined as the collection of information about a system or a process which located in a distant place. The data which is collected is used to study various parameters of a desired system and the implications of it would have on the dependent processes/systems. The systems that enable supervision of remote processes for data collection are termed remote data acquisition or remote data collection systems. These systems are usually designed using PCs and other processor-based input/output modules conforming to RS-232 and RS-485 standards. The advantages offered by the remote data acquisition system equipped with data loggers are:

- Installation is easy
- Ownership cost is low
- Reliability and flexibility
- Lowered risk of electrical faults, lightening surges and other hazardous weather conditions

In case of engineering processing the remote data collection plays a crucial role. To improve the efficiency, performance, reliability of the engineering project manipulation of data is necessary which is provided by the remote data acquisition system.

#### 2.7.1. Available Remote DAQs

Many remote data acquisition system are available depending on the application demand. Some of them are based on internet while the others use wireless sensors to acquire data for further processing or manipulation. Some available data acquisition systems are briefly discussed here.

#### 2.7.2. Retriever

It is a solar-powered, wireless data collection module which is used for landfill, remediation, and other sites. The Retriever is not just a simple hardware, but it facilitates a data delivery and reporting system which delivers data of pump flow and well level. These data can be clearly charted and displayed, and securely archived. From the sensors deployed in water flow and level the built in microprocessor take the data reading in an hourly basis and the acquired data is stored. The daily data acquired can be sent to a preferred web address. The received data can be expressed in tabular format or any other format according to the choice of the user. The data is properly backed up so that one can download the necessary data when need arises. Using a standard web browser one can access the web site containing the data which can be modified according to the corresponding date and time. So without being present in the site it is possible to produce a short summary of operation of the site[9,16,17]

#### 2.7.3. Wireless Modem Models

16

These types of units provide rugged and reliable operation with sophisticated features which make them versatile and easy to use for a wide variety of applications. Their size is compact and easy operation make these units perfect for innumerable mobile/remote data applications. There applications are-

#### Mobile and Fleet Communications

- Automatic Vehicle Location (AVL)
- Differential GPS Navigation
- Computer Aided Dispatch
- Data Base Access from remote places
- Monitoring and Control of traffic

#### GPS

- Automatic Vehicle Location (AVL)
- Differential GPS navigation
- Differential and RTK survey corrections

#### **Industrial Data Communications**

- Monitoring oil and gas Field
- Management of water and waste water
- Control of irrigation
- Control and monitoring of environment
- Security/Alarm System Management
- Automation of factory.

Two type of module are available from Teledesign Systems. These are TS4000 Radio Modem and TS2000 Mobile Radio Modem. Also products from various brands are available meeting the demand of different types of consumers. [8]

# CHAPTER 3 CISC ARCHITECTURE

#### 3.1. Introduction

CISC architecture referred to a computer architecture in which hundreds of operation can be performed by CPU (Central Processing Unit). CISC stands for complex instruction set computing. It referred to a computer where a single instruction can execute various low level operation or capable of multistage operation or addressing modes within single instructions[18]. This is not similar compared to Reduced Instruction Set Computers (RISC), which support fewer instructions. The computers that support CISC, are capable of accomplishing a wide variety of computing tasks, which makes them the priority choice for the general purpose computer. That's why the majority of personal computer in the market is using this architecture. Early in the 1970s and 1980s, the invention of CISC architecture started a new era where the computer became capable of performing complex operation. As a result it gave birth of complex or a bit sophisticated computer program writing. Or it can be said that instead of writing lengthy program this instruction set provided with the opportunity of writing small program for the same tasks.

#### 3.2. History of CISC Architecture

As with the passage of time high-level languages started to become popular, so the computer architects gave a try to make the machine's capabilities match constructs used by programmers. With the help of complex addressing mode reduction of many instructions to single machine instruction become possible. Memory in the past was relatively slow and expensive so, compacting the program size was one of the desirable goals. Faster loading and more available space for other programs are the two advantages offered by the small program size. For the production of memory chips Intel Corporation was founded by Robert Noyce, Gordon Moore and Arthur Rock in 1968. Robert Noyce, invented the integrated silicon circuit. Intel sold the amount of chips that was worth about \$3000 in their first year of operation. Calculators were a bit large electromechanical machines weighing of 20 kg in late 1960s. For a proposed electronic calculator, a Japanese company

named Busicom in September 1969, proposed Intel to manufacture 12 custom chips. Ted Hoff the assigned engineer for this project looked this plan from a different viewpoint. He came up with a idea that if he use a 4-bit general purpose CPU on a single chip than the same thing can be done more simply which will also be cheap as well. As a result the 2300transistor 4004 was born as a first single chip CPU (Faggin et al., 1996). Though Intel had no future plan at the beginning of this project but later on Intel came up with that it would be worthwhile if they use the 4004 in other projects. So Intel bought all the rights of the chip from Busicom at a cost of \$60000. After some research in 1972 the 8-bit version of the chip, the 8008 was introduced. At first Intel started to produce the 8008 at low scale as they are not sure that it will arouse the interest. But this chip was able to arouse a large interest among users so Intel went for the design of a new chip which has the memory space of around 16k like the 8008's. So in 1974, a small general purpose CPU, 8080 is emerged. Within a very short time this product took the market like PDP-8. Intel made a good profit by selling these chips in millions. 8086, a more generalized 16-bit CPU was introduced in 1978. Though the design of 8086 is almost similar to the 8080 but they differ in their compatibility. The next member of this family followed by 8086 was 8088 which has the same architecture as 8086. But instead of having 16 bit bus it had only 8-bit bus which made it not only slower but also cheaper than 8086. This chip became the standard for personal computer industry when IBM chose 8088 as the CPU for IBM pc. Limits for addressing memory for both 8086 and 8088 was 1 megabyte. In the subsequent days it becomes a problem so Intel designed a new chip named 80286. The memory organization of 80286 is different from the 8088 and 8086 but the basic instructions were same. In the midrange PS/2 models and in the IBM PC/AT, 80286 had specific application. 80286 was a great success as people accepted it due to its almost like 8088 but faster than 8088. The quest for a 32-bit pc on a single chip became fruitful in 1985 when Intel introduced 80386. This is also more or less compatible with the earlier versions. This backward compatibility was desirable for the users who are running old software but at the same time the users who are enthusiastic for future change had to hold back for some time. 80486 was introduced after four years. The main feature of 80486 was a floating point unit, 8k of cache memory on the chip and obviously it was faster than the previous version. The function of cache memory is to avoid the slow accesses in the main memory by holding

memory words which are most commonly used inside or close to CPU. 80486 also provided with the opportunity to build system with several CPUs. By the time Intel lost a trademark infringement lawsuit that the numbers cannot be trademarked like 80486 so they give a new name "Pentium" to the next generation. Pentium chips were faster than the 80486 as Pentium has two internal pipeline compared to one internal pipeline of 80486. As a name Pentium became more popular among the marketing people and the new chip was introduced named as Pentium Pro. Though it was almost same as the previous one but it brought a new change. Pentium Pro was able to execute five instructions at a time and it had a huge change in the internal organization. An important feature of Pentium pro was the introduction of the two-level cache memory. For commonly used instructions the processor had its own 8k memory and for holding commonly used data there was an additional 8k memory. There was a second cache memory of 256k in the same package. Pentium II was introduced followed by Pentium pro which was almost similar to the previous version except it has a multimedia extension which is called MMX. In case of audio and video processing this instructions speeded up the computations so there was no need of an additional multimedia coprocessor. As this is a new feature added by Pentium II so it can be called a new version of Pentium Pro with multimedia instructions [10]. PDP-11, System/360, VAX, Motorola 68000 family, and Intel x86 architecture based processors; all the mentioned microprocessors are CISC architecture based. With the passage of time processors like Pentium III, Pentium IV, Dual Core, Core 2 Duo, Quad Core was introduced by Intel. Also Many processor based on CISC architecture is available in the market[18,21,26,27].

#### 3.3. Attributes of CISC Architecture [20,21,24]

Due to the development of CISC architecture there are some attributes which are more or less common among the CISC based microprocessors. These are discussed below:

- Instructions have source and destination following a 2-operand format. Commands available from the register to register, from memory to register and from register to memory. Indexing of arrays requires multiple addressing modes for memory including specialized modes.
- Variable length instructions where the length often varies according to the addressing mode
- Instructions which require multiple clock cycles to execute.

Other common characteristics among CISC architectures are:

- Complex instruction-decoding logic, driven by the need for a single instruction to support multiple addressing modes.
- A small number of general purpose registers. This results from the directly operating instruction on memory. Also for instruction coding, execution and storage of the code the absence of the required amount of chip is responsible.
- Several special purpose registers. Many CTSC designs set aside special registers for the stack pointer, interrupt handling, and so on. By making the instruction set more complex this can simplify the hardware design.
- A 'Condition code" register which is set as a side-effect of most instructions. The function of this register is to check the last operation and to store or record if there is any error condition.



Figure 3.1. Intel 8086 Architecture, the 1st member of x86 family [24]

#### 3.4. Recent Development of CISC Architecture

As advancement of science and technology is ongoing, likewise the new era is starting to emerge in this field. New ideas and technological approach made it possible. There are various development ongoing in CISC architecture. These are –

- The terms RISC and CISC have become less meaningful with the continued evolution of both CISC and RISC designs and implementations.
- CISC chips are now able to execute more than one instruction within a single clock.
   Pipelining is possible due to this and accommodation of many transistors on a single chip is possible.
- Modern x86 processors also decode and split more complex instructions into a series of smaller internal "micro-operations" which can thereby be executed in a pipelined (parallel) fashion, thus achieving high performance.
- Attempts have been made to combine features of both RISC and CISC to develop a new approach
- Intel has teamed up with Hewlett-Packard (HP) to design a new type of ISA. This is known as IA-64 (Intel Architecture 64).

#### 3.5. Advantages of CISC Architecture

There are many advantages of CISC architecture. Some are mentioned below.

- CISC has varying lengths to reduce wasted space in memory.
- Has developed a process to manage power which adjusts clock speed and voltage.
- Uses less instructions to perform similar instructions than RISC.
- Provides programmers with assembly instructions to do a lot with smaller programs.

- Microprogramming is as easy as assembly language to implement, and much less expensive than hardwiring a control unit.
- The ease of micro-coding new instructions allowed designers to make CISC machines upwardly compatible: a new computer could run the same programs as earlier computers because the new computer would include the instruction of the earlier computers as a superset.
- As each instruction became more capable, fewer instructions could be used to implement a given task. So efficient use of slow main memory is possible.
- Because micro-program instruction sets can be written to match the constructs of high-level languages, the compiler does not have to be as complicated.

#### 3.6. Disadvantages of CISC Architecture

Though CISC architecture offers a lot of advantages, it also hyas some disadvantages. These are discussed below.

- CISC chips are relatively slow (compared to RISC chips) per instruction.
- CISC chips require many more transistors than comparable RISC designs.
- Harder to pipeline using CISC architecture.
- Expensive to produce.
- Earlier generations of a processor family generally were contained as a subset in every new version - so instruction set & chip hardware become more complex with each generation of computers.
- So that as many instructions as possible could be stored in memory with the least possible wasted space, individual instructions could be of almost any length - this means for execution different instructions will need different clock time as a result the performance of the machine will be slower.

- Many specialized instructions aren't used frequently enough to justify their existence -approximately 20% of the available instructions are used in a typical program.
- CISC instructions typically set the condition codes as a side effect of the instruction.

#### 3.7. Application of CISC Architecture

CISC architecture is used widely in all kinds of CPU which has wide application as PC or personal computer. Day by day the processors in this PCs' are getting more faster which enables the user with more flexibility in his/her daily use. Texas Instruments calculators like the TI-89, TI-92, and Voyage 200 lines use the 68000 line of processors. CISC based processors also used widely in trainer boards for learning purposes. Palm Pilot series that are running on Palm OS 1.x to 4.x are CISC based and also in the control system of the space shuttle CISC based processors is used. However, they became most well known as the processors powering desktop computers such as the Apple Macintosh, the Commodore Amiga, the Sinclair QL, the Atari ST, purposes [27].

### **CHAPTER 4**

### FPGA

#### 4.1. Introduction

FPGA stands for Field-Programmable Gate Arrays. FPGAs are pre-fabricated silicon devices that can be electrically programmed to become almost any kind of digital circuit or system. They have many advantages over Application Specific Integrated Circuits (ASIC). ASICs are designed for specific application using CAD tools and fabricated at a foundry. Developing an ASIC takes very much time and is expensive. Furthermore, it is not possible to correct errors after fabrication. In contrast to ASICs, FPGAs are configured after fabrication and they also can be reconfigured. This is done with a hardware description language (HDL) which is compiled to a bit stream and downloaded to the FPGA. The disadvantages of FPGAs are that the same application needs more space (transistors) on chip and the application runs slower on a FPGA as modern as the ASIC counterpart. Due to the increase of transistor density FPGA were getting more powerful over the years. On the other hand the development of ASICs was getting slower and more expensive. Therefore FPGAs are increasingly applied to high performance embedded system [29].

#### 4.2. History

We'd have a brief look at the history of FPGA and maybe explain why we prefer to prototype this way before going to full ASIC systems. The development of the first Field Programmable Gate Array (FPGA) was by a company called Xilinx in 1985; however the number of gates on the chip was in the low thousands and it wasn't catching on at the time. Realizing the limitations of PROMs and PLDs the US Naval Surface Warfare dept. funded a project to develop a computer with reprogrammable gates, in this case, 600,000 of them. The patent for this technology was given in 1992, after this point the FPGA took off and started to appear initially in telecoms and networking equipment but later in automotive and consumer applications. In 1997, a researcher at the University of Sussex created algorithms that would adapt the FPGA, creating evolvable hardware. By the turn of the century, chips were starting to have millions of reprogrammable gates on them and the

market share had gone from a small number of millions to billions of dollars. There are of course some downsides over ASICs, although these are changing. Historically FPGAs have been slower, less energy efficient and not had as much functionality. However, on the upside, they are easily reprogrammable to correct bugs and with the new security procedures being developed to securely load them, and the ability to correct security issues on the FPGA as an upgrade to a system, in the future we may well see FPGAs replacing ASICs more and more on a permanent basis [33].

#### 4.3. FPGA Structures

#### 4.3.1. Basic Structure

In the chapter the basic structure of a FPGA will be described. Xilinx is one of the biggest FPGA manufacturers. A Xilinx FPGA is made up of three basic blocks [38]:

• **PLB**: The programmable logic blocks are the user specific functions being calculated.

• **IOB:** The Input / Output block make it possible to connect the FPGA to the other elements of the application

• Interconnect: Interconnect is essential for writing between PLB and from IOBs to PLBs.

The PLBs are located at the center of the chip and the IOBs on the periphery. The interconnect is necessary to implement several designs on the FPGA. The distributed configuration memory controls the behavior of the PLBs and IOBs by storing the program. Next the implementations of PLBs interconnect and IOBs are described more in detail.



Figure 4.1: Basic structure of FPGA [36]

#### 4.4. Configuring a FPGA

FPGAs are not programmed directly. Synthesis tools translate the code into bit stream, which is downloaded to the configuration memory of the FPGA. Commonly, hardware description languages (HDL) are use to configure the device. But resent trends also offer the possibility to high level languages. Furthermore, there are library based solutions which are optimized for a specific device.

#### 4.5. Advantages of FPGA

- Reduction in size (compact)
- Higher resolution
- Lower dead time
- Multifunctional
- Upgradable
- Possible automation of entire acquisition process
- Remote acquisition

#### 4.6. Disadvantages of FPGA

- Signal requires pre-filtering due to ADC limitations
- Complex design procedure (requires knowledge of C/C++, VHDL/Verilog)
- Expensive hardware and software

### **CHAPTER 5**

### HARDWARE AND SOFTWARE

#### 5.1. Introduction

From the title of the chapter it is clear that we are here going to brief about the hardware and software that we have used to implement the project "Remote High Speed Data Acquisition System". The main hardware that we have used to implement the project is "Spartan-3E Starter Kit" and "NI DAQ (National Instruments Data Acquisition System)". As we know that without the proper programming the hardware do not work, so to program the FPGA and interfacing the necessary peripheral of Spartan-3E starter kit 'we have used the "VHDL (Very High Speed Integrated Circuits Hardware Description Language)" and to implement the control of the system we have used the LabVIEW software (Laboratory Virtual Instrumentation Engineering Workbench). An IDE or Integrated Development Environment is a software program that is designed to help programmers and developers build software. To code VHDL we have used Xilinx-13.2 ISE. It may seem a strange fact that why here we separately describing the "USB to RS232". The reason we have mentioned earlier in the abstract and chapter-1 that we have implement two "*Remote Data Acquisition System*". One communicates using the "10/100 Ethernet Physical Layer" and another using "RS232 Serial Ports". So we think it is important make the reader aware of the model that we have used while implementing the projects. This chapter will give reader a fair idea about the hardware and software that are needed to implement such kind of digital system. In hardware section we will give a fair idea about the "Spartan-3E Starter Kit", "USB to RS232" and "NI DAQ". And in the Software section of this chapter we will brief about the VHDL, LabVIEW and Xilinx-13.2 ISE. Here will just brief about what these things are, not how they are working or how to use them. In the appendix section we have given two tutorials on "Xilinx-13.2 ISE" and "VHDL".

#### 5.2. Hardware

#### 5.2.1. Spartan-3E-starter kit

XC3S500E FPGA is the core of the Spartan-3E Starter kit board which is one of the Spartan-3E families. Its logic is higly optimized. This board provides ideal platform for the implementation and verification of designs for embedded and FPGA applications. The Spartan-3E Starter Kit board highlights the unique features of the Spartan-3E FPGA family and provides a convenient development board for embedded processing applications [35]. The board highlights these features:

- Spartan-3E specific features
- Parallel NOR Flash configuration
- MultiBoot FPGA configuration from Parallel NOR Flash PROM
- SPI serial Flash configuration
- Embedded development
- MicroBlaze<sup>™</sup> 32-bit embedded RISC processor
- PicoBlaze<sup>™</sup> 8-bit embedded controller
- DDR memory interfaces

The Spartan-3E Starter Kit board includes additional peripherals and memory; user can design multi-purpose systems with Verilog HDL and VHDL. MicroBlaze or PicoBlaze soft-core processor can run on Spartan-3E FPGA, so users can make use of ISE and EDK development kit to design and debug customer system based on MicroBlaze or PicoBlaze quickly [1].

The key features of the Spartan-3E Starter Kit board are [34,35,36]:

- Xilinx XC3S500E Spartan-3E FPGA
- Up to 232 user-I/O pins
- 320-pin FBGA package
- Over 10,000 logic cells
- Xilinx 4 Mbit Platform Flash configuration PROM
- Xilinx 64-macrocell XC2C64A CoolRunner CPLD
- 64 MByte (512 Mbit) of DDR SDRAM, x16 data interface, 100+ MHz

- 16 MByte (128 Mbit) of parallel NOR Flash (Intel StrataFlash)
- FPGA configuration storage
- Micro Blaze code storage/shadowing
- 16 Mbits of SPI serial Flash (STMicro)
- FPGA configuration storage
- Micro Blaze code shadowing
- 2-line, 16-character LCD screen
- PS/2 mouse or keyboard port
- VGA display port
- 10/100 Ethernet PHY (requires Ethernet MAC in FPGA)
- Two 9-pin RS-232 ports (DTE- and DCE-style)
- On-board USB-based FPGA/CPLD download/debug interface
- 50 MHz clock oscillator
- SHA-1 1-wire serial EEPROM for bitstream copy protection
- Hirose FX2 expansion connector
- Three Digilent 6-pin expansion connectors
- Four-output, SPI-based Digital-to-Analog Converter (DAC)
- Two-input, SPI-based Analog-to-Digital Converter (ADC) with programmable-gain pre-amplifier
- ChipScope<sup>™</sup> SoftTouch debugging port
- Rotary-encoder with push-button shaft
- Eight discrete LEDs
- Four slide switches
- Four push-button switches
- SMA clock input
- 8-pin DIP socket for auxiliary clock oscillator



Figure-5.1. Spartan-3E Starter Kit Board-1 [36]



Figure-5.2. Spartan-3E Starter Kit Board-2 [34]



Figure-5.3. Standard USB Type A/Type B Cable[35]



Figure-5.4. Connect the USB Type B Connector to the Starter Kit Board Connector[35]



Figure-5.5. 10/100 Ethernet PHY with RJ-45 Connector[35]



Figure-5.6. Character LCD Interface [35]



Figure-5.7. Four Slide Switches and Eight LEDs [35].



**Figure-5.8.** Push-Button Switches Require Internal Pull-up Resistor in FPGA Input Pin [35].



Figure-5.9. RS-232 Serial Ports [35].



Figure-5.10. Digital-to-Analog Converter and Associated Header [35].



Figure-5.11. Analog to Digital Converter (Two-Channel Analog Capture Circuit) [35]



Figure-5.12. Connections to Intel StrataFlash Flash Memory [35]



Figure-5.13. FPGA Interface to Micron 512 Mbit DDR SDRAM [35]

Figure 5.3 represents the Commercial Package of Spartan-3E starter kit. Fig 5.4 is the completely indicator diagram of Spartan-3E, means it shows the consisting elements on the board. And from the figure-3 to fig 5.15 are the pictorial representation of the necessary peripherals those we need to interface using the VHDL for the implementation of our project "Remote High Speed Data Acquisition System".

#### 5.3. USB TO RS232 SERIAL Adapter CABLE DB9 PIN PL2303

USB to RS232 serial cable adapter supports over 1Mbps data transfer rate which is enriched with remote Wake-up and power management [34].

#### 5.3.1. USB TO RS232 SERIAL Adapter CABLE DB9 PIN PL2303 Features [38]

High-Speed USB 2.0 To RS232 Serial Pin Cable Adapter-

- USB specification revision 1.1 & 2.0 compliant from this USB Cable Adapter
- High-Speed USB to RS232 Cable support Rs232 serial interface (DB9)
- USB Data Cable Support Windows ME/2000/XP
- Measurement: 81cm/31.8" in length; Weight: 86g



Figure-5.14. USB TO RS232 Serial cable adapter [38]

#### 5.4. Software

In high speed remote data acquisition system VHDL, Lab VIEW, Xilinx-13.2 is used as software. These are going to be described below.

#### 5.4.1. VHDL

VHDL is a Hardware Description Language (HDL) which describes the behavior of an electronic circuit or system. VHDL stands for Very High Speed Integrated Circuits (VHSIC) Hardware Description Language. The development of the VHDL language was funded by the United States Department of Defense (DoD) in the 1980. VHDL's first version was

VHDL-87, later upgraded to the so-called VHDL-93. This is the first and original HDL to be standardized by the IEEE (Institute of Electrical and Electronic Engineers), through the IEEE 1076 standard. An additional standard, the IEEE 1164, was later added to introduce a multi-valued, logic system. VHDL is able to do both circuit synthesis and simulation. VHDL is fully simulatable but not all the constructs are synthesizable. The (automatic) transformation of a less detailed description into a more elaborated one is called synthesis. The main reason behind choosing the VHDL is that, it is a standard, technology or vendor independent language, portable and reusable. The two main applications of VHDL are in the field of Programmable Logic Devices and in the field of ASICs. Programmable Logic Devices are Field Programmable Gate Array (FPGA) and Complex Programmable Logic Devices(CPLD). Once the VHDL code has been written, it can be used either to implement the circuit in a programmable device (Altera, Xilinx, Atmel etc.) or can be submitted to a foundry for fabrication of an AISC chip [1]. VHDL is not sequential language rather it is inherently concurrent (parallel). In concurrent coding the instructions are executed in parallel. Concurrent code is also called the *dataflow code*. This is why VHDL is referred as a "code" rather than a program. Usually WHEN, GENERATE, operators and special kind of assignment, called BLOCK is used for the concurrent coding in VHDL. Purely concurrent code could not be used to implement the synchronous circuits. We can say that, using concurrent code the combinational logic circuit could be built. If we want to implement a sequential circuit then we have to employ the sequential code. But the statement which is placed inside a PROCESS, FUNCTION OR PROCEDURE is executed sequentially [3,39].

#### 5.4.2. Lab VIEW

In the recent days throughout the industry, academia and research labs LabVIEW becomes a common choice of standard as data acquisition and instrument control software. This is a multiplatform instrumentation and analysis softare system which is not only powerful for the required purpose but also provide with flexibiliy. It can be run on Windows , MAC OS X and Linux. The main feature of this software is it can be run on embedded FPGA chips and 32-bit microprocessor which is why it is a popular choice for instrumentation or manipulation of a FPGA based design, Data Acquisition System etc. It has a very user friendly interface which offers feasible writing and execution of programs. Unlike the tradition programming languages LabVIEW features a graphical programming environment with all essential tools for data acquisition, analysis of data and result presentation. It is also able to solve a wide variety of problems in a very short time without any compulsive writing of conventional code in other engineering application.

#### 5.4.3 Xilinx 13.2 ISE

Xilinx is a simulation software for VHDL, Verilog on embedded FPGA based design. The features of logic edition are-

- Complete flow for RTL-based design
- Familiar design flows (pre-7 series devices), with full support of the latest Xilinx 7 series FPGAs and Zynq-7000
- Integrated tool set supporting logic/connectivity, embedded, and DSP designs

The features for embedded edition are-

- Use one tool chain for hard and soft microprocessors
- Reduces board complexity and cost
- Leverage intelligent tools and IP

The features for DSP edition are-

- Leverage tools and IP for varied approaches
- Addresses DSP performance bottlenecks
- Enables leading-edge algorithms

### **CHAPTER 6**

## REMOTE DATA ACQUISITION SYSTEM USING FPGA

#### 6.1. Interfacing the Peripherals of Spartan-3E Starter Kit

With recent improvements in the density of field programmable gate array (FPGA) devices, systems with an increasingly higher level of integration are possible. Digital signal processing is an important application area for FPGAs and such systems often require data converters to provide analog outputs from digital domain representations (D. Sillage, 2009). The DAC could be entirely built on FPGA by using the VHDL (Very High Speed Integrated Circuit Hardware Description Language). As it is completely single chip system so it provides a high degree of flexibility and reduces costs. Developed VHDL code has been implemented on the Spartan-3E starter kit.

#### 6.1.1. DAC

The Spartan-3E Starter Kit board includes an SPI-compatible, four-channel, serial Digital to-Analog Converter (DAC). The DAC device is a Linear Technology LTC2624 quad DAC with 12-bit unsigned resolution. The four outputs from the DAC appear on the J5 header, which uses the Digilent 6-pin Peripheral Module format [71].



Figure-6.1. DAC connection schematics [71]

#### 6.1.2. SPI Communication

The FPGA uses a Serial Peripheral Interface (SPI) to send digital values to each of the four DAC channels. The SPI bus is a full-duplex, synchronous, character-oriented channel employing a simple four-wire interface. The interface signals between the FPGA and the DAC are the SPI\_MOSI, SPI\_MISO, and SPI\_SCK which are shared with the other devices on the SPI bus. The DAC\_CS signal is the active-Low slave select input to the DAC. The DAC\_CLR signal is the active-Low, asynchronous reset input to the DAC. As a bus master the FPGA drives the bus clock signal (SPI\_SCK) and transmits serial data (SPI\_MOSI) to the selected DAC bus slave [72].



Figure-6.2. SPI communication waveform [72]

#### 6.1.3. Communication Protocol

Figure 3 shows the shows the communications protocol required to interface with the LTC2624 DAC. The DAC supports both a 24-bit and 32-bit protocol. The 32-bit protocol is shown. Inside the D/A converter, the SPI interface is formed by a 32-bit shift register [73].



Figure-6.3. SPI communication protocol[73]

Each 32-bit command word consists of a command, an address, followed by data value. The FPGA first sends eight dummy or "don't care" bits, followed by a 4-bit command. The most commonly used command with the board is COMMAND [3:0] = "0011", which immediately updates the selected DAC output with the specified data value. Following the command, the FPGA selects one or all the DAC output channels via a 4-bit address field. Following the address field, the FPGA sends a 12-bit unsigned data value that the DAC converts to an analog value on the selected output(s). Finally, four additional dummy or *don't care* bits pad the 32-bit command word [74].

#### 6.1.4. Character LCD Screen

The Spartan-3E starter kit has 2-line by 16-character LCD. The FPGA controls the LCD by using the 4-bit data interface. The LCD is capable of displaying a variety of information using the standard ASCII and custom characters. The interface character LCD interface signals are the SF\_D, SF\_D, SF\_D, SF\_D, LCD\_E, LCD\_RS and LCD\_RW [74].



Figure-6.4. Character LCD interface [74].

#### 6.1.5. Rotary Push-Button Switch

The rotary push-button switch is capable of producing three outputs. The two shaft encoder outputs are ROT\_A and ROT\_B and the center push-button switch is ROT\_CENTER. This switch integrates two different factions. The switch shaft rotates and outputs values whenever the shaft turns. The shaft can also be pressed, acting as a push-button switch [74].



Figure-6.5. Rotary Switch Shaft Encoder Circuitry [73]

Rotating the shaft operates two push-button switches, as shown in 4. Depending on which way the shaft is rotated, one of the switches opens before the other. Likewise, as the rotation continues, one switch closes before the other. However, when the shaft is stationary, also called the detent position, both switches are closed. Closing a switch connects it to ground, generating a logic Low. When the switch is open, a pull-up resistor within the FPGA pin pulls the signal to logic High [72]



Figure-6.6. Output from Rotary Shaft Encoder Circuitry [73].

#### 6.2. Working Principle

This system produces analog voltage at the output of DAC according to the digital value provided by the FPGA. The digital input of the DAC is controlled with the help of rotary switch. The rotation of switch in clockwise direction increase the analog output value and rotation in anticlockwise direction result in the decrement of the analog output value. The step voltage of increment is controlled with a push-button switch. Default step voltage is 100mv. With pressing this switch we can change the step from 100mv to 10mv. For the next push it switches to previous state.



Figure-6.7. Block Diagram of the Developed System

We have developed several VHDL components to implement system within FPGA as shown in Figure-8. Rotary switch component sense the rotary switch and increment and decrement the DAC's digital values. For a single rotation the DAC's digital input value is increased to 164 for 100mv step or 16 for 10 mv. But in reverse rotation it decreases the DAC digital input with equal amount (164 for 100mv step or 16 for 10 mv). The DAC digital input is passed to DAC component.



Figure-6.8. Block diagram of the system (Software)

The Figure-9 shows the state diagram for DAC component. The components loop in the state S0 and wait for set button press. When set button is pressed the program go to the next state S1. In the state S1 program will make the DAC\_CS = '0' to select the DAC and

transfer control to the state S2. In this state 1-bit out of 32-bit data will be sent making the clock SPI\_SCK low and transferred to the state S3. In state S3 clock SPI\_SCK is made high and condition bitnr < 32 is checked (bitnr is the number of bit transmitted). If the condition bitnr< 32 is true program is transferred to the state S2 otherwise it is transferred to state S4. When the program is in the state S4, switching from this state to other state (S0 or S1) depends upon the set value as depicted in the figure 9.



Figure-6.9. State diagram of the DAC



Figure-6.10. State diagram of the dis\_value component

The DAC digital input is also sent to dis\_value (display value) components. These components process digital input to generate suitable code for representing voltage on the LCD screen. The state diagram for this component is shown in figure-10. In the state S0 val\_adc register is updated with DAC digital value. Then in the next state S1, 1638(equivalent to 1 volt) is subtracted from the val\_adc. If subtracted value is less than 1638, the program is transferred to the next state S2. Here the val\_adc is subtracted by 164(equivalent to .1 volt). In this way this component produces equivalent value for digital input. The generated code is sent to lcd\_driver component. The LCD driver component takes the value from dis\_value component. The component sends an index to the main program and ask bit pattern for the character to be displayed at this index.

ADC stands for Analog to Digital Converter which is essentially a circuit used to convert the analog input values into digital output values. In the Spartan-3E kit board there is a Analog to Digital Converter along with a programmable scaling pre-amplifier, in a two channel analog capture circuit. In the analog capture circuit there is a programmable preamplifier called LTC6912-1. The function of this programmable preamplifier is to scale the analog input signal on header J7 which is embedded on the kit board [76,93].



UG230\_c10\_01\_030306

Figure-6.11. Two-Channel Analog Capture Circuit [76,93].

The output of the preamplifier goes as a input to the ADC called LTC1407A-1. FPGA is responsible for the program control of the preamplifier and ADC.



Figure-6.12. Detailed View of Analog Capture Circuit [76,93].

#### 6.4. Programmable Pre-Amplifier

#### 6.4.1. Programmable Gain

The analog voltage applied on VINA and VINB is converted by analog capture circuit which constitutes a digital representation consisting 14-bit. Two independent inverting amplifiers are provided by LTC6912-1 which has programmable gain. Scaling the incoming voltage on VINA or VINB is the main purpose of using the amplifier as a result the maximization of conversion range of DAC will become around 1.65+1.25v. A programmable gain amplifier is associated with each analog channel, as shown in figure. The amplification of analog voltage input in VINA and VINB is done relative to a reference voltage of 1.65. Using a voltage divider of 3.3V of the supply voltage the reference voltage 1.65V is generated. The amplifiers each have a programmable gain range of -1 to -100, as shown in Table 1 [76,93].

|    |   | Tiogram |    | Settings | 101 110-7 | inpiner [70,5 | ·5].    |
|----|---|---------|----|----------|-----------|---------------|---------|
| A3 |   | A2      | A1 | A0       | Gain      | Input Voltag  | e Range |
| B3 |   | B2      | B1 | B0       |           | Minimun       | Maximum |
|    | 0 | 0       | 0  | 1        | -1        | 0.4           | 2.      |
|    | 0 | 0       | 1  | 0        | -2        | 1.025         | 2.27    |
|    | 0 | 0       | 1  | 1        | -5        | 1.4           | 1.      |
|    | 0 | 1       | 0  | 0        | -10       | 1.525         | 1.77    |
|    | 0 | 1       | 0  | 1        | -20       | 1.5875        | 1.712   |
|    | 0 | 1       | 1  | 0        | -50       | 1.625         | 1.67    |
|    | 0 | 1       | 1  | 1        | -100      | 1.6375        | 1.662   |

| Table-1                                               |
|-------------------------------------------------------|
| Programmable Gain Settings for Pre-Amplifier [76,93]. |

### 6.4.2. Interface

The interface signals between the FPGA and the amplifier have been presented in the table-2. The SPI\_MOSI, SPI\_MISO, and SPI\_SCK signals are shared with other devices on the SPI bus. The AMP\_CS signal is the active-Low slave select input to the amplifier [76,93].

> Table-2 AMP Interface Signals[76,91].

| Signal   | FPGA | Direction |
|----------|------|-----------|
|          | Pin  |           |
| SPI_MOSI | T4   | FPGA→AD   |
| AMP_CS   | N7   | FPGA→AMP  |
| SPI_SCK  | U16  | FPGA→AMP  |
| AMP_SHDN | P7   | FPGA→AMP  |
| AMP_DOUT | E18  | FPGA←AMP  |

#### 6.4.3. SPI Control Interface

**Figure-6.13**. represents the SPI-based communication interface with amplifier. The gain for each amplifier is sent as an 8-bit command word, consisting of two 4-bit fields [76,93].



Figure-6.13. SPI Serial Interface to Amplifier [76,93].

The most-significant bit, B3, is sent first. The AMP\_DOUT output from the amplifier echoes the previous gain settings. The SPI bus transaction starts when the FPGA asserts AMP\_CS Low. The amplifier captures serial data on SPI\_MOSI on the rising edge of the SPI\_SCK clock signal. The amplifier presents serial data on AMP\_DOUT on the falling edge of SPI\_SCK [76,93].





# 6.5. Analog to Digital Converter (ADC)

#### 6.5.1. Interface

Table-3 represents the interface signals between the FPGA and the ADC. The SPI\_MOSI, SPI\_MISO, and SPI\_SCK signals are shared with other devices on the SPI bus. The DAC\_CS signal is the active-Low slave select input to the DAC. The DAC\_CLR signal is the active-Low, asynchronous reset input to the DAC [76,93].

# Table-3 ADC INTERFACE SIGNALS [76,93].

| Signals  | Pin  | Direction              |
|----------|------|------------------------|
|          | FPGA |                        |
| SPI_SCK  | U16  | $FPGA \rightarrow ADC$ |
| AD_CONV  | P11  | $FPGA \rightarrow ADC$ |
| SPI_MISO | N10  | $FPGA \rightarrow ADC$ |

#### 6.5.2. SPI Control Interface

**Figure-6.15.** represents the SPI bus transaction to the ADC. When the AD\_CONV signal goes High, the ADC simultaneously samples both analog channels. The results of this conversion are not presented until the next time AD\_CONV is asserted, a latency of one sample. The maxim sample rate is approximately 1.5 MHz. The ADC presents the digital representation of the sampled analog values as a 14-bit, two's complement binary value [76,93].



Figure-6.15. Analog-to-Digital Conversion Interface [76,93].

**Figure-6.16**. shows detailed transaction timing. The AD\_CONV signal is not a traditional SPI slave select enable. Be sure to provide enough SPI\_SCK clock cycles so that the ADC leaves the SPI\_MISO signal in the high-impedance state. Otherwise, the ADC blocks communication to the other SPI peripherals. The ADC 3-states its data output for two clock cycles before and after each 14-bit data transfer [76,93].



UG230\_c10\_06\_022306

Figure-6.16. Detailed SPI Timing to ADC [76,93].

### 6.6. Interfacing of the Ethernet Controller [91]

#### 6.6.1. Design Strategy

The chip associated with the Ethernet port of the "*Spartan-3E Starter Kit*" does not implement the Ethernet controller rather than the physical transceiver layer. To transmit or receive data over this Ethernet port we have interface the Ethernet controller for which we have used open core Ethernet controller from the Open Cores. The packet communication through the Ethernet controller is demonstrated by a host module [91].

#### 6.6.2. Open Core Ethernet Controller

The controller presents three interfaces [91]

1. An interface to the PHY

2. An interface to external memory where the packets will be stored

3. A user interface that allows the set-up of the rx/tx buffer descriptors and the read/write of the various registers

To interface the PHY the tri-state i/o has to be converted into the two distinct wires. External memory is used by the controller to read or write packets. The addresses are controller by the user setting up the appropriate pointers in the buffer descriptors. This interface is known as standard wishbone interface. Here the controller is master while the memory is slave. The third interface has logically two parts-one is composed of registers and another is composed buffer descriptors. The Ethernet controller is controlled by the registers. The packet transmission is controlled by the buffer descriptors where in the external memory the packets are stored. Buffer descriptors 8-bytes long of which the first 4-bytes contain the status/control of the packet and the last 4-bytes contain the external memory address of the buffer where the packet is stored. The interface is a standard Wishbone interface. This interface is a slave, and the host is the master [91]..

#### 6.6.3. Design



The design diagram is depicted in the following figure.

Figure-6.17. Design Diagram [91].

The top level module, "*eth\_loopback*", instantiates the host, the memory and the wishbone arbiter. The DDR SDRAM choosen as external memory for which the Xilinx MIG 2.0 controller is reused. "*memory\_wb\_to\_mig*" module is used to convert the Wishbone to the MIG 2.0 proprietary interface. "*eth\_cop*"-a simple arbiter is used to interconnect the two masters and two slaves. In order to be synthesizable the module needs very slight modifications. The arbitration provided by "*eth\_cop*" is based on the address values:

- 0x0000-0x0050: Registers (slave 1)
- 0x0400-0x05ff: Tx buffer descriptors (slave 1)
- 0x0600-0x07ff: Rx buffer descriptors (slave 1)
- 0x2000-0x32000: DDR SDRAM (slave 2)

#### 6.6.4. Host

"loopback\_controller" which is a host module reads incoming packets and send them back out without any kinds of modification. The algorithm that works behind loopback is-

initialize mode register forever initialize one rx buffer descriptor wait until packet received in corresponding buffer descriptor initialize tx buffer descriptor w/ same address as rx buffer and same length endforever

For mode register the defaults parameters cannot be used as mode register needs its tx and rx bits set in order to enable receive or transmit. Pointer and control bits constitute the buffer descriptors. The pointer is nothing but the DDR SDRAM address of the packet data. Some control bits are determined by the user while some are determined by the Ethernet core. The most important control bit is the enable bit. In a rx buffer descriptor an enable bit set to 1 indicates to the core that it can write the buffer descriptor and its associated buffer

for packet reception. Once the packet is received, the core resets the enable bit, and the user can read the received packet and its status. The tx buffer descriptors contain a similar enable bit. The user sets it to tell the core to send a packet. Once sent, the core resets this bit indicating that the packet was sent [91].

#### 6.7. Remote Data Acquisition System

The block diagram of the "*Remote Data Acquisition System*" has been shown. Our developed DAQ will acquire the data from the surroundings or radioactive areas in terms of voltage, temperature, pressure etc. Then these acquired analog data will be processed to the FPGA through the data conversion from analog domain to digital domain using the ADC. Ethernet port of the "Spartan-3E Starter Kit" has been interfaced in such a way thus the FPGA could process the acquired data to the user's PC who intended to acquire it. The acquired data could be transmitted to remote place using internet. Our main aim of doing this project is to make the use of the "Ethernet Port" of the "Spartan-3E Starter Kit" thus we could use the internet for transmitting the data to a remote place. For checking the workability of the networking of *Data Acquisition System*, we have designed a network as depicted in the **Figure-6.18.** which is simulated using the *CISCO Packet Tracer 5.* The simulation was carried out in the real time simulation mode in which the clock should run continuously. The simulation results and along with the network design have been represented here respectively.



Figure-6.18. Remote High Speed Data Acquisition System



Figure-6.19. Network Architecture

| Subnets   | Subnet<br>address | Prefix | Mask | Hosts | Default<br>Gateway<br>(First | Broadcast<br>(last<br>address) |
|-----------|-------------------|--------|------|-------|------------------------------|--------------------------------|
|           |                   |        |      |       | address)                     |                                |
| NET- 1    | 10.0.1.0          | 29     | 248  | 8     | 10.0.1.1                     | 10.0.1.7                       |
| NET- 2    | 10.0.1.8          | 29     | 248  | 8     | 10.0.1.9                     | 10.0.1.15                      |
| Point-to- | 10.0.1.16         | 30     | 252  | 4     | Address u                    | sable for                      |
| point     |                   |        |      |       | point-to p                   | oint                           |
| (Router)  |                   |        |      |       | (10.0.1.17                   |                                |
|           |                   |        |      |       | 10.0.1.18)                   |                                |

Table.4. Network Design



Figure-6.20. Simulation Using the CISCO Packet Tracer-5.3

# CHAPTER 7

# **RESULT ANALYSIS AND DISCUSSION**

# 7.1. Result Analysis

# 7.1.1. DAC Implementation on FPGA

The developed VHDL code has been implemented on the Spartan-3E starter kit. The design is synthesized and implemented on the FPGA by using the Xilinx ISE 13.2 software. The kit includes embedded USB based programming logic and an USB end point with a Type B connector [6]. With the help of a USB cable which has connection with the PC and iMPACT programming software we burned the program directly into the FPGA.



Figure-7.1. Experimental Setup

After burning code we have taken different reading using digital multi meter. The taken reading is listed below in the table 4 and table 5. We actually compare the value from the DAC output with the reading displayed on the LCD screen. Following tables show the reading for voltage step 100 mv and 10 mv.

# 7.1.2. Tables and Figures

TABLE -5

FOR 100mV Step

| S/N. | LCD Value | Multimeter (Volt) |
|------|-----------|-------------------|
|      | (Volt)    |                   |
| 1    | 0.092     | 0.09              |
| 2    | 0.192     | 0.19              |
| 3    | 0.292     | 0.29              |
| 4    | 0.392     | 0.39              |
| 5    | 0.492     | 0.48              |
| 6    | 0.592     | 0.59              |
| 7    | 0.692     | 0.68              |
| 8    | 0.792     | 0.78              |
| 9    | 0.892     | 0.88              |
| 10   | 0.992     | 0.98              |
| 11   | 1.194     | 1.17              |
| 12   | 1.294     | 1.27              |
| 13   | 1.394     | 1.37              |
| 14   | 1.494     | 1.47              |
| 15   | 1.594     | 1.55              |
| 16   | 1.694     | 1.67              |
| 17   | 1.794     | 1.77              |
| 18   | 1.894     | 1.86              |
| L    | 1         | l                 |

| 19 | 1.994 | 1.97 |
|----|-------|------|
| 20 | 2.096 | 2.06 |
| 21 | 2.196 | 2.18 |
| 22 | 2.296 | 2.27 |
| 23 | 2.396 | 2.36 |
| 24 | 2.496 | 2.49 |





# TABLE -6

# FOR 10mV Step

| S/N. | LCD Value (Volt) | Multimeter |
|------|------------------|------------|
|      |                  | Value      |
|      |                  | (Volt)     |
|      |                  |            |

| 1  | 2.408 | 2.37 |
|----|-------|------|
| 2  | 2.418 | 2.37 |
| 3  | 2.428 | 2.40 |
| 4  | 2.436 | 2.39 |
| 5  | 2.446 | 2.40 |
| 6  | 2.456 | 2.41 |
| 7  | 2.464 | 2.43 |
| 8  | 2.474 | 2.43 |
| 9  | 2.484 | 2.44 |
| 10 | 2.494 | 2.48 |
|    |       | 2.10 |



Figure-7.3. For 10mV

We have implemented this system in the Lab. There are some deviations in the reading of the multi meter to the LCD display reading. This may happen in the time of conversion from

digital to analog. But the matter of the fact is that the deviation is not great. So we can say that our developed system is almost an accurate and ideal for use for various purposes.



## 7.1.3. Simulation Results

Figure-7.4. Simulation



Figure-7.5. Behavioral



Figure-7.6. RTL Schematic

| LCD_DSIPLAY Project Status (12/19/2011 - 15:57:17) |                           |                       |                               |  |
|----------------------------------------------------|---------------------------|-----------------------|-------------------------------|--|
| Project File:                                      | PROJECT_1cd.xise          | Parser Errors:        | No Errors                     |  |
| Module Name:                                       | LCD_DSIPLAY               | Implementation State: | Programming File Generated    |  |
| Target Device:                                     | xc3s500e-4fg320           | Errors:               | No Errors                     |  |
| Product Version:                                   | ISE 13.2                  | • Warnings:           | 41 Warnings (1 new)           |  |
| Design Goal:                                       | Balanced                  | Routing Results:      | All Signals Completely Routed |  |
| Design Strategy:                                   | Xilinx Default (unlocked) | Timing Constraints:   | All Constraints Met           |  |
| Environment:                                       | System Settings           | Final Timing Score:   | 0 (Timing Report)             |  |

| Device Utilization Summary [-                  |      |           |             |         |
|------------------------------------------------|------|-----------|-------------|---------|
| Logic Utilization                              | Used | Available | Utilization | Note(s) |
| Number of Slice Flip Flops                     | 291  | 9,312     | 3%          |         |
| Number of 4 input LUTs                         | 550  | 9,312     | 5%          |         |
| Number of occupied Slices                      | 400  | 4,656     | 8%          |         |
| Number of Slices containing only related logic | 400  | 400       | 100%        |         |
| Number of Slices containing unrelated logic    | 0    | 400       | 0%          |         |
| Total Number of 4 input LUTs                   | 676  | 9,312     | 7%          |         |
| Number used as logic                           | 550  |           |             |         |
| Number used as a route-thru                    | 126  |           |             |         |
| Number of bonded IOBs                          | 21   | 232       | 9%          |         |
| Number of BUFGMUXs                             | 2    | 24        | 8%          |         |
| Average Fanout of Non-Clock Nets               | 3.23 |           |             |         |

| Figure-7.7 | Design | Summary |
|------------|--------|---------|
|------------|--------|---------|

#### 7.2. Measure Light Intensity using Photodiode

Light intensity is an important management factor for breeder type poultry. The amount of light received by a plant is an important factor, because plants' growth may suffer if they do not receive sufficient light. Light intensity decreases dramatically with distance from the light source. An object located 15 cm from two 40-watt fluorescent lamps receive about 9300 lux, but only 5400 lux if they are 30 cm from the lamps. The human eye is a very poor "instrument" for measuring light intensity, because the pupil adjusts constantly in response to the amount of light it receives. To accurately measure the light intensity in a given spot, it is best to use a light meter. Light intensity may be measured in lux (metric system) or foot-candles (Imperial system).

1 foot-candle = 10.76 lux

#### 7.2.1. Photodiode BPW34 as light sensor

The Photodiode used is the BPW34. This is a high speed and high sensitive silicon PIN photodiode in a miniature flat plastic package. A photodiode is designed to be responsive to optical input. Due to its water clear epoxy the device is sensitive to visible and infrared radiation. The large active area combined with a flat case gives a high sensitivity at a wide viewing angle.

Light Sensor



Figure-7.8. Photodiode BPW34



Figure-7.9. Develop a LabVIEW VI that reads the voltage across the resistor and converts the voltage to lux.

# 7.2.2. Build a Light Intensity Logger

- > Reads the voltage across the resistor and converts the voltage to lux
- Adjustable Update Period
- > Statistics of Maximum, Minimum and Mean Value
- Intensity plot over time (with Reset)
- > A selectable and adjustable Threshold (Limit) and a warning if light is not in Range



Figure-7.10. Front Panel View (Light Intensity Logger)

# 7.3. Measure Distance using the Ultrasonic Sensor

The **MaxSonar-EZ1** uses an ultrasonic sensor to detect objects from 6-inches to 254-inches with a 1-inch resolution. The analog output is given as 10mV/inch. You can connect the sensor to the analog IO module as:





Figure-7.11. Front View (Ultrasonic Sensor)



Figure-7.12. Block Diagram (Ultrasonic Sensor)

# 7.4. Temperature Simulation and Calibration

- Generate a Random Number (Temperature) between 20° to 50 °C
- This number is interpreted as Temperature
- Add a timing (Wait function) for a temperature measurement of 5 Hz
- ( $\rightarrow$  One temperature every 200 ms)



• Display the Temperature curve in a Chart

Figure-7.13. Front Panel View (Temperature)



Figure-7.14. Block Diagram (Temperature)

#### 7.5. Optical Heart Rate Monitor

Pulse Oximetry is a non invasive method of measuring a person's oxygenation level which monitors the percentage of haemoglobin (Hb). A probe comprising LEDs and photo detector is attached to the patient's finger. As the light from the two LEDs (red - 660 nm and infrared - 950 nm) pass through the body tissues to a photodetector, it is absorbed by blood and soft tissue. The light absorption rate at the two wavelengths by the hemoglobin is different and depends on the degree of oxygenation. The light level changes as the blood is pumped by the heart. As a consequence, the oximeter also measures the heart rate in beats per minute (BPM). In this application note, we have created a heart rate monitor by using one IR LED & phototransistor pair and observing the waveform at the phototransistor output. This is intended for illustrating a typical light sensor application and not intended for actual medical use.



Figure-7.15. Optical heart rate monitor schematic



Figure-7.16. IR emitter and detector encased in Velcro





When the console program is first run, the user to place his/her finger on the sensor. When a finger is placed on the phototransistor, the voltage read rises above 0.3V. If a good contact is made, a sinusoidal type signal is observed. As the signal rides on a fluctuating DC signal, a simple differential signal is created. From maths, we know that when a max or min is reached, its differential value is zero. After this an autocorrelation function is applied and the peaks extracted to obtain the heart rate. When the signal is noisy, a wrong BPM will be calculated. Any count that is obviously wrong is ignored. This is all taken care of by the HRM class.

# 7.6. Discussion

7.6.1. DAC

We have implemented this system in the Lab. There are some deviations in the reading of the multi meter to the LCD display reading. This may happen in the time of conversion from digital to analog. But the matter of the fact is that the deviation is not great. So we can say that our developed system is almost an accurate and ideal one which could be used for various purposes.

### 7.6.2. DAQs

Using our developed "*Data Acquisition System*" we have performed four experiments. Those are- Measure Light Intensity using Photodiode, Measure Distance using the Ultrasonic Sensor, Temperature Simulation and Calibration, and Optical Heart Rate Monitor. And in each case we have got the values nearly our expected one.

# REFERENCES

- [1] M. Michael Vai David R. Martinez, Robert A. Bond. High Performance Embedded Computing Handbook. CRC Press, 2008.
- [2] Jonathan Rose Ian Kuon, Russel Tessier. Fpga architecture: Survey and challenges.Foundations and Trends in Electronic Design Automation, 2007.
- [3] Volnei A. Pedroni, Circuit Design with VHDL, 1st Edition, MIT Press, Cambridge, MA, U.S.A., ISBN-978-81-203-2683-5.
- [4] M. Morris Mano, Digital Logic and Computer Design, Prentice Hall College Div (April 1979), ISBN-13: 978-0132145107.
- [5] Peter H. Sydenham and Richard Thorn., Handbook of Measuring System Design C John Wiley & Sons, Ltd, 2005.
- [6] <u>http://www.omega.com/das/</u>, 5<sup>th</sup> January, 2012.
- [7] http://cp.literature.agilent.com/litweb/pdf/5950-3000.pdf, 5<sup>th</sup> January, 2012.
- [8] <u>http://www.techbriefs.com/component/content/article/14608</u>, 7<sup>th</sup> January, 2012.
- [9] J.B. Dixit, <u>Amit Yadav</u>, Intelligent Instrumentation for Engineers, Laxmi Publications Pvt Limited, Sep 1, 2011 - 183 pages.
- [10] <u>http://www.ni.com/data-acquisition/</u>, 8<sup>th</sup> January, 2012.
- [11] <u>http://www.qedenv.com/products/remote wireless data acquisition overview</u>, 8<sup>th</sup> January, 2012.
- [12] <u>http://www.teledesignsystems.com/</u>, 8<sup>th</sup> January, 2012.
- [13] <u>http://www.ti.com/lit/ug/sbou056/sbou056.pdf</u>, 8th January, 2012.
- [14] <u>http://www.abs-cbnnews.com/exam-results/05/31/12/marine-engineer-licensure-exams-results-released</u>, 9th January, 2012.
- [15] <u>http://www.bartington.com/das1-data-acquisition-system.html</u>, 10<sup>th</sup> January, 2012.
- [16] <u>http://www.home.agilent.com/en/pc-1000000676%3Aepsg%3Apgr/data-acquisition-daq?&cc=BD&lc=eng</u>, 11<sup>th</sup> January, 2012.
- [17] <u>http://books.google.com.bd/embedded Systems Design.html?id=Nr esc=y</u>, 17<sup>th</sup>
   January, 2012.

- [18] Yi Gao, Shilang Tang, Zhangli Ding, "Comparison between CISC and RISC", 2000.
- [19] Steve Heath, "Microprocessor Architectures: RISC, CISC and DSP", Second Edition, 1995.
- [20] William Stallings, "Computer Architecture Designing for Performance", "Seventh Edition", 2006.
- [21] John L. Hennessy, David A. Patterson, "Computer Architecture A Quantitative Approach", Third Edition, 2006.
- [22] <u>http://en.wikipedia.org/wiki/Complex instruction set computing</u>, 19th January, 2012.
- [23] <u>http://en.wikipedia.org/wiki/Intel Core</u>, 19<sup>th</sup> January, 2012.
- [24] Marvin Hobbs, "RISC/CISC Development and Test Support". Prentice Hall (September 1991), ISBN-13: 978-0133884142.
- [25] <u>http://en.wikibooks.org/wiki//Instruction\_Set\_Architectures</u>, 25th January.
- [26] Jeff Prosise, "RISc vs. CISC: The Real Story", PC Magazine, 1995.
- [27] Nouf Assad, Microprocessors, History of Computing.
- [28] <u>http://en.wikipedia.org/wiki/Field-programmable gate array</u>, 2<sup>nd</sup> February, 2012.
- [29] <u>http://www.altera.com/products/fpga.html</u>, 2<sup>nd</sup> February, 2012.
- [30] <u>http://www.webopedia.com/TERM/F/FPGA.html</u>, 3rd February, 2012.
- [31] <u>http://www.latticesemi.com/products/fpga/index.cfm</u>, 4<sup>th</sup> February, 2012.
- [32] <u>http://www.eecg.toronto.edu/~vaughn/challenge/fpga\_arch.html</u>, 7<sup>th</sup> February, 2012.

- [33] <u>Scott Hauck, André DeHon</u>, Reconfigurable Computing: The Theory and Practice of FPGA-Based Computation, Morgan Kaufmann, 2008, ISBN 0123705223, 9780123705228.
- [34] http://www.up-tech.com/eng/product/detail.asp?id=35, 15<sup>th</sup> February,2012.
- [35] http://www.xilinx.com/products/boards/s3estarter/reference\_designs.htm,15<sup>th</sup>
   February,2012.
- [36] http://parts.digikey.com/1/parts/1366679-kit-starter-spartan-3e-hw-spar3e-skuni-g.html, 15<sup>th</sup> February,2012.
- [37] http://www.digilentinc.com/Products/ =2,400,792&Prod=S3EBOARD, 15<sup>th</sup>February,2012.
- [38] <u>http://www.amazon.com/RS232-SERIAL-Adapter-CABLE-</u> PL2303/dp/B00404N0IQ?SubscriptionId=AKIAILPV47KBBQYSR3TQ&tag=fataom0 220&linkCode=xm2&camp=2025&creative=165953&creativeASIN=B00404N0IQ , 17<sup>th</sup> February, 2012.
- [39] Peter J. Ashenden, The Designer's Guide to VHDL, 2<sup>nd</sup> Edition, Elseviewer, ISBN-1-55860-674-2.
- [40] Ulrich Heinkel, Martin Padeffke, Werner Haas, Thomas Buerner, Herbert Braisz, Thomas Gentner, Alexander Grassmann, The VHDL Reference, 1<sup>st</sup> Edition, John Wiley ans Sons. Ltd, ISBN-0-47189972-0.
- [41] Yalamanchili S., VHDL Starter's Guid, Englewood Cliffs, NJ, Prentice Hall, 1998.
- [42] Yalamanchili S., Introductory VHDL from Simulation to Synthesis, Englewood Cliffs, NJ, Prentice Hall, 2001.
- [43] Perry D.L., VHDL, New York, McGraw-Hill, 2<sup>nd</sup> Edition, 1994.
- [44] Pellerin D. and D. Taylor, VHDL Made Easy, Englewood Cliffs, NJ, Prentice Hall, 1997.

- [45] Navabi Z., VHDL Analysis and Modeling of Digital System, New York, McGraw-Hill, 2<sup>nd</sup> Edition, 1993.
- [46] Naylor D. and S. jones, VHDL : A Logic Synthesis Approach, London : Chapman and Hall, 1997.
- [47] Hamblen J. and M. Furman, Rapid Prototyping of Digital Systems, Boston : Kluwer Academic Publisher, 2<sup>nd</sup> Edition, 2001.
- [48] Chang K. C., Digital System Design with VHDL and Synthesis-An Integrated Approach, Los Alamitos, CA, IEEE Computer Society Press, 1999.
- [49] Bhasker J., VHDL Primer, Englewood Cliffs, NJ, Prentice Hall, 3<sup>rd</sup> Edition, 1999.
- [50] Armstrong J. R. and F. G. Gray, VHDL Design Representation and Synthesis, Englewood Cliffs, NJ, Prentice Hall, 2<sup>rd</sup> Edition, 2000.
- [51] Ian Grout, Digital Systems Design with FPGAs and CPLDs, Else viewer, 2008. ISBN-978-81-312-1865-3.
- [52] Electronic Industries Association, Standard Data Transfer Format between Data Preparation System and Programmable Logic Device Programmer, JEDEC Standard and JESD3-C, EIA, Washington, DC, 1994.
- [53] Peter Lee Stephanie McBader. An fpga implementation of a flexible, parallel image processing architecture suitable for embedded vision system. IEEE, 2003.
- [54] Peter Alfke and Bernie New. Implementing state machines in LCA devices. In *The Programmable Logic Data Book*, pages 8–169 8–172. Xilinx, Inc., San Jose, CA, 2nd edition, 1994. XAPP 027.001.
- [55] Carol A. Fields. Proper use of hierarchy in HDL-based high density FPGA design. In Will Moore and Wayne Luk, editors, *Field-Programmable Logic and Applications: 5th International Workshop, FPL '95*, volume 975 of *Lecture Notes in Computer Science*, pages 168–177, Berlin, Germany, August 1995. Springer Verlag.

- [56] IEEE. *IEEE Standard VHDL Language Reference Manual*. IEEE, New York, NY, 1988.IEEE Standard 1076-1987.
- [57] IEEE. *IEEE Standard Multi value Logic System for VHDL Model Interoperability (std\_logic\_1164)*. IEEE, New York, NY, 1993. IEEE Standard 1164-1993.
- [58] Manfred Selz. Untersuchungen zur synthesegerechten Verhaltensbeschreibung mit VHDL. PhD thesis, Universita<sup>°</sup>t Erlangen-Nu<sup>°</sup> rnberg, Erlangen, Germany, March 1994.
- [59] Synopsys. *Design Compiler Family Reference*. Synopsys, Inc., Mountain View, CA, April 1995. (Version 3.3a).
- [60] Synopsys. Finite state machine tutorial source code. April 1995. (Version 3.3a).
- [61] Synopsys. *Finite State Machines–Application Note*. Synopsys, Inc., Mountain View, CA, April 1995.
- [62] Synopsys. VHDL Compiler Reference. Synopsys, Inc., Mountain View, CA, April 1995. (Version 3.3a).
- [63] Synopsys. *VSS Reference*. Synopsys, Inc., Mountain View, CA, April 1995. (Version 3.3a).
- [64] Viewlogic Systems. Using Powerview. Viewlogic Systems, Inc., Marlboro, MA, 1994.
- [65] Xilinx. *The Programmable Logic Data Book*. Xilinx, Inc., San Jose, CA, 2nd edition, 1994.
- [66] Xilinx. XACT Reference Guide. Xilinx, Inc., San Jose, CA, April 1994.
- [67] Xilinx. *XACT Xilinx Synopsys Interface FPGA User Guide*. Xilinx, Inc., San Jose, CA, December 1994.
- [68] Xilinx. Floorplanner User Guide. Xilinx, Inc., San Jose, CA, February 1995. (preliminary version).
- [69] D. Sillage, "How to implement DSP algorithms using the Xilinx Spartan-3E starter board", website: <a href="http://www.industrialcontroldesignline.com/howto/207001725;jsessionid">http://www.industrialcontroldesignline.com/howto/207001725;jsessionid</a> =YDZGLZ44Z2B3AQSNDLRSKHSCJUNN2JVN?pgno=2, July 2009.
- [70] Ray C.C. Cheung and K.P. Pun and Steve C.L. Yuen and K.H. Tsoi and Philip H.W. Leong An FPGA-based Re-configurable 24-bit 96kHz Sigma-Delta Audio *DAC.* FPT 2003, Tokyo, Japan.

- [71] <u>http://www.xilinx.com/products/boards/s3estarter/reference\_designs.htm</u>
- [72] Xilinx, "Spartan-3E Starter Kit Board User Guide", Xilinx Ltd, p.67-71, 2012.
- [73] Xilinx, "Spartan-3E Starter Kit Board User Guide", Xilinx Ltd, p.41-51, 2012.
- [74] Xilinx, "Spartan-3E Starter Kit Board User Guide", Xilinx Ltd, p.17-19, 2012.
- [75] Xilinx,Forums,http://forums.xilinx.com/xlnx/board/message?board.id=XLNXBRD& thread.id=463&view=by\_date\_ascending&page=1,December.2011
- [76] Xilinx, "Spartan-3E Starter Kit Board User Guide", Xilinx Ltd, p.75-81,2006.
- [77] K. Chapman, "Picoblaze: amplifier and A/D Converter Control for Spartan-3E Starter Kit", Xilinx Ltd. 2006.
- [78] Xilinx, Forums, http://forums.xilinx.com/xlnx/board/message?board.id=XLNXBRD&thre ad.id=463&view=by\_date\_ascending&page=1, July 2012.
- [79] <u>http://www.elec.york.ac.uk/staff/ajg112.html</u>, 27th May, 2012.
- [80] Abhyankar, Y., Design of a FPGA based data acquisition system for radio astronomy applications, The 16th International Conference on Microelectronics, 2004. ICM 2004 Proceedings.
- [81] Sabat, S.L. Reliable High Speed Data Acquisition System Using FPGA, 2nd International Conference on Emerging Trends in Engineering and Technology (ICETET), 2009.
- [82] Li Xingguang, A high-speed data acquisition system based on FPGA, International Conference on Test and Measurement, 2009. ICTM '09.
- [83] Zhouligong.etc. The ARM Embedded system Software Development Example(1). BeiHang Unviesity Press.
- [84] Xuzhijun CPLD/FPGA design. Publishing house of electronics industry.
- [85] Daode Zhang etc.Hardware Design of Image Recognition System Based ARM and FPGA.
- [86] Howard Johnson, Martin Graham. High-Speed Digital Design. Prentice HALL Press.

- [87] Zhao Zecai, The SOC Design Technology Research Based on FPGA, National Defense Science and Technology University Press, Changsha, 2006.
- [88] Wang Junxiong, The Embedded Applied Research System Based on the FPGA and the NIOS, Southwest Jiaotong University,Xi'an,2006.
- [89] Xu Haijun and Ye Weidong, "The Apply of FPGA in the High-performance Data Acquisition System", Computer Technology and Application, 2005, 25(1), pp. 40-43.
- [90] Ma Mingjian and Zhou Changcheng, Data Acquisition and Processing Technology, Xi'an Jiaotong University Press, Xi'an, 2001.
- [91] <u>http://www.whoyouvotefor.info/ethernet.html</u>, 7<sup>th</sup> May, 2012.
- [92] Wu Jihua and Wang Cheng,The Design of The Altera FPGA/CPLD, Posts & Telecom Press,Beijing,2005.
- [93] Istiyanto, J.E., A VHDL-based ADC on FPGA, International Conference on Instrumentation, Communications, Information Technology, and Biomedical Engineering (ICICI-BME), 2009.

# **APPENDIX-A**

# **XILINX-13.2 ISE TUTORUAL**

### XILINX-13.2 ISE TUTORIAL

#### **INTRODUCTION THE XILINX-13.2 ISE**



, to start the ISE Project Navigator (0.61xd) . After that you will find a

window like figure-1.

| 108 Properties     Module Level Utilization     Timing Constraints     Timing Constraints     Photot Report     Static Timing     Static Timing     and Viamings     Parser Nessages     Translation Messages     May Messages | · III                                                                                                                                    | Project File:<br>Module Hame:<br>Target Device:<br>Product Version:<br>Design Goal:<br>Design Strategy:                                                            | alarm.xise<br>alarm<br>xc3s500e-4fg320<br>ISE 13.2<br>Balanced<br>Xilinx Default (unlocke                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Parser Errors:<br>Implementation State:<br>• Errors:<br>• Warnings:<br>• Routing Results:                                                                                                                                                                                                                                                                                                                                                                                                                | No Error<br><u>7 Warnin</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nd Routed<br>s<br>rgs (1 new)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timing Constraints<br>Pinout Report<br>Clock Report<br>Static Timing<br>and Warnings<br>Parser Messages<br>Synthesis Messages<br>Translation Messages<br>Map Messages                                                          | · III                                                                                                                                    | Target Device:<br>Product Version:<br>Design Goal:<br>Design Strategy:                                                                                             | xc3s500e-4fg320<br>ISE 13.2<br>Balanced                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | • Errors:<br>• Warnings:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No Error<br><u>7 Warnin</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s<br>Ig <u>s (1 new)</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Pinout Report<br>Clock Report<br>Static Timing<br>and Warnings<br>Parser Messages<br>Synthesis Messages<br>Translation Messages<br>Map Messages                                                                                | ш                                                                                                                                        | Product Version:<br>Design Goal:<br>Design Strategy:                                                                                                               | ISE 13.2<br>Balanced                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | • Warnings:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <u>7 Warni</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | igs (1 new)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Static Timing<br>s and Warnings<br>Parser Messages<br>Synthesis Messages<br>Translation Messages<br>Map Messages                                                                                                               |                                                                                                                                          | Design Strategy:                                                                                                                                                   | Balanced                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| s and Warnings<br>Parser Messages<br>Synthesis Messages<br>Translation Messages<br>Map Messages                                                                                                                                |                                                                                                                                          | Design Strategy:                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Douting Docultor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <ul> <li>Parser Messages</li> <li>Synthesis Messages</li> <li>Translation Messages</li> <li>Map Messages</li> </ul>                                                                                                            |                                                                                                                                          |                                                                                                                                                                    | March Real Andread                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <ul> <li>Kouting Kesults:</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Al Signa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Is Completely Routed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Translation Messages<br>Map Messages                                                                                                                                                                                           |                                                                                                                                          |                                                                                                                                                                    | Allinx Default (unlocker                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <u>d)</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | • Timing Constraints:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Al Cons                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | traints Met                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Map Messages                                                                                                                                                                                                                   |                                                                                                                                          | Environment:                                                                                                                                                       | System Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | • Final Timing Score:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 <u>(Timin</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <u>g Report)</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                | i.                                                                                                                                       |                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Place and Route Messages<br>Timing Messages                                                                                                                                                                                    |                                                                                                                                          |                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Device Utilizatio                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | on Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1 Bitgen Messages                                                                                                                                                                                                              |                                                                                                                                          | Logic Utilization                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Used                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Available                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Utilization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Note(s)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| All Implementation Messages                                                                                                                                                                                                    | Ŧ                                                                                                                                        | Number of Slice Flip Flops                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9,312                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| roperties                                                                                                                                                                                                                      | ٦                                                                                                                                        | Number of 4 input LUTs                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9,312                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| nable Message Filtering                                                                                                                                                                                                        |                                                                                                                                          | Number of occupied Slices                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4,656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                |                                                                                                                                          | Number of Slices containing only related k                                                                                                                         | ogic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 100%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| how Failing Constraints                                                                                                                                                                                                        |                                                                                                                                          | Number of Slices containing unrelated logi                                                                                                                         | ic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                |                                                                                                                                          | Total Number of 4 input LUTs                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9,312                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| NOW ETIOIS                                                                                                                                                                                                                     |                                                                                                                                          | Number of bonded <u>IOBs</u>                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 232                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 2%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                |                                                                                                                                          |                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| ISE Design Suite InfoCe                                                                                                                                                                                                        | inter                                                                                                                                    | <u> </u>                                                                                                                                                           | Di                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | esign Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                |                                                                                                                                          |                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ++ [                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                                                                                                                                                                                                                                | is Rossian<br>able Message Filtering<br>lesign Summary Contents<br>ow Clock Report<br>ow Faling Constraints<br>ow Warnings<br>ow Werrors | tennessis<br>able Message Filtering<br>able Message Filtering<br>beign Summary Contents<br>iow Clock Report<br>ow Failing Constraints<br>ow Varnings<br>iow Errors | Auto-state<br>poperties<br>able Message Filtering<br>Design Summary Contents<br>ow Viack Report<br>Number of Silces containing only related is<br>Number of Silces containing unrelated is<br>Number of Silces Conta | Aurobic of 4 Input LUTs     Aurober of 4 Input LUTs     Aurober of Sices containing only related logic     Now Farling Constraints     Now Varnings     Total Number of 9 Anput LUTs     Number of Bices containing unrelated logic     Total Number of 9 Anput LUTs     Number of Bices containing unrelated logic     Total Number of 9 Anput LUTs     Number of Bices containing unrelated logic     Total Number of 9 Anput LUTs     Number of Bices containing     Number of Bices containing unrelated logic     Total Number of 9 Anput LUTs     Number of Bices Containing     Number of Bices Containing unrelated logic | Auto-science         Number of 4 riput LUTs         5           Sperifies         Number of 2 riput LUTs         5           Beign Summary Contents         Number of Scies ontaining only related logic         4           ow Failing Constraints         Number of Scies ontaining only related logic         4           ow Vainings         Total Number of Scies ontaining unrelated logic         0           ow Errors         Number of BUFGHUs         5           Number of BUFGHUs         2 | Autorian         Autor of 4 Hyput LUTs         S         9,312           operties         Autor of 4 Hyput LUTs         S         9,312           beign Summary Contents         Number of cocquied Sites         4         4,655           ow Failing Constraints         Number of Sites containing only related logic         4         4           ow Venings<br>tow Errors         Total Number of Hyput LUTs         S         9,312           Number of Sites containing only related logic         0         4           Number of Sites containing unrelated logic         0         4           Number of Sites containing on related logic         0         4           Number of Sites containing unrelated logic         0         2           Number of BUFGMUIS         S         9,312 | Autorian         Autor of 4 roput LUTs         5         9,312         1%           operties         Number of 4 roput LUTs         5         9,312         1%           beign Summary Contents<br>ow Vook Report         Number of Sizes containing only related logc         4         4,655         1%           Number of Sizes containing only related logc         0         4         0%         0%           Number of Sizes containing unvelated logc         0         4         0%         0%           Number of Sizes containing unvelated logc         0         4         0%         0%           Number of Sizes containing unvelated logc         0         4         0%         0%         0%         1%         0%         1%         0%         1%         0%         1%         0%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1%         1% </td <td>Autorian         Autor of 4 ruput LUTs         5         9,312         1%           operties         Autor of 4 ruput LUTs         5         9,312         1%           beign Summary Contents<br/>ow Vook Report         Number of Sices containing only related logc         4         4,655         1%           Number of Sices containing only related logc         0         4         00%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         5         9,312         1%           Number of Sices containing unvelated logs         5         222         2%           Number of BIFGNUts         2         24         8%  </td> | Autorian         Autor of 4 ruput LUTs         5         9,312         1%           operties         Autor of 4 ruput LUTs         5         9,312         1%           beign Summary Contents<br>ow Vook Report         Number of Sices containing only related logc         4         4,655         1%           Number of Sices containing only related logc         0         4         00%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         0         4         0%           Number of Sices containing unvelated logc         5         9,312         1%           Number of Sices containing unvelated logs         5         222         2%           Number of BIFGNUts         2         24         8% |

Figure-A1. ISE Project Navigator (0.61xd)



#### Figure-A2. Project Navigator Window

#### Step 1. Creating New Project

File→New Project Or,



Click on the Icon,

| reate New Pro           | runie the Project |
|-------------------------|-------------------|
| pecify project location | n and type.       |
| Name:                   | alarm             |
| Location:               | D:\Project\alarm  |
| Working Directory:      | D: \Project\alan  |
|                         | Create Directory  |
| Select the type of to   | D:\Project\alarm  |
| Top-level source typ    | e:                |

Figure-A3. Creating New Project



Figure-A4. Creating New Project (Cont.)

In the figure-4 the most important thing is that you have to select "Evaluation Development Board"-type as "Spartan-3E Starter Board", as we have used this board while developing our system. Xilinx-13.2 ISE supports the following "Evaluation Development Board".

- Kintex-7 KC705 Evaluation Platform.
- Spartan-3A DSP 1800A Starter Board.
- Spartan-3A DSP 3400A Development Board.
- Spartan-3A Starter Kit.
- Spartan-3AN Starter Kit.

- Spartan-3E 1600E Micro blaze Dev Board.
- Spartan-3E Starter Kit.
- Spartan-6 SP601 Evaluation Platform.
- Spartan-6 Sp605 Evaluation Platform.
- Virtex-4 ML403 Evaluation Platform.
- Virtex-4 ML405 Evaluation Platform.
- Virtex-5 ML505 Evaluation Platform.
- Virtex-5 ML506 Evaluation Platform.
- Virtex-5 ML507 Evaluation Platform.
- Virtex-5 ML510 Evaluation Platform.
- Virtex-6 ML605 Evaluation Platform.

The second important thing is that we have considered here the "**VHDL Source Analysis Standard**"-**VHDL-93**. Xilinx-13.2 ISE also supports VHDL-200X.

| Project Summary             |                                                      |  |
|-----------------------------|------------------------------------------------------|--|
| Project Navigator will crea | ate a new project with the following specifications. |  |
| Project:                    |                                                      |  |
| Project Name                | : alarm                                              |  |
| Project Path                | : D:\Project\alarm                                   |  |
| Working Dire                | ctory: D:\Project\alarm                              |  |
| Description:                |                                                      |  |
| Top Level So                | urce Type: HDL                                       |  |
| Device:                     |                                                      |  |
| Evaluation I                | evelopment Board: Spartan-3E Starter Board           |  |
| Device Famil                | y: Spartan3E                                         |  |
| Device:                     | xc3s500e                                             |  |
| Package:                    | fg320                                                |  |
| Speed:                      | -4                                                   |  |
| Top-Level Sc                | urce Type: HDL                                       |  |
| Synthesis To                | ool: XST (VHDL/Verilog)                              |  |
| Simulator: I                | Sim (VHDL/Verilog)                                   |  |
| Preferred La                | nguage: Verilog                                      |  |
| Property Spe                | cification in Project File: Store all values         |  |
| Manual Compi                | le Order: false                                      |  |
| VHDL Source                 | Analysis Standard: VHDL-93                           |  |

Figure-A5. Creating New Project (Cont.)

In the last step simply click finish. Then you will get the following window.



Figure-A6. Creating New Project (Completed).

#### Step-2: Creating New Source

From the design plane, click on the Icon, I knich denotes the "New Source". Choose VHDL Module as "Source Type", Type "alarm" in file name and click next.



Figure-A7. Creating New Source.

| Select source type, file name and its location. | Name the File    |
|-------------------------------------------------|------------------|
| Schematic<br>System Generator Project           |                  |
| User Document<br>Verilog Module                 |                  |
| Verilog Test Fixture                            | File name:       |
| VHDL Library                                    | alarm            |
| VHDL Test Bench                                 | Location:        |
| 🗭 Embedded Processor                            | D:\Project\alarm |
|                                                 |                  |

Figure-A8.New Source Wizard.

| New Source Wizard            |        |      |     |     |     |  |
|------------------------------|--------|------|-----|-----|-----|--|
| Define Module                |        |      |     |     |     |  |
| Specify ports for module.    |        |      |     |     |     |  |
| Entity name alarm            |        |      |     |     |     |  |
| Architecture name Behavioral |        |      |     |     |     |  |
| Port Name                    | Direct | tion | Bus | MSB | LSB |  |
| clk                          | in     | -    |     |     |     |  |
| remote                       | in     | •    |     |     |     |  |
| rst                          | in     | •    |     |     |     |  |
| sensors                      | in     | •    |     |     |     |  |
| siren                        | out    | •    |     |     |     |  |
|                              | out    | •    |     |     |     |  |
|                              | in     | •    |     |     |     |  |
|                              | in     | •    |     |     |     |  |
|                              | in     | •    |     |     |     |  |
|                              | in     | -    |     |     |     |  |

Figure-A9. New Source Wizard (Continue).

Define the port name and direction as shown in the figure-9.



Figure-A10. Project Navigator Window for the Project "alarm".

After that copy the following code in the "**workplace window**". The main objective of this tutorial is to get acquainted the readers with Xilinx-13.2 ISE's use, not to give idea how to write VHDL code. The most important thing about VHDL language is that it is not a case sensitive language like "C". So we have used here the capital letters while programming. This is "alarm.vhd" file.

\_\_\_\_\_

--ENGINEER: HUSNAIN-AL-BUSTAM

-- REVISION 0.01 - FILE CREATED

-----

LIBRARY IEEE;

USE IEEE.STD\_LOGIC\_1164.ALL;

-- UNCOMMENT THE FOLLOWING LIBRARY DECLARATION IF USING

-- ARITHMETIC FUNCTIONS WITH SIGNED OR UNSIGNED VALUES

--USE IEEE.NUMERIC\_STD.ALL;

-- UNCOMMENT THE FOLLOWING LIBRARY DECLARATION IF INSTANTIATING

```
-- ANY XILINX PRIMITIVES IN THIS CODE.
--LIBRARY UNISIM;
--USE UNISIM.VCOMPONENTS.ALL;
ENTITY ALARM IS
 PORT ( CLK : IN STD_LOGIC;
        REMOTE : IN STD_LOGIC;
    RST : IN STD_LOGIC;
    SENSORS : IN STD_LOGIC;
    SIREN : OUT STD_LOGIC);
END ALARM;
ARCHITECTURE BEHAVIOURAL OF ALARM IS
      TYPE ALARM_STATE IS (DISARMED, ARMED, INTRUSION);
      ATTRIBUTE ENUM_ENCODING : STRING;
      ATTRIBUTE ENUM_ENCODING OF ALARM_STATE: TYPE IS "SEQUENTIAL";
      SIGNAL PR_STATE, NX_STATE : ALARM_STATE;
      SIGNAL FLAG: STD_LOGIC;
      CONSTANT RESET: STD_LOGIC :='0';
      BEGIN
----- FLAG: -----
             PROCESS (REMOTE, RST)
             BEGIN
                    IF (RST='1') THEN
                           FLAG <= '0';
                    ELSIF (REMOTE'EVENT AND REMOTE='0') THEN
                    --ELSIF (REMOTE='0') THEN
                           FLAG <= NOT FLAG;
                    END IF;
             END PROCESS;
----- ------LOWER SECTION: ------
             PROCESS (CLK, RST)
             BEGIN
                    IF (RST='1') THEN
                           PR_STATE <= DISARMED;</pre>
                    ELSIF (CLK'EVENT AND CLK='1') THEN
                           PR_STATE <= NX_STATE;</pre>
                    END IF;
             END PROCESS;
```

----- UPPER SECTION: -----

```
PROCESS (PR_STATE, FLAG, REMOTE, SENSORS)
                     BEGIN
                            CASE PR_STATE IS
                            WHEN DISARMED =>
                                   SIREN <= '0';
                                   IF (REMOTE='1' AND FLAG='0') THEN
                                           NX_STATE <= ARMED;
                                   ELSE
                                           NX_STATE <= DISARMED;
                                   END IF;
                            WHEN ARMED =>
                                   SIREN <= '0';
                                   IF (SENSORS='1') THEN
                                           NX_STATE <= INTRUSION;
                                   ELSIF (REMOTE='1' AND FLAG='1') THEN
                                           NX_STATE <= DISARMED;
                                   ELSE
                                           NX_STATE <= ARMED;
                                   END IF;
                            WHEN INTRUSION =>
                                   SIREN <= '1';
                                   IF (REMOTE='1' AND FLAG='1') THEN
                                           NX_STATE <= DISARMED;
                                   ELSE
                                   NX_STATE <= INTRUSION;
                                           END IF;
                                   END CASE;
              END PROCESS;
END BEHAVIOURAL;
```

-----

Expand the "Synthesize-XST". Click "Check Syntax". Correct the error. Then check syntax again.

| ISE Project Navigator (O.61xd) - D:\Project\alarm\alar<br>File Edit View Project Source Process To           |                                                                           |                             | 5   |
|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------|-----|
|                                                                                                              | » 𝒫 𝒫 𝔅 𝔅 𝔅 🖉 💽 🚰 🗖 🖼 🖉 🕨 𝔅 🕨 𝔅                                           | 1 <b>0</b>                  |     |
|                                                                                                              |                                                                           | · V                         |     |
|                                                                                                              |                                                                           | tion if instantiating       |     |
|                                                                                                              |                                                                           | cion il instantiating       |     |
| Hierarchy                                                                                                    | 14 any XIIIX primitives in this code.           15        library UNISIM; |                             |     |
| 👔 - 🗑 alarm                                                                                                  | 16use UNISIM.VComponents.all;                                             |                             |     |
| 🖳 🗁 🛄 xc3s500e-4fq320                                                                                        | = 17                                                                      |                             |     |
| 📲 💷 🍡 📲 alarm - behavioural (alarm.vhd)                                                                      | 18 entity alarm is                                                        |                             |     |
| —                                                                                                            | 19 Port (clk : in STD_LOGIC;<br>20 remote : in STD_LOGIC;                 |                             |     |
| <b>a</b>                                                                                                     | 20 remote : in STD LOGIC;                                                 |                             |     |
| a                                                                                                            | A 21 rst : in STD_LOGIC;                                                  |                             |     |
|                                                                                                              | 22 sensors : in STD_LOGIC;                                                |                             |     |
|                                                                                                              | <pre>23 siren : out STD LOGIC);</pre>                                     |                             |     |
| ×                                                                                                            | 24 end alarm;                                                             |                             |     |
|                                                                                                              | 25                                                                        |                             |     |
| No Processes Running                                                                                         | 26                                                                        |                             |     |
|                                                                                                              | 27 ARCHITECTURE behavioural OF alarm IS                                   |                             |     |
| 14 Processes alarm - benavioural                                                                             | 28                                                                        |                             |     |
| 👷 🛛 📓 Design Summary/Reports                                                                                 | 29 TYPE alarm_state IS (disarmed, armed, i                                | ntrusion);                  |     |
| 👚 🕀 🎽 Design Utilities                                                                                       | 30                                                                        |                             |     |
|                                                                                                              | <pre>31 ATTRIBUTE enum_encoding : STRING;</pre>                           |                             |     |
| 📄 🕀 Synthesize - XST                                                                                         | 32<br>33 ATTRIBUTE enum encoding OF alarm state:                          | TWDE IC HermannialH.        |     |
| View RTL Schematic                                                                                           | 33 AIIRIBULE enum_encoding of alarm_state:                                | IIPE 15 "Sequencial";       |     |
| View Technology Schematic                                                                                    | 35 SIGNAL pr state, nx state : alarm stat                                 |                             |     |
| Generate Post-Synthesis Simulati                                                                             | 36                                                                        | "Check Syntax"-completed    |     |
| Implement Design                                                                                             | T ( III                                                                   | Check Syntax -completed     |     |
| Start 2 Design  Files  Libraries                                                                             | ISE Design Suite InfoCenter I Design Summary (out of                      | successfully means there is | ⊢   |
|                                                                                                              | Z Design Some InfoCenter                                                  | •                           |     |
| Warnings                                                                                                     |                                                                           | no error in the code.       | +   |
|                                                                                                              |                                                                           |                             |     |
|                                                                                                              |                                                                           |                             | L   |
| 4                                                                                                            |                                                                           |                             |     |
|                                                                                                              |                                                                           |                             |     |
| Console                                                                                                      |                                                                           |                             | +   |
| Entity <alarm> (Architecture <behav< td=""><td>ioural&gt;) compiled.</td><td></td><td></td></behav<></alarm> | ioural>) compiled.                                                        |                             |     |
|                                                                                                              |                                                                           |                             |     |
| Process "Check Syntax" completed su                                                                          | ccessfully                                                                |                             |     |
|                                                                                                              |                                                                           |                             |     |
| < m                                                                                                          |                                                                           |                             |     |
| Console 🙀 Find in Files Results                                                                              |                                                                           |                             |     |
|                                                                                                              |                                                                           | 1 - 103                     |     |
|                                                                                                              |                                                                           | Ln 102                      | 011 |

Figure-A11. Checking Syntax (Successful).

## Step-3. Creating Test Bench File

Click of the Icon, (From the Design Plane-New Source). Choose VHDL Test Bench. File name "alarm\_tb". And click "Next" to create file.

| New Source Wizard     Select Source Type                                                                                                                                                                                                                                                                                          | -                  | 23                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------|
| Select source type, file name and its location. BMM File ChipScope Definition and Connection I Implementation Constraints File IP (CORE Generator & Architecture Wiz MEM File Schematic System Generator Project User Document Verilog Module Verilog Test Fixture VHDL Nodule VHDL Library VHDL Library VHDL Library VHDL Ackage | File               | velarm                |
| MUDL Test Bench                                                                                                                                                                                                                                                                                                                   | Select             |                       |
| More Info                                                                                                                                                                                                                                                                                                                         | VHDL<br>Test Bench | roject<br>Next Cancel |

Figure-A12. New Source Wizard (Test Bench)

From the "Design Pane" select the "Simulation" and you will get a hierarchy like figure-13. Click on the "alarm\_tb behavior" as shown in the figure-13.



Figure-A13. New Source Wizard (Test Bench).

After that copy the following code in the "workplace window". The following code is for "alarm\_tb" file.

-----

- -- COMPANY: ISLAMIC UNIVERSITY OF TECHNOLOGY, OIC
- -- ENGINEER:HUSNAIN-AL-BUSTAM
- -- CREATE DATE: 18:08:42 11/18/2011
- -- DESIGN NAME: ALARM
- -- PROJECT NAME: ALARM
- -- TARGET DEVICE: SPARTAN-3E STARTER KIT.
- -- VHDL TEST BENCH CREATED BY ISE FOR MODULE: ALARM

-----

LIBRARY IEEE;

USE IEEE.STD\_LOGIC\_1164.ALL;

- -- UNCOMMENT THE FOLLOWING LIBRARY DECLARATION IF USING
- -- ARITHMETIC FUNCTIONS WITH SIGNED OR UNSIGNED VALUES
- --USE IEEE.NUMERIC\_STD.ALL;

ENTITY ALARM\_TB IS

END ALARM\_TB;

ARCHITECTURE BEHAVIOR OF ALARM\_TB IS

-- COMPONENT DECLARATION FOR THE UNIT UNDER TEST (UUT)

```
COMPONENT ALARM
  PORT(
    CLK : STD_LOGIC;
    REMOTE : IN STD_LOGIC;
    RST : IN STD_LOGIC;
    SENSORS : IN STD_LOGIC;
    SIREN : OUT STD_LOGIC;
    CLKOUT : OUT STD_LOGIC
   );
 END COMPONENT;
 --INPUTS
 SIGNAL CLK : STD_LOGIC := '0';
 SIGNAL REMOTE : STD_LOGIC := '0';
 SIGNAL RST : STD_LOGIC := '0';
 SIGNAL SENSORS : STD_LOGIC := '0';
 SIGNAL SIREN : STD_LOGIC;
 SIGNAL CLKOUT : STD_LOGIC;
BEGIN
 CLK <= NOT CLK AFTER 20 NS;
-- INSTANTIATE THE UNIT UNDER TEST (UUT)
 UUT: ALARM PORT MAP (
    --CLK => CLK,
    CLKIN => CLK,
    REMOTE => REMOTE,
    RST => RST,
    SENSORS => SENSORS,
    SIREN => SIREN,
    CLKOUT => CLKOUT
   );
 -- CLOCK PROCESS DEFINITIONS
 -- STIMULUS PROCESS
 STIM_PROC: PROCESS
 BEGIN
 WAIT FOR 600 NS;
              RST <= '1';
              WAIT FOR 50 NS;
              RST <='0';
```

```
WAIT FOR 50 NS;
REMOTE <='1';
WAIT FOR 50 NS;
SENSORS<='1';
WAIT FOR 100 NS;
--REMOTE <='0';
--WAIT FOR 50 NS;
REMOTE <='1';
WAIT FOR 50 NS;
```

END PROCESS;

END;



Figure-A14. Design (Simulation)

On the view pane select "Simulation". In the hiearchy window select the file "alarm\_tb". In the process window first expand the "ISim Simulator" and run "Behavioural Check Syntax". Click "Simulation Behavioral Model" to start "ISim". Browse the window.



Figure-A15. Simulation.



#### Figure-A16. Isim Window.

#### HARDWARE IMPLEMENTATION

#### <u>STEP-1:</u>

On the view pane now select again the "implementation". Expand "User Constraints". Double click on the "Create Timing Constraints". Then a window will appear before you where you will find "Unconstrained Clocks". This project has two "Unconstrained Clocks"- "clk" and "remote". Just double click on them. Each time one windows will appear when you double click on a clock. For the simplicity we haven't changed any parameter. Click "Ok" to finish. The "Unconstrained Clocks" will be constrained. Save and Exit. The whole process is depicted in the following figures.



Figure-A17. Expanded User Constraints.

| a        |  |
|----------|--|
| 1 clk    |  |
| 2 remote |  |

Figure-A18. Unconstrained Clocks

| Clock Perio                                                |                              | <u>×</u> |
|------------------------------------------------------------|------------------------------|----------|
|                                                            |                              |          |
| * TIMESPEC na                                              |                              | _        |
| <ul> <li>Clock net nar</li> <li>Clock signal of</li> </ul> |                              | •        |
| Specify                                                    |                              |          |
| Time: 2                                                    |                              |          |
| Init                                                       | al dock edge:                |          |
| Ris                                                        | ng duty cycle: 50 Units:     | % 💌      |
|                                                            | to other period TIMESPEC     |          |
| -                                                          | e TIMESPEC:                  | Ŧ        |
| Factor                                                     |                              | Y        |
|                                                            | nd:  Multiply by   Divide by |          |
|                                                            | Value: 1                     |          |
| Phase                                                      | 100 M                        | _        |
| Phase                                                      |                              |          |
|                                                            | Value: 0.0 Units: ns         | ~        |
|                                                            |                              |          |
| Input jitter:                                              | Units:                       | ps 🔻     |
| Priority:                                                  |                              |          |
| Comment:                                                   |                              |          |
|                                                            | OK Close Create H            | ielp     |
|                                                            |                              |          |

Figure-A19. Profile Generated for Clock "CLK"

| Clock Pe     | ve edge i  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
|--------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------|
| * TIMESPE    | C name:    | TS_remo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | te                  |             |
| Clock net    | name:      | remote                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     |             |
| Clock sign   | nal defini | tion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                     |             |
| Spece        | ify time   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
| Time:        | 20         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     | Units: ns 💌 |
|              | Initial do | ock edge:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Rising (HIGH)       |             |
|              | Rising d   | uty cyde:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 50                  | Units: %    |
| 🔘 Rela       | tive to of | ther perior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | TIMESPEC            |             |
| Refe         | erence TI  | MESPEC:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TS_dk               | <b>v</b>    |
| Fa           | ctor       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
| Op           | perand:    | Ø Mul                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | iply by 💿 Divide by |             |
|              |            | Value:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                   |             |
| Ph           | ase shift  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
| Ph           | ase:       | Plus     Plus | O Minus             |             |
|              |            | Value:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0.0                 | Units: ns 👻 |
|              |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
| input jitter | :          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     | Units: ps 💌 |
| Priority:    |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
| Comment:     |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |
|              |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | OK Close Create     | Help        |
|              |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                     |             |

Figure-A20. Profile Generated for Clock "REMOTE"

| <ul> <li>พ ต X ถิ ถิ X ถิ สิ ฐี</li> </ul>                            | PPBI    | 8 P 🖪 🛃 🕤       |                 | · · · · · · · · · · · · · · · · · · · | V        |                                         |             |                    |        |            |         |
|-----------------------------------------------------------------------|---------|-----------------|-----------------|---------------------------------------|----------|-----------------------------------------|-------------|--------------------|--------|------------|---------|
| ng Constraints ↔ □ ♂ ×                                                |         |                 |                 |                                       |          |                                         |             |                    |        |            |         |
| ource Constraint File                                                 |         |                 |                 |                                       |          | tor Clock Domains<br>lick to open conte |             |                    |        |            |         |
| slarm.ucf                                                             | State A | TIMESPEC Name * | Clock Time Name | Clock Net *                           | Period   | Duty Cycle                              | Edge        | Reference TIMESPEC | Factor | Phase Shif |         |
| ) Show constraints from specified file only                           | 1 OK    | TS_clk          | clk             | clk                                   | 20 ns    | 50 %                                    | HIGH        |                    |        |            |         |
| Show constraints from all files                                       | 2 OK    | TS_remote       | remote          | remote                                | 20 ns    | 50 %                                    | HIGH        |                    |        |            |         |
| ave New Constraints To File                                           | 2       |                 |                 |                                       | <u> </u> |                                         |             |                    |        |            |         |
| slarm.ucf                                                             |         |                 |                 |                                       |          |                                         |             |                    |        |            |         |
|                                                                       |         |                 |                 |                                       |          |                                         |             |                    |        |            |         |
| Miscellaneous                                                         | Filter: | Constra:        |                 | ocks                                  | sd) 🙁    | ()<br>()                                | ming Constr | ints* 🙁            |        | B          | nd      |
| Outputs<br>Departing Conditions<br>Group Constraints<br>Miscellaneous | Filter: |                 |                 |                                       | d) 🗶     | ( <sup>23</sup> )                       | ming Constr | ints*              |        | F          | nd<br>↔ |

Figure-A21. Constrained Clocks

#### **STEP-2:**

From the process window select ("User Constraints") select "I/O Planning (Plan Ahead) Post Synthesis" (Figure-14). There you will find a window like "Figure-19". In the "I/O Port" window expand the "Scalar Ports" and assign the values as follows,

- Assign net "clk" to 50 MHz clock.
- Assign "remote" net to the button (V4).
- Assign "rst" net to the button (K17).
- Assign "sensors" net to the slide button (N17).
- Assign "siren" to Led (F9).

Consult "Spartan-3E Starter Kit" for the remaining constraints.

|                                                                                                                                                                                                                                                                                                                                                                                                                                       | 500efg320    |        |               |             |                         |                      |                                               |       |           |       |               | A state            | St 1 Stall         | 1            |          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------|---------------|-------------|-------------------------|----------------------|-----------------------------------------------|-------|-----------|-------|---------------|--------------------|--------------------|--------------|----------|
| st                                                                                                                                                                                                                                                                                                                                                                                                                                    | - D á        | × م    | 🗄 Packa       | ige ×       |                         |                      |                                               |       | 0 0       | א ק×  | Sevic         | e X                |                    |              |          |
| 1 B                                                                                                                                                                                                                                                                                                                                                                                                                                   |              |        | )             |             |                         |                      |                                               |       |           |       | +             |                    | - 00               |              |          |
| rm<br>Nets (19)                                                                                                                                                                                                                                                                                                                                                                                                                       |              |        | +             |             |                         |                      | ш.,                                           | -     |           |       | $\rightarrow$ |                    |                    |              |          |
| Primitives (15)                                                                                                                                                                                                                                                                                                                                                                                                                       |              |        | $\rightarrow$ |             |                         | - Stell              | -44                                           | 110   |           |       | liệi          |                    |                    |              |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |        | P.            |             | i dolo                  |                      |                                               | -     |           |       | 0             |                    |                    |              |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |        | 0             |             |                         |                      |                                               |       |           |       | 3             |                    |                    | - Ŭ :        |          |
| Sources 🙀 Netlist 🔒 Timing Const                                                                                                                                                                                                                                                                                                                                                                                                      | raints (UCF) |        | *             |             |                         |                      |                                               |       |           |       | 4             |                    |                    | - <b>B</b> - |          |
| rties                                                                                                                                                                                                                                                                                                                                                                                                                                 | - 0 6        |        | œ             |             | 0.0101010               |                      | C (2 + 2 1                                    | 10.0  |           |       | at .          |                    | -                  |              |          |
| ives<br>▶ SS k                                                                                                                                                                                                                                                                                                                                                                                                                        | - 0 0        | P ^    | #             |             | <b>B-0-101</b>          | 00000                | 44 <u>4</u>                                   | 2.0.0 |           |       |               |                    |                    |              |          |
| 7 <u>19</u> K                                                                                                                                                                                                                                                                                                                                                                                                                         |              | -      | 2             |             |                         | 111                  |                                               | 10    |           |       | æ             |                    |                    |              |          |
| Properties Clock Regions                                                                                                                                                                                                                                                                                                                                                                                                              |              |        |               |             |                         | 0.040                |                                               |       |           |       | 1211          |                    |                    |              |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |        | J×2 +         |             |                         |                      |                                               |       |           |       | C.I.I.F       |                    |                    |              |          |
| xts                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1.01.11      |        | 100000        | 2 2 00.000  | 1.57 57.5 25            | 11.92 12             |                                               |       |           |       |               |                    |                    |              | - 0      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |        | O Std 1       | /cco Vref   | Drive Strength          | Slew T               | ype Pull                                      | Type  |           |       |               |                    |                    |              |          |
| lame Dir Neg Diff Pair                                                                                                                                                                                                                                                                                                                                                                                                                | and 0        | ALC: Y | 0.000         | need their  | on or other starting of |                      |                                               |       |           |       |               |                    |                    |              |          |
| All ports (5)                                                                                                                                                                                                                                                                                                                                                                                                                         | and 0        | ALIA I | 10.242        | 1000 1101   |                         |                      |                                               |       |           |       |               |                    |                    |              |          |
| ame Dir Neg Diff Par                                                                                                                                                                                                                                                                                                                                                                                                                  | and 0        | an 1   | 0.00          | ices incl   |                         |                      |                                               |       |           |       |               |                    |                    |              |          |
| All ports (5)                                                                                                                                                                                                                                                                                                                                                                                                                         | and D        |        | 0.00          | inter inter |                         |                      |                                               |       |           |       |               |                    |                    |              |          |
| All ports (5)                                                                                                                                                                                                                                                                                                                                                                                                                         | and D        | an i   | 0.00          |             |                         |                      |                                               |       |           |       |               |                    |                    |              |          |
| 2 All ports (5)<br>B 2 Calar ports (5)                                                                                                                                                                                                                                                                                                                                                                                                | and 0        |        |               |             |                         |                      |                                               |       |           |       |               |                    |                    |              |          |
| 2 Al ports (5)                                                                                                                                                                                                                                                                                                                                                                                                                        |              |        |               |             |                         |                      |                                               |       |           | -     |               |                    | 1                  |              | - 0      |
| Al ports (S)     By (2) Scalar ports (S)                                                                                                                                                                                                                                                                                                                                                                                              | Prohibit     |        | I/O Std       | Dir         | Vcco                    |                      | Bank Type                                     |       | Diff Pair | Clock | Voltage       | Min Trace Diy (ps) | Max Trace Dly (ps) | IOB Alias    | 10000000 |
| Al ports (5)     By Coaler ports (5)     By Coaler ports (5)                                                                                                                                                                                                                                                                                                                                                                          |              |        |               |             | Vcco                    | Bank I               | Bank Type                                     |       | Diff Pair | Clock | Voltage       | Min Trace Diy (ps) | Max Trace Dly (ps) | IO8 Alias    | 10000000 |
| P J ports (5)     Scalar ports (5)     P O Scalar ports (5)     pe Pins     Al Pins (120)     O M Pins (120)     O M Pins (120)                                                                                                                                                                                                                                                                                                       |              |        |               |             |                         | Bank I               |                                               |       | Diff Pair | Clock | Voltage       | Min Trace Diy (ps) | Max Trace Dly (ps) | IOB Alias    | 10000000 |
| Al ports (3)     Eric (2)     Scalar ports (5)      Pres  ame     Al Pres (320)                                                                                                                                                                                                                                                                                                                                                       |              |        |               |             | Vcco<br>3.3             | Bank I<br>I S<br>I S | Bank Type<br>Standard                         |       | Diff Pair | Clock | Voltage       | Min Trace Diy (ps) | Max Trace Dly (pc) | 108 Alias    | 10000000 |
| Image: Source (S)         Image: Source (S)           Image: Source (S)         Image: Source (S) |              |        |               |             | Vcco<br>3.3<br>3.3      | Bank I<br>S S<br>S S | Bank Type<br>Standard<br>Standard             |       | Diff Pair | Clock | Voltage       | Min Trace Diy (ps) | Max Trace Dly (ps) | 108 Alias    | 10000000 |
| A ports (S     G) Scalar ports (S     G) Scalar ports (S     G)     ge Pins     Gene     A Desche (Classical (65)     G)                                                                                                                          |              |        |               |             | Vcco<br>3.3<br>3.3      | Bank I<br>S S<br>S S | Bank Type<br>Standard<br>Standard<br>Standard |       | Diff Pair | Clock | Voltage       | Min Trace Diy (ps) | Max Trace Dly (ps) | IOB Alias    | 10000000 |

Figure-A22. Profile Generated After "I/O Planning (Plan Ahead) Post Synthesis"

| Name             | Dir       | Neg Diff Pair | Site | Bank | I/O Std     | Vcco | Vref | Drive Strength | Slew Type | Pull Type |
|------------------|-----------|---------------|------|------|-------------|------|------|----------------|-----------|-----------|
| 🖃 波 All ports (S | 5)        |               |      |      |             |      |      |                |           |           |
| 🗄 放 Scalar       | oorts (5) |               |      |      |             |      |      |                |           |           |
| 🕑 dk             | Input     |               | C9   |      | 0 LVCMOS33* | 3.3  |      | 1              | 2 SLOW    |           |
| - 🕑 remo         | te Input  |               | V4   |      | 2 LVTTL*    | 3.3  |      | 1              | 2 SLOW    | PULLDOWN* |
| - 🕑 rst          | Input     |               | K17  |      | 1 LVTTL*    | 3.3  |      | 1              | 2 SLOW    | PULLDOWN* |
| - 🕑 sens         | ors Input |               | N17  |      | 1 LVTTL*    | 3.3  |      | 1              | 2 SLOW    | PULLUP*   |
|                  | Output    |               | F9   |      | 0 LVTTL*    | 3.3  |      | 8              | * SLOW    |           |

Figure-A23. Planning I/O Ports constraints.

#### **STEP-3: UPLOADING THE CODE INTO THE SPARTAN-3E STARTER KIT**

From the process window run the "Synthesize-XST". Then double click to run the "Implement Design". Then run the "Generate Programming File". Expand the "Configure Target Device". Click on "Manage Configuration Project (iMPACT)". A window namely "ISE iMPACT Window" will appear before you, where you have to do a few steps to burn the generated bit file into the target device (FPGA). Then double click on the "Boundary

Scan". In the "Boundary Scan" window right-click and select "Initialize Chain". Click "yes". Select the "alarm.bit" file. Click "Ok" and "Bypass" twice. Then "Ok".

| TFlows ↔ □ ♂ ×                                                                     |                                   |
|------------------------------------------------------------------------------------|-----------------------------------|
| 3 Boundary Scan<br>SystemACE<br>Create PROM File (PROM File Format<br>WebTalk Data | <br>Double Click on Boundary Scan |
| rProcesses ↔ □ & ×                                                                 |                                   |
|                                                                                    |                                   |
|                                                                                    |                                   |
|                                                                                    |                                   |
| de                                                                                 | •••                               |
| de                                                                                 |                                   |
| *                                                                                  |                                   |





Figure-A25. ISE Design Flow

#### **RTL SCHEMATIC**

To see the "RTL Schematic" and "Technology Schematic", go to the "Process Plane". And do the following.

Synthesize-SXT→ View RTL Schematic.

Synthesize-SXT $\rightarrow$ View Technology Schematic.



Figure-A26. Process Window.

Suppose you wish to see the "RTL-Schematic" first. Just double click on the "View RTL Schematic". Then a window will appear before you asking for the "Startup Mode". Select the "Start with Explorer Wizard". Click "Ok".



Figure-A27. Set RTL/Tech Viewer Startup Mode.

#### Create RTL Schematic

| <ol> <li>Select items you want on the schematic from the "Available Eleme<br/>- Use the Filter control to filter the "Available Elements" list by narr<br/>2) Press the "Create Schematic" button to generate a schematic view</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ne                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| wailable Elements     Image: Second Sec | Add ->  Selected Elements |
| * Tilter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Create Schematic          |

Figure-A28. "Create RTL Schematic"-Wizard

Just Select the "alarm" from the "Available Elements", as shown in the figure-27. And add it to the "Selected Elements". The Click on "Create Schematic". After that you will have a schematic like figure-29.

| Create RTL Schematic                                                                                                                                                                                                                  |                              |                   |        |                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-------------------|--------|------------------|
| <ol> <li>Select items you want on the schematic from the "Available Eler<br/>- Use the Filter control to filter the "Available Elements" list by n</li> <li>Press the "Create Schematic" button to generate a schematic vi</li> </ol> | ame<br>ew using the items in |                   | " list |                  |
| Available Elements                                                                                                                                                                                                                    |                              | Selected Elements |        |                  |
| 🗄 📥 alarm                                                                                                                                                                                                                             | Add ->                       | 🛔 alarm           |        |                  |
|                                                                                                                                                                                                                                       | <-Remove                     |                   |        |                  |
|                                                                                                                                                                                                                                       | < Remove All                 |                   |        |                  |
|                                                                                                                                                                                                                                       | <<- Remove Air               |                   |        |                  |
|                                                                                                                                                                                                                                       |                              |                   |        |                  |
|                                                                                                                                                                                                                                       |                              |                   |        |                  |
|                                                                                                                                                                                                                                       |                              |                   |        |                  |
|                                                                                                                                                                                                                                       |                              |                   |        |                  |
|                                                                                                                                                                                                                                       |                              |                   |        |                  |
| *                                                                                                                                                                                                                                     |                              |                   |        |                  |
| * ▼ Fiter                                                                                                                                                                                                                             |                              |                   |        | Create Schematic |
|                                                                                                                                                                                                                                       |                              |                   |        |                  |

Figure-A29. "Create RTL Schematic"-Wizard (Continue).



Figure-A30. RTL Schematic.





#### **TECHNOLOGY SCHEMATIC**

| 2 | - Set RTL/Tech Viewer Startup Mode                                                                                                                                                                                                              |  |  |  |  |  |
|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|   | Select how the RTL/Tech Viewer behaves when it is initially invoked                                                                                                                                                                             |  |  |  |  |  |
|   | Startup mode                                                                                                                                                                                                                                    |  |  |  |  |  |
|   | Start with the Explorer Wizard                                                                                                                                                                                                                  |  |  |  |  |  |
|   | In this mode, the Explorer Wizard is the initial screen, and allows you to select the elements that you want to see on the initial schematic                                                                                                    |  |  |  |  |  |
|   | Start with a schematic of the top-level block                                                                                                                                                                                                   |  |  |  |  |  |
|   | In this mode, the Explorer Wizard is bypassed and an initial<br>schematic is created with only the top-level block displayed. You can<br>then use the logic expansion capabilities of the Viewer to start<br>expanding from the top-level block |  |  |  |  |  |
|   | You can also change the startup mode by selecting Edit->Preferences under the RTL/Tech Viewer page                                                                                                                                              |  |  |  |  |  |
|   | Show this dialog on startup                                                                                                                                                                                                                     |  |  |  |  |  |

Figure-A32. Set RTL/Tech Viewer Startup Mode.

## **Create Technology Schematic**

- 1) Select items you want on the schematic from the "Available Elements" list and move them to the "Selected Elements" list - Use the Filter control to filter the "Available Elements" list by name
- 2) Press the "Create Schematic" button to generate a schematic view using the items in the "Selected Elements" list

| Available Elements  Availa | Add -><br><- Remove<br><<- Remove All |                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------|
| * Titer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                       | Create Schematic |

Figure-A33. "Create Technology Schematic"-Wizard

#### Create Technology Schematic

Select items you want on the schematic from the "Available Elements" list and move them to the "Selected Elements" list
 Use the Filter control to filter the "Available Elements" list by name

2) Press the "Create Schematic" button to generate a schematic view using the items in the "Selected Elements" list

| Available Elements   Available alarm | Add ->     Add -> | <b>A</b> |
|--------------------------------------|-------------------|----------|
| 🖶 🔁 Signals                          | <-Remove          |          |
| 🗄 🄁 Top Level Ports                  | < Remove All      |          |
|                                      |                   |          |
|                                      |                   |          |
|                                      |                   |          |
|                                      |                   |          |
|                                      |                   |          |
|                                      |                   | =        |
| *                                    | Create Schem      | atic     |

Figure-A34. "Create Technology Schematic"-Wizard (Continue).



Figure-A35. Technology Schematic.



Figure-A36. View of Technology Schematic (Double)

# **APPENDIX-B**

## **VHDL TUTORUAL**

#### An Introduction to VHDL

VHDL is a Hardware Description Language (HDL) which describes the behavior of an electronic circuit or system. VHDL stands for Very High Speed Integrated Circuits (VHSIC) Hardware Description Language. In this section we will present three initial examples of VHDL which will help to illustrate the fundamental aspects regarding overall code structure.

#### O EXAMPLE-1 (SEQUENTIAL VHDL CODE)

Figure-1 represents the diagram of a D-type flip-flop (DFF)., triggered at the rising edge of the clock signal (clk) and with an asynchronous reset input (rst). When rst='1', the output must be turned low, regardless of clk. Otherwise, the output must copy the input.





#### VHDL CODE.



END DFF\_TB;

ARCHITECTURE BEHAVIOR OF DFF\_TB IS

COMPONENT DFF

PORT(

D : IN STD\_LOGIC;

CLK: IN STD\_LOGIC;

RST : IN STD\_LOGIC;

 $Q:OUT\ STD\_LOGIC$ 

);

END COMPONENT;

--INPUTS

SIGNAL D : STD\_LOGIC := '1';

SIGNAL CLK : STD\_LOGIC := '0';

SIGNAL RST : STD\_LOGIC := '1';

--OUTPUTS

SIGNAL Q : STD\_LOGIC;

-- CLOCK PERIOD DEFINITIONS

CONSTANT CLK\_PERIOD : TIME := 10 NS;

BEGIN

-- INSTANTIATE THE UNIT UNDER TEST (UUT)

UUT: DFF PORT MAP (

```
D => D,
```

```
CLK => CLK,
```

```
RST => RST,
```

```
Q \Rightarrow Q
```

```
);
```

-- CLOCK PROCESS DEFINITIONS

CLK\_PROCESS : PROCESS

BEGIN

CLK <= '0';

WAIT FOR CLK\_PERIOD/2;

CLK <= '1';

WAIT FOR CLK\_PERIOD/2;

END PROCESS;

-- STIMULUS PROCESS

STIM\_PROC: PROCESS

BEGIN

-- HOLD RESET STATE FOR 100 NS.

WAIT FOR 100 NS;

WAIT FOR CLK\_PERIOD\*10;

-- INSERT STIMULUS HERE

WAIT;

END PROCESS;

END;

\_\_\_\_\_

SIMULATION RESULTS







**Figure-B3.** When rst = '1', then  $q \le '0'$ .

#### O EXAMPLE-2 [1] (SEQUENTIAL VHDL CODE)

In this example we will demonstrate the implementation of a progressive 1-digit decimal counter  $(0 \rightarrow 9 \rightarrow 0)$ . A top level diagram of the circuit is shown in the figure-2. It contains a single-bit input (clk) and 4-bit output (digit).



Figure-B4. Counter of Example-2

#### VHDL CODE.





Here in this example a variable namely "temp" is used to create the four flip-flops necessary to store 4-bit output signal.

### VHDL TEST BENCH CODE

\_\_\_\_\_

LIBRARY ieee; USE ieee.std\_logic\_1164.ALL;

ENTITY COUNTER\_TESTBENCH IS

END COUNTER\_TESTBENCH;

ARCHITECTURE BEHAVIOR OF COUNTER\_TESTBENCH IS

COMPONENT COUNTER

PORT(

CLK : IN STD\_LOGIC;

DIGIT : OUT INTEGER RANGE 0 TO 9

```
);
```

END COMPONENT;

--INPUTS

SIGNAL CLK : STD\_LOGIC := '0';

--OUTPUTS

```
SIGNAL DIGIT : INTEGER RANGE 0 TO 10;
```

-- CLOCK PERIOD DEFINITIONS

CONSTANT CLK\_PERIOD : TIME := 10 NS;

BEGIN

-- INSTANTIATE THE UNIT UNDER TEST (UUT)

UUT: COUNTER PORT MAP (

CLK => CLK,

DIGIT => DIGIT

```
);
```

-- CLOCK PROCESS DEFINITIONS

CLK\_PROCESS : PROCESS

BEGIN

CLK <= '0';

WAIT FOR CLK\_PERIOD/2;

CLK <= '1';

WAIT FOR CLK\_PERIOD/2;

END PROCESS;

-- STIMULUS PROCESS

STIM\_PROC: PROCESS

BEGIN

-- HOLD RESET STATE FOR 100 NS.

WAIT FOR 100 NS;

WAIT FOR CLK\_PERIOD\*10;

-- INSERT STIMULUS HERE

WAIT;

END PROCESS;

END;



# SIMULATION RESULT

\_\_\_\_\_

Figure-B5. Simulation Result

### O EXAMPLE-3 [1] (CONCURRENT VHDL CODE)

Figure-6 represents a 4-input, one bit per multiplexer. The output must be equal to the input selected by the selection bits, s1-s0.



Figure-B6. 4-input Multiplexer.

### VHDL CODE.



### VHDL TEST BENCH CODE

-----

LIBRARY IEEE;

USE IEEE.STD\_LOGIC\_1164.ALL;

ENTITY MUX\_TB IS

END MUX\_TB;

ARCHITECTURE BEHAVIOR OF MUX\_TB IS

COMPONENT MULTIPLEXER

PORT(

A : IN STD\_LOGIC;

B : IN STD\_LOGIC;

C : IN STD\_LOGIC;

D : IN STD\_LOGIC;

SEL : IN STD\_LOGIC\_VECTOR(1 DOWNTO 0);

Y:OUT STD\_LOGIC

);

END COMPONENT;

--INPUTS

```
SIGNAL A : STD_LOGIC := '0';
```

SIGNAL B : STD\_LOGIC := '0';

SIGNAL C : STD\_LOGIC := '0';

SIGNAL D : STD\_LOGIC := '0';

SIGNAL SEL : STD\_LOGIC\_VECTOR(1 DOWNTO 0) := (OTHERS => '0');

--OUTPUTS

SIGNAL Y : STD\_LOGIC;

BEGIN

UUT: MULTIPLEXER PORT MAP (

A => A, B => B, C => C, D => D, SEL => SEL, Y => Y ); STIM\_PROC: PROCESS

\_\_\_\_

BEGIN

WAIT FOR 100 NS;

WAIT;

END PROCESS;

END;

-----

### SIMULATION RESULTS

|                    |       | 4    | 270,000 ps |
|--------------------|-------|------|------------|
| Name               | Value | 0 ps |            |
| lle a              | 1     |      |            |
| Ц <sub>е b</sub>   | 1     |      |            |
| Ц <mark>а</mark> с | 0     |      |            |
| lle d              | 1     |      |            |
| 🔽 💑 sel[1:0]       | 00    |      | 00         |
| 16 [1]             | 0     |      |            |
| 10                 | 0     |      |            |
| Чау                | 1     |      |            |

**Figure-B7.** <u>Y <= A WHEN SEL = "00"</u>



Figure-B8. Y <= A WHEN SEL = "01"

| Name                | Value | 500,000 ps |
|---------------------|-------|------------|
| 1 <sub>0</sub> a    | 0     |            |
| ll <mark>o</mark> b | 0     |            |
| <u>Ц</u> с          | 1     |            |
| lla d               | 0     |            |
| > 🎝 sel[1:0]        | 10    | 10         |
| 1, у                | 1     |            |
|                     |       |            |

**Figure-B9.** Y <= A WHEN SEL = "10"

| Name             | Value | 0 ps |
|------------------|-------|------|
| lla a            | 0     |      |
| U <sub>o</sub> b | 0     |      |
| Ц <sub>а</sub> с | 0     |      |
| V <sub>e</sub> d | 1     |      |
| ⊳ 🔩 sel[1:0]     | 11    | ( 11 |
| Ц, у             | 1     |      |
|                  |       |      |

**Figure-B10.** Y <= A WHEN SEL = "11"

# **APPENDIX-C**

# **VHDL CODE**

### C.1. VHDL PROGRAM C.1.1. Rotary Switch

```
ENTITYROTARY_SW IS
 PORT (
               CLK : IN STD_LOGIC;
        ROT_A
                     : IN STD_LOGIC;
        ROT_B
                     : IN STD_LOGIC;
         STEP : IN STD_LOGIC;
         DAC_A
                     : OUT STD_LOGIC_VECTOR (11 DOWNTO 0)
             );
ENDROTARY_SW;
ARCHITECTURE BEHAVIORAL OF ROTARY_SW IS
SIGNAL CLKDIV : STD_LOGIC_VECTOR (7 DOWNTO 0):=(OTHERS=>'0');
SIGNAL FLAG : STD_LOGIC_VECTOR (15 DOWNTO 0):=(OTHERS=>'0');
SIGNAL DAC_DATA :STD_LOGIC_VECTOR (11 DOWNTO 0):=(OTHERS=>'0');
BEGIN
PSENSE_A: PROCESS(CLK)
BEGIN
IFRISING_EDGE(CLK)THEN
CLKDIV<=CLKDIV+1;
IFCLKDIV= X"00" THEN
FLAG<=FLAG(14 DOWNTO 0) &ROT_A;
IF FLAG= X"8000" THEN
IFROT_B='1' THEN
IF(STEP='1')THEN
                          -----CODE FOR 100MV STEP
IF (DAC_DATA<3931) THEN
                            DAC_DATA<=DAC_DATA+164;
END IF;
ELSE
                    -----CODE FOR 10MV STEP
                     IF (DAC_DATA<4079) THEN
                            DAC_DATA<=DAC_DATA+16;
                     END IF;
END IF;
             ELSE
                                     ----VOLTAGE DECREMENT
                          -----CODE FOR 100MV STEP
IF(STEP='1')THEN
                     IF (DAC_DATA>164) THEN
                     DAC_DATA<=DAC_DATA-164;
                     END IF;
```

# ELSE -----CODE FOR 10MV STEP IF (DAC\_DATA>16) THEN DAC\_DATA<=DAC\_DATA-16; END IF; END IF;

END IF;

END IF;

END IF;

DAC\_A<=DAC\_DATA; END IF;

END PROCESS;

END BEHAVIORAL;

## DAC

ENTITY DAC IS

| PORT (                                         | CLK   | : IN STD_LOG | IC;                                    |  |
|------------------------------------------------|-------|--------------|----------------------------------------|--|
|                                                | SPI_M | OSI          | : OUT STD_LOGIC;                       |  |
|                                                |       | SPI_MISO     | : IN STD_LOGIC;                        |  |
|                                                |       | SPI_SCK      | : OUT STD_LOGIC;                       |  |
|                                                |       | DAC_CS       | : OUT STD_LOGIC;                       |  |
|                                                |       | DAC_CLR      | : OUT STD_LOGIC;                       |  |
|                                                |       | AMP_CS       | : OUT STD_LOGIC;                       |  |
|                                                |       | SPI_SS_B     | : OUT STD_LOGIC;                       |  |
| FPGA_INIT_B : OUT STD_LOGIC;                   |       |              |                                        |  |
|                                                |       | SF_CE0       | : OUT STD_LOGIC;                       |  |
|                                                |       | AD_CONV      | : OUT STD_LOGIC;                       |  |
|                                                |       | DAC_A : IN   | STD_LOGIC_VECTOR (11 DOWNTO 0):=X"FFF" |  |
|                                                |       | );           |                                        |  |
| END DAC;                                       |       |              |                                        |  |
| ARCHITECTURE BEHAVIORAL OF DAC IS              |       |              |                                        |  |
| TYPE                                           | EVENT | _TYPE IS     | (S0, S1, S2, S3, S4);                  |  |
| SIGNAL SDACSTATE : EVENT_TYPE;                 |       |              |                                        |  |
| SIGNAL SDATA : STD_LOGIC_VECTOR (31 DOWNTO 0); |       |              |                                        |  |
| BEGIN                                          |       |              |                                        |  |
| DAC_CLR<= '1';                                 |       |              |                                        |  |
| SPI_SS_B <= '1';                               |       |              |                                        |  |
| SF_CE0 <= '1';                                 |       |              |                                        |  |
|                                                |       |              |                                        |  |

```
FPGA_INIT_B <= '1';
AD_CONV <= '0';
AMP_CS <= '1';
PDAC: PROCESS (CLK, SDACSTATE)
CONSTANT KDACA : STD_LOGIC_VECTOR(7 DOWNTO 0) := "00110010";</pre>
```

UPDATE IMMEDIATELY

VARIABLEBITNR : INTEGER;

BEGIN

IFRISING\_EDGE (CLK) THEN CASESDACSTATE IS WHEN S0=>DAC\_CS<= '1'; SPI\_SCK <= '0'; SPI\_MOSI<= '0'; SDACSTATE<= S1; WHEN S1 =>DAC\_CS<= '0'; BITNR :=0; SDATA <= "00000000" &KDACA&DAC\_A& "0000"; SDACSTATE<= S2; WHEN S2 =>DAC\_CS <= '0'; -- LOOP: SET DATA SPI\_SCK<= '0'; SPI\_MOSI <= SDATA(31); SDATA <= SDATA (30 DOWNTO 0) & '0'; SDACSTATE<= S3; WHEN S3 =>SPI\_SCK <= '1'; BITNR := BITNR +1; IF (BITNR< 32) THEN -- SET CLOCK SDACSTATE<= S2;

ELSE

SDACSTATE<= S4;

END IF;

WHEN S4 =>DAC\_CS<= '1'; -- OK SPI\_SCK <= '0';

SDACSTATE<= S1;

END CASE;

END IF;

```
END PROCESS;
```

END BEHAVIORAL;

### C.1.2. DIS\_VALUE

ENTITY DISVALUE IS PORT ( CLK : IN STD\_LOGIC; DAC\_DATA: IN STD\_LOGIC\_VECTOR (11 DOWNTO 0); DIS\_DATA: OUT STD\_LOGIC\_VECTOR (15 DOWNTO 0)); END DISVALUE; ARCHITECTURE BEHAVIORAL OF DISVALUE IS SIGNALVAL\_ADC:STD\_LOGIC\_VECTOR (11 DOWNTO 0):=X"000"; TYPE EVENT\_TYPE IS (S0, S1, S2, S3, S4,S5); SIGNAL SDACSTATE : EVENT\_TYPE; BEGIN CONV: PROCESS(CLK) VARIABLE DIG\_0:STD\_LOGIC\_VECTOR (3 DOWNTO 0):="0000"; VARIABLE DIG\_1:STD\_LOGIC\_VECTOR (3 DOWNTO 0):="0000"; VARIABLE DIG\_2:STD\_LOGIC\_VECTOR (3 DOWNTO 0):="0000"; VARIABLE DIG\_3:STD\_LOGIC\_VECTOR (3 DOWNTO 0):="0000"; BEGIN IFRISING\_EDGE(CLK) THEN CASESDACSTATE IS WHEN SO => VAL\_ADC<=DAC\_DATA; SDACSTATE<= S1; WHEN S1 => IF(VAL\_ADC>1638) THEN DIG\_3:=DIG\_3+1; VAL\_ADC<=VAL\_ADC-1638; ELSE SDACSTATE<= S2; END IF; WHEN S2 => IF(VAL\_ADC>163)THEN DIG\_2:=DIG\_2+1;

```
VAL_ADC<=VAL_ADC-164;
                     ELSE
              SDACSTATE<= S3;
                     END IF;
       WHEN S3
                    =>
IF(VAL_ADC>17)THEN
       DIG_1:=DIG_1+1;
VAL_ADC<=VAL_ADC-17;
       ELSE
       SDACSTATE<= S4;
       END IF;
       WHEN S4
                   =>
IF(VAL_ADC>3)THEN
       DIG_0:=DIG_0+2;
VAL_ADC<=VAL_ADC-3;
                     ELSE
       SDACSTATE<= S5;
       END IF;
WHEN S5=>
DIS_DATA<=DIG_3 & DIG_2 & DIG_1 & DIG_0;
               DIG_0:="0000";
      DIG_1:="0000";
              DIG_2:="0000";
      DIG_3:="0000";
             SDACSTATE<= S0;
       WHEN OTHERS =>SDACSTATE<= S0;
END CASE;
END IF;
END PROCESS;
END BEHAVIORAL;
```

### C.1.3. LCD\_DRIVER\_CODE

LIBRARY IEEE; USE IEEE.STD\_LOGIC\_1164.ALL;

```
USE IEEE.STD_LOGIC_ARITH.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY LCD_DRIVER IS
PORT( CLK
                    : IN STD_LOGIC;
             RS
                   : OUT STD_LOGIC;
      RW
             : OUT STD_LOGIC;
      ENABLE
                    : OUT STD_LOGIC;
                    : OUT STD_LOGIC_VECTOR(3 DOWNTO 0);
      LCD_DATA
             INDEX
                          : OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
             CHAR
                          : IN
                                 STD_LOGIC_VECTOR (7 DOWNTO 0)
      );
END LCD DRIVER;
ARCHITECTURE BEHAVIORAL OF LCD DRIVER IS
TYPE CHARSTATE_TYPE IS (10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 110, 111, 112, 113, 114, 115, 116, S0, S1, S2, S3, S4,
S5, S6, S7, S8, S9, S10, S11 );
      SIGNAL CHARSTATE : CHARSTATE_TYPE := I0;
CONSTANT
             T INSTRWAIT : INTEGER := 100000;
                                                     -- 2 MS
CONSTANT
             T_WRPULSE
                          : INTEGER := 12;
                                               -- 0,2 US (200 NS)
CONSTANT
             T_SETUPHOLD : INTEGER := 10;
                          : INTEGER := 2500;
CONSTANT
             T_DATWAIT
                                               -- 50 US
TYPE STATE TYPE IS (INIT, WAIT_FOR_DATA, WRITE_INITL1, WRITE_ADDRH1, WRITE_ADDRH2,
WRITE_ADDRH3,WRITE_ADDRL1, WRITE_ADDRL2, WRITE_ADDRL3,CHK_BUSY11,
      CHK_BUSYI2,WRITE_DATAH1,WRITE_DATAH2, WRITE_DATAH3,WRITE_DATAL1, WRITE_DATAL2,
WRITE_DATAL3,CHK_BUSYD1);
SIGNAL STATE : STATE_TYPE := INIT;
SIGNAL SLCDADR
                           : STD_LOGIC_VECTOR(7 DOWNTO 0);
SIGNAL SLCDDAT
                    : STD_LOGIC_VECTOR(7 DOWNTO 0);
SIGNAL SLCDWR
                    : STD_LOGIC;
SIGNAL SLCDINITWR
                    :STD_LOGIC;
SIGNAL SLCDRDY
                    : STD_LOGIC;
SIGNAL INT_ADDR
                    : STD_LOGIC_VECTOR( 7 DOWNTO 0 );
SIGNAL INT_DATA
                    : STD_LOGIC_VECTOR( 7 DOWNTO 0 );
SIGNAL ENRWRS
                    : STD_LOGIC_VECTOR( 2 DOWNTO 0 );
_____
```

```
140
```

BEGIN

PTEXTOUT: PROCESS (CLK) VARIABLECNT : STD\_LOGIC\_VECTOR (31 DOWNTO 0); VARIABLE I : STD\_LOGIC\_VECTOR (7 DOWNTO 0); --INTEGER RANGE 0 TO 40; BEGIN INDEX<= I; IFRISING\_EDGE (CLK) THEN CASE CHARSTATE IS WHEN IO =>SLCDWR<= '0'; SLCDINITWR<= '0'; SLCDADR<= X"01";</pre> -- WAIT CNT := (OTHERS => '0'); CHARSTATE<= I1; WHEN I1 =>SLCDWR<= '0'; CNT := CNT + 1;IF (CNT> 800000) THEN CHARSTATE<= I2; END IF; WHEN I2 => -- COMMAND 3 SLCDDAT<= X"03"; SLCDINITWR<= '1';</pre> CNT := (OTHERS => '0'); CHARSTATE<= I3; WHEN I3 =>SLCDINITWR <= '0'; CNT := CNT + 1;IF (CNT> 250000) THEN CHARSTATE<= I4; END IF; WHEN I4 => -- COMMAND 3 SLCDDAT<= X"03";</pre> SLCDINITWR<= '1'; CNT := (OTHERS => '0'); CHARSTATE<= I5; WHEN I5 =>SLCDINITWR <= '0'; CNT := CNT + 1;IF (CNT> 5000) THEN

```
CHARSTATE <= I6;
```

```
END IF;
```

```
WHEN I6
                =>
                                          -- COMMAND 4
      SLCDDAT<= X"03";</pre>
      SLCDINITWR<= '1';
       CNT := (OTHERS => '0');
       CHARSTATE<= I7;
      WHEN I7
                     =>SLCDINITWR <= '0';
      CNT := CNT + 1 ;
IF (CNT> 5000) THEN
       CHARSTATE<= I8;
END IF;
      WHEN I8
                  =>
                                    -- COMMAND 2
      SLCDDAT<= X"02";
       SLCDINITWR<= '1';
      CNT := (OTHERS => '0');
       CHARSTATE<= I9;
      WHEN I9 =>SLCDINITWR <= '0';
       CNT := CNT + 1 ;
IF (CNT> 250000) THEN
      CHARSTATE<= I10;
END IF;
```

\_\_\_\_\_

```
WHEN I10 =>SLCDADR<= X"01"; -- COMMAND 28
SLCDDAT<= X"28";
SLCDWR<= '1';
CNT := (OTHERS => '0');
CHARSTATE<= I11;
WHEN I11=>SLCDWR<= '0';
CNT := CNT + 1 ;
```

IF (CNT> 250000) THEN

CHARSTATE <= I12;

END IF;

```
WHEN I12 =>SLCDADR<= X"01"; -- COMMAND 06
```

```
SLCDDAT<= X"06";
```

```
SLCDWR<= '1';
```

```
CNT := (OTHERS => '0');
       CHARSTATE<= I13;
       WHEN I13=>SLCDWR<= '0';
       CNT := CNT + 1;
IF (CNT> 250000) THEN
       CHARSTATE
                   <= I14;
END IF;
       WHEN I14 =>SLCDADR <= X"01"; -- COMMAND 0C
       SLCDDAT<= X"0C";</pre>
       SLCDWR<= '1';
       CNT := (OTHERS => '0');
       CHARSTATE <= I15;
       WHEN I15=>SLCDWR<= '0';
       CNT := CNT + 1 ;
IF (CNT> 250000) THEN
       CHARSTATE<= I16;
END IF:
       WHEN I16=>CHARSTATE<= S0;
       WHEN S0 =>SLCDWR<= '0';
       SLCDADR<= X"01";</pre>
                                    -- CLEAR DISPLAY
       SLCDDAT<= X"20"; -- SPACE
IF (SLCDRDY = '1') THEN
       SLCDWR<= '1';
       CNT := (OTHERS => '0');
       CHARSTATE<= S1;
END IF;
       WHEN S1 =>SLCDWR<= '0';
       CNT := CNT + 1;
IF (CNT>CONV_STD_LOGIC_VECTOR (250000, 16)) THEN -- 100.000 = 2MS
       CHARSTATE<= S2;
       I := (OTHERS=>'0');
END IF;
       WHEN S2 => IF (CHAR = "00000000") THEN
                                                  -- NULL CHARACTER
              IF (I >= X"79") THEN
                     CNT := (OTHERS => '0');
                     CHARSTATE<= S11;
              ELSE
```

```
143
```

```
I := I + 1;
                                 CHARSTATE<= S2;
                           END IF;
                           ELSE
                                 SLCDWR<= '0';
                                 SLCDADR<= '1' & I(6 DOWNTO 0); -- THE CHARACTER
LOCATION
                                 SLCDDAT<= CHAR;
                           IF (SLCDRDY = '1') THEN
                                 SLCDWR<= '1';
                                 CNT := (OTHERS => '0');
                                 CHARSTATE<= S3;
                           END IF;
                           END IF;
                                 WHEN S3 =>SLCDWR<= '0';
                                 CHARSTATE<= S4;
                                 WHEN S4 =>SLCDWR<= '0';
                           IF (SLCDRDY = '1') THEN
                                 CHARSTATE<= S2;
                                 I := I + 1;
                           END IF;
                           WHEN S11=>CNT := CNT + 1;
                    IF (CNT> 1000000) THEN -- WAIT 200 MS : 5 UPDATES /SEC.
      CHARSTATE<= S0;
                                                                          END IF;
                           WHEN OTHERS =>CHARSTATE<= S0;
                           END CASE;
                    END IF;
                    END PROCESS;
 _____
      ENABLE
                    <= ENRWRS(2);
      RW<= ENRWRS(1);
      RS<= ENRWRS(0);
PLCDINSTR:
      PROCESS (CLK)
      VARIABLE COUNTER : INTEGER RANGE 0 TO 50000000 := 0;
      BEGIN
             IFRISING_EDGE (CLK) THEN
```

```
144
```

```
CASE STATE IS
WHEN INIT =>
```

```
COUNTER := COUNTER + 1;
```

IF ( COUNTER >= 500000 ) THEN -- 10 MS

COUNTER := 0;

```
STATE<= WAIT_FOR_DATA;
```

END IF;

---- WAIT FOR NEW DATA HERE

WHEN WAIT\_FOR\_DATA =>

```
COUNTER := 0;
```

IF (SLCDWR = '1') THEN

```
INT_ADDR<= SLCDADR;
```

```
INT_DATA<= SLCDDAT;
```

STATE<= WRITE\_ADDRH1; -- CHK\_BUSY1;</pre>

```
ELSIF (SLCDINITWR ='1') THEN
```

INT\_ADDR<= SLCDADR;

INT\_DATA<= SLCDDAT;</pre>

STATE<= WRITE\_INITL1;</pre>

END IF;

```
WHEN WRITE_INITL1 =>
```

COUNTER := COUNTER + 1;

IF ( COUNTER>= T\_WRPULSE ) THEN -- 2 US WR TIME

```
COUNTER := 0;
```

STATE<= WAIT\_FOR\_DATA;

END IF;

-- ADDRESS: HIGH NIBBLE

WHEN WRITE\_ADDRH1 =>

COUNTER := COUNTER + 1;

```
IF ( COUNTER>= T_WRPULSE ) THEN -- 2 US WR TIME
```

```
COUNTER := 0;
```

STATE<= WRITE\_ADDRH2;

```
END IF;
```

```
WHEN WRITE_ADDRH2 =>
```

```
COUNTER := COUNTER + 1;
```

IF (COUNTER >= T\_SETUPHOLD) THEN

COUNTER := 0;

```
STATE<= WRITE_ADDRL1;
```

```
END IF;
```

-- ADDRESS LOW NIBBLE

WHEN WRITE\_ADDRL1 =>

```
COUNTER := COUNTER + 1;
```

```
IF ( COUNTER>= T_WRPULSE ) THEN
```

COUNTER := 0;

```
STATE<= WRITE_ADDRL2;
```

END IF;

WHEN WRITE\_ADDRL2 =>

COUNTER := COUNTER + 1;

IF (COUNTER >= T\_SETUPHOLD) THEN

COUNTER := 0;

STATE<= CHK\_BUSYI1;</pre>

```
END IF;
```

WHEN CHK\_BUSYI1 =>

COUNTER := COUNTER + 1;

IF ( COUNTER >= T\_DATWAIT ) THEN

COUNTER := 0;

IF  $(INT\_ADDR(7) = '1')$  THEN

```
STATE<= WRITE_DATAH2;
```

ELSE

STATE<= CHK\_BUSYI2;

END IF;

END IF;

WHEN CHK\_BUSYI2 =>

```
COUNTER := COUNTER + 1;
```

IF ( COUNTER >= T\_INSTRWAIT ) THEN

COUNTER := 0;

STATE<= WRITE\_DATAH2;</pre>

```
END IF;
```

----- NOW THE DATA -----

WHEN WRITE\_DATAH2 =>

COUNTER := COUNTER + 1;

IF ( COUNTER>= T\_WRPULSE ) THEN

COUNTER := 0;

STATE<= WRITE\_DATAH3;

```
END IF;
             WHEN WRITE_DATAH3 =>
                    COUNTER := COUNTER + 1;
                    IF (COUNTER >= T_SETUPHOLD) THEN
                           COUNTER := 0;
                           STATE<= WRITE_DATAL2;
                    END IF;
             WHEN WRITE_DATAL2 =>
                    COUNTER := COUNTER + 1;
                    IF ( COUNTER>= T_WRPULSE ) THEN
                           COUNTER := 0;
                           STATE<= WRITE_DATAL3;
                    END IF;
             WHEN WRITE_DATAL3 =>
                    COUNTER := COUNTER + 1;
                    IF (COUNTER >= T_SETUPHOLD) THEN
                           COUNTER := 0;
                           STATE<= CHK_BUSYD1;
                    END IF;
             WHEN CHK_BUSYD1 =>
                    COUNTER := COUNTER + 1;
                    IF ( COUNTER >= T_DATWAIT ) THEN
                                                     -- 50 US
                           COUNTER := 0;
                           STATE<= WAIT_FOR_DATA; --WRITE_DATAH1;</pre>
                    END IF;
             WHEN OTHERS => STATE <= INIT;
      END CASE;
SLCDRDY<= '1' WHEN (STATE = WAIT_FOR_DATA) ELSE '0';
WITH STATE SELECT
LCD_DATA<="ZZZZ" WHEN INIT,
      INT_DATA(3 DOWNTO 0)
                                  WHEN WRITE_INITL1,
      INT_ADDR(7 DOWNTO 4)
                                  WHEN WRITE_ADDRH1,
      INT_ADDR(7 DOWNTO 4)
                                  WHEN WRITE_ADDRH2,
      INT_ADDR(3 DOWNTO 0)
                                  WHEN WRITE_ADDRL1,
      INT_ADDR(3 DOWNTO 0)
                                  WHEN WRITE_ADDRL2,
```

END IF;

END PROCESS;

```
147
```

| INT_DATA(7 DOWNTO 4) | WHEN WRITE_DATAH1, |
|----------------------|--------------------|
| INT_DATA(7 DOWNTO 4) | WHEN WRITE_DATAH2, |
| INT_DATA(7 DOWNTO 4) | WHEN WRITE_DATAH3, |
| INT_DATA(3 DOWNTO 0) | WHEN WRITE_DATAL1, |
| INT_DATA(3 DOWNTO 0) | WHEN WRITE_DATAL2, |
| INT_DATA(3 DOWNTO 0) | WHEN WRITE_DATAL3, |
|                      |                    |

"ZZZZ" WHENWAIT\_FOR\_DATA,

"ZZZZ" WHEN OTHERS;

#### -- ENABLE RW RS

WITH STATE SELECT

ENRWRS<= "000" WHEN INIT,

"000" WHEN WAIT\_FOR\_DATA,

"100" WHEN WRITE\_INITL1,

"100" WHEN WRITE\_ADDRH1,

"000" WHEN WRITE\_ADDRH2,

- "100" WHEN WRITE\_ADDRL1,
- "000" WHEN WRITE\_ADDRL2,
- "001" WHEN WRITE\_DATAH1, -- LCDDATA:
- "101" WHEN WRITE\_DATAH2, -- OUTPUT LCD DATA: ENABLE = 1;
- "001" WHEN WRITE\_DATAH3,
- "001" WHEN WRITE\_DATAL1, -- LCDDATA:
- "101" WHEN WRITE\_DATAL2, -- OUTPUT LCD DATA: ENABLE = 1;
- "001" WHEN WRITE\_DATAL3,
- "000" WHEN OTHERS; END BEHAVIORAL;

### C.2. VHDL Code

## C.2.1. ADC Implementation

--

-- Definition of a dual port ROM for KCPSM2 or KCPSM3 program defined by adc\_ctrl.psm

-- and assmbled using KCPSM2 or KCPSM3 assembler.

--

-- Standard IEEE libraries

--

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

```
use IEEE.STD_LOGIC_ARITH.ALL;
```

```
use IEEE.STD_LOGIC_UNSIGNED.ALL;
--
-- The Unisim Library is used to define Xilinx primitives. It is also used during
-- simulation. The source can be viewed at %XILINX%\vhdl\src\unisims\unisim_VCOMP.vhd
--
library unisim;
use unisim.vcomponents.all;
---
--
entity adc_ctrl is
  Port ( address : in std_logic_vector(9 downto 0);
      instruction : out std_logic_vector(17 downto 0);
      proc_reset : out std_logic;
          clk : in std_logic);
 end adc_ctrl;
--
architecture low_level_definition of adc_ctrl is
-- Declare signals internal to this module
--
signal jaddr : std_logic_vector(10 downto 0);
signal jparity : std_logic_vector(0 downto 0);
signal jdata : std_logic_vector(7 downto 0);
             : std_logic_vector(7 downto 0);
signal doa
signal dopa
             : std_logic_vector(0 downto 0);
signal tdo1
             : std_logic;
signal tdo2
             : std_logic;
signal update : std_logic;
signal shift : std_logic;
signal reset : std_logic;
signal tdi
            : std_logic;
signal sel1
            : std_logic;
signal drck1 : std_logic;
signal drck1_buf : std_logic;
signal sel2
            : std_logic;
signal drck2 : std_logic;
```

```
signal capture : std_logic;
signal tap5 : std_logic;
signal tap11 : std_logic;
signal tap17 : std_logic;
```

--

-- Attributes to define ROM contents during implementation synthesis.

-- The information is repeated in the generic map for functional simulation

--

attribute INIT\_00 : string; attribute INIT\_01 : string; attribute INIT\_02 : string; attribute INIT\_03 : string; attribute INIT\_04 : string; attribute INIT\_05 : string; attribute INIT\_06 : string; attribute INIT\_07 : string; attribute INIT\_08 : string; attribute INIT\_09 : string; attribute INIT\_0A : string; attribute INIT\_0B : string; attribute INIT\_0C : string; attribute INIT\_0D : string; attribute INIT\_0E : string; attribute INIT\_OF : string; attribute INIT\_10 : string; attribute INIT\_11 : string; attribute INIT\_12 : string; attribute INIT\_13 : string; attribute INIT\_14 : string; attribute INIT\_15 : string; attribute INIT\_16 : string; attribute INIT\_17 : string; attribute INIT\_18 : string; attribute INIT\_19 : string; attribute INIT\_1A : string; attribute INIT\_1B : string; attribute INIT\_1C : string;

attribute INIT\_1D : string; attribute INIT\_1E : string; attribute INIT\_1F : string; attribute INIT\_20 : string; attribute INIT\_21 : string; attribute INIT\_22 : string; attribute INIT\_23 : string; attribute INIT\_24 : string; attribute INIT\_25 : string; attribute INIT\_26 : string; attribute INIT\_27 : string; attribute INIT\_28 : string; attribute INIT\_29 : string; attribute INIT\_2A : string; attribute INIT\_2B : string; attribute INIT\_2C : string; attribute INIT\_2D : string; attribute INIT\_2E : string; attribute INIT\_2F : string; attribute INIT\_30 : string; attribute INIT\_31 : string; attribute INIT\_32 : string; attribute INIT\_33 : string; attribute INIT\_34 : string; attribute INIT\_35 : string; attribute INIT\_36 : string; attribute INIT\_37 : string; attribute INIT\_38 : string; attribute INIT\_39 : string; attribute INIT\_3A : string; attribute INIT\_3B : string; attribute INIT\_3C : string; attribute INIT\_3D : string; attribute INIT\_3E : string; attribute INIT\_3F : string; attribute INITP\_00 : string; attribute INITP\_01 : string; attribute INITP\_02 : string; attribute INITP\_03 : string; attribute INITP\_04 : string; attribute INITP\_05 : string; attribute INITP\_06 : string; attribute INITP\_07 : string;

--

-- Attributes to define ROM contents during implementation synthesis.

--

attribute INIT\_00 of ram\_1024\_x\_18 : label is "E0060000020C01B301B301B301B301B3016102110523014E0211051001FB011F"; attribute INIT\_01 of ram\_1024\_x\_18 : label is "E0068001600650164FFF548D2E0454862E014E00C0010FFF4092E005E0040001"; attribute INIT\_02 of ram\_1024\_x\_18 : label is "0520A700A600050600E4012700116301620001996000019960010211052CC080"; attribute INIT\_03 of ram\_1024\_x\_18 : label is "640463016200007401D1052DA7008601E7FFE6FF403B052B54362780017F0211"; attribute INIT\_04 of ram\_1024\_x\_18 : label is "505A440501FC0018505A440301F80030505A440201EC0077505A440101D800EF"; attribute INIT\_05 of ram\_1024\_x\_18 : label is "A7068672A700A600050600E401FF009C505A440101FF0038505A440601FE000C"; attribute INIT\_06 of ram\_1024\_x\_18 : label is "547242FF5472431F407201D1053E546C4200546C43E063016200017802110517"; attribute INIT\_07 of ram\_1024\_x\_18 : label is "01D18530650801D18530650901D1052E01D18530650A01024014007401D1053C"; attribute INIT\_08 of ram\_1024\_x\_18 : label is "C0016004C000409200075492400880016004C000A00001D1052001D185306507"; attribute INIT\_09 of ram\_1024\_x\_18 : label is "01D1053D01D10547021105100122D20002060206020602066205E00400015492"; attribute INIT\_0A of ram\_1024\_x\_18 : label is "01D1053254B5400240DF01D1052001D1052001D1053154AC4001600401D1052D"; attribute INIT\_0B of ram\_1024\_x\_18 : label is "54C7400440DF01D1052001D1052001D1053554BE400340DF01D1052001D10520"; attribute INIT\_0C of ram\_1024\_x\_18 : label is "40DF01D1052001D1053001D1053254D0400540DF01D1052001D1053001D10531"; attribute INIT\_0D of ram\_1024\_x\_18 : label is "01AE01D1053001D1053001D1053140DF01D1052001D1053001D1053554D94006"; attribute INIT\_0E of ram\_1024\_x\_18 : label is "0008010E0A0F198008FF50EC238008000400050006000700401454DF20054000"; attribute INIT\_0F of ram\_1024\_x\_18 : label is "F680F530D4205D01200154EECA010900080003000206B790B680B53094205CF5"; attribute INIT\_10 of ram\_1024\_x\_18 : label is "03A002000700060015701460A0005504C0018801F480010A08070005A000F790"; attribute INIT\_11 of ram\_1024\_x\_18 : label is "00AEA0005511C1010208030E07000606B5309420411906075916F530D420010D"; attribute INIT\_12 of ram\_1024\_x\_18 : label is "5526C101C008E001020023404301C008E001C2040108C008E008011FA000C008"; attribute INIT\_13 of ram\_1024\_x\_18 : label is "060023804301C008E001C008E0010122C008E010C008E010011FA000C008E008"; attribute INIT\_14 of ram\_1024\_x\_18 : label is "01D10550A0000608070A0608070A0808090A0808090A5539C101090008000700"; attribute INIT\_15 of ram\_1024\_x\_18 : label is "01D1056501D1057A01D1056101D1056C01D1054201D1056F01D1056301D10569"; attribute INIT\_16 of ram\_1024\_x\_18 : label is "057401D1056E01D1056F01D1054301D1052001D1054301D1054401D10541A000"; attribute INIT\_17 of ram\_1024\_x\_18 : label is "0541A00001D1053D01D1054101D10556A00001D1056C01D1056F01D1057201D1"; attribute INIT\_18 of ram\_1024\_x\_18 : label is "101012000194000E000E000E000E1100A00001D1053D01D1054401D1052F01D1"; attribute INIT\_19 of ram\_1024\_x\_18 : label is "A00001D1156001D1152016100188A000803A80075997C00AA00011000194A00F"; attribute INIT\_1A of ram\_1024\_x\_18 : label is "01A90314A00055AAC20101A40219A00055A5C10101A00128A00055A1C001000B"; attribute INIT 1B of ram 1024 x 18 : label is "C440A4F8A000C440E40101A0C440E401A00055B4C40101AE0414A00055AFC301"; attribute INIT\_1C of ram\_1024\_x\_18 : label is "C44004F001A401BE0406040604060407145001A001BEC408A4F01450A00001B8"; attribute INIT\_1D of ram\_1024\_x\_18 : label is "04F001A401B8C4400406040604070407145001A001B8C440C40CA4F01450A000"; attribute INIT\_1E of ram\_1024\_x\_18 : label is "E401400201A0C440E40101A0C440E401450201A0C440E401C440040EA000C440"; attribute INIT\_1F of ram\_1024\_x\_18 : label is "01BE01AE01BE043001AEA00001A4C4400404D500000E000E000E000EA5F0C440";

attribute INIT\_20 of ram\_1024\_x\_18 : label is "01A901A901C2050101C2050C01C2050601C2052801A401BE042001A401BE01A9"; attribute INIT 21 of ram 1024 x 18 : label is "E703E602E901E8000133A00001C2C5C0A50FA00001C2C580A50F52172510A000"; attribute INIT\_22 of ram\_1024\_x\_18 : label is attribute INIT\_23 of ram\_1024\_x\_18 : label is attribute INIT\_24 of ram\_1024\_x\_18 : label is attribute INIT\_25 of ram\_1024\_x\_18 : label is attribute INIT\_26 of ram\_1024\_x\_18 : label is attribute INIT\_27 of ram\_1024\_x\_18 : label is attribute INIT\_28 of ram\_1024\_x\_18 : label is attribute INIT\_29 of ram\_1024\_x\_18 : label is attribute INIT\_2A of ram\_1024\_x\_18 : label is attribute INIT\_2B of ram\_1024\_x\_18 : label is attribute INIT\_2C of ram\_1024\_x\_18 : label is attribute INIT 2D of ram 1024 x 18 : label is attribute INIT\_2E of ram\_1024\_x\_18 : label is attribute INIT\_2F of ram\_1024\_x\_18 : label is attribute INIT\_30 of ram\_1024\_x\_18 : label is attribute INIT\_31 of ram\_1024\_x\_18 : label is 

attribute INIT\_32 of ram\_1024\_x\_18 : label is attribute INIT\_33 of ram\_1024\_x\_18 : label is attribute INIT\_34 of ram\_1024\_x\_18 : label is attribute INIT\_35 of ram\_1024\_x\_18 : label is attribute INIT\_36 of ram\_1024\_x\_18 : label is attribute INIT\_37 of ram\_1024\_x\_18 : label is attribute INIT\_38 of ram\_1024\_x\_18 : label is attribute INIT\_39 of ram\_1024\_x\_18 : label is attribute INIT\_3A of ram\_1024\_x\_18 : label is attribute INIT\_3B of ram\_1024\_x\_18 : label is attribute INIT\_3C of ram\_1024\_x\_18 : label is attribute INIT\_3D of ram\_1024\_x\_18 : label is attribute INIT\_3E of ram\_1024\_x\_18 : label is attribute INIT 3F of ram 1024 x 18 : label is attribute INITP\_00 of ram\_1024\_x\_18 : label is "D34CD3FCDDF3743C55B0D0D0D0D0D0D003C50CDF16C0333293774CE88FFFF3CF"; attribute INITP\_01 of ram\_1024\_x\_18 : label is "5776A957A03400F4F333CCCDF3337CCCDF3337CCCDF3334CCCCCAA234F353B34"; attribute INITP\_02 of ram\_1024\_x\_18 : label is "2CCCB33333333332CCCCCCCCAAAAB6A922088E8D892223A2DAA5ED4000B5B09"; attribute INITP\_03 of ram\_1024\_x\_18 : label is "FCEE0AA20E38388A3EAA3E028FAA3C0B8A38B72DCB72DCB4B30E5D8C0EA8B333"; attribute INITP\_04 of ram\_1024\_x\_18 : label is

attribute INITP\_05 of ram\_1024\_x\_18 : label is

attribute INITP\_06 of ram\_1024\_x\_18 : label is

attribute INITP\_07 of ram\_1024\_x\_18 : label is

--

begin

--

--Instantiate the Xilinx primitive for a block RAM

ram\_1024\_x\_18: RAMB16\_S9\_S18

--synthesis translate\_off

--INIT values repeated to define contents for functional simulation

generic map (INIT\_00 =>

X"E0060000020C01B301B301B301B301B3016102110523014E0211051001FB011F",

INIT 01 => X"E0068001600650164FFF548D2E0454862E014E00C0010FFF4092E005E0040001". INIT\_02 => X"0520A700A600050600E4012700116301620001996000019960010211052CC080", INIT\_03 => X"640463016200007401D1052DA7008601E7FFE6FF403B052B54362780017F0211", INIT\_04 => X"505A440501FC0018505A440301F80030505A440201EC0077505A440101D800EF", INIT\_05 => X"A7068672A700A600050600E401FF009C505A440101FF0038505A440601FE000C", INIT\_06 => X"547242FF5472431F407201D1053E546C4200546C43E063016200017802110517", INIT\_07 => X"01D18530650801D18530650901D1052E01D18530650A01024014007401D1053C", INIT\_08 => X"C0016004C000409200075492400880016004C000A00001D1052001D185306507", INIT\_09 => X"01D1053D01D10547021105100122D20002060206020602066205E00400015492", INIT 0A => X"01D1053254B5400240DF01D1052001D1052001D1053154AC4001600401D1052D". INIT\_0B => X"54C7400440DF01D1052001D1052001D1053554BE400340DF01D1052001D10520", INIT\_0C => X"40DF01D1052001D1053001D1053254D0400540DF01D1052001D1053001D10531", INIT\_0D => X"01AE01D1053001D1053001D1053140DF01D1052001D1053001D1053554D94006", INIT\_0E => X"0008010E0A0F198008FF50EC238008000400050006000700401454DF20054000", INIT\_0F => X"F680F530D4205D01200154EECA010900080003000206B790B680B53094205CF5", INIT\_10 => X"03A002000700060015701460A0005504C0018801F480010A08070005A000F790", INIT\_11 => X"00AEA0005511C1010208030E07000606B5309420411906075916F530D420010D", INIT\_12 => X"5526C101C008E001020023404301C008E001C2040108C008E008011FA000C008", INIT\_13 => X"060023804301C008E001C008E0010122C008E010C008E010011FA000C008E008", INIT\_14 => X"01D10550A0000608070A0608070A0808090A0808090A5539C101090008000700",

INIT\_15 => X"01D1056501D1057A01D1056101D1056C01D1054201D1056F01D1056301D10569", INIT\_16 => X"057401D1056E01D1056F01D1054301D1052001D1054301D1054401D10541A000", INIT\_17 => X"0541A00001D1053D01D1054101D10556A00001D1056C01D1056F01D1057201D1", INIT\_18 => X"101012000194000E000E000E0100A00001D1053D01D1054401D1052F01D1", INIT\_19 => X"A00001D1156001D1152016100188A000803A80075997C00AA00011000194A00F", INIT\_1A => X"01A90314A00055AAC20101A40219A00055A5C10101A00128A00055A1C001000B", INIT\_1B => X"C440A4F8A000C440E40101A0C440E401A00055B4C40101AE0414A00055AFC301", INIT\_1C => X"C44004F001A401BE0406040604060407145001A001BEC408A4F01450A00001B8", INIT\_1D => X"04F001A401B8C4400406040604070407145001A001B8C440C40CA4F01450A000", INIT\_1E => X"E401400201A0C440E40101A0C440E401450201A0C440E401C440040EA000C440", INIT\_1F => X"01BE01AE01BE043001AEA00001A4C4400404D500000E000E000E000EA5F0C440", INIT\_20 => X"01A901A901C2050101C2050C01C2050601C2052801A401BE042001A401BE01A9", INIT\_21 => X"E703E602E901E8000133A00001C2C5C0A50FA00001C2C580A50F52172510A000", 

INITP\_00 =>

X"D34CD3FCDDF3743C55B0D0D0D0D0D0D03C50CDF16C0333293774CE88FFFF3CF",

INITP\_01 => X"5776A957A03400F4F333CCCDF3337CCCDF3337CCCDF3334CCCCCAA234F353B34", INITP\_02 =>

X"2CCCB33333333332CCCCCCCCAAAAB6A922088E8D892223A2DAA5ED4000B5B09",

INITP\_03 =>

X"FCEE0AA20E38388A3EAA3E028FAA3C0B8A38B72DCB72DCB4B30E5D8C0EA8B333",

port map( DIB => "00000000000000",

```
DIPB => "00",
```

```
ENB => '1',
```

```
WEB => '0',
```

SSRB => '0',

CLKB => clk,

ADDRB => address,

DOB => instruction(15 downto 0),

```
DOPB => instruction(17 downto 16),
```

DIA => jdata,

DIPA => jparity,

```
ENA => sel1,
```

WEA => '1',

SSRA => '0',

CLKA => update,

```
ADDRA=> jaddr,
```

```
DOA => doa(7 downto 0),
```

```
DOPA => dopa);
```

```
-- v2_bscan: BSCAN_VIRTEX2
```

```
-- port map( TDO1 => tdo1,
```

- -- TD02 => tdo2,
- -- UPDATE => update,
- -- SHIFT => shift,
- -- RESET => reset,
- -- TDI => tdi,
- -- SEL1 => sel1,
- -- DRCK1 => drck1,
- -- SEL2 => sel2,
- -- DRCK2 => drck2,
- -- CAPTURE => capture);

--buffer signal used as a clock

upload\_clock: BUFG

```
port map( I => drck1,
```

```
0 => drck1_buf);
```

-- Assign the reset to be active whenever the uploading subsystem is active

```
proc_reset <= sel1;</pre>
```

```
srlC1: SRLC16E
```

```
--synthesis translate_off
```

```
generic map (INIT => X"0000")
```

```
--synthesis translate_on
```

```
port map( D => tdi,
```

```
CE => '1',
```

```
CLK => drck1_buf,
```

```
A0 => '1',
```

```
A1 => '0',
```

```
A2 => '1',
```

```
A3 => '1',
```

```
Q => jaddr(10),
```

```
Q15 => jaddr(8));
```

# flop1: FD

```
port map ( D => jaddr(10),
```

```
Q => jaddr(9),
```

```
C => drck1_buf);
```

```
srlC2: SRLC16E
```

```
--synthesis translate_off
```

```
generic map (INIT => X"0000")
```

```
--synthesis translate_on
port map( D => jaddr(8),
     CE => '1',
     CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
     A2 => '1',
     A3 => '1',
      Q => jaddr(7),
     Q15 => tap5);
flop2: FD
port map ( D => jaddr(7),
     Q => jaddr(6),
     C => drck1_buf);
srlC3: SRLC16E
--synthesis translate_off
generic map (INIT => X"0000")
--synthesis translate_on
port map( D => tap5,
     CE => '1',
     CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
     A2 => '1',
     A3 => '1',
      Q => jaddr(5),
     Q15 => jaddr(3));
flop3: FD
port map ( D => jaddr(5),
     Q \Rightarrow jaddr(4),
     C => drck1_buf);
srlC4: SRLC16E
--synthesis translate_off
generic map (INIT => X"0000")
--synthesis translate_on
port map( D => jaddr(3),
     CE => '1',
```

```
CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
     A2 => '1',
     A3 => '1',
      Q => jaddr(2),
     Q15 => tap11);
flop4: FD
port map ( D => jaddr(2),
     Q => jaddr(1),
     C => drck1_buf);
srlC5: SRLC16E
--synthesis translate_off
generic map (INIT => X"0000")
--synthesis translate_on
port map( D => tap11,
     CE => '1',
     CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
     A2 => '1',
     A3 => '1',
      Q => jaddr(0),
     Q15 => jdata(7));
flop5: FD
port map ( D => jaddr(0),
     Q \Rightarrow jparity(0),
     C => drck1_buf);
srlC6: SRLC16E
--synthesis translate_off
generic map (INIT => X"0000")
--synthesis translate_on
port map( D => jdata(7),
     CE => '1',
     CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
```

```
A2 => '1',
     A3 => '1',
      Q => jdata(6),
     Q15 => tap17);
flop6: FD
port map ( D => jdata(6),
     Q => jdata(5),
     C => drck1_buf);
srlC7: SRLC16E
--synthesis translate_off
generic map (INIT => X"0000")
--synthesis translate_on
port map( D => tap17,
     CE => '1',
     CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
     A2 => '1',
     A3 => '1',
      Q => jdata(4),
     Q15 => jdata(2));
flop7: FD
port map ( D => jdata(4),
     Q => jdata(3),
     C => drck1_buf);
srlC8: SRLC16E
--synthesis translate_off
generic map (INIT => X"0000")
--synthesis translate_on
port map( D => jdata(2),
     CE => '1',
     CLK => drck1_buf,
     A0 => '1',
     A1 => '0',
     A2 => '1',
     A3 => '1',
      Q \Rightarrow jdata(1),
```

```
Q15 => tdo1);
flop8: FD
port map ( D => jdata(1),
        Q => jdata(0),
        C => drck1_buf);
end low_level_definition;
--
--
-- END OF FILE adc_ctrl.vhd
```

--

\_\_\_\_\_

#### C.3. ETH\_LOOPBACK

MODULE ETH\_LOOPBACK ( INPUT SYS\_CLK, INPUT RESET\_IN\_N, // PHY SIGNALS: INPUT E\_COL, INPUT E\_CRS, OUTPUT E\_MDC, INOUT E\_MDIO, INPUT E\_RX\_CLK, INPUT E\_RX\_DV, INPUT [4:0] E\_RXD, INPUT E\_TX\_CLK, OUTPUT E\_TX\_EN, OUTPUT [4:0] E\_TXD, // DDR SDRAM SIGNALS: INOUT [15:0] CNTRL0\_DDR\_DQ, OUTPUT [12:0] CNTRL0\_DDR\_A, OUTPUT [1:0] CNTRL0\_DDR\_BA, OUTPUT CNTRL0\_DDR\_CKE, OUTPUT CNTRL0\_DDR\_CS\_N, OUTPUT CNTRL0\_DDR\_RAS\_N, OUTPUT CNTRL0\_DDR\_CAS\_N,

```
OUTPUT CNTRL0_DDR_WE_N,
OUTPUT [1:0] CNTRL0_DDR_DM,
INOUT CNTRL0_RST_DQS_DIV,
INOUT [1:0] CNTRL0_DDR_DQS,
OUTPUT [0:0] CNTRL0_DDR_CK,
OUTPUT [0:0] CNTRL0_DDR_CK_N,
// LED SIGNALS
OUTPUT [7:0] LED
```

);

// WISHBONE MASTER 1: ETHERNET DMA
WIRE [31:0] M1\_WB\_ADR\_I;
WIRE [31:0] M1\_WB\_DAT\_I;
WIRE [3:0] M1\_WB\_SEL\_I;
WIRE M1\_WB\_CYC\_I;
WIRE M1\_WB\_STB\_I;
WIRE M1\_WB\_WE\_I;
WIRE [31:0] M1\_WB\_DAT\_O;
WIRE M1\_WB\_ACK\_O;
WIRE M1\_WB\_ERR\_O;

// WISHBONE MASTER 2: HOST (LOOPBACK CONTROLLER)

| WIRE [31:0] | M2_WB_ADR_I; |
|-------------|--------------|
| WIRE [31:0] | M2_WB_DAT_I; |
| WIRE [3:0]  | M2_WB_SEL_I; |
| WIRE        | M2_WB_CYC_I; |
| WIRE        | M2_WB_STB_I; |
| WIRE        | M2_WB_WE_I;  |
| WIRE [31:0] | M2_WB_DAT_0; |
| WIRE        | M2_WB_ACK_0; |
| WIRE        | M2_WB_ERR_0; |

// WISHBONE SLAVE 1: ETHERNET REGISTERS AND BUFFER DESCRIPTORS

WIRE [31:0]S1\_WB\_DAT\_I;WIRES1\_WB\_ACK\_I;WIRES1\_WB\_ERR\_I;WIRE [31:0]S1\_WB\_ADR\_O;

| WIRE [31:0] | S1_WB_DAT_O; |
|-------------|--------------|
| WIRE [3:0]  | S1_WB_SEL_O; |
| WIRE        | S1_WB_WE_O;  |
| WIRE        | S1_WB_CYC_0; |
| WIRE        | S1_WB_STB_0; |

// WISHBONE SLAVE 2: MEMORY

| WIRE [31:0] | S2_WB_DAT_I; |
|-------------|--------------|
| WIRE        | S2_WB_ACK_I; |
| WIRE        | S2_WB_ERR_I; |
| WIRE [31:0] | S2_WB_ADR_O; |
| WIRE [31:0] | S2_WB_DAT_O; |
| WIRE [3:0]  | S2_WB_SEL_O; |
| WIRE        | S2_WB_WE_O;  |
| WIRE        | S2_WB_CYC_0; |
| WIRE        | S2_WB_STB_O; |
|             |              |

WIRE ETHER\_MDO; WIRE ETHER\_MDIO\_E;

```
// FOR THE USER INTERFACE TO THE DDR
```

WIRE [2:0] COMMAND;

WIRE [((`DATA\_MASK\_WIDTH\*2)-1):0] DATA\_MASK;

WIRE [((`DATA\_WIDTH\*2)-1):0] OUTPUT\_DATA;

WIRE [((`DATA\_WIDTH\*2)-1):0] DDR\_INPUT\_DATA;

WIRE [((`ROW\_ADDRESS +

```
`COL_AP_WIDTH +
```

`BANK\_ADDRESS)-1):0] INPUT\_ADDRESS;

| WIRE | CMD_ACK;      |
|------|---------------|
| WIRE | AUTO_REF_REQ; |
| WIRE | AR_DONE;      |
| WIRE | BURST_DONE;   |

WIRE DATA\_VALID\_OUT; WIRE INIT\_DONE;

// FOR THE INFRASTRUCTURE:

| WIRE       | WAIT_200US;    |
|------------|----------------|
| WIRE       | SYS_RST;       |
| WIRE       | SYS_RST90;     |
| WIRE       | SYS_RST180;    |
| WIRE [4:0] | DELAY_SEL_VAL; |
| WIRE       | CLK0;          |
| WIRE       | CLK90;         |

// TRI-STATE: ASSIGN E\_MDIO = ETHER\_MDIO\_E ? ETHER\_MDO : 1'BZ; //ASSIGN LED = 8'B0;

# // INSTANTIATE THE ETHERNET MODULE ETH\_TOP ETHERNET (

// WISHBONE COMMON
.WB\_CLK\_I(CLK0),
.WB\_RST\_I(SYS\_RST),

```
// WISHBONE SLAVE
.WB_DAT_I(S1_WB_DAT_O),
.WB_DAT_O(S1_WB_DAT_I),
.WB_ADR_I(S1_WB_ADR_O[11:2]),
.WB_SEL_I(S1_WB_SEL_O),
.WB_WE_I(S1_WB_WE_O),
.WB_CYC_I(S1_WB_WE_O),
.WB_STB_I(S1_WB_STB_O),
.WB_ACK_O(S1_WB_ACK_I),
.WB_ERR_O(S1_WB_ERR_I),
```

// WISHBONE MASTER
.M\_WB\_ADR\_O(M1\_WB\_ADR\_I),
.M\_WB\_SEL\_O(M1\_WB\_SEL\_I),
.M\_WB\_WE\_O(M1\_WB\_WE\_I),
.M\_WB\_DAT\_O(M1\_WB\_DAT\_I),

.M\_WB\_DAT\_I(M1\_WB\_DAT\_O), .M\_WB\_CYC\_O(M1\_WB\_CYC\_I), .M\_WB\_STB\_O(M1\_WB\_STB\_I), .M\_WB\_ACK\_I(M1\_WB\_ACK\_O), .M\_WB\_ERR\_I(M1\_WB\_ERR\_O),

#### //TX

.MTX\_CLK\_PAD\_I(E\_TX\_CLK), .MTXD\_PAD\_O(E\_TXD[3:0]), .MTXEN\_PAD\_O(E\_TX\_EN), .MTXERR\_PAD\_O(E\_TXD[4]),

#### //RX

.MRX\_CLK\_PAD\_I(E\_RX\_CLK), .MRXD\_PAD\_I(E\_RXD[3:0]), .MRXDV\_PAD\_I(E\_RX\_DV), .MRXERR\_PAD\_I(E\_RXD[4]), .MCOLL\_PAD\_I(E\_COL), .MCRS\_PAD\_I(E\_CRS),

#### // MIIM

.MDC\_PAD\_O(E\_MDC), .MD\_PAD\_I(E\_MDIO), .MD\_PAD\_O(ETHER\_MDO), .MD\_PADOE\_O(ETHER\_MDIO\_E),

## .INT\_O(ETHER\_INT)

// ,.LED(LED[3:0]) );

#### // INSTANTIATE THE MEMORY

// (ACTUALLY A WISHBONE INTERFACE TO MIG INTERFACE CONVERTER): MEMORY\_WB\_TO\_MIG MEM ( // WB INTERFACE: .WB\_CLK\_I(CLK0), .WB\_RST\_I(SYS\_RST),

.WB\_ADR\_I(S2\_WB\_ADR\_0),

.WB\_SEL\_I(S2\_WB\_SEL\_O),

.WB\_WE\_I(S2\_WB\_WE\_0),

.WB\_CYC\_I(S2\_WB\_CYC\_0),

.WB\_STB\_I(S2\_WB\_STB\_0),

.WB\_ACK\_O(S2\_WB\_ACK\_I),

.WB\_ERR\_O(S2\_WB\_ERR\_I),

.WB\_DAT\_O(S2\_WB\_DAT\_I),

.WB\_DAT\_I(S2\_WB\_DAT\_O),

// MIG INTERFACE:

// (NOTE THAT IT ALSO PROVIDES THE SYSTEM CLOCK)

.MIG\_CLK90(CLK90),

.MIG\_INIT\_DONE(INIT\_DONE),

.MIG\_OUTPUT\_DATA(OUTPUT\_DATA),

.MIG\_INPUT\_DATA(DDR\_INPUT\_DATA),

.MIG\_INPUT\_ADDRESS(INPUT\_ADDRESS),

.MIG\_COMMAND(COMMAND),

.MIG\_CMD\_ACK(CMD\_ACK),

```
.MIG_DATA_VALID(DATA_VALID_OUT),
```

.MIG\_BURST\_DONE(BURST\_DONE),

.MIG\_AR\_DONE(AR\_DONE),

.MIG\_AUTO\_REF\_REQ(AUTO\_REF\_REQ),

.MIG\_WAIT\_200US(WAIT\_200US),

.MIG\_DATA\_MASK(DATA\_MASK)

);

// INSTANTIATE THE MIG MEMORY CONTROLLER: VLOG\_BL2CL25\_TOP\_0 TOP0 ( .AUTO\_REF\_REQ (AUTO\_REF\_REQ), .WAIT\_200US (WAIT\_200US), .RST\_DQS\_DIV\_IN (CNTRL0\_RST\_DQS\_DIV), .RST\_DQS\_DIV\_OUT (CNTRL0\_RST\_DQS\_DIV), .USER\_INPUT\_DATA (DDR\_INPUT\_DATA), .USER\_OUTPUT\_DATA (OUTPUT\_DATA), .USER\_DATA\_VALID (DATA\_VALID\_OUT),

.USER\_INPUT\_ADDRESS (INPUT\_ADDRESS[((`ROW\_ADDRESS + `COL\_AP\_WIDTH

```
+ `BANK_ADDRESS)-1):0]),
```

.USER\_COMMAND\_REGISTER (COMMAND),

.USER\_CMD\_ACK (CMD\_ACK),

.BURST\_DONE (BURST\_DONE),

.INIT\_VAL (INIT\_DONE),

.AR\_DONE (AR\_DONE),

.DDR\_DQS (CNTRL0\_DDR\_DQS),

.DDR\_DQ (CNTRL0\_DDR\_DQ),

.DDR\_CKE (CNTRL0\_DDR\_CKE),

.DDR\_CS\_N (CNTRL0\_DDR\_CS\_N),

.DDR\_RAS\_N (CNTRL0\_DDR\_RAS\_N),

.DDR\_CAS\_N (CNTRL0\_DDR\_CAS\_N),

.DDR\_WE\_N (CNTRL0\_DDR\_WE\_N),

.DDR\_BA (CNTRL0\_DDR\_BA),

.DDR\_A (CNTRL0\_DDR\_A),

.DDR\_DM (CNTRL0\_DDR\_DM),

.USER\_DATA\_MASK (DATA\_MASK),

.DDR\_CK (CNTRL0\_DDR\_CK),

.DDR\_CK\_N (CNTRL0\_DDR\_CK\_N),

.CLK\_INT (CLK0),

.CLK90\_INT (CLK90),

.DELAY\_SEL\_VAL (DELAY\_SEL\_VAL),

.SYS\_RST\_VAL (SYS\_RST),

.SYS\_RST90\_VAL (SYS\_RST90),

.SYS\_RST180\_VAL (SYS\_RST180)

);

// INSTANTIATE THE DCM AND THE DELAY

VLOG\_BL2CL25\_INFRASTRUCTURE\_TOP INFRASTRUCTURE\_TOP0

(

.SYS\_CLK (SYS\_CLK), .RESET\_IN\_N (RESET\_IN\_N), .WAIT\_200US\_ROUT (WAIT\_200US), .DELAY\_SEL\_VAL1\_VAL (DELAY\_SEL\_VAL),

```
.SYS_RST_VAL (SYS_RST),
.SYS_RST90_VAL (SYS_RST90),
.CLK_INT_VAL (CLK0),
.CLK90_INT_VAL (CLK90),
.SYS_RST180_VAL (SYS_RST180)
);
```

// INSTANTIATE THE LOOPBACK CONTROLLER LOOPBACK\_CONTROL LBC

(

.WB\_CLK\_I(CLK0), .WB\_RST\_I(SYS\_RST), .M\_WB\_ADR\_O(M2\_WB\_ADR\_I), .M\_WB\_SEL\_O(M2\_WB\_SEL\_I), .M\_WB\_WE\_O(M2\_WB\_WE\_I), .M\_WB\_DAT\_I(M2\_WB\_DAT\_O), .M\_WB\_DAT\_O(M2\_WB\_DAT\_I), .M\_WB\_CYC\_O(M2\_WB\_CYC\_I), .M\_WB\_STB\_O(M2\_WB\_STB\_I), .M\_WB\_STB\_O(M2\_WB\_STB\_I), .M\_WB\_ACK\_I(M2\_WB\_ACK\_O), .M\_WB\_ERR\_I(M2\_WB\_ERR\_O) .LED(LED[7:0])

);

// INSTANTIATE THE ETHCOP THAT INTERCONNECTS THE 4 WB INTERFACES ETH\_COP ECOP (

// WISHBONE COMMON .WB\_CLK\_I(CLK0), .WB\_RST\_I(SYS\_RST),

// WISHBONE MASTER 1
.M1\_WB\_ADR\_I(M1\_WB\_ADR\_I),
.M1\_WB\_SEL\_I(M1\_WB\_SEL\_I),
.M1\_WB\_WE\_I(M1\_WB\_WE\_I),
.M1\_WB\_DAT\_O(M1\_WB\_DAT\_O),
.M1\_WB\_DAT\_I(M1\_WB\_DAT\_I),

.M1\_WB\_CYC\_I(M1\_WB\_CYC\_I), .M1\_WB\_STB\_I(M1\_WB\_STB\_I), .M1\_WB\_ACK\_O(M1\_WB\_ACK\_O), .M1\_WB\_ERR\_O(M1\_WB\_ERR\_O),

// WISHBONE MASTER 2
.M2\_WB\_ADR\_I(M2\_WB\_ADR\_I),
.M2\_WB\_SEL\_I(M2\_WB\_SEL\_I),
.M2\_WB\_WE\_I(M2\_WB\_WE\_I),
.M2\_WB\_DAT\_O(M2\_WB\_DAT\_O),
.M2\_WB\_DAT\_I(M2\_WB\_DAT\_I),
.M2\_WB\_CYC\_I(M2\_WB\_CYC\_I),
.M2\_WB\_STB\_I(M2\_WB\_STB\_I),
.M2\_WB\_ACK\_O(M2\_WB\_ACK\_O),
.M2\_WB\_ERR\_O(M2\_WB\_ERR\_O),

// WISHBONE SLAVE 1
.S1\_WB\_ADR\_O(S1\_WB\_ADR\_O),
.S1\_WB\_SEL\_O(S1\_WB\_SEL\_O),
.S1\_WB\_WE\_O(S1\_WB\_WE\_O),
.S1\_WB\_CYC\_O(S1\_WB\_CYC\_O),
.S1\_WB\_STB\_O(S1\_WB\_STB\_O),
.S1\_WB\_ACK\_I(S1\_WB\_ACK\_I),
.S1\_WB\_ERR\_I(S1\_WB\_ERR\_I),
.S1\_WB\_DAT\_I(S1\_WB\_DAT\_I),
.S1\_WB\_DAT\_O(S1\_WB\_DAT\_O),

// WISHBONE SLAVE 2
.S2\_WB\_ADR\_O(S2\_WB\_ADR\_O),
.S2\_WB\_SEL\_O(S2\_WB\_SEL\_O),
.S2\_WB\_WE\_O(S2\_WB\_WE\_O),
.S2\_WB\_CYC\_O(S2\_WB\_CYC\_O),
.S2\_WB\_STB\_O(S2\_WB\_STB\_O),
.S2\_WB\_ACK\_I(S2\_WB\_ACK\_I),
.S2\_WB\_ERR\_I(S2\_WB\_ERR\_I),
.S2\_WB\_DAT\_I(S2\_WB\_DAT\_I),
.S2\_WB\_DAT\_O(S2\_WB\_DAT\_O)

#### ENDMODULE // ETH\_LOOPBACK

#### C.4. memory\_wb\_to\_mig

module memory\_wb\_to\_mig ( // wishbone interface: input wb\_clk\_i, wb\_rst\_i, input input [31:0] wb\_adr\_i, input [31:0] wb\_dat\_i, input [3:0] wb\_sel\_i, input wb\_we\_i, input wb\_cyc\_i, wb\_stb\_i, input output reg wb\_ack\_o, output reg wb\_err\_o, output reg [31:0] wb\_dat\_o,

#### // MIG 2.0 interface:

| input                         | mig_clk90,                |  |
|-------------------------------|---------------------------|--|
| input                         | mig_init_done,            |  |
| input                         | [31:0] mig_output_data,   |  |
| output                        | [31:0] mig_input_data,    |  |
| output                        | [25:0] mig_input_address, |  |
| output reg [2:0] mig_command, |                           |  |
| input                         | mig_cmd_ack,              |  |
| input                         | mig_data_valid,           |  |
| output reg mig_burst_done,    |                           |  |
| input                         | mig_ar_done,              |  |
| input                         | mig_auto_ref_req,         |  |
| input                         | mig_wait_200us,           |  |
| output                        | [3:0] mig_data_mask       |  |
|                               |                           |  |

reg [2:0] current\_init\_state; reg [2:0] next\_init\_state; reg [2:0] current\_state; reg [2:0] next\_state; reg [2:0] cntr;

// user commands: localparam NOP\_CMD = 3'b000, PRECHARGE\_CMD = 3'b001, INIT\_CMD = 3'b010, WRITE\_CMD = 3'b100, READ\_CMD = 3'b110;

localparam

INIT\_INIT = 3'b000, WAIT\_200us = 3'b001, SEND\_INIT = 3'b010, WAIT\_INIT = 3'b011, INIT\_DONE = 3'b100;

parameter IDLE\_ST = 3'b000, READ\_START\_ST = 3'b001, WRITE\_START\_ST = 3'b010, WAIT\_ACK\_ST = 3'b011, COMMAND\_ACKED\_ST = 3'b100, BURST\_DONE\_ST = 3'b101, WAIT\_ACK\_N\_ST = 3'b110, ACK\_N\_ST = 3'b111;

localparam WAIT\_BURST\_DONE\_VALUE = 24'b11;

reg wb\_ack\_o\_sync;

```
assign mig_input_address = {wb_adr_i[20:9],wb_adr_i[8], 1'b0, wb_adr_i[7:0], wb_adr_i[22:21]};
assign mig_data_mask = ~wb_sel_i; // see ethernet module
assign mig_input_data = wb_dat_i;
```

```
initial begin
wb_ack_o <= 0;
wb_ack_o_sync <= 0;
wb_err_o <= 0;
cntr <= 0;
mig_command <= NOP_CMD;
current_init_state <= 0;
next_init_state <= 0;
current_state <= 0;
next_state <= 0;
end</pre>
```

```
// process the command
always @ (negedge mig_clk90) begin
if (current_init_state == SEND_INIT) begin
mig_command <= INIT_CMD;
end else if (current_state == READ_START_ST) begin
mig_command <= READ_CMD;
end else if (current_state == WRITE_START_ST) begin
mig_command <= WRITE_CMD;
end else if (current_init_state == WAIT_INIT ||
current_state == BURST_DONE_ST) begin
mig_command <= NOP_CMD;
end
end
```

```
// general counter
always @ (negedge mig_clk90) begin
if (current_state == WAIT_ACK_ST) begin
cntr <= WAIT_BURST_DONE_VALUE;</pre>
```

```
end else begin
cntr <= cntr - 1;
end
end
```

```
// set burst_done output to memory
always @ (negedge mig_clk90) begin
// should be set 3 clocks after a READ or WRITE command has been issued:
if (current_state == BURST_DONE_ST)
mig_burst_done <= 1'b1;
else
mig_burst_done <= 1'b0;
end</pre>
```

```
// memory output data to the wishbone interface:
always @ (negedge mig_clk90) begin
if (mig_data_valid) begin
case (wb_adr_i[1:0])
2'b00: // word access
wb_dat_o <= mig_output_data;</pre>
```

```
2'b10: // half access
wb_dat_o <= {16'b0,mig_output_data[15:0]};</pre>
```

2'b01: // byte access wb\_dat\_o <= {8'b0,mig\_output\_data[23:16],16'b0};

#### 2'b11:

```
wb_dat_o <= {14'b0,mig_output_data[7:0]};
endcase
end
end
```

// state processing

```
always@ (negedge mig_clk90) begin
if (wb_rst_i) begin
  current_init_state <= INIT_INIT;
end else begin
  current_init_state <= next_init_state;
end
end
```

```
always@ (negedge mig_clk90) begin
if (wb_rst_i) begin
current_state <= IDLE_ST;
end else begin
current_state <= next_state;
end
end</pre>
```

```
// synchronizing to the wishbone clock
always @ (negedge mig_clk90) begin
if (((current_state == WAIT_ACK_N_ST) && !mig_cmd_ack) || current_state == ACK_N_ST) begin
wb_ack_o_sync <= 1'b1;
end else begin
wb_ack_o_sync <= 1'b0;
end</pre>
```

```
end
```

```
// this is the ack output to the wb interface clocked by the wishbone
// clock
always @ (posedge wb_clk_i) begin
    if (wb_ack_o_sync) begin
    wb_ack_o <= 1'b1;
    end else begin
    wb_ack_o <= 1'b0;
    end
end</pre>
```

```
// memory initialization:
always @ (*) begin
if (wb_rst_i) begin
next_init_state = INIT_INIT;
end else begin
case (current_init_state)
INIT_INIT:
if (!mig_wait_200us)
next_init_state = SEND_INIT;
else
next_init_state = INIT_INIT;
```

#### SEND\_INIT:

next\_init\_state = WAIT\_INIT;

### WAIT\_INIT: if (mig\_init\_done) next\_init\_state = INIT\_DONE; else

next\_init\_state = WAIT\_INIT;

```
INIT_DONE:
next_init_state = INIT_DONE;
```

```
default
    next_init_state = INIT_DONE;
    endcase // case (current_init_state)
    end // else: !if(wb_rst_i)
end // always @ (*)
```

// state machine after memory initialization
always @ (\*) begin
if (wb\_rst\_i) begin
next\_state = IDLE\_ST;
end else if (mig\_init\_done) begin

```
case (current_state)
IDLE_ST:
    if (wb_cyc_i & wb_stb_i) begin
    if (!wb_we_i) begin
    next_state = READ_START_ST;
    end else begin
    next_state = WRITE_START_ST;
    end
end else begin
    next_state = IDLE_ST;
end
```

```
READ_START_ST:
```

next\_state = WAIT\_ACK\_ST;

```
WRITE_START_ST:
```

next\_state = WAIT\_ACK\_ST;

WAIT\_ACK\_ST:

```
if (mig_cmd_ack)
next_state = COMMAND_ACKED_ST;
else
next_state = WAIT_ACK_ST;
```

```
COMMAND_ACKED_ST:
if (!cntr) begin
```

```
next_state = BURST_DONE_ST;
end else begin
next_state = COMMAND_ACKED_ST;
end
```

```
BURST_DONE_ST:
next_state = WAIT_ACK_N_ST;
```

```
WAIT_ACK_N_ST:
if (!mig_cmd_ack) begin
next_state = ACK_N_ST;
```

```
end else
next_state = WAIT_ACK_N_ST;
```

```
ACK_N_ST:
next_state = IDLE_ST;
```

default:

```
next_state = IDLE_ST;
endcase // case (current_state)
end else begin// if (mig_init_done)
next_state = IDLE_ST;
end // else: !if(init_done)
end
```

#### endmodule

#### C.5. module eth\_cop

`include "../rtl/eth\_defines.v"
`include "../rtl/timescale.v"

module eth\_cop

(

// WISHBONE common wb\_clk\_i, wb\_rst\_i,

```
// WISHBONE MASTER 1
```

m1\_wb\_adr\_i, m1\_wb\_sel\_i, m1\_wb\_we\_i, m1\_wb\_dat\_o, m1\_wb\_dat\_i, m1\_wb\_cyc\_i, m1\_wb\_stb\_i, m1\_wb\_ack\_o, m1\_wb\_err\_o,

#### // WISHBONE MASTER 2

m2\_wb\_adr\_i, m2\_wb\_sel\_i, m2\_wb\_we\_i, m2\_wb\_dat\_o, m2\_wb\_dat\_i, m2\_wb\_cyc\_i, m2\_wb\_stb\_i, m2\_wb\_ack\_o, m2\_wb\_err\_o,

```
// WISHBONE slave 1
s1_wb_adr_o, s1_wb_sel_o, s1_wb_we_o, s1_wb_cyc_o,
s1_wb_stb_o, s1_wb_ack_i, s1_wb_err_i, s1_wb_dat_i,
s1_wb_dat_o,
```

```
// WISHBONE slave 2
s2_wb_adr_o, s2_wb_sel_o, s2_wb_we_o, s2_wb_cyc_o,
s2_wb_stb_o, s2_wb_ack_i, s2_wb_err_i, s2_wb_dat_i,
s2_wb_dat_o
);
```

```
parameter Tp=1;
```

## // WISHBONE common

input wb\_clk\_i, wb\_rst\_i;

```
// WISHBONE MASTER 1
```

input [31:0] m1\_wb\_adr\_i, m1\_wb\_dat\_i; input [3:0] m1\_wb\_sel\_i; input m1\_wb\_cyc\_i, m1\_wb\_stb\_i, m1\_wb\_we\_i; output [31:0] m1\_wb\_dat\_o; output m1\_wb\_ack\_o, m1\_wb\_err\_o;

```
// WISHBONE MASTER 2
```

input [31:0] m2\_wb\_adr\_i, m2\_wb\_dat\_i; input [3:0] m2\_wb\_sel\_i; input m2\_wb\_cyc\_i, m2\_wb\_stb\_i, m2\_wb\_we\_i; output [31:0] m2\_wb\_dat\_o; output m2\_wb\_ack\_o, m2\_wb\_err\_o;

```
// WISHBONE slave 1
input [31:0] s1_wb_dat_i;
input
         s1_wb_ack_i, s1_wb_err_i;
output [31:0] s1_wb_adr_o, s1_wb_dat_o;
output [3:0] s1_wb_sel_o;
output
         s1_wb_we_o, s1_wb_cyc_o, s1_wb_stb_o;
```

// WISHBONE slave 2
input [31:0] s2\_wb\_dat\_i;
input s2\_wb\_ack\_i, s2\_wb\_err\_i;
output [31:0] s2\_wb\_adr\_o, s2\_wb\_dat\_o;
output [3:0] s2\_wb\_sel\_o;
output s2\_wb\_we\_o, s2\_wb\_cyc\_o, s2\_wb\_stb\_o;

reg m1\_in\_progress; reg m2\_in\_progress; reg [31:0] s1\_wb\_adr\_o; reg [3:0] s1\_wb\_sel\_o; reg s1\_wb\_we\_o; reg [31:0] s1\_wb\_dat\_o; reg s1\_wb\_cyc\_o; reg s1\_wb\_stb\_o; reg [31:0] s2\_wb\_adr\_o; reg [3:0] s2\_wb\_sel\_o; reg s2\_wb\_we\_o; reg [31:0] s2\_wb\_dat\_o; reg s2\_wb\_cyc\_o; reg s2\_wb\_stb\_o;

reg m1\_wb\_ack\_o; reg [31:0] m1\_wb\_dat\_o; reg m2\_wb\_ack\_o; reg [31:0] m2\_wb\_dat\_o;

reg m1\_wb\_err\_o; reg m2\_wb\_err\_o;

```
/*
```

wire M1\_ADDRESSED\_S1 = ( (m1\_wb\_adr\_i >= `ETH\_BASE) & (m1\_wb\_adr\_i < (`ETH\_BASE + `ETH\_WIDTH )) ); wire M1\_ADDRESSED\_S2 = ( (m1\_wb\_adr\_i >= `ETH\_MEMORY\_BASE) & (m1\_wb\_adr\_i < (`ETH\_MEMORY\_BASE + `ETH\_MEMORY\_WIDTH)) ); wire M2\_ADDRESSED\_S1 = ( (m2\_wb\_adr\_i >= `ETH\_BASE) & (m2\_wb\_adr\_i < (`ETH\_BASE + `ETH\_WIDTH )) );

```
wire M2_ADDRESSED_S2 = ( (m2_wb_adr_i >= `ETH_MEMORY_BASE) & (m2_wb_adr_i <
(`ETH_MEMORY_BASE + `ETH_MEMORY_WIDTH)) );
*/</pre>
```

| wire | M1_ADDRESSED_S1 = ( (m1_wb_adr_i >= 32'h0) & (m1_wb_adr_i < 32'h800) );                |
|------|----------------------------------------------------------------------------------------|
| wire | $M1\_ADDRESSED\_S2 = ( (m1\_wb\_adr\_i >= 32'h2000) & (m1\_wb\_adr\_i < 32'h32000) );$ |
| wire | M2_ADDRESSED_S1 = ( (m2_wb_adr_i >= 32'h0) & (m2_wb_adr_i < 32'h800) );                |
| wire | $M2\_ADDRESSED\_S2 = ( (m2\_wb\_adr\_i >= 32'h2000) & (m2\_wb\_adr\_i < 32'h32000) );$ |

wire m\_wb\_access\_finished;

| wire | m1_req = m1_wb_cyc_i & m1_wb_stb_i & (M1_ADDRESSED_S1   M1_ADDRESSED_S2); |
|------|---------------------------------------------------------------------------|
| wire | m2_req = m2_wb_cyc_i & m2_wb_stb_i & (M2_ADDRESSED_S1   M2_ADDRESSED_S2); |

initial begin

| m1_in_progress <= 0; |  |
|----------------------|--|
| m2_in_progress <= 0; |  |
| s1_wb_adr_o <= 0;    |  |
| s1_wb_sel_o <= 0;    |  |
| s1_wb_we_o <= 0;     |  |
| s1_wb_dat_o <= 0;    |  |
| s1_wb_cyc_o <= 0;    |  |
| s1_wb_stb_o <= 0;    |  |
| s2_wb_adr_o <= 0;    |  |
| s2_wb_sel_o <= 0;    |  |
| s2_wb_we_o <= 0;     |  |
| s2_wb_dat_o <= 0;    |  |
| s2_wb_cyc_o <= 0;    |  |
| s2_wb_stb_o <= 0;    |  |
| end                  |  |

always @ (posedge wb\_clk\_i or posedge wb\_rst\_i)
begin
if(wb\_rst\_i)
begin
m1\_in\_progress <=#Tp 0;
m2\_in\_progress <=#Tp 0;</pre>

| s1_wb_adr_o | <=#Tp 0; |
|-------------|----------|
| s1_wb_sel_o | <=#Tp 0; |
| s1_wb_we_o  | <=#Tp 0; |
| s1_wb_dat_o | <=#Tp 0; |
| s1_wb_cyc_o | <=#Tp 0; |
| s1_wb_stb_o | <=#Tp 0; |
| s2_wb_adr_o | <=#Tp 0; |
| s2_wb_sel_o | <=#Tp 0; |
| s2_wb_we_o  | <=#Tp 0; |
| s2_wb_dat_o | <=#Tp 0; |
| s2_wb_cyc_o | <=#Tp 0; |
| s2_wb_stb_o | <=#Tp 0; |
| end         |          |

else

begin

case({m1\_in\_progress, m2\_in\_progress, m1\_req, m2\_req, m\_wb\_access\_finished}) // synopsys\_full\_case
synopsys\_paralel\_case

```
5'b00_10_0, 5'b00_11_0 :
```

begin

```
m1_in_progress <= #Tp 1'b1; // idle: m1 or (m1 & m2) want access: m1 -> m
```

```
if(M1_ADDRESSED_S1)
```

begin

```
s1_wb_adr_o <=#Tp m1_wb_adr_i;
```

```
s1_wb_sel_o <=#Tp m1_wb_sel_i;
```

```
s1_wb_we_o <=#Tp m1_wb_we_i;
```

```
s1_wb_dat_o <= #Tp m1_wb_dat_i;</pre>
```

```
s1_wb_cyc_o <=#Tp 1'b1;
```

```
s1_wb_stb_o <=#Tp 1'b1;
```

end

```
else if(M1_ADDRESSED_S2)
```

begin

```
s2_wb_adr_o <=#Tp m1_wb_adr_i;
```

```
s2_wb_sel_o <=#Tp m1_wb_sel_i;</pre>
```

```
s2_wb_we_o <=#Tp m1_wb_we_i;
```

```
s2_wb_dat_o <=#Tp m1_wb_dat_i;
```

```
s2_wb_cyc_o <=#Tp 1'b1;
```

```
s2_wb_stb_o <=#Tp 1'b1;
```

end

//else

//\$display("(%t)(%m)WISHBONE ERROR: Unspecified address space accessed", \$time);

end

```
5'b00_01_0:
```

begin

```
m2_in_progress <= #Tp 1'b1; // idle: m2 wants access: m2 -> m
```

if(M2\_ADDRESSED\_S1)

begin

```
s1_wb_adr_o <=#Tp m2_wb_adr_i;
```

```
s1_wb_sel_o <=#Tp m2_wb_sel_i;
```

```
s1_wb_we_o <=#Tp m2_wb_we_i;
```

```
s1_wb_dat_o <=#Tp m2_wb_dat_i;
```

```
s1_wb_cyc_o <=#Tp 1'b1;
```

s1\_wb\_stb\_o <=#Tp 1'b1;

end

```
else if(M2_ADDRESSED_S2)
```

begin

```
s2_wb_adr_o <=#Tp m2_wb_adr_i;
```

```
s2_wb_sel_o <=#Tp m2_wb_sel_i;
```

```
s2_wb_we_o <=#Tp m2_wb_we_i;
```

```
s2_wb_dat_o <=#Tp m2_wb_dat_i;
```

```
s2_wb_cyc_o <=#Tp 1'b1;
```

```
s2_wb_stb_o <=#Tp 1'b1;
```

end

```
//else
```

```
//$display("(%t)(%m)WISHBONE ERROR: Unspecified address space accessed", $time);
end
```

```
5'b10_10_1, 5'b10_11_1 :
```

begin

```
m1_in_progress <=#Tp 1'b0; // m1 in progress. Cycle is finished. Send ack or err to m1.
```

```
if(M1_ADDRESSED_S1)
```

begin

```
s1_wb_cyc_o <=#Tp 1'b0;
```

```
s1_wb_stb_o <=#Tp 1'b0;
```

end

```
else if(M1_ADDRESSED_S2)
```

```
begin
        s2_wb_cyc_o <=#Tp 1'b0;
        s2_wb_stb_o <=#Tp 1'b0;
       end
     end
    5'b01_01_1, 5'b01_11_1 :
     begin
      m2_in_progress <= #Tp 1'b0; // m2 in progress. Cycle is finished. Send ack or err to m2.
      if(M2_ADDRESSED_S1)
       begin
        s1_wb_cyc_o <=#Tp 1'b0;
        s1_wb_stb_o <=#Tp 1'b0;
       end
      else if(M2_ADDRESSED_S2)
       begin
        s2_wb_cyc_o <=#Tp 1'b0;
        s2_wb_stb_o <=#Tp 1'b0;
       end
     end
   endcase
   end
end
// Generating Ack for master 1
always @ (*)
begin
 if(m1_in_progress)
  begin
   if(M1_ADDRESSED_S1) begin
    m1_wb_ack_o <= s1_wb_ack_i;
    m1_wb_dat_o <= s1_wb_dat_i;
   end
   else if(M1_ADDRESSED_S2) begin
    m1_wb_ack_o <= s2_wb_ack_i;
    m1_wb_dat_o <= s2_wb_dat_i;
   end
```

```
end
```

```
else
m1_wb_ack_o <= 0;
end
```

```
// Generating Ack for master 2
always @ (*)
begin
 if(m2_in_progress)
  begin
   if(M2_ADDRESSED_S1) begin
    m2_wb_ack_o <= s1_wb_ack_i;
    m2_wb_dat_o <= s1_wb_dat_i;
   end
   else if(M2_ADDRESSED_S2) begin
    m2_wb_ack_o <= s2_wb_ack_i;
    m2_wb_dat_o <= s2_wb_dat_i;
   end
   end
  else
  m2_wb_ack_o <= 0;
end
```

```
// Generating Err for master 1
// sensitivity list change lll
//always @ (m1_in_progress or m1_wb_adr_i or s1_wb_err_i or s2_wb_err_i or M2_ADDRESSED_S1 or
M2_ADDRESSED_S2 or
always @ (*)
begin
if(m1_in_progress) begin
if(m1_ADDRESSED_S1)
m1_wb_err_o <= s1_wb_err_i;
else if(M1_ADDRESSED_S2)
m1_wb_err_o <= s2_wb_err_i;
end
else if(m1_wb_cyc_i & m1_wb_stb_i & ~M1_ADDRESSED_S1 & ~M1_ADDRESSED_S2)
```

```
m1_wb_err_o <= 1'b1;
  else
  m1_wb_err_o <= 1'b0;
end
// Generating Err for master 2
always @ (*)
begin
 if(m2_in_progress) begin
  if(M2_ADDRESSED_S1)
   m2_wb_err_o <= s1_wb_err_i;
  else if(M2_ADDRESSED_S2)
   m2_wb_err_o <= s2_wb_err_i;
  end
  else if(m2_wb_cyc_i & m2_wb_stb_i & ~M2_ADDRESSED_S1 & ~M2_ADDRESSED_S2)
  m2_wb_err_o <= 1'b1;
  else
```

```
m2_wb_err_o <= 1'b0;
```

end

```
assign m_wb_access_finished = m1_wb_ack_o | m1_wb_err_o | m2_wb_ack_o | m2_wb_err_o;
```

```
// Activity monitor
/* Ill
integer cnt;
always @ (posedge wb_clk_i or posedge wb_rst_i)
begin
if(wb_rst_i)
cnt <=#Tp 0;
else
if(s1_wb_ack_i | s1_wb_err_i | s2_wb_ack_i | s2_wb_err_i)
cnt <=#Tp 0;
else
if(s1_wb_cyc_o | s2_wb_cyc_o)</pre>
```

```
cnt <=#Tp cnt+1;</pre>
end
 always @ (posedge wb_clk_i)
 begin
 if(cnt==1000) begin
 $display("(%0t)(%m) ERROR: WB activity ??? ", $time);
 if(s1_wb_cyc_o) begin
 display("s1_wb_dat_o = 0x\%0x", s1_wb_dat_o);
 $display("s1_wb_adr_o = 0x%0x", s1_wb_adr_o);
 $display("s1_wb_sel_o = 0x%0x", s1_wb_sel_o);
 $display("s1_wb_we_o = 0x%0x", s1_wb_we_o);
 end
 else if(s2_wb_cyc_o) begin
 display("s2_wb_dat_o = 0x\%0x", s2_wb_dat_o);
 display(s_wb_adr_o = 0x\%0x, s_wb_adr_o);
 $display("s2_wb_sel_o = 0x%0x", s2_wb_sel_o);
 display("s2_wb_we_o = 0x\%0x", s2_wb_we_o);
 end
 $stop;
end
end
 always @ (posedge wb_clk_i)
 begin
 if(s1_wb_err_i & s1_wb_cyc_o) begin
 $display("(%0t) ERROR: WB cycle finished with error acknowledge ", $time);
 display("s1_wb_dat_o = 0x\%0x", s1_wb_dat_o);
 $display("s1_wb_adr_o = 0x%0x", s1_wb_adr_o);
```

\$display("s1\_wb\_sel\_o = 0x%0x", s1\_wb\_sel\_o);

```
$display("s1_wb_we_o = 0x%0x", s1_wb_we_o);
```

\$stop;

end

if(s2\_wb\_err\_i & s2\_wb\_cyc\_o) begin

\$display("(%0t) ERROR: WB cycle finished with error acknowledge ", \$time);

```
$display("s2_wb_dat_o = 0x%0x", s2_wb_dat_o);
$display("s2_wb_adr_o = 0x%0x", s2_wb_adr_o);
$display("s2_wb_sel_o = 0x%0x", s2_wb_sel_o);
$display("s2_wb_we_o = 0x%0x", s2_wb_we_o);
$stop;
end
end
```

\*/

endmodule

#### C.6. eth\_defines.v

`define ETH\_MODER\_ADR 8'h0 // 0x0 `define ETH\_INT\_SOURCE\_ADR 8'h1 // 0x4 `define ETH\_INT\_MASK\_ADR 8'h2 // 0x8 `define ETH\_IPGT\_ADR 8'h3 // 0xC `define ETH\_IPGR1\_ADR 8'h4 // 0x10 `define ETH\_IPGR2\_ADR 8'h5 // 0x14 `define ETH\_PACKETLEN\_ADR 8'h6 // 0x18 `define ETH\_COLLCONF\_ADR 8'h7 // 0x1C `define ETH\_TX\_BD\_NUM\_ADR 8'h8 // 0x20 `define ETH\_CTRLMODER\_ADR 8'h9 // 0x24 `define ETH\_MIIMODER\_ADR 8'hA // 0x28 `define ETH\_MIICOMMAND\_ADR 8'hB // 0x2C `define ETH\_MIIADDRESS\_ADR 8'hC // 0x30 `define ETH\_MIITX\_DATA\_ADR 8'hD // 0x34 `define ETH\_MIIRX\_DATA\_ADR 8'hE // 0x38 `define ETH\_MIISTATUS\_ADR 8'hF // 0x3C `define ETH\_MAC\_ADDR0\_ADR 8'h10 // 0x40 `define ETH\_MAC\_ADDR1\_ADR 8'h11 // 0x44 `define ETH\_HASH0\_ADR 8'h12 // 0x48 `define ETH\_HASH1\_ADR 8'h13 // 0x4C `define ETH\_TX\_CTRL\_ADR 8'h14 // 0x50 `define ETH\_RX\_CTRL\_ADR 8'h15 // 0x54

`define ETH\_MODER\_DEF\_0 8'h00 `define ETH\_MODER\_DEF\_1 8'hA0 `define ETH\_MODER\_DEF\_2 1'h0 `define ETH\_INT\_MASK\_DEF\_0 7'h0 `define ETH\_IPGT\_DEF\_0 7'h12 `define ETH\_IPGR1\_DEF\_0 7'h0C `define ETH\_IPGR2\_DEF\_0 7'h12 `define ETH\_PACKETLEN\_DEF\_0 8'h00 `define ETH\_PACKETLEN\_DEF\_1 8'h06 `define ETH\_PACKETLEN\_DEF\_2 8'h40 `define ETH\_PACKETLEN\_DEF\_3 8'h00 `define ETH\_COLLCONF\_DEF\_0 6'h3f `define ETH\_COLLCONF\_DEF\_2 4'hF `define ETH\_TX\_BD\_NUM\_DEF\_0 8'h40 `define ETH\_CTRLMODER\_DEF\_0 3'h0 `define ETH\_MIIMODER\_DEF\_0 8'h64 `define ETH\_MIIMODER\_DEF\_1 1'h0 `define ETH\_MIIADDRESS\_DEF\_0 5'h00 `define ETH\_MIIADDRESS\_DEF\_1 5'h00 `define ETH\_MIITX\_DATA\_DEF\_0 8'h00 `define ETH\_MIITX\_DATA\_DEF\_1 8'h00 `define ETH\_MIIRX\_DATA\_DEF 16'h0000 // not written from WB `define ETH\_MAC\_ADDR0\_DEF\_0 8'h00 `define ETH\_MAC\_ADDR0\_DEF\_1 8'h00 `define ETH\_MAC\_ADDR0\_DEF\_2 8'h00 `define ETH\_MAC\_ADDR0\_DEF\_3 8'h00 `define ETH\_MAC\_ADDR1\_DEF\_0 8'h00 `define ETH\_MAC\_ADDR1\_DEF\_1 8'h00 `define ETH\_HASH0\_DEF\_0 8'h00 `define ETH\_HASH0\_DEF\_1 8'h00 `define ETH\_HASH0\_DEF\_2 8'h00 `define ETH\_HASH0\_DEF\_3 8'h00 `define ETH\_HASH1\_DEF\_0 8'h00 `define ETH\_HASH1\_DEF\_1 8'h00 `define ETH\_HASH1\_DEF\_2 8'h00

`define ETH\_HASH1\_DEF\_38'h00`define ETH\_TX\_CTRL\_DEF\_08'h00`define ETH\_TX\_CTRL\_DEF\_18'h00`define ETH\_TX\_CTRL\_DEF\_21'h0`define ETH\_RX\_CTRL\_DEF\_08'h00`define ETH\_RX\_CTRL\_DEF\_18'h00

`define ETH\_MODER\_WIDTH\_0 8 `define ETH\_MODER\_WIDTH\_1 8 `define ETH\_MODER\_WIDTH\_2 1 `define ETH\_INT\_SOURCE\_WIDTH\_0 7 `define ETH\_INT\_MASK\_WIDTH\_0 7 `define ETH\_IPGT\_WIDTH\_0 7 `define ETH\_IPGR1\_WIDTH\_0 7 `define ETH\_IPGR2\_WIDTH\_0 7 `define ETH\_PACKETLEN\_WIDTH\_0 8 `define ETH\_PACKETLEN\_WIDTH\_1 8 `define ETH\_PACKETLEN\_WIDTH\_2 8 `define ETH\_PACKETLEN\_WIDTH\_3 8 `define ETH\_COLLCONF\_WIDTH\_0 6 `define ETH\_COLLCONF\_WIDTH\_2 4 `define ETH\_TX\_BD\_NUM\_WIDTH\_0 8 `define ETH\_CTRLMODER\_WIDTH\_0 3 `define ETH\_MIIMODER\_WIDTH\_0 8 `define ETH\_MIIMODER\_WIDTH\_1 1 `define ETH\_MIICOMMAND\_WIDTH\_0 3 `define ETH\_MIIADDRESS\_WIDTH\_0 5 `define ETH\_MIIADDRESS\_WIDTH\_1 5 `define ETH\_MIITX\_DATA\_WIDTH\_0 8 `define ETH\_MIITX\_DATA\_WIDTH\_1 8 `define ETH\_MIIRX\_DATA\_WIDTH 16 // not written from WB `define ETH\_MIISTATUS\_WIDTH 3 // not written from WB `define ETH\_MAC\_ADDR0\_WIDTH\_0 8 `define ETH\_MAC\_ADDR0\_WIDTH\_1 8 `define ETH\_MAC\_ADDR0\_WIDTH\_2 8 `define ETH\_MAC\_ADDR0\_WIDTH\_3 8

`define ETH\_MAC\_ADDR1\_WIDTH\_0 8

`define ETH\_MAC\_ADDR1\_WIDTH\_1 8

8

- `define ETH\_HASH0\_WIDTH\_0
- `define ETH\_HASH0\_WIDTH\_1 8
- `define ETH\_HASH0\_WIDTH\_2 8
- `define ETH\_HASH0\_WIDTH\_3 8
- `define ETH\_HASH1\_WIDTH\_0 8
- `define ETH\_HASH1\_WIDTH\_1 8
- `define ETH\_HASH1\_WIDTH\_2 8
- `define ETH\_HASH1\_WIDTH\_3 8
- `define ETH\_TX\_CTRL\_WIDTH\_0 8
- `define ETH\_TX\_CTRL\_WIDTH\_1 8
- `define ETH\_TX\_CTRL\_WIDTH\_2 1
- `define ETH\_RX\_CTRL\_WIDTH\_0 8
- `define ETH\_RX\_CTRL\_WIDTH\_1 8

// Outputs are registered (uncomment when needed)
`define ETH\_REGISTERED\_OUTPUTS

// Settings for TX FIFO
 `define ETH\_TX\_FIFO\_CNT\_WIDTH 5
 `define ETH\_TX\_FIFO\_DEPTH 16
 `define ETH\_TX\_FIFO\_DATA\_WIDTH 32

// Settings for RX FIFO
 `define ETH\_RX\_FIFO\_CNT\_WIDTH 5
 `define ETH\_RX\_FIFO\_DEPTH 16
 `define ETH\_RX\_FIFO\_DATA\_WIDTH 32

// Burst length
`define ETH\_BURST\_LENGTH 4 // Change also ETH\_BURST\_CNT\_WIDTH
`define ETH\_BURST\_CNT\_WIDTH 3 // The counter must be width enough to count to
ETH\_BURST\_LENGTH

// WISHBONE interface is Revision B3 compliant (uncomment when needed)
//`define ETH\_WISHBONE\_B3

```
// Following defines are needed when eth_cop.v is used. Otherwise they may be deleted.
`define ETH_BASE
                      32'hd0000000
`define ETH_WIDTH
                       32'h800
`define ETH_MEMORY_BASE
                            32'h2000 // renamed for conflict
`define ETH_MEMORY_WIDTH 32'h30000// renamed for conflict
/*
`define MEMORY_BASE
                         32'h2000
`define MEMORY_WIDTH
                           32'h10000
*/
/* Apparently the ISE is not able to do the double translation:
`define M1_ADDRESSED_S1 ( (m1_wb_adr_i >= `ETH_BASE) & (m1_wb_adr_i < (`ETH_BASE + `ETH_WIDTH
)))
`define M1_ADDRESSED_S2 ( (m1_wb_adr_i >= `MEMORY_BASE) & (m1_wb_adr_i < (`MEMORY_BASE +
`MEMORY_WIDTH)) )
`define M2_ADDRESSED_S1 ( (m2_wb_adr_i >= `ETH_BASE) & (m2_wb_adr_i < (`ETH_BASE + `ETH_WIDTH
)))
`define M2_ADDRESSED_S2 ( (m2_wb_adr_i >= `MEMORY_BASE) & (m2_wb_adr_i < (`MEMORY_BASE +
`MEMORY_WIDTH)) )
*/
```

// Previous defines are only needed for eth\_cop.v