aboutsummaryrefslogtreecommitdiffstats
path: root/host
diff options
context:
space:
mode:
Diffstat (limited to 'host')
-rw-r--r--host/docs/devices.dox2
-rw-r--r--host/docs/usrp_n3xx.dox322
2 files changed, 270 insertions, 54 deletions
diff --git a/host/docs/devices.dox b/host/docs/devices.dox
index d3bd78cc3..56b09b2b9 100644
--- a/host/docs/devices.dox
+++ b/host/docs/devices.dox
@@ -15,7 +15,7 @@
## USRP N-Series Devices
\li \subpage page_usrp2 "USRP N2x0 Series"
-\li \subpage page_n3xx "USRP N3xx Series"
+\li \subpage page_usrp_n3xx "USRP N3xx Series"
## USRP B-Series Devices
diff --git a/host/docs/usrp_n3xx.dox b/host/docs/usrp_n3xx.dox
index d51a8a6f4..22dd3fe22 100644
--- a/host/docs/usrp_n3xx.dox
+++ b/host/docs/usrp_n3xx.dox
@@ -5,9 +5,9 @@
\section n3xx_feature_list Comparative features list
- Hardware Capabilities:
- - Dual SFP+ Transceivers (can be used with 1 GigE, 10 GigE)
+ - Dual SFP+ Transceivers (can be used with 1 GigE, 10 GigE, and Aurora)
- External PPS input & output
- - External 10 MHz input & output
+ - External 10 MHz input & output (20 MHz and 25 MHz inputs also supported)
- Internal 25 MHz reference clock
- Internal GPSDO for timing, location, and 20 MHz reference clock + PPS
- External GPIO Connector with UHD API control
@@ -26,69 +26,195 @@
The N3XX series of USRPs is designed as a platform. The following USRPs are
variants of the N3XX series:
-\section n3xx_feature_list_mg N310 (4-channel transceiver)
+\subsection n3xx_feature_list_mg N310 (4-channel transceiver)
- - Supported master clock rates: 200 MHz and 184.32 MHz
- - 4 RX DDC chains in FPGA
- - 4 TX DUC chain in FPGA
+The N310 is a 4-channel receiver based on the AD9371 transceiver IC. It has two
+daughterboards with one AD9371 each; every daughterboard provides two RF
+channels.
+
+- Supported master clock rates: 122.88 MHz, 125 MHz, 153.6 MHz
+- Tuning range: 10 MHz to 6 GHz (below 300 MHz, additional LOs and mixer stages
+ are required to shift the signal into the frequency range of the AD9371
+ transceiver)
+- 4 RX DDC chains in FPGA
+- 4 TX DUC chain in FPGA
-\section n3xx_getting_started Getting started
-This will run you through the first steps relevant to get your USRP N300/N310
-up and running.
+\section n3xx_overview Overview
-\subsection n3xx_getting_started_assembling Assembling the N300/N310 kit
+\subsection n3xx_micro The STM32 microcontroller
tbw
-\subsubsection n3xx_serial Serial connection
+\subsection n3xx_sdcard The SD card
+
+The N3XX series uses a micro SD card as its main storage. The entire root file
+system (Linux kernel, libraries) and any user data are stored on this SD card.
+
+The SD card is partitioned into four partitions:
+
+1. Boot partition (contains the bootloader). This partition usually does not
+ require touching.
+2. A data partition, mounted in /data. This is the only partition that is not
+ erased during file system updates.
+2. Two identical system partitions (root file systems). These contain the
+ operating system and the home directory (anything mounted under / that is not
+ the data or boot partition). The reason there are two of these is to enable
+ remote updates: An update running on one partition can update the other one
+ without any effect to the currently running system. Note that the system
+ partitions are erased during updates and are thus unsuitable for permanently
+ storing information.
+
+Note: It is possible to access the currently inactive root file system by
+mounting it. After logging into the device using serial console or SSH (see the
+following two sections), run the following commands:
+
+ $ mkdir temp
+ $ mount /dev/mmcblk0p3 temp
+ $ ls temp # You are now accessing the idle partition:
+ bin data etc lib media proc sbin tmp usr
+ boot dev home lost+found mnt run sys uboot var
+
+The device node in the mount command will likely differ, depending on which
+partition is currently already mounted.
+
+
+\section n3xx_getting_started Getting started
+
+This will run you through the first steps relevant to getting your USRP N3XX
+series up and running.
+
+\subsection n3xx_getting_started_assembling Assembling the N3XX
+
+Unlike the X300 or N200 series, there is no assembly of daughterboards required.
+Members of the N3XX product family, such as the N310, ship with daughterboards
+pre-installed.
+
+TODO: Sync with getting-started guide
+
+Checklist:
+- Connect power and network
+- Read security settings
+- Connect clocking (if required)
+- Connect external LOs (if required)
+
+\subsection n3xx_getting_started_fpga_update Updating the file system
+
+Before doing any major work with a newly acquired USRP N3XX, it is recommended
+to update the file system to the latest version. By default, the N3xx supports
+two methods of updating:
+
+1. Directly writing the latest SD card image. This requires physical access to
+ the device. To do this, remove the SD card from the device, and plug it into
+ another computer with an SD card reader. Download the latest SD card image
+ file (it typically has a `.sdimg` file ending) and run the following command:
+
+ $ sudo dd if=<yourimage>.sdimg of=/dev/<yoursdcard> bs=1M
+
+ The `<yoursdcard>` device node depends on your operating system and which
+ other devices are plugged in. Typical values are `sdb` or `mmcblk0`.
+
+2. Using Mender to update. For more details on this procedure, see Section
+ \ref n3xx_rasm_mender . This is possible without removing the SD card.
+ Updates will take a bit longer though.
+
+
+\subsection n3xx_getting_started_serial Serial connection
It is possible to gain root access to the device using a serial terminal
-emulator. Most Linuxes, OSX, or other Unix flavours have a tool called 'screen'
+emulator. Most Linux, OSX, or other Unix flavours have a tool called 'screen'
which can be used for this purpose, by running the following command:
$ sudo screen /dev/ttyUSB2 115200
+In this command, we prepend 'sudo' to elevate user privileges (by default,
+accessing serial ports is not available to regular users), we specify the
+device node (in this case, `/dev/ttyUSB2`), and the baud rate (115200).
+
The exact device node depends on your operating system's driver and other USB
-devices that might be already connected.
+devices that might be already connected. Modern Linux systems offer alternatives
+to simply trying device nodes; instead, the OS might have a directory of
+symlinks under `/dev/serial/by-id`:
+
+ $ ls /dev/serial/by-id
+ usb-Digilent_Digilent_USB_Device_25163511FE00-if00-port0
+ usb-Digilent_Digilent_USB_Device_25163511FE00-if01-port0
+ usb-Silicon_Labs_CP2105_Dual_USB_to_UART_Bridge_Controller_007F6CB5-if00-port0
+ usb-Silicon_Labs_CP2105_Dual_USB_to_UART_Bridge_Controller_007F6CB5-if01-port0
+
+Note: Exact names depend on the host operating system version and may differ.
+
+Every N3XX series device connected to USB will by default show up as four
+different devices. The devices labeled "USB_to_UART_Bridge_Controller" are the
+devices that offer a serial prompt. The first (with the `if00` suffix) connects
+to Linux, whereas the second connects to the STM32 microcontroller.
+If you have multiple N3XX devices connect, you may have to try out multiple
+devices. In this case, to use this symlink instead of the raw device node
+address, modify the command above to:
+
+ $ sudo screen /dev/usb-Silicon_Labs_CP2105_Dual_USB_to_UART_Bridge_Controller_007F6CB5-if00-port0 115200
+
+You should be presented with a shell prompt similar to the following:
+
+ root@ni-n3xx-311FE00:~#
+
+On this prompt, you can enter any Linux command available. Using the default
+configuration, the serial console will also show all kernel log messages (unlike
+when using SSH, for example), and give access to the boot loader (U-boot
+prompt). This can be used to debug kernel or bootloader issues more efficiently
+than when logged in via SSH.
-(TODO: Expand upon how to figure this out, include /dev/serial/by-id)
+\subsubsection n3xx_getting_started_serial_micro Connecting to the microcontroller
-You should be presented with a shell similar to the following
+The STM32 microcontroller (which controls the power sequencing, among other
+things) also has a serial console available. To connect to the microcontroller,
+use the other UART device. In the example above:
- root@ni-sulfur-<serial>:~#
+ $ sudo screen /dev/usb-Silicon_Labs_CP2105_Dual_USB_to_UART_Bridge_Controller_007F6CB5-if01-port0 115200
+It provides a very simple prompt. The command 'help' will list all available
+commands. A direct connection to the microcontroller can be used to hard-reset
+the device without physically accessing it (i.e., emulating a power button press)
+and other low-level diagnostics.
-\subsubsection n3xx_ssh SSH connection
+\subsection n3xx_ssh SSH connection
-The USRP N-Series devices have two network connnections: The dual SFP ports,
-and a RJ-45 connector. The latter is by default configured by DHCP; by plugging
+The USRP N-Series devices have two network connections: The dual SFP ports,
+and an RJ-45 connector. The latter is by default configured by DHCP; by plugging
it into into 1 Gigabit switch on a DHCP-capable network, it will get assigned
an IP address and thus be accessible via ssh.
In case your network setup does not include a DHCP server, refer to the section
-\ref n3xx_serial. A serial login can be used to assign an IP address manually.
+\ref n3xx_getting_started_serial. A serial login can be used to assign an IP address manually.
After the device obtained an IP address you can log in from a Linux or OSX
machine by typing:
- $ ssh root@192.168.10.42
+ $ ssh root@ni-n3xx-311FE00 # Replace with your actual device name!
+
+Depending on your network setup, using a `.local` domain may work:
+
+ $ ssh root@ni-n3xx-311FE00.local
+
+Of course, you can also connect to the IP address directly if you know it (or
+set it manually using the serial console).
-where the IP address depends on your local network setup.
(TODO: Add the hostname thing here)
On Microsoft Windows, the connection can be established using a tool such as
Putty, by selecting a username of root without password.
-You should be presented with a shell similar to the following (FIXME):
+Like with the serial console, you should be presented with a prompt like the
+following:
- root@ni-sulfur:~#
+ root@ni-n3xx-311FE00:~#
\subsection n3xx_getting_started_connectivity Network Connectivity
The RJ45 port (eth0) comes up with a default configuration of DHCP,
-that will request a network address from your DHCP server.
+that will request a network address from your DHCP server (if available on your
+network).
The SFP+ (eth1, eth2) ports are configured with static addresses 192.168.10.2/24
and 192.168.20.2/24 respectively.
@@ -100,43 +226,43 @@ For configuration please refer to the manual pages
The factory settings are as follows:
-eth0 (DHCP):
+ eth0 (DHCP):
- [Match]
- Name=eth0
+ [Match]
+ Name=eth0
- [Network]
- DHCP=v4
+ [Network]
+ DHCP=v4
- [DHCPv4]
- UseHostname=false
+ [DHCPv4]
+ UseHostname=false
-eth1 (static):
+ eth1 (static):
- [Match]
- Name=eth1
+ [Match]
+ Name=eth1
- [Network]
- Address=192.168.10.2/24
+ [Network]
+ Address=192.168.10.2/24
- [Link]
- MTUBytes=9000
+ [Link]
+ MTUBytes=9000
-eth2 (static):
+ eth2 (static):
- [Match]
- Name=eth2
+ [Match]
+ Name=eth2
- [Network]
- Address=192.168.20.2/24
+ [Network]
+ Address=192.168.20.2/24
- [Link]
- MTUBytes=9000
+ [Link]
+ MTUBytes=9000
Note: Care needs to be taken when editing these files on the device, since vi / vim sometimes generates
undo files (e.g. /etc/systemd/networkd/eth1.network~), that systemd-networkd might pick up.
-Note: Temporarily setting the IP addresses via ifconfig etc will only change the value till the next reboot / reload of the FPGA image.
+Note: Temporarily setting the IP addresses via ifconfig etc will only change the value until the next reboot / reload of the FPGA image.
\subsection n3xx_getting_started_security Security-related settings
@@ -148,7 +274,6 @@ To set a password, run the command
on the device.
-
\subsection n3xx_getting_started_fpga_update Updating the FPGA
tbw (using uhd_image_loader)
@@ -159,9 +284,9 @@ Like any other USRP, all N3XX USRPs are controlled by the UHD software. To
integrate a USRP N3XX into your C++ application, you would generate a UHD
device in the same way you would for any other USRP:
-~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.cpp}
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.cpp}
auto usrp = uhd::usrp::multi_usrp::make("type=n3xx");
-~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
For a list of which arguments can be passed into make(), see Section
\ref n3xx_usage_device_args.
@@ -193,10 +318,83 @@ For a list of which arguments can be passed into make(), see Section
\section n3xx_rasm Remote Management
-- Mender
-- Salt
+\subsection n3xx_rasm_mender Mender: Remote update capability
+
+Mender is a third-party software that enables remote updating of the root
+file system without physically accessing the device (see also the
+[Mender website](https://mender.io)). Mender can be executed locally on the
+device, or a Mender server can be set up which can be used to remotely update
+an arbitrary number of USRP devices. Mender servers can be self-hosted, or
+hosted by Mender (see [mender.io](https://mender.io) for pricing and
+availability).
+
+When updating the file system using Mender, the tool will overwrite the root file
+system partition that is not currently mounted (note: every SD card comes with
+two separate root file system partitions, only one is ever used at a single
+time). Any data stored on that partition will be permanently lost. After
+updating that partition, it will reboot into the newly updated partition. Only
+if the update is confirmed by the user, the update will be made permanent. This
+means that if an update fails, the device will be always able to reboot into the
+partition from which the update was originally launched (which presumably is in
+a working state). Another update can be launched now to correct the previous,
+failed update, until it works.
+See also Section \ref n3xx_sdcard.
+
+To initiate an update from the device itself, download a Mender artifact
+containing the update itself. These are files with a `.mender` suffix.
+
+Then run mender on the command line:
+
+ $ mender -rootfs /path/to/latest.mender
+
+The artifact can also be stored on a remote server:
+
+ $ mender -rootfs http://server.name/path/to/latest.mender
+
+This procedure will take a while. After mender has logged a successful update,
+reboot the device:
+
+ $ reboot
+
+If the reboot worked, and the device seems functional, commit the changes so
+the boot loader knows to permanently boot into this partition:
+
+ $ mender -commit
+
+To identify the currently installed Mender artifact from the command line, the
+following file can be queried:
+
+ $ cat /etc/mender/artifact_info
+
+If you are running a hosted server, the updates can be initiated from a web
+dashboard. From there, you can start the updates without having to log into the
+device, and can update groups of USRPs with a few clicks in a web GUI. The
+dashboard can also be used to inspect the state of USRPs. This is simple way to
+update groups of rack-mounted USRPs with custom file systems.
+
+\subsection n3xx_rasm_salt Salt: Remote configuration management and execution
+
+Salt (also known as SaltStack, see [Salt Website](https://saltstack.com)) is a
+Python-based tool for maintaining fleets of remote devices. It can be used to
+manage USRP N3XX series remotely for all types of settings that are not
+controlled by UHD. For example, if an operator would like to reset the root
+password on multiple devices, or install custom software, this tool might be a
+suitable choice.
+
+Salt is a third-party project with its [own documentation](https://docs.saltstack.com/en/latest/),
+which should be consulted for configuring it. However, the Salt minion is
+installed by default on every N3XX device. To start it, simply log on to the
+device and run:
+
+ $ systemctl start salt-minion
+
+To permanently enable it at every boot, run (this won't by itself launch the
+salt-minion):
+
+ $ systemctl enable salt-minion
+
+TODO: Add some example
-tbw
\section n3xx_theory_of_ops Theory of Operation
@@ -211,6 +409,24 @@ tbw
\section n3xx_mg N310-specific Features
+\subsection n3xx_mg_external_lo External LOs
+
+The N310 has inputs for external local oscillators. For every daughterboard,
+there is one input for TX and RX, respectively, resulting in 4 LO inputs total
+per N310.
+
+Reasons to use an external LO include:
+
+- Improving phase alignment: The N310 itself has no way of aligning phase
+ between channels, and phase will be random between runs. By applying an
+ external LO, the phase ambiguity is reduced to 180 degrees, produced by a
+ by-2 divider in the AD9371 transceiver IC.
+- Improving phase noise: The quality of the onboard LO depends on the external
+ reference clock, among other things. By providing a custom LO signal, it is
+ possible to more accurately tune, assuming the externally generated LO signal
+ is coming from a high-quality oscillator.
+
+
\subsection n3xx_mg_eeprom Storing user data in the EEPROM
The N310 daughterboard has an EEPROM which is primarily used for storing the