xref: /openbmc/linux/arch/xtensa/boot/Makefile (revision 15e3ae36)
1#
2# arch/xtensa/boot/Makefile
3#
4# This file is subject to the terms and conditions of the GNU General Public
5# License.  See the file "COPYING" in the main directory of this archive
6# for more details.
7#
8#
9
10
11# KBUILD_CFLAGS used when building rest of boot (takes effect recursively)
12KBUILD_CFLAGS	+= -fno-builtin -Iarch/$(ARCH)/boot/include
13HOSTFLAGS	+= -Iarch/$(ARCH)/boot/include
14
15BIG_ENDIAN	:= $(shell echo __XTENSA_EB__ | $(CC) -E - | grep -v "\#")
16
17export BIG_ENDIAN
18
19subdir-y	:= lib
20
21# Subdirs for the boot loader(s)
22
23boot-$(CONFIG_XTENSA_PLATFORM_ISS)    += Image
24boot-$(CONFIG_XTENSA_PLATFORM_XT2000) += Image zImage uImage
25boot-$(CONFIG_XTENSA_PLATFORM_XTFPGA) += Image zImage uImage
26
27all: $(boot-y)
28Image: boot-elf
29zImage: boot-redboot
30uImage: $(obj)/uImage
31xipImage: $(obj)/xipImage
32
33boot-elf boot-redboot: $(addprefix $(obj)/,$(subdir-y))
34	$(Q)$(MAKE) $(build)=$(obj)/$@ $(MAKECMDGOALS)
35
36OBJCOPYFLAGS = --strip-all -R .comment -R .notes -O binary
37
38vmlinux.bin: vmlinux FORCE
39	$(call if_changed,objcopy)
40
41vmlinux.bin.gz: vmlinux.bin FORCE
42	$(call if_changed,gzip)
43
44boot-elf: vmlinux.bin
45boot-redboot: vmlinux.bin.gz
46
47UIMAGE_LOADADDR = $(CONFIG_KERNEL_LOAD_ADDRESS)
48UIMAGE_COMPRESSION = gzip
49
50$(obj)/uImage: vmlinux.bin.gz FORCE
51	$(call if_changed,uimage)
52	$(Q)$(kecho) '  Kernel: $@ is ready'
53
54$(obj)/xipImage: vmlinux FORCE
55	$(call if_changed,objcopy)
56	$(Q)$(kecho) '  Kernel: $@ is ready'
57