From 529d74872ed6f0881865c9f37d459420a680d8fd Mon Sep 17 00:00:00 2001 From: Martina Gloria <114698424+martinaxgloria@users.noreply.github.com> Date: Fri, 27 Oct 2023 17:01:50 +0200 Subject: [PATCH] First attempt to add ergocub sw documentation (#318) Co-authored-by: Ugo Pattacini --- .../ergocub_torso/install_from_scratch.md | 15 +++++ docs/ergocub_operating_systems/index.md | 14 ++++ docs/ergocub_operating_systems/network.md | 64 +++++++++++++++++++ .../icubos/installation-from-scratch.md | 4 +- docs/icub_operating_systems/icubos/jetpack.md | 39 +++++------ .../icub-server-from-scratch.md | 2 +- docs/icub_sw.md | 2 + docs/index.md | 2 +- mkdocs.yml | 7 ++ 9 files changed, 127 insertions(+), 22 deletions(-) create mode 100644 docs/ergocub_operating_systems/ergocub_torso/install_from_scratch.md create mode 100644 docs/ergocub_operating_systems/index.md create mode 100644 docs/ergocub_operating_systems/network.md diff --git a/docs/ergocub_operating_systems/ergocub_torso/install_from_scratch.md b/docs/ergocub_operating_systems/ergocub_torso/install_from_scratch.md new file mode 100644 index 000000000..004c28fce --- /dev/null +++ b/docs/ergocub_operating_systems/ergocub_torso/install_from_scratch.md @@ -0,0 +1,15 @@ +# Install from scratch + +`ergocub-torso` is based on Ubuntu server 22.04, we will install it from the default installer and then we manually customize it. + +To install the OS from scratch, please follow [this guide](../../icub_operating_systems/icubos/installation-from-scratch.md), being careful to install the [**Ubuntu 22.04 LTS Server**](https://releases.ubuntu.com/focal). + +!!! note + Remember to substitute the references to **`icub`** and **`icub-head`** respectively with **`ergocub`** and **`ergocub-torso`**. + +To synchronize the system date and time, edit the file `/etc/default/ntpdate` by changing the following lines: + +``` +NTPDATE_USE_NTP_CONF="no" +NTPSERVERS="10.0.2.1 ntp.ubuntu.com" +``` diff --git a/docs/ergocub_operating_systems/index.md b/docs/ergocub_operating_systems/index.md new file mode 100644 index 000000000..0ff43e051 --- /dev/null +++ b/docs/ergocub_operating_systems/index.md @@ -0,0 +1,14 @@ +# Introduction + +This manual describes how to install and customize the linux operating systems required to run on machines in the ergoCub enviroment. + +The ergoCub robot relies on two machines: `ergocub-head`, a [`NVIDIA Jetson Xavier AGX`](https://www.nvidia.com/en-us/autonomous-machines/embedded-systems/jetson-xavier-series/) used to control the realsense camera, the lidar and the OLED display, and `ergocub-torso`, which is a [`COM express type 10`](https://www.advantech.com/en-eu/products/0a009637-4f9d-4541-8624-a55de3ffb2a6/som-7583/mod_17ca9251-bdf5-4f74-9256-edd63a373b39) that controls the motors. + +# OS configurations + +The following guides will help you to properly configure the OS for the specific board. + +- [ergocub-head](../icub_operating_systems/icubos/jetpack.md) +- [ergocub-torso](ergocub_torso/install_from_scratch.md) + +Alternatively, you can download the OS pre-built images [here](../icub_operating_systems/download.md). diff --git a/docs/ergocub_operating_systems/network.md b/docs/ergocub_operating_systems/network.md new file mode 100644 index 000000000..f5405ab91 --- /dev/null +++ b/docs/ergocub_operating_systems/network.md @@ -0,0 +1,64 @@ +# ergoCub network + +The network on ergocub can be divided in two parts: + +- **internal network (10.0.1.0/24)**: it connects `ergocub-torso` to all the motor controller boards on the robot, it is a segregated network (there is no connection from the nodes on its subnet and the ouside world) and it is used to send motor commands from ergocub-torso to motor control boards; +- **extenal network (10.0.2.0/24)**: it is managed by the ergocub-server and it connects all the ergoCub machines together, handling the internet connection too. This connection can be _wired_ or _wireless_; +- **backup network (10.0.0.0/24)**: this is a backup/troubleshoot network for connecting directly to the robot in case of not reaching the external network. + + +## ergoCub network interfaces + +- `ergocub-torso` + + On ergocub-torso, one of the two ethernet interfaces is connected to the internal network. The other one, instead, is directly connected to ergocub-head via backup network. + +- `ergocub-head` + + On ergocub-head, the ethernet interfaces are bridged together on the backup network. + +Both head and torso are connected to the external network via WiFi. + +## IP addresses and other network configurations + +Below you can find the default network parameters of the ergoCub networks. + +### Internal network configurations + +This configuration depends deeply on the motor control board firmware and thus it can't be changed. + +- **IP address** : 10.0.1.104 - _STATIC_ +- **Netmask** : 255.255.255.0 + +Since this is a segregated network, there is no default gateway. + +### External network configurations + +Usually, it is a static configuration, but it works also in DHCP mode. This configuration _can be changed_ but it is not recommended. + +For `ergocub-torso`: + +- **WiFi IP address** : 10.0.2.2 +- **Netmask** : 255.255.255.0 +- **Default Gateway** : 10.0.2.1 +- **DNS server** : 10.0.2.1 + +For `ergocub-head`: + +- **WiFi IP address** : 10.0.2.3 +- **Netmask** : 255.255.255.0 +- **Default Gateway** : 10.0.2.1 +- **DNS server** : 10.0.2.1 + +### Backup network configurations + +For `ergocub-torso`: + +- **IP address** : 10.0.0.2 +- **Netmask** : 255.255.255.0 + +For `ergocub-head`: + +- **IP address** : 10.0.0.3 +- **Netmask** : 255.255.255.0 + diff --git a/docs/icub_operating_systems/icubos/installation-from-scratch.md b/docs/icub_operating_systems/icubos/installation-from-scratch.md index 049d1fada..2b9cb8589 100644 --- a/docs/icub_operating_systems/icubos/installation-from-scratch.md +++ b/docs/icub_operating_systems/icubos/installation-from-scratch.md @@ -1,6 +1,6 @@ # The OS on icub-head - Installation from scratch -Since iCubOS is based on the Ubuntu server, we will install it from the default installer and then manually customize it. +Since iCubOS is based on the Ubuntu server, we will install the latter from the default installer and then manually customize it. ## Latest versions @@ -40,7 +40,7 @@ Install the system by choosing the default options, except for the following ste #### Identity - **Your name** : `icub` -- **Your Server's name** : `icub-head' +- **Your Server's name** : `icub-head` - **Pick a username** : `icub` - **Choose a password** : `icub` diff --git a/docs/icub_operating_systems/icubos/jetpack.md b/docs/icub_operating_systems/icubos/jetpack.md index 601ff01a7..860c869da 100644 --- a/docs/icub_operating_systems/icubos/jetpack.md +++ b/docs/icub_operating_systems/icubos/jetpack.md @@ -1,7 +1,8 @@ # The NVIDIA JetPack - Introduction -This guide is intended for a developer that wants to flash and setup the Nvidia Jetson Xavier board for the iCub head. -The unit uses a [ConnectTech carrier board](https://connecttech.com/product/quark-carrier-nvidia-jetson-xavier-nx/), so the preliminary instructions will be focused on that specific hardware. +This guide is intended for developers who want to flash and set up the [Nvidia Jetson Xavier boards](https://www.nvidia.com/en-us/autonomous-machines/embedded-systems/jetson-xavier-series/) (i.e., AXG, NX). + +These units use a ConnectTech carrier board ([Quark](https://connecttech.com/product/quark-carrier-nvidia-jetson-xavier-nx/) for the Xavier NX, [Rogue](https://connecttech.com/product/rogue-carrier-nvidia-jetson-agx-xavier/) for the AGX), so the preliminary instructions will be focused on that specific hardware. # Requirements @@ -9,7 +10,7 @@ The unit uses a [ConnectTech carrier board](https://connecttech.com/product/quar - x86 PC/laptop for downloading Jetpack and flashing the OS - USB-C to USB-A (or USB-C to USB-C) cable to connect the PC to the ConnecTech carrier - Power supply cable -- Bench/System/ATE programmable DC power supply, capable of supplying 20V / 2A +- Bench/System/ATE programmable DC power supply, capable of supplying 20V/2A - (optional) Ethernet cable to connect the Xavier to access it with SSH To use the Xavier directly without SSHing into it: @@ -23,8 +24,7 @@ On the developer's host PC: - Nvidia JetPack installed through SDK Manager (instructions below) - Xavier [Connecttech BSP](https://connecttech.com/product/quark-carrier-nvidia-jetson-xavier-nx/) for the `board_type` board (e.g. AGX, NX) and JetPack `jetpack_ver`(e.g 4.4.2, 5.0.2). (Not required if you already have the image ready to flash) - -# Intructions +# Instructions ## Carrier hardware configuration Make sure that the switches on the carrier are set like in the picture below, so that the unit can boot manually when pressing the power (PWR) button. DO NOT power on the unit until instructed. @@ -33,10 +33,10 @@ Make sure that the switches on the carrier are set like in the picture below, so ## Hardware connection -1. Connect the carrier to the power supply through the provided cable, and set the power supply to 16V / 2A +1. Connect the carrier to the power supply through the provided cable, and set the power supply to 16V/2A. 2. Keep the power supply OFF. 3. Connect the HDMI cable, and the mouse/keyboard to the carrier. -4. Use the USB-C cable to connect the PC to the OTG USB port on the carrier +4. Use the USB-C cable to connect the PC to the OTG USB port on the carrier. ![](../img/usbotg.jpg) @@ -48,16 +48,15 @@ If you need to install an new JetPack image from scratch please follow the follo ### Jetpack setup on the host 1. Download the Nvidia SDK manager from the [official website](https://developer.nvidia.com/embedded/jetpack) by clicking *Download Nvidia SDK Manager* - 2. Run SDKManager and login with developer.nvidia.com credentials, and follow these steps: 1. Set the following options: - Target Hardware: Jetson Xavier `board_type` - Target operating system: *Linux Jetpack `jetpack_ver`*. 2. Check that everything is selected and continue - 3. The SDKManager will ask the user password to download all the components and it will install them into a local folder on the host (~12Gb of free space required); Remember, this is the password of the local Ubuntu host, not the Jetson Xavier. - 4. After the installation, the SDK Manager will be ready to flash the OS image on the Xavier; **Do not preceed further!** Press SKIP to abort the operation and quit from the SDK Manager -3. Download the ConnectTech board support package from the [official website](https://connecttech.com/product/quark-carrier-nvidia-jetson-xavier-nx/): under Downloads click on the bsp you need, it will be downloaded as `.tgz` archive. -4. At this point the `sdkManager` should have created a folder tree in `~/nvidia` containing all the files needed for the flash. Copy the `.tgz` package downloaded from Connectech website into `~/nvidia/nvidia_sdk/JetPack__Linux_/Linux_for_Tegra/` + 3. The SDKManager will ask the user password to download all the components and it will install them into a local folder on the host (~12Gb of free space required); remember: this is the password of the local Ubuntu host, not the Jetson Xavier. + 4. After the installation, the SDK Manager will be ready to flash the OS image on the Xavier; **Do not preceed further!** Press SKIP to abort the operation and quit from the SDK Manager +3. Download the ConnectTech board support package from the [official website](https://connecttech.com/product/quark-carrier-nvidia-jetson-xavier-nx/): under Downloads click on the BSP you need, it will be downloaded as `.tgz` archive. +4. At this point the `sdkManager` should have created a folder tree in `~/nvidia` containing all the files needed for the flash. Copy the `.tgz` package downloaded from ConnectTech website into `~/nvidia/nvidia_sdk/JetPack__Linux_/Linux_for_Tegra/` 5. Extract the BSP: `tar -xzf CTI-<*>.tgz` Before flashing the image, we need first to put the board in recovery mode. @@ -65,14 +64,17 @@ Before flashing the image, we need first to put the board in recovery mode. ### Booting the Xavier in Recovery mode -With the Nvidia Jetson Xavier AGX: +With the **Nvidia Jetson Xavier AGX**: + 1. Press the Force Recovery (FR) button on the carrier and keep it pressed 2. Turn on the power supply (16V) 3. Wait for several seconds, keeping the FR button pressed 4. Press the power (PWR) button for at least one second. Wait for several seconds -5. Release the FR button. Now the board is programming mode +5. Release the FR button. + +Now the board is programming mode. -With a Nvidia Jetson Xavier NX, instead, keep the button RST/RECOVERY pressed for several seconds and then, when released, the board will be in recovery mode. +With a **Nvidia Jetson Xavier NX**, instead, keep the button RST/RECOVERY pressed for several seconds and then, when released, the board will be in recovery mode. In order to check that the board went in recovery mode, run on a terminal in the host @@ -92,7 +94,7 @@ At this point we are ready to flash, in the host: 1. Change into the CTI-L4T directory: `cd ./CTI-L4T` 2. Run the install script (as root or sudo) to automatically install the BSP files to the correct locations: `sudo ./install.sh` -[Here](https://connecttech.com/resource-center/kdb373/) you can find the tutorial about the procedure by Connecttech. +[Here](https://connecttech.com/resource-center/kdb373/) you can find the tutorial about the procedure by ConnectTech. ### Verify the installation @@ -103,11 +105,12 @@ After configuring the system, the Xavier should boot normally and be ready to us #### Complete the OEM installation After booting into the OS, follow the OEM installation with the following options: + 1. Accept the license agreement 2. Select English language 3. Select the English (US) keyboard layout 4. Select the preferred time zone -5. User the user name `icub` with the hostname `icub-head-cam` +5. Set the user name to `icub` with the hostname `icub-head-cam` or `ergocub` with hostname `ergocub-head`, depending on the robot the board will be mounted on 6. Allow login without password 7. Let the installation process finish @@ -128,7 +131,7 @@ For example **Jetpack 4.5.1**, which uses **Cuda 10.2** do: sudo apt install cuda-libraries-dev-10-1 cuda-nvcc-10-2 ``` -Then, append to the `.bashrc` file located in `/home/icub/`: +Then, within the `.bashrc`: ```bash export CUDA_HOME=/usr/local/cuda-10.2 diff --git a/docs/icub_operating_systems/other-machines/icub-server-from-scratch.md b/docs/icub_operating_systems/other-machines/icub-server-from-scratch.md index 5ae15d174..46aa264b6 100644 --- a/docs/icub_operating_systems/other-machines/icub-server-from-scratch.md +++ b/docs/icub_operating_systems/other-machines/icub-server-from-scratch.md @@ -1,5 +1,5 @@ # The iCub Dedicated Server - Installation from scratch -Since iCubOS is based on Ubuntu server, we will install Ubuntu server from the default installer and the we manually costimize it. +Since iCubOS is based on Ubuntu server, we will install Ubuntu server from the default installer and then we manually customize it. ## Latest versions Latest version is based on Ubuntu Server 20.04.2 diff --git a/docs/icub_sw.md b/docs/icub_sw.md index 35a8c4c98..656a00101 100644 --- a/docs/icub_sw.md +++ b/docs/icub_sw.md @@ -3,8 +3,10 @@ - [`Software Installation`](./sw_installation/index.md) - [`Software Versioning Table`](./sw_versioning_table/index.md) - [`The OS for the iCub environment`](./icub_operating_systems/index.md) +- [`The OS for the ergoCub environment`](./ergocub_operating_systems/index.md) - [`The YARP Documentation`](https://yarp.it/latest/) - [`The iCub Software Documentation`](https://robotology.github.io/robotology-documentation/doc/html/index.html) +- [`The ergoCub Software Documentation`](https://icub-tech-iit.github.io/ergocub-software/) - [`How to set up multiple iCubs on the same network`](./icub_setup_multiple_robots/index.md) - [`iCub Firmware`](./icub_firmware/index.md) - [`iCub Microphones`](./icub_microphones/icub_microphones.md) diff --git a/docs/index.md b/docs/index.md index f811ef723..f6f93d317 100644 --- a/docs/index.md +++ b/docs/index.md @@ -9,4 +9,4 @@ #### [:gear:{.blink} Documentation resources on the `iCub Hardware`](icub_hw.md) -#### [:computer:{.blink} Documentation resources on the `iCub Software`](icub_sw.md) +#### [:computer:{.blink} Documentation resources on the `iCub Software`](icub_sw.md) \ No newline at end of file diff --git a/mkdocs.yml b/mkdocs.yml index fab0d988f..6f19c866c 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -209,6 +209,13 @@ nav: - Manual Installation: - icub-head: sw_installation/icub_head_manual.md - Software Versioning Table: sw_versioning_table/index.md + - The OS for the ergoCub environment: + - Summary: ergocub_operating_systems/index.md + - Network: ergocub_operating_systems/network.md + - ergocub-head: + - Jetpack installation: icub_operating_systems/icubos/jetpack.md + - ergocub-torso: + - Installation from scratch: ergocub_operating_systems/ergocub_torso/install_from_scratch.md - The OS for the iCub environment: - Summary: icub_operating_systems/index.md - The OS on icub-head: