Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | # |
| 2 | # s390/Makefile |
| 3 | # |
| 4 | # This file is included by the global makefile so that you can add your own |
| 5 | # architecture-specific flags and dependencies. Remember to do have actions |
| 6 | # for "archclean" and "archdep" for cleaning up and making dependencies for |
| 7 | # this architecture |
| 8 | # |
| 9 | # This file is subject to the terms and conditions of the GNU General Public |
| 10 | # License. See the file "COPYING" in the main directory of this archive |
| 11 | # for more details. |
| 12 | # |
| 13 | # Copyright (C) 1994 by Linus Torvalds |
| 14 | # |
| 15 | |
Martin Schwidefsky | 347a8dc | 2006-01-06 00:19:28 -0800 | [diff] [blame] | 16 | ifndef CONFIG_64BIT |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 17 | LDFLAGS := -m elf_s390 |
| 18 | CFLAGS += -m31 |
| 19 | AFLAGS += -m31 |
| 20 | UTS_MACHINE := s390 |
| 21 | STACK_SIZE := 8192 |
viro@ZenIV.linux.org.uk | d310a35 | 2005-09-09 16:56:05 +0100 | [diff] [blame] | 22 | CHECKFLAGS += -D__s390__ |
Martin Schwidefsky | 347a8dc | 2006-01-06 00:19:28 -0800 | [diff] [blame] | 23 | else |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | LDFLAGS := -m elf64_s390 |
| 25 | MODFLAGS += -fpic -D__PIC__ |
| 26 | CFLAGS += -m64 |
| 27 | AFLAGS += -m64 |
| 28 | UTS_MACHINE := s390x |
| 29 | STACK_SIZE := 16384 |
viro@ZenIV.linux.org.uk | d310a35 | 2005-09-09 16:56:05 +0100 | [diff] [blame] | 30 | CHECKFLAGS += -D__s390__ -D__s390x__ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | endif |
| 32 | |
| 33 | cflags-$(CONFIG_MARCH_G5) += $(call cc-option,-march=g5) |
| 34 | cflags-$(CONFIG_MARCH_Z900) += $(call cc-option,-march=z900) |
| 35 | cflags-$(CONFIG_MARCH_Z990) += $(call cc-option,-march=z990) |
| 36 | |
Heiko Carstens | cbbd1fa | 2006-07-03 00:24:38 -0700 | [diff] [blame^] | 37 | # |
| 38 | # Prevent tail-call optimizations, to get clearer backtraces: |
| 39 | # |
| 40 | cflags-$(CONFIG_FRAME_POINTER) += -fno-optimize-sibling-calls |
| 41 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 42 | # old style option for packed stacks |
| 43 | ifeq ($(call cc-option-yn,-mkernel-backchain),y) |
| 44 | cflags-$(CONFIG_PACK_STACK) += -mkernel-backchain -D__PACK_STACK |
| 45 | aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK |
| 46 | cflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK |
| 47 | aflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK |
| 48 | ifdef CONFIG_SMALL_STACK |
| 49 | STACK_SIZE := $(shell echo $$(($(STACK_SIZE)/2)) ) |
| 50 | endif |
| 51 | endif |
| 52 | |
| 53 | # new style option for packed stacks |
| 54 | ifeq ($(call cc-option-yn,-mpacked-stack),y) |
| 55 | cflags-$(CONFIG_PACK_STACK) += -mpacked-stack -D__PACK_STACK |
| 56 | aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK |
| 57 | cflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK |
| 58 | aflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK |
| 59 | ifdef CONFIG_SMALL_STACK |
| 60 | STACK_SIZE := $(shell echo $$(($(STACK_SIZE)/2)) ) |
| 61 | endif |
| 62 | endif |
| 63 | |
| 64 | ifeq ($(call cc-option-yn,-mstack-size=8192 -mstack-guard=128),y) |
| 65 | cflags-$(CONFIG_CHECK_STACK) += -mstack-size=$(STACK_SIZE) |
| 66 | cflags-$(CONFIG_CHECK_STACK) += -mstack-guard=$(CONFIG_STACK_GUARD) |
| 67 | endif |
| 68 | |
| 69 | ifeq ($(call cc-option-yn,-mwarn-dynamicstack),y) |
| 70 | cflags-$(CONFIG_WARN_STACK) += -mwarn-dynamicstack |
| 71 | cflags-$(CONFIG_WARN_STACK) += -mwarn-framesize=$(CONFIG_WARN_STACK_SIZE) |
| 72 | endif |
| 73 | |
| 74 | CFLAGS += -mbackchain -msoft-float $(cflags-y) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 | CFLAGS += -pipe -fno-strength-reduce -Wno-sign-compare |
| 76 | AFLAGS += $(aflags-y) |
| 77 | |
| 78 | OBJCOPYFLAGS := -O binary |
| 79 | LDFLAGS_vmlinux := -e start |
| 80 | |
Heiko Carstens | 0ad775d | 2005-11-07 00:59:12 -0800 | [diff] [blame] | 81 | head-y := arch/$(ARCH)/kernel/head.o arch/$(ARCH)/kernel/init_task.o |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 82 | |
| 83 | core-y += arch/$(ARCH)/mm/ arch/$(ARCH)/kernel/ arch/$(ARCH)/crypto/ \ |
Michael Holzheu | 24bbb1f | 2006-06-23 02:05:06 -0700 | [diff] [blame] | 84 | arch/$(ARCH)/appldata/ arch/$(ARCH)/hypfs/ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 85 | libs-y += arch/$(ARCH)/lib/ |
| 86 | drivers-y += drivers/s390/ |
| 87 | drivers-$(CONFIG_MATHEMU) += arch/$(ARCH)/math-emu/ |
| 88 | |
| 89 | # must be linked after kernel |
| 90 | drivers-$(CONFIG_OPROFILE) += arch/s390/oprofile/ |
| 91 | |
| 92 | boot := arch/$(ARCH)/boot |
| 93 | |
| 94 | all: image |
| 95 | |
| 96 | install: vmlinux |
| 97 | $(Q)$(MAKE) $(build)=$(boot) $@ |
| 98 | |
| 99 | image: vmlinux |
| 100 | $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ |
| 101 | |
| 102 | archclean: |
| 103 | $(Q)$(MAKE) $(clean)=$(boot) |
| 104 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 105 | # Don't use tabs in echo arguments |
| 106 | define archhelp |
| 107 | echo '* image - Kernel image for IPL ($(boot)/image)' |
| 108 | endef |