Wolfspyre Labs 🐺🔥🔬 / Our Guides / CoreDNS @ Wolfspyre Labs / 🏗️ Setting Up CoreDNS / Pi4 Soup to nuts / * eInk woes / * eInk woes ⇦ ⇦ ⇦ But wait!! There’s more! ⑦ … Is it supposed to smell like that?! # ⑨ PaperTTY Params ⇨ ⇨ ⇨ Papertty Pre-reqs Install Packages Install Poetry Clone the repo 🐾 Well…. hell. #If you’re here, it means that something LIKELY didn’t quite go right when kicking off PaperTTY. Lets see if we can help sort that out. not even talking to the display “Whomp Whomp ☹️” #poetry run papertty --driver EPD2in13b scrub gpiozero not found - defaulting to RPi.GPIO Loading PIL font /usr/src/PaperTTY/papertty/resources/tom-thumb.pil. Font size is ignored. Failed to init gpiozero spi device is SPI enabled? root@pi # ls /dev/*spi* /dev/spidev0.0 /dev/spidev0.1 is i2c enabled? root@gitlab-arm60-runner:/usr/src/PaperTTY# ls /dev/*i2c* /dev/i2c-1 are the pins connected in the right places? gpiozero found - using that instead of RPi.GPIO Loading PIL font /usr/src/PaperTTY/papertty/resources/tom-thumb.pil. Font size is ignored. /root/.cache/pypoetry/virtualenvs/papertty-LoWC4mRA-py3.12/lib/python3.12/site-packages/gpiozero/devices.py:300: PinFactoryFallback: Falling back from lgpio: No module named 'lgpio' warnings.warn( cat pyproject.toml [tool.poetry] name = “papertty” version = “0.1.8” description = “Python module to render a TTY or VNC on e-ink” authors = [“Jouko Strömmer jouko.strommer@iki.fi”] readme = “README.md” repository = “https://github.com/joukos/PaperTTY" homepage = “https://github.com/joukos/PaperTTY" [tool.poetry.dependencies] click = “^8.1.7” Pillow = “10.4.0” python = “^3.10” gpiozero = “^2.0.1” lgpio = “^0.2.2.0” “RPi.GPIO” = “^0.7.1” spidev = “^3.6” vncdotool = “^1.2.0” [tool.poetry.scripts] papertty = “papertty.papertty:cli” [build-system] requires = [“poetry>=0.12”] build-backend = “poetry.masonry.api” - noise #### "W...T...F?" If you're... Unlucky.. !(../eink-garbage.jpg) well... Lets see if we can't get you sorted. There's a few different forks of PaperTTY. while I want to encourage y'all to use the upstream. [This fork][mcarr823fork] has a lot of useful fixes. I've found that I can't use the red variants with the original codebase... and (as of now) the 2in13b driver doesn't work with my displays, the `d` variant does. (but only in black/white mode) so... using that and moving on. - Testing in terminal mode Some configs don't work so well in stdin mode, making it a hair challenging to eval 'is this thing on?' fortunately: root@gitlab-arm61-runner:/usr/src/mcarr923/PaperTTY# poetry run papertty –driver EPD2in13v2 –nopartial terminal –vcsa /dev/vcsa3 –font="/usr/share/fonts/truetype/msttcorefonts/Andale_Mono.ttf” –size=9 –cols 46 –rows 11 –sleep 0.9 –cursor=none loiosh@gitlab-arm61-runner:/home/loiosh# echo -e ‘123456789|123456789|123456789|123456789|123456\r\n02_456789|123456789|123456789|123456789|123456\r\n03_456789|123456789|123456789|123456789|123456\r\n04_456789|123456789|123456789|123456789|123456\r\n05_456789|123456789|123456789|123456789|123456\r\n06_456789|123456789|123456789|123456789|123456\r\n07_456789|123456789|123456789|123456789|123456\r\n08_456789|123456789|123456789|123456789|123456\r\n09_456789|123456789|123456789|123456789|123456\r\n10_456789|123456789|123456789|123456789|123456\r\n11_456789|123456789|123456789|123456789|123456’ > /dev/tty3 --size=6 --cols=70 --rows=16 (70x15) --size=7 --cols=60 --rows=14 (60x13) --size=8 --cols=51 --rows=11 9 - 46 x 12 ### PaperTTY {#papertty} #### Install Pre-Reqs{#deps} ##### Apt Packages{#packages} ```shell {linenos=false} apt-get install libjpeg-dev libjpeg-turbo8-dev libjpeg8-dev \ libopenjp2-7 libtiff5 python3-pip python3-pip-whl \ python3-setuptools-whl python3-venv python3.10-venv \ python3-rgpio python3-rpi.gpio rpi.gpio-common \ rgpio-tools librgpio1 Poetry #Poetry is a packaging and dependency management toolchain for Python. Warning I do not advocate running random shit on the internet piped into an interpreter sight unseen. I STRONGLY encourage you to look at the script (found here) before running the install one-liner below: Install Poetry #curl -sSL https://install.python-poetry.org | python3 - Quickly test/validate Poetry’s functionality #root@coredns-03:~# poetry --version Poetry (version 1.2.1) Clone the Repo #root@coredns-03:~# git clone https://github.com/joukos/PaperTTY.git Cloning into 'PaperTTY'... remote: Enumerating objects: 801, done. remote: Counting objects: 100% (29/29), done. remote: Compressing objects: 100% (21/21), done. remote: Total 801 (delta 13), reused 20 (delta 8), pack-reused 772 Receiving objects: 100% (801/801), 7.00 MiB | 13.36 MiB/s, done. Resolving deltas: 100% (497/497), done. root@coredns-03:~# Build PaperTTY # root@coredns-03:~# cd ~/PaperTTY && poetry install root@coredns-03:~# cd ~/PaperTTY && poetry install Creating virtualenv papertty-uSU0pReX-py3.10 in /root/.cache/pypoetry/virtualenvs Updating dependencies Resolving dependencies... (163.6s) Writing lock file Package operations: 1 install, 9 updates, 0 removals • Updating attrs (19.3.0 -> 22.1.0) • Updating idna (2.9 -> 3.4) • Updating setuptools (65.3.0 -> 50.3.2) • Updating six (1.15.0 -> 1.16.0) • Updating hyperlink (19.0.0 -> 21.0.0) • Updating incremental (17.5.0 -> 21.3.0) • Updating pyhamcrest (2.0.2 -> 2.0.3) • Updating zope-interface (5.1.0 -> 5.4.0) • Installing rpi-gpio (0.7.1) • Updating spidev (3.4 -> 3.5) Installing the current project: papertty (0.1.8b) Waveshare recommendations #According to [WaveShare’s guidance][waveshare-docs] [waveshare-docs], the following are necessary: The latest version of [libbcm2835][lib-bcm2835-site][libbcm2835site] here’s a link to the [src tarball][lib-bcm2835-tarball][libbcm2835tarball], The version of WiringPi [specifically from this repo.][wiringpi-repo][wiringpi-repo] I don’t think this was strictly necessary though. In fact, I’m fairly certain this was a red herring. Nevertheless this was the install process.. it’s useful so as to be able to ascertain if the problem is papertty or the eink display / pi BCM2835 #CopyPasta: cd /usr/src && \ wget http://www.airspayce.com/mikem/bcm2835/bcm2835-1.71.tar.gz && \ tar xzvf bcm2835-1.71.tar.gz && \ cd /usr/src/bcm2835-1.71 && \ ./configure && make && make install && \ ls -la /usr/local/lib/libbcm2835.a /usr/local/include/bcm2835.h Acutally running the commands: root@coredns-03:~# cd /usr/src root@coredns-03:/usr/src# wget http://www.airspayce.com/mikem/bcm2835/bcm2835-1.71.tar.gz root@coredns-03:/usr/src# tar xzvf bcm2835-1.71.tar.gz root@coredns-03:/usr/src# cd bcm2835-1.71/ root@coredns-03:/usr/src/bcm2835-1.71# ./configure && make && make install Inspect them for good measure: root@coredns-03:/usr/src/bcm2835-1.71# ls -la /usr/local/lib/libbcm2835.a /usr/local/include/bcm2835.h -rw-r--r-- 1 root root 430648 Sep 18 23:21 /usr/local/lib/libbcm2835.a -rw-r--r-- 1 root root 105329 Sep 18 23:21 /usr/local/include/bcm2835.h WiringPi #Copypasta: cd /usr/src && git clone https://github.com/WiringPi/WiringPi.git && cd WiringPi && /usr/src/WiringPi/build root@coredns-03:/usr/src# cd /usr/src && git clone https://github.com/WiringPi/WiringPi.git Cloning into 'WiringPi'... remote: Enumerating objects: 1730, done. remote: Counting objects: 100% (613/613), done. remote: Compressing objects: 100% (112/112), done. remote: Total 1730 (delta 554), reused 501 (delta 501), pack-reused 1117 Receiving objects: 100% (1730/1730), 802.92 KiB | 3.72 MiB/s, done. Resolving deltas: 100% (1186/1186), done. root@coredns-03:/usr/src# cd WiringPi && /usr/src/WiringPi/build ... sysctls #TBD oepn files network buffers calomel tips Prometheus #apt-get install bwm-ng libconfig9 libfreetype-dev libio-pty-perl libipc-run-perl libpng-dev libpng-tools libsnmp-base libsnmp40 libtime-duration-perl libtimedate-perl lldpad lldpd moreutils nfs-common prometheus-node-exporter prometheus-node-exporter-collectors python-is-python3 python3-pip smartmontools snmp snmp-mibs-downloader sockperf spi-tools Extra Credit #WTFUtil #https://wtfutil.com https://github.com/wtfutil/wtf.git ⬅⃖⃖ Back to Robustify …Continue ➡⃗⃗