![C:\Documents and Settings\Admin\Мои документы\Бланки, логотипы, подписи\jinr-blue-small.png](data:image/png;base64,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)

JOINT INSTITUTE FOR NUCLEAR RESEARCH

Dzhelepov Laboratory of Nuclear Problems

**FINAL REPORT ON THE**

**START PROGRAMME**

*Intel FPGA training. Introduction in development of FPGA based readout systems for Timepix series detectors*

**Supervisor:**

Aleksandr Lapkin

**Student:**

Viktoria Makarova, Russia  
Kazan Federal University

**Participation period:**

October 02 – November 12,

Summer Session 2022

Dubna, 2022

**Abstract**

Currently, the Laboratory of Nuclear Problems is developing a multi-energy X-ray tomograph. It differs from the usual one in that it can separate substances by changing the absorption of X-ray radiation at different energies. Multi-energy X-ray tomograph requires a detector that can determine the energy and position of each absorbed photons (single photon counting). Detectors need readout systems, that connect to computer and detector, as well as software for controlling the detector. For these purposes, it is planned to use a new model of the Timepix4 detector of the Medipix family. Therefore, it is necessary to develop a readout system for Timepix4 based on FPGAs.

**Acknowledgments**

I want to thank my supervisor Alexander Lapkin for valuable advice and continuous mentoring throughout the practice. Special thanks to the organizing committee for the opportunity to participate in the program. It was a great chance to work on an interesting project and gain unique experience in solving engineering tasks under the guidance of specialists.

**Introduction**

Currently, computed tomography is one of the most common imaging and diagnostic methods. This method is based on the fact that materials have different X-ray transmittance in different energy of radiation. The X-ray beam passes through the tissue layer in different directions. Then the transmitted radiation is detected and the information received is converted into an image. Currently, the Laboratory of Nuclear Problems is developing a multi-energy X-ray tomograph. It differs from the usual one in that it can separate substances by changing the absorption of X-ray radiation at different energies. For these purposes, it is planned to use semiconductor hybrid pixel detectors Timepix 4 of the Medipix family as a detector. The very first Medipix chip was released in the 1990s [1]. The development of Timepix4 has been launched in 2016 [2]. The main feature of Timepix is that detectors based on it allow not only to detect the presence of certain sources of radiation, but also to determine the energy of the particles emitted by them. Timepix4 has a larger pixel matrix and can handle higher data rates than other Medipix family devices [3]. It also has a higher energy and spatial resolution. This allows obtaining X-ray images, which make it possible to determine the chemical composition of samples on tomograms, study the microstructure of tissues of living organisms and determine the proportions of various substances in them. To use such detectors, it is necessary to develop a readout system. FPGA is a high-performance device, so it can be used to transfer and process large amounts of data at high speed. Thus, FPGA is a good option for implementing a readout system. For these purposes, the Quartus project design and debugging environment can be used. Therefore, the main purpose of this work is to improve skills in working with the Quartus Prime18.1 software and the Development Kit and be prepared for the next work. To improve skills FPGAs working 5 tasks were completed.

**Task 1. Quartus basic functions.**

The first step was to install the Quartus Prime 19.1 software. For this software to work correctly, the USB-Blaster II driver must have been installed. The appearance of the Programmer window when the Development Kit is connected DE 1\_SoC without the driver installed is shown in Figure 1.1.

|  |
| --- |
|  |
| Figure 1.1 |

At the same time, an unknown device was detected in the Windows Device Manager.  To install the driver, it is needed to update this device and specify the full path to the folder where the driver is located (drivers\usb-blaster-ii\x64). Then the USB-Blaster II driver will be installed. Also, it is needed to have disabled driver signature verification using the boot parameters. Having performed these actions, the Programmer window looks like in Figure 1.2.

|  |
| --- |
|  |
| Figure 1.2 |

The next step was to create a project in Quartus Prime 19.1. It was necessary to set the parameters such as project name, file name, project type and also to find the FPGA model – Cyclone V SoC 5CSEMA5F31 in the user's guide.

Then a schematic file was created and PLL was placed in it. PLL – is an automatic control system used for converting the clock signal, as well as for phase adjustment. It was necessary to setup the PLL: the input frequency was set to 50 MHz, the desired output frequency was set to 16.777408 MHz. Then this diagram was placed in a free field of the diagram. After that, a source file (Verilog HDL File) was created and the code is shown in Figure 1.3 was written in it.

|  |
| --- |
|  |
| Figure 1.3 |

The first block of code specifies the input and output ports of this circuit. The output is 10 LEDs. The Reg type, which is used in this code file, is a data object that stores the value from one procedure assignment to the next and is used only in various functions and procedure blocks. The initial block is used to initialize variables, so it is used for setting input actions, i.e., initial values.

The procedure block described with always @(posedge Clock or posedge Reset) is triggered on the positive edge of the Clock or Reset signal. Therefore, at the rising edge of the clock signal, the next value will be written to the counter registers, which is equal the previous one plus one. This system works synchronously, but with asynchronous reset, i.e., not related to the clock frequency. To implement a synchronous reset scheme, it’s necessary to set always @(posedge Clock) in this block.

Then a schematic file was created. It contains the PLL element, 2 input ports, 1 output port, including 10 pins, a counter (described above), and an inverter (Not element). After that, all the blocks were connected to each other. The resulted scheme is shown in Figure 1.4.

|  |
| --- |
|  |
| Figure 1.4 |

The next step was to work with Pin Planner. It was needed to specify the pin designations used in this diagram. The pin designations can be found in the user's manual [4]. An example is shown in Figure 1.5.

|  |
| --- |
|  |
| Figure 1.5 |

The result after entering the required data in the Location column and assigning the value of I/O Standart 3.3 V was shown in Figure 1.6. It is also worth to mention that the Reset input was connected to the "0" button.

|  |
| --- |
|  |
| Figure 1.6 |

The next step was setting time constraints. It is necessary to describe the external clock signal in the created time constraints file. The clock period was set to 20 ns. The derive\_pll\_clock command was used to automatically generate clock cycles for each PLL output. The time constraints file is shown in Figure 1.7.

|  |
| --- |
|  |
| Figure 1.7 |

Then the project compiling can be started. After successfully completing this step, the Programmer window located on the toolbar is needed to open. It was necessary to select the Development Kit – DE1\_SoC and the compiled project file. The programming can be started by clicking Start button.

The result of this program is an alternating flashing of the LEDs corresponding to the addition of 1, starting from 0 to 1023. A demonstration how the algorithm works is shown in Figure 1.8.

|  |  |
| --- | --- |
|  |  |
| Figure 1.8 | |

Also, by changing the range of values in line 10 of the code shown in Figure 1.3, you can change the frequency of flashing LEDs. By changing this range to [30:21], the LED blinking frequency increased by ~ 8 times. The corrected version of the code is shown in Figure 1.9.

|  |
| --- |
|  |
| Figure 1.9 |

The next task was to transfer the reset function to the "3" button of the Development Kit. To do this, it is necessary to change the output for Reset in Pin Planner. The result of these actions is shown in Figure 1.10.

|  |
| --- |
|  |
| Figure 1.10 |

On the next stage, the project was modeled. The University Program VWF file was created for this purpose. In the field on the left, you need to add registers, inputs and outputs. After that, a clock signal of 50 MHz (20 ns) was applied to the Clock input using Overwrite Clock. Then high logic level was applied to the Reset input using the Forcing High button. In order to run the functional simulation correctly, it is necessary to correct the full path to the previously saved modeling1.vwf file, as well as to the modeling1.vwf.vt file. This file obtained as a result of running ModelSim TestBench and Script. The full path is needed to be corrected in all lines that appear on the screen in the Simulation Settings options. Figure 1.11 shows the fields where it is needed to replace the full path to the required file. In the first line, correct the current path for vector\_source\_source to the path through the output\_files folder\_files, and for testbench\_file to the path through the modelsim folder. It is necessary to add the full path to the modeling1.vwf.vt file in the highlighted line 3. Then copy the modeling1.vwf.vt file from the modelsim folder to the qsim folder.

|  |
| --- |
|  |
| Figure 1.11 |

After that, functional modeling was started, the results of which are shown in Figure 1.12.

|  |
| --- |
|  |
| Figure 1.12 |

The state of the LEDs does not change when the clock pulse arrives. This fact can be explained because of selecting the [33:24] range of value in the code shown in Figure 1.3. Thus, the LEDs are in the "0" state, because the counter [33: 24] is in the "0" state for the set End time = 1 ms (while the first 4 digits are in the Z state). To observe the change in LED states, the range of these values can be changed, for example, to [9:0]. The result of the modified code is shown in Figure 1.13. The End time also can be increasing so the entire counter range [33:24] will change its state to "0" or "1" (but there is a limit of 100 microseconds).

|  |
| --- |
|  |
| Figure 1.13 |

Then a time analysis of the project was performed, which resulted in the value Fmax=405.02 MHz. The maximum frequency value also changing by changing the range shown in Figure 1.3. By changing the range to [30:21], the Fmax becomes equal to 374.67 MHz.

The next step was to work with Chip Planner, which displayed the distribution of the clock signal from the PLL to the project implementation blocks using the Generate Fan-In Connection, Generate Fan-Out Connection and Expand Connection buttons. The resulting signal distribution result is shown in Figure 1.14.

|  |
| --- |
|  |
| Figure 1.14 |

If the previously added PLL output is set as Region Clock by Assigment Editor, the scheme will change, as well as the value of Fmax. Figure 1.15 shows the distribution of the clock signal from PLL to project implementation blocks after previously made changes. Fmax in this case is 334.78 MHz.

|  |
| --- |
|  |
| Figure 1.15 |

**Conclusion:** as a result of this project, the Quartus Prime 19.1 software was installed, the writing code skills in the Verilog language were obtained, as well as Quartus Prime 19.1, Pin Planner and ModelSim working skill. The result of this work is an alternating flashing of the LEDs corresponding to the addition of 1, starting from 0 to 1023, and also their flashing frequency can be changed.

**Task №2. Project with LEDs, buttons and switches.**

The first step was to create a project in Quartus Prime 19.1. It was necessary to set the parameters such as project name, file name, project type and also to find the FPGA model – Cyclone V SoC 5CSEMA5F31 in the user's guide.

Then the SystemVerilog HDL file was created. The code shown in Figure 2.1 was added to this file. The current file with the code was added to the project.

|  |
| --- |
|  |
| Figure 2.1 |

The next step was to create a top-level file in the hierarchy (Verilog HDL File). The code shown in Figure 2.2 was added to this file. This code demonstrates which LEDs will light up when any of the 4 buttons are pressed. Then the current file with the code was also added to the project.

|  |  |
| --- | --- |
|  |  |
| Figure 2.2 | |

The next step after successful Analysis and Synthesis was to work with Pin Planner. It was needed to specify the pin designations used in this diagram. The pin designations can be found in the user's manual. All the pins used in this diagram are shown in Figure 2.3. After entering the required data in the Location column, the I/O Standart column was set to 3.3 V, and the Current Strength column –was set to 16 mA.

|  |
| --- |
|  |
| Figure 2.3 |

The next step was setting time constraints. It is necessary to describe the external clock signal in the created time constraints file. The clock period was set to 20 ns. The derive\_pll\_clock command was used to automatically generate clock cycles for each PLL output. The time constraints file is shown in Figure 2.4. Then the current file was added to the project.

|  |
| --- |
|  |
| Figure 2.4 |

Then the project compilation can be started. After successfully completing this step, the Programmer window located on the toolbar is needed to open. It was necessary to select the Development Kit – DE1\_SoC and the compiled project file. The final view of the Programmer window is shown in Figure 2.5. The programming can be started by clicking Start button.

|  |
| --- |
|  |
| Figure 2.5 |

The result of this scheme is shown in Figures 2.6-2.9. The value "0101101001" was set by using the switches. The status of the LEDs in Figure 2.6 corresponds to the "3" button pressed. When the button is pressed, all 10 LEDs are turned on. This case will be discussed in more details later. The status of the LEDs in Figure 2.7 corresponds to the "2" button pressed. The glow of the LEDs depended on the state of the switch, i.e., LEDs with the switch in the "1" state were turned on. The status of the LEDs in Figure 2.8 corresponds to the "1" button pressed. This state is an inversion of the previous case, i.e., LEDs with the switch in the "0" state were turned on. The status of the LEDs in Figure 2.9 corresponds to the "0" button pressed. When the button is pressed, all 10 LEDs are turned off regardless of the switch position.

|  |
| --- |
|  |
| Figure 2.6 |
|  |
| Figure 2.7 |
|  |
| Figure 2.8 |
|  |
| Figure 2.9 |

When the "3" button is pressed, the brightness of the LEDs depends on the position of the switch. Figure 2.10 shows an example where all switches correspond to the "0" position, in this case the LEDs are turned off. As the position of the switches is changed to "1", the brightness of the LEDs increases. This fact is shown in Figures 2.11-2.13. At the same time, the leftmost switch provides the highest brightness of the LEDs, and the rightmost switch provides the lowest.

|  |
| --- |
|  |
| Figure 2.10 |
|  |
| Figure 2.11 |
|  |
| Figure 2.12 |
|  |
| Figure 2.13 |

Then it was necessary to work with RTL Viewer. This is a utility that allows to see the logical implementation of a project in graphical form. To run this utility, user need to select Netlist Viewers from the Tools menu and then choose RTL Viewer. The result of running RTL Viewer is shown in Figure 2.14.

|  |
| --- |
|  |
| Figure 2.14 |

The next step was to work with Chip Planner, which displayed the distribution of the clock signal from the PLL to the project implementation blocks using the Generate Fan-In Connection, Generate Fan-Out Connection and Expand Connection buttons. The resulting signal distribution result is shown in Figure 2.15. The result obtained by using the Expand Connection button, which allows to display all the components of the selected connection, is shown in Figure 2.16.

|  |
| --- |
|  |
| Figure 2.15 |
|  |
| Figure 2.16 |

Then the SignalTap Logic Analyser, located in the Tools tab was used. It is necessary to add a clock signal (located in the right panel of the window) and tracking signals (located in the left panel). Basic OR is needed to be select in the Trigger Conditions column, and Falling Edge – for led\_driver\_driver:led\_driver\_inst\_driver\_inst|Reset. After that, it is necessary to compile the project, program the FPGA and get the data once. The set switches position and the result of pressing the KEY2 button are shown in Figure 2.17. The results obtained during these actions are shown in Figure 2.18.

|  |
| --- |
|  |
| Figure 2.17 |
|  |
| Figure 2.18 |

**Conclusion:** as a result of this project, RTL Viewer and SignalTap Logic Analyser working skill were obtained. Also, Pin Planner and Chip Planner skills were improved. The result of this work is the LEDs flashing, which depends on which button is pressed.

**Task 3. Quartus debugging tools.**

The first step was to create a project in Quartus Prime 19.1. It was necessary to set the parameters such as project name, file name, project type and also to find the FPGA model – Cyclone V SoC 5CSEMA5F31 in the user's guide.

Then a schematic file was created and PLL was placed in it. PLL – is an automatic control system used for converting the clock signal, as well as for phase adjustment. It was necessary to setup the PLL: the input frequency was set to 50 MHz, the desired output frequency was set to 16.777408 MHz. Then this diagram was placed in a free field of the diagram. After that, a code file (Verilog HDL File) was created and the code is shown in Figure 3.1 was written in it.

|  |
| --- |
|  |
| Figure 3.1 |

The first block of code specifies the input and output ports of this circuit. The output is 10 LEDs. The Reg type, which is used in this code file, is a data object that stores the value from one procedure assignment to the next and is used only in various functions and procedure blocks. The initial block is used to initialize variables, so it is used for setting input actions, i.e. initial values.

The procedure block described with always @(posedge Clock or posedge Reset) is triggered on the positive edge of the Clock or Reset signal. Therefore, at the rising edge of the clock signal, the next value will be written to the counter registers, which is equal the previous one plus one. This system works synchronously, but with asynchronous reset, i.e. not related to the clock frequency. To implement a synchronous reset scheme, it’s necessary to set always @(posedge Clock) in this block.

Then a schematic file was created. It contains the PLL element, 2 input ports, 1 output port with 10 pins, a counter (described above), and an inverter (Not element) and an OR element with 2 inputs (OR2). After that Intel FPGA In-System Sources & Probes was added under the name sys\_probe. The Probe Port Width [0..512] parameter was set to 34. Then it is necessary to add the generated sys\_probe.qip file to the project, and also place this probe on the empty space of the circuit. All the blocks were connected to each other. Then all I/Os were renamed as Clock, Reset, Led[33..24]. The bus from the Led output of the cnt module to the Probe input of the sys\_probe module should be renamed as Led[33..0], as well as the bus leading to the Led pin[33..24] as Led[33..24]. The resulted scheme is shown in Figure 3.2.

|  |
| --- |
|  |
| Figure 3.2 |

The next step was to work with Pin Planner. It was needed to specify the pin designations used in this diagram. The pin designations can be found in the user's manual. An example is shown in Figure 3.3.

|  |
| --- |
|  |
| Figure 3.3 |

The result after entering the required data in the Location column and assigning the value of I/O Standart 3.3 V was shown in Figure 3.4. It is also worth to mention that the Reset input was connected to the "0" button.

|  |
| --- |
|  |
| Figure 3.4 |

The next step was setting time constraints. It is necessary to describe the external clock signal in the created time constraints file. The clock period was set to 20 ns. The derive\_pll\_clock command was used to automatically generate clock cycles for each PLL output. The time constraints file is shown in Figure 3.5.

|  |
| --- |
|  |
| Figure 3.5 |

Then the project compilation can be started. After successfully completing this step, the Programmer window located on the toolbar is needed to open. It was necessary to select the Development Kit – DE1\_SoC and the compiled project file. The programming can be started by clicking Start button.

The result of this program is an alternating flashing of the LEDs corresponding to the addition of 1, starting from 0 to 1023. An example of how the algorithm works is shown in Figure 3.6.

|  |  |
| --- | --- |
|  |  |
| Figure 3.6 | |

The next step was to work with System Probe. It was necessary to run the In-System Sources and Probes Editor located in the Tools tab, then select the previously programmed FPGA (Hardware: DE\_SoC [USB X], Device: @2:5CSE(BA5|MA5)...). The probe polling is needed to be enable by using the Continuously Read Probe Data. The result of these actions is shown in Figure 3.7. Signals with probe[33..24] represent an addition of 1 in binary code, the remaining signals are noise.

|  |
| --- |
|  |
| Figure 3.7 |

In-System Sources and Probes Editor extends the set of verification tools and provides a dynamic debugging environment, as well as allows to control the internal signal. This way, data from all sources and samples in the project can be viewed. Continuously Read Probe Data allows to continuously sample data from the probe. The In-System Sources and Probes Editor allows to store up to 128k samples. This parameter is set in the Maximum Size line (in this project, it was chosen to be 2k).

The next step was to turn off the source probe, i.e. in the Data tab it was set to "0". After that, the probe polling was started again. The result is shown in Figure 3.8. The probe[33..0], which are project outputs, have a value of "0" while Source value is also "0". So, the Source is used to control the input data.

|  |
| --- |
|  |
| Figure 3.8 |

Unfortunately, the In-System Sources and Probes Editor debugging tool has a drawback – a non-constant frequency of polling that cannot be adjusted by the user. This disadvantage is demonstrated in Figure 3.9. It’s clearly shows how much the frequency changes on probe[33..0] in the absence of any changes in the program code and settings.

|  |
| --- |
|  |
| Figure 3.9 |

The next step was to use the SignalTap Logic Analyser located in the Tools tab. It is necessary to add a clock signal (in the Clock field in the right panel of the window) and tracking signals (cnt:inst2|Reset and cnt:inst2|counter[33..0] located in the left panel). Basic OR is needed to be select in the Trigger Conditions column, and Falling Edge – for cnt:inst2|Reset. After that, it is necessary to compile the project, program the FPGA and read the data once. The results obtained during these actions are shown in Figure 3.10.

|  |
| --- |
|  |
| Figure 3.10 |

The SignalTap logic Analyzer is a debugging tool that displays signal behavior in real time, allowing to observe the interaction between hardware and software in projects [5]. This software allows to choose which signals to capture, when signal capture starts, and how many data samples to capture.

The next step was to configure SignalTap, so that data collection occurs after the counter reaches the value 0X1234567. To do this, in the Trigger Conditions column for cnt:inst2|counter[33..0] is needed to be set the "0X1234567" value, and in the line cnt:inst2 /Reset – "Don’'t care". Also the value for Trigger Conditions must be replaced with Basic AND. The view of the Setup window in SignalTap with the changes is shown in Figure 3.11. The result of these operations is shown in Figure 3.12. This figure shows that the beginning of the reference, i.e. zero value on the scale, which located at the top, corresponds to the state of the LEDs "1001000110100010101100111" (which is the number "1234567" in the hexadecimal numeral system).

|  |
| --- |
|  |
| Figure 3.11 |
|  |
| Figure 3.12 |

**Conclusion:** As a result of this project, debugging tools In-System Sources and Probes Editor and SignalTap Logic Analyser working skills were improved. In-System Sources and Probes Editor is a simple tool for setting and managing internal signals. Unfortunately, this debugging tool is not suitable for monitoring high frequency signals. SignalTap Logic Analyzer records FPGA logic signals with the frequency of the selected clock signal and gives user the ability to monitor the signals in real time. Also, worth to mention that SignalTap Logic Analyzer consumes FPGA resources. These debugging tools help clearly demonstrate how the code works.

**Task №4. SDRAM module testing.**

The first stage was the creation of a project, which includes specifying the project name, the model of the FPGA used, etc. Then it was necessary to launch Platform Designer, located in the Tools tab. The Platform Designer window view is shown in Figure 4.1.

|  |
| --- |
|  |
| Figure 4.1 |

Then it was necessary to place the SDRAM Controller, located in the Memory Interfaces and Controllers → SDRAM → SDRAM Controller Intel FPGA IP tab, the PLL (Basic Function → Clock, PLL and Resets → PLL Intel FPGA IP) and the JTAG – Avalon bridge (Basic Functions → Bridges and Adapters → Memory Mapped → JTAG to Avalon Master Bridge). You also need to configure all the elements described above. The first step was to set the requirement parameters, which are shown in Figure 4.2, in the Memory Profile and Timing tabs for the SDRAM Controller.

|  |
| --- |
|  |
| Figure 4.2 |

Then the PLL was configured, the parameters of which are shown in Figure 4.3. The reference clock frequency was set to 50 MHz, and the number of Clock generators was set to 2: outclk0 and outclk1.

|  |
| --- |
|  |
| Figure 4.3 |

After that, by double-clicking in the Export window the necessary elements were exported – wire (named sdram), outclk1 (named sdram\_clock) and locked (named locked). The appearance of the Platform Designer window after making the changes described earlier is shown in Figure 4.4.

|  |
| --- |
|  |
| Figure 4.4 |

Then the code was generated using Generate HDL. After that, the sdram.qip file was added to the project from its folder by using the Add/Remove Files. The next step was to write the code in the previously created DE1\_SoC\_sdram.v file. The Verilog HDL File with the code is shown in Figure 4.5.

|  |
| --- |
|  |
| Figure 4.5 |

At first, input, output and inout (bidirectional) ports were set. Then the single-bit reset and locked circuits were announced. Then the example shown in Figure 4.6 was copied in the Instantiation Templates tab of the Platform Designer window for later declaring SDRAM module instances.

|  |
| --- |
|  |
| Figure 4.6 |

After that, you can proceed to creating the time constraints file, which is shown in Figure 4.7.

|  |
| --- |
|  |
| Figure 4.7 |

Clock frequencies are described using the create\_clock command. In this case, a generator with a frequency of 100 MHz is used, the source of which is the DRAM\_CLK port. A second clock frequency with a period of 20 ns was also set. To use the get\_ports function, when you select Insert Constraint, you must use the Create Timing Netlist tab after running the Timing Analyzer. Then you need to set input and output delays of 3 ns in the Synopsys Design Constraint File File(.sdc) using the set\_input\_delay and set\_output\_delay commands. The next step was to set the maximum and minimum time for input and output delays for clk\_dram, the source of which is the previously announced output and bidirectional ports. These data were obtained from the Development Kit descriptions and manuals.

After successful Analysis and Synthesis, you can start working with Pin Planner. In the user's manual, you need to specify the pin designations used in this diagram. All the pins used in this diagram are shown in Figures 4.8, 4.9 and 4.10.

|  |
| --- |
|  |
| Figure 4.8 |
|  |
| Figure 4.9 |
|  |
| Figure 4.10 |

After entering the required data in the Location column, the I/O Standart column was set to 3.3 V, and the Current Strength column –was set to 16 mA. The final view of the Pin Planner window after making all the changes is shown in Figure 4.11.

|  |
| --- |
|  |
| Figure 4.11 |

The next step was to create a Tcl Script file containing the code shown in Figure 4.12. This code is used for memory testing. Lines 4 and 5 contain the initial values of the first elements of the Fibonacci sequence. Using the while loop, we described filling of rows, in which each next number is equal to the sum of the previous two. These steps are repeated until the number exceeds 0xffffffff value (i.e., 4294967295 in decimal).

|  |
| --- |
|  |
| Figure 4.12 |

After that, you can start compiling the project. After successfully completing this step, you need to open the Programmer window located on the toolbar. You need to select the programmable board – DE1\_SoC and the compiled project file. The final view of the Programmer window is shown in Figure 4.13. After that, you can click Start button to start programming.

|  |
| --- |
|  |
| Figure 4.13 |

After finishing programming, the system console was launched (Tools → System Debugging Tools → System Console). The string "source DE1\_SoC\_sdram\_test.tcl" was inserted in the Tcl Console window. Figure 4.14 shows the result that appears on the screen after running the test.

|  |
| --- |
|  |
| Figure 4.14 |

It is also worth to mention the problems that occurred while working with the Tcl Console. The first result of the program launching was the "test is unsuccessful" message on the display, which indicates problems with memory. After that, to test the internal memory, the On Chip Memory Intel FPGA IP element (Basic Function → On Chip Memory) was added to the project in Platform Designer. The scheme of its connection is shown in Figure 4.15. Also in this figure, you can see that the start and end address values for On Chip Memory were accordingly changed to 0x04000000 and 0x04000fff in the Address Map tab.

|  |
| --- |
|  |
| Figure 4.15 |

After compiling and running the project with the changes made on the Development Kit, the lines shown in Figure 4.16 were entered in System Console. Thus, it was concluded that the internal memory of this board works without errors, since it was possible to write a number into it and then read it. But at the same time, when writing the number "2" to the address 0x0, the external memory reads it as the value 0xffffffff, which corresponds to the number "-1" in the additional code.

|  |
| --- |
|  |
| Figure 4.16 |

**Conclusions:** as a result of this project, the skills of working with Platform Designer and System Console were obtained. The SDRAM module was tested by using the code, which represents the Fibonacci sequence. Also, the operability of internal and external memory was checked.

**Task №5. Nios II module testing.**

The first stage was the creation of a project, which includes specifying the project name, the model of the FPGA used, etc. Then it was necessary to launch Platform Designer, located in the Tools tab. The Platform Designer window view is shown in Figure 5.1.

|  |
| --- |
|  |
| Figure 5.1 |

Then it was necessary to place elements such as the Nios II processor, located in the Processors and Peripherals tab, memory (Basic Function → On Chip Memory → On Chip Memory (RAM or ROM) Intel FPGA IP), System ID (Basic Functions → Simulation; Debug and Verification → Debug and Performance → System ID Peripheral Intel FPGA IP) and UART via JTAG. Also 2 parallel I/O – PIOs (Processors and Peripherals → Peripherals → PIO) should be placed. These PIOs should be renamed as switch, and the other as led, and then export external\_connection for them with the appropriate names. Then all the elements described above are need to be configured. The first step was to set the necessary parameters for Nios II, which are shown in Figure 5.2. But it is worth noting that Nios II was configured after the elements were connected, since it is impossible to specify memory vectors otherwise [6].

|  |
| --- |
|  |
| Figure 5.2 |

For On Chip Memory the Total memory size parameter was set to 204800 bytes. Then the switch and led PIOs were configured: the Width parameter was set to 10, the Direction parameter value for switch – Input, and for led – Output. For the System ID, the value was set equal to 0x00c00000.

The appearance of the Platform Designer window is shown in Figure 5.3. It is also worth to mention that the Assign Base Addresses function was used to set the start and end address values for all elements.

|  |
| --- |
|  |
| Figure 5.3 |

Then the code was generated by using Generate HDL. After that the DE 1\_SoC\_nios.qip file was added to the project by using the Add/Remove Files option. The next step was to write the code in the previously created DE1\_SoC\_nios\_tr.v file. The Verilog HDL File with the code is shown in Figure 5.4.

|  |
| --- |
|  |
| Figure 5.4 |

The next step after successful Analysis and Synthesis was to work with Pin Planner. It was needed to specify the pin designations used in this diagram. The pin designations can be found in the user's manual. All the pins used in this diagram are shown in Figures 5.5.

|  |
| --- |
|  |
| Figure 5.5 |

It is necessary to install the Eclipse development environment to continue working with the project. The file containing Eclipse must be unzipped to the Quartus program folder ".../nios2eds/bin". Then rename the resulted folder to "eclipse\_nios2". Also, for correct operation, Eclipse requires the installation of Windows System for Linux and Ubuntu 18. Then the following command "wsl-set-default-version 1","sudo apt install wsl","sudo apt install dos2unix","sudo apt install make" should be entered on the command line. The Perspective value must be switched to Nios II when the Nios II Software Build Tool for Eclipse is running.

Then it is necessary to run the Eclipse program from the Nios II Command Shell.bat command line. The next step was to create a project (Nios II Application and BSP from Template), and select Hello World as the template. The program window with all the settings is shown in Figure 5.6.

|  |
| --- |
|  |
| Figure 5.6 |

Then the code is shown in Figure 5.7 must be added to a hello\_world.c file in the tab DE1\_SoC\_nios2\_tr\_software.

|  |
| --- |
|  |
| Figure 5.7 |

Then all Makefile in the DE1\_SoC\_nios2\_tr\_software and DE1\_SoC\_nios2\_tr\_software\_bsp folders must be deleted in the Project. The folder with created BSP must be open in the Eclipse Nios II Command Shell.bat. The next stage is running the "dos2unix create-this-bsp" and ". /create-this-bsp --cpu-name nios2\_gen2\_0 --no-make" command. Then similar actions should be performed with the folder of created application DE1\_SoC\_nios2\_tr\_software by using the commands "dos2unix create-this-app" and ". /create-this-app --cpu-name nios2\_gen2\_0 --no-make". The "dos2unix" command implement instantly converting to Unix encoding. The command line containing all the commands described earlier is shown in Figure 5.8.

|  |
| --- |
|  |
| Figure 5.8 |

The next step was to use the BSP Editor. Its settings are shown in Figure 5.9. The «enable\_lightweight\_device\_driver\_api» setting must be disabled. This option allows to reduce the amount of code and data.

|  |
| --- |
|  |
| Figure 5.9 |

After that, you need to open the Makefile created earlier in Eclipse, in which you need to replace 329 and 135 lines: APP\_LDFLAGS += -msys-lib=$(call adjust-path-mixed,$(SYS\_LIB)) with APP\_LDFLAGS += -msys-lib=hal\_bsp, and BUILD\_PRE\_PROCESS := on BUILD\_PRE\_PROCESS := touch $(ELF). srec, respectively. Without these corrections the project building and the elf file generation were unsuccessful. The changes made with the Makefile are shown in Figures 5.10 and 5.11.

|  |
| --- |
|  |
| Figure 5.10 |
|  |
| Figure 5.11 |

Use the context menu to build the BSP and application by using the Build Project command.

Then the project compiling can be started. After successfully completing this step, the Programmer window located on the toolbar is needed to open. It was necessary to select the Development Kit – DE1\_SoC and the compiled project file. The final view of the Programmer window is shown in Figure 5.12. The programming can be started by clicking Start button.

|  |
| --- |
|  |
| Figure 5.12 |

Then it is necessary to run the application in the Eclipse program. The Target Connection tab appears after selecting Run as Nios II Hardware for DE1\_SoC\_nios2\_tr\_software. So it is needed to click Refresh Connections, and then 2 data-filled lines shown in Figure 5.13 will appear.

|  |
| --- |
|  |
| Figure 5.13 |

Then by using the System ID Properties button, user need to check the values of Expected System ID and Connected System ID – they must match. These values are shown in Figure 5.14. Then the application can be started by using the Run button.

|  |
| --- |
|  |
| Figure 5.14 |

The following switch position was set on Development Kit (shown in Figure 5.15), which is equal to the number 0101001011 in binary numeral system.

|  |
| --- |
|  |
| Figure 5.15 |

The result of the program was the illumination of those LEDs for which the switch was in the logical unit position, as well as the Nios II Console screen message shown in Figure 5.16. The number that appears on the screen corresponds to the number set using the switches, but in decimal number system.

|  |
| --- |
|  |
| Figure 5.16 |

In order to increase the processor response time by 2 times, the number of repetitions in the loop for the variable j can be increased by 2 times. This result is shown in Figure 5.17. In practice, it was tested successful, that the processor response time increased by 2 times – from 1 to 2 minutes.

|  |
| --- |
|  |
| Figure 5.17 |

**Conclusions:** as a result of this project, the skills of working with Eclipse development environment were obtained. The Nios II module was tested by using the code. The result of the program was the illumination of those LEDs for which the switch was in the logical unit position.

**References**

1. Medipix\_CERN [http://www.jinr.ru/wp-content/uploads/2016/03/ Medipix\_CERN.pdf](http://www.jinr.ru/wp-content/uploads/2016/03/%20Medipix_CERN.pdf)
2. Ballabriga R., Campbell M., Llopart X. An introduction to the Medipix family ASICs // Radiation Measurements. – 2020. – Т. 136. – С. 106271.
3. Llopart X. et al. Timepix4, a large area pixel detector readout chip which can be tiled on 4 sides providing sub-200 ps timestamp binning // Journal of Instrumentation. – 2022. – Т. 17. – №. 01. – С. C01044.
4. DE1\_SoC User manual <http://download.terasic.com/downloads/cd-rom/de1-soc/DE1-SoC_v.5.1.3_HWrevF.revG_SystemCD.zip>
5. Quartus II Handbook, V.3 [https://hamblen.ece.gatech.edu/ UP3/quartusii\_handbook.pdf](https://hamblen.ece.gatech.edu/%20UP3/quartusii_handbook.pdf)
6. Основы разработки встраиваемых систем на ПЛИС с использованием процессора NIOS® II : учеб. пособие / Д.С. Смирнов, И.Г. Дейнека, А.С. Алейник, И.А. Шарков.. – СПб: Университет ИТМО, 2019. – 95 с.