.. | .. |
---|
12 | 12 | KBUILD_CFLAGS := $(KBUILD_CFLAGS_DECOMPRESSOR) |
---|
13 | 13 | |
---|
14 | 14 | # |
---|
15 | | -# Use -march=z900 for als.c to be able to print an error |
---|
| 15 | +# Use minimum architecture for als.c to be able to print an error |
---|
16 | 16 | # message if the kernel is started on a machine which is too old |
---|
17 | 17 | # |
---|
18 | | -ifneq ($(CC_FLAGS_MARCH),-march=z900) |
---|
| 18 | +ifndef CONFIG_CC_IS_CLANG |
---|
| 19 | +CC_FLAGS_MARCH_MINIMUM := -march=z900 |
---|
| 20 | +else |
---|
| 21 | +CC_FLAGS_MARCH_MINIMUM := -march=z10 |
---|
| 22 | +endif |
---|
| 23 | + |
---|
| 24 | +ifneq ($(CC_FLAGS_MARCH),$(CC_FLAGS_MARCH_MINIMUM)) |
---|
19 | 25 | AFLAGS_REMOVE_head.o += $(CC_FLAGS_MARCH) |
---|
20 | | -AFLAGS_head.o += -march=z900 |
---|
| 26 | +AFLAGS_head.o += $(CC_FLAGS_MARCH_MINIMUM) |
---|
21 | 27 | AFLAGS_REMOVE_mem.o += $(CC_FLAGS_MARCH) |
---|
22 | | -AFLAGS_mem.o += -march=z900 |
---|
| 28 | +AFLAGS_mem.o += $(CC_FLAGS_MARCH_MINIMUM) |
---|
23 | 29 | CFLAGS_REMOVE_als.o += $(CC_FLAGS_MARCH) |
---|
24 | | -CFLAGS_als.o += -march=z900 |
---|
| 30 | +CFLAGS_als.o += $(CC_FLAGS_MARCH_MINIMUM) |
---|
25 | 31 | CFLAGS_REMOVE_sclp_early_core.o += $(CC_FLAGS_MARCH) |
---|
26 | | -CFLAGS_sclp_early_core.o += -march=z900 |
---|
| 32 | +CFLAGS_sclp_early_core.o += $(CC_FLAGS_MARCH_MINIMUM) |
---|
27 | 33 | endif |
---|
28 | 34 | |
---|
29 | 35 | CFLAGS_sclp_early_core.o += -I$(srctree)/drivers/s390/char |
---|
30 | 36 | |
---|
31 | | -obj-y := head.o als.o ebcdic.o sclp_early_core.o mem.o |
---|
32 | | -targets := bzImage startup.a $(obj-y) |
---|
| 37 | +obj-y := head.o als.o startup.o mem_detect.o ipl_parm.o ipl_report.o |
---|
| 38 | +obj-y += string.o ebcdic.o sclp_early_core.o mem.o ipl_vmparm.o cmdline.o |
---|
| 39 | +obj-y += version.o pgm_check_info.o ctype.o text_dma.o |
---|
| 40 | +obj-$(findstring y, $(CONFIG_PROTECTED_VIRTUALIZATION_GUEST) $(CONFIG_PGSTE)) += uv.o |
---|
| 41 | +obj-$(CONFIG_RELOCATABLE) += machine_kexec_reloc.o |
---|
| 42 | +obj-$(CONFIG_RANDOMIZE_BASE) += kaslr.o |
---|
| 43 | +targets := bzImage startup.a section_cmp.boot.data section_cmp.boot.preserved.data $(obj-y) |
---|
33 | 44 | subdir- := compressed |
---|
34 | 45 | |
---|
35 | 46 | OBJECTS := $(addprefix $(obj)/,$(obj-y)) |
---|
36 | 47 | |
---|
37 | | -$(obj)/bzImage: $(obj)/compressed/vmlinux FORCE |
---|
| 48 | +quiet_cmd_section_cmp = SECTCMP $* |
---|
| 49 | +define cmd_section_cmp |
---|
| 50 | + s1=`$(OBJDUMP) -t -j "$*" "$<" | sort | \ |
---|
| 51 | + sed -n "/0000000000000000/! s/.*\s$*\s\+//p" | sha256sum`; \ |
---|
| 52 | + s2=`$(OBJDUMP) -t -j "$*" "$(word 2,$^)" | sort | \ |
---|
| 53 | + sed -n "/0000000000000000/! s/.*\s$*\s\+//p" | sha256sum`; \ |
---|
| 54 | + if [ "$$s1" != "$$s2" ]; then \ |
---|
| 55 | + echo "error: section $* differs between $< and $(word 2,$^)" >&2; \ |
---|
| 56 | + exit 1; \ |
---|
| 57 | + fi; \ |
---|
| 58 | + touch $@ |
---|
| 59 | +endef |
---|
| 60 | + |
---|
| 61 | +$(obj)/bzImage: $(obj)/compressed/vmlinux $(obj)/section_cmp.boot.data $(obj)/section_cmp.boot.preserved.data FORCE |
---|
38 | 62 | $(call if_changed,objcopy) |
---|
| 63 | + |
---|
| 64 | +$(obj)/section_cmp%: vmlinux $(obj)/compressed/vmlinux FORCE |
---|
| 65 | + $(call if_changed,section_cmp) |
---|
39 | 66 | |
---|
40 | 67 | $(obj)/compressed/vmlinux: $(obj)/startup.a FORCE |
---|
41 | 68 | $(Q)$(MAKE) $(build)=$(obj)/compressed $@ |
---|
42 | | - |
---|
43 | | -quiet_cmd_ar = AR $@ |
---|
44 | | - cmd_ar = rm -f $@; $(AR) rcsTP$(KBUILD_ARFLAGS) $@ $(filter $(OBJECTS), $^) |
---|
45 | 69 | |
---|
46 | 70 | $(obj)/startup.a: $(OBJECTS) FORCE |
---|
47 | 71 | $(call if_changed,ar) |
---|
.. | .. |
---|
49 | 73 | install: |
---|
50 | 74 | sh -x $(srctree)/$(obj)/install.sh $(KERNELRELEASE) $(obj)/bzImage \ |
---|
51 | 75 | System.map "$(INSTALL_PATH)" |
---|
52 | | - |
---|
53 | | -chkbss := $(OBJECTS) |
---|
54 | | -chkbss-target := $(obj)/startup.a |
---|
55 | | -include $(srctree)/arch/s390/scripts/Makefile.chkbss |
---|