PHONY += shellcheck
shellcheck:
@if type shellcheck > /dev/null 2>&1; then \
- shellcheck --exclude=SC1090 --exclude=SC1117 --format=gcc \
- $$(find ${top_srcdir}/scripts/*.sh -type f) \
- $$(find ${top_srcdir}/cmd/zed/zed.d/*.sh -type f) \
+ shellcheck --exclude=SC1090,SC1117,SC1091 --format=gcc \
+ $$(find ${top_srcdir} -name "config*" -prune -name tests -prune \
+ -o -name "*.sh" -o -name "*.sh.in" -type f) \
$$(find ${top_srcdir}/cmd/zpool/zpool.d/* \
-type f ${filter_executable}); \
else \
case "$(@sbindir@/zpool list -Ho health "$pool")" in
DEGRADED)
- ret=$(( $ret | 4 ))
+ ret=$(( ret | 4 ))
;;
FAULTED)
awk '!/^([[:space:]]*#.*)?$/ && $1 == "'"$dataset"'" && $3 == "zfs" {exit 1}' /etc/fstab || \
- ret=$(( $ret | 8 ))
+ ret=$(( ret | 8 ))
;;
"")
# Pool not found, error printed by zpool(8)
- ret=$(( $ret | 8 ))
+ ret=$(( ret | 8 ))
;;
*)
;;
-e "s/@SUBJECT@/${subject}/g")"
# shellcheck disable=SC2086
- eval "${ZED_EMAIL_PROG}" ${ZED_EMAIL_OPTS} < "${pathname}" >/dev/null 2>&1
+ ${ZED_EMAIL_PROG} ${ZED_EMAIL_OPTS} < "${pathname}" >/dev/null 2>&1
rv=$?
if [ "${rv}" -ne 0 ]; then
zed_log_err "$(basename "${ZED_EMAIL_PROG}") exit=${rv}"
OIFS="$IFS"
IFS="
"
+ # shellcheck disable=SC2086
zfs list -H -o name $zvols 2>/dev/null
IFS="$OIFS"
}
local poolconfigtemp
local poolconfigoutput
local pooldev
- local prefix
local resolved
- poolconfigtemp=`mktemp`
+ poolconfigtemp="$(mktemp)"
if ! @sbindir@/zpool list -v -H -P "$1" > "$poolconfigtemp" 2>&1 ; then
- poolconfigoutput=$(cat "$poolconfigtemp")
+ poolconfigoutput="$(cat "$poolconfigtemp")"
dinfo "zfsexpandknowledge: pool $1 cannot be listed: $poolconfigoutput"
else
- cat "$poolconfigtemp" | awk -F '\t' '/\t\/dev/ { print $2 }' | \
- while read pooldev ; do
- if [ -n "$pooldev" -a -e "$pooldev" ] ; then
- if [ -h "$pooldev" ] ; then
- resolved=`readlink -f "$pooldev"`
- else
- resolved="$pooldev"
- fi
+ awk -F '\t' '/\t\/dev/ { print $2 }' "$poolconfigtemp" | \
+ while read -r pooldev ; do
+ if [ -e "$pooldev" ] ; then
+ resolved="$(readlink -f "$pooldev")"
dinfo "zfsexpandknowledge: pool $1 has device $pooldev (which resolves to $resolved)"
echo "$resolved"
fi
find_zfs_block_devices() {
local dev
- local blockdev
local mp
local fstype
local pool
- local key
- local n
- local poolconfigoutput
- numfields=`head -1 /proc/self/mountinfo | awk '{print NF}'`
- if [ "$numfields" == "10" ] ; then
- fields="n n n n mp n n fstype dev n"
+ local _
+ numfields="$(awk '{print NF; exit}' /proc/self/mountinfo)"
+ if [ "$numfields" = "10" ] ; then
+ fields="_ _ _ _ mp _ _ fstype dev _"
else
- fields="n n n n mp n n n fstype dev n"
+ fields="_ _ _ _ mp _ _ _ fstype dev _"
fi
- while read $fields ; do
- if [ "$fstype" != "zfs" ]; then continue ; fi
- if [ "$mp" == "$1" ]; then
+ # shellcheck disable=SC2086
+ while read -r ${fields?} ; do
+ [ "$fstype" = "zfs" ] || continue
+ if [ "$mp" = "$1" ]; then
pool=$(echo "$dev" | cut -d / -f 1)
get_pool_devices "$pool"
fi
local _depdev
local _depdevname
local _depdevtype
- local _depmajmin
- local _dev
-if [[ $hostonly ]]; then
+# shellcheck disable=SC2154
+if [ -n "$hostonly" ]; then
for mp in \
"/" \
fstype=$(get_devtype "$dev")
host_fs_types["$dev"]="$fstype"
majmin=$(get_maj_min "$dev")
- if [[ -d /sys/dev/block/$majmin/slaves ]] ; then
- for _depdev in /sys/dev/block/$majmin/slaves/*; do
+ if [ -d "/sys/dev/block/$majmin/slaves" ] ; then
+ for _depdev in "/sys/dev/block/$majmin/slaves"/*; do
[[ -f $_depdev/dev ]] || continue
_depdev=/dev/$(basename "$_depdev")
_depdevname=$(udevadm info --query=property --name="$_depdev" | grep "^DEVNAME=" | sed 's|^DEVNAME=||')
_depdevtype=$(get_devtype "$_depdevname")
- _depmajmin=$(get_maj_min "$_depdevname")
dinfo "zfsexpandknowledge: underlying block device backing ZFS dataset $mp: ${_depdevname//$'\n'/ }"
array_contains "$_depdevname" "${host_devs[@]}" || host_devs+=("$_depdevname")
host_fs_types["$_depdevname"]="$_depdevtype"
#!/usr/bin/env bash
+# shellcheck disable=SC2154
check() {
# We depend on udev-rules being loaded
# Fallback: Guess the path and include all matches
dracut_install /usr/lib/gcc/*/*/libgcc_s.so*
fi
+ # shellcheck disable=SC2050
if [ @LIBFETCH_DYNAMIC@ != 0 ]; then
for d in $libdirs; do
[ -e "$d"/@LIBFETCH_SONAME@ ] && dracut_install "$d"/@LIBFETCH_SONAME@
#!/bin/sh
+# shellcheck disable=SC2034,SC2154
. /lib/dracut-zfs-lib.sh
if [ "${root}" = "zfs:AUTO" ] ; then
if ! ZFS_DATASET="$(find_bootfs)" ; then
+ # shellcheck disable=SC2086
zpool import -N -a ${ZPOOL_IMPORT_OPTS}
if ! ZFS_DATASET="$(find_bootfs)" ; then
warn "ZFS: No bootfs attribute found in importable pools."
#!/bin/sh
+# shellcheck disable=SC2034,SC2154
. /lib/dracut-lib.sh
info "ZFS: Enabling autodetection of bootfs after udev settles."
;;
- ZFS\=*|zfs:*|zfs:FILESYSTEM\=*|FILESYSTEM\=*)
+ ZFS=*|zfs:*|FILESYSTEM=*)
# root is explicit ZFS root. Parse it now. We can handle
# a root=... param in any of the following formats:
# root=ZFS=rpool/ROOT
#!/bin/sh
+# shellcheck disable=SC2016,SC1004
grep -wq debug /proc/cmdline && debug=1
[ -n "$debug" ] && echo "zfs-generator: starting" >> /dev/kmsg
if ! zpool list -H "${pool}" > /dev/null 2>&1; then
info "ZFS: Importing pool ${pool}..."
+ # shellcheck disable=SC2086
if ! zpool import -N ${ZPOOL_IMPORT_OPTS} "${pool}" ; then
warn "ZFS: Unable to import pool ${pool}"
return 1
# export_all OPTS
# exports all imported zfs pools.
export_all() {
- opts="${@}"
ret=0
IFS="${NEWLINE}"
for pool in $(zpool list -H -o name) ; do
if zpool list -H "${pool}" > /dev/null 2>&1; then
- zpool export "${pool}" ${opts} || ret=$?
+ zpool export "${pool}" "$@" || ret=$?
fi
done
IFS="${OLDIFS}"
#!/bin/sh
+# shellcheck disable=SC2154
# only run this on systemd systems, we handle the decrypt in mount-zfs.sh in the mount hook otherwise
[ -e /bin/systemctl ] || [ -e /usr/bin/systemctl ] || return 0
# We use pthreads, but i-t from buster doesn't automatically
# copy this indirect dependency: this can be removed when buster finally dies.
-for libgcc in $(find /lib/ -type f -name libgcc_s.so.[1-9]); do
+find /lib/ -type f -name "libgcc_s.so.[1-9]" | while read -r libgcc; do
copy_exec "$libgcc"
done
+# shellcheck disable=SC2050
if [ @LIBFETCH_DYNAMIC@ != 0 ]; then
- for libfetch in $(find /lib/ -name @LIBFETCH_SONAME@); do
+ find /lib/ -name @LIBFETCH_SONAME@ | while read -r libfetch; do
copy_exec "$libfetch"
done
fi
#!/bin/sh
-PREREQ="mdadm mdrun multipath"
+# shellcheck disable=SC2154
-prereqs()
-{
- echo "$PREREQ"
-}
-case $1 in
-# get pre-requisites
-prereqs)
- prereqs
+if [ "$1" = "prereqs" ]; then
+ echo mdadm mdrun multipath
exit 0
- ;;
-esac
+fi
#
#
message()
{
- if [ -x /bin/plymouth ] && plymouth --ping; then
- plymouth message --text="$@"
+ if plymouth --ping 2>/dev/null; then
+ plymouth message --text="$*"
else
- echo "$@" >&2
+ echo "$*" >&2
fi
return 0
}
exit 1
;;
v)
- # shellcheck disable=SC2034
VERBOSE="yes"
;;
q)
local MAX_DIR_SIZE=$2
local MAX_FILE_SIZE=$3
- # shellcheck disable=SC2086
- mkdir -p $ROOT/{a,b,c,d,e,f,g}/{h,i}
+ mkdir -p "$ROOT"/{a,b,c,d,e,f,g}/{h,i}
DIRS=$(find "$ROOT")
for DIR in $DIRS; do
COUNT=$((RANDOM % MAX_DIR_SIZE))
- # shellcheck disable=SC2034
- for i in $(seq $COUNT); do
+ for _ in $(seq $COUNT); do
FILE=$(mktemp -p "$DIR")
SIZE=$((RANDOM % MAX_FILE_SIZE))
dd if=/dev/urandom of="$FILE" bs=1k \
for TAG in $POOL_TAGS; do
if [ "$TAG" = "all" ]; then
- # shellcheck disable=SC2010
- ALL_TAGS=$(ls "$IMAGES_DIR" | grep "tar.bz2" | \
- sed 's/.tar.bz2//' | tr '\n' ' ')
+ ALL_TAGS=$(echo "$IMAGES_DIR"/*.tar.bz2 | \
+ sed "s|$IMAGES_DIR/||g;s|.tar.bz2||g")
NEW_TAGS="$NEW_TAGS $ALL_TAGS"
else
NEW_TAGS="$NEW_TAGS $TAG"
function core_file
{
- # shellcheck disable=SC2012 disable=2086
- printf "%s" "$(ls -tr1 $coreglob 2> /dev/null | head -1)"
+ # shellcheck disable=SC2012,SC2086
+ ls -tr1 $coreglob 2>/dev/null | head -1
}
function core_prog
prog=$ZTEST
core_id=$($GDB --batch -c "$1" | grep "Core was generated by" | \
tr \' ' ')
- # shellcheck disable=SC2076
- if [[ "$core_id" =~ "zdb " ]]; then
+ if [[ "$core_id" == *"zdb "* ]]; then
prog=$ZDB
fi
printf "%s" "$prog"
zopt="$zopt -s $size"
zopt="$zopt -f $workdir"
- # shellcheck disable=SC2124
- cmd="$ZTEST $zopt $@"
+ cmd="$ZTEST $zopt $*"
desc="$(date '+%m/%d %T') $cmd"
echo "$desc" | tee -a ztest.history
echo "$desc" >>ztest.out
# Read the file a few times to generate some
# duplicate errors of the same blocks
- # shellcheck disable=SC2034
- for i in {1..15}; do
+ for _ in {1..15}; do
dd if=$FILEPATH of=/dev/null bs=128K > /dev/null 2>&1
done
log_must zinject -c all
#!/usr/bin/env bash
+# shellcheck disable=SC1004
#
# This file and its contents are supplied under the terms of the
function get_prefetch_ios
{
- typeset -l data_misses=`awk '$1 == "prefetch_data_misses" \
- { print $3 }' $zfs_kstats/arcstats`
- typeset -l metadata_misses=`awk '$1 == "prefetch_metadata_misses" \
- { print $3 }' $zfs_kstats/arcstats`
- typeset -l total_misses=$(( $data_misses + $metadata_misses ))
+ typeset -l data_misses="$(awk '$1 == "prefetch_data_misses" \
+ { print $3; exit }' "$zfs_kstats/arcstats")"
+ typeset -l metadata_misses="$(awk '$1 == "prefetch_metadata_misses" \
+ { print $3; exit }' "$zfs_kstats/arcstats")"
+ typeset -l total_misses=$(( data_misses + metadata_misses ))
- echo $total_misses
+ echo "$total_misses"
}
function get_prefetched_demand_reads
{
- typeset -l demand_reads=`awk '$1 == "demand_hit_predictive_prefetch" \
- { print $3 }' $zfs_kstats/arcstats`
+ typeset -l demand_reads="$(awk '$1 == "demand_hit_predictive_prefetch" \
+ { print $3; exit }' "$zfs_kstats/arcstats")"
- echo $demand_reads
+ echo "$demand_reads"
}
function get_async_upgrade_sync
{
- typeset -l sync_wait=`awk '$1 == "async_upgrade_sync" \
- { print $3 }' $zfs_kstats/arcstats`
+ typeset -l sync_wait="$(awk '$1 == "async_upgrade_sync" \
+ { print $3; exit }' "$zfs_kstats/arcstats")"
- echo $sync_wait
+ echo "$sync_wait"
}
if [ $# -ne 2 ]
then
- echo "Usage: `basename $0` <poolname> interval" >&2
+ echo "Usage: ${0##*/} poolname interval" >&2
exit 1
fi
-poolname=$1
interval=$2
prefetch_ios=$(get_prefetch_ios)
prefetched_demand_reads=$(get_prefetched_demand_reads)
while true
do
new_prefetch_ios=$(get_prefetch_ios)
- printf "%u\n%-24s\t%u\n" $(date +%s) "prefetch_ios" \
- $(( $new_prefetch_ios - $prefetch_ios ))
+ printf "%u\n%-24s\t%u\n" "$(date +%s)" "prefetch_ios" \
+ $(( new_prefetch_ios - prefetch_ios ))
prefetch_ios=$new_prefetch_ios
new_prefetched_demand_reads=$(get_prefetched_demand_reads)
printf "%-24s\t%u\n" "prefetched_demand_reads" \
- $(( $new_prefetched_demand_reads - $prefetched_demand_reads ))
+ $(( new_prefetched_demand_reads - prefetched_demand_reads ))
prefetched_demand_reads=$new_prefetched_demand_reads
new_async_upgrade_sync=$(get_async_upgrade_sync)
printf "%-24s\t%u\n" "async_upgrade_sync" \
- $(( $new_async_upgrade_sync - $async_upgrade_sync ))
+ $(( new_async_upgrade_sync - async_upgrade_sync ))
async_upgrade_sync=$new_async_upgrade_sync
- sleep $interval
+ sleep "$interval"
done