# **Defective Pixel Correction** Henrik Backe-Hansen Master of Science in Electronics Submission date: June 2010 Supervisor: Einar Johan Aas, IET Co-supervisor: Christian Stephansen, Aptina Norway Norwegian University of Science and Technology Department of Electronics and Telecommunications # **Problem Description** Implementing a system for detection and correction of defective pixels onto an FPGA Assignment given: 05. January 2010 Supervisor: Einar Johan Aas, IET # **Defect Pixel Correction** by ## Henrik Backe-Hansen ### **Masters Thesis** A thesis submitted in partial fulfillment for the requirement for the degree of Master of Technology Supervisors: Prof. Einar Johan Aas and Christian Stephansen June 23, 2010 Norwegian University of Science and Technology Department of Electronics and Telecommunication ### Assignment This assignment specifies that the candidate must find a method of detecting defective pixels in a data stream from an image sensor and correcting them. All the processing is to take place in hardware and the system should be completed to such a degree that it can function with the constraints imposed when operating in a real time environment. This master's thesis is a continuation of a project [22] with the goal of implementing algorithms for detecting and correcting defective pixels in an image, with the processing done in software. The median, conservative smoothing, gradient and adaptive algorithm were programmed in software and then compared with each other based on their peak signal to noise ratio, mean square error, mean absolute error, simulation time, and survey results. The survey was issued by showing the resulting images from the various algorithms with the same amount of noise added pre correction. The results show a correlation between the statistical values and what the survey showed to be the best image. In other words, the image with the highest levels of the measured values was also the image most participants thought was the best image. It was therefore concluded that the median algorithm produced the best results in terms of measured values and visual inspection, and as, such would be a good choice to implement as part of a master's thesis project. The median algorithm will be implemented in hardware using a development board with an Xilinx virtex 5 fpga. Once the vhdl programming is complete, an embedded system will store the values from the algorithm onto a flash memory. The data can then be inspected by measuring values and be subject to visual inspection. Assignment was given 05.January 2010. Supervisors: Einar Johan Aas, NTNU Christian Stephansen, Aptina Norway #### Abstract When using CMOS technology for image sensors, there is a possibility that any given pixel is defective and will thus produce a value that does not correlate to the amount of light it was subject to. As such, the processing unit will calculate a value that differs from the value produced if the transistor was working correctly. Having a pixel with a defective value can manifest itself as a light spot or a dark spot depending on whether the transistor for that pixel is on or off. In some areas where the value of the defective pixel does not differ greatly from its neighbors, the image will not appear as degraded in the eyes of the viewer as if the defective value was in great contrast to its surroundings. The ability to compensate for the defective pixels with an algorithm will result in a more robust device that is not required to function perfectly in order to produce an image. It also translates into profit as a company can sell image sensors that would otherwise have been discarded by testing procedures. This report is organized with chapter 1 providing the introduction to the assignment in terms of the nature of defective pixels and also creating a context with explanation as to why it is an important aspect of manufacturing image sensors. Chapter 2 describes the development board that is utilized and how an embedded system can utilize a vhdl peripheral. It also shows what components will go into making an embedded system with the required functionality. The theory behind components and techniques used in this project is in chapter 3. The vhdl files to be added to a peripheral so that they can be accessed by the cpu, and the architectures of the vhdl files and microblaze are placed in chapter 4. Chapter 5 contains the simulations of the input images with different noise levels and threshold levels in addition to tests designed to determine the embedded systems functional ability. The vhdl files and the microblaze systems are synthesized with the resulting numbers revealed in chapter 6. The tools used in this project are listed in chapter 7 with their version number. Chapter 8 contains discussions regarding the results and techniques in this project. The concluding remarks and the further work for the project are in chapter 9 and 10, respectively. A list of terms will explain abbreviations used in this report. #### Preface This report along with the system produced are the final products of a project that aimed at implementing a defective pixel correction algorithm with all the processing done in hardware. It also concludes the master's degree with specialization in design of digital systems from the Norwegian University of Science and Technology in Trondheim, Norway. The project spans a wide area with designing both hardware and software to communicate with the hardware. As such, it has been necessary to consult with a few key persons in order to get the project completed, and they all deserve recognition for their contributions. Christian Stephansen at Aptina Norway was instrumental in offering in-depth information regarding the demands on an image sensor. He also gave input to what the end goal of the thesis should be. Professor Einar Johan Aas was the supervisor at the university who was also a part of determining the goal of the thesis along with valuable input as to the organization of the report and serving as a technical consultant. Jan Anders Mathisen was kind enough to lend me the Xilinx evaluation board and point out places to learn about the board that facilitated getting into programming at an early stage. He has also been a technical consultant for helping me problem solve building the microblaze system at times where I was at a stand still. My American relatives Teri Venker and Terry Jacobson graciously opened their home to me and allowed me to live with them in Madison, Wisconsin for the duration of the thesis so I could experience another culture while doing the research. Madison, Wisconsin, U.S.A. June 23, 2010 Henrik Backe-Hansen henrik.backe.hansen@gmail.com # Contents | 1 | $\mathbf{Intr}$ | oducti | on | 1 | |---|--------------------|--------|--------------------------------------------------|----| | | 1.1 | Backg | round | 1 | | | | 1.1.1 | Static Defect | 1 | | | | 1.1.2 | Pixel Defect | 2 | | | | 1.1.3 | Programmable Threshold | 3 | | | 1.2 | Motiva | ation | 3 | | | 1.3 | Object | tive | 3 | | 2 | $\mathbf{Sys}_{1}$ | tem | | 4 | | | 2.1 | | ML501 | 4 | | | 2.2 | | $_{ m blaze}$ | 5 | | | | 2.2.1 | Creating an embedded system with platform studio | 5 | | | | 2.2.2 | System Ace Controller | 9 | | | | 2.2.3 | RS232 | 9 | | | | 2.2.4 | Interrupts | 10 | | | | 2.2.5 | Creating an intellectual property | 11 | | | | 2.2.6 | Access Peripherals | 15 | | | | 2.2.7 | Adding c source file | 16 | | | | | | | | 3 | _ | _ | o v | 17 | | | 3.1 | | n Filter | 17 | | | 3.2 | | of Noise | 18 | | | | 3.2.1 | Salt and pepper noise | 18 | | | | 3.2.2 | Gaussian Noise | 19 | | | 3.3 | _ | S | 20 | | | | 3.3.1 | Histogram | 20 | | | | 3.3.2 | Contrast | 21 | | | | 3.3.3 | Bayer Color Filter | 21 | | | | 3.3.4 | PGM Image Format | 22 | | | 3.4 | Numb | er representation | 22 | | | | 3.4.1 | Hexadecimal scale with base 16 | 22 | | | | 3.4.2 | Decibel scale with base 10 | 23 | | | 3.5 | | epresentation using ascii | 24 | | | 3.6 | Measu | red Values | 24 | | | | 3.6.1 | Mean Square Error (MSE) | 24 | | | | 3.6.2 | Mean absolute error(MAE) | 24 | | | | 3.6.3 | Peak signal to noise ratio (PSNR). | | | | | | | | | | | | | . 25 | |---|----------------|---------|--------------------------------------|---|-----|---|-----|---|-------|---|---|---|---|---|---|------------| | | | 3.6.4 | Real time constraints | | | | | | | | | | | | | . 25 | | | 3.7 | TextIC | O vhdl package | | | | | ٠ | | | | | | | | . 25 | | 4 | $\mathbf{Arc}$ | hitectu | ire | | | | | | | | | | | | | 26 | | | 4.1 | VHDL | Architecture | | | | | | | | | | | | | . 26 | | | | 4.1.1 | Size Package Module | | | | | | | | | | | | | | | | | 4.1.2 | Median module | | | | | | | | | | | | | | | | | 4.1.3 | Image core Module | | | | | | | | | | | | | | | | | 4.1.4 | Ctrl Module | | | | | | | | | | | | | | | | 4.2 | | | | | | | | | | | | | | | | | | 4.3 | | $\mathrm{blaze}$ | | | | | | | | | | | | | | | | 1.0 | 4.3.1 | Hardware Architecture | | | | | | | | | | | | | | | | | 4.3.2 | Software Architecture | | | | | | | | | | | | | | | | 4.4 | | o scripts | | | | | | | | | | | | | | | | 4.4 | 4.4.1 | <del>-</del> | | | | | | | | | | | | | | | | | | Reading Image | | | | | | | | | | | | | | | | | 4.4.2 | Write Image | | | | | | | | | | | | | | | | | 4.4.3 | Measuring Statistical Values | • | • • | • | • • | ٠ | <br>• | • | • | • | • | • | • | . 36 | | 5 | Sim | ulation | 1 | | | | | | | | | | | | | 37 | | | 5.1 | VHDL | module testing | | | | | | | | | | | | | . 37 | | | | 5.1.1 | Median Testing | | | | | | | | | | | | | . 37 | | | | 5.1.2 | Image_core Testing | | | | | | | | | | | | ٠ | . 38 | | | | 5.1.3 | Ctrl Testing | | | | | | | | | | | | | . 41 | | | 5.2 | Test of | f the whole $ m VHDL$ system | | | | | | | | | | | | | . 41 | | | | 5.2.1 | Different noise levels | | | | | | | | | | | | | | | | | 5.2.2 | Different threshold values | | | | | | | | | | | | | | | | 5.3 | Softwa | re algorithms | | | | | | | | | | | | | | | | 5.4 | | $olaze simulation \dots \dots \dots$ | | | | | | | | | | | | | | | | | 5.4.1 | System Ace write to card | | | | | | | | | | | | | | | | | 5.4.2 | Interrupt testing | | | | | | | | | | | | | | | | | 5.4.3 | | | | | | | | | | | | | | | | • | a | .1 | | | | | | | | | | | | | | <b>-</b> c | | 6 | • | thesis | C 41 : | | | | | | | | | | | | | 52 | | | 6.1 | | Synthesis | | | | | | | | | | | | | | | | 6.2 | Microb | plaze Syntethization | ٠ | | • | | • | <br>• | ٠ | • | ٠ | • | • | • | . 52 | | 7 | Too | ls | | | | | | | | | | | | | | <b>5</b> 4 | | 8 | Disc | cussion | ı | | | | | | | | | | | | | 55 | | | 8.1 | | ·<br> | | | | | | | _ | | | | | | | | | 8.2 | | $\mathrm{blaze}$ | | | | | | | | | | | | | | | | 8.3 | | ation | | | | | | | | | | | | | | | | 8.4 | | ime operation | | | | | | | | | | | | | | | | 8.5 | | arison with 2009 fall project | | | | | | | | | | | | | | | | 8.6 | _ | <del>-</del> - | | | | | | | | | | | | | | | | 0.0<br>8 7 | | reting images | | | | | | • | ٠ | ٠ | • | • | • | • | . 97 | | | 8.8<br>8.9 | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | |----|------------|--------|------------------------------------------------------| | 9 | Con | cludin | g remarks 5 | | 10 | Furt | ther W | 7ork 6 | | Bi | bliog | raphy | 6 | | Ат | open | dices | 6 | | 1 | .1 | VHDL | | | | • - | .1.1 | VHDL Source Code | | | | .1.2 | VHDL Test Benches | | | .2 | Microb | olaze files | | | | .2.1 | mss | | | | .2.2 | mhs | | | | .2.3 | ucf | | | | .2.4 | xparameters.h | | | .3 | Microb | olaze Synthesize | | | .4 | Matlal | o Scripts | | | | .4.1 | Read Image | | | | .4.2 | Write Image | | | | .4.3 | Measuring Values | | | | .4.4 | Median algorithm | | | .5 | C Cod | e | | | | .5.1 | Test Compact flash | | | | .5.2 | Test interrupt | | | | .5.3 | Test interrupt with read and write | | | .6 | Images | | | | | .6.1 | Original Images | | | | .6.2 | Lena Images from different noise levels | | | | .6.3 | Lena Images from different threshold levels | | | | .6.4 | Field Images from different noise levels | | | | .6.5 | Field Images from different threshold levels | | | | .6.6 | Canyon Images from different noise levels | | | | .6.7 | Canyon Images from different threshold levels | | | | .6.8 | Image from software simulation 24 | # List of Figures | 2.1 | Xilinx ML501 development board | |------|-----------------------------------------------| | 2.2 | Choosing a board | | 2.3 | Choosing peripherals | | 2.4 | Applications | | 2.5 | Base System Builder Complete | | 2.6 | Create Custom Peripheral guide step 1 | | 2.7 | Peripheral interface | | 2.8 | Interupt service | | 2.9 | Peripheral registers | | 2.10 | Peripheral Interconnect | | 2.11 | Peripheral hierarchy | | 2.12 | Import peripheral complete | | 2.13 | Microblaze address map | | 3.1 | Truncated Original Image Values | | 3.2 | Resulting Truncated Image Values | | 3.3 | Impact of salt and pepper noise | | 3.4 | Impact of Gaussian noise | | 3.5 | Image histogram | | 3.6 | High and Low contrast histograms | | 3.7 | Bayer Filter [5] | | 3.8 | Example PGM file format | | 3.9 | Hexadecimal number representation | | 4.1 | Vhdl file hierarchy | | 4.2 | Size package | | 4.3 | Median Module | | 4.4 | Median module state machine | | 4.5 | Image_core Module | | 4.6 | Image_core module state machine | | 4.7 | Ctrl Module | | 4.8 | Ctrl module state machine | | 4.9 | Vhdl Peripheral hierarchy | | 4.10 | Microblaze Block Diagram | | 4.11 | Microprocessor hardware specification example | | 4.12 | User constraint file example | | | Microprocessor software specification | | 5.1 | Input Sequence | |----------|-----------------------------------------------------------| | 5.2 | Output Sequence | | 5.3 | Image_core input sequence | | 5.4 | Image_core end of execution | | 5.5 | Input Image with noise | | 5.6 | Output image | | 5.7 | Ctrl output sequence | | 5.8 | Peak signal to noise ratio for different noise levels | | 5.9 | Mean square error for different noise levels | | 5.10 | Mean absolute error for different noise levels | | 5.11 | Simulation times for different noise levels | | | Simulation times per pixel | | | Peak signal to noise ratio for different threshold levels | | | Mean square error for different threshold levels | | | Mean absolute error for different threshold levels | | 5.16 | Simulation times for different threshold levels | | 5.17 | Compact flash read and write simulation | | | File written by the isr | | 5.19 | Test Read from a Register | | 6.1 | Synthesis delay | | 6.2 | Synthesis resource utilization | | <b>0</b> | | | 1 | Original noise free Lena image | | 2 | Original noise free Canyon image | | 3 | Original noise free Field image | | 4 | Lena image with noise level 0.001 | | 5 | Restored Lena image from noise level 0.001 | | 6 | Lena image with noise level 0.002 | | 7 | Restored Lena image from noise level 0.002 | | 8 | Lena image with noise level 0.004 | | 9 | Restored Lena image from noise level 0.004 | | 10 | Lena image with noise level 0.006 | | 11 | Restored image from noise level 0.006 | | 12 | Lena image with noise level 0.008 | | 13 | Restored Lena image from noise level 0.008 | | 14 | Lena image with noise level 0.01 | | 15 | Restored Lena image from noise level 0.01 | | 16 | Lena image with noise level 0.02 | | 17 | Restored Lena image from noise level 0.02 | | 18 | Lena image with noise level 0.04 | | 19 | Restored Lena image from noise level 0.04 | | 20 | Lena image with noise level 0.06 | | 21 | Restored Lena image from noise level 0.06 | | 22 | Lena image with noise level 0.08 | | 23 | Restored Lena image from noise level 0.08 | | 24 | Lena image with noise level 0.1 | | 25 | Restored Lena image from noise level 0.1 | |----|--------------------------------------------------| | 26 | Lena image with noise level 0.02 | | 27 | Restored Lena image from threshold level 1 | | 28 | Restored Lena image from threshold level 4 | | 29 | Restored Lena image from threshold level 8 | | 30 | Restored Lena image from threshold level 12 | | 31 | Restored image from threshold level 16 | | 32 | Restored Lena image from threshold level 20 | | 33 | Restored Lena image from threshold level 22 | | 34 | Restored Lena image from threshold level 26 | | 35 | Restored Lena image from threshold level 30 | | 36 | Restored Lena image from threshold level 34 | | 37 | Restored Lena image from threshold level 38 | | 38 | Restored Lena image from threshold level 42 | | 39 | Restored Lena image from threshold level 46 | | 40 | Restored Lena image from threshold level 50 | | 41 | Field image with noise level 0.001 | | 42 | Restored Field image from noise level 0.001 | | 43 | Field image with noise level 0.002 | | 44 | Restored Field image from noise level 0.002 | | 45 | Field image with noise level 0.004 | | 46 | Restored Field image from noise level 0.004 | | 47 | Field image with noise level 0.006 | | 48 | Restored Field image from noise level 0.006 | | 49 | Field image with noise level 0.008 | | 50 | Restored Field image from noise level 0.008 | | 51 | Field image with noise level 0.01 | | 52 | Restored Field image from noise level 0.01 | | 53 | Field image with noise level 0.02 | | 54 | Restored Field image from noise level 0.02 | | 55 | Field image with noise level 0.04 | | 56 | Restored Field image from noise level 0.04 | | 57 | Field image with noise level 0.06 | | 58 | Restored Field image from noise level 0.06 | | 59 | Field image with noise level 0.08 | | 60 | Restored Field image from noise level 0.08 | | 61 | Field image with noise level 0.1 | | 62 | Restored Field image from noise level 0.1 | | 63 | Field image with noise level 0.02 | | 64 | Restored Field image from threshold level 1 | | 65 | Restored Field image from threshold level 4 | | 66 | Restored Field image from threshold level 8 | | 67 | Restored Field image from threshold level 12 218 | | 68 | Restored Field image from threshold level 16 | | 69 | Restored Field image from threshold level 20 | | 70 | Restored Field image from threshold level 22 | | 71 | Restored Field image from threshold level 26 | |-----|-----------------------------------------------------------------------| | 72 | Restored Field image from threshold level 30 | | 73 | Restored Field image from threshold level 34 | | 74 | Restored Field image from threshold level 38 | | 75 | Restored Field image from threshold level 42 | | 76 | Restored Field image from threshold level 46 | | 77 | Restored Field image from threshold level 50 | | 78 | Canyon image with noise level 0.001 | | 79 | Restored Canyon image from noise level 0.001 | | 80 | Canyon image with noise level 0.002 | | 81 | Restored Canyon image from noise level 0.002 | | 82 | Canyon image with noise level 0.004 | | 83 | Restored Canyon image from noise level 0.004 | | 84 | Canyon image with noise level 0.006 | | 85 | Restored Canyon image from noise level 0.006 | | 86 | Canyon image with noise level 0.008 | | 87 | Restored Canyon image from noise level 0.008 | | 88 | Canyon image with noise level 0.01 | | 89 | Restored Canyon image from noise level 0.01 | | 90 | Canyon image with noise level 0.02 | | 91 | Restored Canyon image from noise level 0.02 | | 92 | Canyon image with noise level 0.04 | | 93 | Restored Canyon image from noise level 0.04 | | 94 | Canyon image with noise level 0.06 | | 95 | Restored Field image from noise level 0.06 | | 96 | Canyon image with noise level 0.08 | | 97 | Restored Canyon image from noise level 0.08 | | 98 | Canyon image with noise level 0.1 | | 99 | Restored Canyon image from noise level 0.1 | | 100 | Canyon image with noise level 0.02 | | 101 | Restored Canyon image from threshold level 1 | | 102 | Restored Canyon image from threshold level 4 | | 103 | Restored Canyon image from threshold level 8 | | 104 | Restored Canyon image from threshold level 12 | | 105 | Restored Canyon image from threshold level 16 | | 106 | Restored Canyon image from threshold level 20 | | 107 | Restored Canyon image from threshold level 22 | | 108 | Restored Canyon image from threshold level 26 | | 109 | Restored Canyon image from threshold level 30 | | 110 | Restored Canyon image from threshold level 34 | | 111 | Restored Canyon image from threshold level 38 | | 112 | Restored Canyon image from threshold level 42 | | 113 | Restored Canyon image from threshold level 46 | | 114 | Restored Canyon image from threshold level 50 | | 115 | Restored Lena image when using the software algorithm designed in the | | | 2009 fall project | | 116 | Restored field image when using the software algorithm designed in the | | |-----|-------------------------------------------------------------------------|-----| | | 2009 fall project | 244 | | 117 | Restored canyon image when using the software algorithm designed in the | | | | 2009 fall project | 245 | # List of Tables | 5.1 | Software algorithm results | 48 | |-----|----------------------------|----| | 7.1 | Software utilized | 54 | ## List of Terms FPGA Field Programmable Gate Array FLASH Memory that can retain data even when not powered CPU Central Processing Unit i.e. processor NTNU Norwegian University of Science and Technology CMOS Complimentary Metal Oxide Semiconductor MATLAB Mathematical tool for technical computing I/O UNIT Input and Output unit VHDL Hardware Descriptive Language INTERRUPT Signal to the cpu that an IO unit needs attention TEXTIO Vhdl package that enables write to file and read from file BAYER SENSOR A way of representing colors from an image sensor MICROBLAZE Xilinx soft core cpu on the fpga BSB Base system builder to help make embedded design XPS Xilinx platform studio, a tool for working with the cpu RS232 Serial communication protocol LCD Liquid Crystal Display LED Light Emitting Diode HARVARD ARCHITECTURE Separate storage for instruction and data DDR2 MEMORY Double Data Rata Synchronous Memory DSLR Digital Single Lens Reflex FPS Frames per Second BSB Base System Builder PLB Processor Local Bus ILMB Instruction Local Memory Bus DLMB Data Local Memory Bus BRAM, BRAM Storage elements inside the fpga DSP Digital Signal Processing NETLIST Physical description of the system BITFILE A filetype used to program the fpga BITSTREAM The information inside a Bit file ISR Interrupt Service Routine BAUDRATE Rate at which new symbols arrive on a serial line PARITY Error checking mechanism for serial communication START BIT Bit that starts a serial communication STOP BIT Bit that signifies stop of data UART Universal Asynchronous Receive Transmit FIFO First in First out stack memory IP Intellectual Property IPIC Intellectual Property Interconnect IPIF Intellectual Property Interface HEADER FILE File that contains the method of a c file with the same name WRAPPER FILE Vhdl representation of a system component MS Milli Second NS Nano Second MHZ Mega Hertz HZ Hertz KHZ Kilo Hertz LUT Look Up Table SLICE Programmable fpga elements that contains LUTs KB Kilo Byte GB Giga Byte PGM Portable Gray Map CF Compact Flash HEXADECIMAL Number representation with base 16 MHS Microprocessor Hardware Specification MSS Microprocessor Software Specification UCF User Constraint File dB Decibel GB Giga Byte (10<sup>9</sup> byte) F-stop 1 f-stops is Decreasing / Increasing the amount of light by a factor of two .vhd VHDL FILE POSTFIX # Chapter 1 # Introduction This thesis is the continuation of a project that was aimed at creating, comparing and evaluating different methods for correcting defective pixels in an image with all the processing done in software. The projects aims at implementing the best method from the software project into hardware. The assignment is specified by Aptina Norway in conjunction with the Norwegian University of Science and Technology. ## 1.1 Background Defective pixels are caused by an error in the fabrication of the image sensor that translates into a transistor being either static on or static off and will thus translate into the cpu interpreting false value from the pixel. The next sections will describe how defective pixels can manifest themselves on an image and variables involved in the detecting and correcting algorithm. #### 1.1.1 Static Defect Static defective pixels in an image are types of defects that will contribute towards degrading the image on every exposure and in the same way every time. That means that a defective pixel in position (a,b) in the image will show the same value on every image regardless of the amount of light it is subjected to. Static defective pixels can further be divided into two categories of "always-on" and "always-off" where an always off transistor never has any current flowing through it and with an always on transistor having current flowing through it at all times. In a correctly working pixel, the current that flows through a transistor is correlated with the exposure time of the image. A transistor with no current flowing through it will always be interpreted by the cpu as the value 0, corresponding the white color using an 8- bit gray scale color representation. Having a transistor that has current flowing through it at all times will be interpreted by the cpu as the value 255 using the same 8-bit gray scale color representation and it will result in a black color. The idea behind defective pixel correction is to replace defective pixels with the median of the neighboring pixels of the same color according to the Bayer image filter pattern found in section 3.3.3. The end result will have new pixels in the positions of the defective pixels going into the algorithm. The different correcting algorithms mostly differ in the way they calculate the value of the pixel that was defective. The median algorithm utilizes the value of the nine neighboring pixels and replaces the defective pixel with the median of the neighboring pixels. The task becomes even more complex as it is advantageous to have a new pixel value not being based on values that are themselves defective. An even more complex issue is the demands put on an image senor from a camera application when operating in real time and making sure that the system can cope with the demands. #### 1.1.2 Pixel Defect Single defective pixels in an image are situations where the surrounding neighboring pixels are giving off the correct value. Multiple defective pixels, however, can have defective pixels as neighbors, thus complicating the search for working pixels on which to base the new values. #### Individual Pixel Defect With only a single defective pixel in an area, the corrective measure is to assign a new value to the position of the defective pixel based on the nine neighboring pixels of the same color. The algorithm designed adds a two pixel border of the value 127 (for 8 bit image). The border will enable searching for defective pixels at edges and corners all with the same algorithm. The downside to using a border with fixed values is that defective pixels towards corners and edges gets a value that is not based on the values in the vicinity but rather a fixed value, which can lead to a somewhat strange color for that pixel. #### Multiple Pixel Defects An image exposed to high levels of noise is prone to have situations where a defective pixel has a defective pixel as its neighbor of the same color. The adaptiveness of the proposed algorithm will detect this and treat it accordingly by ensuring that no defective values are used in the calculation of a pixel. That is accomplished by having the detection and correction done in separate steps by searching through the image and marking all the positions that are defective. The correction algorithm can then correct values based for every position that is defective while still not utilizing values that are flagged as defective. In the case of a defective value being a target for calculation of another defective pixel, the first defective is replaced by the number 127, which is the middle value for 8-bit values. ### 1.1.3 Programmable Threshold In order to classify any pixel as defective they need to be compared with their neighbors of the same color. The detection algorithm, therefore, needs to know the highest and lowest value of the neighboring pixels, excluding the value of the pixel in question, in order to ascertain whether or not the position should be classified as defective. The threshold [30] is the value that is added to the highest value and subtracted from the lowest value in order to produce an acceptance range of values that are considered to be not defective. Having a value falling outside this range will require the pixels position to be classified as defective. Different images may require different threshold in order to produce the best result. That is why the threshold variable can be altered in the vhdl file package. An image with high contrast has large differences between closely related pixels without the pixels being defective while a low contrasting image does not have such large differences. The programmable threshold is designed to account for different images being processed with different thresholds. ### 1.2 Motivation Being able to correct defective pixels from an image sensor with defective values has the benefit of being able to sell image sensors with defective values that would otherwise have been rejected by test procedures. It will also enable the correction of defects that occur only after some time and so make a more robust device as far as errors are concerned. ## 1.3 Objective This project aims at producing a system that can detect and correct defective pixel values from an image with all the signal processing is done in hardware. A software system is required to read values produced by the processing unit. The resulting image will have to be interpreted visually by a human eye and by the means of statistical values in order to ascertain the algorithm's ability to correct pixels. The resulting image will be a more esthetically pleasing version of the noise degraded input image with fewer visual pixel defects. # Chapter 2 # System ## 2.1 Xilinx ML501 Figure 2.1: Xilinx ML501 development board Xilinx ML501 is an evaluation board with a vertex 5 fpga and a soft core microblaze processor. It has built in DDR2 memory and system-ace to communicate with the compact flash card, and serial communication using the rs232 protocol. It has an LCD display and pushbuttons and LED lights as general purpose I/O. It also has input and output capabilities as far as audio and video are concerned. This project merely utilized a few of its features. The name of the physical pins on the board are specified in [26]. ## 2.2 Microblaze Microblaze is a soft core cpu using Harvard Architecture on the evaluation board. It contains separate data local memory bus (dlmb) and instruction local memory bus (ilmb) in addition to a processor local bus (plb) for connecting the cpu to peripheral components. The system can be customized by adding peripheral units with different functionality in order to tailor a system to specific needs. The cpu model used in the system includes some peripheral units like the system ace controller, vhdl design, rs232 and interrupt controller. The system ace controller is an interface for communication with the compact flash card using read and write commands. The vhdl peripheral contains the vhdl files that actually do the correction processing of defective pixels. Those values are then stored in a register that is accessible by software functions. The next section will explain the methods in the system ace interface and the storing of values from the vhdl peripheral. The interrupt controller relays any interrupt from a peripheral to the cpu so it can execute its interrupt service routine. The rs232 is the default standard input and output for the processor, but it will not be utilized in this project as a debugging tool. ## 2.2.1 Creating an embedded system with platform studio The Xilinx platform studio has a feature called the base system builder wizard that greatly simplifies the task of creating an embedded system to interact with the fpga as it asks for the different parameters in the system and then produces templates and drivers for the system [31, 32]. The wizard will ask where the project is to be placed on the disk and the name of the system. Based on those inputs it creates a folder with all the necessary files for the project. The various postfixes for the files in project directory can be found in [20]. The wizard then asks if the designer would like to specify a custom board or to use an already made development board in the list. The project used a Xilinx ml501 as is evident in figure 2.2. Figure 2.2: Choosing a board The wizard will offer the option to make the processor as a stand alone system or as one of many processors in a system. The next step in the wizard is specifying the clock frequency at which the cpu is to operate. There may be some limitation for the frequency for certain peripherals as they may need a certain frequency. Here, the option to add some memory to the processor is also available that can be turned into cache memory for the processor. This project will stay with the default 125 MHz frequency and 8 KB of local memory for instructions and data. Figure 2.3: Choosing peripherals Figure 2.3 shows how different I/O units can be added to the plb bus and also internal peripherals can be added to the cpu. The external I/O devices communicate with recourses on the board like the LED and the push buttons, in addition to resources off the chip like ethernet, and rs232. The application screen shown in figure 2.4 lets the designer choose what memory to run the built in tests off of and also the standard input and output for the system. This project does not have any external memory, so all instructions for the cpu are stored in local block ram inside the fpga. The RS232 serial connection is default as the standard input and output. It will remain in the system to fulfill its duties but it will not be used for printing status messages as the computer used does not have an RS232 serial port. Figure 2.4: Applications The wizard is now done with all the information it needed to set up the system and after some waiting time the screen will show what is in figure 2.5, which is the home screen of the system with information on the hardware connection as well as the software files. The applications tab shows the two default projects TestApp\_Memory and TestApp\_Perpherial that were created by the wizard. These two projects can be used to run a test on the system so to ensure that it the hardware can communicate with the software correctly for both the memory and the connected peripheral units. The "Ports" tab in the figure shows all the internal and external ports associated with the cpu's address space while the "Addresses" tab shows the address range of all the peripherals connected plb bus. Figure 2.5: Base System Builder Complete It is now time to download the two created test projects to the fpga, one by one, to make sure that the cpu can access the connected peripherals. The first step is to go to the software tab in the main window to "generate libraries and dsp". That will create the libraries with functions that are associated with the peripherals in the system. It is then time to make this project the default project for initializing the bram on the fpga, which means that the data in this project will be placed in the block ram for instructions so that the cpu will execute those instruction when it is turned on. The software source code has to be compiled with the "build project" command. The result of compiling the source is an executable file. The "generate netlist" command reads the executable file and generates an vhdl description of the components in the system and then runs synthesis on those files while the "generate bitstream" takes the netlist files and creates a bit-file that contains the entire embedded system. The bit file is the same format that is used to program an fpga. The software source files needs to be injected into the bitstream in order to get the cpu to execute those instructions. The bit file is complete when the software has been injected into the bit file, and can be downloaded to the fpga with the Impact tool. The Impact tool can program the fpga by creating an ace file or by using a cable to the fpga. For this project it will create an ace file from the bit file which in turn is copied into the compact flash card at address 6. All that is left is to insert the compact flash card into the card reader on the board, power it up, and select the ace file at position 6 as the source file for the cpu. Running the TestApp peripheral will do a test of the connected peripherals e.g. printing strings to a computer connected to the rs232 serial port or flash the LEDs if they are connected. ### 2.2.2 System Ace Controller The system ace controller is an interface between the compact flash card and the processor local bus. It makes sure that the plb bus and the cf card can communicate and that the timing is correct. The controller and all its specifications are given in [29]. The library generated for the system ace controller contains functions to read from the device and write to the device. There is, however, a library called xilinx xilfatfs [28] that further simplifies the interaction with the cf card by the means of functions to open, read, write and close a file. The functions available using the Xilfatfs library, for interacting with the compact flash card, are: ``` sysace_fopen (file, mode) sysace_fread (buffer,size,count,file) sysace_fwrite (buffer, size, count,file) sysace_fclose (file) sysace_mkdir (path) sysace_chdir (path) ``` Interaction with the cf card requires that certain steps are done in the correct order. The first step is to make a directory where the file should be located and then open the file in read or write mode, depending on what is the desired operation. The directory is specified using the sysace\_mkdir command while opening a file in write mode is done with the sysace\_fopen(file, 'w') function. It is now ready for communication with the cf card using the sysace\_fwrite function (assuming that the file was opened in write mode). Upon completion of writing the data, the file has to be closed using the sysace\_fclose function. The function sysace\_fread is used when the target file is opened in read mode, and the sysace\_chdir is a function to change a working directory. #### 2.2.3 RS232 The rs232 protocol is a communication protocol for serial communication with one transmitter and one receiver. The signals used in the communication can be seen in [24] along with the parameters used to setup communication between two participants. Platform studio offers a version of the rs232 called uart lite that only contains the receive and transmit pin as external pins from the chip. This has the added benefit of not requiring knowledge of the entire rs-232 protocol in order to initiate communication. Uart lite is also the default std\_in and std\_out for the cpu. This module can be used for printing status messages to a connected computer so it is in fact a debugging tool for the software platform. A serial communication contains several parameters that must have the same values on the transmitter and the receiver side for the receiver to decode the message correctly. Parameters that need to be specified are the stop bit, start bit, baud rate and parity. The start bit is a message to the receiver that the first bit of the message is being transfered. This is based on the protocol being asynchronous and therefore used the start bit to synchronize with the transmitter. The start bit will therefore synchronize receiver and transmitter. The stop bit denotes the end of the message and acts as a resynchronizations tool if the receiver, for whatever reason, did not receive the start bit and therefore not the message. The parity bit is an error checking tool where the transmitter generates a bit value that the receiver can use to determine whether it received the same message that was sent. ### 2.2.4 Interrupts There are two basic methods for a peripheral to let the processor know that it needs attention; polling and interrupts. Polling is a method where the processor will ask the various peripherals if they have any data for the processor. It will ask each peripheral every time period. This method can work great for systems that only operate on data from peripherals, but will not be such a great choice if the data from the peripherals is not essential for the processing at all times. This system will only act on the data from the interrupts, but it was chosen to use an interrupt controller in order to gain experience with setting up and handling interrupts. Xps offers an interrupt controller that relays interrupts from the peripherals to the cpu. It is connected to the cpu's interrupt port, on one side, and the interrupt signal from the peripheral on the other side. Interrupt based systems are methods where the peripherals will tell the processor when it needs attention and thus only take up processing time when it needs to communicate with the cpu. Good tutorials for creating interrupt based systems can be found in [14, 27]. The system implemented for this project utilizes an interrupt based processor so that it receives an interrupt from the vhdl peripheral that it wants attention, and the processor will go into its interrupt service routine (isr) to execute the instructions for that interrupt. When an interrupt "fires", the processor will store its current values and go into its isr. When the processor completes its isr, it will load the values it had prior to the interrupt as to continue execution where it left off before the interrupt. #### Interrupt Controller The vhdl peripheral will set the interrupt flag of the interrupt controller when it needs to communicate with the processor. One interrupt line can be directly connected to the processor's interrupt port, but having multiple interrupt lines requires the implementation of an interrupt controller that can act as an arbiter to make sure every interrupt gets serviced. It will act as a decoder for interrupt lines for various peripherals as the processor has only one interrupt port. The interrupt controller can relay information to the cpu of the peripheral that triggered an interrupt so the correct isr is executed. When a peripheral sets the interrupt flag high, that will signal to the interrupt controller that it wants to communicate with the processor and the interrupt controller in turn sets the processor's interrupt line high. This is the message to the cpu to go into the isr of the source of the interrupt. The specifications of the interrupt controller can be found in [33]. #### Interrupt enabling When setting up interrupts on a processor it is essential that they are set up correctly on all devices that set, handle and relay the interrupt. It needs to be enabled on the peripheral, interrupt controller and in microblaze in this situation. It is also important that the interrupts are acknowledged on the peripheral and the interrupt controller before de asserting the processor interrupt line to low. This is to avoid a situation where an interrupt is never acknowledged and is therefore blocking all other instruction to the cpu as the cpu will think the peripheral is asking for a new interrupt and go into its isr again. #### Interrupt service routine Is r is the instructions that are executed every time a given peripheral triggers an interrupt. Different peripherals have different is that are executed. It is therefore imperative that the source of the interrupt is found so as to ensure the correct is is being executed. On this project the vhdl peripheral will assert the interrupt signal on the bus and then it is sent to the interrupt controller that will relay the interrupt to the processor. ### 2.2.5 Creating an intellectual property Xps has a wizard for creating peripherals that can be connected to the cpu in such a manner that the designer does not need to know the specifics of the bus protocol in order to access data on a peripheral but can rather communicate on the bus using a few signals. Tutorials on how to create an custom IP and utilize its features can be found at [1, 25]. Figure 2.6 shows the start of the guide where the designer can choose to create a template for a custom peripheral or import an already-made peripheral. Choosing to create a template results in the wizard creating the vhdl wrapper files that enable communication between the custom ip functionality and the plb bus. Once a peripheral is created and the default vhdl files created by the wizard altered, the peripheral has to be imported back into xps with the new changes in order to get a custom ip with the desired functionality. Figure 2.6: Create Custom Peripheral guide step 1 The ipif screen shown in figure 2.7 is where the designer will choose what modules to be implemented into the peripheral. The ability to have read and write fifo, interrupts, memory space or register space can all be specified in the ipif section. This project will utilize an interrupt mechanism for the peripheral to communicate to the cpu that it needs attention and it will include the default checked boxes in the "user logic software register" and "include data phase timer". Figure 2.7: Peripheral interface The user logic software register was chosen by the designer so a determination has to be made as to how many software accessible registers the peripheral should contain. These registers are named $slv_reg0-slv_reg(N-1)$ for N specified registers. It can been seen from the vhdl file user\_logic that it specifies how to read and write to any of the accessible registers. Figure 2.8: Interupt service The next step is specifying the number of interrupts needed in the system and also if the interrupts should be captured as inverted, low level or high level. The wizard will create signals in the user\_logic file that is connected to the interrupt signal on the plb bus. The interrupt mechanism can therefore be accessed by assigning a signal within the vhdl module. By opting for the user logic register in figure 2.7, the number of registers is specified in figure 2.9. The number of registers chosen can be seen in the user\_logic module with each register having a signal assigned, in order for functions in software to read from the registers and write to the registers. Figure 2.9: Peripheral registers The ipic is the tab where all the signals from the ipif module to the user\_logic module are specified, also with the option of checking a new signal that the designer may opt to use. The signals in the tab are shown in figure 2.10. These signals represent a simplified version of the plb bus signals. The signals will be utilized in the peripheral in order to communicate with the ipif that in turn communicates with the plb bus. Figure 2.10: Peripheral Interconnect The hierarchy of the custom peripheral is shown in figure 2.11 with the peripheral being the top level module with the ipif module on the level below and the user\_logic module on the lowest level. There are options for the wizard to create ISE project files for the peripheral and also to make templates for the driver of the peripheral. The created ISE project facilitates easier importation into platform studio as the files can be synthesized prior to being imported. Figure 2.11: Peripheral hierarchy The custom peripheral wizard has now created the two vhdl files as a wrapper for the peripheral. The files are called my\_custom\_ip\_register.vhd and user\_logic.vhd where my\_custom\_ip\_register.vhd is the wrapper for the ipif while the user\_logic is the file where the designer can add functionality given the set of signals shown in figure 2.10. These files are located in the process folder in the working directory. The folder contains all custom ip modules created by the wizard. Figure 2.12: Import peripheral complete The newly created custom ip is located in the IP catalog under user cores and must now be added to the project and have a connection to the plb bus established. The only step left then is to go to the address tab in order to assign an address range for the peripheral so that the processor can communicate with it. The hardware part of connecting the peripheral is now complete but the designer still needs to run the "generate libraries and dsp" command from the software tab in order to create the new libraries with the functions that are associated with the custom peripheral. When the libraries are generated the software will recognize the functions associated with the peripheral. ## 2.2.6 Access Peripherals The cpu has a memory map that indicates which addresses belong to which peripheral. The memory map is a division of the total memory of the cpu divided by the different peripherals and their memory needs so that every unit can be accessed by using those addresses. The various peripherals may need different space allocated in the memory so they will thus have narrower address ranges. The Xilinx Platform Studio makes this memory map an automated feature so the user does not need to specify anything other than the memory needed for each peripheral. There are two variables that are important when a peripheral is to be accessed; the base address and the high address. The base address is the starting address for the peripheral and the high address is the end address of the peripheral. Both addresses are given in hexadecimal numbers. The example given in figure 2.13 illustrates the different peripherals in the system along with their base address, high address, memory size and connection to the bus. The modules all have header files that describe the methods that are associated with that peripheral and also the offset to the different registers within a peripheral. Within the custom peripheral there are methods for reading from a register, writing to a register and setting up interrupts. | imicroblaze_0's Address Map | | | | | | |-----------------------------|------------|------------|------------|------|--------| | dlmb_cntlr | C_BASEADDR | 0x00000000 | 0x0001FFFF | 128K | dlmb | | ··· ilmb_cntlr | C_BASEADDR | 0x00000000 | 0x0001FFFF | 128K | ilmb | | xps_intc_0 | C_BASEADDR | 0x81800000 | 0x8180FFFF | 64K | mb_plb | | SysACE_CompactFlash | C_BASEADDR | 0x83600000 | 0x8360FFFF | 64K | mb_plb | | RS232_Uart | C_BASEADDR | 0x84000000 | 0x8400FFFF | 64K | mb_plb | | mdm_0 | C_BASEADDR | 0x84400000 | 0x8440FFFF | 64K | mb_plb | | my_custom_ip_register_0 | C_BASEADDR | 0xCCC00000 | 0xCCC0FFFF | 64K | mb_plb | Figure 2.13: Microblaze address map The cpu can access the system ace controller using the address range from base address to high address. The size of the address space can be determined by subtracting the base address from the high address. As an example the high address of the system ace controller is 0x8360FFFF and the base address is 0x83600000. Subtracting the base address from the high address leaves us with the address space in bytes. The address space of the system ace controller is 65536 or 64k. The amount of memory is also shown in the address map in order to simplify the calculation of the amount of memory for a given peripheral. The header file of a given peripheral specifies what the different addresses of the peripheral will accomplish. ## 2.2.7 Adding c source file Creating a new c source file for a project is done by clicking on the sources tab and the select "add existing file or add new file". This will create a new file to one of the two processes created by the wizard. The c code will be executed by the cpu if the process it belongs to is set to initialize the block ram. The file is accessible from the "sources" menu in that process. Utilizing functions from a peripheral requires that its header file is included at the start of the c file and also added to the "header" menu in the process. # Chapter 3 # Supporting Theory This chapter will contain the information needed to understand the techniques used in the project, and evaluate the results of the algorithm for detecting and correcting defective pixels in an image. ## 3.1 Median Filter This thesis employs a median algorithm for correcting pixels that are classified as defective. The algorithm will then gather the values of the eight neighbors of the same color, and assign the median of those values as the new value at that position. Figure 3.1 shows some values that will be used to explain the operating procedure of the median filter. Let's assume that the threshold for detection is 10. That means that any value higher than threshold + the highest value, or lower than threshold - lowest value is classified as defective. ``` \begin{bmatrix} & \vdots & \vdots & \vdots & \vdots & \vdots \\ \dots & 114 & 115 & 102 & 92 & 72 & \dots \\ \dots & 140 & 115 & 128 & 111 & 121 & \dots \\ \dots & 100 & 101 & 127 & 103 & 113 & \dots \\ \dots & 141 & 201 & 90 & 131 & 61 & \dots \\ \dots & 117 & 119 & 99 & 97 & 120 & \dots \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots \\ \end{bmatrix} ``` Figure 3.1: Truncated Original Image Values The first step with this algorithm is to calculate the maximum and minimum values not including the pixel in question. The values chosen for the middle pixel in ascending order are {72 99 100 102 113 114 117 120 127}. The extreme values, not including the middle pixel, are 72 and 120. The middle pixel will be classified as defective when using a threshold larger than 7 and classified as a working pixel with a threshold lower than 7. In this instance it is assumed that the threshold is such that the middle pixel is classified as defective. Next step in to replace the defective value with the median of the neighboring pixels of the same color. In this example the median is 113. ``` \begin{bmatrix} & \vdots & \vdots & \vdots & \vdots & \vdots \\ \dots & 114 & 115 & 102 & 92 & 72 & \dots \\ \dots & 140 & 115 & 128 & 111 & 121 & \dots \\ \dots & 100 & 101 & 113 & 103 & 113 & \dots \\ \dots & 141 & 201 & 90 & 131 & 61 & \dots \\ \dots & 117 & 119 & 99 & 97 & 120 & \dots \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots & \end{bmatrix} ``` Figure 3.2: Resulting Truncated Image Values # 3.2 Types of Noise In the previous sections the main focus has been on detecting and correcting defective pixels. The appearance of a defect pixel can be seen as noise when put under scrutiny from an observer. It is therefore possible to model a defective pixel as noise on a testimage in order to conclude which algorithm produces the most esthetically pleasing image when removing the noise. There are two dominating sources of noise in an image; salt and pepper noise and Gaussian noise. The next section will describe them in detail. # 3.2.1 Salt and pepper noise Salt and pepper noise is a somewhat typical noise seen on images with defective pixels. It manifests itself as white spots (salt) or black spots (pepper) on the image [19]. A white spot is caused by a false saturation on the image sensor while the black spot is caused by a failed response of the same image sensor. These defects are usually the result of an error on the fabrication of the image sensor. It can be modeled in matlab were a value (typically 0.01) will determine the probability that a given pixel is corrupted with noise and so interpreted as either a black or white pixel. Statistically this kind of noise has zero mean value and is, thus, described completely by its variance. This kind of noise can be successfully removed based on the understanding that the corrupted pixels will have a very high or very low value. As such it will stand out in comparison to its neighboring pixels, assuming that they work correctly, and the removing filter does not need to be very complex, although a very good reconstruction of an image still requires a degree of complexity in the algorithm to deal with different contrast in the same image. Figure 1 shows an original Lena image [15] and 3.4(b) shows the same image corrupted with salt and pepper noise. The algorithm presented in this thesis will start with an image corrupted by noise and then manipulate it to get as close to the original images as possible. (b) Lena corrupted by salt and pepper noise Figure 3.3: Impact of salt and pepper noise #### 3.2.2 Gaussian Noise Gaussian noise is a noise type that can corrupt pixels with any value within the range of values [11]. Some pixels may be slightly altered while others may be severely altered, thus making the job of detecting and correcting them far more difficult. This type of noise can be added to an image when it is transferred over a noisy information channel. As it is not the scope of this project to remove Gaussian noise, it is only serves the purpose of adding to the understanding of how different noise sources corrupt an image. Gaussian noise has a probability density function (pdf) that describes the probability of a value being within a certain range (see equation (3.1)). The Gaussian noise also has a zero mean value and is described by its variance. $$F(x) = \frac{1}{\sigma\sqrt{2\pi}}e^{-(x-\mu)^2/2\sigma^2}$$ (3.1) In equation (3.1) $\mu$ is the mean value and $\sigma$ is the standard deviation. For a normal distribution the $\mu$ is zero and $\sigma$ is 1. The fact that pixels corrupted by Gaussian noise can have any value makes them harder to detect and correct in the time domain. They may not stand apart from the neighboring pixels, like with the salt and pepper noise, but rather be assigned random values to random pixels. Figure 3.4 shows the impact of Gaussian noise on an image alongside the original image. (b) Lena corrupted by Gaussian noise Figure 3.4: Impact of Gaussian noise # 3.3 Images ## 3.3.1 Histogram Most modern digital cameras have the option of displaying the histogram of the image along with the image itself on the screen of the camera. The histogram is a graphical representation of the exposure with regards to the balance of highlights, mid-tones and shadows [13]. Having few components in the shadow-or-highlights will result in an image that is over exposed or under exposed. A perfect exposure will have components in all the three regions in a histogram. Using an 8-bit image will result in a histogram in the range of 0-255(sometimes expressed as $8\ F$ -stops). Figure 3.5 shows the different tones of an image with its corresponding grey-level range. Looking at the histogram it can be concluded that the image has all its components within the mid-tone and shadows area and as such does not have any highlight components. The rectangular bar at the bottom represents the grey scale with color level and corresponding pixel count. Figure 3.5: Image histogram ### 3.3.2 Contrast A histogram contains several important aspects that will tell a photographer how the different components within the image relate to one another. There are, however, other measures that can be read from the histogram such as the overall contrast of an image and exposure. The contrast is the ratio of the largest component and the smallest component of the histogram. A small ratio, corresponding to a narrow set of values on a histogram, will cause the image to have a low contrast. Having a large ratio will result in a high contrast image. Figure 3.6: High and Low contrast histograms ## 3.3.3 Bayer Color Filter The Bayer color filter [4] is used for arranging colors on a square image sensor. It consists of 50% green, 25 % blue and 25% red. The green color is usually divided into green for red and green for blue so that it really is composed of four different colors. Since it has more than twice as much green values as red and blue combined, it is sometimes called RGBG or RGGB. The correction algorithms need to evaluate only pixels with the same color for any given position which is done by looking at pixel ( $i\pm 2$ , $j\pm 2$ ) assuming that the middle pixel is at position (i,j). The Bayer values are light intensities of red, green, Figure 3.7: Bayer Filter [5] and blue from the image sensor. It is the job of the processor to convert these light intensities into pixel values in order to obtain a RGB image, which is done by looking at the intensity of the neighboring pixels. Each intensity can range from 0 to 255 in an 8 bit image thus resulting in 16.7 million possible combinations. It can be observed that the next neighbor of the same color is two pixels up, down, left and right so that will dictate how the search for neighbors will go on. This pattern will be utilized in the vhdl part in order to find the next neighbors of the same color to be able to classify a pixel as defective. ## 3.3.4 PGM Image Format PGM image formats [18] is an abbreviation for Portable Gray Map where the pixel values indicate a light intensity. An image with 8 bits per pixel will result in 256 different levels from black to white. The interesting aspect of PGM image format is that there is no data compression so the pixel values can be read directly from the image. The file format consists of a file header and the image data. The header consists of a number P1-P5, the size of the image in the x and y direction, and the maximum value. An example PGM file showing the number eight looks like figure 3.8. ``` P2 5 7 15 0 0 0 0 0 0 15 15 15 \ 0 0 15 0 15 0 0 15 15 15 0 0 15 0 15 0 0 15 15 15 0 0 0 0 0 0 ``` Figure 3.8: Example PGM file format # 3.4 Number representation There are several ways of representing a number with the decimal system begin the predominant system. In scientific research there are situations where using the decimal system would be inefficient, e.g representing large memory spaces. The hexadecimal scale is used when dealing with cpu address spaces while the logarithmic scale is used in measuring decibel in an audio visual system. #### 3.4.1 Hexadecimal scale with base 16 The hexadecimal number system [12] is a positional system with a radix or base of 16. There are then sixteen distinct values in the hexadecimal system where 0-9 is the same as the decimal 0-9 and A-F represents decimal 10-15. The hexadecimal number 3CB is equal, in decimal, to $(3*16^2) + (12*16^1) + (11*16^0) = 971$ . A hexadecimal number is often denoted by a 0x number as a prefix or as a postfix number<sub>16</sub>. The use of an identifier is to avoid ambiguity with the number as the decimal number $140_{10}$ is not equal to the hexadecimal number $140_{16}$ . Figure 3.9 shows the different hexadecimal numbers along with their decimal value and its binary value. | Hex | Decimal | Binary | |-----|---------|--------| | 0 | 0 | 0000 | | 1 | 1 | 0001 | | 2 | 2 | 0010 | | 3 | 3 | 0011 | | 4 | 4 | 0100 | | 5 | 5 | 0101 | | 6 | 6 | 0110 | | 7 | 7 | 0111 | | 8 | 8 | 1000 | | 9 | 9 | 1001 | | A | 10 | 1010 | | В | 11 | 1011 | | С | 12 | 1100 | | D | 13 | 1101 | | E | 14 | 1110 | | F | 15 | 1111 | Figure 3.9: Hexadecimal number representation Hexadecimal numbers can be broken down to a binary representation by replacing each number by its binary representation according to figure 3.9. Hexadecimal numbers are used in this project for representing addresses in the address space of the cpu. An address can have the value 0x2F, where the prefix denotes that it is a hexadecimal number. The number 2 is replaced by the binary representation of 2 (0010) and the F is replaced by the binary representation of 0x2F is therefore 00101111 but the leading zeros in a binary representation can be skipped so the resulting number is 101111. The hexadecimal representation can be used to represent large numbers with fewer digits than its binary and decimal representation. #### 3.4.2 Decibel scale with base 10 The logarithmic scale [16, 9] used the logarithm of a value instead of the value itself. The value 100 is replaced by 3, as $3 * log_{10}$ is 100. There are different bases, or radix for the logarithmic scale but for measuring decibel (dB) the base 10 is used for the calculations. Large values become more manageable when using the logarithmic scale. Humans hear in a logarithmic scale, so that is why it is extensively used to measure the quality of an audio systems. The decibel values will be used when measuring the peak signal to noise ratio in the simulation chapter. The formula for calculating a decibel value is in equation (3.2), where $p_0$ and $p_1$ are the measured values from inp ut to output. $$[H]dB = 10 * log_{10}(\frac{P_o}{P_1})$$ (3.2) An increase in decibel from 4 dB to 5 dB represents an increase from 2.51 to 3.16 in real value. Having zero decibel from a system means that the output and the input have the same physical value. If the fraction $P_0/P_1$ is larger than one, the resulting decibel value is positive while it is negative if the fraction is less than one [8]. # 3.5 Text representation using ascii Ascii is the abbreviation for American standard code for information interchange [3, 2] and is a numerical representation of the alphabet. This is useful as a computer cannot interpret a character but rather the ascii value of the character. The initial ascii setup contained 127 characters and thus required seven bits in order to represent all possible combinations. Most of these characters are printable characters like letters and numbers while some characters are non-printable but these are mostly now being considered obsolete. An upper case letter and a lower case letter do have different representation in the ascii coding scheme. Having more bits available introduces more possible symbols to be represented in order to include special letters from different languages. [3] shows the 256 symbols that are represented by 8 bits. The word t-e-s-t is interpreted by a computer as 116-101-115-116 using an 8 bit ascii table. ## 3.6 Measured Values When comparing two images, there are several values that describes the image. The next section will show the measures used in this project. ## 3.6.1 Mean Square Error (MSE) $$MSE = \frac{1}{mn} \sum_{i=0}^{m-1} \sum_{j=0}^{n-1} (I(i,j) - L(i,j))^2$$ (3.3) Equation (3.3), used for images, measures the squared difference between the reconstructed image and the original image. The reconstructed image will not be pixel wise identical to the original image and this method measures how far they are apart in squared value [21]. I(i,j) is the value of the reconstructed image while L(i,j) is the value of the original image. Lower values of mse will translate into a better quality image (see equation 3.5). # 3.6.2 Mean absolute error(MAE) The mean absolute error [17] shows how the values of the reconstructed image compare to the values of the same pixel in the original image and averages that value. Equation (3.4) shows the formula for calculating the mean absolute error. 3.4 $$MAE = \frac{1}{mn} \sum_{i=1}^{m-1} \sum_{j=1}^{n-1} |I(i,j) - L(i,j)|$$ (3.4) ## 3.6.3 Peak signal to noise ratio (PSNR) Peak signal to noise ratio indicates how the maximum signal power compares with the maximum noise power for two images. It is a measure to tell how much an image is pixel wise altered from its original. It is therefore a good measure to determine the quality of the reconstructed image compared to the noise free image [34]. The higher value of psnr translates into a better image quality when comparing two images. $$PSNR = 10 \log_{10} \left[ \frac{MAX_i^2}{MSE} \right] = 20 \log_{10} \left[ \frac{2^{k^2}}{\sqrt{\frac{1}{mn} \sum_{i=0}^{m-1} \sum_{j=0}^{n-1} |I(i,j) - L(i,j)|^2}} \right]$$ (3.5) In the equation above the m and n are the size of the image matrix, I and J are the two images to be inspected and k is the number of bits used to represent the image. ### 3.6.4 Real time constraints Modern DSLR cameras have the ability to expose multiple frames in a sequence within a short time frame, and those cameras are said to have high frames per second (fps) rate. The task of correcting defective pixel's from those types of camera introduces a time constraint criteria in order to keep up with the new frames shot. Exposing 30 frames per second means that each frame takes 33 milliseconds to complete. The correction algorithm should therefore utilize a fraction of the time of the frame itself in order to be efficient. Utilizing a correction algorithm will inevitably lead to a slower fps rate but that may be a tradeoff worth doing if the images come out with a noticeable lower noise level. # 3.7 TextIO vhdl package The textIO is a vhdl package that enables reading from a file and writing to a file when running a test bench in simulation in software. Values from the simulation can be stored in a file in a pre-determined location and the simulation can get its values from a file and then use them in a test bench. This is a useful tool in order to specify multiple input values without the hassle of having to write every value in a vhdl file. The package reads one line with the "readline" command. The line is then stored in a variable that has to be split up if there are multiple values in a line. The "writeline" command writes a value from a variable to a line. That line is written to the file with the "write" command. The directory of the pre and post fix of the file are specified using the "FILE" command along with the operating mode (read / write). # Chapter 4 # Architecture This chapter will introduce the modules that makes up the system for correcting defective pixels in a vhdl peripheral and also the modules used in conjunction with the cpu. The top level module is microblaze with the vhdl files that does the processing as a peripheral to that cpu. The cpu will read a value from the register inside the vhdl peripheral each time an interrupt fires and store the value on the cf card. ## 4.1 VHDL Architecture Figure 4.1 shows the hierarchy of the vhdl files that does the processing with the ctrl module as the top level module but it should be noted that the user\_logic.vhd is on a higher hierarchical level than the ctrl module and the my\_custom\_ip\_register.vhd as the top level vhdl file for the entire peripheral. The my\_custom\_ip\_register.vhd is the interface from the bus to the user\_logic.vhd where the signal mapping of the ctrl, image\_core, median and size modules takes place. Figure 4.1: Vhdl file hierarchy ## 4.1.1 Size Package Module The size package contains variables that are used by the various modules of the system. The reason for using a package is to avoid having to declare the same variables in all the modules, in addition to making it easier to change a value as it only needs to be changed one place. The values are accessible for the modules that implement the package. These values are shown in figure 4.2 where the "size\_x" and the "size\_y" are the size of the image to be corrected with the "th" being the threshold value used in the classification of a defective value. The "bits" variable is the number of bits per pixel. Eight bits per pixel is equivalent to 256 levels. "Bit\_depth" is merely two to the power of bits. ( $2^8 = 256$ ). The "data" is an array that contains the values of the image and those values are converted from the image to an array of the values of the image in such a way that vhdl will recognize the array of values and be able to read those values. Figure 4.2: Size package ### 4.1.2 Median module Figure 4.3: Median Module The median module is the module that calculates the median of any given array, with its input and output signals are given in figure 4.3. The enable signal will cause the state machine to make a transition from "idle" state to the "read\_values" state and the signal also denotes that a new input value is present at the input. That value is stored in an array called "data" at the position indicated by the "packet\_counter" variable. The next state is the "idle" state where the state machine will wait for more values. When all the values have been stored in the "data" array, indicated by the "packet\_counter" = 8, there will be a state transition to the "start" state. This state is the starting state for the double for-loop that will go through all the values in the array and swap two values if the value at "index" is larger than the value at ("index" +1). The "count" variable is that is incremented by one each time a value at "index" is smaller than the value at "index +1 and so does not need to swap place. When the for loop can go through the entire array without swapping any values, that is an indication that the array is in ascending order. This happens when the "count" variable is equal to 8. At that point the next state is "three" where the done flag is set high and the median value set to the value of position 4 in the nine value array. Figure 4.4 shows a graphical representation of the state machine built for this median module along with the signals that will cause a state change. The actual vhdl code for the median module can be found in section .1.1 Figure 4.4: Median module state machine # 4.1.3 Image core Module Figure 4.5: Image core Module The image core is the module where all the processing on the image is done. Its input and output signals are shown in figure 4.5. The state machine for the image core is starting in the "idle" state where it will assign the data out (do) flag to low while waiting for the mod\_en signal to be high. Then the next state is "read\_values" where the values are inputted serially and stored in an array called bayer array. The values are stored as if they where from an image sensor in order to duplicate the reading pattern [23]. These are the values from an image so the size of the bayer array is the same as the size of the pixels within the image. The values are stored in such a manner that it corresponds to the way data are read from a bayer image sensor. The transition to the next state happens when all the values are in their correct place in the array, and the next state is "padding127". This is a state where a new array is created, with the sizes in the x and y direction being four pixels larger than the bayer array. All the positions are assigned with the value 127. The next state is the data mapping state where the original values in the bayer array are mapped into the new array in such a way that the values in the bayer array are surrounded by a two-pixel border of the value 127. The reason for adding this border is to be able to use a single algorithm to go through the entire image including edges and corners as corners and edges are lacking some neighboring pixels of the same color. The next step is to find the defective values in the image one-by-one, and that is done in the "find\_defects" state. The way a pixel is classified as defective is that its value is higher than the threshold value plus the highest of its neighbors or lower than the threshold value minus the lowest of its neighboring values. A defective pixel will be assigned a '1' on that position in the pixel map, which is an array with the same size as the img array but where all the positions have the value 0 or 1. The reasoning for doing detection and correction in two different steps is to avoid using the value of a pixel at a defective position as a basic for a new value. The correction takes place in the "correct" state by going through the pixel map and selecting the positions that have a '1' entry. Then an array is composed with the values of the neighboring pixels of the same color. If one of those values are at a position that is classified as defective, the value 127 is assigned in the array instead of the defective value. The array of the neighboring values are sent to the median module serially by assigning the enable signal to high and assigning values of the array to the data in port of the median module. The above mentioned procedure is done on all the locations that are classified as defective. The last step in the "correct" state is to wait for the median module to produce its result and assign the new value to the correct location in the array. Since the two pixel border is there just for aiding the algorithm with searching for defective values in corners and edges, the border values are removed in the "de mapping" state. The corrected values are mapped into the bayer array where they will be assigned to the output of the module in the "read\_out" state. The values are assigned to the core\_out port along with the data out (do) signal set high when a new value is assigned. Upon completion of assigning all the values to the output the state machine is done with the image in question and set into the "idle" state. The graphical representation of the state machine can be found in figure 4.6 and the vhdl code is in section .1.1. Figure 4.6: Image core module state machine ## 4.1.4 Ctrl Module Figure 4.7: Ctrl Module The crtl module is the top level module in the processing part of the peripheral with its ports being shown in figure 4.7. It only needs the clock signal to start it's instruction and its responsible for assigning the correct flags in order to read and write values to and from the image\_core. It consists of a process that assigns values to the image\_core and a process that reads the values from the image\_core and outputs them to the output of the ctrl module. The process that reads values from the array within the size package contains a small state machine. The "idle" state of the state machine assigns the mod\_en flag high and then makes the transition into the "start" state which is nothing more than a delay state to get the timing right. The variable sent\_count keeps track of the number of values sent to the image\_core, and this value is checked in the state "one" so it can be ascertained when all the values are sent. The mod\_en flag is de asserted in the "one" state and then it makes a transition to the state "two" where the various values are assigned to the core\_in port of the image\_core. The state machine described here can be found in figure 4.8. The second process of the ctrl module reads the values from the image\_core and assigns them to its output. This is triggered when the data out (do) signal from the image\_core is assigned to '1'. The vhdl code for the ctrl module can be found in section .1.1. Figure 4.8: Ctrl module state machine ## 4.2 Note Even though the vhdl files, shown in figure 4.1, showed correct behavior when simulated it seems impossible to run synthesis on the files as the ISE synthesis tool runs out of memory before completing the synthesis. The decision was therefore made, in accordance with the supervisor, to proceed without running synthesis on the vhdl files. This will make it impossible to test the system on the fpga so the simulation of the vhdl files will serve as an indications of the system's ability to detect and correct defective pixel values. The custom ip module is still implemented in the system but with limited functionality. It will contain a process for generating interrupts and test the ability to write to a peripheral register and read from a peripheral register. The peripheral will show how the ctrl.vhd module can be mapped in the user\_logic.vhd file with its mapping of signals. A successful test will provide evidence that the embedded system can handle reading a value from a register and store it on a cf card. ## 4.3 Microblaze The microblaze system contains both hardware and software that enables communication between the cpu and its peripherals. The next section deals with the hardware part of the microblaze system while the preceding section deals with the software part of the system. ### 4.3.1 Hardware Architecture #### Vhdl Peripheral Figure 4.9: Vhdl Peripheral hierarchy The xps wizard created the template for the peripheral to be connected to the cpu by the plb bus. It also created the interface necessary for the peripheral to communicate with the plb bus signals. The ipif communicates with the plb bus using the entire set of plb bus signals. The ipic is the interface between the ipif and the user modules and custom functionality can be added here or custom vhdl module can be mapped from this module. The vhdl file user\_logic.vhd created by the wizard needs to be altered in order to get the correct functionality where a value is read from a register and stored in a file on the cf card. The user logic file has been altered by adding a process that will generate an enable signal and also the component mapping of the ctrl module. It should also be mentioned that the user logic file has six software accessible registers, represented by the signals slv reg0-slv reg5. The file also contains both a process for reading the values of a register and a process for writing values to a register. The process that generates the interrupt also has a reset signal that will reset the interrupt on the peripheral. The reset signal reads its value from bit 0 in the slv\_reg0 register so writing a 0 to that position in slv reg0 resets the interrupt. The file also contains a component mapping for the ctrl module where the clock and reset signals are mapped from the Bus2IP Clk and Bus2IP Reset that is a part of the plb bus signals. The output signal of the ctrl module is mapped to a signal called output so the value of the output can be read by reading slv reg1. #### Connections The Microblaze system is made up of the components described in section 2 that will now be connected to the plb bus so their functions can be utilized by some software on the cpu. The base system builder wizard and the create peripheral wizard described in section 2 made a system with a block diagram that is given in figure 4.10. The custom peripheral was given the address range from 0xCCC00000 to 0xCC0FFFF when the tool generated the addresses. Since there is an interrupt controller in the system it is important that it is connected correctly from the vhdl peripheral all the way to the processor. The peripheral's interrupt signal is connected to the interrupt controllers Intr port, and its Irq port is connected to the cpu's interrupt port. The block diagram of the hardware connections in Microblaze is seen in figure 4.10 where it is apparent that the interrupt controller, my\_custom\_ip\_register and the cpu share a common yellow mark on the top right corner that indicates the handler, source and target, respectively, of the interrupt mechanism. Figure 4.10: Microblaze Block Diagram The microprocessor hardware specification.mhs file for the system defines the hardware components used along with the bus architecture, peripherals, processor, system connec- tivity and address space [20]. The file is located in the main program directory and can be found in section .2.2. ``` BEGIN xps_intc PARAMETER INSTANCE = xps_intc_0 PARAMETER HW_VER = 2.00.a PARAMETER C_BASEADDR = 0x81800000 PARAMETER C_HIGHADDR = 0x8180ffff BUS_INTERFACE SPLB = mb_plb PORT Irq = xps_intc_0_Irq PORT Intr = my_custom_ip_register_0_IP2INTC_Irpt END ``` Figure 4.11: Microprocessor hardware specification example Figure 4.11 shows the hardware settings for the interrupt controller with its name, hardware version, high address, base address, bus interface and ports with the signals connected to the ports. The user constraint file .ucf for the system specifies how the signals inside the fpga are connected to external pins on the fpga. It can be specified which clock on the chip that is used in a design with the ucf file. The file is stored in the data folder in the program directory and can be found in section .2.3. ``` Net fpga_0_clk_1_sys_clk_pin LOC = AD8 | IOSTANDARD=LVCMOS33; Net fpga_0_rst_1_sys_rst_pin TIG; Net fpga_0_rst_1_sys_rst_pin LOC = T23 | IOSTANDARD=LVCMOS33 ``` Figure 4.12: User constraint file example Figure 4.12 show how the vhdl signals fpga\_0\_clk\_1\_sys\_clk\_pin is connected to the external pin of the fpga called AD8. #### 4.3.2 Software Architecture The hardware description and connections of the peripheral are now complete so the designer can utilize the functions of the peripheral in order to achieve the desired result. First, let's look at the header files that are of interest for this project, starting with the xparameters header file (section .2.4) which is the file with the address ranges of all the components connected to the cpu. The sysace\_stdio.h provides functions to read, write, open and close the compact flash card in addition to specifying the directory of the file to be interacted with. The my\_custom\_ip\_register.h contains functions for reading data from the register in the peripheral and functions to write data to the register. The header files mb\_interface.h and xintc.h contains all the functionality to setup interrupts, handle interrupts and acknowledge interrupts on the interrupt controller and on microblaze. The functionality of the c source file as based around interrupts so the file consists of an interrupt service routine and the setup of the interrupts in addition to writing data to the cf card and reading data from registers within the peripheral. Setting up the interrupts requires that an interrupt handler is registered and the enabling of interrupts in all modules that process, send or receive interrupts. Registering an interrupt handler is done with the "XIntc\_RegisterHandler" function found in the xintc\_i.h file which is accessible through the xintc.h file. This is the connection between the interrupt signal from the peripheral and the interrupt service routine for that peripheral. Interrupts needs to be enabled in the custom ip, interrupt controller and microblaze so that it can function correctly. It is set up in the interrupt controller by using "XIntc\_mMasterEnable" function and the "XIntc\_mEnableIntr" function found in the xintc.h file. The custom ip enables interrupt by using the "MY\_CUSTOM\_IP\_REGISTER\_EnableInterrupt" command in the my\_custom\_ip\_register.h file. The last step is to enable interrupts on the processor, and that is done with the "microblaze enable interrupts();" command found in the mb interface.h file. Every time there is an interrupt, the cpu will execute the same piece of code over and over again. That code includes functions to setup a file directory, open the file, read the data from a register and write that value to a file on the compact flash card, close the file and acknowledge the interrupt on the peripheral and in the interrupt controller. The specification of a directory is completed by using the "sysace\_mkdir" command from the sysace\_stdio.h file. The same file contains the functions sysace\_fopen,sysace\_fclose, sysace\_fwrite to open, close and write to the card, respectively. A data value is read from a software accessible register by using the "MY\_CUSTOM\_IP\_REGISTER\_mReadReg" command. This is a general function to read from a register so it is important to get the register offset value correct as not to read from another register. The offset for all the five registers within the peripheral are defined in the my\_custom\_ip\_register.h header file. The base address of the peripheral is defined in the "xparameters.h" file. The c source files used to test the different aspects of the peripheral in this project can be found in sections .5.1,.5.2,.5.3. The microprocessor software specification file .mss specifies the driver name, driver version and the hardware instance to be used on. The .mss file for the system can be found in section .2.1. ``` BEGIN DRIVER PARAMETER DRIVER_NAME = intc PARAMETER DRIVER_VER = 1.11.a PARAMETER HW_INSTANCE = xps_intc_0 END ``` Figure 4.13: Microprocessor software specification Figure 4.13 shows the driver setup for the interrupt controller. Notice how the hardware instance name is the same name as the instance name specified in the mhs file. # 4.4 Matlab scripts Matlab is a great tool for working with images in software as it has the ability to read an array of values from an image and it can write an array of values to an image file. These abilities will be utilized for this project in order to obtain the image data and to make an image from the output values. The next subsections will go into how this is done. This is a good way of evaluating the results of the simulation as the processing vhdl files cannot be synthesized. ## 4.4.1 Reading Image The vhdl modules would normally, in a camera environment, be fed data from an image sensor. This will be duplicated with the aid of Matlab by writing a script, called image\_in.m that reads an image from a file, adds noise and then stores the resulting array as a format that vhdl can recognize as an array of values. The script can be found in section .4.1. This script reads all the values in an image and stores them in a two-dimensional array. The desired noise is then injected into the array of values and then it is written in a format (value1, value2) and stored in a text file. The content of the file can then be pasted into the package vhdl file and read by the vhdl modules. ## 4.4.2 Write Image A Matlab script is also required to read the values in the file written by the textIO package and then convert it to an image. This is done in the image\_out.m file that can be found in section .4.2. The script reads the values in the file produced by the textIO package and then makes a two dimensional array that is written to a PGM image file and stored. Upon completion the images needs to be inverted in a photo editing software before receiving the results in the simulation chapter. ## 4.4.3 Measuring Statistical Values The values used to make the graphs in chapter 5 were gathered using a Matlab script. It reads the original image along with the restored images and stores them in two different two dimensional arrays. A double for-loop searches through the two arrays in order to calculate the mean absolute error, mean square error and the peak signal to noise ratio. The script can be found in section .4.3. # Chapter 5 # Simulation All the modules used in this system have been tested to ensure correct behavior on every level of the hierarchy both in terms of vhdl files and software modules. The next sections will show how the various modules have been tested and the results. All the testing has been done at the clock frequency of 100MHz in Active HDL. # 5.1 VHDL module testing The vhdl files that makes up the vhdl peripheral have been tested using a test benches created in activeHDL, in order to ensure that they will exhibit correct behavior. The following sub sections will show results from simulation of the various modules and then bring it all together with a simulation of all the processing files in the peripheral. # 5.1.1 Median Testing The median module was tested by inputting an array of values and then make sure that the output median value was indeed the median of the input values. Figure 5.1 shows an input sequence where all the values are inputed serially and then stored in an array, called data, within the module. Figure 5.1: Input Sequence The input array for the median module is {115,113,127,127,127,127,141,105,127}. The same array in ascending order is {105,113,115,127,127,127,127,127,141}, and that corresponds to the data array in the median module. Thus, the module produced the correct median value for that array. Figure 5.2 shows the end of the execution of the median module, for these values, where the done signal is assigned high and the median value is assigned to the median port. Figure 5.2: Output Sequence ## 5.1.2 Image core Testing The image\_core is on a higher hierarchical level than the median module. Its job is to search through a two dimensional array of image values in order to determine the positions of the defective pixels. It will input the correct neighboring pixels to the median module and wait for it to produce the median value. The best way to test this module is to input the values from an image with noise and then make an image of the output values in order to visually confirm that the image does in fact have lower levels of noise. Figure 5.3: Image core input sequence Figure 5.3 shows the input signals that are utilized in the image\_core module when values from an image are inputed to the image\_core module. They are then stored in an array called bayer\_array. Figure 5.4 shows that the state machine in the image\_core module returns to idle state when it's done with the processing of the input image. | <b>π</b> clk | 1 | | |---------------|---|----------------------------------------------------------------------------| | vr. CS | | Xidle | | V=x_cor | 0 | | | V=y_cor | 0 | (244 )(245 )(246 )(247 )(248 )(249 )(250 )(251 )(252 )(253 )(254 )(255 )(0 | | V= read_state | 3 | (1/2/1/2/1/2/1/2/1/2/1/2/1/2/1/2/1/2/1/2 | | • do | 0 | | | ™ core_out | | <u> </u> | Figure 5.4: Image\_core end of execution The output values from the image\_core module are stored in a file using the textIO package. Those values are then run through the Matlab script in order to get an image from the values. The values that are sent into the image\_core module are from the Lena [15] image that has been corrupted by noise with the probability of 0.01(1%). The input image is shown in figure 5.5. Figure 5.5: Input Image with noise Figure 5.6 shows the resulting output image from the image\_core and stored in the textIO based file. It is clear that the resulting image is a great improvement over the noise corrupted input image. Figure 5.6: Output image ## 5.1.3 Ctrl Testing Testing the ctrl module is done by using the same input values as when testing the image\_core, but this time the only output signals will be the new image values as that is the only signal declared as output signal in the ctrl module. Figure 5.7: Ctrl output sequence Figure 5.7 shows how the output values of the image are assigned to the output of the ctrl module. This will occur until all the values have been assigned to the data\_out signal. All the values are then stored in a file using the textIO package so the content of the file can be made into an image with the image\_out.m matlab script. The image is identical to figure 5.6 which is only to be expected as there is no added processing happening in the ctrl module. Testing these modules individually proved that they exhibit the correct behavior as intended. # 5.2 Test of the whole VHDL system The whole system will now be simulated using the values obtained from the textIO vhdl package in order to visually and statistically verify that the resulting image is an image with less noise quantities than the image corrupted with noise. The Lena image(256x256) [15], Field image(500x500) [10] and the canyon image(200x300) [7] will be used as input images with different noise levels and threshold levels. These images have different contrast levels and different numbers of pixels so it will be a test of the algorithm's ability to correct pixels from different contrast images and also the scalability of the algorithm. In addition to putting the image under visual scrutiny, a few key values will be measured that are relevant when comparing images. The next sections will show the resulting graphs from the resulting images with different noise levels and different threshold values. ## 5.2.1 Different noise levels The input images were simulated with different noise levels in the interval 0.001-0.1. The mean square error, mean absolute error, peak signal to noise ratio and the simulation time were recorded for every noise level and all the simulation took place with the threshold value at 10. The resulting images can be found in sections .6.2, .6.4, .6.6 along with the input image corrupted by noise. It is therefore possible to view and compare the input image and the output image in order to ascertain the algorithm's ability to remove defective pixels. #### Peak Signal to Noise Ratio The typical values for peak signal to noise ratio for an image with lossy compression is between 30 - 50. That range can be a guideline to evaluate at which noise levels the resulting image will be of sufficient quality. The starting value for the peak signal to noise ratio for the Lena image is 38 at the noise level of 0.001 while the end value at the noise level of 0.1 is 22. That means that the algorithm produces acceptable quality with peak signal to noise ratios for noise levels from 0.001 - 0.02, as can be seen from figure 5.8. It shows the trajectory as a function of noise density, and it is evident that there is an almost inverse exponential relationship between the two except from a few values near the beginning of the graph. The field image does have a lower starting value for the peak signal to noise ratio than the Lena image while it follows a similar trajectory. It will have sufficient quality in the noise range 0.001 - -0.03. The canyon image has its highest peak signal to noise ratio of 23 and will thus not qualify for comparison as it never has a value over 30. Figure 5.8: Peak signal to noise ratio for different noise levels #### Mean Square Error Figure 5.9 shows how the mean square error relates to different noise densities. There is an exponential growth, for the Lena image, in the mean square error with the starting value of 0.043 at 0.001 noise level and ends at 1.33 at 0.1 noise level. The mean square error relates to the peak signal to noise ratio (see section 3.6.1) so that a lower mean square error translates into a higher peak signal to noise ratio. As such, optimizing either one of the values will result in a higher peak signal to noise ratio. The canyon image has a similar trajectory with a higher peak than the trajectory for the Lena image. The trajectory for the field image had a much lower peak signal to noise ratio and thus a higher mean square error trajectory. Figure 5.9: Mean square error for different noise levels #### Mean Absolute Error The mean absolute error for the three input images with different noise levels is shown in figure 5.10. The trajectory of the Lena image follows an exponential path with a starting point of 0.68 at 0.001 noise level and ends at 3.03 at 0.1 noise level. Comparing figure 5.9 and figure 5.10 shows a similar trajectory only with the mean absolute error having a higher values than the graph of the mean square error. The canyon image has a similar trajectory while the trajectory of the field image has a higher value at all noise levels. Figure 5.10: Mean absolute error for different noise levels #### Simulation times As with any system required to operate in real time it does have certain demands as far as time is concerned. These simulation times will, therefore, prove or disprove the systems ability to meet those demands that would be imposed in a real time environment. Figure 5.11: Simulation times for different noise levels Figure 5.11 shows the time it took in order to complete a simulation at the different noise levels for the three input images. All the values of time on the y axis are measured in milliseconds. At low noise densities the simulation for the Lena image time is less than 4 milliseconds. That is equivalent is 250 times per second, which would be fast enough for most camera applications. The highest simulation time comes, not surprisingly, at the highest noise level, results in up to 7.5 milliseconds. That is the same as 133 times per second. In terms of simulation time, this algorithm has sufficient capabilities to be placed in a real time camera environment. The canyon image has a simulation time of 5 milliseconds for small quantities of noise and 9 milliseconds for high noise quantities. Those numbers represents 200 and 111 times per second. The field image does have the highest simulation times of the three images with 21 milliseconds for low noise quantities and 34 which is equivalent to 47 times per second. The images uses 34 milliseconds for high noise quantities which is 29 times per second. Another important aspect of the algorithm is its scalability in terms of simulation time per pixel. An image with a higher number of pixels will require a longer simulation time. It is therefore a trade off for the designer as to how large pixel wise images are required and the time limitation imposed by the environment. Figure 5.12: Simulation times per pixel Figure 5.12 shows the simulation times per pixel for the different noise levels. The Lena image causes the lowest simulation time despite containing more pixels than the canyon image. The field image has many more pixels than the field image but still has about the same simulation time. Given the values from the three images, it's possible to interpolate a trajectory in order to estimate the simulation time any image with a given number of pixels. ### 5.2.2 Different threshold values This section contains data that was gathered with a constant noise level of 0.02 while the threshold value has been changed within the range 2-50 for all the images. The goal of these simulations is to determine whether altering the threshold for an image will result in higher peak signal to noise ratio. The resulting images from the simulation are placed in sections .6.3, .6.5, .6.7. #### Peak Signal to Noise Ratio Figure 5.13 reveals that a threshold of 20-30 is the best level in order to obtain the highest peak signal to noise ratio for the Lena image. Choosing to use the optimized threshold level of 25 as opposed to the default level 10 does only increase the peak signal to noise ratio from 34.5dB to 36dB. Some situations may have this as a trade off worth doing, while others may opt for a shortened simulation time and a smaller peak signal to noise ratio. The canyon image does have a spike in the peak signal to noise ratio in the 10-15 range but it is otherwise pretty much has a constant decline at all threshold levels. The value of the spike is so small that in most cases it will not amount to anything but increased simulation time. The field image does have the highest peak signal to noise ratio for the lowest possible threshold levels. It is clear that this image will require a low threshold in order to produce the highest peak signal to noise ratio. The higher threshold levels also means that areas with low contrasts and defective pixel may not be corrected because th threshold level is too high. As such, it is best to go for the lowest threshold that produces the desired peak signal to noise ratio. Figure 5.13: Peak signal to noise ratio for different threshold levels #### Mean Square Error Figure 5.14 shows that mean square error for the three images. The Lena image does have an optimum level that corresponds to the optimum level of the peak signal to noise ratio in the range 20-30. The canyon image does have its lowest mean square error in the range 10-15 and the field image has its lowest mean square error at low noise quantities. Figure 5.14: Mean square error for different threshold levels #### Mean Absolute Error Figure 5.14 shows the relationship between the mean square error and the noise density. The Lena image still produces the least amount of mean absolute error with a low point in the range 15-35. The canyon image has its low point in the range 15-30 and the field image has its lowest values towards the lowest threshold value. Figure 5.15: Mean absolute error for different threshold levels #### Simulation times The simulation times are shown in figure 5.16. The filed image has the highest simulation time with 40 milliseconds for low threshold levels and 20 milliseconds for high threshold levels. Both the canyon image and the Lena image have a simulation time of 10 milliseconds for low noise levels and 5 milliseconds for high threshold levels. The simulation time should, however, be considered of less importance when tailoring the algorithm to produce best results for a given image as long as it meets the constraints imposed on it by its real time environment. Figure 5.16: Simulation times for different threshold levels # 5.3 Software algorithms This section will show the results of the simulations of the median algorithm that were designed in software in my last semester's project with the three images as input. The matlab script .4.4 was used for the simulations with the threshold of 10 and with the noise level of 0.02. The resulting images from the simulation can be found in section .6.8. | | Lena | Field | Canyon | |----------|------|-------|--------| | psnr(dB) | 35.1 | 31.6 | 32.75 | | time(s) | 3.03 | 6.5 | 1.28 | Table 5.1: Software algorithm results ## 5.4 Microblaze simulation The vhdl peripheral in the microblaze system is a module to test how values can be read to and from the peripheral and how to use interrupts and interacting with the cf card. Values are read from the compact flash card into the peripheral in the first test of the system ace controller. The resulting output value from the peripheral is stored in a file on the compact flash card by using interrupt. The testing will start with the interaction with the cf card, followed by the interrupt mechanism and reading and writing values to and from registers. ## 5.4.1 System Ace write to card The simulation of the compact flash card will verify that files can be read from a file on the cf card and stored back into another file on the card in the same directory. The input file directory is in the root directory of the cf card with a file named "input.txt". The file will contain five integer values, and the file opened in notepad is shown in figure 5.17(a). The read data is stored in a character buffer called "readBuffer" before it is written to a file called "output.txt". Figure 5.17 shows that the output file contains the same data as the input file and thus verifying that the cf card can be written to and read from. The c code used to test the read and write capabilities of the cf card can be found in section .5.1. Figure 5.17: Compact flash read and write simulation ## 5.4.2 Interrupt testing Setting up an interrupt based system requires that the interrupts are enabled on all the components that deal with an interrupt. It is also necessary to register a handler that is invoked whenever the interrupt "fires". One interrupt handler is required for every device that communicates with the cpu by the means of interrupts. The source file requires one function to enable the setup the interrupt on microblaze, the interrupt controller and the my\_custom\_ip\_register and a function to be executed when an interrupt fires. The init() function in the source code(section .5.2) contains all the required functions for the interrupt mechanism to work correctly. It will register an interrupt handler, enable interrupts on the interrupt controller my\_custom\_ip\_register and microblaze. The init() function only needs to be run once when the cpu is turned on. The function intr\_handler() is the interrupt service routine that is executed on every interrupt. A simple test of the interrupts is to write some data to the cf card in the isr. Inspecting the output file will determine if the correct data has been written to the card. For this test the data written to a file on the cf card contains the characters "test", which means that it will be written to the card if the isr is executed. Interaction with the cf card proves to work correctly unless there is an absence of data, in a file with the correct name, written to the card. Figure 5.18 shows the data written to the card by the isr, and it is the same data as the isr was instructed to write. The file is therefore evidence that the interrupt was set up correctly and that it was assigned by the custom ip module. Figure 5.18: File written by the isr ### 5.4.3 Read value from peripheral register This section was the last to be tested as it requires both the interrupt mechanism and the read and write methods for the cf card to function correctly in addition to adding functions to write data to a peripheral register and to read data from the register. A hexadecimal value of A2 (162 in decimal value) is written to register 3 in the peripheral unit before the init() function sets up the interrupts. The isr is altered so that it reads the value of register 3 from the peripheral unit and stores it in a variable before writing it to the predetermined file on the cf card. Having the file contain the same value as the one written to the card will be evidence that interaction with the peripheral is working. Figure 5.19: Test Read from a Register Figure 5.19 shows the file produced by the isr and stored on the card. The output file contains values that are coded in ascii so that it will not show $A2_{16}$ or $162_{10}$ but rather the ascii symbol with the decimal value of 162. The resulting file produced by the isr, in figure 5.19, shows the ascii symbol of the values it read from the register. Using the ascii table at [3] reveals that the symbol written is at the 162nd position and thus confirming that reading from the register and writing to the register works correctly. # Synthesis ## 6.1 VHDL Synthesis The vhdl files that do the processing part of this project cannot be synthesized in the vhdl hierarchy they are built as the Xilinx ise synthetization tool eventually runs out of memory without giving any error message. In accordance with the supervisor at the university, the vhdl files will not be synthesized as part of this project. The vhdl files created by the wizard for the custom ip will, however, be synthesized as part of running synthesis on microblaze. The area report will thus only be for the vhdl files created by the wizard. ## 6.2 Microblaze Syntethization The embedded system created in platform studio are synthesized by the "generate netlist" command and the synthesis report is stored in the report folder in the project directory. The synthesis report for the design can be found in section .3. The maximum delay through the system is 6.18 ns which gives a clock frequency of the system of 161.34 MHz. The clock frequency and variable related to the clock are found in figure 6.2. ``` Timing Summary: ------ Speed Grade: -1 Minimum period: 6.198ns (Maximum Frequency: 161.342MHz) Minimum input arrival time before clock: 2.750ns| Maximum output required time after clock: 6.964ns Maximum combinational path delay: 1.397ns ``` Figure 6.1: Synthesis delay Figure 6.1 shows a part from the synthesis report regarding the resources utilized for the system. The design utilizes 9% of the available registers and 10% of the available LUTs. These numbers shows that the design only utilizes a small amount of resources on the chip as can be expected for a such a small system. Many systems of this kind will have area limitations so that utilizing a small percentage of the resources is always great news. The I/O utilization is at 7% and with 66% of ram/fifo utilized. The reason for having such a large percentage of ram/fifo utilization is a combination of the requirement of storing values within the peripheral that can be read by the cpu, in addition to only having 64 kb of memory to begin with. | Device utilization summary: | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|----------------------------|----------------|-----------------------| | Selected Device : 5vlx50ff676-1 | | | | | | Slice Logic Utilization: Number of Slice Registers: Number of Slice LUTs: Number used as Logic: Number used as Memory: Number used as RAM: Number used as SRL: | 2746<br>2933<br>2779<br>154<br>64<br>90 | out of out of | 28800<br>28800 | 9%<br>10%<br>9%<br>2% | | Slice Logic Distribution: Number of LUT Flip Flop pairs used: Number with an unused Flip Flop: Number with an unused LUT: Number of fully used LUT-FF pairs: Number of unique control sets: | 4530<br>1784<br>1597<br>1149<br>301 | out of | 4530 | 35% | | IO Utilization:<br>Number of IOs:<br>Number of bonded IOBs:<br>IOB Flip Flops/Latches: | 32<br>32<br>58 | out of | 440 | 7% | | Specific Feature Utilization:<br>Number of Block RAM/FIFO:<br>Number using Block RAM only: | 32<br>32 | out of | 48 | 66% | | Number of BUFG/BUFGCTRLs:<br>Number of DSP48Es:<br>Number of PLL_ADVs: | 6<br>5<br>1 | out of<br>out of<br>out of | 32<br>48<br>6 | 18%<br>10%<br>16% | Figure 6.2: Synthesis resource utilization ## Tools This project has required a handful of tools in order to deal with the different aspects of the design from converting an image in software to adding peripheral, to the cpu to synthesizing the complete design. The computer used in this project has a 32 bit Windows Vista Home Basic operating system with Service pack 2, dual processor where each processor has a frequency of 2.26GHz, and the computer has 3.0 GB ram. Matlab was the tool used to convert an image from a file to an array in the vhdl package file and to convert values from the simulation to an image. The hardware programming and simulation were done in Active HDL software, and when the simulation showed correct behavior it was synthesized in ISE project navigator, which is part of the Xilinx web pack. The creation of the embedded design took place in platform studio which also did the synthezation of the embedded design. The design could then be implemented to the fpga with the Impact tool which is a part of the webpack from Xilinx. The various software and version number type can be seen from table 7.1. Development board Xilinx ML501 Matlab Version 7.4.0.287(R2007a) Copyright 1984-2007 The MathWorks, Inc. Active HDL Active HDS version 7.2.1644 Student Edition, Copyright(c) ALDEC, Inc All rights reserved ISE Project Navigator version 11.5, Copyright (c) 1995-2009 ISE Project Navigator version 12.1, Copyright (c) 1995-2009 Platform studio Xilinx Platform Studio 11.5, Copyright (c) 1995-2009 Xilinx, Inc Platform studio Xilinx Platform Studio 12.1, Copyright (c) 1995-2009 Xilinx, Inc Impact ISE impact4 version 11.5, copyright (c) 1995-2009, Inc Impact ISE impact4 version 12.1, copyright (c) 1995-2009, Inc Table 7.1: Software utilized ## Discussion The discussion of the results from the hardware and software part of this project are given separately in order to put the results into context. ### 8.1 Vhdl The vhdl file median.vhd is the only file that will synthesize in the project navigator tool because it is at the lowest level in the vhdl hierarchy. The other vhdl files cannot be synthesized so the simulation of the files in conjunction with the textIO package and Matlab scripts will serve as the bases for determining this design's ability to operate in a real time system. It is clearly not desirable not to be able to synthesize the vhdl files as it introduces uncertainties as to whether the system will have the same behavior in hardware as it exhibited in the simulation in software. It also introduces no evidence as to the physical size of the vhdl files that will inevitably require a higher utilization of resources as the majority of all the processing is done there. The only area values that are given is the area of the two vhdl wrapper files created by the import custom ip wizard in order to set up communication between the custom ip and the plb bus. It is also assumed that adding the other vhdl files will introduce a longer delay path in the design, which will lead to a lower clock frequency. ### 8.2 Microblaze The embedded system was created and synthesized in the platform studio. The design shows that it has a high clock frequency and a low resource utilization except for ram usage. This can be explained by the fact that the system really does very little processing. The other peripherals show higher clock frequencies than the processor so the cpu is the weakest link when calculating the maximum clock frequency. The code written to interact with the cf card, set up interrupts and reading from a register and writing to a register are shown to work as desired. Testing the system by writing values to a file on a cf card would prove to be a better way of testing the system if the output data were written in decimal number as opposed to ascii code as the data could be written into matlab with a simple script. ### 8.3 Simulation The graphs based on the data from the simulations data shows that a high peak signal to noise ratio leads to a low mean square error and mean absolute error. This is also obvious from looking at equations (3.4), (3.3), (3.5) that optimizing for one of the variables will result in an optimization for all the variables. Simulating the images with different thresholds introduced the concept of being able to optimize an image in order to achieve higher peak signal to noise ratio and lower mean square error and mean absolute error on an image-by-image basis. As an illustration, the peak signal to noise ratio for 0.02 noise level with the threshold at 10 is 34.59dB. The simulation of the different thresholds revealed that the optimum threshold for the highest peak signal to noise ratio was 20-30. The peak signal to noise ratio for the threshold of 26 with 0.02 nose level is 36.04dB. Those numbers show that there is something to gain by optimizing the threshold, but that is at the expense of higher simulation times as the optimum threshold level has to be determined based on simulations on different threshold levels. The simulation for correcting the defective pixels can only be run after the threshold level has been found. Having the threshold value at 10 seems to be a good general purpose value as the peak signal to noise ratio is close to the peak signal to noise ratio at the optimized threshold level. ### 8.4 Real time operation Modern cameras like the Canon 7d [6] have the ability to expose multiple images at a fast rate of frames per second. The Canon 7d can shoot 8 frames per second at continuous shooting. That introduces a limit as to how long a correction algorithm can use and still keep up with new data arriving from the sensor. Shooting 8 frames per second translates into 125 milliseconds per image. The simulation times for the 256x256 pixel test image vary between 3.5 and 7.5 millisecond depending on the noise level. Assuming an average simulation time of (3.5+7.5)/2 = 5.5 milliseconds the time frame for a single exposure increased from 125 millisecond to 130.5 millisecond. This results in the frames per second being reduced from 8 to 7.6. The time it takes to correct an image is a small fraction of the time it takes to expose an image, which is what is desirable as the main function of the system is to expose images. The field image used an average simulation time of 28 milliseconds and thus increased the time for each exposure to a total of 153 milliseconds, which is equivalent to 6.5 exposures per second with the 8 fps initially. The canyon image has an average simulation time of 6.5 milliseconds which makes the total exposure time 131.5 milliseconds. That enables the camera to have a fps rate of 7.6 which is the same as for the Lena image. ### 8.5 Comparison with 2009 fall project The simulation of the algorithm designed in my 2009 fall project was re-simulated with the Lena, field and canyon images in order to compare it with statistical values and simulation times of the same algorithm designed in hardware. The comparison values were both gathered during simulation using a threshold of 10 and a noise level of 0.02. The simulation times and the peak signal to noise ratios for the software algorithms are shown in figure .6.8. The Lena image took 3.03 seconds to simulate in software and 4.46 milliseconds in hardware so a tremendous amount of execution time is saved when doing the processing in hardware. The corresponding peak signal to noise ratio from the software algorithm is 35.1 dB while it is 34.5 dB for the version where all the processing is done in hardware. The field image took 6.5 seconds to simulate in hardware while it took 24.76 milliseconds. The peak signal to noise ratio was 31.6 dB for the software version and 21.66 milliseconds for the hardware version. The canyon image took 1.28 seconds to simulate in software with a corresponding peak signal to noise ratio of 32.74 dB while the hardware version was simulated in 5.64 milliseconds with a peak signal to noise ratio of 31.33 dB. The above data shows that doing the processing in hardware for this algorithm executes much faster with a somewhat lower peak signal to noise ratio. ## 8.6 Interpreting images The values resulting from the vhdl simulation have been interpreted by a Matlab script in order to get the values, stored by the textIO package, into a two dimensional array that in turn can be written to an image. There is, however, a phenomena where an image may be inverted when the Matlab script image\_out.m ( .4.2) is done executing. These images therefore needs to be entered into a photo editing software where the images have to be inverted. I have found no clue to the nature of this phenomena in the PGM standards so it is still an unsolved mystery. ### 8.7 Border pixels Defective pixels near an edge or a corner will use the border-pixels in order to find the new value for a pixel. As the border-pixels all have the value 127 it may replace a pixel with a value that does not represent its neighbors. A better way of making a border might be to create the border as a mirror of the values in the first two rows and columns in such a way that the first border row will have the same values as the second row of the image, looking at the upper edge. The new pixel values will then have a value corresponding to the neighboring pixels. ## 8.8 Tools Xilinx released the 12.1 version of the ise webpack and the platform studio as the project are ongoing so that is the reason that both the 11.5 version and the 12.1 version was listed in the tools chapter. ## 8.9 Appendix The package vhdl file contains an array with all the values from the input images and it was not possible to get Latex to add that file to the appendix as the pdflatex compiler kept shutting down when attempting to compile. The file is therefore added to the appendix without the array with the image values. The values in the array are specified in the signal the data\_array. # Concluding remarks This project aimed at making an algorithm to detect and correct defective pixels in images, and with all the processing done in hardware. The simulations show that the algorithm is exhibiting correct behavior with the output values represented as an image showing less quantity of noise than the input. The project has met the goals that were associated with the assignment even though simulation had to take place in several steps as opposed to if the vhdl file could have been synthesized. ## Further Work The project has been simulated in software but has not been synthesized due to ISE software is unable to synthesize the design as it runs out of memory. Further work for the project can then be divided into getting the algorithm to a working stage in an fpga and improving the design once it is working. The embedded system has a peripheral that outputs values to a register in the same manner as the vhdl peripheral was intended to do. The user logic.vhd file and the ctrl.vhd can be altered to accommodate the ability to read values from a file into the ctrl module. The ctrl.vhd module needs to add in input signal for data. It would then read the input signal, and relay them to the image core module. The value can be read from a slv reg in the peripheral. The output values from the ctrl module can be mapped to the output signal of the user logic. The value can now be read by software by reading slv reg1. The border pixels should be given values that represents the values of the images as opposed to having a fixed value for all images. This can be done by having the border rows mirror the value of the edges of the image. The values on the border would then ensure that a better replacement value for the pixel was used. That would make the system more functional as it can operate on any set of values given that the size of the image is the same. The task of improving the system once operational is about making tradeoffs between the variables in the design like execution time and resource utilization. It is therefore imperative that the system is operational and that the limitation of the target device is known before attempting to optimize the system. # Bibliography - [1] Adding a custom ip , http://www.youtube.com/watch?v=DkjVXeqRKjE&feature=related. - [2] Ascii table, http://en.wikipedia.org/wiki/ASCII. - [3] Ascii table, http://www.web-source.net/symbols.htm. - [4] Bayer filter, http://en.wikipedia.org/wiki/Bayer\_filter. - [5] Bayer image filter, http://en.wikipedia.org/wiki/Bayer\_filter. - [6] Canon 7d, http://shop.usa.canon.com/webapp/wcs/stores/servlet/product\_10051\_10051\_230851\_-1. - [7] Canyon image, http://bluemesaphotography.com/hye/wp-content/uploads/2009/07/IMGP8596Crop6by9BW-200x300.jpg. - [8] Decibel measuring, http://www.phys.unsw.edu.au/jw/dB.html. - [9] Decibel scale, http://en.wikipedia.org/wiki/Decibel. - [10] Field image, http://www.thephotoargus.com/wp-content/uploads/2009/11/bw47.jpg. - [11] Gaussian noise, http://en.wikipedia.org/wiki/Gaussian\_noise. - [12] Hexadecimal nubers, http://en.wikipedia.org/wiki/Hexadecimal. - [13] Histogram , http://www.cambridgeincolour.com/tutorials/histograms1. htm.. - [14] Interrupt in microblaze tutorial, http://www.fpgadeveloper.com/2008/10/timer-with-interrupts.html. - [15] Lena image, http://www.cs.cmu.edu/~chuck/nsipg/nsi.html. - [16] Logarithmic nubers, http://en.wikipedia.org/wiki/Logarithmic\_scale. - [17] Mean absolute error http://www.fmi.uni-sofia.bg/vesta/Virtual\_Labs/freq/freq6.html. - [18] Pgm file format, http://netpbm.sourceforge.net/doc/pgm.html. - [19] Salt and pepper noise, http://en.wikipedia.org/wiki/Salt\_and\_pepper\_noise. - [20] Xilinx file extensions, http://www.xilinx.com/itp/xilinx8/help/platform\_studio/html/ps\_r\_gst\_project\_files.htm. - [21] Mood A., F Graybill, and D Boes. *Introduction to the Theory of Statistics*. McGraw-Hill, 3rd edition, 1974. - [22] Henrik Backe-Hansen. Defective pixel correction. Technical report, 2009. - [23] Nokia Coroporation. Smia 1.0 part 1:functional spesification. Technical report, 2004. - [24] Granite Island group. Rs232 interface. Technical report. - [25] Rod Jesman, Fernando Martinez Vanilla, and Jafar Saniie. Microblaze tutorial creating a simple embedded system and adding custom peripheral using xilinx edk software tools. Technical report. - [26] Xilinx. Ml501 evalutaion platform. Technical report. - [27] Xilinx. Using and creating interrupt-based systems. Technical report, 2005. - [28] Xilinx. Libxil fatfile system(fatfs). Technical report, 2006. - [29] Xilinx. System ace compactflash solution. Technical report, 2008. - [30] Xilinx. Defective pixel correction v1.0. Technical report, 2009. - [31] Xilinx. Edk concepts, tools, and techniques. Technical report, 2009. - [32] Xilinx. Embedded system tools reference guide. Technical report, 2009. - [33] Xilinx. Logicore ip xps interrupt controller (v2.01a). Technical report, 2010. - [34] Wang Yuanji, Li Jianhua, Lu Yi, Fu Yao, and Jiang Qinzhong. Image quality evaluation based on image weighted separating block peak signal to noise ratio, 2003. ### .1 VHDL #### .1.1 VHDL Source Code #### Median Module ``` : median.vhd -- Title — Design : defect pixel corr : Henrik Backe-Hansen Author : NTNU / Aptina Norway — Company -- Description : this module will take the w_size, enable and data_in as the primary input signals. --the enable signal will denote that a new value is ready at the data in port. ---the w_size will determine the size of the internal data array as the size is w size*w size-1 -The values are first inputed into the data array and then sorted --the median of the array is then put on the median output port and the done flag is set to '1'; library IEEE; use IEEE.std logic 1164.all; use work.size.all; entity median is port ( rst : in std_logic; module --clock -- reset signal from top level data_in : in integer range 0 to bit_depth; —integers from the sliding window enable : in --signal to enble the std_logic; median module : out std logic; ---signal denotes the median values is found median : out integer range 0 to bit depth —the corresponding median value ); end entity; architecture med arch of median is -Signal declaration ``` ``` type state type is (idle, read values, start, one, two, three, reset); signal cs, ns: state type; type data format is array (8 downto 0) of integer range 0 to bit depth; --input data array size setup signal data: data format:= (others => 0); begin This process resets the module in case of the rst signal being evaluated to '1'. --It changes the value of the ns(Next State) signal to the cs(Current State) signal if rst is '0' sync proc: process (clk, rst) begin if (rst = '1') then cs \ll reset; elsif (rising edge (clk)) then cs \le ns; end if; end process; -temp is a variable used when two values changes places -index is used to loop through the array —median counter points to the position of the median in a sorted array --count counts the number of instruction that can be done on one pass of the array -packet counter is the number of values in the data array and if all the packets are present --it will start the median calculation by setting ns to start --state idle will trigger on the enable signal and then set the ns signal to read values --the read_values state will store the input in the location ,in the data array, denoted by packet counter -state one will loop through all the values and swap values if the higher value is at the higher position --when all the values have been sorted count = w_data*w_size-1, and the ns signal is three --In the state three the median is set on the output, the done flag is set to '1' and ns is idle, —and the median module is ready to read other values output signals are given default values in the begining of the process ``` ``` comb proc : process (cs, enable, data in) : natural range 0 to 255 := 0; variable temp variable index : natural range 0 to 255 := 1; variable count : natural range 0 to 255 := 0; variable packet_counter: natural range 0 to 255 := 0; begin <= '0'; done median = 0; ns \ll idle; case cs is when reset => median \ll 0; packet_counter := 0; packet counter:=0; count := 0; index := 0; ns \le idle; when idle => if (enable = '1') then ns <= read_values; else ns \ll cs; end if; when read_values => data(packet_counter) <= data_in; packet counter := packet counter +1; if (packet counter = data 'length) then ns \le start; else ns \le idle; end if; when start => packet_counter := 0; count := 0; ns \le one; index := 1; when one => if(data(9 - index)) > data(8 - index))then ``` ``` temp := data(9 - index); \mathtt{data}\,(9\ -\ \mathtt{index}\,) \! < =\ \mathtt{data}\,(8\ -\ \mathtt{index}\,)\;; data(8 - index) \le temp; count := 0; else count := count +1; temp := 0; end if; if (index = 8) then ns \le start; index := 0; else ns \le two; end if; index := index +1; if(count = 8) then ns \ll three; else ns \le two; end if; when two => ns <= one; when three => ns <= idle; done <= '1'; median <= data(4); when others => ns <= idle; end case; end process; end architecture; ``` #### Image core Module ``` — Title : image_core — Design : defect pixel corr : Henrik Backe-Hansen -- Author — Company : NTNU / Aptina Norway -- File : image core.vhd -- Generated : Mon Feb 1 14:09:23 2010 -- From : interface description file — Ву : Itf2Vhdl ver. 1.20 - Description : This image core is the top level unit of the defective pixel correction algorithm. It uses —the median module in order to calculate the median of the values at its input. The image core is enabled by the mod_en signal and will then read in one pixel-value at the time untill all pixels have been read —The data array will consist of the read pixel-values and a two pixel border with the value 127. This is to make it —easier to read and correct edge and corner pixels. library IEEE; use IEEE.STD LOGIC 1164.all; use work.size.all; entity image core is port ( clk : in std logic; : in std_logic; mod en rst : in std logic; : in integer range 0 to bit depth; core in di : in std logic; —data in : out std logic; —data out do core_out : out integer range 0 to bit_depth ); end image core; architecture image core arch of image core is -Signals to the median mod- -These signals are the signals that communicates between the median module and the image core ``` ``` signal enable : std logic; signal data in :integer range 0 to bit depth; signal done :std_logic; signal median :integer range 0 to bit_depth; ---type definitions---- type pix map is array (0 to size x+3,0 to size y+3) of bit; --pixel map type img array is array (0 to size x+3,0 to size y+3) of integer range 0 to bit depth; —image array with 2 pixel border type bye_array is array(0 \text{ to size}_x-1,0 \text{ to size}_y-1) of integer range 0 to bit depth; —bayer image array data type median_array is array(8 downto 0) of integer range 0 to bit depth; --array with the array to the median mod ---FSM---- type state_type is (idle ,read_values ,correct ,read_out ,padding127 , data_mapping, de_mapping, find_defects, reset); states signal cs, ns: state type; ---FSM signals --Instansiation of the median module component and mapping signals to the median module signals begin median mod: entity work.median (med arch) port map( clk, rst, data in, enable, done, median ); --process that is sensitive to the input values, clk, reset, and done signal. The process will read the pixels into the ---bayer array, then add a border and map it to the data array. sync proc : process (clk, rst, core in, done) variable bayer_array : bye_array; variable pixel map :pix map; ``` ``` variable data :img array; variable med array : median array; variable state : integer := 1; variable a : integer := 0; variable b : integer := 0; :integer range 0 to bit depth:= 0; variable high variable low : integer \ \, range \ \, 0 \ \, to \ \, bit\_depth := bit\_depth \, ; : integer range 0 to 2 := 0; variable timer variable x_cor : integer range 0 to size x-1:=0; variable y cor : integer range 0 to size y-1:=0; variable read state :integer range 0 to 3:= 1; variable testing : integer := th; begin if (rst = '1') then cs \le reset; elsif (rising_edge(clk))then cs \le ns; case cs is -The reset state will set default values to all the variables used when reset => timer := 0; := 0: := 0; med array := (others => 0); data := (others \Rightarrow (others \Rightarrow 0)); bayer array := (others \Rightarrow (others \Rightarrow 0)); pixel map :=(others =>(others => '0')); ns \le idle; -The idle state will wait for the mod en signal to start its work when idle => do \le '0'; if (mod_en = '1') then core out \leq 0; ns <= read_values; else ns \ll cs; end if; ``` ``` -The values are read into the bayer array in this state. The values come from the input integer in. when read_values => -- read the image values and store them in the data array case read state is when 0 \Rightarrow if(x\_cor = size\_x-1)then x \quad cor := 0; read state := 2; ns <= read_values; x_{cor} := x_{cor} + 1; read\_state := 1; end if; when 1=> if (di = '1') then bayer_array(x_cor, y_cor) := core_in; if (y \text{ cor } = \text{ size } y-1) then read\_state := 0; y\_cor := 0; y\_cor := y\_cor +1; end if; else read state := 1; end if; when 2=> ns \le padding 127; read state:= 1; when others => read state := 1; end case; --The padding127 state will fill the entire data array with the values of 127. This is in order to make a two pixel border -when the bayer_array is mapped to the data array. The data array hence have the size 4 greater than the bayer array -filling the entire 2D array with when padding 127 \Rightarrow the value 127 for a in size x+3 downto 0 loop for b in size y+3 downto 0 loop ``` ``` data(a,b) := 127; end loop; end loop; ns <= data_mapping; -Data mapping is where the bayer array is mapped onto the data array -The result is when an array with the bayer array with a two pixel —of the values 127(\text{halv way between 0 and } 255) when data_mapping => for a in size x-1 downto 0 loop ---mapping the data from the bayer array to the data array for b in size_y-1 downto 0 loop data(a+2,b+2):= bayer array(a,b); end loop; end loop; ns <=find defects; -This state will go through the enitire image, exept the borders, and place a '1' entry into the pixe_map at that possision —if the value is classefied to be defective. For every pixel its eight pixels of the same color are evaluated in order to -determine if the pixel is defective. If the middle pixel have less value than the smallest values - threshold or higher than -- the highest value + threshold, the pixel is classefied as defective , denoted by a '1' entry in the pixel map at that position. -The highest and lowest of the eight pixels have to be recalculated for every pixel. That is done with two for loops. —When done going through the image tha next state will be correct. when find defects => for j in size_y+1 downto 2 loop for i in size_x+1 downto 2 loop med array(0) := data(i-2,j-2); med array(1) := data(i, j-2); med array(2) := data(i+2,j-2); med_array(3) := data(i-2,j+2); := data(i, j+2); med array(4) med_array(5) := data(i+2,j+2); med array (6) := data(i-2,j); med array(7) := data(i+2,j); med array(8) := data(i,j); ``` ``` high:=0; low := 255; for count in 0 to 7 loop ——finding highest and lowest value if (med array (count)>high) then high:= med array(count); end if; end loop; for count in 0 to 7 loop ——finding highest and highest value if (med array (count) < low) then low:= med_array(count); end if; end loop; if(data(i,j) > high+testing)then ---defective pixel with higher value pixel map(i,j):= '1'; --adding the location to the pixel map elsif(data(i,j) < low-testing)then —-defective pixel with lower value pixel map(i,j):= '1'; —adding the location to the pixel map end if; end loop; end loop; ns <= correct; -The correct state consist of a state machine that is triggered by the state variable. -The 0 and 1 state acts as a double for loop in order to go through the pixel map to search for '1' entries. --If there is a '1' entry, denoteing a defective pixel, the median array if filled. —The value of the neigboring pixel is added to the median array as long as that position does not contain a '1' entry in —the pixel map. --State 2-10 will set the enable flag, set the data in value according to the values in the median array, then reset the enable —When all the values in the median array have been sent the state will be 11, and will be there until the median value —is not zero. -At that point the median value will be placed in its proper position in the data array, and then set the state variable to 1; ``` -Being in state 12 indicates that the entire image have been corrected according to the '1' entries in the $\bar{\rm pixel\_map}$ when correct => case state is when 0=> —outer for loop if (a=size x+2) then state := 12;a := 0; else a := a+1;state := 1;b := 0; end if; when $1 \Rightarrow --inner$ for loop $if(b=size_y+3)then$ state := 0;else if (pixel map(a,b)='1') then --a+2,b+2if $(pixel_map(a+2,b+2)='1')$ then med array(0) := 127;else med array(0) := data(a+2,b+2);end if; if (pixel map (a+2,b) = '1') then --a+2,bmed array(1) := 127;else med array(1) := data(a+2,b);end if; if $(pixel_map(a+2,b-2)='1')$ then -a+2,b-2med array(2) := 127;else med array(2) := data(a+2,b-2);end if; if (pixel map (a, b+2) = '1') then —a, b+2 med array(3) := 127;else $med_array(3) := data(a,b+2);$ end if; med array(4) := data(a,b); --a,bif (pixel map (a, b-2) = '1') then —a, b-2 ``` med_array(5) := 127; else med_array(5) := data(a,b-2); end if; if (pixel map (a-2,b+2) = '1') then -a-2,b+2 med array (6) := 127; med_array(6) := data(a-2,b+2); end if; if (pixel_map(a-2,b) = '1') then --a-2,b med_array(7) := 127; else med_array(7) := data(a-2,b); end if; if (pixel_map(a-2,b-2)='1') then --a-2,b-2 med array(8) := 127; med_array(8) := data(a-2,b-2); end if; state := 2; else state := 1; end if; b := b+1; end if; when 2=> --start sending data enable <= '1'; data_in <= med_array(0); --1st value if (timer = 2) then ns \le correct; state := 3; e\,n\,a\,b\,l\,e\ <=\ \ '0\ '; timer := 0; else ns \le correct; state := 2; timer := timer +1; end if; when 3 => enable <= '1'; ``` ``` data_in <= med_array(1); -2nd value if (timer = 2) then ns <= correct; state := 4; enable <= \ '0'; timer := 0; else ns \le correct; state := 3; timer := timer +1; end if; when 4 => enable <= '1'; data_in <= med_array(2); --3rd value if (timer = 2) then ns <= correct; state := 5; enable <= '0'; timer := 0; else ns \le correct; state := 4; timer := timer +1; end if; when 5 => enable <= '1'; data_in <= med_array(3); --4th value if (timer = 2) then ns <= correct; state := 6; enable <= '0'; timer := 0; else ns \le correct; state := 5; timer := timer +1; end if; when 6 \Rightarrow enable <= '1'; data_in <= med_array(4); --5th value if (timer = 2) then ns <= correct; state := 7; enable <= '0'; timer := 0; else ``` ``` ns \le correct; state := 6; timer := timer +1; end if; when 7 \Rightarrow enable <= '1'; data_in \le med_array(5); —6th value if (timer = 2) then ns <= correct; state := 8; enable <= '0'; timer := 0; else ns <= correct; state := 7; timer := timer +1; end if; when 8=> enable \ll '1'; data_in \le med_array(6); —7th value if (timer = 2) then ns <= correct; state := 9; enable \ll '0'; timer := 0; ns \!\!< = correct; state := 8; timer := timer +1; end if; when 9 => enable <= '1'; data_in \le med_array(7); —8th value if (timer = 2) then ns \le correct; state := 10; enable <= '0'; \operatorname{timer} \ := \ 0 \, ; else ns \le correct; state := 9; timer := timer +1; end if; when 10 \Rightarrow enable <= '1'; ``` ``` data_in \le med_array(8); --9th value if (timer = 2) then ns <= correct; state := 11; enable <= '0'; timer := 0; else ns \le correct; state := 10; timer := timer +1; end if; when 11 = > if (done = '1') then --waiting for the median module to produce its output data(a,b-1):= median; --replacing the defective value with the median of its neighboring pixels state := 1; else \mathrm{state}\ :=\ 11; end if; ns <= correct; when 12 \Rightarrow ns <= de_mapping; when others => state:= 1; end case; -The two pixel border is removed in the de_mapping state. -The new bayer array has size of the original array, but with corrected values. when de_mapping => for a in size_x-1 downto 0 loop for b in size y-1 downto 0 loop bayer array(a,b) := data(a+2,b+2); end loop; end loop; ns <= read_out; -Read_out will read out the data array, one value at the time when read out => ``` ``` case read_state is when 0 = > if(x\_cor = size\_x-1)then read_state := 3; x_{cor} := 0; x_{cor} := x_{cor} + 1; read state:= 1; end if; when 1=> do \ll '1'; --x_cor,y_cor core_out <= bayer_array(x_cor,y_cor); read\_state := 2; when 2=> do \ll 0; if(y\_cor = size\_y-1)then y\_cor := 0; read_state := 0; read\_state := 1; y\_cor := y\_cor + 1; end if; when 3=> ns \!\! < = idle ; when others => read\_state := 1; end case; -Required state as to avioid cs signal with a wrong value(not a defined state) when others => ns \le idle; end case; end if; end process; end image_core_arch; ``` #### Ctrl Module ``` -- Title : ctrl -- Design : defect pixel corr : Henrik Backe-Hansen -- Author -- Company : NTNU / Aptina Norway : ctrl.vhd -- File -- Generated : Fri Mar 5 13:51:13 2010 -- From : interface description file — By : Itf2Vhdl ver. 1.20 -- Description : Top level unit in the defective pixel correction algorithm. Reads -- data from RAM and inputs them to image core, and reads the values from image core -- back to RAM library IEEE; use IEEE.STD LOGIC 1164.all; use work.size.all; use IEEE.numeric std.all; entity ctrl is port ( : in std logic; clk data_out : out integer; rst : in std_logic ); end ctrl; architecture ctrl_arch of ctrl is -The following signals are used to map to the image core --signals to these signals in order to communicate with --sub-modules signal mod en :std logic; signal core_in :integer range 0 to bit depth; signal core out :integer range 0 to bit depth; ``` ``` --State machine signals for the two state machines. -The cs r and ns r denotes the read operation from ram while --cs w and ns_w denotes a write operation from ram type state_type is (idle, one, two, start, wait1, wait2); signal cs r,cs w,ns r,ns w:state type; begin -Initialize the image core module and mapping signals to the module image core module: entity work.image core (image core arch) port map( clk, mod en, rst, core_in, di, do, core_out ); -Synchrounes process that makes the state transistions on the rising edge of the clock sync proc: process(clk) begin if (rising_edge(clk))then if (rst = '1') then cs r \le idle; cs_w \ll idle; else cs r \le ns r; cs w \le ns w; end if; end if; end process; -This process will read all the vlaues of an image from ram into the image core -the ram module inputs and outputs only std logic vector so the values (ram out) ---needs to be converted from std_logic_vector to integer before inputting ``` ``` -- them to the image core. The flags data in (di) also needs to be set in order for the lamge core ---to know that its receiving data. The mod_en signal also needs to be set in order to enable the -\mathrm{image\_core} . -The state machine is necesarry in order to get the right timing on the input signals to the image core -Read adr is a variable that needs to be converted to std_logic_vector in order to get correct -communication between ram and image core write_to_core_from_ram:process(cs_r, data_array) variable sent_count:natural:= 0; begin case cs r is when idle => sent count := 0; ns r \le start; \mod \ \mathrm{en} <= '1'; when start \Rightarrow ns r \le one; when one => if(sent\_count = ((size\_x*size\_y)))then ns r \le start; else = two; ns r end if; \bmod\_{en} \quad <= \ '0 \ '; di <= '0'; when two => <= '1'; <= data_array(sent_count);</pre> core_in sent\_count := sent\_count +1; ns_r <= one; when others => ns r \le idle; end case; end process; ``` ``` -This process will write the output values from the image_core back to the ram module. -There they will be stored in the ram block array. -Data out from the image_core is denoted by the data out(do) flag so cheching the flag --will ensure that all data out values are stored to ram. -The ram module only accepts std_logic_vector so the write_adr and value will be converted from -integer to eight bit std_logic_vector. -The process will start writing values at position 0 and end with position size x * size y -1 read_from_core_to_ram:process(do,cs_w,mod_en,core_out) variable recv_count:natural range 0 to ((size_x*size_y)):= 0; begin case cs_w is when idle => if (do = '1' and mod_en = '0') then data out <= core out; recv count := recv count +1; end if; when others => ns w \le idle; end case; end process; end ctrl_arch; ``` #### Size Package ``` — Title : size_package -- Design : defect_pixel_corr -- Author : Henrik Backe-Hansen -- Company : NTNU / Aptina Norway -- File : size_package.vhd -- Generated : Fri Feb 26 15:09:28 2010 -- From : interface description file -- By : Itf2Vhdl ver. 1.20 -- Description : library IEEE; use IEEE.std logic 1164.all; use IEEE.numeric_std.all; use IEEE.std logic unsigned.all; package size is constant size_y : natural := 256; --size of the image in the y direction constant size x : natural := 256; --size of the image in the x direction constant th : natural := 50; ---threshold for detecting defective pixels constant bits : natural :=8; —number of bits in the pixelvalues (8=255) constant bit depth : natural := 2** bits; --255 for 8 bits type ram type is array (0 to 65535) of integer; signal data array:ram type; end size; ``` ## User\_logic | | user_logic.vhd - entity/architecture pair | |--|-------------------------------------------------------------------------| | | | | | ************************************** | | | ** | | | ** ** Xilinx , Inc . ** | | | ** XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS" ** | | | ** AS A COURTESY TO YOU, SOLELY FOR USE IN DEVELOPING PROGRAMS AND ** | | | ** SOLUTIONS FOR XILINX DEVICES. BY PROVIDING THIS DESIGN, CODE, ** | | | ** OR INFORMATION AS ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE, ** | | | ** APPLICATION OR STANDARD, XILINX IS MAKING NO REPRESENTATION ** | | | ** THAT THIS IMPLEMENTATION IS FREE FROM ANY CLAIMS OF INFRINGEMENT, ** | | | $\ast\ast$ AND YOU ARE RESPONSIBLE FOR OBTAINING ANY RIGHTS YOU MAY | | | REQUIRE ** ** FOR YOUR IMPLEMENTATION. XILINX EXPRESSLY DISCLAIMS ANY | | | ** ** WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE ** | | | ** IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR ** | | | ** REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF ** | | | ** INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ** | | | ** FOR A PARTICULAR PURPOSE. | | | ** | | | ** | | | ********* | | | | | | Filename: user_logic.vhd | | | Version: 1.00.a | | | Description: User logic. | ``` Fri May 28 23:21:09 2010 (by Create and Import — Date: Peripheral Wizard) - VHDL Standard: VHDL'93 - Naming Conventions: "* n" active low signals: "clk", "clk div#", "clk # clock signals: "rst", "rst_n" reset signals: "C *" generics: "* TYPE" user defined types: state machine next state: "*\_ns" "* cs" state machine current state: combinatorial signals: "* com" pipelined or register delay signals: "* d#" "*cnt*" counter signals: clock enable signals: "*_ce" "* i" internal version of output port: "*\_\!\operatorname{pin}" device pins: "- Names begin with ports: Uppercase" "* PROCESS" processes: component instantiations: "<\!\!ENTITY>\!\!I<\!\!\#|FUNC\!\!>" — DO NOT EDIT BELOW THIS LINE — library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; use IEEE.NUMERIC_STD.all; library proc_common_v3_00_a; use proc_common_v3_00_a.proc_common_pkg.all; — DO NOT EDIT ABOVE THIS LINE — --USER libraries added here - Entity section - Definition of Generics: C SLV DWIDTH - Slave interface data bus width - Number of software accessible C_NUM_REG registers -- Number of interrupt event C NUM INTR - Definition of Ports: ``` ``` -- Bus to IP clock Bus2IP Clk Bus2IP Reset -- Bus to IP reset Bus2IP Data -- Bus to IP data bus Bus2IP_BE - Bus to IP byte enables Bus2IP\_RdCE - Bus to IP read chip enable -- Bus to IP write chip enable Bus2IP WrCE {\rm IP2Bus\_Data} -- IP to Bus data bus IP2Bus\_RdAck -- IP to Bus read transfer acknowledgement IP2Bus\_WrAck -- IP to Bus write transfer acknowledgement IP2Bus_Error -- IP to Bus error response IP2Bus IntrEvent -- IP to Bus interrupt event entity user_logic is generic --- ADD USER GENERICS BELOW THIS LINE ---- ---USER generics added here — ADD USER GENERICS ABOVE THIS LINE — -- DO NOT EDIT BELOW THIS LINE --- -- Bus protocol parameters, do not add to or delete C SLV DWIDTH : integer := 32; C_NUM_REG : integer := 6; C NUM INTR : integer := 1 -- DO NOT EDIT ABOVE THIS LINE - ); port -- ADD USER PORTS BELOW THIS LINE ---- --USER ports added here -- ADD USER PORTS ABOVE THIS LINE - — DO NOT EDIT BELOW THIS LINE — -- Bus protocol ports, do not add to or delete Bus 2IP\_Clk std_logic; in Bus2IP_Reset std_logic; in Bus2IP Data in std logic vector (0 to C_SLV_DWIDTH-1); Bus2IP BE std_logic_vector(0 to in C_SLV_DWIDTH/8-1); Bus2IP RdCE std_logic_vector(0 to : in C_NUM_REG_{-1}; Bus2IP\_WrCE std_logic_vector(0 to in C NUM REG-1); IP2Bus Data : out std_logic_vector(0 to C SLV DWIDTH-1); ``` ``` IP2Bus RdAck : out std_logic; IP2Bus WrAck : out std logic; : out std logic; IP2Bus\_Error IP2Bus_IntrEvent : out std_logic_vector(0 to C_NUM_INTR-1) — DO NOT EDIT ABOVE THIS LINE — ); attribute SIGIS : string; attribute SIGIS of Bus2IP Clk : signal is "CLK"; attribute SIGIS of Bus2IP Reset : signal is "RST"; end entity user_logic; Architecture section architecture IMP of user_logic is -- USER signal declarations added here, as needed for user logic - Signals for user logic slave model s/w accessible register example signal slv reg0 : std logic vector (0 to C_SLV_DWIDTH-1);—vals read by cpu signal slv_reg1 : std_logic_vector(0 to C_SLV_DWIDTH-1);—reset write signal slv_reg2 : std logic vector (0 to C_SLV_DWIDTH-1); --reset read signal slv reg3 : std logic vector (0 to C_SLV_DWIDTH-1);—di write : std logic vector (0 to signal slv reg4 C_SLV_DWIDTH-1);—di read signal slv reg5 : std logic vector (0 to C SLV DWIDTH-1);—value in signal slv_reg_write_sel : std_logic_vector(0 to 5); signal slv_reg_read_sel : std_logic_vector(0 to 5); signal slv_ip2bus_data : std_logic_vector(0 to C SLV DWIDTH-1); signal slv_read_ack : std_logic; signal slv_write_ack : std logic; - Signals for user logic interrupt example signal intr counter : std logic; ``` ``` signal reset_wr : std_logic; signal output : std_logic_vector(31 downto 0); signal clk : std_logic; signal rst :std_logic; component ctrl port ( Bus2IP Clk :in std_logic; output : out std logic vector(31 downto 0); Bus2IP_Reset : in std_logic end component; begin \langle = slv reg0(0); reset\_wr --- USER logic implementation added here read values: process (Bus2IP Clk) is variable i:integer:= 0; begin if (rising_edge (Bus2IP_Clk)) then if (Bus2IP Reset = '1') then intr_counter <= '0'; else intr_counter <= '1'; if (reset\_wr = '1') then intr counter <= '0'; end if; end if; end if; end process; IP2Bus IntrEvent(0) <= intr counter; — Example code to read/write user logic slave model s/w accessible registers -- Note: -- The example code presented here is to show you one way of reading/writing software accessible registers implemented in the user logic slave model. ``` ``` -- Each bit of the Bus2IP WrCE/Bus2IP RdCE signals is configured to correspond - to one software accessible register by the top level template. For example, - if you have four 32 bit software accessible registers in the user logic, - you are basically operating on the following memory mapped registers: Bus2IP WrCE/Bus2IP RdCE Memory Mapped Register "1000" C BASEADDR + 0x0 "0100" C BASEADDR + 0x4 "0010" C BASEADDR + 0x8 "0001" C BASEADDR + 0xC slv reg_write_sel <= Bus2IP_WrCE(0 to 5); slv reg read sel \le Bus2IP RdCE(0 to 5); <= Bus2IP WrCE(0) or Bus2IP WrCE(1) or</pre> slv write ack Bus2IP WrCE(2) or Bus2IP WrCE(3) or Bus2IP WrCE(4) or Bus2IP WrCE(5); slv read_ack \leq Bus2IP RdCE(0) or Bus2IP RdCE(1) or Bus2IP RdCE(2) or Bus2IP RdCE(3) or Bus2IP RdCE(4) or Bus2IP RdCE(5); -- implement slave model software accessible register(s) SLAVE REG WRITE PROC : process ( Bus2IP Clk ) is begin if Bus2IP Clk'event and Bus2IP Clk = '1' then if Bus2IP Reset = '1' then slv reg5 \ll (others \implies '0'); else case slv_reg_write_sel is when "100000" => for byte index in 0 to (C SLV DWIDTH/8)-1 loop if (Bus2IP BE(byte index) = '1') then slv reg0 (byte index*8 to byte index*8+7) <= Bus2IP_Data(byte_index*8 to byte_index*8+7); end if; end loop; when "010000" \implies for byte_index in 0 to (C_SLV_DWIDTH/8)-1 loop if (Bus2IP BE(byte index) = '1') then slv reg1(byte index*8 to byte index*8+7) <= Bus2IP Data(byte_index*8 to byte_index*8+7); end if; end loop; when "001000" => ``` ``` for byte index in 0 to (C SLV DWIDTH/8)-1 loop if (Bus2IP BE(byte index) = '1') then slv reg2 (byte index*8 to byte index*8+7) <= Bus2IP_Data(byte_index*8 to byte_index*8+7); end if; end loop; when "000100" => for byte index in 0 to (C SLV DWIDTH/8)-1 loop if (Bus2IP_BE(byte_index) = '1') then slv reg3 (byte index*8 to byte index*8+7) <= Bus2IP Data (byte index *8 to byte index *8+7); end if; end loop; when "000010" => for byte index in 0 to (C SLV DWIDTH/8)-1 loop if (Bus2IP BE(byte index) = '1') then slv reg4(byte index*8 to byte index*8+7) <= Bus2IP Data (byte index *8 to byte index *8+7); end if; end loop; when "000001" \Longrightarrow for byte_index in 0 to (C_SLV_DWIDTH/8)-1 loop if (Bus2IP BE(byte index) = '1') then slv reg5 (byte index*8 to byte index*8+7) <= Bus2IP Data (byte index *8 to byte index *8+7); end if; end loop; when others => null; end case; end if; end if; end process SLAVE REG WRITE PROC; -- implement slave model software accessible register(s) read mux SLAVE REG READ PROC: process ( slv reg read sel, slv reg0, slv reg1 , slv reg2, output, slv reg4, slv reg5) is begin case slv_reg_read sel is when "1000000" \Rightarrow slv ip2bus data \ll slv reg0; when "010000" \Rightarrow slv ip2bus data <= output; when "001000" \Rightarrow slv_ip2bus_data \ll slv_reg2; when "000100" \Rightarrow slv ip2bus data \ll slv reg3; when "000010" \Rightarrow slv_ip2bus_data \ll slv_reg4; when "000001" \Rightarrow slv_ip2bus_data \ll slv_reg5; when others \Rightarrow slv ip2bus data \Leftarrow (others \Rightarrow '0'); end case; ``` ``` end process SLAVE_REG_READ_PROC; —— Example code to drive IP to Bus signals —— Example code to drive IP to Bus signals —— IP2Bus_Data <= slv_ip2bus_data; IP2Bus_WrAck <= slv_write_ack; IP2Bus_RdAck <= slv_read_ack; IP2Bus_Error <= '0'; end IMP; ``` # ${\bf My\_custom\_ip\_register}$ | my_custom_ip_register.vhd - entity/architecture pair | |-----------------------------------------------------------------------------------------------------------------------------------------------------------| | — IMPORTANT: — DO NOT MODIFY THIS FILE EXCEPT IN THE DESIGNATED SECTIONS. | | — DO NOT MODIFT THIS FILE EXCELT IN THE DESIGNATED SECTIONS. | | — SEARCH FOR —USER TO DETERMINE WHERE CHANGES ARE ALLOWED. | | — TYPICALLY, THE ONLY ACCEPTABLE CHANGES INVOLVE ADDING NEW — PORTS AND GENERICS THAT GET PASSED THROUGH TO THE INSTANTIATION — OF THE USER_LOGIC ENTITY. | | | | ********************************** | | ** Copyright (c) 1995-2010 Xilinx, Inc. All rights reserved. | | ** | | ** | | ** Xilinx , Inc . | | ** | | ** XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS" ** | | ** AS A COURTESY TO YOU, SOLELY FOR USE IN DEVELOPING PROGRAMS AND | | ** SOLUTIONS FOR XILINX DEVICES. BY PROVIDING THIS DESIGN, CODE, | | ** ** OR INFORMATION AS ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE, | | ** | | ** | | ** THAT THIS IMPLEMENTATION IS FREE FROM ANY CLAIMS OF INFRINGEMENT, ** | | ** AND YOU ARE RESPONSIBLE FOR OBTAINING ANY RIGHTS YOU MAY | | REQUIRE ** | | ** FOR YOUR IMPLEMENTATION. XILINX EXPRESSLY DISCLAIMS ANY | | ** ** WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE | | ** ** IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR | | ** ** REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF | | ** INEDDICEMENT INDITED WARDANGED OF MEDCHANGARD FRY AND FRANCES | | ** INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ** | | ** FOR A PARTICULAR PURPOSE. | | ** | ``` - ** my custom ip register.vhd - Filename: -- Version: 9.00.a - Description: Top level design, instantiates library components and user logic. Sat May 29 12:48:00 2010 (by Create and Import Peripheral Wizard) -- VHDL Standard: VHDL'93 - Naming Conventions: active low signals: "* n" "clk", "clk_div#", "clk_# clock signals: x'' "rst", "rst n" reset signals: ^{\prime\prime}\mathrm{C}~*^{\prime\prime} generics: "* TYPE" user defined types: "*_ns" state machine next state: "* cs" state machine current state: combinatorial signals: "* com" "* d#" pipelined or register delay signals: counter signals: "*cnt*" "* ce" clock enable signals: "*_i" internal version of output port: "*_pin" device pins: "- Names begin with ports: Uppercase" "* PROCESS" processes: "<\!\!ENTITY>\!\!I<\!\!\#|FUNC\!\!>" component instantiations: library ieee; use ieee.std logic 1164.all; use ieee.std_logic_arith.all; use ieee.std_logic_unsigned.all; library proc_common_v3_00_a; use proc common v3 00 a.proc common pkg.all; use proc_common_v3_00_a.ipif_pkg.all; library interrupt_control_v2_01_a; use interrupt_control_v2_01_a.interrupt_control; library plbv46 slave single v1 01 a; use plbv46 slave single v1 01 a.plbv46 slave single; ``` ``` library my custom ip register_v9_00_a; use my custom ip register v9 00 a.user logic; -- Entity section — Definition of Generics: -- PLBv46 slave: base address C BASEADDR C HIGHADDR -- PLBv46 slave: high address -- PLBv46 slave: address bus width C SPLB AWIDTH C_SPLB_DWIDTH -- PLBv46 slave: data bus width C SPLB NUM MASTERS -- PLBv46 slave: Number of masters C_SPLB_MID_WIDTH -- PLBv46 slave: master ID bus width C SPLB NATIVE DWIDTH -- PLBv46 slave: internal native data bus width C SPLB P2P -- PLBv46 slave: point to point interconnect scheme C SPLB SUPPORT BURSTS - PLBv46 slave: support bursts C SPLB SMALLEST MASTER -- PLBv46 slave: width of the smallest master C SPLB CLK PERIOD PS -- PLBv46 slave: bus clock in picoseconds -- PLBv46 slave: Data Phase Timer C INCLUDE DPHASE TIMER configuration; 0 = exclude timer, 1 = include timer - Xilinx FPGA family C FAMILY — Definition of Ports: -- PLB main bus clock SPLB Clk SPLB Rst -- PLB main bus reset PLB ABus -- PLB address bus PLB UABus -- PLB upper address bus PLB PAValid -- PLB primary address valid indicator PLB SAValid -- PLB secondary address valid indicator -- PLB secondary to primary read PLB_rdPrim request indicator -- PLB secondary to primary write PLB wrPrim request indicator PLB masterID -- PLB current master identifier PLB_abort -- PLB abort request indicator -- PLB bus lock PLB busLock PLB RNW -- PLB read/not write PLB BE - PLB byte enables PLB MSize -- PLB master data bus size PLB size — PLB transfer size PLB type -- PLB transfer type ``` ``` -- PLB lock error indicator PLB lockErr PLB wrDBus — PLB write data bus -- PLB burst write transfer PLB_{\_} wrBurst indicator PLB rdBurst -- PLB burst read transfer indicator PLB wrPendReq -- PLB write pending bus request indicator -- PLB read pending bus request PLB rdPendReq indicator {\tt PLB\_wrPendPri} - PLB write pending request priority PLB rdPendPri -- PLB read pending request priority PLB reqPri -- PLB current request priority -- PLB transfer attribute PLB TAttribute Sl_addrAck - Slave address acknowledge Sl SSize — Slave data bus size Sl wait -- Slave wait indicator Sl rearbitrate -- Slave re-arbitrate bus indicator Sl wrDAck -- Slave write data acknowledge Sl\_wrComp -- Slave write transfer complete indicator -- Slave terminate write burst Sl wrBTerm transfer Sl rdDBus -- Slave read data bus Sl rdWdAddr -- Slave read word address Sl rdDAck -- Slave read data acknowledge Sl_rdComp - Slave read transfer complete indicator Sl rdBTerm -- Slave terminate read burst transfer -- Slave busy indicator Sl MBusy Sl_MWrErr -- Slave write error indicator - Slave read error indicator Sl MRdErr Sl MIRQ - Slave interrupt indicator IP2INTC Irpt — Interrupt output to processor entity my custom ip register is generic — ADD USER GENERICS BELOW THIS LINE — ---USER generics added here — ADD USER GENERICS ABOVE THIS LINE — -- DO NOT EDIT BELOW THIS LINE ---- -- Bus protocol parameters, do not add to or delete ``` ``` C BASEADDR : std\_logic\_vector := X" FFFFFFFF": := X'' C HIGHADDR : std_logic_vector 00000000"; C SPLB AWIDTH : integer := 32: C SPLB DWIDTH := 128; : integer C SPLB NUM MASTERS = 8; : integer C SPLB MID WIDTH : integer := 3; : integer C SPLB NATIVE DWIDTH := 32; C SPLB P2P := 0; : integer : integer : integer C SPLB SUPPORT BURSTS := 0: C_SPLB_SMALLEST_MASTER := 32; C SPLB CLK PERIOD PS : integer := 10000; : integer C_INCLUDE_DPHASE_TIMER := 1; C FAMILY : string = "virtex5 — DO NOT EDIT ABOVE THIS LINE — ); port -- ADD USER PORTS BELOW THIS LINE ---- --USER ports added here -- ADD USER PORTS ABOVE THIS LINE ----- -- DO NOT EDIT BELOW THIS LINE - -- Bus protocol ports, do not add to or delete SPLB Clk std logic; in SPLB Rst : in std_logic; PLB_ABus : in std_logic_vector(0 to 31); std_logic_vector(0 to 31); PLB UABus in PLB PAValid std logic; in PLB SAValid : in std logic; {\rm PLB} \quad {\rm rdPrim} : in std_logic; PLB_wrPrim in std_logic; PLB masterID std logic vector (0 to in C_SPLB_MID_WIDTH-1); PLB abort std logic; in PLB\_busLock std_logic; in PLB_RNW std_logic; in std logic vector (0 to PLB BE in C_SPLB_DWIDTH/8-1); std_logic_vector(0 to 1); PLB MSize : in PLB\_size in std_logic_vector(0 to 3); std logic vector (0 to 2); PLB type : i n PLB lockErr in std_logic; std logic vector (0 to PLB_wrDBus : in C SPLB DWIDTH-1); PLB wrBurst in std logic; PLB rdBurst in std logic; ``` ``` PLB wrPendReq : in std logic; PLB\_rdPendReq : in std logic; PLB wrPendPri : in std_logic_vector(0 to 1); PLB_rdPendPri : in std_logic_vector(0 to 1); PLB reqPri std_logic_vector(0 to 1); in std_logic_vector(0 to 15); PLB TAttribute Sl addrAck : out std_logic; Sl SSize : out std logic vector(0 to 1); Sl wait : out std logic; Sl rearbitrate : out std logic; Sl wrDAck : out std logic; : out std_logic; Sl wrComp Sl wrBTerm : out std logic; Sl rdDBus : out std_logic_vector(0 to C SPLB DWIDTH-1); Sl rdWdAddr : out std logic vector(0 to 3); : out std_logic; Sl rdDAck Sl rdComp : out std logic; Sl rdBTerm : out std logic; : out std logic vector (0 to Sl MBusy C SPLB NUM MASTERS-1); : out std logic vector (0 to Sl MWrErr C SPLB NUM MASTERS-1); : out std logic vector (0 to Sl MRdErr C SPLB NUM MASTERS-1); Sl MIRQ : out std_logic_vector(0 to C_SPLB_NUM MASTERS-1); IP2INTC Irpt : out std logic -- DO NOT EDIT ABOVE THIS LINE - ); attribute SIGIS : string; attribute SIGIS of SPLB Clk : signal is "CLK"; attribute SIGIS of SPLB_Rst : signal is "RST"; attribute SIGIS of IP2INTC Irpt : signal is "INTR LEVEL HIGH"; end entity my custom ip register; Architecture section architecture IMP of my_custom_ip_register is - Array of base/high address pairs for each address range constant ZERO ADDR PAD : std logic vector(0 to 31) := (others => '0'); ``` ``` constant USER SLV BASEADDR : std_logic_vector C BASEADDR or X"00000000"; constant USER_SLV_HIGHADDR : std_logic_vector := C_BASEADDR or X"000000FF"; constant INTR BASEADDR : std_logic_vector := C BASEADDR or X"00000100"; constant INTR HIGHADDR : std logic vector C BASEADDR or X"000001FF"; constant IPIF ARD ADDR RANGE ARRAY : SLV64 ARRAY TYPE := ZERO ADDR PAD & USER SLV BASEADDR, — user logic slave space base address ZERO ADDR PAD & USER SLV HIGHADDR, — user logic slave space high address ZERO ADDR_PAD & INTR_BASEADDR, — interrupt control space base address ZERO_ADDR_PAD & INTR_HIGHADDR — interrupt control space high address ); - Array of desired number of chip enables for each address range constant USER SLV NUM REG : integer := constant USER NUM REG : integer := USER SLV NUM REG; constant INTR NUM CE : integer 16; constant IPIF_ARD_NUM_CE_ARRAY : INTEGER ARRAY TYPE ( 0 => pad_power2 (USER_SLV_NUM_REG), -- number of ce for user logic slave space 1 \implies INTR NUM CE -- number of ce for interrupt control space ); - Ratio of bus clock to core clock (for use in dual clock systems) --1 = ratio is 1:1 -2 = ratio is 2:1 constant IPIF BUS2CORE CLK RATIO : integer := 1; - Width of the slave data bus (32 only) ``` ``` constant USER SLV DWIDTH : integer := C SPLB NATIVE DWIDTH; constant IPIF_SLV_DWIDTH : integer := C SPLB NATIVE DWIDTH; - Number of device level interrupts constant INTR NUM IPIF IRPT SRC : integer := 4; - Capture mode for each IP interrupt (generated by user logic) --1 = pass through (non-inverting) --2 = pass through (inverting) -- 3 = registered level (non-inverting) - 4 = registered level (inverting) --5 = positive edge detect -- 6 = negative edge detect : integer constant USER NUM INTR := constant USER INTR CAPTURE MODE : integer := constant INTR_IP_INTR_MODE_ARRAY : INTEGER ARRAY TYPE 0 \implies USER INTR CAPTURE MODE ); - Device priority encoder feature inclusion/omission - true = include priority encoder - false = omit priority encoder constant INTR INCLUDE DEV PENCODER : boolean := true; — Device ISC feature inclusion/omission - true = include device ISC -- false = omit device ISC := true; ``` ``` -- Index for CS/CE constant USER_SLV_CS_INDEX : integer constant USER_SLV_CE_INDEX : integer calc start ce index (IPIF ARD NUM CE ARRAY, USER SLV CS INDEX); {\tt constant\ INTR\_CS\_INDEX} : integer constant INTR CE INDEX : integer := calc_start_ce_index(IPIF_ARD_NUM_CE_ARRAY, INTR_CS_INDEX); constant USER CE INDEX : integer USER_SLV_CE_INDEX; - IP Interconnect (IPIC) signal declarations signal ipif_Bus2IP_Clk : std_logic; {\tt signal~ipif\_Bus2IP\_Reset} : std logic; signal ipif IP2Bus Data : std logic vector (0 to IPIF_SLV_DWIDTH-1); signal ipif_IP2Bus_WrAck : std_logic; signal ipif IP2Bus RdAck : std logic; signal ipif_IP2Bus_Error : std_logic; signal ipif Bus2IP Addr : std logic vector (0 to C_SPLB_AWIDTH-1); signal ipif Bus2IP Data : std logic vector (0 to IPIF_SLV_DWIDTH-1); signal ipif_Bus2IP_RNW : std_logic; signal ipif_Bus2IP_BE : std logic vector (0 to IPIF_SLV_DWIDTH/8-1); signal ipif Bus2IP CS : std logic vector(0 to (( IPIF\_ARD\_ADDR\_RANGE\_ARRAY' length)/2)-1); signal ipif_Bus2IP_RdCE : std_logic_vector(0 to calc num ce (IPIF ARD NUM CE ARRAY) -1); signal ipif Bus2IP WrCE : std logic vector (0 to calc num ce (IPIF ARD NUM CE ARRAY) -1); signal intr_IPIF_Reg_Interrupts signal intr_IPIF_Lvl_Interrupts : std_logic_vector(0 to 1); : std_logic_vector(0 to INTR_NUM_IPIF_IRPT_SRC-1); signal intr_IP2Bus_Data : std_logic_vector(0 to IPIF SLV DWIDTH-1); signal intr_IP2Bus_WrAck : std_logic; signal intr_IP2Bus_RdAck : std logic; {\color{red} \mathbf{signal} \hspace{0.1cm} intr\_IP2Bus\_Error} : std_logic; signal user_Bus2IP_RdCE : std_logic_vector(0 to USER NUM REG-1); signal user_Bus2IP_WrCE : std logic vector (0 to USER NUM REG-1); ``` ``` signal user_IP2Bus_Data : std_logic_vector(0 to USER_SLV_DWIDTH-1); signal user_IP2Bus_RdAck : std_logic; signal user_IP2Bus_WrAck : std_logic; signal user_IP2Bus_Error : std_logic; signal user IP2Bus IntrEvent : std logic vector(0 to USER\_NUM\_INTR-1)\;; begin - instantiate plbv46_slave_single PLBV46_SLAVE_SINGLE_I : entity plbv46_slave_single_v1_01_a. plbv46_slave_single generic map C_ARD_ADDR_RANGE_ARRAY => IPIF_ARD_ADDR_RANGE_ARRAY, \Rightarrow IPIF_ARD_NUM_CE_ARRAY, C_ARD_NUM_CE_ARRAY C SPLB P2P \Rightarrow C SPLB P2P, \Rightarrow IPIF_BUS2CORE_CLK_RATIO, C_BUS2CORE_CLK_RATIO \Rightarrow C_SPLB_MID_WIDTH, C_SPLB_MID_WIDTH C_SPLB_NUM_MASTERS => C SPLB NUM MASTERS, C SPLB AWIDTH \Rightarrow C_SPLB_AWIDTH, C SPLB DWIDTH \Rightarrow C SPLB DWIDTH. C_SIPIF_DWIDTH \Rightarrow IPIF_SLV_DWIDTH, => C_INCLUDE_DPHASE_TIMER, C_INCLUDE_DPHASE_TIMER \Rightarrow C_FAMILY C_FAMILY port map \Rightarrow SPLB Clk, SPLB Clk SPLB_Rst \Longrightarrow SPLB_Rst, \Rightarrow PLB_ABus, PLB_ABus PLB UABus => PLB UABus, PLB_PAValid => PLB PAValid, => PLB SAValid, PLB SAValid PLB_rdPrim \Rightarrow PLB_rdPrim, => PLB_wrPrim, PLB\_wrPrim {\rm PLB\_masterID} \Rightarrow PLB_masterID, PLB_abort => PLB_abort, PLB busLock => PLB busLock, PLB_RNW \Rightarrow PLB_RNW, PLB BE => PLB BE, => PLB_MSize, PLB_MSize PLB_size \Rightarrow PLB_size, PLB_type \Rightarrow PLB_type, PLB_lockErr => PLB_lockErr, PLB wrDBus \Rightarrow PLB wrDBus, ``` ``` PLB wrBurst \Rightarrow PLB wrBurst, PLB rdBurst => PLB rdBurst, PLB\_wrPendReq ⇒ PLB wrPendReq, PLB_rdPendReq => PLB_rdPendReq, PLB_wrPendPri \Rightarrow PLB_wrPendPri, PLB rdPendPri ⇒ PLB rdPendPri, \Rightarrow PLB_reqPri, PLB\_reqPri PLB_TAttribute => PLB TAttribute, => Sl\_addrAck\;, Sl_addrAck Sl SSize => Sl SSize, Sl wait => Sl wait, \Longrightarrow Sl_rearbitrate, Sl_rearbitrate Sl wrDAck \Rightarrow Sl wrDAck, Sl_wrComp \Rightarrow Sl_wrComp, Sl wrBTerm => Sl wrBTerm, => Sl rdDBus, Sl rdDBus Sl_rdWdAddr \Rightarrow Sl_rdWdAddr, Sl_rdDAck \Rightarrow Sl_rdDAck, => Sl rdComp, Sl rdComp Sl rdBTerm \Rightarrow Sl rdBTerm, Sl MBusy \Rightarrow Sl MBusy, => Sl MWrErr, Sl MWrErr Sl MRdErr \Rightarrow Sl MRdErr, \Rightarrow Sl MIRQ, Sl MIRQ Bus2IP Clk => ipif Bus2IP Clk, Bus2IP\_Reset => ipif_Bus2IP_Reset, IP2Bus_Data => ipif IP2Bus Data, IP2Bus\_WrAck => ipif_IP2Bus_WrAck, => ipif_IP2Bus_RdAck, IP2Bus_RdAck => ipif_IP2Bus_Error, IP2Bus Error Bus2IP\_Addr => ipif Bus2IP Addr, Bus2IP Data => ipif Bus2IP Data, Bus2IP RNW => ipif Bus2IP RNW, \Rightarrow ipif_Bus2IP_BE, Bus2IP\_BE Bus2IP CS \Rightarrow ipif _Bus2IP_CS, Bus2IP RdCE => ipif Bus2IP RdCE, Bus2IP WrCE \Rightarrow ipif Bus2IP WrCE ); — instantiate interrupt_control INTERRUPT_CONTROL_I : entity interrupt_control_v2_01_a. interrupt control generic map C NUM CE \Rightarrow INTR NUM CE, C NUM IPIF IRPT SRC => INTR NUM IPIF IRPT SRC, C IP INTR MODE ARRAY => INTR IP INTR MODE ARRAY, ``` ``` C_INCLUDE_DEV_PENCODER => INTR INCLUDE DEV PENCODER, C INCLUDE DEV ISC => INTR INCLUDE DEV ISC, C_IPIF_DWIDTH => IPIF_SLV_DWIDTH port map => ipif_Bus2IP_Clk, Bus2IP_Clk Bus2IP Reset => ipif Bus2IP Reset, Bus2IP Data \Longrightarrow ipif_Bus2IP_Data, => ipif Bus2IP BE, Bus2IP BE Interrupt RdCE => ipif Bus2IP RdCE( INTR_CE_INDEX to INTR_CE_INDEX+INTR_NUM_CE-1) , => ipif Bus2IP WrCE( Interrupt WrCE INTR_CE_INDEX to INTR_CE_INDEX+INTR_NUM_CE-1), IPIF_Reg_Interrupts => intr_IPIF_Reg_Interrupts, IPIF_Lvl_Interrupts => intr_IPIF_Lvl_Interrupts, > \ user\_IP2Bus\_IntrEvent \; , IP2Bus_IntrEvent Intr 2Bus\_DevIntr => IP2INTC_Irpt, Intr 2Bus\_DBus => intr [IP2Bus_Data, => intr IP2Bus WrAck, Intr2Bus WrAck Intr2Bus_RdAck => intr IP2Bus RdAck, Intr2Bus_Error => intr_IP2Bus_Error, Intr2Bus Retry => open, Intr2Bus ToutSup => open ); - feed registered and level-pass-through interrupts into Device ISC if exists, otherwise ignored intr_IPIF_Reg_Interrupts(0) <= '0'; intr_IPIF_Reg_Interrupts(1) <= '0'; intr IPIF Lvl Interrupts(0) <= '0'; intr IPIF Lvl Interrupts(1) <= '0'; intr_IPIF_Lvl_Interrupts(2) <= '0'; intr IPIF Lvl Interrupts(3) <= '0'; -- instantiate User Logic USER_LOGIC_I : entity my_custom_ip_register_v9_00_a.user_logic generic map — MAP USER GENERICS BELOW THIS LINE — --- USER generics mapped here — MAP USER GENERICS ABOVE THIS LINE — C_SLV_DWIDTH => USER_SLV_DWIDTH, \Longrightarrow USER NUM_REG, C NUM REG C NUM INTR \Rightarrow USER NUM INTR ``` ``` port map — MAP USER PORTS BELOW THIS LINE —— ---USER ports mapped here — MAP USER PORTS ABOVE THIS LINE – Bus2IP Clk \Rightarrow ipif_Bus2IP_Clk, Bus 2 IP \_ Reset => ipif Bus2IP Reset, Bus2IP\_Data => ipif_Bus2IP_Data, Bus2IP BE => ipif Bus2IP BE, Bus2IP RdCE => user Bus2IP RdCE, Bus2IP\_WrCE => user_Bus2IP_WrCE, IP2Bus Data => user IP2Bus Data, IP2Bus\_RdAck => user_IP2Bus_RdAck, IP2Bus WrAck => user IP2Bus WrAck, IP2Bus Error => user IP2Bus Error, IP2Bus\_IntrEvent => user IP2Bus IntrEvent ); -- connect internal signals IP2BUS DATA MUX PROC: process (ipif Bus2IP CS, user IP2Bus Data, intr IP2Bus Data ) is begin case ipif Bus2IP CS is when "10" => ipif IP2Bus Data <= user IP2Bus Data; when "01" => ipif IP2Bus Data <= intr IP2Bus Data; when others => ipif IP2Bus Data <= (others => '0'); end case; end process IP2BUS DATA MUX PROC; ipif IP2Bus WrAck <= user IP2Bus WrAck or intr IP2Bus WrAck; ipif IP2Bus RdAck <= user IP2Bus RdAck or intr IP2Bus RdAck; ipif IP2Bus Error <= user IP2Bus Error or intr IP2Bus Error; user\_Bus2IP\_RdCE <= ipif\_Bus2IP\_RdCE (USER\_CE\_INDEX to USER\_CE\_INDEX) +USER NUM REG-1); user_Bus2IP_WrCE <= ipif_Bus2IP_WrCE (USER_CE_INDEX to USER_CE_INDEX +USER NUM REG-1); end IMP; ``` # .1.2 VHDL Test Benches #### Median ``` - Title : median tb : defect_pixel_corr – Design -- Author : Henrik Backe-Hansen : NTNU / Aptina Norway Company -- File : median mod tb.vhd : Tue Jan 26 23:24:31 2010 - Generated - From : interface description file — Ву : Itf2Vhdl ver. 1.20 -- Description : -This testbench the input will be entered one-by-by and compared with the data in a certain position in the data golden array -The display will show ERROR if the input value does not match the data golden value for that position. —A FAILURE message will appear if the median value is different from the median calculated for the data golden array (123) —a FAILURE message will be shown saying "simulation completed correctly without error" to indicate that the simulation has completed library IEEE; use IEEE.std_logic_1164.all; use work.size.all; entity median testbench is end entity; architecture struct of median testbench is ---Component declaration component median mod port ( --component declaration std_logic; clk in in std_logic; data in :in integer; enable in std logic; done : out std_logic; ``` ``` median : out integer ); end component; -Signal declaration : std logic := '0'; signal clk signal rst : std_logic := '0'; signal data_in : integer := 0 ; signal enable : std_logic := '0'; signal done : std_logic := ,0; signal median : integer := 0 ; type data_format is array (8 downto 0) of integer range 0 to bit depth; —input data array size setup signal data_golden:data_format:= (127, 105, 141, 127, 127, 127, 127, 113, 115); -Device under test (DUT) instansiation begin DUT: median mod port map( clk \Rightarrow clk, rst \Rightarrow rst, data_in \Rightarrow data_in, \Rightarrow enable, enable done \Rightarrow done, median => median ); -process to generate the clock for 100MHz clk_gen : process begin wait for 5 ns; clk \le not(clk); end process; -Stimuli test_bench : process variable test:integer:= 0; variable test2: integer:= 0; begin ``` ``` rst <= '1'; wait for 20 ns; rst \ll 0; wait for 20 ns; -latching in input values enable <= '1'; --data(0) <= 115 data in \leq 115; wait for 20 ns; enable \leq 0; wait for 20 ns; assert data_golden(0) = data_in report "data_golden(0) differs from input 0" severity error; --data(1) <= 123 enable \ll '1'; data in \leq 113; wait for 20 ns; enable \leq 0; wait for 20 ns; assert data_in = data_golden(1) report "data_golden(1) differs from input 1" severity error; --data(2) <= 105 enable <= '1'; data in \leq 127; wait for 20 ns; enable \ll '0'; wait for 20 ns; assert data_in = data_golden(2) report "data golden(2) differs from input 2" severity error; --data(3) <= 129 enable \ll '1'; data in \leq 127; wait for 20 ns; enable <= '0'; wait for 20\,\mathrm{ns}; assert data_in = data_golden(3) report "data_golden(3) differs from input 3" severity error; enable \ll '1'; --data(4) <= 249 ``` ``` data in \leq 127; wait for 20 ns; enable \ll '0'; wait for 20 ns; assert data_in = data_golden(4) report "data golden (4) differs from input 4" severity error; enable \ll '1'; --data(5) <= 135 data in \leq 127; wait for 20 ns; enable \ll '0'; wait for 20 ns; assert data_in = data_golden(5) report "data_golden(5) differs from input 5" severity error; --data(6) <= 102 enable \ll '1'; data in \leq 141; wait for 20 ns; enable \ll '0'; wait for 20 ns; assert data_in = data_golden(6) report "data_golden(6) differs from input 6" severity error; --data(7) <= 136 enable <= '1'; data in \leq 105; wait for 20 ns; enable \ll '0'; wait for 20 ns; assert data_in = data_golden(7) report "data golden (7) differs from input 7" severity error; --data(8) <= 117 enable \ll '1'; data in \leq 127; wait for 20 ns; enable <= '0'; wait for 20 ns; assert data_in = data_golden(8) report "data_golden(8) differs from input 8" severity error; -Comparing the output with the golden output ``` ``` wait on done; assert median = 127 report"wrong median value calculated" severity failure; wait for 50ns; assert true; report "simulation completed correctly without error" severity failure; wait; end process; end architecture; ``` # Image core ``` -- Title : image_core_tb — Design : defect pixel corr : Henrik Backe-Hansen - Author - Company : NTNU / Aptina Norway -- File : image_core_tb.vhd -- Generated : Mon Feb 22 17:01:01 2010 -- From : interface description file — Ву : Itf2Vhdl ver. 1.20 -Testbench to test the image_core.vhd file. The stimuli is fed to the image core file -value by value, row by row until all values are read. library IEEE; use IEEE.STD_LOGIC_1164.all; use work.size.all; use IEEE.numeric std.all; use std.textio.all; use IEEE.std_logic_unsigned.all; entity image core to is end image core tb; architecture arch of image_core_tb is type in array is array (0 to size x-1) of INTEGER; type out_array is array(0 to size_y)of INTEGER; component image_core port ( --component declaration clk std_logic; in mod en :in std_logic; std_logic; : in rst core in :in integer; std_logic; dі in :out std_logic; core_out :out integer end component; ``` ``` \begin{array}{lll} \textbf{signal} & \textbf{clk} & : \textbf{std\_logic} & := & \textbf{'0'}; \\ \textbf{signal} & \textbf{mod\_en} & : \textbf{std\_logic} & := & \textbf{'0'}; \\ \end{array} signal rst :std_logic := '0'; signal core_in : integer := 0 ; signal core_out :integer := 0 ; begin DUT: image_core —device under test signal mapping port map( \Rightarrow clk, clk mod_en \implies mod_en, rst \implies rst, core_in => core_in, di \implies di, \Rightarrow do, do core out \implies core out ); clk_gen:process begin wait for 5 ns; clk \ll not(clk); end process; read_values:process begin \mod en \leq '1'; wait for 20ns; \mod en \leq 0; wait for 20ns; for i in 0 to ((size_y*size_x)-1) loop di <= '1'; --setting the data in (di)flag core_in <= data_array(i); --inputing the values to</pre> integer in wait for 10ns; di \le 0; wait for 10ns; end loop; wait; end process; ``` ``` write_file:process :TEXT open WRITE_MODE IS "src\data_out_th_50.pgm"; FILE file_out variable line_out :LINE; variable output:out_array; variable i : integer := 0; begin wait for 10 ns; if (do = '1') then output(i):=core_out; write (\,line\_out\;,output\,(\,i\,)\,)\;; write(line_out, string'("")); i := i+1; if(i = size_y)then i := 0; writeline(file_out,line_out); else end if; end if; end process; end arch; ``` #### Ctrl ``` Title : ctrl_tb Design : defect_pixel_corr Author : Henrik Backe-Hansen Company : NTNU / Aptina Norway -- File : ctrl_tb.vhd -- Generated : Mon Mar 15 21:21:11 2010 -- From : interface description file -- By : Itf2Vhdl ver. 1.20 — Ву -- Description : Testbench for the ctrl module library IEEE; use IEEE.STD_LOGIC_1164.all; use IEEE.numeric_std.all; use std.textio.all; use work.size.all; entity ctrl tb is end ctrl_tb; architecture ctrl_tb_arch of ctrl_tb is type out_array is array(0 to size_y)of INTEGER; component ctrl port ( clk :in std logic; rst :in std_logic; data out: out integer ); end component; signal clk : std_logic := '0'; signal rst : std_logic := '0'; signal data_out : integer := 0; begin DUT: ctrl port map( ``` ``` clk \implies clk, rst \implies rst, data_out=> data_out ); clk_gen:process begin wait for 5 ns; clk \le not(clk); end process; write_to_file:process FILE file_out :TEXT open WRITE_MODE is "src\out_ctrl.pgm"; variable line_out :LINE; variable output:out_array; variable i: integer:=0; begin wait for 100 ns; if (data_out /= -2147483648) then output(i) := data_out; textio.write(line out,output(i)); textio.write(line_out, string; (""")); i := i +1; if(i = size_y)then i := 0; writeline(file_out, line_out); end if; end if; end process; end ctrl tb arch; ``` # .2 Microblaze files # .2.1 mss ``` PARAMETER VERSION = 2.2.0 BEGIN OS PARAMETER OS NAME = standalone PARAMETER OS VER = 3.00.a PARAMETER PROC_INSTANCE = microblaze 0 PARAMETER stdin = RS232 Uart PARAMETER stdout = RS232 Uart END BEGIN PROCESSOR PARAMETER DRIVER NAME = cpu PARAMETER DRIVER_VER = 1.12.b PARAMETER HW INSTANCE = microblaze 0 PARAMETER xmdstub peripheral = RS232 Uart END BEGIN DRIVER PARAMETER DRIVER NAME = bram PARAMETER DRIVER VER = 1.00 .a PARAMETER HW INSTANCE = dlmb cntlr END BEGIN DRIVER PARAMETER DRIVER NAME = bram PARAMETER DRIVER_VER = 1.00. a PARAMETER HW INSTANCE = ilmb cntlr END BEGIN DRIVER PARAMETER DRIVER_NAME = generic PARAMETER DRIVER VER = 1.00.a PARAMETER HW INSTANCE = lmb bram END BEGIN DRIVER PARAMETER DRIVER NAME = uartlite PARAMETER DRIVER VER = 1.14.a PARAMETER HW_INSTANCE = RS232_Uart END ``` ``` BEGIN DRIVER PARAMETER DRIVER NAME = sysace PARAMETER DRIVER_VER = 1.12.a PARAMETER HW INSTANCE = SysACE CompactFlash END BEGIN DRIVER PARAMETER DRIVER NAME = generic PARAMETER DRIVER VER = 1.00.a PARAMETER HW_INSTANCE = clock generator 0 END BEGIN DRIVER PARAMETER DRIVER NAME = uartlite PARAMETER DRIVER VER = 1.14.a PARAMETER HW_INSTANCE = mdm_0 END BEGIN DRIVER PARAMETER DRIVER NAME = generic PARAMETER DRIVER_VER = 1.00.a PARAMETER HW_INSTANCE = proc sys reset 0 END BEGIN DRIVER PARAMETER DRIVER NAME = intc PARAMETER DRIVER VER = 1.11.a PARAMETER HW_INSTANCE = xps_intc_0 END BEGIN DRIVER PARAMETER DRIVER NAME = generic PARAMETER DRIVER_VER = 1.00. a PARAMETER HW INSTANCE = mb plb END BEGIN DRIVER PARAMETER DRIVER_NAME = my_custom_ip_register PARAMETER DRIVER VER = 9.00.a PARAMETER HW_INSTANCE = my_custom_ip_register_0 END BEGIN LIBRARY PARAMETER LIBRARY_NAME = xilfatfs PARAMETER LIBRARY VER = 1.00.a PARAMETER PROC INSTANCE = microblaze 0 PARAMETER CONFIG WRITE = true ``` PARAMETER CONFIG\_DIR\_SUPPORT = true PARAMETER CONFIG\_FAT12 = true END # .2.2 mhs ``` # Created by Base System Builder Wizard for Xilinx EDK 11.5 Build EDK LS5.70 # Sat Apr 17 13:59:14 2010 # Target Board: Xilinx Virtex 5 ML501 Evaluation Platform Rev 1 # Family: virtex5 # Device: xc5vlx50 # Package: ff676 # Speed Grade: -1 # Processor number: 1 # Processor 1: microblaze 0 # System clock frequency: 125.0 # Debug Interface: On-Chip HW Debug Module PARAMETER VERSION = 2.1.0 PORT fpga 0 RS232 Uart RX pin = fpga 0 RS232 Uart RX pin, DIR = I PORT fpga 0 RS232 Uart TX pin = fpga 0 RS232 Uart TX pin, DIR = O PORT fpga 0 SysACE CompactFlash SysACE MPA pin = fpga 0 SysACE CompactFlash SysACE MPA pin, DIR = O, VEC = [6:0] PORT\ fpga\_0\_SysACE\_CompactFlash\_SysACE\_CLK\_pin = 0 fpga 0 SysACE CompactFlash SysACE CLK pin, DIR = I PORT fpga 0 SysACE CompactFlash SysACE MPIRQ pin = fpga 0 SysACE CompactFlash SysACE MPIRQ pin, DIR = I PORT fpga 0 SysACE CompactFlash SysACE CEN pin = fpga_0_SysACE_CompactFlash_SysACE_CEN_pin, DIR = O PORT fpga 0 SysACE CompactFlash SysACE OEN pin = fpga 0 SysACE CompactFlash SysACE OEN pin, DIR = O PORT fpga 0 SysACE CompactFlash SysACE WEN pin = fpga 0 SysACE CompactFlash SysACE WEN pin, DIR = O PORT fpga 0 SysACE CompactFlash SysACE MPD pin = fpga 0 SysACE CompactFlash SysACE MPD pin, DIR = IO, VEC = [15:0] PORT\ fpga\_0\_clk\_1\_sys\_clk\_pin\ =\ dcm\_clk\_s\,,\ DIR\ =\ I\;,\ SIGIS\ =\ CLK, CLK FREQ = 1000000000 PORT fpga 0 rst 1 sys rst pin = sys rst s, DIR = I, SIGIS = RST, RST POLARITY = 0 BEGIN xps_intc PARAMETER INSTANCE = xps_intc_0 PARAMETER HW VER = 2.01.a ``` ``` PARAMETER C BASEADDR = 0 \times 81800000 PARAMETER C HIGHADDR = 0 \times 8180 \text{ffff} BUS INTERFACE SPLB = mb_plb PORT Irq = microblaze 0 INTERRUPT PORT Intr = my custom ip register 0 IP2INTC Irpt BEGIN proc sys reset PARAMETER INSTANCE = proc sys reset 0 PARAMETER C EXT RESET HIGH = 0 PARAMETER HW VER = 2.00. a PORT Slowest_sync_clk = clk_125_0000MHz PORT Ext Reset In = sys rst s PORT MB_Debug_Sys_Rst = Debug_SYS_Rst PORT Dcm locked = Dcm all locked PORT MB Reset = mb reset PORT Bus Struct Reset = sys_bus_reset END BEGIN microblaze PARAMETER INSTANCE = microblaze 0 PARAMETER C_INTERCONNECT = 1 PARAMETER C USE FPU = 1 PARAMETER C DEBUG ENABLED = 1 PARAMETER HW VER = 7.30. a BUS INTERFACE DLMB = dlmb BUS INTERFACE ILMB = ilmb BUS INTERFACE DPLB = mb plb BUS INTERFACE IPLB = mb_plb BUS INTERFACE DEBUG = microblaze 0 mdm bus PORT MB_RESET = mb reset PORT INTERRUPT = microblaze 0 INTERRUPT END BEGIN mdm PARAMETER INSTANCE = mdm 0 PARAMETER C MB DBG PORTS = 1 PARAMETER C USE UART = 1 PARAMETER C_UART_WIDTH = 8 PARAMETER HW VER = 1.00. g PARAMETER C BASEADDR = 0 \times 84400000 PARAMETER C HIGHADDR = 0 \times 8440 \text{ffff} BUS INTERFACE SPLB = mb plb BUS INTERFACE MBDEBUG 0 = microblaze_0_mdm_bus PORT Debug SYS Rst = Debug SYS Rst END BEGIN plb v46 PARAMETER INSTANCE = mb_plb ``` ``` PARAMETER HW VER = 1.04.a PORT PLB Clk = clk 125 0000MHz PORT SYS_Rst = sys_bus_reset END BEGIN bram block PARAMETER INSTANCE = lmb bram PARAMETER HW VER = 1.00. a BUS INTERFACE PORTA = ilmb port BUS INTERFACE PORTB = dlmb port END BEGIN lmb bram if cntlr PARAMETER INSTANCE = ilmb_cntlr PARAMETER HW VER = 2.10.b PARAMETER C BASEADDR = 0 \times 000000000 PARAMETER C_HIGHADDR = 0 \times 0 \times 0 \times 1 ffff BUS INTERFACE SLMB = ilmb BUS INTERFACE BRAM_PORT = ilmb_port END BEGIN lmb_v10 PARAMETER INSTANCE = ilmb PARAMETER HW_VER = 1.00. a PORT LMB Clk = clk 125 0000MHz PORT SYS_Rst = sys_bus_reset END BEGIN lmb_bram_if_cntlr PARAMETER INSTANCE = dlmb cntlr PARAMETER HW VER = 2.10.b PARAMETER C BASEADDR = 0 \times 000000000 PARAMETER C HIGHADDR = 0 \times 0 \times 0 \times 1 ffff BUS INTERFACE SLMB = dlmb BUS INTERFACE BRAM PORT = dlmb port END BEGIN lmb v10 PARAMETER INSTANCE = dlmb PARAMETER HW VER = 1.00. a PORT\ LMB\_Clk\ =\ clk\_125\_0000MHz PORT SYS_Rst = sys_bus_reset END BEGIN clock_generator PARAMETER INSTANCE = clock_generator_0 PARAMETER C_EXT_RESET HIGH = 0 PARAMETER C CLKIN FREQ = 100000000 PARAMETER C CLKOUT0 FREQ = 125000000 ``` ``` PARAMETER C CLKOUT0 PHASE = 0 PARAMETER C CLKOUTO GROUP = NONE PARAMETER C CLKOUT0 BUF = TRUE PARAMETER HW_VER = 3.02.a PORT CLKIN = dcm_clk_s PORT CLKOUT0 = clk 125 0000MHz PORT RST = sys rst s PORT LOCKED = Dcm all locked END BEGIN xps sysace PARAMETER INSTANCE = SysACE CompactFlash PARAMETER C MEM WIDTH = 16 PARAMETER HW VER = 1.01.a PARAMETER C BASEADDR = 0x83600000 PARAMETER C HIGHADDR = 0 \times 8360 ffff BUS INTERFACE SPLB = mb plb PORT SysACE MPA = fpga 0 SysACE CompactFlash SysACE MPA pin PORT SysACE CLK = fpga 0 SysACE CompactFlash SysACE CLK pin PORT SysACE MPIRQ = fpga 0 SysACE CompactFlash SysACE MPIRQ pin PORT SysACE CEN = fpga 0 SysACE CompactFlash SysACE CEN pin PORT SysACE\_OEN = fpga\_0\_SysACE\_CompactFlash\_SysACE\_OEN\_pin PORT SysACE WEN = fpga 0 SysACE CompactFlash SysACE WEN pin PORT SysACE MPD = fpga 0 SysACE CompactFlash SysACE MPD pin END BEGIN xps uartlite PARAMETER INSTANCE = RS232 Uart PARAMETER C BAUDRATE = 9600 PARAMETER C DATA BITS = 8 PARAMETER C USE PARITY = 0 PARAMETER C ODD PARITY = 0 PARAMETER HW_VER = 1.01.a PARAMETER C BASEADDR = 0x84000000 PARAMETER C HIGHADDR = 0 \times 8400 ffff BUS INTERFACE SPLB = mb plb PORT RX = fpga 0 RS232 Uart RX pin PORT TX = fpga 0 RS232 Uart TX pin END BEGIN my_custom_ip_register PARAMETER INSTANCE = my custom ip register 0 PARAMETER HW_VER = 9.00. a PARAMETER C BASEADDR = 0 \times c \cdot c \cdot c \cdot 0 \cdot 0 \cdot 0 \cdot 0 PARAMETER C HIGHADDR = 0 \times c \cdot c \cdot c \cdot 0 ffff BUS INTERFACE SPLB = mb plb PORT IP2INTC_Irpt = my_custom_ip_register_0_IP2INTC_Irpt END ``` ## .2.3 ucf ``` Virtex 5 ML501 Evaluation Platform Net fpga_0_RS232_Uart_RX_pin LOC = AC7 | IOSTANDARD=LVCMOS33; Net fpga_0_RS232_Uart_TX_pin LOC = AD14 | IOSTANDARD=LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<0> LOC=N6 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<1> LOC=E5 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<2> LOC=F5 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<3> LOC=F4 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<4> LOC=J5 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<5> LOC=E7 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPA pin<6> LOC=G7 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE CLK pin LOC=AB12 IOSTANDARD = LVCMOS33 | PERIOD = 30000 ps; \label{eq:compactFlash} Net \ fpga\_0\_SysACE\_CompactFlash \ SysACE \ MPIRQ \ pin \ LOC\!\!=\!\!G6 IOSTANDARD = LVCMOS33 TIG: Net fpga 0 SysACE CompactFlash SysACE CEN pin LOC=F7 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE OEN pin LOC=E6 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE WEN pin LOC=M5 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<0> LOC=M6 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<1> LOC=K5 IOSTANDARD = LVCMOS33; Net \ fpga\_0\_SysACE\_CompactFlash \ SysACE \ MPD \ pin<2>\ LOC\!\!=\!\!L3 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<3> LOC=L4 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<4> LOC=L7 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<5> LOC=L5 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<6> LOC=H6 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<7> LOC=G5 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<8> LOC=M7 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<9> LOC=H7 IOSTANDARD = LVCMOS33; ``` ``` Net \ fpga \ 0 \ SysACE\_CompactFlash\_SysACE\_MPD\_pin < 10 > \ LOC = J6 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<11> LOC=G4 IOSTANDARD = LVCMOS33; Net \ fpga \ 0 \ SysACE \ CompactFlash \_ SysACE \_ MPD \_ pin < 12 > \ LOC \!\!=\!\! K7 IOSTANDARD = LVCMOS33; Net \ fpga \ 0 \ SysACE \ CompactFlash \_ SysACE \_ MPD \_ pin < 13 > \ LOC \!\!=\! \! J4 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<14> LOC=H4 IOSTANDARD = LVCMOS33; Net fpga 0 SysACE CompactFlash SysACE MPD pin<15> LOC=K6 IOSTANDARD = LVCMOS33; Net fpga 0 clk 1 sys clk pin TNM NET = sys clk pin; TIMESPEC TS_sys_clk_pin = PERIOD sys_clk_pin 100000 kHz; Net fpga_0_clk_1_sys_clk_pin LOC = AD8 | IOSTANDARD=LVCMOS33; Net fpga_0_rst_1_sys_rst_pin TIG; Net fpga_0_rst_1_sys_rst_pin LOC = T23 IOSTANDARD=LVCMOS33 PULLUP; ``` ## .2.4 xparameters.h ``` * CAUTION: This file is automatically generated by libgen. * Version: Xilinx EDK 12.1 EDK MS1.53d * DO NOT EDIT. * Copyright (c) 1995-2010 Xilinx, Inc. All rights reserved. * Description: Driver parameters *********************** #define STDIN_BASEADDRESS 0x84000000 #define STDOUT BASEADDRESS 0x84000000 /* Definitions for driver UARTLITE */ #define XPAR XUARTLITE NUM INSTANCES 2 /* Definitions for peripheral MDM 0 */ #define XPAR MDM 0 BASEADDR 0x84400000 #define XPAR MDM 0 HIGHADDR 0x8440FFFF #define XPAR MDM 0 DEVICE ID 0 #define XPAR MDM 0 BAUDRATE 0 #define XPAR MDM 0 USE PARITY 0 #define XPAR MDM 0 ODD PARITY 0 #define XPAR MDM 0 DATA BITS 0 /* Definitions for peripheral RS232 UART */ #define XPAR RS232 UART BASEADDR 0x84000000 #define XPAR RS232 UART HIGHADDR 0x8400FFFF #define XPAR RS232 UART DEVICE ID 1 #define XPAR RS232 UART BAUDRATE 9600 #define XPAR RS232 UART USE PARITY 0 #define XPAR RS232 UART ODD PARITY 0 #define XPAR RS232 UART DATA BITS 8 /* Canonical definitions for peripheral MDM 0 */ #define XPAR UARTLITE 0 DEVICE ID XPAR MDM 0 DEVICE ID ``` ``` #define XPAR UARTLITE 0 BASEADDR 0x84400000 #define XPAR UARTLITE 0 HIGHADDR 0x8440FFFF #define XPAR UARTLITE 0 BAUDRATE 0 #define XPAR UARTLITE 0 USE PARITY 0 #define XPAR UARTLITE 0 ODD PARITY 0 #define XPAR UARTLITE 0 DATA BITS 0 #define XPAR UARTLITE 0 SIO CHAN -1 /* Canonical definitions for peripheral RS232 UART */ #define XPAR UARTLITE 1 DEVICE ID XPAR RS232 UART DEVICE ID #define XPAR UARTLITE 1 BASEADDR 0x84000000 #define XPAR UARTLITE 1 HIGHADDR 0x8400FFFF #define XPAR UARTLITE 1 BAUDRATE 9600 #define XPAR UARTLITE 1 USE PARITY 0 #define XPAR UARTLITE 1 ODD PARITY 0 #define XPAR UARTLITE 1 DATA BITS 8 #define XPAR UARTLITE 1 SIO CHAN -1 #define XPAR XSYSACE MEM WIDTH 16 /* Definitions for driver SYSACE */ #define XPAR XSYSACE NUM INSTANCES 1 /* Definitions for peripheral SYSACE COMPACTFLASH */ #define XPAR SYSACE COMPACTFLASH DEVICE ID 0 #define XPAR SYSACE COMPACTFLASH BASEADDR 0x83600000 #define XPAR SYSACE COMPACTFLASH HIGHADDR 0x8360FFFF #define XPAR SYSACE COMPACTFLASH MEM WIDTH 16 /* Canonical definitions for peripheral SYSACE COMPACTFLASH */ #define XPAR SYSACE 0 DEVICE ID XPAR SYSACE COMPACTFLASH DEVICE ID #define XPAR SYSACE 0 BASEADDR 0x83600000 #define XPAR SYSACE 0 HIGHADDR 0x8360FFFF #define XPAR SYSACE 0 MEM WIDTH 16 /* Definitions for peripheral DLMB CNTLR */ #define XPAR DLMB CNTLR BASEADDR 0x00000000 #define XPAR DLMB CNTLR HIGHADDR 0x0001FFFF ``` ``` /* Definitions for peripheral ILMB CNTLR */ #define XPAR ILMB CNTLR BASEADDR 0x00000000 #define XPAR_ILMB_CNTLR HIGHADDR 0x0001FFFF /* Definitions for driver MY CUSTOM IP REGISTER */ #define XPAR MY CUSTOM IP REGISTER NUM INSTANCES 1 /* Definitions for peripheral MY CUSTOM IP REGISTER 0 */ #define XPAR MY CUSTOM IP REGISTER 0 DEVICE ID 0 #define XPAR MY CUSTOM IP REGISTER 0 BASEADDR 0xCCC00000 #define XPAR_MY_CUSTOM IP REGISTER 0 HIGHADDR 0xCCC0FFFF #define XPAR INTC MAX NUM INTR INPUTS 1 #define XPAR_XINTC_HAS_IPR 1 #define XPAR XINTC USE DCR 0 /* Definitions for driver INTC */ #define XPAR XINTC NUM INSTANCES 1 /* Definitions for peripheral XPS INTC 0 */ #define XPAR XPS INTC_0_DEVICE_ID 0 #define XPAR_XPS_INTC_0_BASEADDR 0x81800000 #define XPAR XPS INTC 0 HIGHADDR 0x8180FFFF #define XPAR XPS INTC 0 KIND OF INTR 0xFFFFFFFE #define XPAR INTC SINGLE BASEADDR 0x81800000 #define XPAR INTC SINGLE HIGHADDR 0x8180FFFF #define XPAR INTC SINGLE DEVICE ID XPAR XPS INTC 0 DEVICE ID #define XPAR_MY_CUSTOM_IP_REGISTER_0_IP2INTC_IRPT_MASK 0X000001 #define XPAR XPS INTC 0 MY CUSTOM IP REGISTER_0_IP2INTC_IRPT_INTR 0 /st Canonical definitions for peripheral XPS INTC 0 st/ #define XPAR INTC 0 DEVICE ID XPAR XPS INTC 0 DEVICE ID #define XPAR_INTC_0_BASEADDR 0x81800000 #define XPAR INTC 0 HIGHADDR 0x8180FFFF #define XPAR INTC 0 KIND OF INTR 0xFFFFFFFE ``` ``` #define XPAR_INTC_0 MY CUSTOM IP REGISTER 0 VEC ID XPAR_XPS_INTC_0_MY_CUSTOM_IP_REGISTER 0 IP2INTC IRPT INTR /* Definitions for bus frequencies */ #define XPAR CPU DPLB FREQ HZ 125000000 #define XPAR CPU IPLB FREQ HZ 125000000 /* Canonical definitions for bus frequencies */ #define XPAR_PROC_BUS_0_FREQ_HZ 125000000 #define XPAR CPU CORE CLOCK FREQ HZ 125000000 #define XPAR MICROBLAZE CORE CLOCK FREQ HZ 125000000 /* Definitions for peripheral MICROBLAZE 0 */ #define XPAR MICROBLAZE 0 SCO 0 #define XPAR MICROBLAZE 0 FREQ 125000000 #define XPAR MICROBLAZE 0 DATA SIZE 32 #define XPAR MICROBLAZE 0 DYNAMIC BUS SIZING 1 #define XPAR MICROBLAZE 0 AREA OPTIMIZED 0 #define XPAR MICROBLAZE 0 OPTIMIZATION 0 #define XPAR MICROBLAZE 0 INTERCONNECT 1 #define XPAR MICROBLAZE 0 DPLB DWIDTH 32 #define XPAR MICROBLAZE 0 DPLB NATIVE DWIDTH 32 #define XPAR MICROBLAZE 0 DPLB BURST EN 0 #define XPAR MICROBLAZE 0 DPLB P2P 0 #define XPAR MICROBLAZE 0 IPLB DWIDTH 32 #define XPAR MICROBLAZE 0 IPLB NATIVE DWIDTH 32 #define XPAR MICROBLAZE 0 IPLB BURST EN 0 #define XPAR MICROBLAZE 0 IPLB P2P 0 #define XPAR MICROBLAZE 0 D PLB 1 #define XPAR MICROBLAZE 0 D LMB 1 #define XPAR MICROBLAZE 0 I PLB 1 #define XPAR MICROBLAZE 0 I LMB 1 #define XPAR MICROBLAZE 0 USE MSR INSTR 1 #define XPAR MICROBLAZE 0 USE PCMP INSTR 1 #define XPAR MICROBLAZE 0 USE BARREL 0 #define XPAR MICROBLAZE 0 USE DIV 0 #define XPAR MICROBLAZE 0 USE HW MUL 1 #define XPAR MICROBLAZE 0 USE FPU 1 #define XPAR MICROBLAZE 0 UNALIGNED EXCEPTIONS 0 #define XPAR MICROBLAZE 0 ILL OPCODE EXCEPTION 0 #define XPAR MICROBLAZE 0 IPLB BUS EXCEPTION 0 ``` ``` #define XPAR MICROBLAZE 0 DPLB BUS EXCEPTION 0 #define XPAR MICROBLAZE 0 DIV ZERO EXCEPTION 0 #define XPAR MICROBLAZE 0 FPU EXCEPTION 0 #define XPAR MICROBLAZE 0 FSL EXCEPTION 0 #define XPAR MICROBLAZE 0 PVR 0 #define XPAR MICROBLAZE 0 PVR USER1 0x00 #define XPAR MICROBLAZE 0 PVR USER2 0x00000000 #define XPAR_MICROBLAZE_0_DEBUG ENABLED 1 #define XPAR MICROBLAZE 0 NUMBER OF PC BRK 1 #define XPAR MICROBLAZE 0 NUMBER OF RD ADDR BRK 0 #define XPAR MICROBLAZE 0 NUMBER OF WR ADDR BRK 0 #define XPAR MICROBLAZE 0 INTERRUPT IS EDGE 0 #define XPAR MICROBLAZE 0 EDGE IS POSITIVE 1 #define XPAR_MICROBLAZE_0_RESET_MSR 0x00000000 #define XPAR MICROBLAZE 0 OPCODE 0X0 ILLEGAL 0 #define XPAR MICROBLAZE 0 FSL LINKS 0 #define XPAR MICROBLAZE 0 FSL DATA SIZE 32 #define XPAR MICROBLAZE 0 USE EXTENDED FSL INSTR 0 #define XPAR MICROBLAZE 0 ICACHE BASEADDR 0x00000000 #define XPAR MICROBLAZE 0 ICACHE HIGHADDR 0x3FFFFFFF #define XPAR MICROBLAZE 0 USE ICACHE 0 #define XPAR MICROBLAZE 0 ALLOW ICACHE WR 1 #define XPAR MICROBLAZE 0 ADDR TAG BITS 0 #define XPAR MICROBLAZE 0 CACHE BYTE SIZE 8192 #define XPAR_MICROBLAZE_0_ICACHE USE FSL 1 #define XPAR MICROBLAZE 0 ICACHE LINE LEN 4 #define XPAR MICROBLAZE 0 ICACHE ALWAYS USED 0 #define XPAR MICROBLAZE 0 ICACHE INTERFACE 0 #define XPAR_MICROBLAZE_0_ICACHE_VICTIMS 0 #define XPAR MICROBLAZE 0 ICACHE STREAMS 0 #define XPAR MICROBLAZE 0 DCACHE BASEADDR 0x00000000 #define XPAR MICROBLAZE 0 DCACHE HIGHADDR 0x3FFFFFFF #define XPAR MICROBLAZE 0 USE DCACHE 0 #define XPAR_MICROBLAZE_0_ALLOW_DCACHE_WR 1 #define XPAR MICROBLAZE 0 DCACHE ADDR TAG 0 #define XPAR MICROBLAZE 0 DCACHE BYTE SIZE 8192 #define XPAR MICROBLAZE 0 DCACHE USE FSL 1 #define XPAR MICROBLAZE 0 DCACHE LINE LEN 4 #define XPAR_MICROBLAZE_0_DCACHE_ALWAYS_USED 0 #define XPAR MICROBLAZE 0 DCACHE INTERFACE 0 #define XPAR MICROBLAZE 0 DCACHE USE WRITEBACK 0 #define XPAR MICROBLAZE 0 DCACHE VICTIMS 0 #define XPAR MICROBLAZE 0 USE MMU 0 #define XPAR MICROBLAZE 0 MMU DTLB SIZE 4 #define XPAR MICROBLAZE 0 MMU ITLB SIZE 2 #define XPAR_MICROBLAZE_0_MMU_TLB_ACCESS 3 #define XPAR MICROBLAZE 0 MMU ZONES 16 #define XPAR MICROBLAZE 0 USE INTERRUPT 1 #define XPAR MICROBLAZE 0 USE EXT BRK 1 ``` ``` #define XPAR MICROBLAZE 0 USE EXT NM BRK 1 #define XPAR MICROBLAZE 0 USE BRANCH TARGET CACHE 0 #define XPAR MICROBLAZE 0 BRANCH TARGET CACHE SIZE 0 #define XPAR CPU ID 0 #define XPAR MICROBLAZE ID 0 #define XPAR MICROBLAZE SCO 0 #define XPAR MICROBLAZE FREQ 125000000 #define XPAR MICROBLAZE DATA SIZE 32 #define XPAR MICROBLAZE DYNAMIC BUS SIZING 1 #define XPAR MICROBLAZE AREA OPTIMIZED 0 #define XPAR MICROBLAZE OPTIMIZATION 0 #define XPAR_MICROBLAZE INTERCONNECT 1 #define XPAR MICROBLAZE DPLB DWIDTH 32 #define XPAR MICROBLAZE DPLB NATIVE DWIDTH 32 #define XPAR MICROBLAZE DPLB BURST EN 0 #define XPAR MICROBLAZE DPLB P2P 0 #define XPAR MICROBLAZE IPLB DWIDTH 32 #define XPAR MICROBLAZE IPLB NATIVE DWIDTH 32 #define XPAR MICROBLAZE IPLB BURST EN 0 #define XPAR MICROBLAZE IPLB P2P 0 #define XPAR MICROBLAZE D PLB 1 #define XPAR MICROBLAZE D LMB 1 #define XPAR MICROBLAZE I PLB 1 #define XPAR MICROBLAZE I LMB 1 #define XPAR MICROBLAZE USE MSR INSTR 1 #define XPAR MICROBLAZE USE PCMP INSTR 1 #define XPAR MICROBLAZE USE BARREL 0 #define XPAR MICROBLAZE USE DIV 0 #define XPAR MICROBLAZE USE HW MUL 1 #define XPAR MICROBLAZE USE FPU 1 #define XPAR MICROBLAZE UNALIGNED EXCEPTIONS 0 #define XPAR MICROBLAZE ILL OPCODE EXCEPTION 0 #define XPAR MICROBLAZE IPLB BUS EXCEPTION 0 #define XPAR MICROBLAZE DPLB BUS EXCEPTION 0 #define XPAR MICROBLAZE DIV ZERO EXCEPTION 0 #define XPAR MICROBLAZE FPU EXCEPTION 0 #define XPAR MICROBLAZE FSL EXCEPTION 0 #define XPAR MICROBLAZE PVR 0 #define XPAR MICROBLAZE PVR USER1 0x00 #define XPAR MICROBLAZE PVR USER2 0x00000000 #define XPAR MICROBLAZE DEBUG ENABLED 1 #define XPAR MICROBLAZE NUMBER OF PC BRK 1 #define XPAR MICROBLAZE NUMBER OF RD ADDR BRK 0 #define XPAR MICROBLAZE NUMBER OF WR ADDR BRK 0 #define XPAR MICROBLAZE INTERRUPT IS EDGE 0 #define XPAR MICROBLAZE EDGE IS POSITIVE 1 ``` ``` #define XPAR MICROBLAZE RESET MSR 0x00000000 #define XPAR MICROBLAZE OPCODE 0X0 ILLEGAL 0 #define XPAR MICROBLAZE FSL LINKS 0 #define XPAR MICROBLAZE FSL DATA SIZE 32 #define XPAR MICROBLAZE USE EXTENDED FSL INSTR 0 #define XPAR MICROBLAZE ICACHE BASEADDR 0x00000000 #define XPAR MICROBLAZE ICACHE HIGHADDR 0x3FFFFFFF #define XPAR MICROBLAZE USE ICACHE 0 #define XPAR MICROBLAZE ALLOW ICACHE WR 1 #define XPAR_MICROBLAZE_ADDR_TAG_BITS 0 #define XPAR MICROBLAZE CACHE BYTE SIZE 8192 #define XPAR MICROBLAZE ICACHE USE FSL 1 #define XPAR MICROBLAZE ICACHE LINE LEN 4 #define XPAR MICROBLAZE ICACHE ALWAYS USED 0 #define XPAR MICROBLAZE ICACHE INTERFACE 0 #define XPAR MICROBLAZE ICACHE VICTIMS 0 #define XPAR MICROBLAZE ICACHE STREAMS 0 #define XPAR MICROBLAZE DCACHE BASEADDR 0x00000000 #define XPAR MICROBLAZE DCACHE HIGHADDR 0x3FFFFFFF #define XPAR MICROBLAZE USE DCACHE 0 #define XPAR MICROBLAZE ALLOW DCACHE WR 1 #define XPAR MICROBLAZE DCACHE ADDR TAG 0 #define XPAR MICROBLAZE DCACHE BYTE SIZE 8192 #define XPAR MICROBLAZE DCACHE USE FSL 1 #define XPAR MICROBLAZE DCACHE LINE LEN 4 #define XPAR MICROBLAZE DCACHE ALWAYS USED 0 #define XPAR MICROBLAZE DCACHE INTERFACE 0 #define XPAR MICROBLAZE DCACHE USE WRITEBACK 0 #define XPAR MICROBLAZE DCACHE VICTIMS 0 #define XPAR MICROBLAZE USE MMU 0 #define XPAR MICROBLAZE MMU DTLB SIZE 4 #define XPAR MICROBLAZE MMU ITLB SIZE 2 #define XPAR MICROBLAZE MMU TLB ACCESS 3 #define XPAR MICROBLAZE_MMU_ZONES 16 #define XPAR MICROBLAZE USE INTERRUPT 1 #define XPAR MICROBLAZE USE EXT BRK 1 #define XPAR MICROBLAZE USE EXT NM BRK 1 #define XPAR MICROBLAZE USE BRANCH TARGET CACHE 0 #define XPAR_MICROBLAZE_BRANCH_TARGET_CACHE_SIZE 0 #define XPAR MICROBLAZE HW VER "7.30.a" #define XILFATFS MAXFILES 5 #define XILFATFS BUFCACHE SIZE 10240 ``` ## .3 Microblaze Synthesize ``` Release 12.1 - xst M.53d (nt) Copyright (c) 1995-2010 Xilinx, Inc. All rights reserved. TABLE OF CONTENTS 1) Synthesis Options Summary 2) HDL Compilation 3) Design Hierarchy Analysis 4) HDL Analysis 5) HDL Synthesis 5.1) HDL Synthesis Report 6) Advanced HDL Synthesis 6.1) Advanced HDL Synthesis Report 7) Low Level Synthesis 8) Partition Report 9) Final Report 9.1) Device utilization summary 9.2) Partition Resource Summary 9.3) TIMING REPORT Synthesis Options Summary —— Source Parameters Input Format : MIXED Input File Name : "system xst.prj" Verilog Include Directory : {"C:\Users\Magician\Desktop\ bsb project\pcores\" "C:\Xilinx\12.1\ISE DS\EDK\hw\ XilinxProcessorIPLib\pcores\" } --- Target Parameters : xc5v1x50ff676-1 Target Device : "../implementation/system.ngc" Output File Name ——— Source Options Top Module Name : system —— Target Options Add IO Buffers : YES Global Maximum Fanout : 10000 — General Options Optimization Goal : speed Netlist Hierarchy : as_optimized ``` ``` Optimization Effort : 1 Hierarchy Separator — Other Options Cores Search Directories : {../implementation} WARNING: Utilities C - The message filter file "../ xps/ise/filter. filter" specified with the -filter switch can't be found. WARNING: Utilities C - The message filter file "../_xps/ise/filter. filter" specified with the -filter switch can't be found. HDL Compilation Compiling vhdl file "C:/Users/Magician/Desktop/bsb_project/hdl/system .vhd" in Library work. Entity <system> compiled. Entity <system> (Architecture <STRUCTURE>) compiled. Design Hierarchy Analysis Analyzing hierarchy for entity < system> in library < work> ( architecture <STRUCTURE>). HDL Analysis Analyzing Entity < system > in library < work > (Architecture < STRUCTURE >). Set property "BUFFER TYPE = BUFGP" for signal < fpga 0 SysACE CompactFlash SysACE CLK pin> in unit <system>. WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 1191: Unconnected output port 'RstcPPCresetcore 0' of component 'proc sys reset 0 wrapper'. ``` - WARNING: Xst:753 "C:/ Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1191: Unconnected output port 'RstcPPCresetchip\_0' of component 'proc\_sys\_reset\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1191: Unconnected output port 'RstcPPCresetsys\_0' of component 'proc sys reset 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1191: Unconnected output port 'RstcPPCresetcore\_1' of component 'proc sys reset 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1191: Unconnected output port 'RstcPPCresetchip\_1' of component 'proc sys reset 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1191: Unconnected output port 'RstcPPCresetsys\_1' of component 'proc sys reset 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1191: Unconnected output port 'Peripheral\_Reset' of component 'proc\_sys\_reset\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'MB\_Halted' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Instruction' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Valid\_Instr' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_PC' of component' microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Reg\_Write' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Reg\_Addr' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_MSR\_Reg' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_PID\_Reg' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_New\_Reg\_Value' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Exception\_Taken' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Exception\_Kind' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Jump\_Taken' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Delay\_Slot' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Data\_Address' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Data\_Access' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Data\_Read' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Data\_Write' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Data\_Write\_Value' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Data\_Byte\_Enable' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_DCache\_Req' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_DCache\_Hit' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_DCache\_Rdy' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_DCache\_Read' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_ICache\_Req' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_ICache\_Hit' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_ICache\_Rdy' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_OF\_PipeRun' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_EX\_PipeRun' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_MEM\_PipeRun' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_MB\_Halted' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'Trace\_Jump\_Hit' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL0\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL0\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSLO\_M\_CLK' of component 'microblaze\_O\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL0\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSLO\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSLO\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL1\_S\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL1\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL1\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL1\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL1\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL1\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL2\_S\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL2\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL2\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL2\_M\_WRITE' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL2\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL2\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL3\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL3\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL3\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL3\_M\_WRITE' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL3\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL3\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL4\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL4\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL4\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL4\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL4\_M\_DATA' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL4\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL5\_S\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL5\_S\_READ' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL5\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL5\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL5\_M\_DATA' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL5\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL6\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL6\_S\_READ' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL6\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL6\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL6\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL6\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL7\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL7\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL7\_M\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL7\_M\_WRITE' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL7\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL7\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL8\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL8\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL8\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL8\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL8\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL8\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL9\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL9\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL9\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL9\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL9\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL9\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL10\_S\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL10\_S\_READ' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL10\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL10\_M\_WRITE' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL10\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL10\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL11\_S\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL11\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL11\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL11\_M\_WRITE' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL11\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL11\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL12\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL12\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL12\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/ Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL12\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL12\_M\_DATA' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL12\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL13\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL13\_S\_READ' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL13\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL13\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL13\_M\_DATA' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL13\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL14\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL14\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL14\_M\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL14\_M\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL14\_M\_DATA' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL14\_M\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL15\_S\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/ Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL15\_S\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL15\_M\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL15\_M\_WRITE' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL15\_M\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'FSL15\_M\_CONTROL' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'ICACHE\_FSL\_IN\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'ICACHE\_FSL\_IN\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'ICACHE\_FSL\_OUT\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'ICACHE\_FSL\_OUT\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'ICACHE\_FSL\_OUT\_DATA' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'ICACHE\_FSL\_OUT\_CONTROL' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/ Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'DCACHE\_FSL\_IN\_CLK' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'DCACHE\_FSL\_IN\_READ' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'DCACHE\_FSL\_OUT\_CLK' of component 'microblaze 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'DCACHE\_FSL\_OUT\_WRITE' of component 'microblaze\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1215: Unconnected output port 'DCACHE\_FSL\_OUT\_DATA' of component 'microblaze\_0\_wrapper'. ``` WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 1215: Unconnected output port 'DCACHE_FSL_OUT_CONTROL' of component 'microblaze 0 wrapper'. ``` - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Interrupt' of component mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'MDM\_DBus' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'MDM\_errAck' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'MDM\_retry' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'MDM\_toutSup' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'MDM\_xferAck' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_1' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_1' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Reg\_En\_1' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_1' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Shift\_1' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_1' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_1' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_2' of component mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_2' of component 'mdm\_0\_wrapper'. ``` WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg_Reg_En_2' of component 'mdm 0 wrapper'. ``` - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_2' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Shift\_2' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_2' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_2' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_3' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_3' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Reg\_En\_3' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_3' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Shift\_3' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_3' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_3' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_4' of component mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_4' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Reg\_En\_4' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_4' of component 'mdm\_0\_wrapper'. ``` WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg_Shift_4' of component 'mdm 0 wrapper'. ``` - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_4' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_4' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_5' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_5' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Reg\_En\_5' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_5' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Shift\_5' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_5' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_5' of component mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_6' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_6' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Reg\_En\_6' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_6' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Shift\_6' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_6' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_6' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Clk\_7' of component mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_TDI\_7' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Reg\_En\_7' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Capture\_7' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Shift\_7' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Update\_7' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Dbg\_Rst\_7' of component mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_tdi' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_reset' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_shift' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_update' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_capture' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_sell' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'bscan\_drck1' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'FSL0\_S\_CLK' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'FSL0\_S\_READ' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'FSL0\_M\_CLK' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'FSL0\_M\_WRITE' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'FSLO\_M\_DATA' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'FSLO\_M\_CONTROL' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_DRCK' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_RESET' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_SEL' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_CAPTURE' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_SHIFT' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_UPDATE' of component 'mdm 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1520: Unconnected output port 'Ext\_JTAG\_TDI' of component 'mdm\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_Rst' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'MPLB\_Rst' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_dcrAck' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_dcrDBus' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SaddrAck' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SMRdErr' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SMWrErr' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SMBusy' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SrdBTerm' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SrdComp' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SrdDAck' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SrdDBus' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SrdWdAddr' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_Srearbitrate' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_Sssize' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_Swait' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SwrBTerm' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SwrComp' of component 'mb plb wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'PLB\_SwrDAck' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1673: Unconnected output port 'Bus\_Error\_Det' of component 'mb\_plb\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT1' of component' clock generator 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT2' of component' clock generator 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT3' of component 'clock generator 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT4' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT5' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT6' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system.vhd" line 1880: Unconnected output port 'CLKOUT7' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT8' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT9' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT10' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT11' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT12' of component 'clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT13' of component 'clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT14' of component' clock generator 0 wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKOUT15' of component' clock\_generator\_0\_wrapper'. - WARNING: Xst:753 "C:/Users/Magician/Desktop/bsb\_project/hdl/system. vhd" line 1880: Unconnected output port 'CLKFBOUT' of component' clock\_generator\_0\_wrapper'. ``` WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb project/hdl/system. vhd" line 1880: Unconnected output port 'PSDONE' of component ' clock generator 0 wrapper'. WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 1909: Unconnected output port 'SysACE IRQ' of component 'sysace compactflash wrapper'. WARNING: Xst:753 - "C:/Users/Magician/Desktop/bsb project/hdl/system. vhd" line 1965: Unconnected output port 'Interrupt' of component ' rs232 uart wrapper' vhd" line 2061: Instantiating black box module <IOBUF>. WARNING: Xst:2211 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 2069: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb_project / hdl / system. vhd" line 2077: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb project / hdl / system. vhd" line 2085: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb_project / hdl / system. vhd" line 2093: Instantiating black box module <IOBUF>. WARNING: Xst:2211 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 2101: Instantiating black box module <IOBUF>. vhd" line 2109: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb project / hdl / system. vhd" line 2117: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb_project / hdl / system. vhd" line 2125: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb_project / hdl / system. vhd" line 2133: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb project / hdl / system. vhd" line 2141: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb project / hdl / system. vhd" line 2149: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb project / hdl / system. vhd" line 2157: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb project / hdl / system. vhd" line 2165: Instantiating black box module <IOBUF>. WARNING: Xst:2211 - "C:/Users/Magician/Desktop/bsb_project/hdl/system. vhd" line 2173: Instantiating black box module <IOBUF>. WARNING: Xst: 2211 - "C: / Users / Magician / Desktop / bsb_project / hdl / system. vhd" line 2181: Instantiating black box module <IOBUF>. Entity <system> analyzed. Unit <system> generated. ``` HDL Synthesis \* ``` Performing bidirectional port resolution ... Synthesizing Unit <system>. Related source file is "C:/Users/Magician/Desktop/bsb project/hdl /system.vhd". Unit <system> synthesized. HDL Synthesis Report Found no macro Advanced HDL Synthesis Reading core <.../implementation/xps intc 0 wrapper.ngc>. Reading core <../implementation/proc_sys_reset_0_wrapper.ngc>. Reading core <../implementation/microblaze_0_wrapper.ngc>. Reading core <.../implementation/mdm 0 wrapper.ngc>. Reading core <../implementation/mb plb wrapper.ngc>. Reading core <.../implementation/lmb bram wrapper.ngc>. Reading core <.../implementation/ilmb cntlr wrapper.ngc>. Reading core <../implementation/ilmb_wrapper.ngc>. Reading core <../implementation/dlmb cntlr wrapper.ngc>. Reading core <../implementation/dlmb wrapper.ngc>. Reading core <../implementation/clock generator 0 wrapper.ngc>. Reading core <.../implementation/sysace compactflash wrapper.ngc>. Reading core <.../implementation/rs232_uart_wrapper.ngc>. Reading core <.../implementation/my custom ip register 0 wrapper.ngc>. Loading core <xps into 0 wrapper> for timing and area information for instance \langle xps | intc | 0 \rangle. Loading core core_sys_reset_0_wrapper> for timing and area information for instance <proc sys reset 0>. Loading core <microblaze 0 wrapper> for timing and area information for instance <microblaze 0>. Loading core <mdm 0 wrapper> for timing and area information for ``` instance < mdm 0>. Loading core <mb\_plb\_wrapper> for timing and area information for instance <mb\_plb>. Loading core <lmb\_bram\_wrapper> for timing and area information for instance <|mb\_bram>. Loading core <ilmb\_cntlr\_wrapper> for timing and area information for instance <ilmb\_cntlr>. Loading core <ilmb\_wrapper> for timing and area information for instance <ilmb>. Loading core <dlmb\_cntlr\_wrapper> for timing and area information for instance <dlmb\_cntlr>. Loading core <dlmb\_wrapper> for timing and area information for instance <dlmb>. Loading core <clock\_generator\_0\_wrapper> for timing and area information for instance <clock\_generator\_0>. Loading core <sysace\_compactflash\_wrapper> for timing and area information for instance <SysACE CompactFlash>. Loading core <my\_custom\_ip\_register\_0\_wrapper> for timing and area information for instance <my\_custom\_ip\_register\_0>. Advanced HDL Synthesis Report Found no macro Low Level Synthesis \* Optimizing unit <system> ... Mapping all equations... Building and optimizing final netlist ... INFO: Xst:2260 - The FF/Latch <mb\_plb/GEN\_SHARED.I\_PLB\_ARBITER\_LOGIC/I\_ARBCONTROL\_SM/arbSecRdInProgReg\_i> in Unit <mb\_plb> is equivalent to the following 2 FFs/Latches : <mb plb/GEN\_SHARED. ``` I PLB ARBITER LOGIC/I ARBCONTROL SM/arbSecRdInProgReg i 1> <mb plb /GEN SHARED.I PLB ARBITER LOGIC/I ARBCONTROL SM/ arbSecRdInProgReg i 2> INFO: Xst:2260 - The FF/Latch < mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I_ARB_ENCODER/arbAddrSelReg_i_1> in Unit <mb_plb> is equivalent to the following FF/Latch : <mb plb/GEN SHARED.I PLB ARBITER LOGIC/ I ARB ENCODER/arbAddrSelReg i 1 1> INFO: Xst:2260 - The FF/Latch < mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I_ARB_ENCODER/arbAddrSelReg_i_0> in Unit <mb_plb> is equivalent to the following FF/Latch: <mb plb/GEN SHARED.I PLB ARBITER LOGIC/ I ARB ENCODER/arbAddrSelReg i 0 1> INFO: Xst:2260 - The FF/Latch < mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I_ARBCONTROL_SM/arbctrl_sm_cs_FSM_FFd3> in Unit <mb_plb> is equivalent to the following FF/Latch : <mb_plb/GEN_SHARED. I PLB ARBITER LOGIC/I ARBCONTROL SM/arbctrl sm cs FSM FFd3 1> INFO: Xst:2260 - The FF/Latch < mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I_ARBCONTROL_SM/arbSecRdInProgReg_i> in Unit <mb_plb> is equivalent to the following 2 FFs/Latches: <mb_plb/GEN_SHARED. I PLB ARBITER LOGIC/I ARBCONTROL SM/arbSecRdInProgReg i 1> <mb plb /GEN SHARED.I PLB ARBITER LOGIC/I ARBCONTROL SM/ arbSecRdInProgReg i 2> INFO: Xst:2260 - The FF/Latch < mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I ARB ENCODER/arbAddrSelReg i 0> in Unit <mb plb> is equivalent to the following FF/Latch : <mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I ARB ENCODER/arbAddrSelReg i 0 1> INFO: Xst:2260 - The FF/Latch < mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I_ARB_ENCODER/arbAddrSelReg_i_1> in Unit <mb_plb> is equivalent to the following FF/Latch : <mb_plb/GEN_SHARED.I_PLB_ARBITER_LOGIC/ I_ARB_ENCODER/arbAddrSelReg_i_1_1_1> INFO: Xst: 2260 - The FF/Latch < mb plb/GEN SHARED.I PLB ARBITER LOGIC/ I ARBCONTROL SM/arbctrl sm cs FSM FFd3> in Unit <mb plb> is equivalent to the following FF/Latch : <mb\_plb/GEN\_SHARED. I PLB ARBITER LOGIC/I ARBCONTROL SM/arbctrl sm cs FSM FFd3 1> INFO: Xst: 2260 - The FF/Latch < mb_plb/GEN_MPLB_RST[1].I_MPLB_RST> in Unit <mb plb> is equivalent to the following 7 FFs/Latches : < \label{eq:mb_gen} mb - plb/GEN - MPLB_RST [\ 0\ ] \ . \ I_MPLB_RST > \\ < mb_plb/GEN_SPLB_RST [\ 4\ ] \ . I SPLB RST> <mb plb/GEN SPLB RST[3].I SPLB RST> <mb plb/ GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 1 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 1 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST [ 2 ] . I\_SPLB\_RST < mb\_plb/GEN\_SPLB\_RST mb\_plb/GEN\_SPLB < mb\_plb/GEN\_SPLB < mb\_plb/GEN\_SPLB < mb_plb/GEN\_SPLB < mb\_plb/GEN\_SPLB < mb_plb/GEN\_SPLB mb_plb/GEN\_SPL mb\_plb/GEN\_SPLB\_RST[0].I\_SPLB\_RST> < mb\_plb/I\_PLB\_RST> Final Macro Processing ... Final Register Report Found no macro ``` ## Partition Report Partition Implementation Status No Partitions were found in this design. Final Report Final Results Top Level Output File Name : ../implementation/system.ngc Output Format : ngc Optimization Goal : speed Keep Hierarchy : no Design Statistics # IOs : 32 Cell Usage: # BELS : 3937 GND : 16 : 54 INV LUT1 : 128 LUT2 : 251 : 519 LUT3 LUT4 : 522 # LUT5 : 506 LUT6 : 948 LUT6 2 : 31 # # MULT AND : 12 : 266 MUXCY # MUXCY L : 196 : 39 MUXF5 MUXF7 : 123 : 4 MUXF7 L MUXF8 L : 2 : 12 # VCC ``` XORCY : 308 # FlipFlops/Latches : 3042 FD : 240 # # FDC : 63 FDC_1 : 5 FDCE : 47 FDE : 534 FDE_1 : 5 FDP : 25 : 795 FDR FDRE : 1184 : 1 # FDRE 1 : 20 # FDRS # FDRSE : 6 # FDS : 59 FDSE : 58 # RAMS : 55 RAM32M : 21 # RAM32X1D : 2 RAMB36 EXP : 32 # Shift Registers : 90 SRL16 : 3 : 32 SRL16E : 55 SRLC16E # Clock Buffers : 6 : 5 BUFG BUFGP : 1 # IO Buffers : 31 IBUF : 4 : 16 IOBUF : 11 OBUF # DSPs : 5 DSP48E : 5 : 2 # Others BSCAN VIRTEX5 : 1 PLL ADV : 1 Device utilization summary: Selected Device : 5 \text{ vlx} 50 \text{ ff} 676 -1 Slice Logic Utilization: Number of Slice Registers: 2984 10% out of 28800 Number of Slice LUTs: 28800 10% 3137 out of 2959 Number used as Logic: out of 28800 10% ``` | Number used as Memory: Number used as RAM: Number used as SRL: | 178<br>88<br>90 | out | of | 7680 | 2% | |---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------|-------|--------|------| | Slice Logic Distribution: | | | | | | | Number of LUT Flip Flop pairs used: | 4892 | | | | | | Number with an unused Flip Flop: | 1908 | out | of | 4892 | 39% | | Number with an unused LUT: | 1755 | out | o f | 4892 | 35% | | Number of fully used LUT-FF pairs: | 1229 | out | of | 4892 | 25% | | Number of unique control sets: | 295 | | | | | | IO Utilization: | | | | | | | Number of IOs: | 32 | | | | | | Number of bonded IOBs: | 32 | out | of | 440 | 7% | | ${f IOB}$ ${f Flip}$ ${f Flops/Latches}$ : | 58 | | | | | | Specific Feature Utilization: | | | | | | | Number of Block RAM/FIFO: | 32 | out | of | 48 | 66% | | Number using Block RAM only: | 32 | | | | 00,0 | | Number of BUFG/BUFGCTRLs: | 6 | out | of | 32 | 18% | | Number of DSP48Es: | 5 | out | | 48 | 10% | | | 4 | out | of | 6 | 16% | | Number of PLL_ADVs: Partition Resource Summary: | 1 | 041 | | Ü | 1070 | | Number of PLL_ADVs: Partition Resource Summary: No Partitions were found in this de | | | | · | 1070 | | Partition Resource Summary: No Partitions were found in this de | sign . | | | | | | Partition Resource Summary: No Partitions were found in this de | sign . SYNTH | ESIS I | ESTIN | IATE . | | | Partition Resource Summary: No Partitions were found in this de TIMING REPORT NOTE: THESE TIMING NUMBERS ARE ONLY A FOR ACCURATE TIMING INFORMATION REPORT | sign . SYNTH | ESIS I | ESTIN | IATE . | | ``` clock_generator_0/clock_generator_0/PLL0_CLK OUT<0>| BUFG 2858 mdm = 0/mdm = 0/drck = i BUFG 204 mdm 0/bscan update1 BUFG 35 fpga\_0\_SysACE\_CompactFlash\_SysACE\_CLK\_pin BUFGP 95 Asynchronous Control Signals Information: Control Signal | Buffer (FF name) Load lmb bram/lmb bram/net gnd0(lmb bram/lmb bram/XST GND:G) | NONE(lmb bram/lmb bram/ramb36 0) 128 mb plb/SPLB Rst<2>(mb plb/mb plb/GEN SPLB RST[2].I SPLB RST:Q) NONE(SysACE CompactFlash/SysACE CompactFlash/I SYSACE CONTROLLER /MEM STATE MACHINE I/Done) 89 mdm 0/mdm 0/MDM Core I1/Config Reg Acst inv(mdm 0/mdm 0/MDM Core I1/ Config Reg Acst inv1 INV 0:O) NONE(mdm 0/mdm 0/MDM Core I1/Config Reg 0) 23 mdm 0/mdm 0/MDM Core I1/SEL inv(mdm 0/mdm 0/MDM Core I1/ SEL inv1 INV 0:O) NONE(mdm 0/mdm 0/MDM Core I1/PORT Selector 0) SysACE CompactFlash/SysACE CompactFlash/I SYSACE CONTROLLER/ SYNC_2_CLOCKS_I/done3 (SysACE_CompactFlash/SysACE_CompactFlash/ I SYSACE CONTROLLER/SYNC 2 CLOCKS I/DONE REG3:Q) | NONE( SysACE CompactFlash/SysACE CompactFlash/I SYSACE CONTROLLER/ SYNC 2 CLOCKS I/RDCE REG1) microblaze 0/microblaze 0/Performance.Use Debug Logic.Debug I1/ Command Reg Rst(microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug I1/Command Reg Rst:Q) NONE ( ``` ``` microblaze 0/microblaze 0/Performance.Use Debug Logic.Debug I1/ command reg 0) mdm 0/mdm 0/MDM Core I1/PLB Interconnect.JTAG CONTROL I/data cmd inv( mdm_0/mdm_0/MDM_Core_I1/PLB_Interconnect.JTAG_CONTROL_I/ data_cmd_inv1_INV_0:O) | NONE(mdm 0/mdm MDM Core II/PLB Interconnect.JTAG CONTROL I/execute) mdm 0/mdm 0/MDM Core I1/PLB Interconnect.JTAG CONTROL I/local sel n3( mdm 0/mdm 0/MDM Core I1/PLB Interconnect.JTAG CONTROL I/ Insert Delays [4]. LUT Delay: O) | NONE(mdm 0/mdm MDM_Core_I1/PLB_Interconnect.JTAG CONTROL I/FDC I) - 1 mdm 0/mdm 0/MDM Core I1/reset RX FIFO(mdm 0/mdm 0/MDM Core I1/ reset_RX_FIFO:Q) NONE (mdm 0/mdm 0/MDM Core I1/PLB Interconnect. JTAG CONTROL I/ Have_UARTs.RX_FIFO_I/data_Exists_I) | 1 mdm 0/mdm 0/MDM Core I1/reset TX FIFO (mdm 0/mdm 0/MDM Core I1/ reset TX FIFO:Q) NONE(mdm 0/mdm 0/MDM Core I1/PLB Interconnect.JTAG CONTROL I/ Have_UARTs.TX_FIFO_I/data_Exists_I) | 1 microblaze 0/microblaze 0/Performance.Use Debug Logic.Debug I1/ continue from brk (microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug I1/continue from brk:Q) microblaze_0/microblaze_0/Performance.Use_Debug_Logic.Debug_I1/ continue from brk TClk) 1 microblaze 0/microblaze 0/Performance.Use Debug Logic.Debug I1/ force_stop_CMD(microblaze_0/microblaze_0/Performance. Use Debug Logic. Debug I1/force stop CMD:Q) NONE ( microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug I1/ force stop TClk) microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug I1/ normal_stop_cmd (microblaze_0/microblaze_0/Performance. Use Debug Logic. Debug I1/normal stop cmd:Q) NONE ( microblaze 0/microblaze 0/Performance.Use Debug Logic.Debug I1/ normal stop TClk) microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug I1/ start_single_step(microblaze_0/microblaze_0/Performance. Use Debug Logic.Debug I1/start single step:Q) | NONE( microblaze_0/microblaze_0/Performance.Use_Debug Logic.Debug I1/ single\_Step\_TClk) Timing Summary: Speed Grade: -1 ``` ``` Minimum period: 6.198ns (Maximum Frequency: 161.342MHz) Minimum input arrival time before clock: 2.750ns Maximum output required time after clock: 7.206 ns Maximum combinational path delay: 1.397 ns Timing Detail: All values displayed in nanoseconds (ns) Timing constraint: Default period analysis for Clock ' {\tt clock\_generator\_0/clock\_generator\_0/PLL0\_CLK\_OUT<0>'} Clock period: 5.997ns (frequency: 166.750MHz) Total number of paths / destination ports: 763463 / 9782 Delay: 5.997 \, \text{ns} \, (\text{Levels of Logic} = 6) microblaze 0/microblaze 0/Performance. Source: Data Flow I/FPU I/mem MantA 2 31 (FF) microblaze 0/microblaze 0/Performance. Destination: Data Flow I/FPU I/Use FPU.FPU ADDSUB I/mem MantB 3 34 (FF) Source Clock: clock generator 0/clock generator 0/PLL0 CLK OUT <0> rising Destination Clock: clock generator 0/clock generator 0/PLL0 CLK OUT <0> rising Data Path: microblaze 0/microblaze 0/Performance.Data Flow I/FPU I/ mem MantA 2 31 to microblaze 0/microblaze 0/Performance. Data Flow I/FPU I/Use FPU.FPU ADDSUB I/mem MantB 3 34 Gate Net Delay Delay Logical Name (Net Name) Cell:in->out fanout FDRE: C->Q 0.471 1.080 microblaze 0/ Performance. Data Flow I/FPU I/mem MantA 2 31 (microblaze 0/ Performance.Data_Flow_I/FPU_I/mem_MantA_2<31>) LUT6: I0 -> O 4 \quad 0.094 0.726 microblaze 0/ Performance . Data_Flow_I/FPU_I/Use_FPU.FPU_ADDSUB_I/ mem\_rot\_mux1 < 31 > 1 \quad (microblaze\_0 / Performance.Data\_Flow\_I / FPU\_I) = (microblaze\_0 / Performance) /Use FPU.FPU ADDSUB I/mem rot mux1<31>) LUT5 : I2 -> O 0.094 0.816 microblaze_0/ Performance.Data Flow I/FPU I/Use FPU.FPU ADDSUB I/ mem_rot_mux2<11>1 (microblaze_0/Performance.Data_Flow_I/FPU_I /Use FPU.FPU ADDSUB I/mem rot mux2<11>) LUT6: I2 -> O 0.094 0.794 microblaze 0/ Performance . Data_Flow_I/FPU_I/Use_FPU.FPU_ADDSUB_I/ mem rot mux3<27>1 (microblaze 0/Performance.Data Flow I/FPU I /Use FPU.FPU ADDSUB I/mem rot mux3<27>) ``` ``` LUT6: I2->O 1 0.094 0.000 microblaze 0/ Performance.Data Flow I/FPU I/Use FPU.FPU ADDSUB I/ mem_mant_sticky_3_cmb113_F (N535) 0.480 MUXF7: I0 ->O 0.251 microblaze 0/ Performance . Data_Flow_I/FPU_I/Use_FPU.FPU_ADDSUB_I/ mem mant sticky 3 cmb113 (microblaze 0/Performance. Data Flow I/FPU I/Use FPU.FPU ADDSUB I/ mem\_mant\_sticky\_3\_cmb113) LUT5: I4->O 0.094 0.336 microblaze 0/ Performance.Data Flow I/FPU I/Use FPU.FPU ADDSUB I/ mem\_mant\_sticky\_3\_cmb164 \ (microblaze \ 0 / Performance. Data Flow I/FPU I/Use FPU.FPU ADDSUB I/ mem_mant_sticky_3_cmb164) FDRS: S microblaze 0/ 0.573 Performance.Data Flow I/FPU I/Use FPU.FPU ADDSUB I/ mem MantB 3 34 Total 5.997ns (1.765ns logic, 4.232ns route) (29.4% logic, 70.6% route) Timing constraint: Default period analysis for Clock 'mdm 0/mdm 0/ drck i' Clock period: 6.198ns (frequency: 161.342MHz) Total number of paths / destination ports: 302 / 250 Delay: 3.099 \,\mathrm{ns} (Levels of Logic = 4) Source: mdm 0/mdm 0/MDM Core I1/PLB Interconnect. JTAG CONTROL I/SYNC FDRE (FF) microblaze - 0 / microblaze \_ 0 / Performance \,. Destination: Use Debug Logic. Debug I1/shift Count 0 (FF) Source Clock: mdm_0/mdm_0/drck_i falling Destination Clock: mdm 0/mdm 0/drck i rising Data Path: mdm 0/mdm 0/MDM Core I1/PLB Interconnect.JTAG CONTROL I/ SYNC FDRE to microblaze 0/microblaze 0/Performance. Use_Debug_Logic.Debug_I1/shift_Count_0 Gate Net Logical Name (Net Name) Cell:in->out fanout Delay Delay FDRE 1: C \rightarrow Q 0.973 PLB_Interconnect. 0.467 JTAG CONTROL I/SYNC FDRE (PLB Interconnect.JTAG CONTROL I/ sync) LUT6: I1->O 0.094 0.380 PLB Interconnect. JTAG CONTROL I/shifting Data (Dbg Shift 7) end scope: 'mdm 0/MDM Core I1' end scope: 'mdm 0' ``` ``` begin scope: 'microblaze 0' INV: I \rightarrow O 0.238 0.374 microblaze 0/ Performance. Use_Debug_Logic. Debug_I1/Shift_inv1_INV_0 ( microblaze_0/Performance.Use_Debug_Logic.Debug_I1/Shift_inv) 0.573 microblaze 0/ Performance. Use Debug Logic. Debug I1/shift Count 0 Total 3.099 \, \text{ns} \, (1.372 \, \text{ns} \, \log ic \, , \, 1.727 \, \text{ns} \, \text{route}) (44.3\% \log ic, 55.7\% \text{ route}) Timing constraint: Default period analysis for Clock 'mdm 0/ bscan update1' Clock period: 5.746 ns (frequency: 174.034MHz) Total number of paths / destination ports: 209 / 40 Delay: 2.873 \, \text{ns} (Levels of Logic = 4) Source: mdm 0/mdm 0/MDM Core I1/PLB Interconnect. JTAG CONTROL I/FDC I (FF) microblaze_0/microblaze_0/Performance. Destination: Use Debug Logic. Debug I1/force stop TClk (FF) mdm 0/bscan_update1 falling Source Clock: Destination Clock: mdm 0/bscan update1 rising Data Path: mdm 0/mdm 0/MDM Core I1/PLB Interconnect.JTAG CONTROL I/ FDC I to microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug_I1/force_stop_TClk Gate Net Cell:in->out fanout Delay Delay Logical Name (Net Name) FDC 1: C \rightarrow Q 10 0.467 0.625 PLB Interconnect. JTAG_CONTROL_I/FDC_I (PLB_Interconnect.JTAG_CONTROL_I/ data cmd) LUT2:I0-\!\!>\!\!O 6 0.094 1.000 PLB Interconnect. JTAG CONTROL I/Dbg Reg En I<4>1 (Dbg Reg En 0<4>) end scope: 'mdm_0/MDM_Core_I1' end scope: 'mdm_0' begin scope: 'microblaze 0' LUT5 : I0 -> O 9 0.094 microblaze 0/ 0.380 Performance. Use Debug Logic. Debug I1/ Control_Reg_En_cmp_eq00001 (microblaze_0/Performance. Use Debug Logic. Debug I1/Control Reg En) FDCE: CE 0.213 microblaze 0/ Performance. Use Debug Logic. Debug I1/force stop TClk Total 2.873 ns (0.868 ns logic, 2.005 ns route) (30.2\% \text{ logic}, 69.8\% \text{ route}) ``` ``` Timing constraint: Default period analysis for Clock fpga\_0\_SysACE\_CompactFlash\_SysACE\_CLK\_pin~^{?} Clock period: 2.224ns (frequency: 449.640MHz) Total number of paths / destination ports: 227 / 70 Delay: 2.224 \,\mathrm{ns} (Levels of Logic = 2) SysACE CompactFlash/SysACE CompactFlash/ Source: I SYSACE CONTROLLER/MEM STATE MACHINE I/current State FSM FFd4 ( FF) SysACE CompactFlash/SysACE CompactFlash/ Destination: I SYSACE CONTROLLER/MEM STATE MACHINE I/SYSACE WEN REG (FF) fpga 0 SysACE CompactFlash SysACE CLK pin rising Destination Clock: fpga 0 SysACE CompactFlash SysACE CLK pin rising Data Path: SysACE CompactFlash/SysACE CompactFlash/ I SYSACE CONTROLLER/MEM STATE MACHINE I/current State FSM FFd4 to SysACE CompactFlash/SysACE CompactFlash/I SYSACE CONTROLLER/ MEM_STATE_MACHINE_I/SYSACE_WEN_REG Gate Net Logical Name (Net Name) Cell:in->out Delay Delay fanout FDC: C->Q 3 0.471 1.080 SysACE CompactFlash/ I SYSACE CONTROLLER/MEM STATE MACHINE I/ current State FSM FFd4 (SysACE CompactFlash/ I SYSACE CONTROLLER/MEM STATE MACHINE I/ current State FSM FFd4) 0.485 SysACE CompactFlash/ LUT6 : I0 -> O 0.094 I SYSACE CONTROLLER/MEM STATE MACHINE I/sysace wen cmb21 ( SysACE CompactFlash/I SYSACE CONTROLLER/MEM STATE MACHINE I/ N3) LUT3: I2->O 0.000 SysACE CompactFlash/ 0.094 I SYSACE CONTROLLER/MEM STATE MACHINE I/sysace wen cmb1 ( SysACE CompactFlash/I SYSACE CONTROLLER/MEM STATE MACHINE I/ sysace_wen_cmb) -0.018 FDP:D SysACE_CompactFlash/ I SYSACE CONTROLLER/MEM STATE MACHINE I/SYSACE WEN REG Total 2.224ns (0.659ns logic, 1.565ns route) (29.6\% \text{ logic}, 70.4\% \text{ route}) Timing constraint: Default OFFSET IN BEFORE for Clock ' clock generator 0/clock generator 0/PLLO CLK OUT<0> Total number of paths / destination ports: 3 / 3 ``` ``` Offset: 1.733 \,\mathrm{ns} (Levels of Logic = 3) Source: fpga_0_rst_1_sys_rst_pin (PAD) Destination: proc_sys_reset_0/proc_sys_reset_0/EXT_LPF/exr_d1 (FF) Destination Clock: clock generator 0/clock generator 0/PLL0 CLK OUT <0> rising Data Path: fpga_0_rst_1_sys_rst_pin to proc_sys_reset_0/ proc sys reset 0/EXT LPF/exr d1 Gate Net Cell:in->out fanout Delay Delay Logical Name (Net Name) IBUF: I->O 0.818 0.341 fpga_0_rst_1_sys_rst_pin_IBUF (fpga_0_rst_1_sys_rst_pin_IBUF) begin scope: 'proc_sys_reset_0' 0.238 INV: I \rightarrow O 0.336 proc sys reset 0/ EXT LPF/exr d1 or000011 INV 0 (proc sys reset 0/EXT LPF/ exr d1 or00001) FDS:D -0.018 proc sys reset 0/ EXT_LPF/exr_d1 Total 1.733 ns (1.056 ns logic, 0.677 ns route) (60.9\% \text{ logic}, 39.1\% \text{ route}) Timing constraint: Default OFFSET IN BEFORE for Clock 'mdm 0/mdm 0/ drck i' Total number of paths / destination ports: 129 / 96 Offset: 2.750 \,\mathrm{ns} (Levels of Logic = 4) mdm 0/mdm 0/Use Virtex5.BSCAN VIRTEX5 I:SHIFT ( Source: PAD) microblaze 0/microblaze 0/Performance. Destination: Use Debug Logic. Debug I1/shift Count 0 (FF) Destination Clock: mdm_0/mdm_0/drck_i rising Data Path: mdm_0/mdm_0/Use_Virtex5.BSCAN_VIRTEX5_I:SHIFT to microblaze 0/microblaze 0/Performance. Use Debug Logic. Debug I1/ shift_Count_0 Net Gate Cell: in->out fanout Delay Delay Logical Name (Net Name) BSCAN VIRTEX5: SHIFT 0.000 0.000 mdm 0/Use Virtex5. BSCAN VIRTEX5 I (bscan shift) begin scope: 'mdm 0/MDM Core I1' ``` ``` 0.094 0.380 PLB Interconnect. LUT6: I0 -> O 9 JTAG CONTROL I/shifting Data (Dbg Shift 7) end scope: 'mdm 0/MDM Core I1' end scope: 'mdm 0' begin scope: 'microblaze 0' INV: I \rightarrow O 8 0.238 microblaze 0/ 0.374 Performance. Use Debug Logic. Debug I1/Shift inv1 INV 0 ( microblaze 0/Performance. Use Debug Logic. Debug I1/Shift inv) 0.573 FDR:R microblaze 0/ Performance. Use Debug Logic. Debug I1/shift Count 0 2.750 ns (1.996 ns logic, 0.754 ns route) Total (72.6\% \text{ logic}, 27.4\% \text{ route}) Timing constraint: Default OFFSET IN BEFORE for Clock 'mdm 0/ bscan update1' Total number of paths / destination ports: 14 / 14 Offset: 1.670 \, \mathrm{ns} (Levels of Logic = 2) Source: mdm 0/mdm 0/Use Virtex5.BSCAN VIRTEX5 I:SEL (PAD Destination: mdm 0/mdm 0/MDM Core I1/PORT Selector 1 0 (FF) Destination Clock: mdm 0/bscan update1 rising Data Path: mdm_0/mdm_0/Use_Virtex5.BSCAN_VIRTEX5_I:SEL to mdm_0/ mdm 0/MDM Core I1/PORT Selector 1 0 Net Gate Cell:in->out Logical Name (Net Name) fanout Delay Delay BSCAN VIRTEX5: SEL 0.000 mdm 0/Use Virtex5. 0.000 BSCAN_VIRTEX5_I \pmod{0/sel} begin scope: 'mdm 0/MDM Core I1' LUT5: I0 \longrightarrow O 4 \quad 0.094 0.352 MDM SEL1 (MDM SEL) FDCE: CE 0.213 PORT Selector 1 0 Total 1.670 ns (1.318 ns logic, 0.352 ns route) (78.9% logic, 21.1% route) Timing constraint: Default OFFSET IN BEFORE for Clock ' fpga 0 SysACE CompactFlash SysACE CLK pin' Total number of paths / destination ports: 16 / 16 Offset: 1.154 \,\mathrm{ns} (Levels of Logic = 2) ``` ``` Source: fpga 0 SysACE CompactFlash SysACE MPD pin<0> ( PAD) SysACE CompactFlash/SysACE CompactFlash/ Destination: I_SYSACE_CONTROLLER/SYNC_2_CLOCKS_I/MEM_DQ_I_GEN[7].MEM_DQ_I_1 ( Destination Clock: fpga 0 SysACE CompactFlash SysACE CLK pin rising Data Path: fpga 0 SysACE CompactFlash SysACE MPD pin<0> to SysACE CompactFlash/SysACE CompactFlash/I SYSACE CONTROLLER/ SYNC 2 CLOCKS I/MEM DQ I GEN[7].MEM DQ I 1 Gate Delay Logical Name (Net Name) Cell:in->out fanout Delay IOBUF: IO->O 1 0.818 iobuf 15 ( 0.336 fpga 0 SysACE CompactFlash SysACE MPD pin I<0>) begin scope: 'SysACE CompactFlash' FDCE: D SysACE CompactFlash/ -0.018 I SYSACE CONTROLLER/SYNC 2 CLOCKS I/MEM DQ I GEN[7]. MEM DQ I 1 Total 1.154ns (0.818ns logic, 0.336ns route) (70.9\% \text{ logic}, 29.1\% \text{ route}) Timing constraint: Default OFFSET OUT AFTER for Clock ' fpga 0 SysACE CompactFlash SysACE CLK pin' Total number of paths / destination ports: 42 / 26 3.259 \,\mathrm{ns} (Levels of Logic = 2) Offset: SysACE CompactFlash/SysACE CompactFlash/ Source: I SYSACE CONTROLLER/MEM STATE MACHINE I/SYSACE CEN REG (FF) fpga_0_SysACE_CompactFlash_SysACE_CEN_pin (PAD) Destination: Source Clock: fpga 0 SysACE CompactFlash SysACE CLK pin rising Data Path: SysACE CompactFlash/SysACE CompactFlash/ I SYSACE CONTROLLER/MEM STATE MACHINE I/SYSACE CEN REG to fpga_0_SysACE_CompactFlash_SysACE_CEN_pin Gate Net Logical Name (Net Name) Cell:in->out fanout Delay Delay FDP: C->Q 0.471 0.336 SysACE CompactFlash/ I SYSACE CONTROLLER/MEM STATE MACHINE I/SYSACE CEN REG ( SysACE CEN) end scope: 'SysACE CompactFlash' OBUF: I \rightarrow O 2.452 fpga 0 SysACE CompactFlash SysACE CEN pin OBUF ( fpga 0 SysACE CompactFlash SysACE CEN pin) ``` ``` Total 3.259 ns (2.923 ns logic, 0.336 ns route) (89.7% logic, 10.3% route) Timing constraint: Default OFFSET OUT AFTER for Clock ' clock_generator_0/clock_generator_0/PLL0_CLK_OUT<0>' Total number of paths / destination ports: 1 / 1 Offset: 3.259 \,\mathrm{ns} (Levels of Logic = 2) Source: RS232 Uart/RS232 Uart/UARTLITE CORE I/ UARTLITE TX I/TX (FF) Destination: fpga 0 RS232 Uart TX pin (PAD) Source Clock: clock_generator_0/clock_generator_0/PLL0_CLK_OUT <0> rising Data Path: RS232 Uart/RS232 Uart/UARTLITE CORE I/UARTLITE TX I/TX to fpga 0 RS232 Uart TX pin Gate Net Cell:in->out fanout Delay Delay Logical Name (Net Name) FDS: C->Q 0.471 0.336 RS232 Uart/ UARTLITE CORE I/UARTLITE TX I/TX (TX) end scope: 'RS232 Uart' OBUF: I->O 2.452 fpga 0 RS232 Uart TX pin OBUF (fpga 0 RS232 Uart TX pin) Total 3.259 ns (2.923 ns logic, 0.336 ns route) (89.7% logic, 10.3% route) Timing constraint: Default OFFSET OUT AFTER for Clock 'mdm 0/mdm 0/ Total number of paths / destination ports: 119 / 1 7.206 \,\mathrm{ns} (Levels of Logic = 8) Offset: microblaze_0/microblaze_0/Performance. Use_Debug_Logic.Debug_I1/Use_SRL16.The_Cache Addresses[5]. SRL16E_Cache_I (FF) mdm 0/mdm 0/Use Virtex5.BSCAN VIRTEX5 I:TDO (PAD Destination: Source Clock: mdm 0/mdm 0/drck i rising Data Path: microblaze 0/microblaze 0/Performance.Use Debug Logic. Debug I1/Use SRL16. The Cache Addresses [5]. SRL16E Cache I to ``` ``` mdm 0/mdm 0/Use Virtex5.BSCAN VIRTEX5 I:TDO Gate Net Cell: in->out fanout Delay Delay Logical Name (Net Name) SRL16E : CLK \rightarrow Q 1.889 0.973 microblaze 0/ Performance. Use Debug Logic. Debug I1/Use SRL16. The Cache Addresses [5]. SRL16E Cache I (microblaze 0/ Performance. Use Debug Logic. Debug I1/tdo config word1<6>) LUT6: I1->O 1 0.094 0.973 microblaze 0/ Performance. Use Debug Logic. Debug I1/TDO42 (microblaze 0/ Performance. Use_Debug_Logic.Debug_I1/TDO42) LUT6: I1->O 0.094 0.000 microblaze 0/ Performance. Use Debug Logic. Debug I1/TDO387 SW01 ( microblaze_0/Performance.Use_Debug_Logic.Debug_I1/TDO387_SW0) MUXF7: I1->O 1 0.254 0.789 microblaze 0/ Performance. Use_Debug_Logic. Debug_I1/TDO387_SW0_f7 (N463) LUT6: I2->O 0.094 1.069 microblaze 0/ Performance. Use Debug Logic. Debug I1/TDO387 (DBG TDO) end scope: 'microblaze 0' begin scope: 'mdm 0' begin scope: 'mdm 0/MDM Core I1' LUT6 : I0 -> O 1 0.094 0.789 TDO i79 (TDO i79) LUT6: I2->0 0 0.094 0.000 TDO i225 (TDO) end scope: 'mdm 0/MDM Core II' BSCAN VIRTEX5:TDO 0.000 mdm 0/Use Virtex5. BSCAN VIRTEX5 I Total 7.206 ns (2.613 ns logic, 4.593 ns route) (36.3\% \text{ logic}, 63.7\% \text{ route}) Timing constraint: Default OFFSET OUT AFTER for Clock 'mdm 0/ bscan update1 Total number of paths / destination ports: 36 / 1 Offset: 4.996 \,\mathrm{ns} (Levels of Logic = 9) mdm 0/mdm 0/MDM Core I1/PLB Interconnect. Source: JTAG CONTROL I/FDC I (FF) mdm 0/mdm 0/Use Virtex5.BSCAN VIRTEX5 I:TDO (PAD Destination: Source Clock: mdm 0/bscan update1 falling Data Path: mdm_0/mdm_0/MDM_Core_I1/PLB_Interconnect.JTAG_CONTROL_I/ FDC_I to mdm_0/mdm_0/Use_Virtex5.BSCAN_VIRTEX5_I:TDO Gate Net Cell:in->out Logical Name (Net Name) fanout Delay Delav ``` ``` FDC 1: C \rightarrow Q 10 0.467 0.625 PLB Interconnect. JTAG CONTROL I/FDC I (PLB Interconnect.JTAG CONTROL I/ data cmd) LUT2: I0 \longrightarrow O 0.094 1.096 PLB Interconnect. 6 \label{loss_eq_en_loss} JTAG\_CONTROL\_I/Dbg\_Reg\_En\_I<4>1 \ (Dbg\_Reg\_En\_0<4>) end scope: 'mdm 0/MDM Core I1' end scope: 'mdm 0' begin scope: 'microblaze 0' LUT6 : I0 -> O 1 0.094 0.480 microblaze 0/ Performance. Use_Debug_Logic. Debug_I1/TDO351 (microblaze_0/ Performance. Use Debug Logic. Debug I1/TDO351) LUT6: I5 -> O 0.094 1.069 microblaze 0/ Performance. Use Debug Logic. Debug I1/TDO387 (DBG TDO) end scope: 'microblaze_0' begin scope: 'mdm 0' begin scope: 'mdm 0/MDM Core I1' LUT6 : I0 -> O TDO i79 (TDO i79) 1 0.094 0.789 LUT6: I2 -> O 0 0.094 0.000 TDO i225 (TDO) end scope: 'mdm 0/MDM Core II' BSCAN VIRTEX5:TDO 0.000 mdm 0/Use Virtex5. BSCAN VIRTEX5 I Total 4.996 ns (0.937 ns logic, 4.059 ns route) (18.8% logic, 81.2% route) Timing constraint: Default path analysis Total number of paths / destination ports: 2 / 2 Delay: 1.397 \, \text{ns} (Levels of Logic = 3) fpga 0 rst 1 sys rst pin (PAD) Source: clock_generator_0/clock_generator_0/Using_PLL0. Destination: PLL0 INST/PLL INST/Using PLL ADV.PLL ADV inst:RST (PAD) Data Path: fpga 0 rst 1 sys rst pin to clock generator 0/ clock generator 0/Using PLL0.PLL0 INST/PLL INST/Using PLL ADV. PLL\_ADV\_inst:RST Gate Net Cell:in->out Logical Name (Net Name) fanout Delay Delay IBUF: I \rightarrow O 0.818 0.341 fpga_0_rst_1_sys_rst_pin_IBUF (fpga_0_rst_1_sys_rst_pin_IBUF) begin scope: 'clock_generator_0' INV: I \rightarrow O 0.238 0.000 clock generator 0/ Using PLL0.PLL0 INST/PLL INST/rsti1 INV 0 (clock generator 0/ Using PLL0.PLL0 INST/PLL INST/rsti) ``` ``` PLL_ADV:RST 0.000 clock_generator_0/ Using_PLL0.PLL0_INST/PLL_INST/Using_PLL_ADV.PLL_ADV_inst Total 1.397ns (1.056ns logic, 0.341ns route) (75.6% logic, 24.4% route) Total REAL time to Xst completion: 25.00 secs Total CPU time to Xst completion: 25.75 secs Total memory usage is 257840 kilobytes Number of errors : 0 ( 0 filtered) Number of warnings : 278 ( 0 filtered) Number of infos : 10 ( 0 filtered) ``` # .4 Matlab Scripts #### .4.1 Read Image ``` a = imread('canyon.gif'); [y,x] = size(a); size_x = x; size_y = y; b = imnoise(a, 'salt & pepper', 0.02); string = '('; for j = 1: size_x for i = 1: size_y if ( j==size_x && i==size_y) string = [string, num2str(b(i,j))]; else string = [string, num2str(b(i,j)), ', ']; end; end; end; string = [string, ')']; file_in = fopen('image_in_0.02.pgm', 'w'); fprintf(file_in ,string); fclose (file_in); \operatorname{size} \_x size_y ``` ### .4.2 Write Image ``` a = textread('one.pgm'); b = a'; [y,x]= size(b); img = zeros(x,y-(y-x)); for i = 1:y-1 for j = 1:x img(i,j) = b(i,j); end; end; end; size(img) imwrite(img, 'canyon_noise_0.01.pgm', 'encoding', 'ascii'); ``` #### .4.3 Measuring Values ``` img = imread('field.gif'); noisy = imread('field_output_noise_0.001.png'); img = im2double(img); noisy = im2double(noisy); [x,y] = size(img); \max \text{ val} = \max(\max(\text{img})); [x,y] = size(img); mse = 0; mae = 0; for i=2:x-1 for j=2:y-1 mse = mse + (img(i,j)-noisy(i,j))^2; mae = mae + abs(img(i,j)-noisy(i,j)); end end mse = mse/(2*x*y); mae = mae/(2*x*y); psnr = 10*log10((max_val^2)/mse); mse = mse * 256; mae = mae * 256; mse mae psnr ``` #### .4.4 Median algorithm ``` %image is the image to be noised then denoised %m is the vindowsize \%th is the threshold in added value, a value of 0,2 will classefy any \%of +-0,2 as defect %n is the noise percentage function image median (image, m, th, n) %start time tic; %reading image file I = imread(image); [x, y, z] = size(I); %calculating the size of the input image % matrix which stores pixel map = zeros(x,y,z); the positions of the pixels that have been corrected img = im2double(I); %converting from unit8 to double: scale from 0..1 in stead of 0--256 img noisy = imnoise(img, 'salt & pepper', n); %adding noise to the input image noise = img noisy; %duplicating the noist image in order to dispay both of them % imwrite(noise, 'img_two_noisy_salt.jpg');% writing corrected image to %The corners, edges and mid image will have to be done separately due to %how matlab indexes and m *n*3 matrix. It is impossible to access a position %outside the matrix. The image matrix will have corners(1,1),(1,y),(x) ,1) and \%(x,y) %correcting the corners of all the layers in the image by replacing a noisv %pixel with the median of the three neighboring pixels. The z variable will %be 3 for an RGB image. \%left upper corner (1,1) of all the layers (3 layers for an RGB image) ``` ``` for k=1:z c1 = [img \ noisy(2,1,k), img \ noisy(2,2,k), img \ noisy(1,2,k)]; if (img\ noisy(1,1,k)>th+max(c1) \mid img\ noisy(1,1,k)<th+min(c1)) pixel_map(1,1,k) = 1; img noisy (1,1,k)=median (c1); %left upper corner (1,y) of all layers end end for k=1:z c2 = [img \ noisy(1, y-1, k), img \ noisy(2, y, k), img \ noisy(2, y-1, k)]; if (img noisy(1,y,k)>th+max(c2)) \mid img noisy(1,y,k)<th+min(c2)) pixel map (1, y, k) = 1; img_noisy(1,y,k)=median(c2); %right upper corner(1,y) of all layers end end for k=1:z c3 = [img noisy(x,2,k), img noisy(x-1,1,k), img noisy(x-1,2,k)]; if (img_noisy(x,1,k)>th+max(c3))|img_noisy(x,1,k)<th+min(c3)) pixel_map(x,1,k)=1; img noisy (x,1,k)=median (c3); %left lower corner (x,1) of all layers end end for k=1:z c4 = [img\_noisy(x,y,k), img\_noisy(x-1,y-1,k), img\_noisy(x-1,y,k)]; if(img_noisy(x,y,k)>th+max(c4)||img_noisy(x,y,k)<th+min(c4)) pixel map(x, y, k) = 1; img noisy(x,y,k)=median(c4); %right lower corner(x,y) of all layers end end %correcting the edges of the image is done by storing the neigboring %pixel values and assigning the median of those values to the pisition of %the defect pixel. The windowsize is m, and correcting from ((m-(( m+1)/2)) \%to ((m-((m-1)/2))) will correct the edges that ``` ``` the mid image correction %function can not reach with its for loop. for k=1:z %upper horizontal line for i = 2: ((m-((m+1)/2))) for j = 2:((m-((m-1)/2))) e1 = [img\_noisy(i, j-1,k), img\_noisy(i, j+1,k)], img noisy (i+1,j-1,k), img noisy (i+1,j,k), img noisy(i+1,j+1,k); if (img\_noisy(i,j,k)>th+max(e1)||img\_noisy (i, j, k) pixel_map(i,j,k)=1; img noisy(i,j,k) = median(e1); end end end end for k=1:z %lower horizontal line for i = 2 : (x - (m - ((m+1)/2))) for j=y:(y-(m-((m-1)/2))) e2 = [img\_noisy(i, j-1,k), img\_noisy(i, j+1,k)], img_noisy(i+1,j-1,k), img_noisy(i+1,j,k), img noisy(i+1,j+1,k); if (img_noisy(i,j,k)>th+max(e2)||img_noisy(i,j ,k > th + min(e2) pixel map(i,j,k)=1; img noisy(i,j,k)=median(e2); else end end end \quad \text{end} \quad for k=1:z %left vertical line for i = 2: ((m-((m+1)/2))) for j = 2: ((m-((m+1)/2))) e3 = [img\_noisy(i-1,j,k), img\_noisy(i+1,j,k)], img noisy(i+1,j+1,k), img noisy(i,j+1,k), img_noisy(i-1,j+1,k); if (img_noisy(i,j,k)>th+max(e3)||img_noisy(i,j ,k <th+min (e3) pixel map(i,j,k)=1; img noisy(i, j, k)=median(e3); ``` ``` end end end end for k=1:z %right vertical line for i=y:(y-(m-((m+1)/2))) for j = 2: (x-(m-((m+1)/2))) e4 = [img_noisy(i, j-1,k), img_noisy(i, j+1,k)], img_noisy(i+1,j-1,k), img_noisy(i+1,j,k), img_noisy(i+1,j+1,k); if (img_noisy(i,j,k)>th+max(e4)||img_noisy(i,j , k > th + min(e4) pixel_map(i,j,k)=1; img_noisy(i,j,k) = median(e4); end end end end %Correcting mid image from (m-(m-1)/2):x-(m-1) -(m+1)/2) to \%(m-(m-1)/2):y-(m-(m+1)/2 will ensure that the enitre image has been %corrected when first doing the coreners, then the edges and at last the %mid image. for k=1:z for i = (m-(m-1)/2) : x-(m-(m+1)/2) for j = (m-(m-1)/2) : y-(m-(m+1)/2) %counter for val = 1; the values array count = 1; values = zeros(1,m^2); %array to store the neigboring pixel values array = zeros(1, m^1-1); for a=-(m-((m+1)/2)):(m-((m+1)/2)) for b=-(m-(m+1)/2):(m-((m+1)/2)) if (a==0 \&\& b==0) else array (count)=img_noisy (i+a, j+b, k); ``` ``` end values (val)=img noisy (i+a, j+b, k val = val + 1; end end if(img\_noisy(i,j,k)>th+max(array)|| img noisy(i,j,k)<th+min(array)) % img\_noisy(i,j,k)=median(values); replacing the defect pixel with the median of the values array pixel_map(i,j,k)=1; storing the position of the defect end end end end %stop time imwrite(img_noisy, 'median_res.jpg'); % write the %restored image to predetermined filename %plotting the original, noisy and reconstructed image str=sprintf('Median filtered image with windowsize %d', m); subplot (2, 2, 1:2), imshow (I) title ('Original image'); subplot(2,2,3), imshow(noise) title ('Noisy image'); subplot(2,2,4), imshow(img noisy) title (str); When the image has been corrected it is time to measure the mse, mae and %psnr.This is done by looping through the entire image in order %calculate these values. J = img_noisy; \max_{\text{val}} = \max_{\text{max}} (\max_{\text{max}} (\max_{\text{img}}))); [x, y, z] = size(I); mse = 0; mae = 0; for k=1:z ``` ``` for i=2:x-1 for j = 2: y-1 mse = mse + (img(i,j,k)-J(i,j,k))^2; mae = mae + abs(img(i,j,k)-J(i,j,k)); end end end mse = mse/(3*x*y); mae = mae/(3*x*y); psnr = 10*log10((max_val^2)/mse); \%defects = sum(sum(sum(pixel_map))); mse = 256*mse; mae = 256*mae; %displaying the measured values. _{ m mse} mae psnr end ``` #### .5 C Code #### .5.1 Test Compact flash ``` #include "sysace_stdio.h" #include "xparameters.h" #include "xutil.h" #include "xio.h" #include "stdio.h" int main(void){ unsigned char buffer [3]; char*file_out = "output.txt"; //input and output files name, type the char*file_in = "input.txt"; //directory int numread; char readBuffer[2]; //the variable that stored charackters read from the cf card SYSACE FILE * outfile; //input file handler SYSACE_FILE * outfile; //input file handle SYSACE_FILE * infile; //output file handler write mode infile = sysace fopen(file in, "r"); //open the input file in read mode numread = sysace fread(readBuffer,1,19,infile); //reading 19 characters from the input file into the readBuffer sysace fwrite (readBuffer, 1, 19, outfile); // writing the characters from the readBuffer into the file on the cf card sysace_fclose(outfile); //closing the output file sysace fclose (infile); //closing the input file return 0; ``` #### .5.2 Test interrupt ``` #include "sysace stdio.h" #include "xparameters.h" #include "xutil.h" #include "xio.h" #include "stdio.h" #include "my custom_ip_register.h" #include "xintc.h" #include "mb interface.h" #define SLV REG0 0 \times 000000000 #define SLV REG1 0 \times 000000004 #define SLV_REG2 0 \times 000000008 #define SLV REG3 0 \times 00000000C #define SLV REG4 0x00000010 #define BaseAddress 0xCCC00000 #define read 0 \times 00000001 #define reset 0 \times 000000000 void intr_handler(){ char*file out = "outfile.txt"; //declaring the output file name, type and directory //variable to store data char readValue; int numwrite; SYSACE FILE * outfile; //output file handler unsigned char buffer [4] = "test"; //data to be written to the file status = MY CUSTOM IP REGISTER mReadReg( XPAR MY CUSTOM IP REGISTER 0 BASEADDR, MY CUSTOM IP REGISTER INTR IPISR OFFSET); //read the status of the interrupt service register MY CUSTOM IP REGISTER mWriteReg( XPAR MY CUSTOM IP REGISTER 0 BASEADDR, MY CUSTOM IP REGISTER INTR IPISR OFFSET, 0); //Acknowledge interrupt on peripheral XIntc mAckIntr(XPAR XPS INTC 0 BASEADDR, XPAR MY CUSTOM IP REGISTER 0 IP2INTC IRPT MASK); //Acknowledge interrupt on interrupt controller outfile = sysace fopen(file out, "w"); //open file in write mode numwrite = sysace_fwrite(buffer,1,sizeof(buffer),outfile); //write the data in buffer to the file sysace fclose(outfile); //close file } ``` ``` void init(){ // Registering an Interrupt handler XIntc_RegisterHandler(XPAR_XPS_INTC_0_BASEADDR, XPAR_XPS_INTC_0_MY_CUSTOM_IP_REGISTER_0_IP2INTC_IRPT_INTR, intr handler, (void *)XPAR MY CUSTOM IP REGISTER 0 BASEADDR); // enabling interrupts on the interrupt controller, my custom ip and microblaze XIntc mMasterEnable(XPAR MY CUSTOM IP REGISTER 0 BASEADDR); XIntc mEnableIntr(XPAR MY CUSTOM IP REGISTER 0 BASEADDR, XPAR MY CUSTOM IP REGISTER 0 IP2INTC IRPT MASK); MY CUSTOM IP REGISTER EnableInterrupt ((void *) XPAR_MY_CUSTOM_IP_REGISTER_0_BASEADDR); microblaze_enable_interrupts(); } int main(void){ //run the function to set up the interrupts init(); intr_handler(); //the function run for every interrupt while (1) { } return 0; ``` #### .5.3 Test interrupt with read and write ``` #include "sysace stdio.h" #include "xparameters.h" #include "xutil.h" #include "xio.h" #include "stdio.h" #include "my custom_ip_register.h" #include "xintc.h" #include "mb interface.h" void intr handler(){ SYSACE FILE * outfile; char* file out = "outfile.txt"; //output file name, type and directory Xuint32 readValue; //variable to store data read from the register //status of the interrupt register Xuint32 status; //variable used to store char representation char test [3]; of readValue char data [30]; //variable that is written to the cf card status = MY CUSTOM IP REGISTER mReadReg( XPAR MY CUSTOM IP REGISTER 0 BASEADDR, MY CUSTOM IP REGISTER INTR IPISR OFFSET); //read the status of the interrupt service register MY CUSTOM IP REGISTER mWriteReg( XPAR\_MY\_CUSTOM\_IP\_REGISTER\_0\_BASEADDR, MY CUSTOM IP REGISTER INTR IPISR OFFSET, 0); Acknowledge interrupt on peripheral XIntc mAckIntr(XPAR XPS INTC 0 BASEADDR, XPAR_MY_CUSTOM_IP_REGISTER_0_IP2INTC_IRPT_MASK); //Acknowledge interrupt on interrupt controller outfile = sysace_fopen(file_out, "w"); //open file in write mode readValue = MY CUSTOM IP REGISTER mReadReg( XPAR MY CUSTOM IP REGISTER 0 BASEADDR, MY CUSTOM IP REGISTER SLV REG3 OFFSET); //read value from register 3 test |0| = readValue; //stores value in the test variable strncat (data, test, 2); //stores the test value into a char array sysace_fwrite((char *)data,1,sizeof(data),outfile); //writes the value of data to the cf card sysace fclose (outfile); //close the file ``` ``` } int init(i){ // Registering an Interrupt handler XIntc RegisterHandler (XPAR XPS INTC 0 BASEADDR, XPAR_XPS_INTC_0_MY_CUSTOM_IP_REGISTER_0_IP2INTC_IRPT_INTR, intr handler, (void *)XPAR MY CUSTOM IP REGISTER 0 BASEADDR); // enabling interrupts on the interrupt controller, my custom ip and microblaze XIntc_mMasterEnable(XPAR_MY_CUSTOM_IP_REGISTER_0_BASEADDR); XIntc mEnableIntr(XPAR MY CUSTOM IP REGISTER 0 BASEADDR, XPAR_MY_CUSTOM_IP_REGISTER_0_IP2INTC_IRPT_MASK); MY CUSTOM IP REGISTER EnableInterrupt ((void *) XPAR_MY_CUSTOM_IP_REGISTER_0_BASEADDR); microblaze_enable_interrupts(); i = 0; return i; } int main(void) { MY_CUSTOM_IP_REGISTER_mWriteReg(XPAR_MY_CUSTOM_IP_REGISTER_0_BASEADDR ,MY CUSTOM IP REGISTER SLV REG3 OFFSET, 0xA2); //writing a test value to register 3 init(); //function to set up the interrupts intr handler(); //function that is invoked when there is an interrupt. while (1) { return 0; ``` # .6 Images # .6.1 Original Images Figure 1: Original noise free Lena image ${\bf Figure} \ {\bf 2:} \ {\bf Original} \ {\bf noise} \ {\bf free} \ {\bf Canyon} \ {\bf image}$ $\textbf{Figure 3:} \ \, \textbf{Original noise free Field image}$ # .6.2 Lena Images from different noise levels Figure 4: Lena image with noise level 0.001 Figure 5: Restored Lena image from noise level 0.001 Figure 6: Lena image with noise level 0.002 Figure 7: Restored Lena image from noise level 0.002 Figure 8: Lena image with noise level 0.004 Figure 9: Restored Lena image from noise level 0.004 Figure 10: Lena image with noise level 0.006 Figure 11: Restored image from noise level 0.006 Figure 12: Lena image with noise level 0.008 Figure 13: Restored Lena image from noise level 0.008 Figure 14: Lena image with noise level 0.01 Figure 15: Restored Lena image from noise level 0.01 Figure 16: Lena image with noise level 0.02 Figure 17: Restored Lena image from noise level 0.02 Figure 18: Lena image with noise level 0.04 Figure 19: Restored Lena image from noise level 0.04 Figure 20: Lena image with noise level 0.06 Figure 21: Restored Lena image from noise level 0.06 Figure 22: Lena image with noise level 0.08 Figure 23: Restored Lena image from noise level 0.08 Figure 24: Lena image with noise level 0.1 **Figure 25:** Restored Lena image from noise level 0.1 ## .6.3 Lena Images from different threshold levels Figure 26: Lena image with noise level 0.02 Figure 27: Restored Lena image from threshold level 1 Figure 28: Restored Lena image from threshold level 4 Figure 29: Restored Lena image from threshold level 8 Figure 30: Restored Lena image from threshold level 12 Figure 31: Restored image from threshold level 16 Figure 32: Restored Lena image from threshold level 20 Figure 33: Restored Lena image from threshold level 22 Figure 34: Restored Lena image from threshold level 26 Figure 35: Restored Lena image from threshold level 30 Figure 36: Restored Lena image from threshold level 34 Figure 37: Restored Lena image from threshold level 38 Figure 38: Restored Lena image from threshold level 42 Figure 39: Restored Lena image from threshold level 46 Figure 40: Restored Lena image from threshold level 50 ## .6.4 Field Images from different noise levels Figure 41: Field image with noise level 0.001 Figure 42: Restored Field image from noise level 0.001 Figure 43: Field image with noise level 0.002 Figure 44: Restored Field image from noise level 0.002 Figure 45: Field image with noise level 0.004 Figure 46: Restored Field image from noise level 0.004 Figure 47: Field image with noise level 0.006 Figure 48: Restored Field image from noise level 0.006 Figure 49: Field image with noise level 0.008 Figure 50: Restored Field image from noise level 0.008 Figure 51: Field image with noise level 0.01 $\textbf{Figure 52:} \ \ \text{Restored Field image from noise level } 0.01$ Figure 53: Field image with noise level 0.02 $\textbf{Figure 54:} \ \, \text{Restored Field image from noise level } 0.02 \\$ Figure 55: Field image with noise level 0.04 Figure 56: Restored Field image from noise level 0.04 Figure 57: Field image with noise level 0.06 $\textbf{Figure 58:} \ \ \text{Restored Field image from noise level } \ 0.06$ Figure 59: Field image with noise level 0.08 Figure 60: Restored Field image from noise level 0.08 Figure 61: Field image with noise level 0.1 Figure 62: Restored Field image from noise level 0.1 ## .6.5 Field Images from different threshold levels Figure 63: Field image with noise level 0.02 Figure 64: Restored Field image from threshold level 1 Figure 65: Restored Field image from threshold level 4 Figure 66: Restored Field image from threshold level 8 Figure 67: Restored Field image from threshold level 12 Figure 68: Restored Field image from threshold level 16 Figure 69: Restored Field image from threshold level 20 Figure 70: Restored Field image from threshold level 22 Figure 71: Restored Field image from threshold level 26 Figure 72: Restored Field image from threshold level 30 Figure 73: Restored Field image from threshold level 34 Figure 74: Restored Field image from threshold level 38 Figure 75: Restored Field image from threshold level 42 Figure 76: Restored Field image from threshold level 46 Figure 77: Restored Field image from threshold level 50 ## .6.6 Canyon Images from different noise levels Figure 78: Canyon image with noise level 0.001 Figure 79: Restored Canyon image from noise level 0.001 Figure 80: Canyon image with noise level 0.002 Figure 81: Restored Canyon image from noise level 0.002 Figure 82: Canyon image with noise level 0.004 Figure 83: Restored Canyon image from noise level 0.004 Figure 84: Canyon image with noise level 0.006 $\textbf{Figure 85:} \ \, \text{Restored Canyon image from noise level } 0.006 \\$ Figure 86: Canyon image with noise level 0.008 $\textbf{Figure 87:} \ \, \text{Restored Canyon image from noise level } 0.008 \\$ Figure 88: Canyon image with noise level 0.01 Figure 89: Restored Canyon image from noise level 0.01 Figure 90: Canyon image with noise level 0.02 Figure 91: Restored Canyon image from noise level 0.02 Figure 92: Canyon image with noise level 0.04 Figure 93: Restored Canyon image from noise level 0.04 Figure 94: Canyon image with noise level 0.06 **Figure 95:** Restored Field image from noise level 0.06 Figure 96: Canyon image with noise level 0.08 Figure 97: Restored Canyon image from noise level 0.08 Figure 98: Canyon image with noise level 0.1 Figure 99: Restored Canyon image from noise level 0.1 ## .6.7 Canyon Images from different threshold levels Figure 100: Canyon image with noise level 0.02 Figure 101: Restored Canyon image from threshold level 1 Figure 102: Restored Canyon image from threshold level 4 ${\bf Figure~103:~Restored~Canyon~image~from~threshold~level~8}$ Figure 104: Restored Canyon image from threshold level 12 $\textbf{Figure 105:} \ \, \text{Restored Canyon image from threshold level 16}$ Figure 106: Restored Canyon image from threshold level 20 ${\bf Figure~107:~Restored~Canyon~image~from~threshold~level~22}$ Figure 108: Restored Canyon image from threshold level 26 $\textbf{Figure 109:} \ \, \text{Restored Canyon image from threshold level 30} \\$ Figure 110: Restored Canyon image from threshold level 34 ${\bf Figure~111:~Restored~Canyon~image~from~threshold~level~38}$ Figure 112: Restored Canyon image from threshold level 42 $\textbf{Figure 113:} \ \, \text{Restored Canyon image from threshold level 46} \\$ Figure 114: Restored Canyon image from threshold level 50 ## .6.8 Image from software simulation Figure 115: Restored Lena image when using the software algorithm designed in the 2009 fall project Figure 116: Restored field image when using the software algorithm designed in the 2009 fall project Figure 117: Restored canyon image when using the software algorithm designed in the 2009 fall project