blob: 779c9ec5c3d102db719682003d768f29451f9d3c [file] [log] [blame]
Simon Glassbbb0b122011-10-15 05:48:21 +00001#
2# Copyright (c) 2011 The Chromium OS Authors.
3#
Wolfgang Denk1a459662013-07-08 09:37:19 +02004# SPDX-License-Identifier: GPL-2.0+
Simon Glassbbb0b122011-10-15 05:48:21 +00005#
6
7# This Makefile builds the internal U-Boot fdt if CONFIG_OF_CONTROL is
8# enabled. See doc/README.fdt-control for more details.
9
Masahiro Yamadaefcf8612014-02-04 17:24:40 +090010DEVICE_TREE ?= $(CONFIG_DEFAULT_DEVICE_TREE:"%"=%)
11ifeq ($(DEVICE_TREE),)
Masahiro Yamada3284c8b2014-02-05 11:28:27 +090012DEVICE_TREE := unset
Masahiro Yamadaefcf8612014-02-04 17:24:40 +090013endif
Simon Glassbbb0b122011-10-15 05:48:21 +000014
James Balean27cb7302017-03-15 23:11:31 -050015ARCH_PATH := arch/$(ARCH)/dts
16dtb_depends := arch-dtbs
17
Simon Glassd18926a2014-06-12 07:24:43 -060018ifneq ($(EXT_DTB),)
19DTB := $(EXT_DTB)
Simon Glass63b4b5b2014-06-02 22:04:50 -060020else
James Balean27cb7302017-03-15 23:11:31 -050021DTB := $(ARCH_PATH)/$(DEVICE_TREE).dtb
22dtb_depends += $(DTB:.dtb=.dts)
Simon Glass63b4b5b2014-06-02 22:04:50 -060023endif
Simon Glassbbb0b122011-10-15 05:48:21 +000024
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000025$(obj)/dt-spl.dtb: $(DTB) $(objtree)/tools/fdtgrep FORCE
26 $(call if_changed,fdtgrep)
27
Masahiro Yamada3284c8b2014-02-05 11:28:27 +090028$(obj)/dt.dtb: $(DTB) FORCE
Masahiro Yamadab9d1dbd2014-06-04 10:11:18 +090029 $(call if_changed,shipped)
Simon Glassbbb0b122011-10-15 05:48:21 +000030
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000031targets += dt.dtb dt-spl.dtb
Simon Glassbbb0b122011-10-15 05:48:21 +000032
James Balean27cb7302017-03-15 23:11:31 -050033$(DTB): $(dtb_depends)
34ifeq ($(EXT_DTB),)
35 $(Q)$(MAKE) $(build)=$(ARCH_PATH) $@
36endif
Masahiro Yamada3284c8b2014-02-05 11:28:27 +090037 $(Q)test -e $@ || ( \
38 echo >&2; \
39 echo >&2 "Device Tree Source is not correctly specified."; \
40 echo >&2 "Please define 'CONFIG_DEFAULT_DEVICE_TREE'"; \
41 echo >&2 "or build with 'DEVICE_TREE=<device_tree>' argument"; \
42 echo >&2; \
43 /bin/false)
44
45arch-dtbs:
James Balean27cb7302017-03-15 23:11:31 -050046 $(Q)$(MAKE) $(build)=$(ARCH_PATH) dtbs
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090047
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000048.SECONDARY: $(obj)/dt.dtb.S $(obj)/dt-spl.dtb.S
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090049
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000050
51ifeq ($(CONFIG_SPL_BUILD),y)
52obj-$(CONFIG_OF_EMBED) := dt-spl.dtb.o
53# support "out-of-tree" build for dtb-spl
54$(obj)/dt-spl.dtb.o: $(obj)/dt-spl.dtb.S FORCE
55 $(call if_changed_dep,as_o_S)
56else
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090057obj-$(CONFIG_OF_EMBED) := dt.dtb.o
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000058endif
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090059
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000060dtbs: $(obj)/dt.dtb $(obj)/dt-spl.dtb
Masahiro Yamada6ab6b2a2014-02-05 11:28:25 +090061 @:
62
Goldschmidt Simon9bd76b82017-11-21 12:29:56 +000063clean-files := dt.dtb.S dt-spl.dtb.S
Masahiro Yamada3284c8b2014-02-05 11:28:27 +090064
65# Let clean descend into dts directories
Masahiro Yamadabe6b2b32016-01-24 03:50:02 +090066subdir- += ../arch/arm/dts ../arch/microblaze/dts ../arch/mips/dts ../arch/sandbox/dts ../arch/x86/dts