💾 Archived View for ibannieto.info › stuff › openbsd.gmi captured on 2024-05-10 at 10:27:34. Gemini links have been rewritten to link to archived content
⬅️ Previous capture (2023-11-04)
-=-=-=-=-=-=-
OpenBSD installation and notes
Because I don't have (yet) a USBC->RJ45 dongle and still we don't have yet the firmware for the wireless adapter, we can use the USB tethering from your phone in order to get a temporal connection to internet, if needed.
Also, there is a documented method in that you can build a installation image within the firmware files, but I never used it yet.
TIP: Use the USB tethering feature from your phone by connection a USB-C cable to the laptop in order to get a temporal connection to Internet.
You will need the proper firmware binary file for your hardware, which is 'automagically' detected by the kernel and installed by using :
# fw_update fw_update: added intel,inteldrm,iwm,vmm; updated none; kept none # reboot
patch the current system :
# syspatch # reboot
wired method :
# ifconfig em0 up ; ifconfig em0 inet autoconf
wireless method :
create file /etc/hostname.iwm0
# cat /etc/hostname.iwm0 join YOURESSID wpakey YOURPASSWORD inet autoconf
change permissions to 640 to the file
# chmod 0640 /etc/hostname.iwm0
you should get your connection up and working.
install a package :
# pkg_add packagename
upgrade all :
# pkg_add -uv
list packages installed by user (without the dependencies) :
# pkg_info -mz | tee list.txt
install the previous package list in another computer :
# pkg_add -l list.txt
find packages :
# pkg_info -Q packagename # pkglocate packagename
delete packages (modified configuration files will not be removed. Unneeded dependencies can be trimmed by running pkg_delete -a at any time) :
# pkg_delete packagename # pkg_delete -a
This is my package list :
ImageMagick-- age-- amfora-- aspell-- aspell-es-- awscli-- bat-- blender-- bonzomatic-- cairo-- calcurse-- cmake-- cmatrix-- cool-retro-term-- dino-- drawterm-- dunst-- exa-- exfat-fuse-- feh-- firefox-- fish-- font-awesome-- fossil-- fzf-- geteltorito-- git-- gnuplot-- go-- gopass-- grafx2-- groff-- heirloom-doctools-- helix-- html-xml-utils-- irssi-- jq-- krita-- kubectl-- lagrange-- libreoffice-- libreoffice-i18n-es-- libreoffice-i18n-uk-- links+-- mc-- moc-- mpv-- mutt--gpgme ncdu-- neofetch-- newsboat-- nnn--nerd node-- nomacs-- nsxiv-- obsdfreqd-- openvpn-- p5-Image-ExifTool-- pango-- picom-- pinentry-- pqiv-- profanity-- pv-- pwgen-- py3-pip-- qt5ct-- quirks-- ranger-- rc-- redshift-- rsync-- rtorrent-- rust-- rust-rustfmt-- scdoc-- scrot-- scummvm-- sdl2-ttf-- simple-mtpfs-- sops-- streamlink-- sxhkd-- syncthing-- tabbed-- terminus-font-- tic80-- toot-- tree-sitter-- typespeed-- u9fs-- vault-- w3m--image wget-- wkhtmltopdf-- xbanish-- xcalib-- xclip-- xcursor-dmz-- xdg-utils-- youtube-dl-- zathura-- zathura-pdf-mupdf-- zathura-ps--
This is REQUIRED for a laptop!
Install and enable apmd and obsdfreqd :
# pkg_add obsdfreqd # rcctl enable apmd # rcctl set apmd flags -L # rcctl start apmd apmd(ok) # rcctl enable obsdfreqd # rcctl start obsdfreqd obsdfreqd(ok)
Add the following configurations to /etc/X11/xorg.conf.d/ :
/etc/X11/xorg.conf.d/compositor.conf
BackSection "Extensions" Option "Composite" "true" EndSection
/etc/X11/xorg.conf.d/intel.conf
Section "Device" Identifier "drm" Driver "intel" Option "TearFree" "true" #Option "DRI" "iris" EndSection
/etc/X11/xorg.conf.d/synaptics.conf
Section "InputClass" Identifier "touchpad" Driver "synaptics" MatchIsTouchpad "on" Option "TapButton1" "1" Option "TapButton2" "3" Option "TapButton3" "2" Option "VertEdgeScroll" "on" Option "VertTwoFingerScroll" "on" Option "HorizEdgeScroll" "on" Option "HorizTwoFingerScroll" "on" Option "CircularScrolling" "on" Option "CircScrollTrigger" "2" Option "EmulateTwoFingerMinZ" "40" Option "EmulateTwoFingerMinW" "8" Option "CoastingSpeed" "0" Option "FingerLow" "30" Option "FingerHigh" "50" Option "MaxTapTime" "125" Option "TapAndDragGesture" "1" Option "TappingDragLock" "1" Option "PalmDetect" "1" Option "PalmMinWidth" "8" Option "PalmMinZ" "100" #Option "VertScrollDelta" "-111" # Option "HorizScrollDelta" "-111" EndSection
I'm still playing with PalmDetect/MinWidth/MinZ in order to get annoying accidental touch in the middle of a file or a conversations :-\
VertScrollDelta is needed if you want to change to "natural scrolling", which is not for me but works perfect for someothers.
Modify the following configuration files in /etc/X11/xenodm :
/etc/X11/xenodm/GiveConsole
#!/bin/sh prefix="/usr/X11R6" exec_prefix="${prefix}" chown $USER /dev/console if [ -c /dev/dri/card0 ]; then chown $USER /dev/dri/card0 fi if [ -c /dev/dri/renderD128 ]; then chown $USER /dev/dri/renderD128 fi ${exec_prefix}/bin/sessreg -a -l $DISPLAY -u none $USER
/etc/X11/xenodm/Xresources
! $OpenBSD: Xresources.in,v 1.4 2022/11/07 17:12:06 matthieu Exp $ xlogin*login.translations: #override \ <Key>F1: set-session-argument(failsafe) finish-field()\n\ <Key>Left: move-backward-character()\n\ <Key>Right: move-forward-character()\n\ <Key>Home: move-to-begining()\n\ <Key>End: move-to-end()\n\ Ctrl<Key>KP_Enter: set-session-argument(failsafe) finish-field()\n\ <Key>KP_Enter: set-session-argument() finish-field()\n\ Ctrl<Key>Return: set-session-argument(failsafe) finish-field()\n\ <Key>Return: set-session-argument() finish-field() xlogin*greeting: CLIENTHOST xlogin*namePrompt: \040\040\040\040\040\040\040Login: xlogin*fail: Login incorrect or forbidden #if WIDTH > 800 xlogin*greetFace: Cascadia Code-22:bold:italic:dpi=75 xlogin*face: Cascadia Code-16:dpi=75 xlogin*promptFace: Cascadia Code-16:bold:dpi=75 xlogin*failFace: Cascadia Code-16:bold:dpi=75 #else xlogin*greetFace: DejaVu Sans Condensed-18:bold:italic:dpi=75 xlogin*face: DejaVu Sans Condensed-12:dpi=75 xlogin*promptFace: DejaVu Sans Condensed-12:bold:dpi=75 xlogin*failFace: DejaVu Sans Condensed-12:bold:dpi=75 #endif #if !(defined(bpp1) || defined(bpp4) || defined(bpp8) || defined(bpp15)) # if PLANES < 4 # ifndef bpp1 # define bpp1 # endif # else # if PLANES > 4 # if PLANES > 8 # ifndef bpp15 # define bpp15 # endif # else # ifndef bpp8 # define bpp8 # endif bpp8 # endif # else # ifndef bpp4 # define bpp4 # endif # endif # endif #endif /* If manual override */ #ifndef bpp1 xlogin*borderWidth: 1 xlogin*frameWidth: 2 xlogin*innerFramesWidth: 0 xlogin.Login.sepWidth: 0 ! top/left border xlogin*hiColor: #445566 ! bottom/right border xlogin*shdColor: #445566 ! 'Welcome to..' text color xlogin*greetColor: #ded866 #if defined(bpp4) || defined(bpp8) || defined(bpp15) ! flood fill xlogin*background: #596a79 !xlogin*background: #6187ad xlogin*inpColor: #798a99 #endif xlogin*failColor: #ff4d29 ! 'Login:' and 'Password:'
/etc/X11/xenodm/Xsetup_0
#!/bin/sh # $OpenBSD: Xsetup_0.in,v 1.1 2021/08/30 15:38:27 matthieu Exp $ prefix="/usr/X11R6" exec_prefix="${prefix}" #${exec_prefix}/bin/xsetroot -fg \#6f6f6f -bg \#bfbfbf -bitmap ${prefix}/include/X11/bitmaps/root_weave ${exec_prefix}/bin/xsetroot -solid black # ${exec_prefix}/bin/xconsole -geometry 480x130-0-0 -daemon -notify -verbose -fn fixed -exitOnFail # install package openbsd-backgrounds # then uncomment: # # if test -x /usr/local/bin/openbsd-wallpaper # then # /usr/local/bin/openbsd-wallpaper # fi # sxpm OpenBSD.xpm & xset b off
TODO
This is my ~/.xsession file:
#!/bin/sh -x # disable core dumps ulimit -Sc 0 cleanup() { echo "Cleaning up..." pkill dbus-daemon picom dunst gpg-agent rm -f ~/.Xauthority rm -r ~/.xsession-errors gpgconf --kill gpg-agent } trap cleanup INT TERM QUIT if [ -x /usr/local/bin/dbus-launch -a -z "${DBUS_SESSION_BUS_ADDRESS}" ]; then eval `dbus-launch --sh-syntax --exit-with-x11` fi export GOPATH=~/go export PATH=$PATH:$GOPATH/bin:$HOME/.cargo/bin:$HOME/.bin:$HOME/.local/bin GPG_TTY=$(tty) export LANG=en_GB.UTF-8 export EDITOR=hx export QT_QPA_PLATFORMTHEME="qt5ct" export GPG_TTY eval $(gpg-agent --daemon --enable-ssh-support --sh) # why? #eval $(ssh-agent -c) export XDG_RUNTIME_DIR='/tmp/runtime-iban' # needs fix #export XDG_RUNTIME_DIR=$(ls -d /tmp/service-$USER.???* 2>/dev/null || mktemp -d /tmp/service-$USER.XXXXXX | tee >(xargs chmod 0700)) dunst & xrandr -s 1920x1080 xrandr --dpi 96 xrdb -merge ~/.Xresources xset r rate 350 35 xset b 0 0 0 xset s off xset dpms 0 0 0 xbacklight -set 35 & xidle -timeout 900 -ne -program xlock & xbanish & # needed for slstatus (external script for get the weather and kwh pricing) $HOME/.bin/weather > ~/.weather & $HOME/.bin/preciokw > ~/.price-kwh & # wallpaper feh --bg-fill ~/Pictures/wallpapers/wallpapersden.com_retro-wave-sunrise-path_2400x1350.jpg & # prepare desktop picom -b slstatus & # margo salutes! dunstify -u low "Welcome back!" "Margo is ready for kick asses" & # run suckless dwm exec dwm
Increase the default limits from the system by adding your user to the staff group and modify login configuration :
% su - Password: # usermod -G staff username
Modify the file /etc/login.conf file and look for staff :
staff:\ :datasize-cur=16117M:\ :datasize-max=infinity:\ :maxproc-max=1024:\ :maxproc-cur=1024:\ :openfiles-max=8192:\ :openfiles-cur=4096:\ :stacksize-cur=32M:\ :ignorenologin:\ :requirehome@:\ :tc=default:
Tune your filesystems and add cache by modifying the file /etc/fstab (CAUTION) :
a5636cdf25bfb5a8.b none swap sw a5636cdf25bfb5a8.a / ffs rw,softdep,noatime 1 1 a5636cdf25bfb5a8.l /home ffs rw,softdep,noatime,nodev,nosuid 1 2 a5636cdf25bfb5a8.d /tmp ffs rw,softdep,noatime,nodev,nosuid 1 2 a5636cdf25bfb5a8.f /usr ffs rw,softdep,noatime,nodev 1 2 a5636cdf25bfb5a8.g /usr/X11R6 ffs rw,softdep,noatime,nodev 1 2 a5636cdf25bfb5a8.h /usr/local ffs rw,softdep,noatime,wxallowed,nodev 1 2 a5636cdf25bfb5a8.k /usr/obj ffs rw,softdep,noatime,nodev,nosuid 1 2 a5636cdf25bfb5a8.j /usr/src ffs rw,softdep,noatime,nodev,nosuid 1 2 a5636cdf25bfb5a8.e /var ffs rw,softdep,noatime,nodev,nosuid 1 2 swap /home/user/.cache mfs rw,nodev,nosuid,-s=300m 0 0
Because my X280 sometimes 'forgot' some seconds during the week I need to modify /etc/ntpd.conf and enable NTP :
# rcctl enable ntpd # rcctl start ntpd
This is my /etc/ntpd.conf :
servers pool.ntp.org server hora.roa.es # when I'm in Spain sensor * constraint from "9.9.9.9" # quad9 v4 without DNS constraint from "2620:fe::fe" # quad9 v6 without DNS
As root create the file /etc/doas.conf and add the following lines :
permit nopass YOURUSER as root cmd mount permit nopass YOURUSER as root cmd umount
Optionally you can use this to perform supergod mode (not recommended) :
permit persist keepenv YOURUSER
This is my file /etc/rc.conf.local :
apmd_flags=-L dhcpd_flags=vether0 pkg_scripts=obsdfreqd sndiod_flags=-s default -m play,mon -s mon xenodm_flags=
Enable virtual machine functionallity :
# rcctl enable vmd # rcctl start vmd
This is my /etc/vm.conf
switch "uplink" { interface bridge0 } vm "k8s" { disable memory 4G cdrom "/usr/local/vm/alpine-virt-3.17.3-x86_64.iso" disk "/usr/local/vm/k8s.qcow2" owner iban interface { switch "uplink" lladdr 52:54:00:00:EE:03 } } vm "podman" { disable memory 2G cdrom "/usr/local/vm/alpine-virt-3.17.3-x86_64.iso" disk "/usr/local/vm/podman.qcow2" owner iban interface { switch "uplink" lladdr 52:54:00:00:EE:04 } } vm "9front" { disable memory 2G cdrom "/usr/local/vm/9front.iso" disk "/usr/local/vm/9front.qcow2" owner iban interface { switch "uplink" lladdr 52:54:00:00:EE:05 } }
TIP: for 9front (cpu+auth server) vm if connecting from outside of the host is required, you'll need to modify the file /etc/pf.conf :
pass in on egress proto tcp from any to any port 564 rdr-to 10.0.2.2 pass in on egress proto tcp from any to any port 567 rdr-to 10.0.2.2 pass in on egress proto tcp from any to any port 17019 rdr-to 10.0.2.2
10.0.2.2 is the IP address 9front VM gets, in this case, ie /etc/hostname.vether0 has inet 10.0.2.1/24.
Modify the following files :
/etc/dhcpcd.config
subnet 10.0.2.1 netmask 255.255.255.0 { # ip range to give away range 10.0.2.2 10.0.2.20; # that's host's IP address on vether0 option routers 10.0.2.1; # you might want to configure something else here ofc option domain-name-servers 9.9.9.9;
/etc/hostname.bridge0
add vether0 up
/etc/hostname.vether0
inet 10.0.2.1/24 up
TODO: All modified files (should be in a repo or something)
/etc/X11/xorg.conf.d/ /etc/X11/xenodm/ /etc/...