blob: 0c796cf8158629abf23adb530c17ba2a8ceb9be5 [file] [log] [blame]
Michal Simek5f8ffb52009-03-27 14:25:51 +01001#
2# arch/microblaze/boot/Makefile
3#
4
Michal Simek6a8dfe12009-10-14 17:38:26 +02005MKIMAGE := $(srctree)/scripts/mkuboot.sh
6
Michal Simekf05131c2009-09-14 15:15:49 +02007obj-y += linked_dtb.o
8
9targets := linux.bin linux.bin.gz simpleImage.%
Michal Simek5f8ffb52009-03-27 14:25:51 +010010
Michal Simek6a8dfe12009-10-14 17:38:26 +020011OBJCOPYFLAGS := -O binary
Michal Simek5f8ffb52009-03-27 14:25:51 +010012
Michal Simekf05131c2009-09-14 15:15:49 +020013# Ensure system.dtb exists
14$(obj)/linked_dtb.o: $(obj)/system.dtb
15
16# Generate system.dtb from $(DTB).dtb
17ifneq ($(DTB),system)
18$(obj)/system.dtb: $(obj)/$(DTB).dtb
19 $(call if_changed,cp)
20endif
21
Michal Simek5f8ffb52009-03-27 14:25:51 +010022$(obj)/linux.bin: vmlinux FORCE
Michal Simek5f8ffb52009-03-27 14:25:51 +010023 $(call if_changed,objcopy)
Michal Simek6a8dfe12009-10-14 17:38:26 +020024 $(call if_changed,uimage)
Michal Simek5f8ffb52009-03-27 14:25:51 +010025 @echo 'Kernel: $@ is ready' ' (#'`cat .version`')'
26
27$(obj)/linux.bin.gz: $(obj)/linux.bin FORCE
28 $(call if_changed,gzip)
29 @echo 'Kernel: $@ is ready' ' (#'`cat .version`')'
30
Michal Simekf05131c2009-09-14 15:15:49 +020031quiet_cmd_cp = CP $< $@$2
32 cmd_cp = cat $< >$@$2 || (rm -f $@ && echo false)
33
34quiet_cmd_strip = STRIP $@
Michal Simekca28b512010-07-28 09:29:11 +020035 cmd_strip = $(STRIP) -K microblaze_start -K _end -K __log_buf \
Michal Simek61b403a2010-07-28 07:58:06 +020036 -K _fdt_start vmlinux -o $@
Michal Simekf05131c2009-09-14 15:15:49 +020037
Michal Simek6a8dfe12009-10-14 17:38:26 +020038quiet_cmd_uimage = UIMAGE $@.ub
Michal Simek61b403a2010-07-28 07:58:06 +020039 cmd_uimage = $(CONFIG_SHELL) $(MKIMAGE) -A microblaze -O linux -T kernel \
40 -C none -n 'Linux-$(KERNELRELEASE)' \
41 -a $(CONFIG_KERNEL_BASE_ADDR) -e $(CONFIG_KERNEL_BASE_ADDR) \
42 -d $@ $@.ub
Michal Simek6a8dfe12009-10-14 17:38:26 +020043
Michal Simekf05131c2009-09-14 15:15:49 +020044$(obj)/simpleImage.%: vmlinux FORCE
45 $(call if_changed,cp,.unstrip)
Michal Simek6a8dfe12009-10-14 17:38:26 +020046 $(call if_changed,objcopy)
47 $(call if_changed,uimage)
Michal Simekf05131c2009-09-14 15:15:49 +020048 $(call if_changed,strip)
49 @echo 'Kernel: $@ is ready' ' (#'`cat .version`')'
50
Michal Simekf05131c2009-09-14 15:15:49 +020051
52# Rule to build device tree blobs
Dirk Brandewie710fc042010-12-22 11:57:29 -080053DTC_FLAGS := -p 1024
Michal Simekf05131c2009-09-14 15:15:49 +020054
Dirk Brandewie710fc042010-12-22 11:57:29 -080055$(obj)/%.dtb: $(src)/dts/%.dts FORCE
Stephen Warren7c431852012-01-09 11:38:15 -070056 $(call if_changed_dep,dtc)
Michal Simekf05131c2009-09-14 15:15:49 +020057
Arun Bhanu8a8804f2010-03-17 16:06:03 +080058clean-files += *.dtb simpleImage.*.unstrip linux.bin.ub