2005-04-16 15:20:36 -07:00
#
# s390/Makefile
#
# This file is included by the global makefile so that you can add your own
# architecture-specific flags and dependencies. Remember to do have actions
# for "archclean" and "archdep" for cleaning up and making dependencies for
# this architecture
#
# This file is subject to the terms and conditions of the GNU General Public
# License. See the file "COPYING" in the main directory of this archive
# for more details.
#
# Copyright (C) 1994 by Linus Torvalds
#
2006-01-06 00:19:28 -08:00
i f n d e f C O N F I G _ 6 4 B I T
2005-04-16 15:20:36 -07:00
LDFLAGS := -m elf_s390
CFLAGS += -m31
AFLAGS += -m31
UTS_MACHINE := s390
STACK_SIZE := 8192
2005-09-09 16:56:05 +01:00
CHECKFLAGS += -D__s390__
2006-01-06 00:19:28 -08:00
e l s e
2005-04-16 15:20:36 -07:00
LDFLAGS := -m elf64_s390
MODFLAGS += -fpic -D__PIC__
CFLAGS += -m64
AFLAGS += -m64
UTS_MACHINE := s390x
STACK_SIZE := 16384
2005-09-09 16:56:05 +01:00
CHECKFLAGS += -D__s390__ -D__s390x__
2005-04-16 15:20:36 -07:00
e n d i f
cflags-$(CONFIG_MARCH_G5) += $( call cc-option,-march= g5)
cflags-$(CONFIG_MARCH_Z900) += $( call cc-option,-march= z900)
cflags-$(CONFIG_MARCH_Z990) += $( call cc-option,-march= z990)
# old style option for packed stacks
i f e q ( $( call cc -option -yn ,-mkernel -backchain ) , y )
cflags-$(CONFIG_PACK_STACK) += -mkernel-backchain -D__PACK_STACK
aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK
cflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK
aflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK
i f d e f C O N F I G _ S M A L L _ S T A C K
STACK_SIZE := $( shell echo $$ ( ( $( STACK_SIZE) /2) ) )
e n d i f
e n d i f
# new style option for packed stacks
i f e q ( $( call cc -option -yn ,-mpacked -stack ) , y )
cflags-$(CONFIG_PACK_STACK) += -mpacked-stack -D__PACK_STACK
aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK
cflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK
aflags-$(CONFIG_SMALL_STACK) += -D__SMALL_STACK
i f d e f C O N F I G _ S M A L L _ S T A C K
STACK_SIZE := $( shell echo $$ ( ( $( STACK_SIZE) /2) ) )
e n d i f
e n d i f
i f e q ( $( call cc -option -yn ,-mstack -size =8192 -mstack -guard =128) , y )
cflags-$(CONFIG_CHECK_STACK) += -mstack-size= $( STACK_SIZE)
cflags-$(CONFIG_CHECK_STACK) += -mstack-guard= $( CONFIG_STACK_GUARD)
e n d i f
i f e q ( $( call cc -option -yn ,-mwarn -dynamicstack ) , y )
cflags-$(CONFIG_WARN_STACK) += -mwarn-dynamicstack
cflags-$(CONFIG_WARN_STACK) += -mwarn-framesize= $( CONFIG_WARN_STACK_SIZE)
e n d i f
CFLAGS += -mbackchain -msoft-float $( cflags-y)
CFLAGS += -pipe -fno-strength-reduce -Wno-sign-compare
AFLAGS += $( aflags-y)
OBJCOPYFLAGS := -O binary
LDFLAGS_vmlinux := -e start
2005-11-07 00:59:12 -08:00
head-y := arch/$( ARCH) /kernel/head.o arch/$( ARCH) /kernel/init_task.o
2005-04-16 15:20:36 -07:00
core-y += arch/$( ARCH) /mm/ arch/$( ARCH) /kernel/ arch/$( ARCH) /crypto/ \
2006-06-23 02:05:06 -07:00
arch/$( ARCH) /appldata/ arch/$( ARCH) /hypfs/
2005-04-16 15:20:36 -07:00
libs-y += arch/$( ARCH) /lib/
drivers-y += drivers/s390/
drivers-$(CONFIG_MATHEMU) += arch/$( ARCH) /math-emu/
# must be linked after kernel
drivers-$(CONFIG_OPROFILE) += arch/s390/oprofile/
boot := arch/$( ARCH) /boot
all : image
install : vmlinux
$( Q) $( MAKE) $( build) = $( boot) $@
image : vmlinux
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
archclean :
$( Q) $( MAKE) $( clean) = $( boot)
# Don't use tabs in echo arguments
d e f i n e a r c h h e l p
echo '* image - Kernel image for IPL ($(boot)/image)'
e n d e f