xref: /openbmc/linux/scripts/dtc/Makefile (revision c3476d2f)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
29fffb55fSDavid Gibson# scripts/dtc makefile
39fffb55fSDavid Gibson
4*c3476d2fSRob Herring# *** Also keep .gitignore in sync when changing ***
50da6bcd9SViresh Kumarhostprogs-always-$(CONFIG_DTC)		+= dtc fdtoverlay
6faabed29SMasahiro Yamadahostprogs-always-$(CHECK_DT_BINDING)	+= dtc
79fffb55fSDavid Gibson
89fffb55fSDavid Gibsondtc-objs	:= dtc.o flattree.o fstree.o data.o livetree.o treesource.o \
9658f29a5SJohn Bonesio		   srcpos.o checks.o util.o
109fffb55fSDavid Gibsondtc-objs	+= dtc-lexer.lex.o dtc-parser.tab.o
119fffb55fSDavid Gibson
120da6bcd9SViresh Kumar# The upstream project builds libfdt as a separate library.  We are choosing to
130da6bcd9SViresh Kumar# instead directly link the libfdt object files into fdtoverlay.
140da6bcd9SViresh Kumarlibfdt-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
150da6bcd9SViresh Kumarlibfdt		= $(addprefix libfdt/,$(libfdt-objs))
160da6bcd9SViresh Kumarfdtoverlay-objs	:= $(libfdt) fdtoverlay.o util.o
170da6bcd9SViresh Kumar
189fffb55fSDavid Gibson# Source files need to get at the userspace version of libfdt_env.h to compile
19efe84d40SUwe Kleine-KönigHOST_EXTRACFLAGS += -I $(srctree)/$(src)/libfdt
209fffb55fSDavid Gibson
21067c650cSPavel Modilaynenifeq ($(shell pkg-config --exists yaml-0.1 2>/dev/null && echo yes),)
220903060fSMasahiro Yamadaifneq ($(CHECK_DT_BINDING)$(CHECK_DTBS),)
234f0e3a57SRob Herring$(error dtc needs libyaml for DT schema validation support. \
244f0e3a57SRob Herring	Install the necessary libyaml development package.)
254f0e3a57SRob Herringendif
26f858927fSRob HerringHOST_EXTRACFLAGS += -DNO_YAML
27f858927fSRob Herringelse
28f858927fSRob Herringdtc-objs	+= yamltree.o
29f8d8b46cSMasahiro Yamada# To include <yaml.h> installed in a non-default path
30f8d8b46cSMasahiro YamadaHOSTCFLAGS_yamltree.o := $(shell pkg-config --cflags yaml-0.1)
31f8d8b46cSMasahiro Yamada# To link libyaml installed in a non-default path
32067c650cSPavel ModilaynenHOSTLDLIBS_dtc	:= $(shell pkg-config yaml-0.1 --libs)
33f858927fSRob Herringendif
34f858927fSRob Herring
35e3fd9b53SMasahiro Yamada# Generated files need one more search path to include headers in source tree
369cc342f6SMasahiro YamadaHOSTCFLAGS_dtc-lexer.lex.o := -I $(srctree)/$(src)
379cc342f6SMasahiro YamadaHOSTCFLAGS_dtc-parser.tab.o := -I $(srctree)/$(src)
389fffb55fSDavid Gibson
399fffb55fSDavid Gibson# dependencies on generated files need to be listed explicitly
4095abef88SArnaud Lacombe$(obj)/dtc-lexer.lex.o: $(obj)/dtc-parser.tab.h
41