From a424e6498528a63c6f8186242ce974e59e55f050 Mon Sep 17 00:00:00 2001 From: Bohdan Buinich Date: Mon, 29 Jan 2024 03:13:01 +0200 Subject: [PATCH] [ALL] Fix Service Failures during Boot (resolve issue 3) --- .../systemd/system/connectivity-check.service | 4 +- .../rootfs-overlay/usr/libexec/ovos-zram | 78 +++++++------------ 2 files changed, 29 insertions(+), 53 deletions(-) diff --git a/buildroot-external/rootfs-overlay/usr/lib/systemd/system/connectivity-check.service b/buildroot-external/rootfs-overlay/usr/lib/systemd/system/connectivity-check.service index 9bd81bfbe..c751986e6 100644 --- a/buildroot-external/rootfs-overlay/usr/lib/systemd/system/connectivity-check.service +++ b/buildroot-external/rootfs-overlay/usr/lib/systemd/system/connectivity-check.service @@ -2,10 +2,10 @@ DefaultDependencies=no After=nss-lookup.target Before=network-online.target -Type=oneshot -RemainAfterExit=yes [Service] +Type=oneshot +RemainAfterExit=yes ExecStart=sh -c 'while ! ping -c 1 docker.io; do sleep 1; done' [Install] diff --git a/buildroot-external/rootfs-overlay/usr/libexec/ovos-zram b/buildroot-external/rootfs-overlay/usr/libexec/ovos-zram index 332142039..a9d51c65a 100755 --- a/buildroot-external/rootfs-overlay/usr/libexec/ovos-zram +++ b/buildroot-external/rootfs-overlay/usr/libexec/ovos-zram @@ -1,81 +1,57 @@ #!/bin/sh # Credits go to: https://github.com/home-assistant/operating-system/ -set -e - -#### Options #### +set -e # Exit on any command failure +# Options TYPE="" -MOUNT="" -DEVICE="" SIZE=0 +MOUNT="" -#### Parse arguments #### - -while [ "$1" != "" ]; do - key=$1 - case $key in - -t|--type) - TYPE=$2 - shift - ;; - -s|--size) - SIZE=$2 - shift - ;; - -m|--mount) - MOUNT=$2 - shift - ;; - *) - echo "[Error] $0 : Argument '$1' unknown" - exit 1 - ;; +# Parse arguments +while [ "$#" -gt 0 ]; do + case "$1" in + -t|--type) TYPE="$2"; shift 2 ;; + -s|--size) SIZE="$2"; shift 2 ;; + -m|--mount) MOUNT="$2"; shift 2 ;; + *) echo "Error: Invalid argument '$1'"; exit 1 ;; esac - shift done -# Valide Type +# Validate Type if [ "$TYPE" != "swap" ] && [ "$TYPE" != "fs" ]; then - echo "[Error] Type unknown!" + echo "Error: Type must be 'swap' or 'fs'" exit 1 fi -# Lookup device +# Determine device based on type and mount +DEVICE="/dev/zram" if [ "$TYPE" = "swap" ]; then - DEVICE="/dev/zram0" + DEVICE+="0" elif [ "$MOUNT" = "var" ]; then - DEVICE="/dev/zram1" -#elif [ "$MOUNT" = "tmp" ]; then -# DEVICE="/dev/zram1" + DEVICE+="1" else - echo "[Error] No device for lookup!" + echo "Error: No device for lookup!" exit 1 fi -# Calc 20% of memory for ZRAM swap partition -if [ "$TYPE" = "swap" ] && [ "$SIZE" -eq "0" ]; then - SIZE="$(awk '/MemTotal/{ print $2 * 0.20 }' /proc/meminfo)K" +# Calculate 20% of memory for ZRAM swap partition if not specified +if [ "$TYPE" = "swap" ] && [ "$SIZE" -eq 0 ]; then + SIZE=$(awk '/MemTotal/{ print int($2 * 0.20) }' /proc/meminfo)K fi -# Init device +# Initialize ZRAM device zramctl "$DEVICE" -s "$SIZE" -a lz4 -# Swap +# Setup based on type if [ "$TYPE" = "swap" ]; then mkswap -L "ovos-zramswap" "$DEVICE" -fi - -# FileSystem -if [ "$TYPE" = "fs" ]; then +elif [ "$TYPE" = "fs" ]; then mkfs.ext4 -L "ovos-$MOUNT" -O ^has_journal "$DEVICE" fi -# Copy persistent file structures into zram device +# Handle var mount if [ "$MOUNT" = "var" ]; then - # Check if this is a first run - if [ ! -d /mnt/data/var ]; then - mkdir -p /mnt/data/var - cp -af /var/* /mnt/data/var/ - fi - cp -af /mnt/data/var/* "$DEVICE" + VAR_DIR="/mnt/data/var" + [ ! -d "$VAR_DIR" ] && mkdir -p "$VAR_DIR" && cp -af /var/* "$VAR_DIR" + cp -af "$VAR_DIR"/* "$DEVICE" fi