Ubuntu Focal 20.04 LTS for Nitrogen8M and Nitrogen8M Mini boards – August 2020 (kernel 5.4.x)

Published on August 6, 2020

Ubuntu 20.04 Weston/Wayland Compositor We’re glad to release our first Ubuntu Focal image for Nitrogen8MQ and Nitrogen8M Mini board. Since this board supports only Wayland graphical backend, the system is simpler than earlier systems with i.MX6. We use Weston, the reference Wayland compositor in this system. This image is a console developer image also, it boots to the command prompt. Weston compositor could be started manually or you can set autostart the service, as per your preference. This system contains NXP/Freescale licensed content, so you will need to register on our web-site and log in before you can accept the license agreement and download the images from here: Nitrogen8M board:

Nitrogen8M Mini board:

Important ! Before installing this image please check your U-Boot version as it requires U-Boot version 2018.07  to be used. Make sure to visit our wiki if you need to upgrade:

You can find the bootscript in the /boot subdirectory now, its named boot.scr. The partition labels are set if you use the fastboot method. If you use your own method please check the boot partition labels, because the fstab boots by label (LABEL=sys-0Ch for example) now. You can use e2label to modify partition label.

Programming the image

Since the Nitrogen8M board has no SD card slot, you need to program this image in the same way as an Android  system: by using fastboot. Please install the following packages on your desktop PC, Debian or Ubuntu :

$ sudo apt update
$ sudo apt install fastboot android-tools-fastboot

To avoid using sudo for each command, please download the following file and move it to the /lib/udev/rules.d directory, then reboot your PC:

Now connect your Nitrogen8M board's J67 USB OTG port to your PC's USB port. Use regular USB2.0 OTG cable do not use USB3.0 cable (as it seems to be problematic with U-Boot). Connect the Nitrogen board's RS232 console to your PC so you can communicate with the board. You can then power up the Nitrogen8M board, and stop the u-boot execution by pressing any key. Then type:

Hit any key to stop autoboot: 0
=> fastboot 0

Now test the USB connection on the PC, please type on the PC:

$ sudo fastboot devices -l
 fastboot usb-x:y

If you get the above response, a MAC address , the word fastboot, then the USB device:id numbers, the communication is OK. Now type on PC:

$ sudo fastboot flash gpt gpt_8G.img
$ sudo fastboot flash rootfs rootfs_8G.simg

, then wait till its completed. When its done you can disconnect USB cable, and restart your Nitrogen8M board. Note that you can also use fastboot from a Windows Host PC, see following blog post to learn how: https://boundarydevices.com/android-tools-windows-support-nitrogen-platforms/


Since the Nitrogen8M_Mini board has an SD card slot, not like Nitrogen8M, you can create an SD car similarly to i.MX6 boards. The image is a slightly-less-than-4GiB image file containing the partition table.  Inspired by ubuntu-mate.org, I changed over from dd to another disk copy program called ddrescue. It is a much more talkative program, although dd does do it’s job honestly. I don’t like mute programs, you never know whats happening in a given moment. For example, if you want to create an SD card for a console image, you need to do the following :

$ sudo apt-get install gddrescue xz-utils util-linux
$ gunzip 20200806-nitrogen8mm-5.4.x_2.1.0_ga-focal-en_US-console-weston_aarch64.img.gz
$ sudo ddrescue -D --force 20200806-nitrogen8mm-5.4.x_2.1.0_ga-focal-en_US-console-weston_aarch64.img /dev/sdX

You have to replace sdX with your actual SDHC reader/writer device. Use the lsblk command to check it. Type lsblk with unplugged SDHC reader, then insert the device, and type lsblk again. A new node will be added , that is your SDHC reader/writer device.


Usernames and passwords

Two users are defined for use on the system: ubuntu and root. The password for each is Boundary (capital B). The user ubuntu has administrator rights, but doesn't need to enter password at sudo command. We wanted to make life easier at the cost of some security. If you want to change this please type:

ubuntu@focal-dev64:~$ sudo visudo

, and comment out or delete the last line with "ubuntu" and "NOPASSWD:" An ssh server is configured on the system, though it does not allow password-based authentication for user root. User ubuntu has sudo privileges, so you can place your ssh public key (normally $HOME/.ssh/id_rsa.pub) to the system like so :

ubuntu@focal-dev64:~$ sudo mkdir /root/.ssh
ubuntu@focal-dev64:~$ sudo nano /root/.ssh/authorized_keys
... paste content of $HOME/.ssh/id_rsa.pub here
ubuntu@focal-dev64:~$ sudo chmod 600 /root/.ssh/auth*
ubuntu@focal-dev64:~$ sudo chmod 600 /root/.ssh/

What's supported

Since the images above include our stable 5.4.x kernel, essentially everything is supported including :

  • Vivante GPU accelerations for Wayland
  • The Hantro Video Processing Unit supports the following decoders:
    • video/x-h265 (8MQ + 8MM)
    • video/x-vp9 (8MQ + 8MM)
    • video/x-h264 (8MQ + 8MM)
    • video/x-vp8 (8MQ + 8MM)
    • video/x-vp6-flash (8MQ)
    • video/mpeg (8MQ)
    • video/x-h263 (8MQ)
    • video/x-flash-video (8MQ)
    • video/x-divx (8MQ)
    • video/x-xvid (8MQ)
    • video/x-cavs (8MQ)
    • video/x-wmv (8MQ)
    • video/x-pn-realvideo (8MQ)
    • video/x-raw (8MQ + 8MM)
  • The Hantro Video Processing Unit supports the following encoders:
    • video/x-h265 (8MM)
    • video/x-vp9 (8MM)
    • video/x-h264 (8MM)
    • video/x-vp8 (8MM)
  • Wi-Fi and Bluetooth modules for the built-in Silex module
  • All kind of storage devices , eMMC, SATA hdd (via USB3-SATA adapter), USB3.0/2.0 pen drives, mini PCIe devices, cell modems
  • All of our supported touch panels

The packaging (inluding kernel) is done in the normal debian way, so apt-get update/dist-upgrade will keep your image up and running the latest as patches come out.

What's new in this release

The Linux kernel was upgraded to 5.4.50 ( meta-package name: linux-boundary-18f ) GPU driver was upgraded to Vivante 6.4.0p2.4 ( meta-package name: imx-gpu-viv-f17-... ). The module galcore (CONFIG_MXC_GPU_VIV) was removed from the kernel, and it's an externally built module. This change makes the graphics system modular, and more upgradeable, at the price of longer kernel upgrading time. Upgrading kernel takes about 3-4 minutes now, instead of 30 seconds, because every kernel upgrade rebuilds the galcore driver from sources, because its a DKMS module. The NXP/Vivante GPU SDK was added : imx-gpu-sdk 4.0.2 . You can get the source with the usual apt-get source command. The SDK has many new demos, for example OpenCL, OpenVG, and for OpenVX and Vulkan. The distribution is Focal 20.04 LTS . Here are some main component versions :

  • Xorg server 1.20.8-2ubuntu2.2
  • gstreamer1.0 1.16.2
  • bluez 5.53-0ubuntu3
  • qcacld-lea-2.0 Wi-Fi driver for BD-SDMAC
  • VPU Hantro libraries v1.18.0
  • Qt5 5.12.8
  • apt 2.0.3
  • dpkg 1.19.7ubuntu3.1
  • gcc/g++ 9.3.0-1ubuntu2
  • libwayland 1.18.0
  • weston 6.0.1
  • Silex WiFi / Bluetooth is supported in Focal also, as well as in Bionic and Buster.


Weston playing video via gstreamer.
Running the glmark2 GPU Benchmark
The system boots to the command prompt, as I mentioned before. You can start Weston compositor on any tty (not ssh, not RS232) terminal by typing:

ubuntu@focal-dev64:~$ wl
or
ubuntu@focal-dev64:~$ weston-launch

If you want to start Weston at boot automatically, you have to enable the service, you have to type the following:

ubuntu@focal-dev64:~$ sudo systemctl unmask weston.service
ubuntu@focal-dev64:~$ sudo systemctl enable weston.service

If you want to disable the autostart again you need to type:

ubuntu@focal-dev64:~$ sudo systemctl disable weston.service
ubuntu@focal-dev64:~$ sudo systemctl mask weston.service

You can find the weston.ini file in the /usr/share/weston/examples directory. Please type:

ubuntu@focal-dev64:~$ man weston.ini

,to check the options, and feel free to modify it to suit your needs.    

Weston keyboard bindings

The Weston desktop shell has a number of keyboard shortcuts. They are listed here. Almost all keyboard shortcuts for Weston include a specified modifier mod key which is determined in the file weston.ini (5): [shell] binding-modifier={none | ctrl | alt | super} The mod key is the same as the super key by default. The super key is in between and , usually a key. mod + Shift + F Make active window fullscreen mod + K Kill active window mod + Shift + M Maximize active window mod + PageUp, mod + PageDown Zoom desktop in (or out) mod + Tab Switch active window mod + Up, mod + Down Increment/decrement active workspace number, if there are multiple mod + Shift + Up, mod + Shift + Down Move active window to the succeeding/preceding workspace, if possible mod + F1/F2/F3/F4/F5/F6 Jump to the numbered workspace, if it exists Ctrl + Alt + Backspace If supported, terminate Weston. (Note this combination often is used to hard restart Xorg.) Ctrl + Alt + F Toggle if Weston is fullscreen; only works when nested under a Wayland compositor Ctrl + Alt + S Share output screen, if possible Ctrl + Alt + F1/F2/F3/F4/F5/F6/F7/F8 Switch virtual terminal, if possible super + S Make a screenshot of the desktop super + R Start or stop recording video of the desktop

Weston touch / mouse bindings

There are also a number of bindings involving a mouse: , , Activate clicked window super + Alt + Change the opacity of a window mod + Zoom/magnify the visible desktop mod + Click and drag to move a window mod + Shift + mod + mod + Click and drag to resize a window mod + Rotate the window (if supported)

As always, please give us some feedback and let us know how things work for you.