# **MOBILE VIDEO SURVEILLANCE**



By

NC Zainab Khalid NC Zunaira Sajjad NC Samoona Aslam NC Jovaria Maqsood

Project Supervisor Lec Intisar Rizwan-i-Haque

Submitted to the Faculty of Electrical Engineering, Military College of Signals National University of Sciences and Technology, Rawalpindi in partial fulfillment for the requirements of a B.E. Degree in Electrical (Telecommunication) Engineering JUNE 2014

## ABSTRACT

### MOBILE VIDEO SURVEILLANCE

Surveillance systems have been going through an era of development. This has been mainly because of the increasing need of security. Real-time surveillance has gained rising popularity due to their automatic surveillance and security actions. This mobile video surveillance is a real time intelligent system based on FPGA (Field Programmable Gate Array). It provides the functionality of monitoring, security and control in order to improve efficiency of security system with respect to timing constraints. There are two units of the system: the first being FPGA which is connected with motion sensors, IP camera and GPRS/GSM module and the second unit is the mobile phone. Sensors monitor the target area including the entrance as well as windows. The video of the target area is continuously captured by the IP camera. In case of any abnormal situation, alarm messages are sent to the user's mobile through GPRS/GSM module. The video is then transmitted to the user through Wi-Fi module. The user also has the option to arm/disarm the system.

## DECLARATION

No portion of the work presented in this dissertation has been submitted in support of another award or qualification either at this institution or at elsewhere.

Copyright by Zainab Khalid Zunaira Sajjad Samoona Aslam Jovaria Maqsood

## **DEDICATION**

In the name of Allah, the Most Merciful, the Most Beneficent.

To our parents, without whose constant support and unstinting cooperation and assistance a work of this magnitude would not have been possible.

## ACKNOWLEDGEMENTS

All praises for Allah Almighty who gave us the strength to accomplish this mighty task despite numerous difficulties and hardships on our way.

We offer our utmost gratitude to our Supervisor, Lec Intisar Rizwan-i-Haque for his constant guidance and encouragement. He gave us hope and boosted up our confidence during the tough phases of our project. The project wouldn't have been possible without his expert advice, unfailing patience and invaluable efforts.

We are also grateful to our parents and family for their admirable support and last but not the least, our auspicious university for making us what we are today.

# **Table of Contents**

| Chapter                                              | Page no. |
|------------------------------------------------------|----------|
| Chapter 1: Introduction                              | 1        |
| 1.1. Project Overview                                | 1        |
| 1.2. Problem Statement                               | 1        |
| 1.3. Project Scope                                   | 1        |
| 1.4. Objectives                                      | 2        |
| 1.5. Deliverables                                    | 2        |
| 1.6. Conclusion                                      | 2        |
| Chapter 2: Literature Review                         | 3        |
| 2.1. Surveillance                                    |          |
| 2.2. Video Surveillance                              |          |
| 2.3. FPGA                                            | 4        |
| 2.4. Verilog                                         | 5        |
| 2.5. IP Cores                                        | 5        |
| 2.6. Virtex-6 embedded tri-mode Ethernet MAC wrapper | б        |
| 2.7. Conclusion                                      | 6        |
| Chapter 3: Technological Requirements                | 7        |
| 3.1. Hardware Requirements                           |          |
| 3.1.1. Virtex-6 XC6VLX240T-1FFG1156                  |          |

| 3.1.2. SIM900 Module                 |
|--------------------------------------|
| 3.1.3. IP Camera                     |
| 3.1.4. Laptop and Mobile phone       |
| 3.1.5. Wi-Fi Router                  |
| 3.1.6. Switch                        |
| 3.1.7. Motion Sensor                 |
| 3.2. Software Requirements           |
| 3.2.1. Xilinx ISE Design suite       |
| 3.2.2. iSpy                          |
| 3.2.3. IP cam viewer                 |
| 3.2.4. Wireshark                     |
| 3.2.5. Docklight                     |
| 3.3. Conclusion                      |
| Chapter 4: Design and Development 17 |
| 4.1. System Overview                 |
| 4.1.1. System Block Diagram          |
| 4.2. Operating Frequencies           |
| 4.3. Hardware Integration            |
| 4.3.1. Interfacing Motion Sensor     |
| 4.3.2. GSM Module                    |

| 4.3.3. Ethernet                                    |
|----------------------------------------------------|
| 4.4. Video Storage                                 |
| 4.4.1. Camera Settings                             |
| 4.4.2. Video Storage On Detection                  |
| 4.4.3. Assigned Directory                          |
| 4.5. Conclusion                                    |
| Chapter 5: Project Analysis and Evaluation 32      |
| 5.1. Top Module                                    |
| 5.2. GSM Command Transmitter Module                |
| 5.3. GSM Command Receiver Module                   |
| 5.4. GSM Interfacing Module                        |
| 5.5. Ethernet Core Generation                      |
| 5.5.1. Ethernet Module-Eth 0 (Copper Interface) 40 |
| 5.5.2. SFP Module Eth1 (Optical Interface)         |
| 5.6. Conclusion                                    |
| Chapter 6: Future Work and Conclusion46            |
| 6.1. Future Work                                   |
| 6.1.1. H.264 Video Compression                     |
| 6.1.2. Encryption and Decryption of Video          |
| 6.1.3. Face detection and fingerprint algorithms   |

| 6.1.4. Object Classification         |    |
|--------------------------------------|----|
| 6.1.5. Increase in the coverage area |    |
| 6.2. Conclusion                      |    |
| Chapter 7: Bibliography              | 50 |
| APPENDIX A-1                         | 51 |
| APPENDIX A-2                         | 59 |
| APPENDIX A-3                         | 64 |
| APPENDIX A-4                         | 76 |

## LIST OF TABLES

| Table                                                            | Page no. |
|------------------------------------------------------------------|----------|
| Table 3-1: Features of Virtex-6 XC6VLX240T-1FFG1156              | 9        |
| Table 4-1: Operating frequencies                                 |          |
| Table 4-2: Sensor pin assignment on FPGA                         |          |
| Table 4-3: SIM900 module and FPGA interfacing                    |          |
| Table 4-4: Communication between FPGA and user via SIM900 module |          |
| Table 4-5: Number of bits for frame                              |          |
| Table 5-1: Top module design summary                             |          |

## LIST OF FIGURES

| Figure                                              | Page no. |
|-----------------------------------------------------|----------|
| Figure 3-1: Breakdown of technological requirements | 7        |
| Figure 3-2: Block diagram of Virtex-6               |          |
| Figure 3-3: Virtex-6 board                          | 9        |
| Figure 3-4: SIM900 module                           | 11       |
| Figure 3-5: IP camera                               | 11       |
| Figure 3-6: Live video transmission on mobile phone |          |
| Figure 3-7: Motion sensor                           | 13       |
| Figure 4-1: System layout                           |          |
| Figure 4-2: System block diagram                    |          |
| Figure 4-3: GSM module                              |          |
| Figure 4-4: System interfacing                      |          |
| Figure 4-5: FPGA interfacing with FPGA and router   |          |
| Figure 4-6: Frame processing                        |          |
| Figure 4-7: Camera settings                         |          |
| Figure 4-8: Video storage on detection              |          |
| Figure 4-9: Stored clips in software                |          |
| Figure 5-1: Top module                              |          |
| Figure 5-2: Top module design in Xilinx             |          |
| Figure 5-3: GSM command transmitter module          |          |
| Figure 5-4: GSM command receiver module             | 35       |
| Figure 5-5: GSM interfacing module                  |          |

| Figure 5-6: RTL schemeatic of Top module | . 39 |
|------------------------------------------|------|
| Figure 5-7: Ethernet core generation     | . 41 |
| Figure 5-8: BANK33                       | . 42 |
| Figure 5-9: SFP module core generation   | . 43 |
| Figure 5-10: BANK 116                    | . 44 |
| Figure 6-1: Video coding                 | . 47 |

## LIST OF ABBREVIATIONS

| ACE   | Advanced Configuration Environment      |  |
|-------|-----------------------------------------|--|
| AVI   | Audio Video Interleaved                 |  |
| BPI   | Byte Peripheral Interface               |  |
| CF    | Compact Flash                           |  |
| CCTV  | Closed-circuit television               |  |
| CMOS  | Complementary metal-oxide-semiconductor |  |
| CAT 5 | Category 5                              |  |
| DDR3  | Double Data Rate Type Three             |  |
| FPGA  | Field-programmable gate array           |  |
| GPIO  | General-Purpose Input/Output            |  |
| GPRS  | General packet radio service            |  |
| GMII  | Gigabit Media Independent Interface     |  |
| HDL   | Hardware description language           |  |
| I/O   | Input/output                            |  |
| IP    | Internet Protocol                       |  |
| IR    | Infrared                                |  |
| JTAG  | Joint Test Action Group                 |  |
| JPEG  | Joint Photographic Experts Group        |  |
| LED   | Light Emitting Diode                    |  |
| LCD   | Liquid Crystal Display                  |  |
| MAC   | Media Access Control                    |  |
| M2M   | Machine-to-Machine                      |  |

| MJPEG  | Motion Joint Photographic Experts Group     |  |
|--------|---------------------------------------------|--|
| РНҮ    | Physical Layer                              |  |
| PCS    | Physical Coding Sub-Layer                   |  |
| PMA    | Physical Media Access                       |  |
| RGMI   | Reduced Media Independent Interface         |  |
| RTL    | Register Transfer Level                     |  |
| SODIMM | Small Outline Dual In-Line Memory Module    |  |
| SMA    | SubMiniature Version A                      |  |
| SGMII  | Serial Gigabit Media Independent Interface  |  |
| SFP    | Small Form-Factor Pluggable                 |  |
| ТСР    | Transport Control Protocol                  |  |
| USB    | Universal Serial Bus                        |  |
| UART   | Universal Asynchronous Receiver/Transmitter |  |
| UCF    | User Constraint File                        |  |
| VGA    | Video Graphics Array                        |  |
| Wi-Fi  | Wireless Fidelity                           |  |

# Chapter 1: Introduction

This chapter will give a brief description of the design and will explain why there was a need to develop an effective anti-theft system. It will then explain the objectives, scope and deliverables of the project.

## 1.1. Project Overview

This mobile video surveillance system is a real time intelligent system based on FPGA. It provides the functionality of monitoring, security and control with the help of IP camera, motion sensor and GPRS/GSM module.

### **1.2. Problem Statement**

In light of the worsening crime situations, the need for efficient security system has increased. People lead busy lives, come in and out of work, go on vacations, and run errands so they need to access a live view of their security cameras when they are away from their home or business. Thus, most of the time one is not actually able to be on the site where cameras are installed. Therefore, a real time mobile video surveillance system based on FPGA has been designed. One of the primary benefits of this system is that the user can view the target area on his mobile anywhere provided that there is internet access.

### **1.3. Project Scope**

The surveillance system can serve as a handy tool for monitoring indoor environment. The intruder can be detected within a range of 12m.

## **1.4. Objectives**

The objective is to design an efficient security system using FPGA. Due to the increasing threats people want security systems that can warn them instantly and provide them access to the live video of the target area even if they are not on the site (where the camera is installed). The following user requirements form the target objectives of our project:

- Reception of alarm messages on mobile phone in case of an intrusion that detected by motion sensor
- Knowledge of the location through which the intruder has entered
- Access to the video through internet
- Video can be monitored remotely through mobile
- Backup storage

## **1.5. Deliverables**

The end goal is to have an embedded real time interactive video transmission and control system to meet the actual needs for home security, monitoring the target area remotely, and to prevent car-theft.

## 1.6. Conclusion

Mobile video surveillance is an intelligent security system which has the functionality of providing access to the video of the target area remotely to the user.

# Chapter 2: Literature Review

This chapter will include the literature review conducted from the start of the project and will give brief description of the important concepts related to the project.

Throughout the project, literature review was an ongoing process. In order to gain more knowledge and learn the necessary skills required to complete this project, it was very essential to refer to the variety of sources.

#### 2.1. Surveillance

To monitor the activities, changing information and behavior, mostly regarding people is surveillance. Usually government organizations observe a a particular suspected group or individuals.

#### 2.2. Video Surveillance

Over the years, video surveillance has been a well-known security tool since it allows the user to monitor the target area remotely. Due to advancement in technology, security cameras have shown a great deal of improvement. It is a commonly deployed surveillance technique in contrast to the other types of surveillance. Banks, offices, markets and others are highly dependent on these effective surveillance systems.

CCTV (Closed Circuit Television) analog systems were used in the past, they can be expensive because they require constant maintenance. Cost effective, simple to operate and flexibility are some praise worthy features of digital technology. In order to match user's specific needs, Security systems deploying IP (Internet Protocol) cameras are a good option since they are easy to install and maintain.

### **2.3. FPGA**

FPGA stands for "Field Programmable Gate Array". FPGA essentially is a huge array of gates, which can be programmed and reconfigured anytime anywhere. FPGAs are manufactured by companies like Xilinx, Altera, Actel etc. We implemented different tutorials on Spartan-3E regarding VGA, LCD display, instantiation etc initially. [1]

For basic understanding of FPGA some tutorials were implemented using Spartan 3-E Starter Kit. The software used was Xilinx ISE 12.3. Brief description of these tutorials is given below:

- Simple introductory project: This tutorial consisted of two parts. The first was linked to the design of the program and circuit implementation. The second step was the test bench simulation in order to test the project. The results were simulated by giving the inputs and observing the outputs. [2]
- Multiple instantiations of same component: In this tutorial, a single component was created and simulated. Replicating the components three times was another task.
   [3]
- **IP cores:** In order to incorporate an IP core into the project, it was learnt how to use Xilinx's CORE Generator System by creating a multiplier. [4]
- Image generation on the Digilent Spartan 3-E board: In this tutorial, images were generated on the VGA (Video Graphics Array) monitors by implementing a VGA

controller. An encryption algorithm was written to show this implementation. To display the video on the screen of the monitor, VGA display port was used. [5]

• Serial RS-232: RS-232 port was used control the frequency of a simple 4-bit counter using hyperterminal in which five different frequencies were used. A laptop was connected with an FPGA kit using available RS-232 port on the board. [6]

### 2.4. Verilog

The hardware designers in industry and academia use Verilog as one of the major Hardware Description Languages (HDL). The second one being VHDL. It is easier to learn Verilog as compared to VHDL. Verilog HDL uses four different levels of abstraction including architectural or behavioral level as well as gate and switch levels. Three important levels of abstractions are as follows:

- **Behavioral Level**: Concurrent algorithms are used to describe this level. There are a set of instructions which are executed sequentially. Main elements include functions, tasks and always block.
- **Register-Transfer Level:** Transfer of data between the registers and characteristics of circuits by operations are specified by register transfer level.
- Gate Level: Logical links and timing properties describe the characteristics of the system. Discrete Signals can have definite logic values. [7]

### 2.5. IP Cores

Xilinx Targeted Design Platforms key building blocks consist of Intellectual Property (IP) cores. To easily create Plug-and-Play IP, Xilinx FPGA tools and designs play an important role. The market and general specific needs of the end users can easily be met with the help of an extensive catalog of cores. This provides with a competitive advantage. [8]

## 2.6. Virtex-6 embedded tri-mode Ethernet MAC wrapper

For the generation of HDL wrapper files for the Ethernet core in Virtex-6, the CORE Generator Virtex-6 Embedded Tri-mode Ethernet Media Access Controller (MAC) Wrapper is used. Depending on the user requirements, simulation scripts, HDL wrappers and test benches are generated automatically through core generation functionality of Xilinx ISE. Its striking features include:

- A physical interface that is user configurable
- The connection between the PHY and Ethernet MAC is simplified
- SGMII or 1000base-X interfaces with single bit stream
- 2.5 Gbps as the upper limit for 1000base-X interface
- In GMII/MII or RGMII modes, Clock Enable inputs are available

#### 2.7. Conclusion

The literature review carried out was mainly focused on the tutorials performed on Spartan-3E starter kit, learning Verilog, features of Virtex-6 and learning about various components used in the project for e.g. IP camera, motion sensors etc.

# **Chapter 3: Technological Requirements**

This chapter will provide a brief overview of the technological requirements for the project "Mobile video surveillance".

Mobile Video Surveillance provides three functionalities i.e. monitoring, security and control. For monitoring purposes, an IP camera is required to be interfaced with FPGA kit. A Wi-Fi router is required so that the captured video can be viewed anywhere on the mobile phone provided that there is internet access.

For storage purposes, a backup is required which can save the video clip whenever an intruder is detected so that incase the user didn't view the message or was unable to view the video, he can still view the video clip later through backup.

The technological requirements are sub-divided into hardware and software and are discussed in the following sub-sections. Figure 3-1 shows valid breakdown of Technological Requirements.



Figure 3-1: Break down of technological requirements

## **3.1. Hardware Requirements**

The Hardware required for the implementation of the project includes:

### 3.1.1. Virtex-6 XC6VLX240T-1FFG1156

Virtex-6 board was selected because two Ethernet ports were required for the project. As it can be seen in Figure 3-3 that virtex-6 comprises of both these ports.



Figure 3-2: Block diagram of Virtex-6



Figure 3-3: Virtex-6 board

Few important features of this board are discussed in Table 3-1.

| No. | Feature                       | Notes                          |
|-----|-------------------------------|--------------------------------|
| 1   | FPGA Virtex-6                 | XC6VLX240T-1FFG1156            |
| 2   | DDR3 SODIMM                   | Micron 512 MB MT4JSF6464HY-1G1 |
| 3   | 128 MB Platform Flash         | Xilinx XCF128X-FTG64C          |
| 4   | Linear BPI Flash              | Numonyx JS28F256P30T95         |
| 5   | System ACE CF Controller      | Xilinx XCCACE-TQ1441           |
|     |                               | (bottom of board)              |
| 6   | JTAG Cable Connector (        | USB JTAG circuit               |
|     | USB Mini-B)                   |                                |
|     | Clock generation              | 200 MHz OSC, SMA connectors    |
|     | a. 200 MHz oscillator (on     | siTime 200 MHz 2.5V LVDS OSC   |
|     | backside)                     |                                |
| 7   | b. oscillator socket, single- | MMD Components 66 MHz 2.5 V    |
|     | ended                         |                                |
|     | c. SMA connectors             | SMA pair                       |

|    | d. MGT REFCLK SMA            | SMA pair                                 |
|----|------------------------------|------------------------------------------|
|    | connectors                   |                                          |
| 8  | SFP connector                | AMP 136073-1                             |
| 9  | Ethernet (10/100/1000) with  | Marvel M88E1111 EPHY                     |
|    | SGMII                        |                                          |
| 10 | USB Mini-B, USB-to-UART      | Silicon Labs CP2103GM bridge             |
| 11 | USB-A Host, USB Mini-B       | Cypress CY7C67300-100AXI                 |
|    | peripheral connectors        |                                          |
| 12 | Video- DVI connector         | Chrontel CH7301C-TF codec                |
|    | Status LEDs                  |                                          |
| 13 | a. Ethernet status           | Right-angle link rate and direction LEDs |
|    | b. FPGA INIT, DONE           | Init (red), done (green)                 |
|    | c. system ACECF status       | Status (green), Error (red)              |
|    | User I/O                     |                                          |
|    | a. User LEDs, green(8)       | User I/O (active-High)                   |
|    | b. User pushbuttons, N.O.    | User I/O (active-High)                   |
|    | momentary (5)                |                                          |
| 14 | c. User LEDs, green (5)      | User I/O (active-High)                   |
|    | d. User DIP switch (8-pole)  | User I/O (active-High)                   |
|    | e. User GPIO SMA             | SMA pair                                 |
|    | connectors                   |                                          |
|    | f. LCD 16 Character x 2 line | Displaytech S162D BA BC                  |
|    | display                      |                                          |
|    | Switches                     |                                          |
|    | a. Power ON/OFF              | Slide switch                             |
|    | b. FPGA –PROG- B Push        | Active-low                               |
| 15 | button                       |                                          |

#### 3.1.2. SIM900 Module

SIM900 Module works on a number of frequencies including 850 MHz, 900 MHz, 1800 MHz and 1900 MHz. To use as plug in GSM modem is really easy to use and portable. The PC Serial port can be directly connected with the RS232 Level converter on the modem. The AT commands can be used to configure the baud rate where by initially it is in Auto baud mode. To enable the user to connect with internet via GPRS, the GSM/GPRS RS232 modem has an internal TCP/IP stack. It can be used for data transfer as well as SMS applications.



Figure 3-4: SIM900 module

#### 3.1.3. IP Camera

IP camera used provides Day/Night high-resolution image. The Compression format used is Motion-JPEG. Its resolution is CMOS 300,000 pixels. Pan Horizontal rotation is 0-270° whereas tilt vertical rotation is 0-90°. Its range is up to 10m. Multiple users can access it at the same time and it can be protected with the help of a password.



Figure 3-5: IP camera

### 3.1.4. Laptop and Mobile phone

Laptops are required to create backup storage. In case the user doesn't has internet access and is unable to receive live transmission of video, he still can watch the video clip later through backup storage. Mobile phone is required to view the video captured by the IP camera.



Figure 3-6: Live video transmission on mobile phone

### 3.1.5. Wi-Fi Router

Wi-Fi router is needed to assist wireless video transmission on mobile phone. The user can monitor his home even when he is far away.

## 3.1.6. Switch

The TP-LINK with 5 ports can be used as a switch to covert to Gigabit Ethernet.

### **3.1.6.1.** Features

- Five 10/100/1000Mbps RJ-45 port
- Auto-Negotiation, Auto MDI/MDIX, Half/Full duplex
- IEEE 802.3 flow control
- Plug and play
- 15K jumbo frame

## 3.1.7. Motion Sensor

Motion sensors are deployed at multiple locations like windows, doors etc. on a single site. The model required for the project is HVR-SA 1200. It can easily detect movement

within an area of 40 feet with a detection angle of 180°. Its sensitivity can be increased and decreased according to the requirements of the user. Day/night settings can also be adjusted.



Figure 3-7: Motion sensor

## **3.2. Software Requirements**

The software(s) required for the implementation of the project includes:

### 3.2.1. Xilinx ISE Design suite

Xilinx ISE 13.4 was used for the coding of the design. Xilinx has produced Xilinx ISE (Integrated Software Environment) software tool that is used for synthesis and analysis of HDL designs that enables the developer the following:

- The design can be synthesized
- Timing analysis can be performed
- Register-transfer level diagrams examination
- A design's reaction to different stimuli can be simulated

• The programmer can configure the target device

#### 3.2.2. iSpy

The libraries and programs needed for handling multimedia data are provided by iSpy connect which is open source software. To detect and record movement or sound and provides features of monitoring, alerting, surveillance, and security, iSpy uses webcams and microphones. All the captured media is made available securely over the web. It can be run on many computers together [9]. Following are the functions that it performs:

- When motion is detected it automatically captures images
- Motion detection trigger level that is adjustable
- 99 cameras can be supported
- Capability of DVR card
- Capability of multiplexing
- Sensitivity level of image can be adjusted
- Image Archiving (1,000s of images)

#### 3.2.3. IP cam viewer

Real time video from IP or USB cameras can be viewed on mobile phone by using IP Camera Viewer. Wherever security is required, any USB or IP camera can be used, be it your home, office or parking area.

Up to 4 camera feeds can be controlled by the user simultaneously. By using this lightweight application, the user can get a live preview from multiple cameras. By using

centralized camera and layout management, the user can view cameras from multiple remote locations on a single screen. To cater the security needs, the user can change the arrangement and preview layout of the cameras. [10]

The orientation of camera preview can also be adjusted. By supporting many PTZ (Pan/Tilt/Zoom) enabled network cameras, it helps in adjusting the coverage area. IP Camera Viewer provides an additional functionality of digital zoom irrespective of the fact whether it is supported or not.

#### 3.2.4. Wireshark

This software is an open-source and free packet analyzer. Analysis, communications protocol development, network trouble shooting are some of its features [11].

It understands the encapsulation procedure of different networking protocols. Together with the meanings, it can display the fields and parse as specified by different networking protocols. Following are the features of Wireshark:

- Hundreds of protocols can be inspected
- Can perform offline analysis and live capture
- Three-pane packet browser as the standard
- A Multi-platform software supported on Linux, Windows, Solaris, OS X, netbsd, and FreeBSD
- Display filters that are the most powerful
- Rich VoIP analysis
- Captured gzip compressed files can be decompressed on the fly

 Allows live data reading from IEEE 802.11, PPP/HDLC, Ethernet, Bluetooth, ATM, Ring, Frame Relay, Token, USB and FDDI

## 3.2.5. Docklight

For serial communication protocol, Docklight is an analysis, simulation and testing tool. It can be used for testing the serial communication of a single device and for monitoring the communication between two serial devices. Communications automotive, automation and control, consumer products and equipment manufacturers are some industry areas where productivity can be increased using Docklight. Lastly it is very easy to use.[12]

## **3.3.** Conclusion

The hardware part of the project consists of Virtex-6 kit, SIM900 module, IP camera, motion sensors, switches and router. Xilinx Design Suite 13.4, Docklight, Wireshark and IP cam Viewer are the softwares that were used to carry out different tests.

# Chapter 4: Design and Development

This chapter will provide information regarding the methodology and approach leading to the development of this project.

#### **4.1. System Overview**

There are two units of the system: the first being FPGA which is connected with the sensors and IP camera along with the SIM900 module and the second unit consists of mobile phone. Target area will be monitored by sensors installed at certain locations including the entrance as well as the windows. The video of the target area will be continuously captured by the rotatable IP camera that is connected to the Ethernet port of FPGA via switch. When an intruder will enter, the system will send 'INT AT LOC X' (Intruder at location x) message to the mobile user via SIM900. The user can than view the video of the target area in his mobile phone by providing the correct username and password. In a highly secure place, the number of police station can also be added so in case an intruder enters, the message will be sent to them as well. If the user fails to read the message at that time, the user can view the video later that will be stored using video storage software. The user can also ARM/DISRAM the system. When the user wants to stop the system, he will send a 'DIS' (Disarm) message to FPGA via SIM900.



Figure 4-1: System layout

#### 4.1.1. System Block Diagram

Figure 4-2 shows the system block diagram of Mobile Video Surveillance. The sensor is connected to the FPGA through J62 pins and IP camera is connected to the Ethernet port on FPGA. The SIM900 GPRS/GSM module is also connected to the FPGA kit through J62 pins which acts as the communication medium between the FPGA and the mobile station. By using this unit, information is sent from the FPGA to the mobile station and the instructions are sent from the mobile station to the FPGA. FPGA executes any instruction sent by the user from the mobile station. Any mobile phone that can send and receive messages can be used for this purpose. The instructions that are sent to FPGA and any alert from the FPGA is received in form of a message. The video that is captured through the IP camera is transmitted through Wi-Fi. Wi-Fi device is connected to the switch which is further connected to the SFP port on FPGA.



Figure 4-2: System block diagram

## 4.2. Operating Frequencies

Table 4-1 gives the operating frequencies of various modules of the system.

| Table 4-1: Operating | frequencies |
|----------------------|-------------|
|----------------------|-------------|

| Module                   |               | Operating Frequency |  |
|--------------------------|---------------|---------------------|--|
| Eth 1 (optic             | al interface) | 125 MHz             |  |
| Eth 0 (copper interface) |               | 125 MHz             |  |
| GSM                      | Тх            | 1200 Hz             |  |
|                          | Rx            | 16 x 1200 Hz        |  |

## 4.3. Hardware Integration

The hardware development of Mobile Video Surveillance revolves around Virtex-6 XC6VLX240T-1FFG1156 FPGA. All the modules including motion sensor, SIM900 and IP camera are interfaced with Virtex-6 XC6VLX240T-1FFG1156 FPGA.

#### 4.3.1. Interfacing Motion Sensor

Sensors will be installed at various locations in the target area. When an intruder will enter, the signal will be cut and a message "INT AT LOC X" will be sent from FPGA to the user via SIM900 module. Motion sensors are assigned on the dip switches on FPGA. Their assignment is shown in Table 4-2

| U1 FPGA Pir | Schematic Net | Pin            | Function assigned  |
|-------------|---------------|----------------|--------------------|
| L20         | GPIO_DIP_SW   | DIP Switch Pin | Sensor at location |
|             | 4             | SW1.4          | 1                  |
| L21         | GPIO_DIP_SW   | DIP Switch Pin | Sensor at location |
|             | 3             | SW1.3          | 2                  |

Table 4-2: Sensor pin assignment on FPGA

Schematic Net name is used to search the general purpose input output Dip switch FPGA pin on the schematics. U1 FPGA pin number is used in the UCF (User Constraint File). FPGA pin L20 and L21 are assigned the functionality of sensor at location 1 and location 2. When the Dip switch 4/3 is high indicating that the signal is cut, a message that an intruder has entered from location 1/2 is sent to the user.

#### 4.3.2. GSM Module

GSM command transmitter module is used to send messages. The five commands that are Test connect, Set number, Set text, Send message and Delete all messages are executed sequentially. GSM command receiver module is used to receive messages. The messages that are received by the system are ARM and DISARM. GSM command transmitter and receiver together comprise the GSM interfacing module which is part of the Top module in FPGA design. The top module also includes the Ethernet module and the SFP module.



Figure 4-3: GSM module

## 4.3.2.1. Interfacing SIM900 module



Figure 4-4: System interfacing

J62 pins of FPGA are used to interface SIM900 module with FPGA. The connections are explained in Table 4-3.

| U1 FPGAPin | Schematic Net<br>Name | Pin                               | Controlled LED | Function<br>assigned  |
|------------|-----------------------|-----------------------------------|----------------|-----------------------|
| D22        | GPIO_DIP_SW1          | DIP Switch Pin<br>SW1.1           | _              | SIM900 enable         |
| G26        | GPIO_SW_C             | Pushbutton<br>Switch Pin<br>SW9.2 | _              | Reset                 |
| AC22       | GPIO_LED_0            | GPIO J62 Pin 1                    | D\$12          | SIM900<br>Receiver    |
| AD24       | GPIO_LED_7            | GPIO J62 Pin 8                    | D\$21          | SIM900<br>Transmitter |

The pin D22 is assigned the functionality of enabling SIM900 module. G26 pin resets the system. A wire from pin AC22 (FPGA transmitter) is connected to SIM900 receiver slot. It performs the functionality of transmitting the messages from FPGA to the user. A wire from AD24 (FPGA receiver) is connected to SIM900 transmitter slot. It performs the functionality of receiving the messages from the user to the FPGA.

#### 4.3.2.2. Communication between FPGA and User via SIM900 Module

The SIM900 GPRS/GSM module acts as the communication medium between the FPGA and the mobile station. By using this unit, information is sent from the FPGA to the mobile station and the instructions are sent from the mobile station to the FPGA. This communication is done in form of text messages.

| Action          | Message transmitted | Transmitter | Receiver |
|-----------------|---------------------|-------------|----------|
| System powers   | "POWER"             | FPGA        | User     |
| ON              |                     |             |          |
| When the signal | "INT AT LOC X"      | FPGA        | User     |
| is cut (sensor) |                     |             |          |
| To disable      | "DIS"               | User        | FPGA     |
| transmission of | 215                 | 0501        | man      |
| video           |                     |             |          |
| To enable       | "ARM"               | User        | FPGA     |
| transmission of | ANN                 | 0361        | non      |
| video           |                     |             |          |

Table 4-4: Communication between FPGA and user via SIM900 module

## 4.3.3. Ethernet

IP Camera is used to capture the video of the target area which is connected to Copper interface (Eth 0) of FPGA via switch. The IP camera operates on 100 Mbps. The Copper

interface of FPGA can work on 10/100/1000Mbps but due to its complexity, 1000Mbps have been used, so there was a need to use a switch between the camera and copper interface. A camera with Gbps interface could also be used but due to it's unavailability it was not used. The switch performs auto-negotiation (converts from Mbps (IP camera) to Gbps (FPGA)). This video is then transmitted from optical interface of FPGA to the user via switch.



Figure 4-5: FPGA interfacing with FPGA and router

The following ports will be physically connected through CAT 5 cable with RJ-45 connectors at both the ends.

- IP camera and switch
- Switch and Eth 0 (Copper interface FPGA)
- Eth 1 (Optical interface FPGA) and switch
- Switch and router

#### **4.3.3.1.** Ethernet Core Design and Configuration

Xilinx's Core Generator tool was used to design a Virtex-6 Embedded Tri-mode Ethernet MAC Wrapper to enable the Ethernet ports of FPGA board. The wrapper that we designed through the software was for standard Virtex-6 FPGA board (ML605), therefore it had to be configured according to the FPGA board available, i.e. Virtex 6 (xc6vlx240t, ff1156) to enable its Ethernet ports. Therefore the entire UCF of the project was changed according to the development board. The changes that were made are shown in the Figure 5-6 and 5-8.

Changing the UCF was quite a challenging task. BANK33 and BANK116 were used from schematics of Virtex-6 (ML605) inorder to change the UCF. The following options for the interfaces were used during the core generation in Xilinx ISE 13.4.

#### **Eth0** (copper interface):

- Virtex-6 Tri-Mode Ethernet MAC Wrapper 1.5
- PHY interface: GMII
- BANK 33

#### **Eth1 (Optical interface):**

- Virtex-6 Tri-Mode Ethernet MAC Wrapper 2.2
- PHY interface: 1000BASE X PCS PMA
- BANK 116

4.3.3.2. Frame Processing



Figure 4-6: Frame processing

At the SOF (start of the frame), as shown in the Figure 4-6, the signal gets low for one cycle. As soon as that happens, the src ready signal also gets low and the reception of valid data starts. 'xxxx' indicates invalid data. The data received during the time the source ready signal is low is the valid data. As soon as the signal gets high during one clock cycle, the src ready signals gets high and it indicates that this is the end of frame. Valid data is recieved for a number of cycles and starts when the frame starts and ends when the frame ends.

The bits utilized by each signal are shown in Table 4-5.

| SIGNALS                | BITS |
|------------------------|------|
| SOF (Start of frame)   | 1    |
| EOF (End of frame)     | 1    |
| SRC RDY (Source Ready) | 1    |
| DATA IN (Data Input)   | 8    |

Table 4-5: Number of bits for frame

### 4.4. Video Storage

Being expensive, closed source, lacking a number of features, restricted data usage, poor control over sensitivity and poor audio control are a number of problems that are linked with the current security and surveillance software. Using iSpy you can do pretty much anything, protecting your business and home with an open source software. iSpy is sensitive to movement and sound so it makes an awesome camera security system. Cameras and microphones can be added, configured and monitored- displaying live video and audio from a variety of network sources. You can switch cameras and microphones on or off, trigger recordings, switch on alerts etc. Following are some important features of iSpy:

- When motion is detected it automatically captures images
- Motion detection trigger level that is adjustable
- 99 cameras can be supported

- Capability of DVR card
- Capability of multiplexing
- Sensitivity level of image can be adjusted
- Image Archiving (1000s of images)

In the project, whenever an intruder enters, motion detector which is installed at entrances detects an intruder and sends alarming messages to user with details of the particular location through which the intruder has entered. The user can then view the live video of the target area in his mobile phone. In case the user fails to view the video at that particular time due to some reasons, he can view the video later which is stored using the iSpy software.

The video storage works on 'Record on detect' i.e. whenever some movement is detected, it starts to record the video and it keeps on recording the video until there is no movement. It will record up to 8 seconds after no movement is detected. The duration for which the video is recorded after no movement is detected can be set according to the user's requirement. After that it will stop recording automatically. These settings are done in order to increase the efficiency since there is no use of continuous storage. It is just wastage of space. The video that is recorded is automatically stored in a local directory as per the user's choice.

Initially cameras are added to the software and camera settings are made according to the camera model and user requirement.

### 4.4.1. Camera Settings

In the camera settings, following settings need to be changed:

- Motion detection: Motion detection sensitivity, display style and number of frames processed can be changed
- Alerts: The alert can be enabled on movement or no movement. The alert interval and the action performed upon alert can be set.
- **Recording:** The recording mode whether to detect on movement or without movement and inactivity recording duration can be set.
- **Storage:** By using this option, the user can set the storage directory and the video storage folder size.

| Talk         |             |          |          |
|--------------|-------------|----------|----------|
| Camera Model | None        | •        | Settings |
| IP Address   | 192.168.1.2 | Port     | 81       |
| Usemame      | admin       | Password |          |
|              |             |          |          |

Figure 4-7: Camera settings

### 4.4.2. Video Storage On Detection

When movement is detected, iSpy starts recording the video. Blue rectangles start appearing around the border of any object that is detected. Under no movement condition, no video is recorded.



Figure 4-8: Video storage on detection

The blue boxes in Figure 4-8 shows that it has detected an intruder as explained above and red dot on top right shows recording has started.

## 4.4.3. Assigned Directory

The recorded clips are stored in the local user assigned directory.



Figure 4-9: Stored clips in software

# 4.5. Conclusion

The hardware integration comprises of interfacing SIM900 module, IP camera and motion sensor with FPGA. Video storage has been done using iSpy which is mainly the backup storage.

# Chapter 5: Project Analysis and Evaluation

In this chapter, simulations will be discussed that were used to evaluate the performance of the project design.

## 5.1. Top Module

The top module of the project is composed of three sub modules as shown in Figure 5-1.



Figure 5-1: Top module

Figure 5-2 shows the design of Top module in Xilinx. The algorithm designed for the project was synthesized, implemented and then its programming file was generated using Xilinx's Project Navigator.



Figure 5-2: Top module design in Xilinx

In order to check whether the designed algorithm was valid or not, initially a test bench was created. Inputs for the test bench were defined within the code. The simulator used was Xilinx's simulator version13.4, IS im.



## 5.2. GSM Command Transmitter Module

Figure 5-3: GSM command transmitter module

Figure 5-3 shows the timing diagram of GSM command transmitter module. The input of this module is a go\_signal that indicates the system is ready to start and commands can be executed one by one which is received from the main module. If the state of this signal is 0 then it stays at its initial position but if the state is 1 then the signal passes through the selection function. It can be seen in Figure 5-3 that at the positive edge of din\_rdy i.e when the data is ready to be transmitted, eight bits of din\_byte are transmitted during one cycle. The data is stored in the buffer and most significant eight bits of the data are transmitted during one cycle. When all the data has been transmitted, the din\_rdy signal becomes low indicating that there is no data to be transmitted. c\_state and n\_state indicates the current state and the next state of the state machine respectively. There are five different commands that are executed sequentially following the same procedure.

- **Test connect**: This command makes sure that GSM module is connected to the system.
- Set number: This command sets the number of the mobile user with whom the communication is done to control the system.
- Message: This command sets the message that has to be sent.
- Send message: This command sends the text to the user to let him know about the state of the system.
- Delete all messages: This command deletes all the previous inbox messages.



## **5.3. GSM Command Receiver Module**

Figure 5-4: GSM command receiver module

This module processes the signal received from the SIM900 module. When message is received, it is checked whether the message is valid or not. Receiver mode can have two states. If receive mode equals 1, the message is valid and if it is equal to 0 then the message is not valid. In above case it is an invalid message i.e. it is an update message for the SIM and rx\_mode is 0, it waits for a particular duration to completely process the update info and waits for dout\_rdy to be 1 (indicates that the o/p is ready to be saved in the next stage) otherwise if 0 then receiving of update info continues as can be seen in

simulation. Four message bytes are meant to be received (the simulation shows that four bytes are received) and if they are valid it goes to output. Now in the other case if the output is valid it goes to other stage of the rx\_mode and waits until all the 86 bytes (688 bits) of message have been received. Waiting is done to receive 86 bytes and then this data is saved in the next stage and further processing is done according to the received command.



## **5.4. GSM Interfacing Module**

|                                         |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                | 500000 us                               |        |
|-----------------------------------------|---------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------|
| e                                       | Value         |                                         | 6,700 us                                | 6,800 us                                | 6,900 us                                | 7,000 us                                | 7, 100 us                               | 7,200 us                                            | 7,300 us                                | 7,400 us                                | 7,500 us                                | ,                                                                                                              | 7,600 us                                | 7,700  |
| int_flag                                | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
|                                         | 000           |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| gsm_seria                               |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| -                                       | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| -                                       |               |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| -                                       | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| rx_en                                   | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| timer[26:C                              | 00000000      |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| start                                   | 1             |                                         |                                         |                                         |                                         |                                         |                                         | ******                                              |                                         |                                         |                                         |                                                                                                                |                                         |        |
| ostate[3:                               |               |                                         |                                         |                                         |                                         |                                         | 000                                     | 1                                                   |                                         |                                         |                                         |                                                                                                                |                                         |        |
|                                         | 0001          |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         | +      |
| ew Divider                              | 0001          |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| -                                       | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
|                                         | 1             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         | -      |
| rx_data[6{                              | _<br>00000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000             | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 00000                                                                                                          | 000000000000000000000000000000000000000 | 000000 |
| rx_serial_i                             |               | 000000000000000000000000000000000000000 |                                         |                                         | ,00000000000000000000000000000000000000 |                                         |                                         |                                                     | 000000000000000000000000000000000000000 |                                         | 000000000000000000000000000000000000000 | 00000                                                                                                          | 000000000000000000000000000000000000000 | 000000 |
|                                         |               | ******                                  |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| <u> </u>                                |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| ock_11520                               |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
|                                         | 00000000      |                                         |                                         |                                         |                                         |                                         | 000000000000000000000000000000000000000 | 00000000000                                         |                                         |                                         |                                         |                                                                                                                |                                         |        |
| 22<br>                                  | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| ·                                       | 00000000      |                                         |                                         |                                         |                                         |                                         | 000000                                  |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
|                                         | 0001          |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| · · ·                                   | 0001          |                                         |                                         |                                         |                                         |                                         | 000                                     | 1                                                   |                                         |                                         |                                         |                                                                                                                |                                         |        |
| ew Divider                              |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
|                                         |               | V4 7 570 50000                          |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| timer[14:0                              | 01001011      | X1: 7,570.50000                         | U US                                    | ******                                  | *                                       | 4                                       | *******                                 | *****                                               |                                         | *****                                   | 4                                       | k and the second se |                                         |        |
| clk_11520                               |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         | 00000000                                                                                                       |                                         | ****** |
| start_cou                               |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| count[26:                               |               |                                         |                                         |                                         |                                         |                                         | 000000000000000000000000000000000000000 | d00000000000                                        |                                         |                                         |                                         |                                                                                                                |                                         |        |
| c_state[2:                              |               |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| n_state[2:                              | 000           |                                         |                                         |                                         |                                         |                                         | 000                                     |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| din_byte[                               | 00000000      |                                         |                                         |                                         |                                         |                                         | 00000                                   | 000                                                 |                                         |                                         |                                         |                                                                                                                |                                         |        |
| din_rdy                                 | 0             |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| { tx_buff[19                            |               |                                         |                                         |                                         |                                         |                                         |                                         | 000000000000000000000000000000000000000             |                                         |                                         |                                         |                                                                                                                |                                         |        |
| test_conr                               |               |                                         |                                         |                                         |                                         |                                         |                                         | 000000000000000000000000000000000000000             |                                         |                                         |                                         |                                                                                                                |                                         |        |
| set_num(                                |               |                                         |                                         |                                         |                                         |                                         |                                         | 323239383830323637                                  |                                         |                                         |                                         |                                                                                                                |                                         |        |
| message[                                |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| in a constant of the                    |               |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| message_                                | 22439854      |                                         |                                         |                                         |                                         |                                         |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| s message_                              | 1=040=00      |                                         |                                         |                                         |                                         | 10000000                                |                                         |                                                     |                                         |                                         |                                         |                                                                                                                |                                         |        |
| § message_<br>§ send_mes                |               |                                         |                                         |                                         |                                         | 41542b434                               | 4744413d2244454c                        | 20414c4c220d0a0000                                  | 000000                                  |                                         |                                         |                                                                                                                |                                         |        |
| send_message_<br>send_mes<br>del_all[19 |               |                                         |                                         |                                         |                                         |                                         | 4744413d2244454c                        | 20414c4c220d0a0000<br>00000000000000000000000000000 |                                         |                                         |                                         |                                                                                                                |                                         |        |

Figure 5-5: GS Minterfacing module

Figure 5-5 shows the simulation for GSM interfacing module. This module is formed by combining the GSM command transmitter module and GSM command receiver module. It performs the functionality of both the modules. The sensor functionality is added here. In case an intruder enters, the sensor is cut. Three bits are assigned to the sensor showing which sensor is cut.

The design was synthesized for hardware testing. The design summary generated is shown in Table 5-1.

| Device Utilization Summary                                         |       |           |             |  |  |
|--------------------------------------------------------------------|-------|-----------|-------------|--|--|
| Slice Logic Utilization                                            | Used  | Available | Utilization |  |  |
| Number of Slice Registers                                          | 1,566 | 301,440   | 1%          |  |  |
| Number used as Flip Flops                                          | 1,556 |           |             |  |  |
| Number used as Latches                                             | 10    |           |             |  |  |
| Number used as Latch-thrus                                         | 0     |           |             |  |  |
| Number used as AND/OR logics                                       | 0     |           |             |  |  |
| Number of Slice LUTs                                               | 1,194 | 150,720   | 1%          |  |  |
| Number used as logic                                               | 1,117 | 150,720   | 1%          |  |  |
| Number using O6 output only                                        | 502   |           |             |  |  |
| Number using O5 output only                                        | 66    |           |             |  |  |
| Number using O5 and O6                                             | 549   |           |             |  |  |
| Number used as ROM                                                 | 0     |           |             |  |  |
| Number used as Memory                                              | 24    | 58,400    | 1%          |  |  |
| Number of occupied Slices                                          | 474   | 37,680    | 1%          |  |  |
| Number of LUT Flip Flop pairs used                                 | 1,451 |           |             |  |  |
| Number with an unused Flip Flop                                    | 258   | 1,451     | 17%         |  |  |
| Number with an unused LUT                                          | 257   | 1,451     | 17%         |  |  |
| Number of fully used LUT-FF pairs                                  | 936   | 1,451     | 64%         |  |  |
| Number of unique control sets                                      | 86    |           |             |  |  |
| Number of slice register sites lost<br>to control set restrictions | 378   | 301,440   | 1%          |  |  |
| Number of bonded IOBs                                              | 35    | 600       | 5%          |  |  |
| Number of LOCed IOBs                                               | 34    | 35        | 97%         |  |  |
| IOB Flip Flops                                                     | 21    |           |             |  |  |
| Number of bonded IPADs                                             | 4     |           |             |  |  |

Table 5-1: Top module design summary

Table 5-1 shows the device utilization summary. Number of slice registers available are 301,440 while only 1566 are utilized. In the same way, only 1556 flip flops and only 1% of the memory is utilized.

After the synthesis phase of the synthesis process, a schematic representation of the design was displayed. Figure 5-4 shows the RTL schematic view of the various sub modules of the top module.



Figure 5-6: RTL schemeatic of Top module

Figure 5-6 shows the external Transfer of data between the registers and characteristics of circuits by operations are specified by register transfer level.

After design implementation, a .bit file was generated. This is bascially used to link the code with the hardware. The programming file was ported on the FPGA using via USB Port available on the FPGA. When it was verified that the code was working, the MCS file was burnt on EPROM.

## 5.5. Ethernet Core Generation

Xilinx's Core Generator tool was used to design a Virtex-6 Tri-mode Ethernet MAC Wrapper to enable the Ethernet ports of Virtex-6 FPGA board.

#### 5.5.1. Ethernet Module-Eth 0 (Copper Interface)

The steps done to design a Virtex-6 Tri-mode Ethernet MAC Wrapper are:

Tools  $\rightarrow$  Core generator  $\rightarrow$  File  $\rightarrow$  New project  $\rightarrow$  Project options  $\rightarrow$  Part

The following options were selected:

Family: Virtex6

Virtex-6 was used since it has two Ethernet ports which is requirement of our project.

Device: xc6vlx240t

This device type contains features which satisfy our requirements.

Package: ff1156

ff indicates package type and 1156 indicates number of pins.

## Speed Grade: -1

Speed grade -1 indicates that the slope of performance is low.

Then we selected Communication and networking  $\rightarrow$  Networking  $\rightarrow$  Virtex-6 Tri-Mode

Ethernet MAC Wrapper 1.5

In PHY interface, GMII was selected and core was generated.

| 📢 Virtex-6 Embedded Tri-Mode Ethernet | MAC Wrapper                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| View Documents                        |                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| IP Symbol                             | 8 ×                                                                                               | Materia C. Furth added Tol: Made                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                       |                                                                                                   | University of the second secon |
|                                       |                                                                                                   | Component Name v6_emac_v1_5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CLIENTEMACTXD[7:0]                    |                                                                                                   | Interface Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                       |                                                                                                   | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| CLIENTEMACTXDVLDMSW                   | → EMACCLIENTRXBADFRAME                                                                            | Physical Interface Client Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CLIENTEMACTXFIRSTBYTE                 | → EMACCLIENTRXFRAMEDROP                                                                           | PHY Interface GMII 🔹 Data Width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CLIENTEMACTXUNDERRUN                  | EMACCLIENTRXSTATS[8:0]                                                                            | Speed Overclocking © 8-bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CLIENTEMACTXIFGDELAY[7:0]             |                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CLIENTEMACPAUSEREQ                    | → EMACCLIENTRXSTATSBYTEVLD                                                                        | ◎ Tri-speed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CLIENTEMACPAUSEVAL[15:0]              | → EMACCLIENTTXCLIENTCLKOUT                                                                        | 1000 Mbps     2000 Mbps     Option to reduce BUFG use                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PHYEMACGTX_CLK                        | > EMACCLIENTTXACK                                                                                 | 0 10/100 Mbps 0 2500 Mbps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PHYEMACTXGMIIMIICLKIN                 | → EMACCLIENTTXCOLLISION<br>→ EMACCLIENTTXRETRANSMIT                                               | Clock Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                       | → EMACCLIENTTXSTATS  → EMACCLIENTTXSTATSVLD  → EMACCLIENTTXSTATSBYTEVLD  → EMACCHIYTXSMIMIICLKOUT | Host and Management Interfaces Host Type DCR-specific options DCR-specific options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                       | HOSTWRDATA[31:0]                                                                                  | O DCR DCR Base Address 00 Range: 00FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| HOSTOPCODE[1:0]                       | HOSTMIIMRDY                                                                                       | Host     Management Data I/O Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| HOSTADDR[9:0]                         |                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| HOSTRDDATA[31:0]                      |                                                                                                   | None     Enable MDIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                       |                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| HOSTREQ                               |                                                                                                   | SGMII Capabilities                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                       |                                                                                                   | 10/100/1000 Mb/s (clock tolerance compliant with Ethernet specification)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DCREMACABUS[1:0]                      | EMACDCRDBUS[31:0]                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                       | > EMACDCRACK                                                                                      | 10/100/1000 Mb/s (restricted tolerance for clocks) OR 100/1000 Mb/s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                       |                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DCREMACDBUS[31:0]                     |                                                                                                   | Include SGMII / 1000BASE-X mode switching block in wrapper                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                       |                                                                                                   | Datasheet Sack Page 1 of 2 Next > Generate Cancel Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| · III                                 | 4                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Figure 5-7: Ethernet core generation

After the generation of the core, all the files from Virtex-6 embedded Tri-Mode example's design folder were added step by step. The entire UCF of the project was changed for the available development board using BANK 33 from schematics of ML-605.



Figure 5-8: BANK33

The marked portion in the Figure 5-8 indicates the pins that are used to configure the generated UCF.

## **5.5.2. SFP Module Eth1 (Optical Interface)**

Steps followed to generate Virtex-6 Tri-Mode Ethernet MAC Wrapper 2.2 are:

Communication and networking  $\rightarrow$  Networking  $\rightarrow$  Virtex-6 Tri-Mode Ethernet MAC

Wrapper 2.2

In PHY interface, 1000BASE X PCS PMA was selected and core was generated.

| Virtex-6 Embedded Tri-Mo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ode Ethernet MAC Wrapper                                    |                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| View Documents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                             |                                                                                                                              |
| IP Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ₽×                                                          | Vinter C Encloaded Tri Made                                                                                                  |
| glbi_rstn →<br>rx_axi_rstn →<br>tx_axi_rstn →<br>gtx_elk →                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ▲<br>→ tx, axi, cik, out                                    | Virtex-6 Embedded Tri-Mode<br>Ethernet MAC Wrapper       xilinx.com:ip:v6_emac:2.2         Component Name       v6_emac_v2_2 |
| gtx_clk_div2>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 70,00,00,000                                                | Interface Configuration Physical Interface Management Interface                                                              |
| nc_axi_clk →<br>nc_reset_out ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ← bus2ip_olk<br>← bus2ip_reset                              | PHY Interface 1000BASE X PCS PMA  Management Interface Speed AXI4-Lite                                                       |
| rx_axis_mac_tdata[7:0] ←<br>rx_axis_mac_tkeep[1:0] ←<br>rx_axis_mac_tvalid ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ← bus2ip_addr(10:0)<br>← bus2ip_cs<br>← bus2ip_rdce         | © 2500 Mbps © None                                                                                                           |
| rx_axis_mac_tlast ←<br>rx_axis_mac_tuser ←<br>rx_axis_filter_tuser[4:0] ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ← bus2ip_wrce<br>← bus2ip_data[31:0]<br>→ ip2bus_data[31:0] | 2000 Mbps     MDIO Interface     10/100/1000 Mbps     E                                                                      |
| nx_statistics_vector[27:0] ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | → ip2bus_wraok<br>→ ip2bus_rdaok                            | 1000 Mbps     10/100 Mbps                                                                                                    |
| tx_axi_clk →                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | → ip2bus_error<br>→ mac_irq                                 | Address Filter Options                                                                                                       |
| tx_reset_out ←<br>tx_axis_mac_tdata[7:0] <del>→</del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                             | Number of Address Table Entries 4 Range: 08                                                                                  |
| tx_axis_mac_tkeep[1:0]<br>tx_axis_mac_tvalid<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast<br>tx_axis_mac_tlast | → mdc out                                                   | Statistics Counter Options  Statistics Counters                                                                              |
| tx_axis_mac_tuser →<br>tx_axis_mac_tready ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | (— mdo_in<br>—→ mdio_tri                                    | Statistics Reset                                                                                                             |
| tx_collision ←<br>tx_retransmit ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | → mdio_out<br>← mdio_in                                     | Statistics_Width 32bit  SGMII Capabilities                                                                                   |
| tx_ifg_delay(7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                             | Datasheet     < Back     Page 1 of 3     Next >     Generate     Cancel     Help                                             |



After the generation of the core, all the files from Virtex-6 embedded Tri-Mode example's design folder were added step by step. We changed the entire UCF of the project for our development board using BANK 116 from schematics of ML-605.



Figure 5-10: BANK 116

Figure 5-10 shows BANK 116 which was used to change the generated UCF. The marked portion indicates the pins that were incorporated in the UCF to configure it according to the requirements.

# 5.6. Conclusion

Multiple test benches were designed to analyze and evaluate the performance of the project in Xilinx ISE 13.4. The GSM transmitter and receiver modules were tested using these test benches. Ethernet core (Eth0 and Eth1) was generated by using core generator in Xilinx ISE 13.4.

# Chapter 6: Future Work and Conclusion

In this chapter, the aspects for further developments in the proposed project will be discussed. Moreover, a summarized view of the entire project will also be provided which highlights Mobile Video Surveillance's core processes and at the end the conclusion will be the discussed.

### 6.1. Future Work

A project like Mobile Video Surveillance can be customized easily to demand of the user. Some of the enhancements are discussed in this chapter that can be made to the project in future to enhance its features.

#### 6.1.1. H.264 Video Compression

To effectively send video files over a network and store them on computer disks, video compression technologies are used that reduce and remove redundant video data. A significant reduction in file size can be achieved without much effect on the visual quality by using these techniques.

The latest MPEG standard for video encoding is H.264. As compared to Motion JPEG, H.264 encoder can effectively reduce the size of a digital video file by more than 80% and 50% more as compared to the MPEG-4 standard. Thus requiring lesser storage space and network bandwidth for a video file. Similarly given the same bit rate, a much higher video quality can be achieved.

Digital television, mobile TV, internet video streaming, DVD-Video and video conferencing are some of the applications of video compression technology. The products

from different manufacturers including storage media, encoders and decoders can interoperate due to standardization of video compression. A video can be converted into a compressed format by using an encoder and it can uncompressed by using a decoder. H.264 can be implemented in a video surveillance system by first encoding the video from the camera into a bit stream and than sending it to a decoder which reconstructs the original video.

#### 6.1.1.1. Working of H.264

A compressed H.264 bit stream can be produced by carrying out prediction, transforming and encoding processes. Inverse processes are performed by H.264 video decoder including decoding, inverse transform and reconstruction to produce the original video. As shown in the figure below, initially a sequence of original video frames are encoded into the H.264 format, a series of bits that represents the video in compressed form which are than stored or transmitted and can be decoded to reconstruct the video sequence. It must be kept in mind that the original sequence is not identical since this is a lossy compression technique which does not retain the original quality and picture. [13]



Figure 6-1: Video coding

This H.264 compression can be added to our project. The video from the IP camera can be compressed used FPGA and then this video can be sent to the user's mobile phone.

#### 6.1.2. Encryption and Decryption of Video

FPGA Implementation of Real Time Encryption Engine for Real Time Video Encryption can be done to implement crypto cores for three different algorithms viz. AES, 3DES and Twofish in order to achieve real time encryption and decryption of video data from a real time source.

#### **6.1.3.** Face detection and fingerprint algorithms

The locations and sizes of human faces in digital images can be located using a technology known as face detection. Objects such as buildings, trees and bodies are rejected there by detecting only faces. Face detection can be regarded as a more general case of face localization. The locations and sizes of a number of faces (usually one) that are known is found through face localization. Face processing and bitwise matching with the underlying face image that is stored in the database is carried out in face detection. There are a number of face detection applications including human computer interface, video surveillance, biometrics and image database management.

The automated method of verifying a match between two human fingerprints is known as fingerprint recognition or fingerprint authentication. A number of individuals can be identified and their identity can be verified by using this method.

#### 6.1.4. Object Classification

Object classification can be added to our project that will help in differentiating vehicles and humans.

#### 6.1.5. Increase in the coverage area

In our project we used one camera and one motion sensor and other two sensors were assigned on the DIP switches. To secure bigger areas we can add more number of cameras and sensors.

Other syndicates can work on the above mentioned areas to make this project more secure and by integrating our project with one of the above techniques would produce a very useful project for the industry.

### 6.2. Conclusion

Hence, our mobile video surveillance provides completely digital solution. It can enable efficient surveillance with the help of many security features. Many people have worked on individual modules in the past. We have customized the modules according to our requirements. Whereas we have added many security features from our own and integrated them together into a complete system.

Programming has been done in verilog using Xilinx and implemented on FPGA. Interfacing of camera, sensors, SIM 900 and the motion sensor has been done with FPGA. FPGA controls all the processing i-e the sending and receiving of messages, video transmission and the intruder detection part by using motion sensor.

In a highly secure place, the number of police station can also be added so incase an intruder enters, the message will be sent to them as well. This security system can be implemented in banks or highly secured areas.

49

# Chapter 7: Bibliography

- [1] www.ecs.csun.edu/~smirzaei/site2014/fpga\_fundamentals.pdf
- [2] http://www.cosmiac.org/tutorial\_1.html
- [3] http://www.cosmiac.org/tutorial\_2.html
- [4] http://www.cosmiac.org/tutorial\_8.html
- [5] http://www.cosmiac.org/tutorial\_9.html
- [6] http://www.cosmiac.org/tutorial\_10.html
- [7] hdlplanet.tripod.com/verilog/verilog-manual.htm
- [8] www.xilinx.com/publications/archives/xcell/Xcell48.pdf
- [9] www.ispyconnect.com/
- [10] www.deskshare.com/ip-camera-viewer.aspx
- [11] www.wireshark.org/
- [12] www.docklight.de/pdf/docklight\_manual.pdf  $\$
- [13] www.slideshare.net/vcodex/h264-video-compression-an-overview

# **APPENDIX A-1**

# **Code for Top Module**

`timescale 1ns / 1ps module Top( MGTCLK\_P, MGTCLK\_N, reset, TXP, TXN, RXP, RXN, PHYAD, GMII\_TXD, GM II \_TX\_ EN, GMII\_TX\_ ER, GMII\_TX\_ CLK, GMII\_RXD, GMII\_RX\_DV, GM II \_RX\_ ER, GMII\_RX\_CLK, phy\_reset, lcd\_locked, clk, // rst, sensor, gsm\_en, gsm\_serial\_in,

gsm\_serial\_out, flag, arm\_flag, ser\_flag ); input MGTCLK\_P; input MGTCLK\_N; input reset; output TXP; output TXN; input RXP; input RXN; input [4:0]PHYAD; output [7:0] GMII\_TXD; output GMII\_TX\_ EN; output GMII\_TX\_ER; output GMII\_TX\_ CLK; input [7:0] GMII\_RXD; input GMII\_RX\_DV; input GMII\_RX\_ER; input GMII\_RX\_CLK; output phy\_reset;

output lcd\_locked;

| input  |       | clk;            |
|--------|-------|-----------------|
| input  | [2:0] | sensor;         |
| input  |       | gsm_en;         |
| input  |       | gsm_serial_in;  |
| output |       | gsm_serial_out; |

| output | flag;     |
|--------|-----------|
| output | arm_flag; |
| output | ser_flag; |

//-----wires-----//

wire wire\_tx\_clk\_1;

wire wire\_clk\_125;

wire ref\_clk;

wire locked;

wire reset\_1;

wire [7:0] wire\_in\_tx\_ll\_data\_i\_0;

wire wire\_in\_tx\_ll\_sof\_n\_i\_0;

wire wire\_in\_tx\_ll\_eof\_n\_i\_0;

wire wire\_in\_tx\_ll\_src\_rdy\_n\_i\_0;

wire [7:0] wire\_tx\_ll\_data\_i\_0;

wire wire\_tx\_ll\_sof\_n\_i\_0;

wire wire\_tx\_ll\_eof\_n\_i\_0;

wire wire\_tx\_ll\_ src\_rdy\_n\_i\_0;

wire kl;

reg reset\_flag = 1'b0;

reg lock\_delay1,lock\_delay2;

reg[11:0]phy\_reg;

reg Phy\_rst;

wire phy\_reset\_wire;

////------key signal-----

base\_1000\_x\_example\_design m1\_SFP

( // Client receiver interface

| .EMACCLIENTRXDVLD               | ( ),   |
|---------------------------------|--------|
| .EMACCLIENTRXFRAMEDROP          | (),    |
| .EMACCLIENTRXSTATS              | ( ),   |
| .EMACCLIENTRXSTATSVLD           | (),    |
| .EMACCLIENTRXSTATSBYTEVL        | D ( ), |
| // Client transmitter interface |        |
| .CLIENTEMA CTXIFGDELA Y         | (),    |
| .EMACCLIENTTXSTATS              | ( ),   |
| .EMACCLIENTTXSTATSVLD           | ( ),   |
| .EMACCLIENTTXSTATSBYTEVLI       | D (),  |
| // MAC control interface        |        |
| .CLIENTEMA CPAUSEREQ            | (),    |
| .CLIENTEMA CPAUSEVAL            | (),    |
|                                 |        |

#### // EMAC-transceiver link status

|                            | ()  |
|----------------------------|-----|
| .EMACCLIENTS YNCA CQSTATUS | (), |

// 1000BASE-X PCS/PMA interface

| .TXP | (TXP), |
|------|--------|
| .TXN | (TXN), |
| .RXP | (RXP), |
| .RXN | (RXN), |

.RXN

.PHYAD 0,

// 1000BASE-X PCS/PMA clock buffer input

//-- MGTCLK\_N,

//-- MGTCLK\_P,

// Asynchronous reset

| .RESET   | (reset_1),      |
|----------|-----------------|
| .clk_ds1 | (clk_ds),       |
| .clk_125 | (wire_clk_125), |

| .in _tx_ll_data_i_0      | (wire_in_tx_ll_ data_i_0),      |
|--------------------------|---------------------------------|
| .in _tx_ll_sof_n_i_0     | (wire_in_tx _ll_ sof_n_i_0),    |
| .in _tx_ll_eof_n_i_0     | (wire_in_tx_ll_eof_n_i_0),      |
| .in _tx_ll_src_rdy_n_i_0 | (wire_in_tx_ll_src _rdy_n_i_0), |
| .tx_ll_data_i_0          | (wire_tx_ll_data _i_0),         |
| .tx_ll_sof_n_i_0         | (wire_tx_ll_sof_ n_i_0),        |
| .tx_ll_eof_n_i_0         | (wire_tx_ll_eof_ n_i_0),        |
| .tx_ll_src_rdy_n_i_0     | (wire_tx _ll_src_rdy _n_i_0)    |
| ///                      |                                 |

#### );

v6\_emac\_v1\_5\_example\_design m2\_Ethernet

| 1  | 11 | ( liont | racalvar | interface |
|----|----|---------|----------|-----------|
| ١. | 11 | CHEIR   |          | internace |
|    |    |         |          |           |

| .EMACCLIENTRXDVLD               | ( ),         |
|---------------------------------|--------------|
| .EMACCLIENTRXFRAMEDROP          | (),          |
| .EMACCLIENTRXSTATS              | (),          |
| .EMACCLIENTRXSTATSVLD           | (),          |
| .EMACCLIENTRXSTATSBYTEVLI       | <b>D</b> (), |
| // Client transmitter interface |              |
| .CLIENTEMA CTXIFGDELA Y         | ( ),         |
| .EMACCLIENTTXSTATS              | ( ),         |
| .EMACCLIENTTXSTATSVLD           | ( ),         |
| .EMACCLIENTTXSTATSBYTEVLI       | <b>D</b> (), |
| // MAC control interface        |              |
| .CLIENTEMA CPAUSEREQ            | ( ),         |
| .CLIENTEMACPAUSEVAL             | ( ),         |
|                                 |              |
|                                 |              |

// Clock signal

//--GTX\_CLK,

// GMII interface

| .GM II_TXD   | (GM II _TXD),    |
|--------------|------------------|
| .GMII_TX_EN  | (GMII_TX_EN),    |
| .GMII_TX_ER  | (GMII_TX_ER),    |
| .GMII_TX_CLK | (GM II _TX_CLK), |
| .GMII_RXD    | (GMII_RXD),      |
| .GMII_RX_DV  | (GMII_RX_DV),    |
| .GMII_RX_ER  | (GMII_RX_ER),    |
| .GMII_RX_CLK | (GMII_RX_CLK),   |

// Reference clock for IODELA Ys

| .REFCLK                  | (ref_clk),                     |
|--------------------------|--------------------------------|
| // Asynchronous reset    |                                |
| .RESET                   | (reset_1),                     |
| .tx_clk_1                | (wire_tx_clk_1),               |
| .in _tx_ll_data_i_1      | (wire_tx_ll_data_i_0),         |
| .in _tx_ll_sof_n_i_1     | (wire_tx_ll_sof_n_i_0),        |
| .in _tx_ll_eof_n_i_1     | (wire_tx_ll_eof_n_i_0),        |
| .in _tx_ll_src_rdy_n_i_1 | (wire_tx_ll_src_rdy_n_i_0),    |
| .tx_ ll_data_i_1         | (wire_in_ tx_ll_data_i_0),     |
| .tx_ll_sof_n_i_1         | (wire_in_tx_ll_sof_n_i_0),     |
| .tx_ll_eof_n_i_1         | (wire_in_tx_ll_eof_n_i_0),     |
| .tx_ll_src_rdy_n_i_1     | (wire_in_ tx_ll_src_rdy_n_i_0) |
| ////                     |                                |

);

// IBUF reset\_ibuf (

// .I (reset),

```
// .O (reset_1)
```

// );

IBUFDS\_GTXE1 clkingen (

.I (MGTCLK\_P),

```
.IB (MGTCLK_N),
   .CEB (1'b0),
   .O (clk_ds),
   .ODIV2 ()
  );
 BUFG bufg_tx (
    .I (wire_clk_125),
    .O (wire_tx_clk_1)
  );
clk_200 m3
(
    .CLK_IN1(wire_clk_125),
    .CLK_OUT1(ref_clk),
    .LOCKED(locked)
);
//assign phy_reset = !reset_1;
assign lcd_locked = locked;
//-----auto reset------//
assign phy_reset_wire = (!(lock_delay2 ^ locked)) || reset_flag; //switch;
always @ (posedge wire_tx_clk_1)
begin
lock_delay 1 <= locked;</pre>
lock_delay2 <= lock_delay1;</pre>
end
always @ (phy_reset)
begin
if(phy_reset == 0)
reset_flag = 1'b1;
```

end

```
57
```

```
assign reset_1 = !phy_reset | reset | (~arm_flag);
always@(posedge wire_tx_clk_1)
begin
if(phy_reset_wire==1b0)
begin
phy_reg<=12'b1100_0000_0000;
Phy_rst<=1'b1;
end
else
begin
phy_reg<=1'b1;
phy_reg[11:1]<=phy_reg[10:0];
Phy_rst<=phy_reg[11];
end
end
assign phy_reset =Phy_rst;
//========
                     GSM_INT inst_gsm(
                                    .clk(clk),
                                    .rst(reset),
                                    .sensor(sensor),
                                    .gsm_en(gsm_en),
                                    .gsm_serial_in(gsm_serial_in),
                                    .gsm_serial_out(gsm_serial_out),
                                    .flag(flag),
                                    .arm_flag(arm_flag),
                                    .ser_flag(ser_flag)
```

//flag\_1

);

endmodule

# **APPENDIX A-2**

## **Code for Clock:**

// "Output Output Phase Duty Pk-to-Pk Phase"
// "Clock Freq (MHz) (degrees) Cycle (%) Jitter (ps) Error (ps)"
//-----// CLK\_OUT1\_\_\_200.000\_\_\_\_0.000\_\_\_50.0\_\_\_109.241\_\_\_\_96.948//
//-----// "Input Clock Freq (MHz) Input Jitter (UI)"
//-----// \_\_primary\_\_\_\_125.000\_\_\_\_\_0.010
`timescale 1ps/1ps
(\* CORE\_GENERATION\_INFO =

"clk\_200,clk\_wiz\_v3\_2,{component\_name=clk\_200,use\_phase\_alignment=true,use\_min\_o\_jitter=false,use e\_max\_i\_jitter=false,use\_dyn\_phase\_shift=false,use\_inclk\_switchover=false,use\_dyn\_reconfig=false,feedb ack\_source=FDBK\_AUTO,primtype\_sel=MMCM\_ADV,num\_out\_clk=1,clkin1\_period=8.000,clkin2\_peri od=10.000,use\_power\_down=false,use\_reset=false,use\_locked=true,use\_inclk\_stopped=false,use\_status=f alse,use\_freeze=false,use\_clk\_valid=false,feedback\_type=SINGLE,clock\_mgr\_type=MANUAL,manual\_o verride=false}" \*)

module clk\_200

(// Clock in ports

input CLK\_IN1,

// Clock out ports

output CLK\_OUT1,

// Status and control signals

output LOCKED

);

// Input buffering

//-----

// IBUFG clkin 1\_buf

// (.O (clkin1),

### // .I(CLK\_IN1));

// Clocking primitive

//-----

### // Instantiation of the MMCM primitive

- // \* Unused inputs are tied off
- // \* Unused outputs are labeled unused
- wire [15:0] do\_unused;

| wire | drdy_unused;         |
|------|----------------------|
| wire | psdone_unused;       |
| wire | clkfbout;            |
| wire | clkfbout_buf;        |
| wire | clkfboutb_unused;    |
| wire | clkout0b_unused;     |
| wire | clkout1_unused;      |
| wire | clkout1b_unused;     |
| wire | clkout2_unused;      |
| wire | clkout2b_unused;     |
| wire | clkout3_unused;      |
| wire | clkout3b_unused;     |
| wire | clkout4_unused;      |
| wire | clkout5_unused;      |
| wire | clkout6_unused;      |
| wire | clkfbstopped_unused; |
| wire | clkinstopped_unused; |

MMCM\_ADV

#(.BANDWIDTH ("OPTIMIZED"),

.CLKOUT4\_CASCADE ("FALSE"),

.CLOCK\_HOLD ("FALSE"),

.COMPENSATION ("ZHOLD"),

.STARTUP\_WAIT ("FALSE"),

.DIVCLK\_DIVIDE (1),

.CLKFBOUT\_MULT\_F (8.000),

.CLKFBOUT\_PHASE (0.000),

.CLKFBOUT\_USE\_FINE\_PS ("FALSE"),

.CLKOUT0\_DIVIDE\_F (5.000),

.CLKOUT0\_PHASE (0.000),

.CLKOUT0\_DUTY\_CYCLE (0.500),

.CLKOUT0\_USE\_FINE\_PS ("FALSE"),

.CLKIN1\_PERIOD (8.000),

.REF\_JITTER1 (0.010))

mmcm\_adv\_inst

// Output clocks

(.CLKFBOUT (clkfbout),

.CLKFBOUTB (clkfboutb\_unused),

.CLKOUT0 (clkout0),

.CLKOUT0B (clkout0b\_unused),

.CLKOUT1 (clkout1\_unused),

.CLKOUT1B (clkout1b\_unused),

.CLKOUT2 (clkout2\_unused),

.CLKOUT2B (clkout2b\_unused),

.CLKOUT3 (clkout3\_unused),

.CLKOUT3B (clkout3b\_unused),

.CLKOUT4 (clkout4\_unused),

.CLKOUT5 (clkout5\_unused),

.CLKOUT6 (clkout6\_unused),

// Input clock control

.CLKFBIN (clkfbout\_buf),

.CLKIN1 (CLK\_IN1),

.CLKIN2 (1'b0),

// Tied to always select the primary input clock

.CLKINSEL (1'b1),

// Ports for dynamic reconfiguration

| .DA DDR                              | (7'h0),                      |  |
|--------------------------------------|------------------------------|--|
| .DCLK                                | (1'b0),                      |  |
| .DEN                                 | (1'b0),                      |  |
| .DI                                  | (16h0),                      |  |
| .DO                                  | (do_unused),                 |  |
| .DRDY                                | (drdy_unused),               |  |
| .DW E                                | (1'b0),                      |  |
| // Ports .for dynamic phase shift    |                              |  |
| . PSCLK                              | (1'b 0),                     |  |
| . PSEN                               | (1 <sup>°</sup> b 0),        |  |
| . PSINCDEC                           | C (1'b 0),                   |  |
| . PSDONE                             | (psdone_unused),             |  |
| // Other control status signals      |                              |  |
| .LOCKED                              | (LOCKED),                    |  |
| .CLKINSTOPPED (clkinstopped_unused), |                              |  |
| .CLKFBSTC                            | OPPED (clkfbstopped_unused), |  |
| .PW RDWN                             | (1'b0),                      |  |
| .RST                                 | (1'b0));                     |  |
|                                      |                              |  |

### // Output buffering

//-----

BUFG clkf\_buf

(.O (clkfbout\_buf),

.I (clkfbout));

## BUFG clkout1\_buf

- (.O (CLK\_OUT1),
- .I (clkout0));

endmodule

# **APPENDIX A-3**

## <u>UCF</u>

# The xc6v1x240tff1156-1 part is chosen for the example design.

# This value should be modified to match thedevice.

CONFIG PART = xc 6v1x240tff1156-1;

# Locate the Tri-Mode Ethernet MAC instance

INST "m2\_Ethernet/\*v6\_emac" LOC = "TEMAC\_X0Y0";

#INST "m1/\*v6\_emac" LOC = "TEMAC\_X0Y1";

INST "m1\_SFP/\*gtx0\_v6\_gtxwizard\_i?gtxe1\_i" LOC = "GTXE1\_X0Y17";

### **# CLOCK CONSTRAINTS**

# The following constraints are required. If you choose to not use example.

# design level of wrapper hierarchy, the net names should be translated to

# match the design.

\*\*\*\*\*\*\*

## Ethernet GTX\_ CLK high 125 MHz reference clock

#NET "\*GTX\_CLK" TNM\_NET = "ref\_ gtx\_clk";

#TIMEGRP "v6\_emac\_v1\_5\_clk\_ref\_gtx" = "ref\_gtx\_clk";

#TIMESPEC " TS\_v6\_emac \_v1\_5\_clk\_ref\_gtx" = PERIOD "v6\_emc\_v1\_5\_clk\_ref\_gtx" 8 ns HIGH 50
%;

# Ethernet GTX\_CLK high quality 125 MHz reference clock

NET "WIRE\_TX\_CLK\_1" TNM\_NET = "ref\_gtx\_clk";

TIMEGRP "v6\_emac\_v1\_5\_clk\_ref\_gtx" = "ref\_gtx\_clk";

TIMESPEC "TS\_v6\_emac\_v1\_5\_clk\_ref\_gtx" = PERIOD "v6\_emac\_v1\_5\_clk\_ref\_gtx" 8 ns HIGH 50 %;

# Ethernet GMII PHY-side receive clock

NET "\*GMII\_RX\_CLK" TNM\_NET = "phy\_clk\_rx";

TIMEGRP "v6\_emac\_v1\_5\_clk\_phy\_rx" = "phy\_clk\_rx";

TIMESPEC "TS\_v6\_emac\_v1\_5\_clk\_phy\_rx" = PERIOD "v6\_emac\_v1\_5\_clk\_phy\_rx" 7.5 ns HIGH 50 %;

# Ethernet MAC reference clock driven by transceiver

NET "\*clk125\_o" TNM\_NET = "clk\_gt\_clk";

TIMEGRP "base\_1000\_x\_gt\_clk" = "clk\_gt\_clk";

TIMESPEC "TS\_base\_1000\_x\_gt\_clk" = PERIOD "base\_1000\_x\_gt\_clk" 8 ns HIGH 50 %;

## IDELA YCTRL 200 MHz reference clock

#NET "REFCLK" TNM\_NET = "clk\_ref\_clk";

#TIMEGRP "ref\_clk" = "clk\_ref\_clk";

#TIMESPEC "TS\_ref\_clk" = PERIOD "ref\_clk" 5 ns HIGH 50 %;

\*\*\*\*\*\*\*

### # PHYSICAL INTERFACE CONSTRAINTS

# The following constraints are necessary for proper operation, and are tuned

# for this example design. They should be modified to suit your design.

\*\*\*\*\*\*\*

# GMII physical interface constraints

# ------

# Set the IDELA Y values on the PHY inputs, tuned for this example design.

# These values should be modified to suit your design.

INST "\*gmii?ideldv" IDELA Y\_VALUE = 26;

INST "\*gmii?ideld0" IDELA Y\_VALUE = 26;

INST "\*gmii?ideld1" IDELA Y\_VALUE = 26;

INST "\*gmii?ideld 2" IDELA Y\_VALUE = 26; INST "\*gmii?ideld 3" IDELA Y\_VALUE = 26; INST "\*gmii?ideld 4" IDELA Y\_VALUE = 26; INST "\*gmii?ideld 5" IDELA Y\_VALUE = 26; INST "\*gmii?ideld 6" IDELA Y\_VALUE = 26; INST "\*gmii?ideld 7" IDELA Y\_VALUE = 26; INST "\*gmii?ideler" IDELA Y\_VALUE = 0; INST "\*gmii\_rxc\_delay" IDELA Y\_VALUE = 0;

# Group all IDELA Y-related blocks to use a single IDELA YCTRL

INST "\*dlyctrl" IODELA Y\_GROUP = gmii\_idelay;

INST "\*ideld?" IODELA Y\_GROUP = g mii\_idelay;

INST "\*ideldv" IODELA Y\_GROUP = g mii\_idelay;

INST "\*ideler" IODELAY\_GROUP = gmii\_idelay;

INST "\*gmii\_rxc\_delay" IODELA Y\_GROUP = gmii\_idelay;

# The following constraints work in conjunction with IDELA Y\_VALUE settings to # check that the GMII receive bus remains in alignment with the rising edge of # GMII\_RX\_CLK, to within 2ns setup time and 0 hold time. INST "GMII\_RXD<?>" TNM = "gmii\_rx"; INST "GMII\_RX\_DV" TNM = "gmii\_rx"; INST "GMII\_RX\_ER" TNM = "gmii\_rx"; TIMEGRP "gmii\_rx" OFFSET = IN 2 ns VALID 2 ns BEFORE "GMII\_RX\_CLK" RISING;

# Constrain the GMII physical interface flip-flops to IOBs

INST "\*gmii?RXD\_TO\_MAC\*" IOB = true;

INST "\*gmii?RX\_DV\_TO\_MAC" IOB = true;

INST "\*gmii?RX\_ER\_TO\_MAC" IOB = true;

INST "\*gmii?GMII\_TXD\_?" IOB = true;

INST "\*gmii?GMII\_TX\_EN" IOB = true;

INST "\*gmii?GMII\_TX\_ER" IOB = true;

# Location constraints are chosen for this example design.

- # These values should be modified to suit your design.
- # \* Note that regional clocking imposes certain requirements
- # on the location of the physical interface pins and the TEMAC instance.
- # Please refer to the Virtex-6 FPGA Embedded Tri-Mode Ethernet MAC

# User Guide for additional details. \*

| 1                                       |                             |
|-----------------------------------------|-----------------------------|
| ####################################### | *****                       |
| #NET "PHY_COL"                          | LOC = "AK13"; ## 114 on U80 |
| #NET "PHY_CRS"                          | LOC = "AL13"; ## 115 on U80 |
| #NET "PHY_INT"                          | LOC = "AH14"; ## 32 on U80  |
| #NET "PHY_MDC"                          | LOC = "AP14"; ## 35 on U80  |
| #NET "PHY_MDIO"                         | LOC = "AN14"; ## 33 on U80  |
| #NET "PHY_RESET"                        | LOC = "AH13"; ## 36 on U80  |
| #NET "PHY_RXCLK"                        | LOC = "AP11"; ## 7 on U80   |
| #NET "PHY_RXCTL_RXDV"                   | LOC = "AM13"; ## 4 on U80   |
| #NET "PHY_RXD0"                         | LOC = "AN13"; ## 3 on U80   |
| #NET "PHY_RXD1"                         | LOC = "AF14"; ## 128 on U80 |
| #NET "PHY_RXD2"                         | LOC = "AE14"; ## 126 on U80 |
| #NET "PHY_RXD3"                         | LOC = "AN12"; ## 125 on U80 |
| #NET "PHY_RXD4"                         | LOC = "AM12"; ## 124 on U80 |
| #NET "PHY_RXD5"                         | LOC = "AD11"; ## 123 on U80 |
| #NET "PHY_RXD6"                         | LOC = "AC12"; ## 121 on U80 |
| #NET "PHY_RXD7"                         | LOC = "AC13"; ## 120 on U80 |
| #NET "PHY_RXER"                         | LOC = "AG12"; ## 9 on U80   |
| #NET "PHY_TXCLK"                        | LOC = "AD12"; ## 10 on U80  |

| #NET "PHY_TXCTL_TXEN" | LOC = "AJ10"; ## 16 on U80 |
|-----------------------|----------------------------|
| #NET "PHY_TXC_GTXCLK" | LOC = "AH12"; ## 14 on U80 |
| #NET "PHY_TXD0"       | LOC = "AM11"; ## 18 on U80 |
| #NET "PHY_TXD1"       | LOC = "AL11"; ## 19 on U80 |
| #NET "PHY_TXD2"       | LOC = "AG10"; ## 20 on U80 |
| #NET "PHY_TXD3"       | LOC = "AG11"; ## 24 on U80 |
| #NET "PHY_TXD4"       | LOC = "AL10"; ## 25 on U80 |
| #NET "PHY_TXD5"       | LOC = "AM10"; ## 26 on U80 |
| #NET "PHY_TXD6"       | LOC = "AE11"; ## 28 on U80 |
| #NET "PHY_TXD7"       | LOC = "AF11"; ## 29 on U80 |
| #NET "PHY_TXER"       | LOC = "AH10"; ## 13 on U80 |

#######////------

# Locate the GMII physical interface pins INST "GMII\_TXD<0>" LOC = "AM11"; INST "GMII\_TXD<1>" LOC = "AL11"; INST "GMII\_TXD<2>" LOC = "AG10"; INST "GMII\_TXD<3>" LOC = "AG11"; INST "GMII\_TXD<4>" LOC = "AL10"; INST "GMII\_TXD<5>" LOC = "AM10"; INST "GMII\_TXD<6>" LOC = "AE11"; INST "GMII\_TXD<7>" LOC = "AF11"; INST "GMII\_TX\_EN" LOC = "AJ10"; INST "GMII\_TX\_ER" LOC = "AH10"; INST "GMII\_TX\_CLK" LOC = "AH12"; INST "GMII\_RXD<0>" LOC = "AN13"; INST "GMII\_RXD<1>" LOC = "AF14"; INST "GMII\_RXD<2>" LOC = "AE14"; INST "GMII\_RXD<3>" LOC = "AN12"; INST "GMII\_RXD<4>" LOC = "AM12"; INST "GMII\_RXD<5>" LOC = "AD11"; INST "GMII\_RXD<6>" LOC = "AC12"; INST "GMII\_RXD<7>" LOC = "AC13"; INST "GMII\_RX\_DV" LOC = "AM13"; INST "GMII\_RX\_ER" LOC = "AG12"; INST "GMII\_RX\_CLK" LOC = "AP11";

# Locate the 125 MHz reference clock buffer INST "bufg\_tx" LOC = "BUFGCTRL\_X0Y28"; //y6 # ## Locate the 200 MHz delay controller clock buffer #INST "refclk\_bufg" LOC = "BUFGCTRL\_X0Y7";

### # LOCALLINK FIFO CONSTRAINTS

# The following constraints are necessary for proper operation of the LocalLink

# FIFO. If you choose to not use the LocalLink level of wrapper hierarchy,

# these constraints should be removed.

\*\*\*\*\*\*\*

# LocalLink client FIFO transmit-side constraints

# ------

# Group the clock crossing signals into timing groups

INST "\*client\_side\_FIFO\_1?tx\_fifo\_i?rd\_tran\_frame\_tog" TNM = "tx\_fifo\_rd\_to\_wr\_1";

INST "\*client\_side\_FIFO\_1?tx\_fifo\_i?rd\_retran\_frame\_tog" TNM = "tx\_fifo\_rd\_to\_wr\_1";

INST "\*client\_side\_FIFO\_1?tx\_fifo\_i?rd\_col\_window\_pipe\_1" TNM = "tx\_fifo\_rd\_to\_wr\_1";

INST "\*client\_side\_FIFO\_1?tx\_fifo\_i?rd\_addr\_txfer\*" TNM = "tx\_fifo\_rd\_to\_wr\_1";

INST "\*client\_side\_FIFO\_1?tx\_fifo\_i?rd\_txfer\_tog" TNM = "tx\_fifo\_rd\_to\_wr\_1";

INST "\*client\_side\_FIFO\_1?tx\_fifo\_i?wr\_frame\_in\_fifo" TNM = "tx\_fifo\_wr\_to\_rd\_1";

TIMESPEC "TS\_tx\_fifo\_rd\_to\_wr\_1" = FROM "tx\_fifo\_rd\_to\_wr\_1" TO "v6\_emac\_v1\_5\_clk\_ref\_gtx" 8 ns DATAPATHONLY;

TIMESPEC "TS\_tx\_fifo\_wr\_to\_rd\_1" = FROM "tx\_fifo\_wr\_to\_rd\_1" TO "v6\_emac\_v1\_5\_clk\_ref\_gtx" 8 ns DATAPATHONLY;

# Reduce clock period to allow for metastability settling time

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_tran\_frame\_tog" TNM = "tx\_metastable \_1";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_rd\_addr\*" TNM = "tx\_metastable\_1";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_txfer\_tog" TNM = "tx\_metastable\_ 1";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?frame\_in\_fifo" TNM = "tx\_metastable\_1";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_retran\_frame\_tog\*" TNM = "tx\_metastable\_1";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_col\_window\_pipe\_0" TNM = "tx\_metastable\_1";

TIMESPEC "TS\_tx\_meta\_protect\_" = FROM "tx\_metastable\_1" 5 ns DATAPATHONLY;

# Transmit-side client FIFO address bus timing

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_addr\_tfer\*" TNM = "tx\_addr\_rd\_ 1";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_rd\_adr\*" TNM = "tx\_addr\_wr\_ 1";

TIMESPEC "TS\_tx\_fifo\_addr\_" = FROM "tx\_addr\_rd\_1" TO "tx\_addr\_wr\_1" 10 ns;

# LocalLink client FIFO receive-side constraints

# ------

## Group the crossing signals into timing groups

#INST "\*client\_side\_FIFO\_1?rx\_fifo\_i?wr\_store\_frame\_tog" TNM = "rx\_fifo\_wr\_to\_rd\_1";

#INST "\*client\_side\_FIFO\_1?rx\_fifo\_i?rd\_addr\_gray\*" TNM = "rx\_fifo\_rd\_to\_wr\_1";

#

#TIMESPEC "TS\_rx\_fifo\_wr\_to\_rd\_" = FROM "rx\_fifo\_wr\_to\_rd\_1" TO "v6\_emac\_v\_5\_clk\_ref\_gtx" 8
ns DATAPATHONLY;

#TIMESPEC "TS\_rx\_fifo\_rd\_to\_wr\_" = FROM "rx\_fifo\_rd\_to\_wr\_1" TO "v6\_emac\_v\_5\_clk\_phy\_rx" 8
ns DATAPATHONLY;

## Reduce clock period to allow for metastability settling time

#INST "\*client\_side\_FIFO\_1?rx\_fifo\_i?wr\_rd\_addr\_gray\_sync\*" TNM = "rx\_metastable\_1";

#INST "\*client\_side\_FIFO\_1?rx\_fifo\_i?rd\_store\_frame\_tog" TNM = "rx\_metastable\_1";

#TIMESPEC "TS\_rx\_meta\_protect\_1" = FROM "rx\_metastable\_1" 5 ns;

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

#### ## LOCALLINK sfp FIFO CONSTRAINTS

## The following constraints are necessary for proper operation of the LocalLink

## FIFO. If you choose to not use the LocalLink level of wrapper hierarchy,

## these constraints should be removed.

#

## LocalLink client FIFO transmit-side constraints

## ------

#

## Group the clock signals into timing groups

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_tran\_frame\_tog" TNM = "tx\_fifo\_rd\_to \_wr\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_retran\_frame\_tog" TNM = " tx\_fifo\_rd\_to \_wr\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_col\_window\_pipe\_1" TNM = "tx\_fifo\_rd\_ to\_wr\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_addr\_txfer\*" TNM = "tx\_fifo\_rd\_to\_wr\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_txfer\_tog" TNM = "tx\_fifo\_rd\_to\_wr\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_frame\_in\_fifo" TNM = " tx\_fifo\_wr\_to\_ rd\_0";

TIMESPEC "TS\_tx\_fifo\_rd\_to\_wr\_" = FROM "tx\_fifo\_rd\_to\_wr\_0" TO "base\_1000\_x\_gt\_clk" 8 ns DATAPATHONLY;

TIMESPEC "TS\_tx\_fifo\_wr\_to\_rd\_0 = FROM "tx\_fifo\_wr\_to\_rd\_0" TO "base\_1000\_x\_gt\_clk" 8 ns DATAPATHONLY;

# Reduce clock period to allow for metastability settling time

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_tran\_frame\_tog" TNM = "tx\_metastable\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_rd\_addr\*" TNM = "tx\_metastable\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_txfer\_tog" TNM = "tx\_metastable\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?frame\_in\_fifo" TNM = "tx\_metastable\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_retran\_frame\_tog\*" TNM = "tx\_metastable\_0";

```
INST "*client_side_FIFO_?tx_fifo_i?wr_col_window_pipe_0" TNM = "tx_metastable_0";
TIMESPEC "TS_tx_meta_protect_0" = FROM "tx_metastable_0" 5 ns DATAPATHONLY;
```

# Transmit-side client FIFO address bus timing

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?rd\_addr\_txfer\*" TNM = "tx\_adr\_rd\_0";

INST "\*client\_side\_FIFO\_?tx\_fifo\_i?wr\_rd\_addr\*" TNM = "tx\_adr\_wr\_0";

TIMESPEC "TS\_tx\_fifo\_addr\_" = FROM "tx\_addr\_rd\_" TO "tx\_addr\_wr\_0" 10 ns;

# LocalLink client FIFO receive-side constraints

# ------

## Group the clock crossing signals into timing groups

#INST "\*client\_side\_FIFO\_0?rx\_fifo\_i?wr\_store\_frame\_tog" TNM = "rx\_fifo\_wr\_to\_rd\_0";

#INST "\*client\_side\_FIFO\_0?rx\_fifo\_i?rd\_addr\_gray\*" TNM = "rx\_fifo\_rd\_to\_wr\_0";

#

#TIMESPEC "TS\_rx\_fifo\_wr\_to\_rd\_0" = FROM "rx\_fifo\_wr\_to\_rd\_0" TO "base\_1000\_x\_gt\_clk" 8 ns
DATAPATHONLY;

#TIMESPEC "TS\_rx\_fifo\_rd\_to\_wr\_0" = FROM "rx\_fifo\_rd\_to\_wr\_0" TO "base\_1000\_x\_gt\_clk" 8 ns
DATAPATHONLY;

#

## Reduce clock period to allow for metastability settling time

#INST "\*client\_side\_FIFO\_0?rx\_fifo\_i?wr\_rd\_addr\_gray\_sync\*" TNM = "rx\_metastable\_0";

#INST "\*client\_side\_FIFO\_0?rx\_fifo\_i?rd\_store\_frame\_tog" TNM = "rx\_metastable\_0";

#TIMESPEC "TS\_rx\_meta\_protect\_0" = FROM "rx\_metastable\_0" 5 ns;

## Locate the Tri-Mode Ethernet MAC instance

#INST "\*v6\_emac" LOC = "TEMAC\_X0Y0";

## Group design elements around Ethernet MAC

## closure in this example design. These values may be modified

## removed to best suit your design.

#INST "\*" AREA\_GROUP = "AG\_example\_design";

#AREA\_GROUP "AG\_example\_design" RANGE = CLOCKREGION\_X1Y0:CLOCKREGION\_X1Y3; #INST "\*client\_side\_FIFO\_0?tx\_fifo\_i?ramgen" LOC = "RAMB36\_X7Y16"; #INST "\*client\_side\_FIFO\_0?rx\_fifo\_i?ramgen" LOC = "RAMB36\_X7Y17";

\*\*\*\*\*\*\*\*

### **# CLOCK CONSTRAINTS**

# The following constraints are required. If you choose to not use the example# design level of wrapper hierarchy, the net names should be translated to# match your design.

\*\*\*\*\*\*\*

## Ethernet MAC reference clock driven by transceiver

#NET "clk125\_o" TNM\_NET = "clk\_gt\_clk";

#TIMEGRP "base\_1000\_x\_gt\_clk" = "clk\_gt\_clk";

#TIMESPEC "TS\_base\_1000\_x\_gt\_clk" = PERIOD "base\_1000\_x\_gt\_clk" 8 ns HIGH 50 %;

\*\*\*\*\*\*

#### **# PHYSICAL INTERFACE CONSTRAINTS**

# The following constraints are necessary for proper operation, and are tuned

# for this example design. They should be modified to suit your design.

\*\*\*\*\*\*\*

#### # 1000BASE-X physical interface constraints

# ------

////-----

| #NET "SFP_LOS"           | LOC = "V23"; | ## 8 on P4            |
|--------------------------|--------------|-----------------------|
| #NET "SFP_RX_N"          | LOC = "E4";  | ## 12 on P4           |
| #NET "SFP_RX_P"          | LOC = "E3";  | ## 13 on P4           |
| #NET "SFP_TX_DISA BLE_FP | GA" LOC      | = "AP12"; ## 1 on Q22 |

| #NET "SFP_TX_N"       | LOC = "C4"; ## 19 on P4              |
|-----------------------|--------------------------------------|
| #NET "SFP_TX_P"       | LOC = "C3"; ## 18 on P4              |
| ##                    |                                      |
| #NET "SGMIICLK_QO_N"  | LOC = "H5"; ## 2 on series C55 0.1uF |
| #NET "SGM IICLK_QO_P" | LOC = "H6"; ## 2 on series C56 0.1uF |

# Place the transceiver components, chosen for this example design.

# These values should be modified according to your specific design.

INST "MGTCLK\_N" LOC = "H5";

INST "MGTCLK\_P" LOC = "H6";

INST "TXP" LOC = "C3";

INST "TXN" LOC = "C4";

INST "RXP" LOC = "E3";

INST "RXN" LOC = "E4";

NET "arm\_flag" LOC = AE23; NET "flag" LOC = AE22; #NET "rst" LOC = G26; NET "clk" LOC = U23;

NET "gsm\_en" LOC = D22;

NET "gsm\_serial\_out" LOC = AC22;

NET "gsm\_serial\_in" LOC = AD24;

NET "sensor[0]" LOC = L20;

NET "sensor[1]" LOC = L21;

NET "sensor[2]" LOC = A E24;

NET "ser\_flag" LOC = J25;

# **APPENDIX A-4**

# **USER MANUAL**

### 1. READING INSTRUCTIONS

This Manual is a guide to the system "Mobile Video Surveillance". It contains essential instructions for setup and operations.

## 2. INTERFACING OF THE SYSTEM

## 2.1. Interfacing Of Motion Sensor With FPGA

Install the motion sensor at the target area such that when there is some motion in the target area the motion sensor detects the motion. Assign the sensors on the dip switches on FPGA. Their assignment is following:

- Sensor 1 is assigned to U1 FPGA Pin L20
- Sensor 2 is assigned to U1 FPGA Pin L21
- Sensor 3 is assigned to U1 FPGA Pin AE24

## 2.2. Testing The Voltage Of Sim900 Module

Before interfacing the SIM900 module with FPGA check the voltage of the module with the help of DMM. It should be in the range of 3.4V to 4.5V.

### 2.3. Interfacing Of Sim900 Module With FPGA

Interface SIM900 module with J62 pins of FPGA. The connections are as following:

- SIM900 is enabled by GPIO DIP SW1 (D22)
- The system is reset by GPIO SW C (G26)
- SIM900 receiver is connected to GPIO LED 0 (AC22) on FPGA
- SIM900 transmitter is connected to GPIO LED 7 (AD24) on FPGA

### **2.4. CAT-5 Cable Connections**

Connect the following ports through CAT 5 cable with RJ-45 connectors at both the ends.

- IP camera and switch
- Switch and Eth 0 (Copper interface FPGA)
- Eth 1 (Optical interface FPGA) and switch
- Switch and router

## 3. OPERATING THE SYSTEM

After making all the connections, first of all turn on the router, IP camera and switches.

Then turn on the SIM900 module, FPGA kit and motion sensor.

After the SIM900 module is turned on, a message of "POWER" is received at the mobile. When there is some movement in front of the motion sensor, a message of "INT AT LOC 3" will be received at the user's mobile.

### 4. VIEWING THE VIDEO ON MOBILE

In order to view the video on mobile phone open the "IP cam viewer" application installed on the mobile phone. IP camera can also be rotated with the help of this application.

### 5. VIDEO STORAGE ON iSPY SOFTWARE

In order to view the stored video open the iSpy sofware installed on the laptop. The video storage works on 'Record on detect' i.e. whenever some movement is detected, it starts to record the video and it keeps on recording the video until there is no movement. It will record up to 8 seconds after no movement is detected. After that it will stop recording automatically.

### 5.1. Camera Settings

In the camera settings, following settings need to be changed:

- Motion detection
- Alerts
- Recording
- PTZ
- Cloud storage
- Scheduling
- Storage

### 5.2. Video Storage on Detection

When movement is detected, iSpy starts recording the video. The blue boxes appear on detection of an intruder and red dot appears on top right showing recording has started.

The recorded clips are stored in the local user assigned directory.

## 6. CD Contents:

- Project presentation with voice narration
- Project Video
- Project thesis (pdf + word document)
- Codes and executables