fw_lib.sh 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. # Library of helpers for test scripts.
  4. set -e
  5. DIR=/sys/devices/virtual/misc/test_firmware
  6. PROC_CONFIG="/proc/config.gz"
  7. TEST_DIR=$(dirname $0)
  8. # Kselftest framework requirement - SKIP code is 4.
  9. ksft_skip=4
  10. print_reqs_exit()
  11. {
  12. echo "You must have the following enabled in your kernel:" >&2
  13. cat $TEST_DIR/config >&2
  14. exit $ksft_skip
  15. }
  16. test_modprobe()
  17. {
  18. if [ ! -d $DIR ]; then
  19. print_reqs_exit
  20. fi
  21. }
  22. check_mods()
  23. {
  24. local uid=$(id -u)
  25. if [ $uid -ne 0 ]; then
  26. echo "skip all tests: must be run as root" >&2
  27. exit $ksft_skip
  28. fi
  29. trap "test_modprobe" EXIT
  30. if [ ! -d $DIR ]; then
  31. modprobe test_firmware
  32. fi
  33. if [ ! -f $PROC_CONFIG ]; then
  34. if modprobe configs 2>/dev/null; then
  35. echo "Loaded configs module"
  36. if [ ! -f $PROC_CONFIG ]; then
  37. echo "You must have the following enabled in your kernel:" >&2
  38. cat $TEST_DIR/config >&2
  39. echo "Resorting to old heuristics" >&2
  40. fi
  41. else
  42. echo "Failed to load configs module, using old heuristics" >&2
  43. fi
  44. fi
  45. }
  46. check_setup()
  47. {
  48. HAS_FW_LOADER_USER_HELPER="$(kconfig_has CONFIG_FW_LOADER_USER_HELPER=y)"
  49. HAS_FW_LOADER_USER_HELPER_FALLBACK="$(kconfig_has CONFIG_FW_LOADER_USER_HELPER_FALLBACK=y)"
  50. PROC_FW_IGNORE_SYSFS_FALLBACK="0"
  51. PROC_FW_FORCE_SYSFS_FALLBACK="0"
  52. if [ -z $PROC_SYS_DIR ]; then
  53. PROC_SYS_DIR="/proc/sys/kernel"
  54. fi
  55. FW_PROC="${PROC_SYS_DIR}/firmware_config"
  56. FW_FORCE_SYSFS_FALLBACK="$FW_PROC/force_sysfs_fallback"
  57. FW_IGNORE_SYSFS_FALLBACK="$FW_PROC/ignore_sysfs_fallback"
  58. if [ -f $FW_FORCE_SYSFS_FALLBACK ]; then
  59. PROC_FW_FORCE_SYSFS_FALLBACK="$(cat $FW_FORCE_SYSFS_FALLBACK)"
  60. fi
  61. if [ -f $FW_IGNORE_SYSFS_FALLBACK ]; then
  62. PROC_FW_IGNORE_SYSFS_FALLBACK="$(cat $FW_IGNORE_SYSFS_FALLBACK)"
  63. fi
  64. if [ "$PROC_FW_FORCE_SYSFS_FALLBACK" = "1" ]; then
  65. HAS_FW_LOADER_USER_HELPER="yes"
  66. HAS_FW_LOADER_USER_HELPER_FALLBACK="yes"
  67. fi
  68. if [ "$PROC_FW_IGNORE_SYSFS_FALLBACK" = "1" ]; then
  69. HAS_FW_LOADER_USER_HELPER_FALLBACK="no"
  70. HAS_FW_LOADER_USER_HELPER="no"
  71. fi
  72. if [ "$HAS_FW_LOADER_USER_HELPER" = "yes" ]; then
  73. OLD_TIMEOUT="$(cat /sys/class/firmware/timeout)"
  74. fi
  75. OLD_FWPATH="$(cat /sys/module/firmware_class/parameters/path)"
  76. }
  77. verify_reqs()
  78. {
  79. if [ "$TEST_REQS_FW_SYSFS_FALLBACK" = "yes" ]; then
  80. if [ ! "$HAS_FW_LOADER_USER_HELPER" = "yes" ]; then
  81. echo "usermode helper disabled so ignoring test"
  82. exit 0
  83. fi
  84. fi
  85. }
  86. setup_tmp_file()
  87. {
  88. FWPATH=$(mktemp -d)
  89. FW="$FWPATH/test-firmware.bin"
  90. echo "ABCD0123" >"$FW"
  91. NAME=$(basename "$FW")
  92. if [ "$TEST_REQS_FW_SET_CUSTOM_PATH" = "yes" ]; then
  93. echo -n "$FWPATH" >/sys/module/firmware_class/parameters/path
  94. fi
  95. }
  96. __setup_random_file()
  97. {
  98. RANDOM_FILE_PATH="$(mktemp -p $FWPATH)"
  99. # mktemp says dry-run -n is unsafe, so...
  100. if [[ "$1" = "fake" ]]; then
  101. rm -rf $RANDOM_FILE_PATH
  102. sync
  103. else
  104. echo "ABCD0123" >"$RANDOM_FILE_PATH"
  105. fi
  106. echo $RANDOM_FILE_PATH
  107. }
  108. setup_random_file()
  109. {
  110. echo $(__setup_random_file)
  111. }
  112. setup_random_file_fake()
  113. {
  114. echo $(__setup_random_file fake)
  115. }
  116. proc_set_force_sysfs_fallback()
  117. {
  118. if [ -f $FW_FORCE_SYSFS_FALLBACK ]; then
  119. echo -n $1 > $FW_FORCE_SYSFS_FALLBACK
  120. check_setup
  121. fi
  122. }
  123. proc_set_ignore_sysfs_fallback()
  124. {
  125. if [ -f $FW_IGNORE_SYSFS_FALLBACK ]; then
  126. echo -n $1 > $FW_IGNORE_SYSFS_FALLBACK
  127. check_setup
  128. fi
  129. }
  130. proc_restore_defaults()
  131. {
  132. proc_set_force_sysfs_fallback 0
  133. proc_set_ignore_sysfs_fallback 0
  134. }
  135. test_finish()
  136. {
  137. if [ "$HAS_FW_LOADER_USER_HELPER" = "yes" ]; then
  138. echo "$OLD_TIMEOUT" >/sys/class/firmware/timeout
  139. fi
  140. if [ "$TEST_REQS_FW_SET_CUSTOM_PATH" = "yes" ]; then
  141. if [ "$OLD_FWPATH" = "" ]; then
  142. # A zero-length write won't work; write a null byte
  143. printf '\000' >/sys/module/firmware_class/parameters/path
  144. else
  145. echo -n "$OLD_FWPATH" >/sys/module/firmware_class/parameters/path
  146. fi
  147. fi
  148. if [ -f $FW ]; then
  149. rm -f "$FW"
  150. fi
  151. if [ -d $FWPATH ]; then
  152. rm -rf "$FWPATH"
  153. fi
  154. proc_restore_defaults
  155. }
  156. kconfig_has()
  157. {
  158. if [ -f $PROC_CONFIG ]; then
  159. if zgrep -q $1 $PROC_CONFIG 2>/dev/null; then
  160. echo "yes"
  161. else
  162. echo "no"
  163. fi
  164. else
  165. # We currently don't have easy heuristics to infer this
  166. # so best we can do is just try to use the kernel assuming
  167. # you had enabled it. This matches the old behaviour.
  168. if [ "$1" = "CONFIG_FW_LOADER_USER_HELPER_FALLBACK=y" ]; then
  169. echo "yes"
  170. elif [ "$1" = "CONFIG_FW_LOADER_USER_HELPER=y" ]; then
  171. if [ -d /sys/class/firmware/ ]; then
  172. echo yes
  173. else
  174. echo no
  175. fi
  176. fi
  177. fi
  178. }