aboutsummaryrefslogtreecommitdiff
path: root/src/docs/install.txt
diff options
context:
space:
mode:
Diffstat (limited to 'src/docs/install.txt')
-rw-r--r--src/docs/install.txt361
1 files changed, 361 insertions, 0 deletions
diff --git a/src/docs/install.txt b/src/docs/install.txt
new file mode 100644
index 0000000..2dba19e
--- /dev/null
+++ b/src/docs/install.txt
@@ -0,0 +1,361 @@
+1 Installation
+**************
+
+These are the step-by-step instructions for installing Carbs Linux.
+
+1.1 Preparing Environment
+=========================
+
+To install Carbs Linux, you will need a Live Linux ISO. For that
+purpose, you can obtain a Gentoo or Void Linux live image. You can
+follow their instructions to boot and setup your network.
+
+ You will need the following programs in order to install Carbs Linux:
+ * tar
+ * wget
+ * xz
+ * some form of base utilities (coreutils, sbase, busybox, etc.)
+
+ Rest of these instructions will assume that you have set all of these
+up, and will continue on that point.
+
+1.1.1 Download
+--------------
+
+First, we need to download the rootfs tarball. You can do the following
+in order to obtain the rootfs. If you are using an i686 machine,
+replace the 'x86_64' with 'i686'. We are setting this in a URL variable
+so that we don't have to write it every time.
+
+ $ URL=https://dl.carbslinux.org/releases/x86_64
+ $ wget $URL/carbs-rootfs.tar.xz
+
+ We can then check the integrity of the tarball and do a signature
+verification. Even thought these are optional, they are highly
+recommended.
+
+1.1.2 Check the integrity of the tarball (Recommended)
+------------------------------------------------------
+
+All of the releases are saved in a single file named 'sha256sums.txt',
+but the latest release is saved on 'carbs-rootfs.tar.xz.sha256'. You
+can acquire and verify the tarball.
+
+ $ wget $URL/carbs-rootfs.tar.xz.sha256
+ $ sha256sum -c carbs-rootfs.tar.xz.sha256
+
+1.1.3 Verify the signature
+--------------------------
+
+It is highly recommended to verify the signature of the tarball. You
+will need GPG for this.
+
+ $ wget $URL/carbs-rootfs.tar.xz.sig
+ $ gpg --recv-keys FF484BDFEFCEF8FF
+ $ gpg --verify carbs-rootfs.tar.xz.sig
+
+1.1.4 Extracting the tarball
+----------------------------
+
+You will need to extract the tarball to your desired location. For
+partitioning, you can follow this guide
+(https://wiki.archlinux.org/index.php/Partitioning). This will assume
+that you will be mounting your root partition to '/mnt'.
+
+ $ mount /dev/sdx1 /mnt
+ $ tar xf carbs-rootfs.tar.xz -C /mnt
+
+1.1.5 Obtain the chroot helper
+------------------------------
+
+You can obtain the 'cpt-chroot' script in order to do a simple chroot
+into your new root filesystem.
+
+ $ wget https://dl.carbslinux.org/distfiles/cpt-chroot
+ $ chmod a+x cpt-chroot
+
+1.2 Chroot
+==========
+
+Chroot into Carbs Linux!
+
+ $ ./cpt-chroot /mnt
+
+1.2.1 Setting up repositories
+-----------------------------
+
+Newest tarballs do not come with repositories, so you will need to
+manually obtain them, and set your 'CPT_PATH' environment variable.
+Carbs Linux repositories can either be obtained by 'git' or 'rsync'.
+While rsync repositories are overall faster and smaller, git offers the
+whole history of the repository and a means to manipulate your
+repository as you like it. If you want to obtain the git repository,
+you will need to install 'git' itself.
+
+ The following guide will assume that you put the repositories into
+'~/repos/' directory, but you can put the repositories into any
+directory you want. So go ahead and create that directory. 'mkdir -p
+$HOME/repos'.
+
+1.2.1.1 Obtaining from rsync
+............................
+
+Carbs Linux rsync repositories live in <rsync://carbslinux.org/repo>.
+In order to obtain it, run the following:
+
+ $ rsync -avc rsync://carbslinux.org/repo $HOME/repos/carbs
+
+1.2.1.2 Obtaining from git
+..........................
+
+Carbs Linux git repositories can be found both from the main server and
+GitHub (mirror). Here are both their repository links. You can clone
+any of them.
+
+ * <git://git.carbslinux.org/repository>
+ * <https://github.com/carbslinux/repository>
+
+ $ git clone git://git.carbslinux.org/repository $HOME/repos/carbs
+
+1.2.1.3 Making the package manager use the repositories
+.......................................................
+
+In your shell's configuration file, or in your '~/.profile' file, add
+the following lines:
+
+ export CPT_PATH=''
+ CPT_PATH=$CPT_PATH:$HOME/repos/carbs/core
+ CPT_PATH=$CPT_PATH:$HOME/repos/carbs/extra
+ CPT_PATH=$CPT_PATH:$HOME/repos/carbs/xorg
+ CPT_PATH=$CPT_PATH:$HOME/repos/carbs/community
+ export CPT_PATH
+
+1.2.2 Updating packages
+-----------------------
+
+It is good practice to make sure your system is up to date, especially
+before building new packages. If there is an update for the package
+manager you will need to update twice.
+
+ $ cpt update
+
+1.2.3 Installing packages
+-------------------------
+
+Since you are operating on a really small base, you might need to build
+and install new programs to extend the functionality of your system. In
+order to build and install packages new packages in Carbs, you need to
+execute the following. "Package" is not actually a package and is given
+as an example.
+
+ $ cpt build package
+ $ cpt install package
+
+1.2.4 Essential Software
+------------------------
+
+Here is a list of software that you might want to have on your system.
+
+ BOOTLOADERS
+ * efibootmgr
+ * grub
+ FILESYSTEMS
+ * e2fsprogs
+ * dosfstools
+ * ntfs-3g
+ NETWORKING
+ * dhcpcd
+ * wpa_supplicant
+ TEXT EDITORS
+ * nano
+ * vim
+ * neatvi
+ * nvi
+ * emacs
+ * emacs-nox (terminal-only version of emacs)
+ USER SHELLS
+ * bash
+ * zsh
+ * dash
+ * oksh
+ * rc
+ POSIX BASE UTILITIES
+ * busybox
+ * sbase
+ * coreutils
+ DOCUMENTATION
+ * carbs-docs
+ * man-pages
+ * man-pages-posix
+
+1.2.5 Obtaining the documentation (optional)
+--------------------------------------------
+
+All the documentation for Carbs Linux can be found on a single info
+manual to be viewed offline. You can obtain texinfo or the info
+(standalone) package in order to view the documentation.
+
+ Install the documentation.
+ $ cpt b carbs-docs && cpt i carbs-docs
+
+ Install either texinfo or the info package. We will be installing standalone info
+ as it doesn't need perl.
+ $ cpt b info && cpt i info
+
+ You can then run info and navigate through the documentation.
+ $ info carbslinux
+
+1.3 System Configuration
+========================
+
+After you have finished installing some extra packages, you can
+configure your system to your liking.
+
+1.3.1 Configuring hostname (recommended)
+----------------------------------------
+
+You might want to add a hostname, especially in a networked environment.
+Your hostname will default to 'carbslinux' unless you set this.
+
+ $ echo your-hostname > /etc/hostname
+
+1.3.2 Setting up hosts file (optional)
+--------------------------------------
+
+You can edit your /etc/hosts file, which is the static lookup table for
+host names. By default, there are two entries for localhost which are
+OKAY. You can replace the 'localhost' part of these entries to your
+hostname.
+
+ 127.0.0.1 localhost.localdomain localhost
+ ::1 localhost.localdomain localhost ip6-localhost
+
+1.4 Kernel
+==========
+
+Kernel isn't managed under the main repositories, even though you could
+package one for your personal use. Here is an example kernel package
+(https://github.com/cemkeylan/kiss-repository/tree/master/personal/linux),
+which you will need to reconfigure for your specific setup if you want
+to make use of it.
+
+1.4.1 Obtaining the kernel sources
+----------------------------------
+
+You can visit the https://kernel.org website to choose a kernel that you
+want to install. Though only the latest stable and longterm (LTS)
+versions are supported.
+
+ Download the kernel and extract it
+ $ wget https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.7.6.tar.xz
+ $ tar xf linux-5.7.6.tar.xz
+
+ Change directory into the kernel sources
+ $ cd linux-5.7.6
+
+1.4.2 Installing dependencies
+-----------------------------
+
+In order to compile the kernel you will need to install some
+dependencies. You will need 'libelf' to compile the kernel. If you
+want to configure using the menu interface you will also need 'ncurses'.
+
+ The package manager asks to install if you are building more than one package,
+ so no need to run 'cpt i ...'
+ $ cpt b libelf ncurses
+
+ In the vanilla kernel sources, you need perl to compile the kernel,
+but it can be easily patched out. You will need to apply the following
+patch. Patch was written by E5ten (https://github.com/E5ten). You will
+need to obtain and apply the patch in the kernel source directory.
+
+ $ wget https://dl.carbslinux.org/distfiles/kernel-no-perl.patch
+ $ patch -p1 < kernel-no-perl.patch
+
+1.4.3 Compiling the kernel
+--------------------------
+
+Next step is configuring and building the kernel. You can check
+Gentoo's kernel configuration guide
+(https://wiki.gentoo.org/wiki/Kernel/Configuration) to learn more about
+the matter. Overall, Gentoo Wiki is a good place to learn about
+configuration according to your hardware. The following will assume a
+monolithic kernel.
+
+ $ make menuconfig
+ $ make
+ $ install -Dm755 $(make -s image_name) /boot/vmlinuz-linux
+
+1.5 Making your system bootable
+===============================
+
+In order to be able to boot your fresh system, wou will need an
+init-daemon, init-scripts and a bootloader. The init daemon is already
+provided by busybox, but you can optionally change it.
+
+1.5.1 Installing a bootloader
+-----------------------------
+
+In the main repository, there is efibootmgr and grub to serve as
+bootloaders. efibootmgr can be used as a standalone bootloader, or can
+be used to install grub in a UEFI environment. efibootmgr is needed
+unless you are using a device without UEFI support (or you really want
+to use BIOS for a reason).
+
+ GRUB BIOS installation
+
+ $ cpt b grub && cpt i grub
+ $ grub-install --target=i386-pc /dev/sdX
+ $ grub-mkconfig -o /boot/grub/grub.cfg
+
+ GRUB UEFI installation
+
+ $ cpt b efibootmgr && cpt i efibootmgr
+ $ cpt b grub && cpt i grub
+
+ $ grub-install --target=x86_64-efi \
+ --efi-directory=esp \
+ --bootloader-id=CarbsLinux
+
+ $ grub-mkconfig -o /boot/grub/grub.cfg
+
+1.5.2 Installing init scripts
+-----------------------------
+
+Only thing left to do is installing the init-scripts, and now you are
+almost ready to boot your system!
+
+ $ cpt b carbs-init && cpt i carbs-init
+
+1.5.3 Generating fstab
+----------------------
+
+You can now manually edit your fstab entry, or you can use the genfstab
+tool. If you want to use the tool, exit the chroot and run the
+following:
+
+ $ wget https://github.com/cemkeylan/genfstab/raw/master/genfstab
+ $ chmod +x genfstab
+ $ ./genfstab -U /mnt >> /mnt/etc/fstab
+
+1.6 Post-installation
+=====================
+
+The base installation is now complete, you can now fine tune your system
+according to your needs. Rest of these instructions are completely
+optional.
+
+1.6.1 Acquiring kiss repositories
+---------------------------------
+
+While not 100% compatible with cpt, you can use kiss repositories in
+your system the same way you are using the distribution repositories.
+Here is an example for the KISS Linux Community repository.
+
+ $ git clone https://github.com/kisslinux/community $HOME/repos/kiss-community
+ $ export CPT_PATH=$CPT_PATH:$HOME/repos/kiss-community/community
+
+ NOTE: There are lots of packages on the KISS community repository
+that are also on Carbs Linux main repository. I would advise giving
+lower priority to the KISS community repository as it may affect other
+packages that you might install.