2 # arch/riscv/boot/Makefile
4 # This file is included by the global makefile so that you can add your own
5 # architecture-specific flags and dependencies.
7 # This file is subject to the terms and conditions of the GNU General Public
8 # License. See the file "COPYING" in the main directory of this archive
11 # Copyright (C) 2018, Anup Patel.
12 # Author: Anup Patel <anup@brainfault.org>
14 # Based on the ia64 and arm64 boot/Makefile.
19 OBJCOPYFLAGS_Image :=-O binary -R .note -R .note.gnu.build-id -R .comment -S
20 OBJCOPYFLAGS_xipImage :=-O binary -R .note -R .note.gnu.build-id -R .comment -S
22 targets := Image Image.* loader loader.o loader.lds loader.bin
23 targets := Image Image.* loader loader.o loader.lds loader.bin xipImage
25 ifeq ($(CONFIG_XIP_KERNEL),y)
27 quiet_cmd_mkxip = $(quiet_cmd_objcopy)
28 cmd_mkxip = $(cmd_objcopy)
30 $(obj)/xipImage: vmlinux FORCE
31 $(call if_changed,mkxip)
32 @$(kecho) ' Physical Address of xipImage: $(CONFIG_XIP_PHYS_ADDR)'
36 $(obj)/Image: vmlinux FORCE
37 $(call if_changed,objcopy)
39 $(obj)/Image.gz: $(obj)/Image FORCE
40 $(call if_changed,gzip)
42 $(obj)/loader.o: $(src)/loader.S $(obj)/Image
44 $(obj)/loader: $(obj)/loader.o $(obj)/Image $(obj)/loader.lds FORCE
45 $(Q)$(LD) -T $(obj)/loader.lds -o $@ $(obj)/loader.o
47 $(obj)/Image.bz2: $(obj)/Image FORCE
48 $(call if_changed,bzip2)
50 $(obj)/Image.lz4: $(obj)/Image FORCE
51 $(call if_changed,lz4)
53 $(obj)/Image.lzma: $(obj)/Image FORCE
54 $(call if_changed,lzma)
56 $(obj)/Image.lzo: $(obj)/Image FORCE
57 $(call if_changed,lzo)
59 $(obj)/loader.bin: $(obj)/loader FORCE
60 $(call if_changed,objcopy)
63 $(CONFIG_SHELL) $(srctree)/$(src)/install.sh $(KERNELRELEASE) \
64 $(obj)/Image System.map "$(INSTALL_PATH)"
67 $(CONFIG_SHELL) $(srctree)/$(src)/install.sh $(KERNELRELEASE) \
68 $(obj)/Image.gz System.map "$(INSTALL_PATH)"