1 #+title: sources of aminb.org's pages and posts
4 #+seq_todo: TODO DRAFT DONE
5 #+property: header-args :eval never-export
8 #+macro: abbr @@html:<abbr>$1</abbr>@@
9 #+macro: span @@html:<span class="$1">$2</span>@@
13 :EXPORT_HUGO_SECTION: /
14 :EXPORT_FILE_NAME: _index
17 I'm a [[/uw][graduate student]] in the [[https://watform.uwaterloo.ca][WatForm]] group at University of Waterloo,
18 supervised by [[https://cs.uwaterloo.ca/~nday/][Dr. Nancy Day]]. I'm interested in using formal methods,
19 especially type systems, to help make software more reliable.
23 :EXPORT_HUGO_SECTION: /
24 :EXPORT_HUGO_MENU: :menu topnav
32 My academic {{{abbr(CV)}}} is available as [[/cv.pdf][cv.pdf]],
33 and an outdated professional resume is available as [[/resume.pdf][resume.pdf]] as
36 I'm interested in functional programming and functional languages,
37 type systems, and formal methods in general. I love writing Haskell
38 and I'm looking into Rust and Lean as well. Feel free to [[/contact][drop me a
39 line]] if you like to geek out about any of the above.
49 :EXPORT_HUGO_SECTION: post
50 :EXPORT_HUGO_MENU: :menu main
51 :EXPORT_HUGO_AUTO_SET_LASTMOD: t
54 ** Arch GNU/Linux on MacBook Air 2013 :arch:macbook:
56 :EXPORT_FILE_NAME: arch-macbook-air
57 :EXPORT_DATE: 2016-11-01
59 :EXPORT_HUGO_MENU: :menu main
60 :EXPORT_HUGO_ALIASES: /2016/11/arch-macbook-air
61 :EXPORT_HUGO_CUSTOM_FRONT_MATTER: :toc true
64 This post summarizes how I install and dual-boot Arch GNU/Linux with
65 Full-Disk Encryption alongside macOS. It is not meant to be a
66 replacement for the [[https://wiki.archlinux.org/index.php/installation_guide][Installation Guide]] or the former [[https://csdietz.github.io/arch-beginner-guide/][Beginner's Guide]].
67 Rather, it mostly serves as a small summary with a few useful notes
70 So, make sure you understand what you type into your terminal. If you
71 don't, checking out the Arch wiki should probably be your first step.
73 /Note:/ you will need internet access throughout the installation and
74 the MacBook Air's WiFi doesn't work out of the box on Arch. I
75 recommend using your phone's USB Tethering (if it does support it), or
76 using an Ethernet-USB adapter.
78 *** Shrinking the macOS partition
80 The first step I take is resizing the HFS+ macOS partition to make
81 room for the new {{{abbr(GNU/Linux)}}} installation. There are plenty
82 of tutorials on how to do this using macOS's Disk Utility, so do that
85 *** Creating a bootable Arch Installer USB
87 There are different ways of creating a bootable Arch USB, all
88 documented on the [[https://wiki.archlinux.org/index.php/USB_flash_installation_media][USB flash installation media]] page on the Arch wiki,
89 but the simplest one is using =dd= if you already have access to
92 {{{span(red,Warning:)}}} make sure you backup the data on your flash
93 drive, as =dd= will irrevocably destroy all data on it.
95 Use =lsblk= to find the name (block device) of your USB drive, then
96 run =dd= (as root) as shown below:
99 dd bs=4M if=/path/to/archlinux.iso of=/dev/sdx status=progress && sync
102 Replace =/path/to/archlinux.iso= with the path to the Arch image you
103 have downloaded, and =/dev/sdx= with your drive.
105 *** Booting up from the USB
107 After creating the install USB, reboot your laptop and hold the alt
108 key and boot into the USB.
110 When booting is complete and you're presented with the prompt, it's a
111 good time to make sure you're connected to the internet (see the
112 /note/ at the top of this post).
114 Use =ping= to verify that you've established a connection:
120 *** Updating the system clock
122 Once you're connected to the internet, make sure the system clock is
126 timedatectl set-ntp true # start and enable systemd-timesyncd
129 You can check the service status using =timedatectl status=.
133 :CUSTOM_ID: partitioning
136 I won't dive into partitioning and instead, I'll refer you to the
137 [[https://wiki.archlinux.org/index.php/Partitioning][Partitioning]] page of Arch wiki. Of the available partitioning tools, I
138 personally prefer =cfdisk=.
140 *** Setting up LVM & LUKS
142 I use a [[https://wiki.archlinux.org/index.php/Dm-crypt/Encrypting_an_entire_system#LVM_on_LUKS][LVM on LUKS]] setup, where I set up LVM on top of the encrypted
145 First, let's set up the underlying encrypted partition:
148 cryptsetup -v --cipher aes-xts-plain64 --key-size 512 --hash sha512 \
149 --iter-time 5000 --use-urandom -y luksFormat /dev/sdaX
152 where =/dev/sdaX= is the partition you created in the last step
153 (e.g. =/dev/sda4=). For more information about the =cryptsetup=
154 options, see the [[https://wiki.archlinux.org/index.php/Dm-crypt/Device_encryption#Encryption_options_for_LUKS_mode][LUKS encryption options]].
156 Then we open the container:
159 cryptsetup open --type luks /dev/sdaX lvm
162 Now it's time to use lvm and prepare the logical volume(s):
165 pvcreate /dev/mapper/lvm
166 vgcreate vg /dev/mapper/lvm
167 lvcreate --extents +100%FREE -n root vg
170 This will create a physical volume on the mapping we just opened,
171 create a volume group named =vg= on the physical volume, and create a
172 logical volume named =root= that spans the entire volume group. More
173 complex setups are possible thanks to the great flexibility of lvm.
175 We now format the logical volume with =ext4=:
178 mkfs.ext4 /dev/mapper/vg-root
181 *** Installing the base system
183 Let's mount the logical volume, make a directory for the mount point
184 of the boot partition, and mount the boot partition (=/dev/sda1=):
187 mount /dev/mapper/vg-root /mnt
189 mount /dev/sda1 /mnt/boot
192 Finally, let's install the base system (and optionally =base-devel=):
195 pacstrap /mnt base base-devel
198 *** Configuring the system
200 Let's generate the fstab:
203 genfstab -U /mnt >> /mnt/etc/fstab
206 Use your favorite terminal-based editor, edit the fstab file and add
207 the =discard= option for the root partition to enable TRIM on the SSD.
209 Now we change root into our newly installed system and will configure
210 it. Adjust these according to your own setup.
213 arch-chroot /mnt /bin/bash
214 passwd # set the root password
215 echo myhostname > /etc/hostname # set the hostname
216 ln -s /usr/share/zoneinfo/Canada/Eastern /etc/localtime # time zone
217 hwclock --systohc --utc # write system clock to hardware clock (UTC)
218 useradd -m -G wheel -s /bin/bash myuser # create myuser
219 passwd myuser # set the password for myuser
220 echo "myuser ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers.d/myuser
221 # uncomment en_US.UTF-8 UTF-8 and other needed locales in /etc/locale.gen
223 echo LANG=en_US.UTF-8 > /etc/locale.conf
224 export LANG=en_US.UTF-8
227 Then adjust the initramfs hooks in =/etc/mkinitcpio.conf= and enable
228 the =encrypt= and =lvm2= hooks, and make sure =keyboard= is available
229 before =encrypt= so you can actually type in the LUKS password when
230 booting. Your =HOOKS= line should look similar to this:
233 HOOKS="base udev autodetect modconf block keyboard encrypt lvm2 filesystems fsck"
236 After adjusting the hooks, build the initramfs:
242 Now, install the =intel-ucode= package. We'll configure the bootloader
243 to enable intel microcode updates.
246 pacman -S intel-ucode
249 Create the =/boot/loader/loader.conf= with the following content
250 (adjust the timeout to your liking):
257 Then create the entry for Arch:
260 mkdir -p /boot/loader/entries
261 touch /boot/loader/entries/arch.conf
264 Now edit =/boot/loader/entries/arch.conf= to specify the Arch entry:
269 initrd /intel-ucode.img
270 initrd /initramfs-linux.img
271 options cryptdevice=/dev/sdaX:vg:allow-discards root=/dev/mapper/vg-root rw
274 Again, =/dev/sdaX= is the partition you created in the [[#partitioning][partitioning]]
275 step as the underlying encrypted partition.
277 Finally, install the bootloader, exit the chroot, umount and reboot!
286 *** Post-installation recommendations
288 Congratulations! You now have a minimal Arch installation.
290 At this point, I usually install my favorite AUR helper, [[https://aur.archlinux.org/packages/pacaur/][pacaur]], then
291 I install the [[https://aur.archlinux.org/packages/broadcom-wl-dkms/][broadcom-wl-dkms]] wireless driver and [[https://aur.archlinux.org/packages/mba6x_bl-dkms/][mba6x_bl-dkms]]
292 backlight driver to fix the post suspend/resume issue where three's no
293 brightness after waking up from suspend, and the only available
294 brightness would be 100%.
297 pacaur -S linux-headers dkms # linux-headers is required for dkms
298 pacaur -S broadcom-wl-dkms
299 pacaur -S mba6x_bl-dkms
302 Then, I'd like to install
304 - input, graphics, and sound drivers,
305 - a desktop environment (I prefer Xfce or LXQt),
306 - a display manager for login screen (lightdm or sddm), and
307 - a network manager (NetworkManager or ConnMan).
309 Check out the [[https://wiki.archlinux.org/index.php/General_recommendations][General recommendations]] for more details.
313 Here are some resources I've come across each with lots of useful bits
314 and pieces, about installing Arch on a MacBook:
316 - [[https://github.com/pandeiro/arch-on-air][pandeiro/arch-on-air]]
317 - [[https://loicpefferkorn.net/2015/01/arch-linux-on-macbook-pro-retina-2014-with-dm-crypt-lvm-and-suspend-to-disk/][Arch Linux on MacBook Pro Retina 2014 with DM-Crypt, LVM and suspend to disk]]
318 - [[http://frankshin.com/installing-archlinux-on-macbook-air-2013/][Installing Archlinux on Macbook Air 2013]]
319 - [[http://panks.me/posts/2013/06/arch-linux-installation-with-os-x-on-macbook-air-dual-boot/][Arch Linux Installation with OS X on Macbook Air (Dual Boot)]]
320 - [[https://visual-assault.org/2016/03/05/install-encrypted-arch-linux-on-apple-macbook-pro/][Installing (encrypted) Arch Linux on an Apple MacBook Pro]]
321 - [[http://alexeyzabelin.com/arch-on-mac][Installing Arch Linux on a MacBook Air 2013]]
322 - [[https://medium.com/phils-thought-bubble-of-recent-stuff/arch-linux-running-on-my-macbook-2ea525ebefe3][Arch Linux running on my MacBook]]
323 - [[http://codylittlewood.com/arch-linux-on-macbook-pro-installation/][Dual boot Arch Linux on MacBook Pro Installation]]
328 :EXPORT_HUGO_SECTION: /
329 :EXPORT_FILE_NAME: search
330 :EXPORT_HUGO_LAYOUT: search
331 :EXPORT_HUGO_OUTPUTS: html json
332 :EXPORT_HUGO_CUSTOM_FRONT_MATTER: :sitemap '((priority . 0.1))
334 Results from static site search implemented using /Fusejs/, /jquery/
335 and /mark.js/. -- [[https://gist.github.com/eddiewebb/735feb48f50f0ddd65ae5606a1cb41ae][Source]]
337 * COMMENT Local Variables :ARCHIVE:
339 # org-hugo-footer: "\n\n[//]: # \"Exported with love from a post written in Org mode\"\n[//]: # \"- https://github.com/kaushalmodi/ox-hugo\""