fw_lib.sh 4.2 KB

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