Compare commits
	
		
			No commits in common. "4d32b1bd93c8847f004deddacec08a4d62fd6d51" and "0a857f4c23294a09628cafefdc994b058bfd51e3" have entirely different histories.
		
	
	
		
			4d32b1bd93
			...
			0a857f4c23
		
	
		|  | @ -28,7 +28,7 @@ PuzzleFW has the following features: | ||||||
| Further details about the firmware are in these documents: | Further details about the firmware are in these documents: | ||||||
| 
 | 
 | ||||||
| - [User manual](doc/user_manual.md) | - [User manual](doc/user_manual.md) | ||||||
| - [Developer manual](doc/devel_manual.md), including build procedure | - Developer manual, including the build procedure, to be written | ||||||
| - [FPGA firmware description](doc/fpga_firmware.md) | - [FPGA firmware description](doc/fpga_firmware.md) | ||||||
| 
 | 
 | ||||||
| ## Supported boards | ## Supported boards | ||||||
|  |  | ||||||
|  | @ -1,479 +0,0 @@ | ||||||
| --- |  | ||||||
| gitea: none |  | ||||||
| include_toc: true |  | ||||||
| --- |  | ||||||
| 
 |  | ||||||
| # Development manual |  | ||||||
| 
 |  | ||||||
| This document gives an overview of the internal structure of the PuzzleFW firmware package. |  | ||||||
| It also describes the process to build the FPGA firmware and the embedded software. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ## FPGA design overview |  | ||||||
| 
 |  | ||||||
| The FPGA captures ADC samples and digital input signals. |  | ||||||
| ADC samples go into the analog acquisition chain. |  | ||||||
| The acquisition chain handles triggering and optional downsampling. |  | ||||||
| A configurable number of samples are collected following each trigger event. |  | ||||||
| Trigger events and collected samples are transferred to a buffer in DDR memory via the AXI slave interface of the Zynq processing system. |  | ||||||
| 
 |  | ||||||
| Digital signals go into a timetagger subsystem. |  | ||||||
| The timetagger detects edges on selected signals and assigns timestamps to such events. |  | ||||||
| Timestamped events are transferred to a buffer in DDR memory via the AXI slave interface. |  | ||||||
| 
 |  | ||||||
| All synchronous elements are clocked at 125 MHz, derived from the ADC sample clock. |  | ||||||
| 
 |  | ||||||
|  |  | ||||||
| 
 |  | ||||||
| ### Block design |  | ||||||
| 
 |  | ||||||
| A Vivado block design contains the Zynq processing system (ARM), AXI interconnect, and AXI-to-APB bridge. |  | ||||||
| This block design is instantiated in the top-level VHDL file. |  | ||||||
| 
 |  | ||||||
|  |  | ||||||
| 
 |  | ||||||
| ### PS-to-PL interfaces |  | ||||||
| 
 |  | ||||||
| The following interfaces are used between the PS (ARM) and PL (FPGA): |  | ||||||
| 
 |  | ||||||
| - M\_AXI\_GP0 <br> |  | ||||||
|   Used by embedded software to read and write registers in the FPGA via AXI and APB bus. |  | ||||||
|   This interface is mapped to addresses 0x43000000 to 0x431fffff in the PS address map. |  | ||||||
| - S\_AXI\_HP0 <br> |  | ||||||
|   Used by FPGA firmware to read and write DDR memory. |  | ||||||
| - GPIO <br> |  | ||||||
|   The PS controls a few specific digital signals in the FPGA via GPIO lines. |  | ||||||
|   One of these lines is a global reset signal for the FPGA firmware. |  | ||||||
| - SPI0 <br> |  | ||||||
|   Routed via EMIO through the FPGA to the SPI bus of the ADCs (only on 4-input boards). |  | ||||||
| - IRQ\_F2P <br> |  | ||||||
|   Used by FPGA firmware to trigger interrupts in the PS. |  | ||||||
| - FCLK\_CLK0 <br> |  | ||||||
|   Fixed 200 MHz clock generated by the PS. |  | ||||||
|   On 4-input boards, the FPGA uses this clock as reference for IODELAY primitives. |  | ||||||
|   On 2-input boards, this clock is not used. |  | ||||||
| 
 |  | ||||||
| ### ADC input timing |  | ||||||
| 
 |  | ||||||
| The ADC transfers samples via a parallel source-synchronous interface. |  | ||||||
| The interface is synchronous to a 125 MHz clock output signal from the ADC. |  | ||||||
| This is also the main clock source of the FPGA design. |  | ||||||
| 
 |  | ||||||
| On 2-input Red Pitaya boards, the ADC is hardwired to operate in _full rate CMOS mode_. |  | ||||||
| Each analog channel has 14 parallel data signals from ADC to FPGA. |  | ||||||
| These data signals transition on the falling clock edge and are captured by the FPGA on the rising clock edge. |  | ||||||
| Data signals are captured in the FPGA in IOB flip-flops. |  | ||||||
| These flip-flops are clocked on a 125 MHz clock, derived by a PLL from the ADC output clock. |  | ||||||
| It turns out that a phase shift of 90 degrees in the PLL provides near-optimal timing for capturing the data signals. |  | ||||||
| This follows from synthesizer timing reports and has been confirmed experimentally by testing different PLL phase shift settings. |  | ||||||
| 
 |  | ||||||
| On 4-input Red Pitaya boards, only 7 parallel data signals per analog channel are connected from the ADCs to the FPGA. |  | ||||||
| The ADCs must be programmed (via SPI) to operate in _double data rate CMOS mode_. |  | ||||||
| In this mode, the data lines transition on both edges of the 125 MHz clock. |  | ||||||
| The data signals are routed through IDELAY components in the FPGA before being captured in IDDR registers. |  | ||||||
| The IDDR are clocked on the 125 MHz clock from the ADC that produces the samples (without PLL). |  | ||||||
| The IDELAY components use a fixed delay, tuned to 2.34 ns to optimize data capture timing. |  | ||||||
| Timing reports indicate that this provides sufficient margin. |  | ||||||
| This has been confirmed experimentally by testing different phase-shift settings of the ADC output clock. |  | ||||||
| The main FPGA design runs on a 125 MHz clock, derived by a PLL from the ADC that samples channels 1 and 2. |  | ||||||
| Transferring samples from channels 3 and 4 to the main clock is slightly tricky because the two ADC clocks may be skewed with respect to each other. |  | ||||||
| A few mysterious timing constraints were added to deal with this. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ## Embedded software overview |  | ||||||
| 
 |  | ||||||
| The purpose of the embedded software is to make the system remotely accessible via the network. |  | ||||||
| The software collects data from the FPGA and transmits it via TCP. |  | ||||||
| Similarly, the software accepts remote control commands via TCP and executes these by accessing registers in the FPGA. |  | ||||||
| 
 |  | ||||||
| ### Operating system |  | ||||||
| 
 |  | ||||||
| The embedded software runs within an embedded Linux system on the Red Pitaya. |  | ||||||
| 
 |  | ||||||
| The core operating system is based on [Buildroot](https://buildroot.org/), a framework that builds an embedded Linux system from scratch. |  | ||||||
| Buildroot automatically downloads and builds many additional open source packages that are needed to construct the embedded system. |  | ||||||
| Among these packages is a cross-compilation toolchain. |  | ||||||
| 
 |  | ||||||
| The kernel for the embedded system is built from the [Xilinx distribution of the Linux kernel](https://github.com/Xilinx/linux-xlnx). |  | ||||||
| It is necessary to use the Xilinx variant of Linux. |  | ||||||
| The vanilla Linux kernel can run on the Red Pitaya, but the Xilinx kernel provides important features that are missing from the vanilla kernel, such as programming the FPGA. |  | ||||||
| 
 |  | ||||||
| The shell and system utilities of the embedded system are based on Busybox. |  | ||||||
| Dropbear is installed as SSH server, but disabled by default. |  | ||||||
| 
 |  | ||||||
| The set of packages to be installed in the embedded system, along with their compile-time settings, are specified in the Buildroot configuration. |  | ||||||
| Further tweaking of the embedded system is done via a _filesystem overlay_: a set of files that are injected into the embedded root filesystem as a final step. |  | ||||||
| The overlay mechanism is used to install boot scripts and configuration files. |  | ||||||
| It is also used to install custom user space software. |  | ||||||
| 
 |  | ||||||
| ### Boot flow |  | ||||||
| 
 |  | ||||||
| [U-Boot](https://source.denx.de/u-boot/u-boot) is used as boot loader and as _secondary program loader_ (SPL). |  | ||||||
| Building U-Boot requires a proper device tree for the board. |  | ||||||
| 
 |  | ||||||
| Building the U-Boot SPL image also requires the file `ps7_init_gpl.c`. |  | ||||||
| The contents of this file depend on the configuration of the Zynq programming system which is specified in the Vivado block design. |  | ||||||
| To generate this file, the FPGA design must be _exported_ from Vivado in the form of an XSA file. |  | ||||||
| The XSA file is actually a ZIP archive which contains `ps7_init_gpl.c` and the corresponding header file. |  | ||||||
| The U-Boot build script (`12_build_uboot.sh`) copies these files to the correct location in the U-Boot source tree. |  | ||||||
| 
 |  | ||||||
| The boot process of the Red Pitaya is as follows: |  | ||||||
| 
 |  | ||||||
| - The Zynq PS boots from ROM. |  | ||||||
|   The ROM program reads `boot.bin` from the SD card and runs it. |  | ||||||
| 
 |  | ||||||
| - `boot.bin` is the U-Boot SPL image. |  | ||||||
|   It initializes many subsystems in the Zynq PS, including the DDR memory controller. |  | ||||||
|   It then reads `u-boot.img` from the SD card and runs it. |  | ||||||
| 
 |  | ||||||
|   Note that we don't use a Xilinx FSBL at all. |  | ||||||
|   Many Zynq tutorials explain how to build `boot.bin` using Xilinx tools. |  | ||||||
|   That requires a non-free FSBL image which must be built in a Vitis project. |  | ||||||
|   The PuzzleFW package avoids that whole mess by using U-Boot SPL instead. |  | ||||||
| 
 |  | ||||||
| - `u-boot.img` is the main U-Boot program image. |  | ||||||
|   It reads and executes `boot.scr`, a script which describes the Linux boot process. |  | ||||||
|   The script instructs U-Boot to read the Linux kernel `uImage`, |  | ||||||
|   the device tree `devicetree.dtb` and the root filesystem image `rootfs.cpio.uboot` |  | ||||||
|   from the SD card. |  | ||||||
|   It then runs the Linux kernel. |  | ||||||
| 
 |  | ||||||
| - `uImage` is the Linux kernel image. |  | ||||||
|   The kernel initializes drivers and subsystems. |  | ||||||
|   The root filesystem is unpacked and mounted as a RAM filesystem. |  | ||||||
|   The filesystem is writeable, but any changes remain in RAM and will be forgotten on the next reboot. |  | ||||||
| 
 |  | ||||||
| - A set of boot scripts are invoked to initialize the embedded system and start services. |  | ||||||
|   Most of these scripts are prepared by Buildroot, but some scripts have been tweaked or specially created for PuzzleFW. |  | ||||||
|   These scripts take care of the following: |  | ||||||
|     - Read the MAC address from the EEPROM on the Red Pitaya board, and assign it to the Ethernet interface. |  | ||||||
|     - Set a unique hostname `rp-XXXXXX` based on the MAC address. |  | ||||||
|     - Obtain an IPv4 address via DHCP or a preconfigured static address. |  | ||||||
|       This is controlled by a file in the configuration partition of the SD card. |  | ||||||
|     - Start an SSH server, if enabled. By default, this is disabled. |  | ||||||
|     - Read a BIT file from the SD card and program the FPGA. |  | ||||||
|       Information in the EEPROM is used to determine which FPGA image must be used. |  | ||||||
|     - Configure ADCs on the Red Pitaya board via SPI or GPIO. |  | ||||||
|     - Load the Linux kernel driver to access the FPGA firmware. |  | ||||||
|     - Run a user space program that accepts remote control commands via TCP. |  | ||||||
| 
 |  | ||||||
| ### Linux kernel driver |  | ||||||
| 
 |  | ||||||
| A custom Linux kernel module is used to access the FPGA firmware. |  | ||||||
| This module is called `puzzlefw.ko`. |  | ||||||
| 
 |  | ||||||
| The driver is based on the Linux UIO framework. |  | ||||||
| The kernel module itself has minimal functionality. |  | ||||||
| Its only functions are: |  | ||||||
| 
 |  | ||||||
|  - mapping the register address range of the FPGA to user space via mmap |  | ||||||
|  - mapping the DMA buffer to user space via mmap |  | ||||||
|  - handling FPGA interrupts and notifying user space via UIO |  | ||||||
| 
 |  | ||||||
| All non-trivial interactions with the FPGA are done in user space. |  | ||||||
| This includes managing the DMA data flow. |  | ||||||
| 
 |  | ||||||
| ### User space software |  | ||||||
| 
 |  | ||||||
| The FPGA firmware is controlled by a user space program. |  | ||||||
| This program accepts remote control commands via TCP. |  | ||||||
| Commands are handled by reading and writing registers in the FPGA. |  | ||||||
| The program also collects data from the FPGA via DMA, and transmits these data through the network via TCP. |  | ||||||
| 
 |  | ||||||
| The program is written in C++. |  | ||||||
| It uses Boost Asio, an asynchronous I/O framework. |  | ||||||
| 
 |  | ||||||
| ### Configuration partition |  | ||||||
| 
 |  | ||||||
| While the embedded software runs, the root filesystem is located in RAM. |  | ||||||
| The filesystem is writable, but any changes will be lost on the next boot. |  | ||||||
| 
 |  | ||||||
| In order to store persistent settings, the SD card has a separate configuration partition. |  | ||||||
| This is `/dev/mmcblk0p2`, formatted as Ext4. |  | ||||||
| The following files are stored there: |  | ||||||
| 
 |  | ||||||
| - `network.conf`: IP address configuraton (DHCP or static IP address) |  | ||||||
| - `calibration.conf`: analog calibration coefficients |  | ||||||
| - `start_ssh.conf`: enables or disables starting the SSH server |  | ||||||
| - SSH host key |  | ||||||
| 
 |  | ||||||
| The configuration partition is temporarily mounted read-only during boot, to read the configuration files. |  | ||||||
| Otherwise, the partition is only accessed when the configuration is modified. |  | ||||||
| In such cases, the partition is temporarily mounted to write the updated files, then unmounted again. |  | ||||||
| As a result, writes to the SD card occur only when the user changes the persistent configuration of the system. |  | ||||||
| This avoids unnecessary wear of the SD card. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ## Build procedure |  | ||||||
| 
 |  | ||||||
| A Linux PC (x86-64) is required to build the system. |  | ||||||
| Development was done with Debian 12 (bookworm). |  | ||||||
| Other Linux distributions will probably also work. |  | ||||||
| 
 |  | ||||||
| The build process consists of two main steps. |  | ||||||
| These steps must be done in the following order: |  | ||||||
| 
 |  | ||||||
|  1. Build the FPGA firmware for the Zynq PL. |  | ||||||
|  2. Build the embedded software for the Zynq PS. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ## Building FPGA firmware |  | ||||||
| 
 |  | ||||||
| Building the FPGA firmware requires Vivado release 2020.2. |  | ||||||
| Later releases will probably work, but may require adjustments. |  | ||||||
| 
 |  | ||||||
| There are two ways to build the firmware: as a Vivado project, or in Vivado non-project mode. |  | ||||||
| In most cases, non-project mode will be easier. |  | ||||||
| 
 |  | ||||||
| ### Preparing the build environment |  | ||||||
| 
 |  | ||||||
| **Install Vivado** <br> |  | ||||||
| Download and install Vivado 2020.2. |  | ||||||
| The build scripts assume that Vivado is installed in `/opt/Xilinx/Vivado/2020.2`. |  | ||||||
| If a different location is used, it must be configured in the script environment file. |  | ||||||
| 
 |  | ||||||
| **Configure paths** <br> |  | ||||||
| If necessary, edit the file `redpitaya-puzzlefw/fpga/script_env` and make sure that `VIVADO_DIR` points to the directory where Vivado is installed. |  | ||||||
| 
 |  | ||||||
| **Install board files** <br> |  | ||||||
| When running Vivado in project mode, it requires board definition files |  | ||||||
| for the Red Pitaya. |  | ||||||
| These files are available from the original Red Pitaya FPGA repository. |  | ||||||
| Use the following steps to download and install these files. |  | ||||||
| 
 |  | ||||||
| - Go to directory `redpitaya-puzzlefw/fpga` |  | ||||||
| - Run `./01_get_redpitaya.sh` |  | ||||||
| - Copy the complete folder `redpitaya-puzzlefw/fpga/RedPitaya-FPGA/brd/redpitaya` |  | ||||||
|   to `/opt/Xilinx/Vivado/2020.2/data/boards/board_files` |  | ||||||
| 
 |  | ||||||
| ### Building FPGA firmware in non-project mode |  | ||||||
| 
 |  | ||||||
| There are two top-level designs, each targeting a specific Red Pitaya board type. |  | ||||||
| These designs are built in separate design runs: |  | ||||||
| 
 |  | ||||||
|  - `puzzlefw_top` for the normal (2-input) Red Pitaya |  | ||||||
|  - `puzzlefw_top_4ch` for the 4-input Red Pitaya |  | ||||||
| 
 |  | ||||||
| The following steps invoke Vivado in non-project mode to handle synthesis, implementation and bitfile generation of each top-level design. |  | ||||||
| 
 |  | ||||||
| - Go to directory `redpitaya-puzzlefw/fpga` |  | ||||||
| - Run `./11_build_bitfile.sh` |  | ||||||
| - Run `./12_build_bitfile_4ch.sh` |  | ||||||
| 
 |  | ||||||
| It is normal for the build process to display a large number of messages and warnings. |  | ||||||
| The build process produces the following output files: |  | ||||||
| 
 |  | ||||||
| - `puzzlefw_top.bit.bin` <br> |  | ||||||
|   This file is required to program the FPGA. |  | ||||||
| - `redpitaya_puzzlefw.xsa` <br> |  | ||||||
|   This file contains a description of the system configuration. |  | ||||||
|   It is necessary to build U-boot. |  | ||||||
| - Similar files for the 4-input design. |  | ||||||
| 
 |  | ||||||
| The build process also creates various logs and report files in directory `vivado/output` (or `output_4ch`). |  | ||||||
| It is recommended to review the contents of `vivado/output/post_route_timing.rpt` to make sure that it does not report any timing violations and contains the line `All user specified timing constraints are met`. |  | ||||||
| 
 |  | ||||||
| ### Building FPGA firmware in project mode |  | ||||||
| 
 |  | ||||||
| The repository contains a Vivado project file to build the design for the normal (2-input) Red Pitaya. |  | ||||||
| There is currently no project file for the 4-input board. |  | ||||||
| 
 |  | ||||||
| The following steps may be used to build the design in Vivado in project mode: |  | ||||||
| 
 |  | ||||||
| - Start Vivado, typically by running something like <br> |  | ||||||
|   `source /opt/Xilinx/Vivado/2020.1/settings64.sh ; vivado` |  | ||||||
| - Open the project file `redpitaya-puzzlefw/fpga/vivado/redpitaya_puzzlefw.xpr`. |  | ||||||
| - In the *Flow Navigator* panel on the left, click on "Run Synthesis", then click "Ok". |  | ||||||
|   It may appear that very little is happening, but synthesis should be running in the background. |  | ||||||
|   The status is displayed in the *Design Runs* panel at the bottom of the screen. |  | ||||||
| - When synthesis completes successfully, choose "Run Implementation" and click "Ok". |  | ||||||
| - When implementation completes successfully, choose "Generate Bitstream" and click "Ok". |  | ||||||
| - When bitstream generation completes successfully, choose "View Reports". |  | ||||||
| - In the *Project Summary* panel, check that timing is ok (Number of Falling Endpoints should be 0). |  | ||||||
| - In the main menu bar, click *File*, *Export*, *Export Hardware*. |  | ||||||
|   Select "Pre-synthesis". |  | ||||||
|   Change XSA file name and export folder to write the XSA file to |  | ||||||
|   `redpitaya-puzzlefw/fpga/redpitaya_puzzlefw.xsa`. |  | ||||||
|   Then click "Finish". |  | ||||||
| 
 |  | ||||||
| The build process produces a BIT file `puzzlefw_top.bit` containing the FPGA design. |  | ||||||
| The Zynq software needs this file in a different format (`.bit.bin`) which can not be created by the Vivado IDE. |  | ||||||
| Use the following steps to convert the BIT file: |  | ||||||
| 
 |  | ||||||
| - Go to directory `redpitaya-puzzlefw/fpga` |  | ||||||
| - Run `./make_binfile.sh vivado/redpitaya_puzzlefw.runs/impl_1/puzzlefw_top.bit` |  | ||||||
| 
 |  | ||||||
| ### Editing the block design |  | ||||||
| 
 |  | ||||||
| Most source files for the FPGA firmware can be edited with any text editor. |  | ||||||
| The VHDL source files are in directory `redpitaya-puzzlefw/fpga/rtl`. |  | ||||||
| Constraint files are in `redpitaya-puzzlefw/fpga/constraints`. |  | ||||||
| 
 |  | ||||||
| The only exception is the block design that links the Zynq processing system to the FPGA logic. |  | ||||||
| The block design is stored as `redpitaya-puzzlefw/fpga/vivado/redpitaya_puzzlefw.srcs/sources_1/bd/puzzlefw/puzzlefw.bd`. |  | ||||||
| This file can only be edited through Vivado, as follows: |  | ||||||
| 
 |  | ||||||
| - Start Vivado as described above. |  | ||||||
| - Open the project file `redpitaya-puzzlefw/fpga/vivado/redpitaya_puzzlefw.xpr`. |  | ||||||
| - In the *Flow Navigator* panel on the left, click on "Open Block Design". |  | ||||||
| - Make changes as needed. |  | ||||||
| - In the main menu bar, click *File*, *Save Block Design*. |  | ||||||
| 
 |  | ||||||
| Both top-level designs (2-input and 4-input boards) use the same block design file. |  | ||||||
| This is a tricky situation because the block design file targets a specific FPGA part (e.g. `xc7z010clg400-1`), but the two boards have different FPGA parts. |  | ||||||
| When using the non-project build flow, we find that this just seems to work without issues. |  | ||||||
| During the build flow, Vivado quietly modifies the block design file to match the target part of the design run. |  | ||||||
| 
 |  | ||||||
| ### Adding VHDL files to the project |  | ||||||
| 
 |  | ||||||
| When VHDL files are added to the project, both the Vivado project and the non-project build script must be updated. |  | ||||||
| 
 |  | ||||||
| To update the Vivado project: |  | ||||||
| 
 |  | ||||||
| - Open the project file `redpitaya-puzzlefw/fpga/vivado/redpitaya_puzzlefw.xpr`. |  | ||||||
| - In the *Flow Navigator* panel on the left, click "Add Sources". |  | ||||||
| - Add VHDL files directly from the directory `redpitaya-puzzlefw/fpga/rtl`. |  | ||||||
|   Do not select "Copy sources into project". |  | ||||||
| - Vivado may get a confused because, by default, it does not support VHDL-2008. |  | ||||||
|   To fix this, in the *Sources* panel, click "Libraries" below the hierachy tree. |  | ||||||
|   Right-click each new VHDL file, choose "Set File Type" and change the file type to "VHDL 2008". |  | ||||||
| 
 |  | ||||||
| Vivado stores all project settings in the XPR file. |  | ||||||
| Changes to that file must be tracked in the Git repository. |  | ||||||
| 
 |  | ||||||
| To update the non-project build script: |  | ||||||
| 
 |  | ||||||
| - Open `redpitaya-puzzlefw/fpga/vivado/nonproject.tcl` in a text editor. |  | ||||||
| - Add `read_vhdl` statements to load the new VHDL files. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ## Building embedded software |  | ||||||
| 
 |  | ||||||
| ### Preparing the build environment |  | ||||||
| 
 |  | ||||||
| Install the following Debian packages (or equivalent packages on other Linux distributions): |  | ||||||
| <br> |  | ||||||
| `build-essential`, |  | ||||||
| `bc`, |  | ||||||
| `bzip2`, |  | ||||||
| `cpio`, |  | ||||||
| `dosfstools`, |  | ||||||
| `file`, |  | ||||||
| `git`, |  | ||||||
| `libncurses-dev`, |  | ||||||
| `mtools`, |  | ||||||
| `patch`, |  | ||||||
| `perl`, |  | ||||||
| `rsync`, |  | ||||||
| `unzip`, |  | ||||||
| `wget`. |  | ||||||
| 
 |  | ||||||
| ### Downloading software |  | ||||||
| 
 |  | ||||||
| Use the following steps to download required software packages: |  | ||||||
| 
 |  | ||||||
| - Go to directory `redpitaya-puzzlefw/sw` |  | ||||||
| - Run `./01_get_buildroot.sh` to download [Buildroot](https://buildroot.org). |  | ||||||
| - Run `./02_get_uboot.sh` to download [U-Boot](https://source.denx.de/u-boot/u-boot). |  | ||||||
| - Run `./03_get_kernel.sh` to download the [Xilinx distribution of the Linux kernel](https://github.com/Xilinx/linux-xlnx). |  | ||||||
| 
 |  | ||||||
| ### Building embedded software |  | ||||||
| 
 |  | ||||||
| Use the following steps to build the embedded software: |  | ||||||
| 
 |  | ||||||
| - Go to directory `redpitaya-puzzlefw/sw` |  | ||||||
| - Run `./11_build_buildroot.sh` to configure and build Buildroot. |  | ||||||
|   <br> |  | ||||||
|   One of the outcomes of this step is a cross-compilation toolchain for the ARM architecture. |  | ||||||
|   Other build steps need this toolchain, therefore this must be the first step of the build flow. |  | ||||||
| - Run `./12_build_uboot.sh` to configure and build U-Boot. |  | ||||||
|   <br> |  | ||||||
|   This step requires the file `redpitaya-puzzlefw/fpga/redpitaya_puzzlefw.xsa` from the FPGA build flow. |  | ||||||
| - Run `./13_build_kernel.sh` to configure and build the Linux kernel. |  | ||||||
| - Run `./14_build_devicetree.sh` to build the device tree. |  | ||||||
| - Run `./15_build_driver.sh` to build the Linux kernel module that provides access to the FPGA firmware. |  | ||||||
| - Run `./16_build_userspace.sh` to build user space applications that will run on the Red Pitaya. |  | ||||||
| - Run `./21_rebuild_rootfs.sh` to re-build the embedded root filesystem, including the kernel driver and user space tools that were built during previous steps. |  | ||||||
| - Run `./22_prepare_sdcard.sh` to collect the files that must be installed on the SD card for the Red Pitaya. |  | ||||||
| - Run `./23_sdcard_image.sh` to build an image file which can be written to the SD card. |  | ||||||
| 
 |  | ||||||
| ### Changing the Buildroot configuration |  | ||||||
| 
 |  | ||||||
| The Buildroot configuration for this project is stored in the folder `config`. |  | ||||||
| To change the configuration, start by applying the existing settings, then run the Buildroot configuration tool, then copy the new settings to the `config` folder. |  | ||||||
| Use the following steps: |  | ||||||
| 
 |  | ||||||
| - Copy `sw/config/buildroot_puzzlefw_defconfig` to `sw/buildroot-2023.02.08/.config` |  | ||||||
| - Go to `sw/buildroot-2023.02.8` |  | ||||||
| - Run `make olddefconfig` |  | ||||||
| - Run `make nconfig` |  | ||||||
| - Use the menu to change the configuration as needed. |  | ||||||
| - Run `make savedefconfig` |  | ||||||
| - Copy `sw/buildroot-2023.02.08/defconfig` to `sw/config/buildroot_puzzlefw_defconfig` |  | ||||||
| 
 |  | ||||||
| After changing the Buildroot configuration, rerun step `11_build_buildroot.sh`. |  | ||||||
| 
 |  | ||||||
| ### Changing the U-Boot configuration |  | ||||||
| 
 |  | ||||||
| The U-Boot configuration for this project is stored in the folder `config`. |  | ||||||
| To change the configuration, start by applying the existing settings, then run the U-boot configuration tool, then copy the new settings to the `config` folder. |  | ||||||
| Use the following steps: |  | ||||||
| 
 |  | ||||||
| - Copy `sw/config/uboot_redpitaya_puzzlefw_defconfig` to `sw/u-boot/configs/redpitaya_puzzlefw_defconfig` |  | ||||||
| - Go to `sw/u-boot` |  | ||||||
| - Run `make redpitaya_puzzlefw_defconfig` |  | ||||||
| - Run `make nconfig` |  | ||||||
| - Use the menu to change the configuration as needed. |  | ||||||
| - Run `make savedefconfig` |  | ||||||
| - Copy `sw/u-boot/defconfig` to `sw/config/uboot_redpitaya_puzzlefw_defconfig` |  | ||||||
| 
 |  | ||||||
| After changing the Buildroot configuration, rerun step `12_build_uboot.sh`. |  | ||||||
| 
 |  | ||||||
| ### Changing the Linux kernel configuration |  | ||||||
| 
 |  | ||||||
| The Linux kernel configuration for this project is stored in the folder `config`. |  | ||||||
| To change the configuration, start by applying the existing settings, then run the kernel configuration tool, then copy the new settings to the `config` folder. |  | ||||||
| Use the following steps: |  | ||||||
| 
 |  | ||||||
| - Copy `sw/config/linux_redpitaya_puzzlefw_defconfig` to `sw/linux-xlnx/.config` |  | ||||||
| - Go to `sw/linux-xlnx` |  | ||||||
| - Run `make ARCH=arm olddefconfig` |  | ||||||
| - Run `make ARCH=arm nconfig` |  | ||||||
| - Use the menu to change the configuration as needed. |  | ||||||
| - Run `make ARCH=arm savedefconfig` |  | ||||||
| - Copy `sw/linux-xlnx/defconfig` to `sw/config/linux_redpitaya_puzzlefw_defconfig` |  | ||||||
| 
 |  | ||||||
| After changing the Buildroot configuration, rerun step `13_build_kernel.sh`. |  | ||||||
| 
 |  | ||||||
| ### Preparing the SD card |  | ||||||
| 
 |  | ||||||
| This section explains how to set up the SD card manually. |  | ||||||
| It is not normally necessary to do this. |  | ||||||
| An easier way to set up the SD card is by building an image file and writing it to the card. |  | ||||||
| 
 |  | ||||||
| The SD card contains two partitions: |  | ||||||
| 
 |  | ||||||
| - `/dev/mmcblk0p1` is a 256 MB partition with FAT filesystem |  | ||||||
| - `/dev/mmcblk0p2` is a 256 MB partition with an Ext4 filesystem |  | ||||||
| 
 |  | ||||||
| The FAT partition contains the following files: |  | ||||||
| 
 |  | ||||||
| | File                       | Description | |  | ||||||
| |----------------------------|-------------| |  | ||||||
| | `boot.bin`                 | first stage boot loader for the Zynq (built by U-Boot) | |  | ||||||
| | `u-boot.img`               | main boot loader program (U-Boot) | |  | ||||||
| | `boot.scr`                 | boot script for U-Boot | |  | ||||||
| | `devicetree.dtb`           | device tree for the Linux kernel | |  | ||||||
| | `uImage`                   | Linux kernel image | |  | ||||||
| | `rootfs.cpio.uboot`        | root filesystem image | |  | ||||||
| | `puzzlefw_top.bit.bin`     | FPGA firmware image for 2-input board | |  | ||||||
| | `puzzlefw_top_4ch.bit.bin` | FPGA firmware image for 4-input board | |  | ||||||
| 
 |  | ||||||
| The Ext4 partition can be left empty initially. |  | ||||||
| Configuration files will be written to this partition by the embedded system. |  | ||||||
| 
 |  | ||||||
| The following commands may be used to format the two partitions: |  | ||||||
| 
 |  | ||||||
|     mkdosfs -F 16 /dev/mmcblk0p1 |  | ||||||
|     mke2fs -t ext4 -b 4096 /dev/mmcblk0p2 |  | ||||||
| 
 |  | ||||||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 166 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 36 KiB | 
|  | @ -1,506 +0,0 @@ | ||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
| 
 |  | ||||||
| <svg |  | ||||||
|    width="297mm" |  | ||||||
|    height="210mm" |  | ||||||
|    viewBox="0 0 297 210" |  | ||||||
|    version="1.1" |  | ||||||
|    id="svg5" |  | ||||||
|    inkscape:version="1.2.2 (b0a8486541, 2022-12-01)" |  | ||||||
|    sodipodi:docname="fpga_design_overview.svg" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg"> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="namedview7" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:showpageshadow="2" |  | ||||||
|      inkscape:pageopacity="0.0" |  | ||||||
|      inkscape:pagecheckerboard="0" |  | ||||||
|      inkscape:deskcolor="#d1d1d1" |  | ||||||
|      inkscape:document-units="mm" |  | ||||||
|      showgrid="true" |  | ||||||
|      inkscape:zoom="1.2938725" |  | ||||||
|      inkscape:cx="71.490816" |  | ||||||
|      inkscape:cy="177.37451" |  | ||||||
|      inkscape:window-width="1514" |  | ||||||
|      inkscape:window-height="1247" |  | ||||||
|      inkscape:window-x="576" |  | ||||||
|      inkscape:window-y="53" |  | ||||||
|      inkscape:window-maximized="0" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      inkscape:lockguides="false"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid29" |  | ||||||
|        originx="0" |  | ||||||
|        originy="0" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <defs |  | ||||||
|      id="defs2"> |  | ||||||
|     <marker |  | ||||||
|        style="overflow:visible" |  | ||||||
|        id="marker29490" |  | ||||||
|        refX="0" |  | ||||||
|        refY="0" |  | ||||||
|        orient="auto" |  | ||||||
|        inkscape:stockid="Dot" |  | ||||||
|        markerWidth="4" |  | ||||||
|        markerHeight="4" |  | ||||||
|        viewBox="0 0 5.4 5.4" |  | ||||||
|        inkscape:isstock="true" |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        preserveAspectRatio="xMidYMid"> |  | ||||||
|       <path |  | ||||||
|          transform="scale(0.45)" |  | ||||||
|          style="fill:context-fill;fill-rule:evenodd;stroke:context-stroke;stroke-width:2" |  | ||||||
|          d="M 5,0 C 5,2.76 2.76,5 0,5 -2.76,5 -5,2.76 -5,0 c 0,-2.76 2.3,-5 5,-5 2.76,0 5,2.24 5,5 z" |  | ||||||
|          id="path29488" |  | ||||||
|          sodipodi:nodetypes="sssss" /> |  | ||||||
|     </marker> |  | ||||||
|     <marker |  | ||||||
|        style="overflow:visible" |  | ||||||
|        id="marker29344" |  | ||||||
|        refX="0" |  | ||||||
|        refY="0" |  | ||||||
|        orient="auto" |  | ||||||
|        inkscape:stockid="Dot" |  | ||||||
|        markerWidth="4" |  | ||||||
|        markerHeight="4" |  | ||||||
|        viewBox="0 0 5.4 5.4" |  | ||||||
|        inkscape:isstock="true" |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        preserveAspectRatio="xMidYMid"> |  | ||||||
|       <path |  | ||||||
|          transform="scale(0.45)" |  | ||||||
|          style="fill:context-fill;fill-rule:evenodd;stroke:context-stroke;stroke-width:2" |  | ||||||
|          d="M 5,0 C 5,2.76 2.76,5 0,5 -2.76,5 -5,2.76 -5,0 c 0,-2.76 2.3,-5 5,-5 2.76,0 5,2.24 5,5 z" |  | ||||||
|          id="path29342" |  | ||||||
|          sodipodi:nodetypes="sssss" /> |  | ||||||
|     </marker> |  | ||||||
|     <marker |  | ||||||
|        style="overflow:visible" |  | ||||||
|        id="marker29218" |  | ||||||
|        refX="0" |  | ||||||
|        refY="0" |  | ||||||
|        orient="auto" |  | ||||||
|        inkscape:stockid="Dot" |  | ||||||
|        markerWidth="4" |  | ||||||
|        markerHeight="4" |  | ||||||
|        viewBox="0 0 5.4 5.4" |  | ||||||
|        inkscape:isstock="true" |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        preserveAspectRatio="xMidYMid"> |  | ||||||
|       <path |  | ||||||
|          transform="scale(0.45)" |  | ||||||
|          style="fill:context-fill;fill-rule:evenodd;stroke:context-stroke;stroke-width:2" |  | ||||||
|          d="M 5,0 C 5,2.76 2.76,5 0,5 -2.76,5 -5,2.76 -5,0 c 0,-2.76 2.3,-5 5,-5 2.76,0 5,2.24 5,5 z" |  | ||||||
|          id="path29216" |  | ||||||
|          sodipodi:nodetypes="sssss" /> |  | ||||||
|     </marker> |  | ||||||
|     <marker |  | ||||||
|        style="overflow:visible" |  | ||||||
|        id="marker9466" |  | ||||||
|        refX="0" |  | ||||||
|        refY="0" |  | ||||||
|        orient="auto" |  | ||||||
|        inkscape:stockid="Dot" |  | ||||||
|        markerWidth="4" |  | ||||||
|        markerHeight="4" |  | ||||||
|        viewBox="0 0 5.4 5.4" |  | ||||||
|        inkscape:isstock="true" |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        preserveAspectRatio="xMidYMid"> |  | ||||||
|       <path |  | ||||||
|          transform="scale(0.45)" |  | ||||||
|          style="fill:context-fill;fill-rule:evenodd;stroke:context-stroke;stroke-width:2" |  | ||||||
|          d="M 5,0 C 5,2.76 2.76,5 0,5 -2.76,5 -5,2.76 -5,0 c 0,-2.76 2.3,-5 5,-5 2.76,0 5,2.24 5,5 z" |  | ||||||
|          id="path9464" |  | ||||||
|          sodipodi:nodetypes="sssss" /> |  | ||||||
|     </marker> |  | ||||||
|     <marker |  | ||||||
|        style="overflow:visible" |  | ||||||
|        id="TriangleStart" |  | ||||||
|        refX="0" |  | ||||||
|        refY="0" |  | ||||||
|        orient="auto-start-reverse" |  | ||||||
|        inkscape:stockid="TriangleStart" |  | ||||||
|        markerWidth="4.3239999" |  | ||||||
|        markerHeight="4.9988437" |  | ||||||
|        viewBox="0 0 5.3244081 6.1553851" |  | ||||||
|        inkscape:isstock="true" |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        preserveAspectRatio="xMidYMid"> |  | ||||||
|       <path |  | ||||||
|          transform="scale(0.5)" |  | ||||||
|          style="fill:context-stroke;fill-rule:evenodd;stroke:context-stroke;stroke-width:1pt" |  | ||||||
|          d="M 5.77,0 -2.88,5 V -5 Z" |  | ||||||
|          id="path135" /> |  | ||||||
|     </marker> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="110" |  | ||||||
|        height="50" |  | ||||||
|        id="rect8262" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="110" |  | ||||||
|        height="50" |  | ||||||
|        id="rect9048" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="110" |  | ||||||
|        height="50" |  | ||||||
|        id="rect10560" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="110" |  | ||||||
|        height="50" |  | ||||||
|        id="rect10566" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="105.41406" |  | ||||||
|        height="67.484375" |  | ||||||
|        id="rect10624" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect12086" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect12123" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect12855" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect14313" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect14321" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect16505" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect17237" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="150.125" |  | ||||||
|        height="27.484377" |  | ||||||
|        id="rect20229" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="105.41406" |  | ||||||
|        height="67.484375" |  | ||||||
|        id="rect29672" /> |  | ||||||
|     <rect |  | ||||||
|        x="50" |  | ||||||
|        y="160" |  | ||||||
|        width="80.114585" |  | ||||||
|        height="23.184275" |  | ||||||
|        id="rect29708" /> |  | ||||||
|   </defs> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1"> |  | ||||||
|     <rect |  | ||||||
|        style="fill:none;stroke:#000000;stroke-width:0.3;stroke-linecap:round;stroke-linejoin:round;stroke-opacity:1;stroke-dasharray:none" |  | ||||||
|        id="rect133" |  | ||||||
|        width="190.6516" |  | ||||||
|        height="84.732727" |  | ||||||
|        x="26.458334" |  | ||||||
|        y="7.9375" /> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#fff799;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect2424" |  | ||||||
|        width="31.750004" |  | ||||||
|        height="52.916664" |  | ||||||
|        x="179.91667" |  | ||||||
|        y="13.229167" /> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#b2ffb2;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect6690" |  | ||||||
|        width="31.75" |  | ||||||
|        height="10.583332" |  | ||||||
|        x="31.75" |  | ||||||
|        y="13.229167" /> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#ccdfff;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-opacity:1;stroke-dasharray:none" |  | ||||||
|        id="rect6694" |  | ||||||
|        width="42.068748" |  | ||||||
|        height="15.874999" |  | ||||||
|        x="74.270424" |  | ||||||
|        y="13.594255" /> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#ffcdb2;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect6698" |  | ||||||
|        width="42.333328" |  | ||||||
|        height="10.583332" |  | ||||||
|        x="127" |  | ||||||
|        y="13.229167" /> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#cbdcff;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect9828" |  | ||||||
|        width="42.068752" |  | ||||||
|        height="15.875004" |  | ||||||
|        x="74.083336" |  | ||||||
|        y="50.270832" /> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,169.33334,-27.245888)" |  | ||||||
|        id="text10622" |  | ||||||
|        style="font-size:14.6667px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect10624);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="172.97659" |  | ||||||
|          id="tspan32207"><tspan |  | ||||||
|            style="fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32205">block design |  | ||||||
| </tspan></tspan><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="191.30997" |  | ||||||
|          id="tspan32211"><tspan |  | ||||||
|            style="fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32209">(PS)</tspan></tspan></text> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#ffcdb2;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect11354" |  | ||||||
|        width="42.068748" |  | ||||||
|        height="10.318751" |  | ||||||
|        x="127" |  | ||||||
|        y="34.395832" /> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,116.20478,-26.880356)" |  | ||||||
|        id="text12084" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect12086);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32215"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32213">dma_write_channel</tspan></tspan></text> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#ffcdb2;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect12117" |  | ||||||
|        width="42.333328" |  | ||||||
|        height="10.583332" |  | ||||||
|        x="127" |  | ||||||
|        y="55.5625" /> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,116.20478,15.452982)" |  | ||||||
|        id="text12121" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect12123);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32219"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32217">dma_write_channel</tspan></tspan></text> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,116.20479,-5.732634)" |  | ||||||
|        id="text12853" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect12855);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32223"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32221">dma_axi_master</tspan></tspan></text> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,21.166668,-26.933748)" |  | ||||||
|        id="text14311" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect14313);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32227"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32225">adc_capture</tspan></tspan></text> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#b2ffb2;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect14315" |  | ||||||
|        width="31.75" |  | ||||||
|        height="10.583332" |  | ||||||
|        x="31.75" |  | ||||||
|        y="50.270832" /> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,21.166666,10.10792)" |  | ||||||
|        id="text14319" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect14321);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32231"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32229">deglitch</tspan></tspan></text> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,63.499996,10.107924)" |  | ||||||
|        id="text16503" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect16505);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32235"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32233">timetagger</tspan></tspan></text> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,63.687086,-26.568659)" |  | ||||||
|        id="text17235" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect17237);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32239"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32237">acquisition_chain</tspan></tspan></text> |  | ||||||
|     <rect |  | ||||||
|        style="fill:#ccffff;fill-opacity:1;stroke:#000000;stroke-width:0.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect20223" |  | ||||||
|        width="31.74999" |  | ||||||
|        height="10.583332" |  | ||||||
|        x="179.91667" |  | ||||||
|        y="76.729164" /> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,168.70976,36.600693)" |  | ||||||
|        id="text20227" |  | ||||||
|        style="font-size:13.3333px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect20229);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="171.79685" |  | ||||||
|          id="tspan32243"><tspan |  | ||||||
|            style="font-family:'DejaVu Sans Mono';-inkscape-font-specification:'DejaVu Sans Mono';fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32241">registers</tspan></tspan></text> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="m 63.5,18.520833 7.9375,0" |  | ||||||
|        id="path21149" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="m 63.5,55.5625 7.937501,0" |  | ||||||
|        id="path22406" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="m 116.41667,18.520833 h 7.9375" |  | ||||||
|        id="path22424" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="m 116.41667,60.854167 h 7.9375" |  | ||||||
|        id="path22430" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="m 169.33333,39.6875 h 7.9375" |  | ||||||
|        id="path22436" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="M 140.22917,55.5625 V 47.625" |  | ||||||
|        id="path22442" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="M 140.22917,23.8125 V 31.75" |  | ||||||
|        id="path22448" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#TriangleStart)" |  | ||||||
|        d="M 58.208333,50.270833 V 39.6875 H 79.375 l 0,-7.9375" |  | ||||||
|        id="path22557" |  | ||||||
|        sodipodi:nodetypes="cccc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.75;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-start:url(#TriangleStart);marker-end:url(#TriangleStart)" |  | ||||||
|        d="m 190.5,74.083333 0,-5.291666" |  | ||||||
|        id="path24899" |  | ||||||
|        sodipodi:nodetypes="cc" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;marker-end:url(#marker29218);stroke-dasharray:none" |  | ||||||
|        d="M 31.75,52.916666 H 21.166666" |  | ||||||
|        id="path25030" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#marker9466)" |  | ||||||
|        d="M 31.75,54.239583 H 21.166666" |  | ||||||
|        id="path26680" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#marker29344)" |  | ||||||
|        d="M 31.750001,55.5625 H 21.166667" |  | ||||||
|        id="path26650" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-dasharray:none;stroke-opacity:1;marker-end:url(#marker29490)" |  | ||||||
|        d="M 31.75,56.885417 H 21.166666" |  | ||||||
|        id="path26658" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:#eabfff;fill-opacity:1;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;stroke-dasharray:none" |  | ||||||
|        d="M 13.229167,18.520833 15.875,15.875 h 5.291666 v 5.291666 H 15.875 Z" |  | ||||||
|        id="path27546" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;stroke-dasharray:none" |  | ||||||
|        d="M 21.166666,17.197916 H 31.75" |  | ||||||
|        id="path28300" /> |  | ||||||
|     <path |  | ||||||
|        style="fill:none;fill-opacity:0.75;fill-rule:evenodd;stroke:#000000;stroke-width:0.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;stroke-dasharray:none" |  | ||||||
|        d="M 21.166666,19.84375 H 31.75" |  | ||||||
|        id="path28302" /> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,-0.20448484,-32.592506)" |  | ||||||
|        id="text29670" |  | ||||||
|        style="font-size:14.6667px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect29672);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="172.97659" |  | ||||||
|          id="tspan32247"><tspan |  | ||||||
|            style="fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32245">ADC</tspan></tspan></text> |  | ||||||
|     <text |  | ||||||
|        xml:space="preserve" |  | ||||||
|        transform="matrix(0.26458333,0,0,0.26458333,-7.9374998,4.5041105)" |  | ||||||
|        id="text29706" |  | ||||||
|        style="font-size:14.6667px;line-height:125%;font-family:'DejaVu Sans';-inkscape-font-specification:'DejaVu Sans';letter-spacing:0px;word-spacing:0px;white-space:pre;shape-inside:url(#rect29708);display:inline;fill:none;fill-opacity:0.75;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"><tspan |  | ||||||
|          x="50" |  | ||||||
|          y="172.97659" |  | ||||||
|          id="tspan32251"><tspan |  | ||||||
|            style="fill:#000000;fill-opacity:1;stroke:none" |  | ||||||
|            id="tspan32249">digital I/O</tspan></tspan></text> |  | ||||||
|     <rect |  | ||||||
|        style="fill:none;fill-opacity:1;stroke:none;stroke-width:0.499999;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:none;stroke-opacity:1" |  | ||||||
|        id="rect32120" |  | ||||||
|        width="216.95833" |  | ||||||
|        height="89.958336" |  | ||||||
|        x="2.6458333" |  | ||||||
|        y="5.2916665" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 22 KiB | 
|  | @ -40,7 +40,6 @@ By manipulating these GPIO signals, the Linux system can reset the FPGA firmware | ||||||
| | 0             | 54         | out (to FPGA)  | Global firmware reset | | | 0             | 54         | out (to FPGA)  | Global firmware reset | | ||||||
| | 1             | 55         | in (from FPGA) | Reset status report | | | 1             | 55         | in (from FPGA) | Reset status report | | ||||||
| | 2             | 56         | out (to FPGA)  | ADC clock duty cycle stabilizer | | | 2             | 56         | out (to FPGA)  | ADC clock duty cycle stabilizer | | ||||||
| | 3             | 57         | out (to FPGA)  | ADC sample derandomization | |  | ||||||
| 
 | 
 | ||||||
| ### GPIO 0: Global firmware reset | ### GPIO 0: Global firmware reset | ||||||
| 
 | 
 | ||||||
|  | @ -83,19 +82,6 @@ This GPIO signal is asynchronously routed through the FPGA to the ADC. | ||||||
| Changing the state of this signal may shift the phase of the ADC data clock. | Changing the state of this signal may shift the phase of the ADC data clock. | ||||||
| It must therefore only be changed while the FPGA firmware is in reset. | It must therefore only be changed while the FPGA firmware is in reset. | ||||||
| 
 | 
 | ||||||
| ### GPIO 3: ADC sample derandomization |  | ||||||
| 
 |  | ||||||
| GPIO 3 controls a sample derandomization function in the FPGA. |  | ||||||
| 
 |  | ||||||
| - GPIO 3 is an output from the PS to the FPGA. |  | ||||||
| - Driving this signal as `0` disables sample derandomization. |  | ||||||
| - Driving this signal as `1` enables sample derandomization. |  | ||||||
| 
 |  | ||||||
| This signal is only supported on Red Pitaya boards with 4 input channels. |  | ||||||
| On these boards, the ADC can optionally be configured to randomize its output |  | ||||||
| by XOR-ing the least significant bit into all other bits. |  | ||||||
| The derandomization function in the FPGA recovers the original sample values. |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| # SPI signals | # SPI signals | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -0,0 +1,502 @@ | ||||||
|  | # Remote access | ||||||
|  | 
 | ||||||
|  | Remote access to the acquisition system is supported via TCP connections. | ||||||
|  | Three TCP server ports are used: | ||||||
|  | 
 | ||||||
|  | - port 5001 is used to transfer analog sample data; | ||||||
|  | - port 5002 is used to transfer timetagger data; | ||||||
|  | - port 5025 is used for commands. | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ## Analog sample data stream | ||||||
|  | 
 | ||||||
|  | A client may connect to TCP port 5001 to receive analog sample data. | ||||||
|  | At most one client can be connected to this port at any time. | ||||||
|  | If a new client connects while another connection is still active, | ||||||
|  | the server closes the old connection and uses the new connection instead. | ||||||
|  | 
 | ||||||
|  | Data flows through the TCP connection in one direction: from the server | ||||||
|  | to the client. | ||||||
|  | The client must not send anything back to the server. | ||||||
|  | 
 | ||||||
|  | Analog sample data are transferred as a sequence of 64-bit binary messages. | ||||||
|  | Each message is sent as a group of 8 bytes with the least significant byte first. | ||||||
|  | The message stream corresponds to the output data format of the | ||||||
|  | analog acquisition chain as described in the FPGA firmware documentation. | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ## Timetagger event stream | ||||||
|  | 
 | ||||||
|  | A client may connect to TCP port 5002 to receive timetagger data. | ||||||
|  | At most one client can be connected to this port at any time. | ||||||
|  | If a new client connects while another connection is still active, | ||||||
|  | the server closes the old connection and uses the new connection instead. | ||||||
|  | 
 | ||||||
|  | Data flows through the TCP connection in one direction: from the server | ||||||
|  | to the client. | ||||||
|  | The client must not send anything back to the server. | ||||||
|  | 
 | ||||||
|  | Timetagger data are transferred as a sequence of 64-bit binary messages. | ||||||
|  | Each message is sent as a group of 8 bytes with the least significant byte first. | ||||||
|  | The message stream corresponds to the output data format of the timetagger | ||||||
|  | as described in the FPGA firmware documentation. | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ## Command protocol | ||||||
|  | 
 | ||||||
|  | A client may connect to TCP port 5025 to send commands. | ||||||
|  | Multiple clients may be simultaneously connected to this port. | ||||||
|  | In that case, it is the responsibility of the clients to make sure | ||||||
|  | that they do not interfere with eachother. | ||||||
|  | 
 | ||||||
|  | The remote control protocol is based on ASCII strings. | ||||||
|  | The protocol is vaguely similar to SCPI, but it is not compatible with SCPI. | ||||||
|  | 
 | ||||||
|  | Every interaction is initiated by the client sending a command, | ||||||
|  | and completed by the server sending a response. | ||||||
|  | Each command and each response consists of an ASCII string terminated by linefeed (ASCII 10). | ||||||
|  | Commands are case-insensitive. | ||||||
|  | 
 | ||||||
|  | The server ignores empty lines and lines that contain only white space characters. | ||||||
|  | In all other cases, the server sends one response for every command received, even if the command is not recognized or not supported. | ||||||
|  | The server only sends data in response to a command; it never sends data spontaneously. | ||||||
|  | 
 | ||||||
|  | A _query_ is a command that ends with a `?` character. | ||||||
|  | The server responds to a query either by sending the requested data, | ||||||
|  | or by sending an error message. | ||||||
|  | An error message starts with the string `ERROR`, followed by | ||||||
|  | a space character, followed by a short description of the error. | ||||||
|  | 
 | ||||||
|  | The server responds to a non-query command either by sending the string `OK` | ||||||
|  | to indicate that the command was completed successfully, | ||||||
|  | or by sending an error message. | ||||||
|  | 
 | ||||||
|  | Some commands require one or more _parameters_. | ||||||
|  | In the command string, the command and parameters are separated from eachother by space characters. | ||||||
|  | 
 | ||||||
|  | The response to some queries may consist of multiple data elements. | ||||||
|  | In the response string, such data elements are separated by space characters. | ||||||
|  | 
 | ||||||
|  | ### Example | ||||||
|  | 
 | ||||||
|  | | Client                   | Server        | | ||||||
|  | |--------------------------|---------------| | ||||||
|  | | `AIN:SRATE?`             |               | | ||||||
|  | |                          | `1000000.000` | | ||||||
|  | | `AIN:SRATE:DIVISOR 1000` |               | | ||||||
|  | |                          | `OK`          | | ||||||
|  | | `AIN:SRATE?`             |               | | ||||||
|  | |                          | `125000.000`  | | ||||||
|  | | `AIN:NSAMPLES 0`         |               | | ||||||
|  | |                          | `ERROR Invalid argument` | | ||||||
|  | | `Hello`                  |               | | ||||||
|  | |                          | `ERROR Unknown command` | | ||||||
|  | 
 | ||||||
|  | ### List of commands and queries | ||||||
|  | 
 | ||||||
|  | | Command                   | Description | | ||||||
|  | |---------------------------|-------------| | ||||||
|  | | `*IDN?`                   | Instrument identification. | | ||||||
|  | | `RESET`                   | Restore default settings. | | ||||||
|  | | `TIMESTAMP?`              | Timestamp counter. | | ||||||
|  | | `AIN:CHANNELS:COUNT?`     | Number of input channels. | | ||||||
|  | | `AIN:CHANNELS:ACTIVE`     | Number of active input channels. | | ||||||
|  | | `AIN:CHn:RANGE`           | Analog input range. | | ||||||
|  | | `AIN:CHn:OFFSET`          | Offset calibration. | | ||||||
|  | | `AIN:CHn:GAIN`            | Gain calibration. | | ||||||
|  | | `AIN:CAL:SAVE`            | Save calibration. | | ||||||
|  | | `AIN:CHn:SAMPLE[:RAW]?`   | Read ADC sample. | | ||||||
|  | | `AIN:CHn:MINMAX[:RAW]?`   | Read ADC range monitor. | | ||||||
|  | | `AIN:MINMAX:CLEAR`        | Reset ADC range monitor. | | ||||||
|  | | `AIN:SRATE`               | Sample rate. | | ||||||
|  | | `AIN:SRATE:DIVISOR`       | Downsample factor. | | ||||||
|  | | `AIN:SRATE:MODE`          | Downsample mode. | | ||||||
|  | | `AIN:SRATE:GAIN?`         | Downsample gain. | | ||||||
|  | | `AIN:NSAMPLES`            | Number of samples per trigger. | | ||||||
|  | | `AIN:TRIGGER`             | Force a trigger event. | | ||||||
|  | | `AIN:TRIGGER:MODE`        | Select trigger mode. | | ||||||
|  | | `AIN:TRIGGER:DELAY`       | Trigger delay. | | ||||||
|  | | `AIN:TRIGGER:STATUS?`     | Trigger status. | | ||||||
|  | | `AIN:TRIGGER:EXT:CHANNEL` | External trigger channel. | | ||||||
|  | | `AIN:TRIGGER:EXT:EDGE`    | External trigger edge. | | ||||||
|  | | `AIN:ACQUIRE:ENABLE`      | Enable analog acquisition. | | ||||||
|  | | `TT:SAMPLE?`              | Digital input state. | | ||||||
|  | | `TT:EVENT:MASK`           | Timetagger event mask. | | ||||||
|  | | `TT:MARK`                 | Emit timetagger marker. | | ||||||
|  | | `TEMP:FPGA?`              | FPGA temperature. | | ||||||
|  | | `IPCFG[:SAVED]`           | IP address configuration. | | ||||||
|  | | `HALT`                    | Shut down system. | | ||||||
|  | | `REBOOT`                  | Reboot system. | | ||||||
|  | 
 | ||||||
|  | ### `*IDN?` | ||||||
|  | 
 | ||||||
|  | Query: `*IDN?` <br> | ||||||
|  | Response: string with 4 comma-separated fields. | ||||||
|  | 
 | ||||||
|  | This query returns the instrument identification string. | ||||||
|  | The response consists of 4 comma-separated fields: | ||||||
|  | `manufacturer,model,serialnr,version`. | ||||||
|  | 
 | ||||||
|  | ### `RESET` | ||||||
|  | 
 | ||||||
|  | Command: `RESET` | ||||||
|  | 
 | ||||||
|  | This command restores most non-persistent settings to power-on defaults. | ||||||
|  | It resets all settings, except for the following: | ||||||
|  | 
 | ||||||
|  | - saved calibration; | ||||||
|  | - active network configuration; | ||||||
|  | - saved network configuration. | ||||||
|  | 
 | ||||||
|  | The active calibration is restored to match the saved calibration. | ||||||
|  | Other settings are restored to fixed power-on defaults. | ||||||
|  | 
 | ||||||
|  | Any ongoing analog acquisition is stopped. | ||||||
|  | 
 | ||||||
|  | ### `TIMESTAMP?` | ||||||
|  | 
 | ||||||
|  | Query: `TIMESTAMP?` <br> | ||||||
|  | Response: decimal integer, representing the current timestamp in units of 8 ns. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHANNELS:COUNT?` | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHANNELS:COUNT?` <br> | ||||||
|  | Response: number of supported analog input channels. | ||||||
|  | 
 | ||||||
|  | The response is `2` for a standard Red Pitaya, or `4` for a 4-input Red Pitaya. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHANNELS:ACTIVE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CHANNELS:ACTIVE n` <br> | ||||||
|  | Parameter _n_: number of active channels, either `2` or `4`. | ||||||
|  | 
 | ||||||
|  | This command is only supported on a 4-input Red Pitaya. | ||||||
|  | When 2 channels are active, only analog input channels 1 and 2 are included in analog acquisition data. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHANNELS:ACTIVE?` <br> | ||||||
|  | Response: number of active channels, either `2` or `4`. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHn:RANGE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CHn:RANGE range` <br> | ||||||
|  | Field _n_: channel number, in range 1 to 4. <br> | ||||||
|  | Parameter _range_: input range, either `LO` or `HI`. | ||||||
|  | 
 | ||||||
|  | This command specifies which set of calibration coefficients should be used to interpret ADC samples. | ||||||
|  | Note that this command does not change the actual input range of the Red Pitaya. | ||||||
|  | The input range can only be changed by manually placing a jumper on the board. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:RANGE?` <br> | ||||||
|  | Response: currently configured input range, either `LO` or `HI`. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHn:OFFSET[:LO|HI]` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CHn:OFFSET offs` <br> | ||||||
|  | Field _n_: channel number, in range 1 to 4. <br> | ||||||
|  | Parameter _offs_: floating point number specifying the offset calibration. | ||||||
|  | 
 | ||||||
|  | The offset calibration specifies the raw ADC code corresponding to analog input level 0 Volt. | ||||||
|  | The expected value is in the middle of the ADC code range, i.e. approximately 8192. | ||||||
|  | The plain variant of the command configures the offset calibration for the active input range of the channel. | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CHn:OFFSET:LO offs` <br> | ||||||
|  | Command: `AIN:CHn:OFFSET:HI offs` <br> | ||||||
|  | These variants of the command configure the offset calibration for a specific input range. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:OFFSET?` <br> | ||||||
|  | Query: `AIN:CHn:OFFSET:LO?` <br> | ||||||
|  | Query: `AIN:CHn:OFFSET:HI?` <br> | ||||||
|  | Response: floating point number indicating the offset calibration for the active input range or the specified input range. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHn:GAIN[:LO|HI]` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CHn:GAIN gain` <br> | ||||||
|  | Field _n_: channel number, in range 1 to 4. <br> | ||||||
|  | Parameter _gain_: floating point number specifying the gain calibration. | ||||||
|  | 
 | ||||||
|  | The gain calibration specifies the difference in raw ADC code corresponding to a 1 Volt difference in analog input level. | ||||||
|  | The expected value is negative, because the Red Pitaya uses an inverting input amplifier. | ||||||
|  | The plain variant of the command configures the gain calibration for the active input range of the channel. | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CHn:GAIN:LO offs` <br> | ||||||
|  | Command: `AIN:CHn:GAIN:HI offs` <br> | ||||||
|  | These variants of the command configure the gain calibration for a specific input range. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:GAIN?` <br> | ||||||
|  | Query: `AIN:CHn:GAIN:LO?` <br> | ||||||
|  | Query: `AIN:CHn:GAIN:HI?` <br> | ||||||
|  | Response: floating point number indicating the gain calibration for the active input range or the specified input range. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CAL:SAVE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:CAL:SAVE` | ||||||
|  | 
 | ||||||
|  | This command saves the active calibration settings to the SD card, to be used as power-on defaults. | ||||||
|  | The following settings are saved: for each analog input channel, its input range, offset calibration for low and high range, and gain calibration for low and high range. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHn:SAMPLE[:RAW]?` | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:SAMPLE?` <br> | ||||||
|  | Field _n_: channel number, in range 1 to 4. <br> | ||||||
|  | Response: floating point number representing the most recent ADC sample for the specified input channel in Volt. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:SAMPLE:RAW?` <br> | ||||||
|  | Response: decimal integer representing the raw ADC code of the most recent sample for the specified input channel. | ||||||
|  | 
 | ||||||
|  | Sample rate settings are not applicable to this command. | ||||||
|  | The ADC always samples at 125 MSa/s. | ||||||
|  | This command returns the most recent single sample, without downsampling or averaging. | ||||||
|  | 
 | ||||||
|  | ### `AIN:CHn:MINMAX[:RAW]?` | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:MINMAX?` <br> | ||||||
|  | Field _n_: channel number, in range 1 to 4. <br> | ||||||
|  | Response: two floating point numbers separated by a space character, representing the minimum and maximum input level in Volt. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:CHn:MINMAX:RAW?` <br> | ||||||
|  | Response: two decimal integers separated by a space character, representing the minimum and maximum raw ADC code. | ||||||
|  | 
 | ||||||
|  | The returned values are the minimum and maximum sample values that occurred since the last reset of the range monitor. | ||||||
|  | 
 | ||||||
|  | ### `AIN:MINMAX:CLEAR` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:MINMAX:CLEAR` | ||||||
|  | 
 | ||||||
|  | This command resets the input range monitors of all analog input channels. | ||||||
|  | 
 | ||||||
|  | ### `AIN:SRATE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:SRATE rate` <br> | ||||||
|  | Parameter _rate_: floating point number specifying the sample rate in samples per second. | ||||||
|  | 
 | ||||||
|  | This command configures the effective sample rate of the acquisition chain. | ||||||
|  | Valid sample rates are in range 500 to 125e6 samples per second. | ||||||
|  | The specified sample rate will be rounded to the nearest supported rate. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:SRATE?` <br> | ||||||
|  | Response: floating point number representing the sample rate in samples per second. | ||||||
|  | 
 | ||||||
|  | ### `AIN:SRATE:DIVISOR` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:SRATE:DIVISOR divisor` <br> | ||||||
|  | Parameter _divisor_: decimal integer specifying the downsample factor. | ||||||
|  | 
 | ||||||
|  | This command configures the downsample factor of the acquisition chain. | ||||||
|  | Valid downsample factors are in range 1 to 250000. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:SRATE:DIVISOR?` <br> | ||||||
|  | Response: decimal integer representing the downsample factor. | ||||||
|  | 
 | ||||||
|  | **Note:** Commands `AIN:SRATE` and `AIN:SRATE:DIVISOR` are different methods to control the same internal setting. | ||||||
|  | 
 | ||||||
|  | **Note:** When auto-trigger mode is selected, the downsample factor must be at least 2. | ||||||
|  | When 4 channels are active, the downsample factor must be at least 2, or 4 if auto-trigger mode is selected. | ||||||
|  | 
 | ||||||
|  | ### `AIN:SRATE:MODE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:SRATE:MODE mode` <br> | ||||||
|  | Parameter _mode_: downsample mode, either `DECIMATE` or `AVERAGE`. | ||||||
|  | 
 | ||||||
|  | This command selects downsampling by means of decimation or averaging. | ||||||
|  | Downsampling works by collecting groups of consecutive raw ADC samples and translating each group into a single downsampled value. | ||||||
|  | The number of raw samples per group is determined by the downsample factor (see `AIN:SRATE:DIVISOR`). | ||||||
|  | In mode `DECIMATE`, the first sample of a group is used as downsampled value; the other samples in the group are discarded. | ||||||
|  | In mode `AVERAGE`, the sum of all samples in a group is used as downsampled value. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:SRATE:MODE?` <br> | ||||||
|  | Response: either `DECIMATE` or `AVERAGE`. | ||||||
|  | 
 | ||||||
|  | ### `AIN:SRATE:GAIN?` | ||||||
|  | 
 | ||||||
|  | Query: `AIN:SRATE:GAIN?` <br> | ||||||
|  | Response: floating point number representing the effective gain factor due to downsampling. | ||||||
|  | 
 | ||||||
|  | The value returned by this query depends on the downsample factor and the downsample mode. | ||||||
|  | 
 | ||||||
|  | In downsample mode `DECIMATE`, this query always returns 1.0. | ||||||
|  | In downsample mode `AVERAGE`, this query returns a number between 1 and 1024. | ||||||
|  | 
 | ||||||
|  | ### `AIN:NSAMPLES` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:NSAMPLES n` <br> | ||||||
|  | Parameter _n_: decimal integer specifying the number of samples per channel per trigger. | ||||||
|  | 
 | ||||||
|  | This command configures the number of (downsampled) samples to collect for each trigger. | ||||||
|  | Valid values are from 1 to 65536. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:NSAMPLES?` <br> | ||||||
|  | Response: decimal integer representing the number of samples per trigger. | ||||||
|  | 
 | ||||||
|  | ### `AIN:TRIGGER` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:TRIGGER` | ||||||
|  | 
 | ||||||
|  | This command forces a trigger to occur, regardless of the configured trigger mode. | ||||||
|  | 
 | ||||||
|  | Note that even a forced trigger may be ignored if the acquisition chain is still processing a previous trigger. | ||||||
|  | 
 | ||||||
|  | ### `AIN:TRIGGER:MODE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:TRIGGER:MODE mode` <br> | ||||||
|  | Parameter _mode_: trigger mode, either `NONE` or `AUTO` or `EXTERNAL` or `EXTERNAL_ONCE`. | ||||||
|  | 
 | ||||||
|  | **Note:** When trigger mode `EXTERNAL_ONCE` is selected, the trigger mode automatically changes to `NONE` as soon as a trigger occurs. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:TRIGGER:MODE?` <br> | ||||||
|  | Response: active trigger mode. | ||||||
|  | 
 | ||||||
|  | ### `AIN:TRIGGER:DELAY` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:TRIGGER:DELAY n` <br> | ||||||
|  | Parameter _n_: decimal integer specifying trigger delay as a number of 8 ns cycles. | ||||||
|  | 
 | ||||||
|  | This configures a delay between trigger detection and the start of sample collection. | ||||||
|  | Valid values are from 0 to 65535. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:TRIGGER:DELAY?` <br> | ||||||
|  | Response: decimal integer representing the trigger delay as a number of 8 ns cycles. | ||||||
|  | 
 | ||||||
|  | ### `AIN:TRIGGER:STATUS?` | ||||||
|  | 
 | ||||||
|  | Query: `AIN:TRIGGER:STATUS?` <br> | ||||||
|  | Response: trigger status, either `BUSY` or `WAITING`. | ||||||
|  | 
 | ||||||
|  | This query returns `BUSY` when the acquisition chain is processing a trigger, or `WAITING` if the acquisition chain is waiting for a trigger. | ||||||
|  | 
 | ||||||
|  | ### `AIN:TRIGGER:EXT:CHANNEL` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:TRIGGER:EXT:CHANNEL n` <br> | ||||||
|  | Parameter _n_: decimal integer specifying a digital input channel, in range 0 to 3. | ||||||
|  | 
 | ||||||
|  | This command selects the digital input channel to use as external trigger. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:TRIGGER:EXT:CHANNEL?` <br> | ||||||
|  | Response: decimal integer specifying the selected digital input channel. | ||||||
|  | 
 | ||||||
|  | ### `AIN:TRIGGER:EXT:EDGE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:TRIGGER:EXT:EDGE edge` <br> | ||||||
|  | Parameter _edge_: trigger edge, either `RISING` or `FALLING`. | ||||||
|  | 
 | ||||||
|  | This command selects rising or falling edges in the external trigger signal. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:TRIGGER:EXT:EDGE?` <br> | ||||||
|  | Response: either `RISING` or `FALLING`. | ||||||
|  | 
 | ||||||
|  | ### `AIN:ACQUIRE:ENABLE` | ||||||
|  | 
 | ||||||
|  | Command: `AIN:ACQUIRE:ENABLE en` <br> | ||||||
|  | Parameter _en_: either `0` or `1`. | ||||||
|  | 
 | ||||||
|  | This command enables or disables analog acquisition. | ||||||
|  | When enabled, analog samples are acquired according to the configured trigger mode. | ||||||
|  | When disabled, all triggers are ignored and any ongoing analog acquisition stops immediately. | ||||||
|  | 
 | ||||||
|  | Query: `AIN:ACQUIRE:ENABLE?` <br> | ||||||
|  | Response: either `0` or `1`. | ||||||
|  | 
 | ||||||
|  | ### `TT:SAMPLE?` | ||||||
|  | 
 | ||||||
|  | Query: `TT:SAMPLE?` <br> | ||||||
|  | Response: array of 4 digits `0` or `1`, separated by space characters. | ||||||
|  | 
 | ||||||
|  | This query returns the input state of all digital input channels. | ||||||
|  | 
 | ||||||
|  | ### `TT:EVENT:MASK` | ||||||
|  | 
 | ||||||
|  | Command: `TT:EVENT:MASK mask` <br> | ||||||
|  | Parameter _mask_: decimal integer specifying a bit mask of enabled events. | ||||||
|  | 
 | ||||||
|  | This command configures the set of enabled timetagger events. | ||||||
|  | The integer value of _mask_ represents an 8-bit mask. | ||||||
|  | Each bit position denotes an event type, as follows: | ||||||
|  | 
 | ||||||
|  | | Bit index | Value | Description | | ||||||
|  | |-----------|-------|-------------| | ||||||
|  | | 0         | 1     | Rising edge on digital input 0. | | ||||||
|  | | 1         | 2     | Falling edge on digital input 0. | | ||||||
|  | | 2         | 4     | Rising edge on digital input 1. | | ||||||
|  | | 3         | 8     | Falling edge on digital input 1. | | ||||||
|  | | 4         | 16    | Rising edge on digital input 2. | | ||||||
|  | | 5         | 32    | Falling edge on digital input 2. | | ||||||
|  | | 6         | 64    | Rising edge on digital input 3. | | ||||||
|  | | 7         | 128   | Falling edge on digital input 3. | | ||||||
|  | 
 | ||||||
|  | Query: `TT:EVENT:MASK?` <br> | ||||||
|  | Response: decimal integer representing the event mask. | ||||||
|  | 
 | ||||||
|  | ### `TT:MARK` | ||||||
|  | 
 | ||||||
|  | Command: `TT:MARK` | ||||||
|  | 
 | ||||||
|  | This command emits a marker record in the timetagger event stream. | ||||||
|  | 
 | ||||||
|  | ### `TEMP:FPGA?` | ||||||
|  | 
 | ||||||
|  | Query: `TEMP:FPGA?` <br> | ||||||
|  | Response: floating point number representing the temperature in Celsius. | ||||||
|  | 
 | ||||||
|  | The temperature is measured by the internal temperature sensor of the Zynq FPGA. | ||||||
|  | 
 | ||||||
|  | ### `IPCFG[:SAVED]` | ||||||
|  | 
 | ||||||
|  | Command: `IPCFG DHCP` <br> | ||||||
|  | Command: `IPCFG STATIC ipaddr netmask gateway` <br> | ||||||
|  | Parameter _ipaddr_: IPv4 address in dotted-quad notation. <br> | ||||||
|  | Parameter _netmask_: netmask in dotted-quad notation. <br> | ||||||
|  | Parameter _gateway_: optional gateway address in dotted-quad notation. | ||||||
|  | 
 | ||||||
|  | This command configures the IP address of the system. | ||||||
|  | It expects between 1 and 4 parameters, depending on the specific address configuration. | ||||||
|  | 
 | ||||||
|  | If address mode `DHCP` is selected, the command expects no further parameters. | ||||||
|  | In this mode, the system attempts to get an IPv4 address from a DHCP server on the local network. | ||||||
|  | 
 | ||||||
|  | If address mode `STATIC` is selected, the command expects 2 or 3 additional parameters to specify the address, netmask and optional gateway. | ||||||
|  | IP addresses are specified in _dotted-quad_ notation: 4 decimal integers separated by period characters. | ||||||
|  | The parameter _gateway_ may be omitted or specified as `0.0.0.0` to indicate that no gateway should be used. | ||||||
|  | 
 | ||||||
|  | The command `IPCFG` takes effect immediately. | ||||||
|  | This command does not send an `OK` response. | ||||||
|  | Instead, all TCP connections are closed while the system prepares to change its IP address. | ||||||
|  | Changing the IP address typically takes a few seconds. | ||||||
|  | When the new address is active, the client may re-connect to the new IP address. | ||||||
|  | 
 | ||||||
|  | **Note:** Configuring an invalid IP address may make the system unreachable. | ||||||
|  | In that case, the saved IP address configuration can be restored by power-cycling the system. | ||||||
|  | 
 | ||||||
|  | Command: `IPCFG:SAVED DHCP` <br> | ||||||
|  | Command: `IPCFG:SAVED STATIC ipaddr netmask gateway` | ||||||
|  | 
 | ||||||
|  | This variant of the command configures the saved IP address configuration. | ||||||
|  | It uses the same set of parameters as `IPCFG`. | ||||||
|  | This command has no effect on the active IP address. | ||||||
|  | When the command completes, it sends an `OK` response and the system continues to function normally. | ||||||
|  | The saved address configuration takes effect on the next reboot of the system. | ||||||
|  | 
 | ||||||
|  | Query: `IPCFG?` <br> | ||||||
|  | Query: `IPCFG:SAVED?` <br> | ||||||
|  | Response: active or saved IP address configuration. | ||||||
|  | 
 | ||||||
|  | ### `HALT` | ||||||
|  | 
 | ||||||
|  | Command: `HALT` | ||||||
|  | 
 | ||||||
|  | This command iniates a shutdown of the system. | ||||||
|  | It does not send an `OK` response. | ||||||
|  | Instead, all TCP connections are closed while the system initiates shutdown. | ||||||
|  | 
 | ||||||
|  | The halt command causes the system to become unresponsive to further commands. | ||||||
|  | To recover from the halt state, the system must be power-cycled. | ||||||
|  | 
 | ||||||
|  | ### `REBOOT` | ||||||
|  | 
 | ||||||
|  | Command: `REBOOT` | ||||||
|  | 
 | ||||||
|  | This command initiates a system reboot. | ||||||
|  | It does not send an `OK` response. | ||||||
|  | Instead, all TCP connections are closed while the system initiates shutdown. | ||||||
|  | 
 | ||||||
|  | A reboot involves a complete reset of the FPGA and the embedded ARM processor. | ||||||
|  | The system then proceeds as if just powered on. | ||||||
|  | 
 | ||||||
		Loading…
	
		Reference in New Issue