1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0 21da177e4SLinus Torvalds# 31da177e4SLinus Torvalds# Makefile for the linux s390-specific parts of the memory manager. 41da177e4SLinus Torvalds# 51da177e4SLinus Torvalds 6c5944a7eSIlya Leoshkevich# Tooling runtimes are unavailable and cannot be linked for early boot code 78282cd64SVasily GorbikKCOV_INSTRUMENT := n 88282cd64SVasily GorbikGCOV_PROFILE := n 98282cd64SVasily GorbikUBSAN_SANITIZE := n 100a9b4091SVasily GorbikKASAN_SANITIZE := n 11e37b3dd0SIlya LeoshkevichKCSAN_SANITIZE := n 12c5944a7eSIlya LeoshkevichKMSAN_SANITIZE := n 138282cd64SVasily Gorbik 148282cd64SVasily Gorbik# 15fccb175bSHeiko Carstens# Use minimum architecture level so it is possible to print an error 168282cd64SVasily Gorbik# message if the kernel is started on a machine which is too old 178282cd64SVasily Gorbik# 18c263a4e9SArnd BergmannCC_FLAGS_MARCH_MINIMUM := -march=z10 19c263a4e9SArnd Bergmann 20fccb175bSHeiko CarstensKBUILD_AFLAGS := $(filter-out $(CC_FLAGS_MARCH),$(KBUILD_AFLAGS_DECOMPRESSOR)) 21fccb175bSHeiko CarstensKBUILD_CFLAGS := $(filter-out $(CC_FLAGS_MARCH),$(KBUILD_CFLAGS_DECOMPRESSOR)) 22819275e1SPetr PavluKBUILD_AFLAGS += $(CC_FLAGS_MARCH_MINIMUM) -D__DISABLE_EXPORTS 23819275e1SPetr PavluKBUILD_CFLAGS += $(CC_FLAGS_MARCH_MINIMUM) -D__DISABLE_EXPORTS 248282cd64SVasily Gorbik 25a1d7d91fSVasily GorbikCFLAGS_sclp_early_core.o += -I$(srctree)/drivers/s390/char 26a1d7d91fSVasily Gorbik 278c37cb7dSVasily Gorbikobj-y := head.o als.o startup.o physmem_info.o ipl_parm.o ipl_report.o vmem.o 289641b8ccSMartin Schwidefskyobj-y += string.o ebcdic.o sclp_early_core.o mem.o ipl_vmparm.o cmdline.o 296067891bSHeiko Carstensobj-y += version.o pgm_check.o ctype.o ipl_data.o relocs.o alternative.o 30*996f7f29SIlya Leoshkevichobj-y += uv.o printk.o trampoline.o 31b2d24b97SGerald Schaeferobj-$(CONFIG_RANDOMIZE_BASE) += kaslr.o 32edd4a866SHeiko Carstensobj-y += $(if $(CONFIG_KERNEL_UNCOMPRESSED),,decompressor.o) info.o 33edd4a866SHeiko Carstensobj-$(CONFIG_KERNEL_ZSTD) += clz_ctz.o 34008dead4SIlya Leoshkevichobj-$(CONFIG_KMSAN) += kmsan.o 35edd4a866SHeiko Carstensobj-all := $(obj-y) piggy.o syms.o 36edd4a866SHeiko Carstens 37edd4a866SHeiko Carstenstargets := bzImage section_cmp.boot.data section_cmp.boot.preserved.data $(obj-y) 38edd4a866SHeiko Carstenstargets += vmlinux.lds vmlinux vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 39edd4a866SHeiko Carstenstargets += vmlinux.bin.xz vmlinux.bin.lzma vmlinux.bin.lzo vmlinux.bin.lz4 40edd4a866SHeiko Carstenstargets += vmlinux.bin.zst info.bin syms.bin vmlinux.syms $(obj-all) 41778666dfSJosh Poimboeuftargets += relocs.S 421da177e4SLinus Torvalds 438282cd64SVasily GorbikOBJECTS := $(addprefix $(obj)/,$(obj-y)) 44edd4a866SHeiko CarstensOBJECTS_ALL := $(addprefix $(obj)/,$(obj-all)) 458282cd64SVasily Gorbik 469b5c37bbSVasily Gorbikclean-files += vmlinux.map 479b5c37bbSVasily Gorbik 48251b72a4SVasily Gorbikquiet_cmd_section_cmp = SECTCMP $* 49251b72a4SVasily Gorbikdefine cmd_section_cmp 507f115ff4SNathan Chancellor s1=`$(OBJDUMP) -t "$<" | grep "\s$*\s\+" | sort | \ 51251b72a4SVasily Gorbik sed -n "/0000000000000000/! s/.*\s$*\s\+//p" | sha256sum`; \ 527f115ff4SNathan Chancellor s2=`$(OBJDUMP) -t "$(word 2,$^)" | grep "\s$*\s\+" | sort | \ 53251b72a4SVasily Gorbik sed -n "/0000000000000000/! s/.*\s$*\s\+//p" | sha256sum`; \ 54251b72a4SVasily Gorbik if [ "$$s1" != "$$s2" ]; then \ 55251b72a4SVasily Gorbik echo "error: section $* differs between $< and $(word 2,$^)" >&2; \ 56251b72a4SVasily Gorbik exit 1; \ 57251b72a4SVasily Gorbik fi; \ 58251b72a4SVasily Gorbik touch $@ 59251b72a4SVasily Gorbikendef 60251b72a4SVasily Gorbik 61edd4a866SHeiko Carstens$(obj)/bzImage: $(obj)/vmlinux $(obj)/section_cmp.boot.data $(obj)/section_cmp.boot.preserved.data FORCE 621844c9bcSMartin Schwidefsky $(call if_changed,objcopy) 631844c9bcSMartin Schwidefsky 64edd4a866SHeiko Carstens$(obj)/section_cmp%: vmlinux $(obj)/vmlinux FORCE 65251b72a4SVasily Gorbik $(call if_changed,section_cmp) 66251b72a4SVasily Gorbik 672151fd9aSNathan ChancellorLDFLAGS_vmlinux-$(CONFIG_LD_ORPHAN_WARN) := --orphan-handling=$(CONFIG_LD_ORPHAN_WARN_LEVEL) 682151fd9aSNathan ChancellorLDFLAGS_vmlinux := $(LDFLAGS_vmlinux-y) --oformat $(LD_BFD) -e startup $(if $(CONFIG_VMLINUX_MAP),-Map=$(obj)/vmlinux.map) --build-id=sha1 -T 69edd4a866SHeiko Carstens$(obj)/vmlinux: $(obj)/vmlinux.lds $(OBJECTS_ALL) FORCE 70edd4a866SHeiko Carstens $(call if_changed,ld) 711844c9bcSMartin Schwidefsky 722151fd9aSNathan ChancellorLDFLAGS_vmlinux.syms := $(LDFLAGS_vmlinux-y) --oformat $(LD_BFD) -e startup -T 73edd4a866SHeiko Carstens$(obj)/vmlinux.syms: $(obj)/vmlinux.lds $(OBJECTS) FORCE 74edd4a866SHeiko Carstens $(call if_changed,ld) 75edd4a866SHeiko Carstens 76edd4a866SHeiko Carstensquiet_cmd_dumpsyms = DUMPSYMS $< 77edd4a866SHeiko Carstensdefine cmd_dumpsyms 78edd4a866SHeiko Carstens $(NM) -n -S --format=bsd "$<" | sed -nE 's/^0*([0-9a-fA-F]+) 0*([0-9a-fA-F]+) [tT] ([^ ]*)$$/\1 \2 \3/p' | tr '\n' '\0' > "$@" 79edd4a866SHeiko Carstensendef 80edd4a866SHeiko Carstens 81edd4a866SHeiko Carstens$(obj)/syms.bin: $(obj)/vmlinux.syms FORCE 82edd4a866SHeiko Carstens $(call if_changed,dumpsyms) 83edd4a866SHeiko Carstens 84edd4a866SHeiko CarstensOBJCOPYFLAGS_syms.o := -I binary -O elf64-s390 -B s390:64-bit --rename-section .data=.decompressor.syms 85edd4a866SHeiko Carstens$(obj)/syms.o: $(obj)/syms.bin FORCE 86edd4a866SHeiko Carstens $(call if_changed,objcopy) 87edd4a866SHeiko Carstens 889ea30fd1SNathan ChancellorOBJCOPYFLAGS_info.bin := -O binary --only-section=.vmlinux.info --set-section-flags .vmlinux.info=alloc,load 89edd4a866SHeiko Carstens$(obj)/info.bin: vmlinux FORCE 90edd4a866SHeiko Carstens $(call if_changed,objcopy) 91edd4a866SHeiko Carstens 92edd4a866SHeiko CarstensOBJCOPYFLAGS_info.o := -I binary -O elf64-s390 -B s390:64-bit --rename-section .data=.vmlinux.info 93edd4a866SHeiko Carstens$(obj)/info.o: $(obj)/info.bin FORCE 94edd4a866SHeiko Carstens $(call if_changed,objcopy) 95edd4a866SHeiko Carstens 96edd4a866SHeiko CarstensOBJCOPYFLAGS_vmlinux.bin := -O binary --remove-section=.comment --remove-section=.vmlinux.info -S 97edd4a866SHeiko Carstens$(obj)/vmlinux.bin: vmlinux FORCE 98edd4a866SHeiko Carstens $(call if_changed,objcopy) 99edd4a866SHeiko Carstens 10057216cc9SJens Remus# relocs.S is created by the vmlinux postlink step. 10157216cc9SJens Remus$(obj)/relocs.S: vmlinux 10257216cc9SJens Remus @true 103778666dfSJosh Poimboeuf 104edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_GZIP) := .gz 105edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_BZIP2) := .bz2 106edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_LZ4) := .lz4 107edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_LZMA) := .lzma 108edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_LZO) := .lzo 109edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_XZ) := .xz 110edd4a866SHeiko Carstenssuffix-$(CONFIG_KERNEL_ZSTD) := .zst 111edd4a866SHeiko Carstens 112edd4a866SHeiko Carstens$(obj)/vmlinux.bin.gz: $(obj)/vmlinux.bin FORCE 113edd4a866SHeiko Carstens $(call if_changed,gzip) 114edd4a866SHeiko Carstens$(obj)/vmlinux.bin.bz2: $(obj)/vmlinux.bin FORCE 115edd4a866SHeiko Carstens $(call if_changed,bzip2_with_size) 116edd4a866SHeiko Carstens$(obj)/vmlinux.bin.lz4: $(obj)/vmlinux.bin FORCE 117edd4a866SHeiko Carstens $(call if_changed,lz4_with_size) 118edd4a866SHeiko Carstens$(obj)/vmlinux.bin.lzma: $(obj)/vmlinux.bin FORCE 119edd4a866SHeiko Carstens $(call if_changed,lzma_with_size) 120edd4a866SHeiko Carstens$(obj)/vmlinux.bin.lzo: $(obj)/vmlinux.bin FORCE 121edd4a866SHeiko Carstens $(call if_changed,lzo_with_size) 122edd4a866SHeiko Carstens$(obj)/vmlinux.bin.xz: $(obj)/vmlinux.bin FORCE 123edd4a866SHeiko Carstens $(call if_changed,xzkern_with_size) 124edd4a866SHeiko Carstens$(obj)/vmlinux.bin.zst: $(obj)/vmlinux.bin FORCE 125edd4a866SHeiko Carstens $(call if_changed,zstd22_with_size) 126edd4a866SHeiko Carstens 127edd4a866SHeiko CarstensOBJCOPYFLAGS_piggy.o := -I binary -O elf64-s390 -B s390:64-bit --rename-section .data=.vmlinux.bin.compressed 128edd4a866SHeiko Carstens$(obj)/piggy.o: $(obj)/vmlinux.bin$(suffix-y) FORCE 129edd4a866SHeiko Carstens $(call if_changed,objcopy) 130