generic-board-config.sh 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. #!/bin/sh
  2. #
  3. # Copyright (C) 2017 Imagination Technologies
  4. # Author: Paul Burton <paul.burton@mips.com>
  5. #
  6. # This program is free software; you can redistribute it and/or modify it
  7. # under the terms of the GNU General Public License as published by the
  8. # Free Software Foundation; either version 2 of the License, or (at your
  9. # option) any later version.
  10. #
  11. # This script merges configuration fragments for boards supported by the
  12. # generic MIPS kernel. It checks each for requirements specified using
  13. # formatted comments, and then calls merge_config.sh to merge those
  14. # fragments which have no unmet requirements.
  15. #
  16. # An example of requirements in your board config fragment might be:
  17. #
  18. # # require CONFIG_CPU_MIPS32_R2=y
  19. # # require CONFIG_CPU_LITTLE_ENDIAN=y
  20. #
  21. # This would mean that your board is only included in kernels which are
  22. # configured for little endian MIPS32r2 CPUs, and not for example in kernels
  23. # configured for 64 bit or big endian systems.
  24. #
  25. srctree="$1"
  26. objtree="$2"
  27. ref_cfg="$3"
  28. cfg="$4"
  29. boards_origin="$5"
  30. shift 5
  31. # Only print Skipping... lines if the user explicitly specified BOARDS=. In the
  32. # general case it only serves to obscure the useful output about what actually
  33. # was included.
  34. case ${boards_origin} in
  35. "command line")
  36. print_skipped=1
  37. ;;
  38. environment*)
  39. print_skipped=1
  40. ;;
  41. *)
  42. print_skipped=0
  43. ;;
  44. esac
  45. for board in $@; do
  46. board_cfg="${srctree}/arch/mips/configs/generic/board-${board}.config"
  47. if [ ! -f "${board_cfg}" ]; then
  48. echo "WARNING: Board config '${board_cfg}' not found"
  49. continue
  50. fi
  51. # For each line beginning with # require, cut out the field following
  52. # it & search for that in the reference config file. If the requirement
  53. # is not found then the subshell will exit with code 1, and we'll
  54. # continue on to the next board.
  55. grep -E '^# require ' "${board_cfg}" | \
  56. cut -d' ' -f 3- | \
  57. while read req; do
  58. case ${req} in
  59. *=y)
  60. # If we require something =y then we check that a line
  61. # containing it is present in the reference config.
  62. grep -Eq "^${req}\$" "${ref_cfg}" && continue
  63. ;;
  64. *=n)
  65. # If we require something =n then we just invert that
  66. # check, considering the requirement met if there isn't
  67. # a line containing the value =y in the reference
  68. # config.
  69. grep -Eq "^${req/%=n/=y}\$" "${ref_cfg}" || continue
  70. ;;
  71. *)
  72. echo "WARNING: Unhandled requirement '${req}'"
  73. ;;
  74. esac
  75. [ ${print_skipped} -eq 1 ] && echo "Skipping ${board_cfg}"
  76. exit 1
  77. done || continue
  78. # Merge this board config fragment into our final config file
  79. ${srctree}/scripts/kconfig/merge_config.sh \
  80. -m -O ${objtree} ${cfg} ${board_cfg} \
  81. | grep -Ev '^(#|Using)'
  82. done