blob: a7a604303cc63ae836b8c4c16635514c24e6c3ef [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
Simon Glass38d6b8d2011-10-15 05:48:21 +00002#
3# Copyright (c) 2011 The Chromium OS Authors.
Simon Glass38d6b8d2011-10-15 05:48:21 +00004
5# This Makefile builds the internal U-Boot fdt if CONFIG_OF_CONTROL is
6# enabled. See doc/README.fdt-control for more details.
7
Masahiro Yamada43c08932014-02-05 11:28:25 +09008DEVICE_TREE ?= $(CONFIG_DEFAULT_DEVICE_TREE:"%"=%)
9ifeq ($(DEVICE_TREE),)
Masahiro Yamadae7a579f2014-02-05 11:28:27 +090010DEVICE_TREE := unset
Masahiro Yamada43c08932014-02-05 11:28:25 +090011endif
Stephen Warrenc198ef72013-07-24 10:09:19 -070012
James Baleanbc432632017-03-15 23:11:31 -050013ARCH_PATH := arch/$(ARCH)/dts
14dtb_depends := arch-dtbs
15
Simon Glassc3b0de42014-06-12 07:24:43 -060016ifneq ($(EXT_DTB),)
17DTB := $(EXT_DTB)
Simon Glass67bce6b2014-06-02 22:04:50 -060018else
James Baleanbc432632017-03-15 23:11:31 -050019DTB := $(ARCH_PATH)/$(DEVICE_TREE).dtb
20dtb_depends += $(DTB:.dtb=.dts)
Simon Glass67bce6b2014-06-02 22:04:50 -060021endif
Stephen Warrenc198ef72013-07-24 10:09:19 -070022
Goldschmidt Simon5e7a1c22017-11-21 12:29:56 +000023$(obj)/dt-spl.dtb: $(DTB) $(objtree)/tools/fdtgrep FORCE
24 $(call if_changed,fdtgrep)
25
Masahiro Yamadae7a579f2014-02-05 11:28:27 +090026$(obj)/dt.dtb: $(DTB) FORCE
Masahiro Yamada97e101c2014-06-04 10:11:18 +090027 $(call if_changed,shipped)
Simon Glass38d6b8d2011-10-15 05:48:21 +000028
Goldschmidt Simon5e7a1c22017-11-21 12:29:56 +000029targets += dt.dtb dt-spl.dtb
Simon Glass38d6b8d2011-10-15 05:48:21 +000030
James Baleanbc432632017-03-15 23:11:31 -050031$(DTB): $(dtb_depends)
32ifeq ($(EXT_DTB),)
33 $(Q)$(MAKE) $(build)=$(ARCH_PATH) $@
34endif
Masahiro Yamadae7a579f2014-02-05 11:28:27 +090035 $(Q)test -e $@ || ( \
36 echo >&2; \
37 echo >&2 "Device Tree Source is not correctly specified."; \
38 echo >&2 "Please define 'CONFIG_DEFAULT_DEVICE_TREE'"; \
39 echo >&2 "or build with 'DEVICE_TREE=<device_tree>' argument"; \
40 echo >&2; \
41 /bin/false)
42
43arch-dtbs:
James Baleanbc432632017-03-15 23:11:31 -050044 $(Q)$(MAKE) $(build)=$(ARCH_PATH) dtbs
Simon Glass38d6b8d2011-10-15 05:48:21 +000045
Goldschmidt Simon5e7a1c22017-11-21 12:29:56 +000046ifeq ($(CONFIG_SPL_BUILD),y)
47obj-$(CONFIG_OF_EMBED) := dt-spl.dtb.o
48# support "out-of-tree" build for dtb-spl
49$(obj)/dt-spl.dtb.o: $(obj)/dt-spl.dtb.S FORCE
50 $(call if_changed_dep,as_o_S)
51else
Masahiro Yamada43c08932014-02-05 11:28:25 +090052obj-$(CONFIG_OF_EMBED) := dt.dtb.o
Goldschmidt Simon5e7a1c22017-11-21 12:29:56 +000053endif
Simon Glass38d6b8d2011-10-15 05:48:21 +000054
Goldschmidt Simon5e7a1c22017-11-21 12:29:56 +000055dtbs: $(obj)/dt.dtb $(obj)/dt-spl.dtb
Masahiro Yamada43c08932014-02-05 11:28:25 +090056 @:
Simon Glass38d6b8d2011-10-15 05:48:21 +000057
Goldschmidt Simon5e7a1c22017-11-21 12:29:56 +000058clean-files := dt.dtb.S dt-spl.dtb.S
Masahiro Yamadae7a579f2014-02-05 11:28:27 +090059
60# Let clean descend into dts directories
Lukas Auerbad1b5e2018-11-22 11:26:11 +010061subdir- += ../arch/arm/dts ../arch/microblaze/dts ../arch/mips/dts ../arch/sandbox/dts ../arch/x86/dts ../arch/powerpc/dts ../arch/riscv/dts