Makefile 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. # scripts/dtc makefile
  2. # *** Also keep .gitignore in sync when changing ***
  3. hostprogs-y := dtc fdtoverlay
  4. ifeq ($(DTC_EXT),)
  5. always := $(hostprogs-y)
  6. endif
  7. dtc-objs := dtc.o flattree.o fstree.o data.o livetree.o treesource.o \
  8. srcpos.o checks.o util.o
  9. dtc-objs += dtc-lexer.lex.o dtc-parser.tab.o
  10. # The upstream project builds libfdt as a separate library. We are choosing to
  11. # instead directly link the libfdt object files into fdtoverlay.
  12. libfdt-objs := fdt.o fdt_ro.o fdt_wip.o fdt_sw.o fdt_rw.o fdt_strerror.o fdt_empty_tree.o fdt_addresses.o fdt_overlay.o
  13. libfdt = $(addprefix libfdt/,$(libfdt-objs))
  14. fdtoverlay-objs := $(libfdt) fdtoverlay.o util.o
  15. # Source files need to get at the userspace version of libfdt_env.h to compile
  16. HOST_EXTRACFLAGS += -I$(src)/libfdt
  17. ifeq ($(shell pkg-config --exists yaml-0.1 2>/dev/null && echo yes),)
  18. HOST_EXTRACFLAGS += -DNO_YAML
  19. else
  20. dtc-objs += yamltree.o
  21. # To include <yaml.h> installed in a non-default path
  22. HOSTCFLAGS_yamltree.o := $(shell pkg-config --cflags yaml-0.1)
  23. # To link libyaml installed in a non-default path
  24. HOSTLDLIBS_dtc := $(shell pkg-config --libs yaml-0.1)
  25. endif
  26. # Generated files need one more search path to include headers in source tree
  27. HOSTCFLAGS_dtc-lexer.lex.o := -I$(src)
  28. HOSTCFLAGS_dtc-parser.tab.o := -I$(src)
  29. # dependencies on generated files need to be listed explicitly
  30. $(obj)/dtc-lexer.lex.o: $(obj)/dtc-parser.tab.h
  31. # generated files need to be cleaned explicitly
  32. clean-files := dtc-lexer.lex.c dtc-parser.tab.c dtc-parser.tab.h