shell$ apt-get install qemu-user-static debootstrap binfmt-support
shell$ export targetdir=ubuntu22.04-console-rootfs
shell$ export distro=jammy
shell$ mkdir $PWD/$targetdir
shell$ sudo debootstrap --arch=arm64 --foreign $distro $PWD/$targetdir
shell$ sudo cp /usr/bin/qemu-aarch64-static $PWD/$targetdir/usr/bin
shell$ sudo cp /etc/resolv.conf $PWD/$targetdir/etc
shell$ sudo cp scripts/build-ubuntu22.04-console-rootfs.sh $PWD/$targetdir
shell$ sudo cp debian/*.deb $PWD/$targetdir
shell$ sudo mount -vt proc proc $PWD/$targetdir/proc
shell$ sudo mount -vt devpts devpts -o gid=5,mode=620 $PWD/$targetdir/dev/pts
shell$ sudo chroot $PWD/$targetdir
There are two ways
- run build-ubuntu22.04-console-rootfs.sh (easy)
- run this chapter step-by-step (annoying)
ubuntu22.04-rootfs# distro=jammy
ubuntu22.04-rootfs# export LANG=C
ubuntu22.04-rootfs# /debootstrap/debootstrap --second-stage
ubuntu22.04-rootfs# cat <<EOT > /etc/apt/sources.list
deb http://ports.ubuntu.com/ubuntu-ports jammy main restricted universe multiverse
deb-src http://ports.ubuntu.com/ubuntu-ports jammy main restricted universe multiverse
deb http://ports.ubuntu.com/ubuntu-ports jammy-updates main restricted universe multiverse
deb-src http://ports.ubuntu.com/ubuntu-ports jammy-updates main restricted universe multiverse
deb http://ports.ubuntu.com/ubuntu-ports jammy-security main restricted universe multiverse
deb-src http://ports.ubuntu.com/ubuntu-ports jammy-security main restricted universe multiverse
EOT
ubuntu22.04-rootfs# cat <<EOT > /etc/apt/apt.conf.d/71-no-recommends
APT::Install-Recommends "0";
APT::Install-Suggests "0";
EOT
ubuntu22.04-rootfs# apt -y update
ubuntu22.04-rootfs# apt -y upgrade
ubuntu22.04-rootfs# apt install -y locales dialog
ubuntu22.04-rootfs# dpkg-reconfigure locales
ubuntu22.04-rootfs# apt install -y net-tools openssh-server ntpdate resolvconf sudo less hwinfo ntp tcsh zsh file
Here, please select "160. en_US.UTF-8 UTF-8" and "2. C.UTF-8" Set a different locales if necessary.
ubuntu22.04-rootfs# echo ubuntu-fpga > /etc/hostname
ubuntu22.04-rootfs# passwd
This time, we set the "admin" at the root' password.
To be able to login as root from Zynq serial port.
ubuntu22.04-rootfs# cat <<EOT >> /etc/securetty
# Seral Port for Xilinx Zynq
ttyPS0
ttyPS1
EOT
ubuntu22.04-rootfs# adduser fpga
This time, we set the "fpga" at the fpga'password.
ubuntu22.04-rootfs# echo "fpga ALL=(ALL:ALL) ALL" > /etc/sudoers.d/fpga
ubuntu22.04-rootfs# sed -i -e 's/#PasswordAuthentication/PasswordAuthentication/g' /etc/ssh/sshd_config
ubuntu22.04-rootfs# dpkg-reconfigure tzdata
or if noninteractive set to Asia/Tokyo
ubuntu22.04-rootfs# echo "Asia/Tokyo" > /etc/timezone
ubuntu22.04-rootfs# dpkg-reconfigure -f noninteractive tzdata
ubuntu22.04-rootfs# cat <<EOT > /etc/fstab
none /config configfs defaults 0 0
EOT
ubuntu22.04-rootfs# mkdir /lib/firmware
ubuntu22.04-rootfs# mkdir /lib/firmware/ti-connectivity
ubuntu22.04-rootfs# mkdir /lib/firmware/mchp
ubuntu22.04-rootfs# apt install -y build-essential
ubuntu22.04-rootfs# apt install -y pkg-config
ubuntu22.04-rootfs# apt install -y curl
ubuntu22.04-rootfs# apt install -y git git-lfs
ubuntu22.04-rootfs# apt install -y kmod
ubuntu22.04-rootfs# apt install -y flex bison
ubuntu22.04-rootfs# apt install -y u-boot-tools device-tree-compiler
ubuntu22.04-rootfs# apt install -y libssl-dev
ubuntu22.04-rootfs# apt install -y socat
ubuntu22.04-rootfs# apt install -y ruby rake ruby-msgpack ruby-serialport
ubuntu22.04-rootfs# apt install -y python3 python3-dev python3-setuptools python3-wheel python3-pip python3-numpy
ubuntu22.04-rootfs# pip3 install msgpack-rpc-python
ubuntu22.04-rootfs# apt install -y wireless-tools
ubuntu22.04-rootfs# apt install -y wpasupplicant
ubuntu22.04-rootfs# git clone git://git.ti.com/wilink8-wlan/wl18xx_fw.git
ubuntu22.04-rootfs# cd wl18xx_fw && git checkout d2588c16809ecca8e0dc7ea011fc6180c7b08a92 && cd ..
ubuntu22.04-rootfs# cp wl18xx_fw/wl18xx-fw-4.bin /lib/firmware/ti-connectivity
ubuntu22.04-rootfs# rm -rf wl18xx_fw/
ubuntu22.04-rootfs# git clone git://git.ti.com/wilink8-bt/ti-bt-firmware
ubuntu22.04-rootfs# cp ti-bt-firmware/TIInit_11.8.32.bts /lib/firmware/ti-connectivity
ubuntu22.04-rootfs# rm -rf ti-bt-firmware
ubuntu22.04-rootfs# git clone https://github.com/linux4wilc/firmware linux4wilc-firmware
ubuntu22.04-rootfs# cp linux4wilc-firmware/*.bin /lib/firmware/mchp
ubuntu22.04-rootfs# rm -rf linux4wilc-firmware
ubuntu22.04-rootfs# apt install -y samba
ubuntu22.04-rootfs# apt install -y avahi-daemon
ubuntu22.04-rootfs# apt install -y haveged
ubuntu22.04-rootfs# apt install -y network-manager
ubuntu22.04-rootfs# cat <<EOT >/etc/NetworkManager/conf.d/10-globally-managed-devices.conf
[keyfile]
unmanaged-devices=none
EOT
ubuntu22.04-rootfs# mkdir home/fpga/debian
ubuntu22.04-rootfs# mv *.deb home/fpga/debian
ubuntu22.04-rootfs# chown fpga.fpga -R home/fpga/debian
ubuntu22.04-rootfs# dpkg -i home/fpga/debian/linux-image-6.1.70-zynqmp-fpga-trial_6.1.70-zynqmp-fpga-trial-2_arm64.deb
ubuntu22.04-rootfs# dpkg -i home/fpga/debian/linux-headers-6.1.70-zynqmp-fpga-trial_6.1.70-zynqmp-fpga-trial-2_arm64.deb
ubuntu22.04-rootfs# apt-get clean
ubuntu22.04-rootfs# dpkg -l > dpkg-console-list.txt
ubuntu22.04-rootfs# exit
shell$ sudo rm -f $PWD/$targetdir/usr/bin/qemu-aarch64-static
shell$ sudo rm -f $PWD/$targetdir/build-ubuntu22.04-console-rootfs.sh
shell$ sudo mv $PWD/$targetdir/dpkg-console-list.txt files/ubuntu22.04-console-dpkg-list.txt
shell$ sudo umount $PWD/$targetdir/proc
shell$ sudo umount $PWD/$targetdir/dev/pts
shell$ cd $PWD/$targetdir
shell$ sudo tar cfz ../ubuntu22.04-console-rootfs.tgz *
shell$ cd ..
shell$ mkdir ubuntu22.04-console-rootfs.tgz.files
shell$ cd ubuntu22.04-console-rootfs.tgz.files
shell$ split -d --bytes=40M ../ubuntu22.04-console-rootfs.tgz
shell$ cd ..