Makefile 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. # SPDX-License-Identifier: GPL-2.0
  2. DT_DOC_CHECKER ?= dt-doc-validate
  3. DT_EXTRACT_EX ?= dt-extract-example
  4. DT_MK_SCHEMA ?= dt-mk-schema
  5. DT_SCHEMA_LINT = $(shell which yamllint || \
  6. echo "warning: python package 'yamllint' not installed, skipping" >&2)
  7. DT_SCHEMA_MIN_VERSION = 2023.9
  8. PHONY += check_dtschema_version
  9. check_dtschema_version:
  10. @which $(DT_DOC_CHECKER) >/dev/null || \
  11. { echo "Error: '$(DT_DOC_CHECKER)' not found!" >&2; \
  12. echo "Ensure dtschema python package is installed and in your PATH." >&2; \
  13. echo "Current PATH is:" >&2; \
  14. echo "$$PATH" >&2; false; }
  15. @{ echo $(DT_SCHEMA_MIN_VERSION); \
  16. $(DT_DOC_CHECKER) --version 2>/dev/null || echo 0; } | sort -Vc >/dev/null || \
  17. { echo "ERROR: dtschema minimum version is v$(DT_SCHEMA_MIN_VERSION)" >&2; false; }
  18. quiet_cmd_extract_ex = DTEX $@
  19. cmd_extract_ex = $(DT_EXTRACT_EX) $< > $@
  20. $(obj)/%.example.dts: $(src)/%.yaml check_dtschema_version FORCE
  21. $(call if_changed,extract_ex)
  22. find_all_cmd = find $(src) \( -name '*.yaml' ! \
  23. -name 'processed-schema*' \)
  24. find_cmd = $(find_all_cmd) | \
  25. sed 's|^$(srctree)/||' | \
  26. grep -F -e "$(subst :," -e ",$(DT_SCHEMA_FILES))" | \
  27. sed 's|^|$(srctree)/|'
  28. CHK_DT_EXAMPLES := $(patsubst $(srctree)/%.yaml,%.example.dtb, \
  29. $(shell $(find_cmd) | xargs grep -l '^examples:'))
  30. quiet_cmd_yamllint = LINT $(src)
  31. cmd_yamllint = ($(find_cmd) | \
  32. xargs -n200 -P$$(nproc) \
  33. $(DT_SCHEMA_LINT) -f parsable -c $(src)/.yamllint >&2) \
  34. && touch $@ || true
  35. quiet_cmd_chk_bindings = CHKDT $(src)
  36. cmd_chk_bindings = ($(find_cmd) | \
  37. xargs -n200 -P$$(nproc) $(DT_DOC_CHECKER) -u $(src)) \
  38. && touch $@ || true
  39. quiet_cmd_mk_schema = SCHEMA $@
  40. cmd_mk_schema = f=$$(mktemp) ; \
  41. $(find_all_cmd) > $$f ; \
  42. $(DT_MK_SCHEMA) -j $(DT_MK_SCHEMA_FLAGS) @$$f > $@ ; \
  43. rm -f $$f
  44. DT_DOCS = $(patsubst $(srctree)/%,%,$(shell $(find_all_cmd)))
  45. override DTC_FLAGS := \
  46. -Wno-avoid_unnecessary_addr_size \
  47. -Wno-unique_unit_address \
  48. -Wunique_unit_address_if_enabled
  49. $(obj)/processed-schema.json: $(DT_DOCS) check_dtschema_version FORCE
  50. $(call if_changed,mk_schema)
  51. targets += .dt-binding.checked .yamllint.checked
  52. $(obj)/.yamllint.checked: $(DT_DOCS) $(src)/.yamllint FORCE
  53. $(if $(DT_SCHEMA_LINT),$(call if_changed,yamllint),)
  54. $(obj)/.dt-binding.checked: $(DT_DOCS) FORCE
  55. $(call if_changed,chk_bindings)
  56. always-y += processed-schema.json
  57. targets += $(patsubst $(obj)/%,%, $(CHK_DT_EXAMPLES))
  58. targets += $(patsubst $(obj)/%.dtb,%.dts, $(CHK_DT_EXAMPLES))
  59. # Hack: avoid 'Argument list too long' error for 'make clean'. Remove most of
  60. # build artifacts here before they are processed by scripts/Makefile.clean
  61. clean-files = $(shell find $(obj) \( -name '*.example.dts' -o \
  62. -name '*.example.dtb' \) -delete 2>/dev/null)
  63. dt_compatible_check: $(obj)/processed-schema.json
  64. $(Q)$(srctree)/scripts/dtc/dt-extract-compatibles $(srctree) | xargs dt-check-compatible -v -s $<
  65. PHONY += dt_binding_check_one
  66. dt_binding_check_one: $(obj)/.dt-binding.checked $(obj)/.yamllint.checked
  67. PHONY += dt_binding_check
  68. dt_binding_check: dt_binding_check_one $(CHK_DT_EXAMPLES)