The Funtoo Linux project has transitioned to "Hobby Mode" and this wiki is now read-only.
Difference between revisions of "ODROID-XU4 Installation"
(7 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
This page documents a procedure you can use to install Funtoo Linux on the ODROID XU4. We assume that you have purchased the ODROID XU4 with an EMMC image containing Ubuntu. This guide will show you how to back up the Ubuntu image and then replace it with a Funtoo Linux image. | This page documents a procedure you can use to install Funtoo Linux on the ODROID XU4. We assume that you have purchased the ODROID XU4 with an EMMC image containing Ubuntu. This guide will show you how to back up the Ubuntu image and then replace it with a Funtoo Linux image. | ||
{{Note|The following instuctions also work with the ODROID XU3 and ODROID XU3-LITE because they are fully software compatible with the ODROID XU4.}} | |||
{{Note|These installation docs work even if you don't have another ARM system. You can use an existing x86 Linux system for the steps below.}} | {{Note|These installation docs work even if you don't have another ARM system. You can use an existing x86 Linux system for the steps below.}} | ||
Line 36: | Line 37: | ||
The {{c|e2label}} command associates the label "rootfs" with the root filesystem, which will come in handy later. Now, we will want to mount our filesystem so we can start installing Funtoo. | The {{c|e2label}} command associates the label "rootfs" with the root filesystem, which will come in handy later. Now, we will want to mount our filesystem so we can start installing Funtoo. | ||
{{Note|If you have sufficient capacity on your EMMC card, it's recommended that you use {{c|fdisk}} to delete the second paritition, and create a swap partition as well as a partition for the root filesystem. 2GB of swap is optimal, but any amount helps.}} | |||
=== Mount and Install === | === Mount and Install === | ||
Now, time to mount the new filesystem, download a Funtoo stage3, and extract it to our new filesystem: | Now, time to mount the new filesystem, [[ODROID-XU4|download a Funtoo stage3]], and extract it to our new filesystem: | ||
{{console|body= | {{console|body= | ||
Line 45: | Line 48: | ||
# ##i##mount /dev/sdc2 /mnt/funtoo | # ##i##mount /dev/sdc2 /mnt/funtoo | ||
# ##i##cd /mnt/funtoo | # ##i##cd /mnt/funtoo | ||
# ##i##wget http://build.funtoo.org/ | # ##i##wget http://build.funtoo.org/1.4-release-std/arm-32bit/odroid-xu4/stage3-latest.tar.xz | ||
# ##i##tar | # ##i##tar xpvf stage3-latest.tar.xz | ||
}} | }} | ||
Line 76: | Line 79: | ||
=== Setting Root Password === | === Setting Root Password === | ||
Now, we need to set the root password on the ODROID Funtoo image. If you are on an x86 system, you can't just chroot into {{f|/mnt/funtoo}} since all the binaries are ARM, not x86. So to do this, you will edit the {{f|/etc/shadow}} on your local system and {{f|/mnt/funtoo/etc/shadow}}. Then copy the line starting with {{c|root}} from the former to the latter file. This will copy the password set on your local Linux system to your ODROID. | Now, we need to set the root password on the ODROID Funtoo image. If you are on an x86 system, you can't just chroot into {{f|/mnt/funtoo}} since all the binaries are ARM, not x86. So to do this, you will edit the {{f|/etc/shadow}} on your local system and {{f|/mnt/funtoo/etc/shadow}}. Then copy the line starting with {{c|root}} from the former to the latter file. This will copy the root password set on your local Linux system to your ODROID. | ||
=== Setting Boot Options === | === Setting Boot Options === | ||
Line 97: | Line 100: | ||
Now, we can unmount the boot filesystem, detach our USB MicroSD card reader, and attach our EMMC card to a powered-down ODROID: | Now, we can unmount the boot filesystem, detach our USB MicroSD card reader, and attach our EMMC card to a powered-down ODROID: | ||
{{ | {{console|body= | ||
# ##i##umount /mnt/boot | # ##i##umount /mnt/boot | ||
# ##i##sync | # ##i##sync | ||
Line 105: | Line 108: | ||
=== Final Steps === | === Final Steps === | ||
Next, you will want to hook the ODROID, EMMC installed, up to an HDMI monitor and a functioning ethernet cable. Power up the ODROID. You should see Funtoo Linux boot and you should be able to login with your other system's root password. You can now continue Funtoo Linux setup according to the [[Install|Funtoo Linux Installation Guide]]. | Next, you will want to hook the ODROID, EMMC installed, up to an HDMI monitor and a functioning ethernet cable. Power up the ODROID. You should see Funtoo Linux boot and you should be able to login with your other system's root password. You can now continue Funtoo Linux setup according to the [[Install|Funtoo Linux Installation Guide]]. The remaining steps to complete are to perform an initial {{c|emerge --sync}}, configure your hostname, and configure your network. It is not necessary to install a kernel or bootloader as the Funtoo boot process is fully working. |
Latest revision as of 18:51, October 10, 2019
This page documents a procedure you can use to install Funtoo Linux on the ODROID XU4. We assume that you have purchased the ODROID XU4 with an EMMC image containing Ubuntu. This guide will show you how to back up the Ubuntu image and then replace it with a Funtoo Linux image.
The following instuctions also work with the ODROID XU3 and ODROID XU3-LITE because they are fully software compatible with the ODROID XU4.
These installation docs work even if you don't have another ARM system. You can use an existing x86 Linux system for the steps below.
Backing Up Ubuntu
The first thing you will want to do is to attach your Linux EMMC module to an ODROID EMMC to MicroSD adapter. Then, using a device such as a USB MicroSD card reader, attach the EMMC module to an existing Linux system (it doesn't need to be an ARM system -- it can be an x86 system) where you would like to store the Ubuntu backup. The filesystem we want to back up is located on the second partition of the drive:
root # install -d /mnt/ubuntu root # mount /dev/sdc2 /mnt/ubuntu -o ro root # cd /root root # tar czvf ubuntu-backup.tar.gz -C /mnt/ubuntu
You will also want to back up the lib/firmware
and lib/modules
directories from the Ubuntu image, for easy access, as well as the etc/fstab
file. We will end up putting these on the new Funtoo root filesystem to ensure that things boot correctly. Do this as follows:
root # install -d /root/ubuntu-backup root # cp -a /mnt/ubuntu/lib/modules /root/ubuntu-backup/ root # cp -a /mnt/ubuntu/lib/firmware /root/ubuntu-backup/ root # cp /mnt/ubuntu/etc/fstab /root/ubuntu-backup/
You are now ready to recreate the ext4 filesystem to wipe it clean.
Create New Root Filesystem
To create a new root filesystem for Funtoo, you will perform the following steps:
root # umount /mnt/ubuntu root # mkfs.ext4 /dev/sdc2 root # e2label /dev/sdc2 rootfs
The e2label
command associates the label "rootfs" with the root filesystem, which will come in handy later. Now, we will want to mount our filesystem so we can start installing Funtoo.
If you have sufficient capacity on your EMMC card, it's recommended that you use fdisk
to delete the second paritition, and create a swap partition as well as a partition for the root filesystem. 2GB of swap is optimal, but any amount helps.
Mount and Install
Now, time to mount the new filesystem, download a Funtoo stage3, and extract it to our new filesystem:
root # install -d /mnt/funtoo root # mount /dev/sdc2 /mnt/funtoo root # cd /mnt/funtoo root # wget http://build.funtoo.org/1.4-release-std/arm-32bit/odroid-xu4/stage3-latest.tar.xz root # tar xpvf stage3-latest.tar.xz
Installation is almost complete! But we have a few more finishing touches before the system is bootable.
Getting Funtoo Boot-Ready
To get the ODROID XU4 boot-ready, we will need to copy back the firmware
and modules
directories, and set up the etc/fstab
file. We'll do this as follows:
root # cp /root/ubuntu-backup/etc/fstab /mnt/funtoo/etc root # cp -a /root/ubuntu-backup/firmware /mnt/funtoo/lib root # cp -a /root/ubuntu-backup/modules /mnt/funtoo/lib
Now, let's edit the fstab
file and ensure it's set up correctly:
root # vim /mnt/funtoo/etc/fstab
You'll want the file to look like this:
LABEL=rootfs / ext4 errors=remount-ro,noatime 0 1
LABEL=boot /boot vfat noauto 0 1
Setting Root Password
Now, we need to set the root password on the ODROID Funtoo image. If you are on an x86 system, you can't just chroot into /mnt/funtoo
since all the binaries are ARM, not x86. So to do this, you will edit the /etc/shadow
on your local system and /mnt/funtoo/etc/shadow
. Then copy the line starting with root
from the former to the latter file. This will copy the root password set on your local Linux system to your ODROID.
Setting Boot Options
We've completed sufficient steps to prepare the root filesystem for boot. Now, we need to make a minor tweak to the boot filesystem on the EMMC card. Let's mount our boot filesystem:
root # umount /mnt/funtoo root # install -d /mnt/boot root # mount /dev/sdc1 /mnt/boot root # vim /mnt/boot/boot.ini
We will now change the line near the top starting with setenv bootrootfs
so it looks exactly like this:
setenv bootrootfs "console=tty1 consoleblank=0 root=LABEL=rootfs rootwait ro fsck.repair=yes net.ifnames=0"
Now, we can unmount the boot filesystem, detach our USB MicroSD card reader, and attach our EMMC card to a powered-down ODROID:
root # umount /mnt/boot root # sync (Now remove the reader/card)
Final Steps
Next, you will want to hook the ODROID, EMMC installed, up to an HDMI monitor and a functioning ethernet cable. Power up the ODROID. You should see Funtoo Linux boot and you should be able to login with your other system's root password. You can now continue Funtoo Linux setup according to the Funtoo Linux Installation Guide. The remaining steps to complete are to perform an initial emerge --sync
, configure your hostname, and configure your network. It is not necessary to install a kernel or bootloader as the Funtoo boot process is fully working.