#!/bin/sh # This validates that the kernel will load firmware out of its list of # firmware locations on disk. Since the user helper does similar work, # we reset the custom load directory to a location the user helper doesn't # know so we can be sure we're not accidentally testing the user helper. set -e modprobe test_firmware DIR=/sys/devices/virtual/misc/test_firmware OLD_TIMEOUT=$(cat /sys/class/firmware/timeout) OLD_FWPATH=$(cat /sys/module/firmware_class/parameters/path) FWPATH=$(mktemp -d) FW="$FWPATH/test-firmware.bin" test_finish() { echo "$OLD_TIMEOUT" >/sys/class/firmware/timeout echo -n "$OLD_PATH" >/sys/module/firmware_class/parameters/path rm -f "$FW" rmdir "$FWPATH" } trap "test_finish" EXIT # Turn down the timeout so failures don't take so long. echo 1 >/sys/class/firmware/timeout # Set the kernel search path. echo -n "$FWPATH" >/sys/module/firmware_class/parameters/path # This is an unlikely real-world firmware content. :) echo "ABCD0123" >"$FW" NAME=$(basename "$FW") if printf '\000' >"$DIR"/trigger_request 2> /dev/null; then echo "$0: empty filename should not succeed" >&2 exit 1 fi # Request a firmware that doesn't exist, it should fail. if echo -n "nope-$NAME" >"$DIR"/trigger_request 2> /dev/null; then echo "$0: firmware shouldn't have loaded" >&2 exit 1 fi if diff -q "$FW" /dev/test_firmware >/dev/null ; then echo "$0: firmware was not expected to match" >&2 exit 1 else echo "$0: timeout works" fi # This should succeed via kernel load or will fail after 1 second after # being handed over to the user helper, which won't find the fw either. if ! echo -n "$NAME" >"$DIR"/trigger_request ; then echo "$0: could not trigger request" >&2 exit 1 fi # Verify the contents are what we expect. if ! diff -q "$FW" /dev/test_firmware >/dev/null ; then echo "$0: firmware was not loaded" >&2 exit 1 else echo "$0: filesystem loading works" fi exit 0