11da177e4SLinus Torvalds# 24f193362SPaul Smith# This file is included by the global makefile so that you can add your own 34f193362SPaul Smith# architecture-specific flags and dependencies. 44f193362SPaul Smith# 51da177e4SLinus Torvalds# Copyright (C) 2002 Jeff Dike (jdike@karaya.com) 61da177e4SLinus Torvalds# Licensed under the GPL 71da177e4SLinus Torvalds# 81da177e4SLinus Torvalds 91da177e4SLinus TorvaldsARCH_DIR := arch/um 101da177e4SLinus TorvaldsOS := $(shell uname -s) 111da177e4SLinus Torvalds# We require bash because the vmlinux link and loader script cpp use bash 121da177e4SLinus Torvalds# features. 131da177e4SLinus TorvaldsSHELL := /bin/bash 141da177e4SLinus Torvalds 151da177e4SLinus Torvaldsfilechk_gen_header = $< 161da177e4SLinus Torvalds 171da177e4SLinus Torvaldscore-y += $(ARCH_DIR)/kernel/ \ 181da177e4SLinus Torvalds $(ARCH_DIR)/drivers/ \ 191da177e4SLinus Torvalds $(ARCH_DIR)/os-$(OS)/ 201da177e4SLinus Torvalds 211da177e4SLinus Torvalds# Have to precede the include because the included Makefiles reference them. 221da177e4SLinus TorvaldsSYMLINK_HEADERS := archparam.h system.h sigcontext.h processor.h ptrace.h \ 23fbdf2161SPaolo 'Blaisorblade' Giarrusso module.h vm-flags.h elf.h host_ldt.h 241da177e4SLinus TorvaldsSYMLINK_HEADERS := $(foreach header,$(SYMLINK_HEADERS),include/asm-um/$(header)) 251da177e4SLinus Torvalds 261da177e4SLinus Torvalds# XXX: The "os" symlink is only used by arch/um/include/os.h, which includes 271da177e4SLinus Torvalds# ../os/include/file.h 281da177e4SLinus Torvalds# 291da177e4SLinus Torvalds# These are cleaned up during mrproper. Please DO NOT fix it again, this is 301da177e4SLinus Torvalds# the Correct Thing(tm) to do! 311da177e4SLinus TorvaldsARCH_SYMLINKS = include/asm-um/arch $(ARCH_DIR)/include/sysdep $(ARCH_DIR)/os \ 321da177e4SLinus Torvalds $(SYMLINK_HEADERS) $(ARCH_DIR)/include/uml-config.h 331da177e4SLinus Torvalds 341da177e4SLinus Torvaldsum-modes-$(CONFIG_MODE_TT) += tt 351da177e4SLinus Torvaldsum-modes-$(CONFIG_MODE_SKAS) += skas 361da177e4SLinus Torvalds 371da177e4SLinus TorvaldsMODE_INCLUDE += $(foreach mode,$(um-modes-y),\ 384abfbf40SGennady Sharapov -I$(srctree)/$(ARCH_DIR)/include/$(mode)) 391da177e4SLinus Torvalds 401da177e4SLinus TorvaldsMAKEFILES-INCL += $(foreach mode,$(um-modes-y),\ 411da177e4SLinus Torvalds $(srctree)/$(ARCH_DIR)/Makefile-$(mode)) 421da177e4SLinus Torvalds 431da177e4SLinus Torvaldsifneq ($(MAKEFILES-INCL),) 441da177e4SLinus Torvalds include $(MAKEFILES-INCL) 451da177e4SLinus Torvaldsendif 461da177e4SLinus Torvalds 471da177e4SLinus TorvaldsARCH_INCLUDE := -I$(ARCH_DIR)/include 48fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 49fd7aab9cSAl ViroARCH_INCLUDE += -I$(srctree)/$(ARCH_DIR)/include 50fd7aab9cSAl Viroendif 511da177e4SLinus TorvaldsSYS_DIR := $(ARCH_DIR)/include/sysdep-$(SUBARCH) 521da177e4SLinus Torvalds 5398105d47SPaolo 'Blaisorblade' Giarrusso# -Dvmap=kernel_vmap prevents anything from referencing the libpcap.o symbol so 5498105d47SPaolo 'Blaisorblade' Giarrusso# named - it's a common symbol in libpcap, so we get a binary which crashes. 55fd748104SPaolo 'Blaisorblade' Giarrusso# 5698105d47SPaolo 'Blaisorblade' Giarrusso# Same things for in6addr_loopback and mktime - found in libc. For these two we 5798105d47SPaolo 'Blaisorblade' Giarrusso# only get link-time error, luckily. 5898105d47SPaolo 'Blaisorblade' Giarrusso# 5998105d47SPaolo 'Blaisorblade' Giarrusso# These apply to USER_CFLAGS to. 60ecc354a9SPaolo 'Blaisorblade' Giarrusso 61ecc354a9SPaolo 'Blaisorblade' GiarrussoCFLAGS += $(CFLAGS-y) -D__arch_um__ -DSUBARCH=\"$(SUBARCH)\" \ 62fd748104SPaolo 'Blaisorblade' Giarrusso $(ARCH_INCLUDE) $(MODE_INCLUDE) -Dvmap=kernel_vmap \ 63fd748104SPaolo 'Blaisorblade' Giarrusso -Din6addr_loopback=kernel_in6addr_loopback 64fd748104SPaolo 'Blaisorblade' Giarrusso 6593ea5a5bSAl ViroAFLAGS += $(ARCH_INCLUDE) 66ecc354a9SPaolo 'Blaisorblade' Giarrusso 67*d45e44d4Sakpm@osdl.orgUSER_CFLAGS = $(patsubst $(KERNEL_DEFINES),,$(patsubst -D__KERNEL__,,\ 68*d45e44d4Sakpm@osdl.org $(patsubst -I%,,$(CFLAGS)))) $(ARCH_INCLUDE) $(MODE_INCLUDE) \ 69*d45e44d4Sakpm@osdl.org -D_FILE_OFFSET_BITS=64 70*d45e44d4Sakpm@osdl.org 71*d45e44d4Sakpm@osdl.orginclude $(srctree)/$(ARCH_DIR)/Makefile-$(SUBARCH) 72*d45e44d4Sakpm@osdl.org 73*d45e44d4Sakpm@osdl.org#This will adjust *FLAGS accordingly to the platform. 74*d45e44d4Sakpm@osdl.orginclude $(srctree)/$(ARCH_DIR)/Makefile-os-$(OS) 75ecc354a9SPaolo 'Blaisorblade' Giarrusso 761da177e4SLinus Torvalds# -Derrno=kernel_errno - This turns all kernel references to errno into 771da177e4SLinus Torvalds# kernel_errno to separate them from the libc errno. This allows -fno-common 781da177e4SLinus Torvalds# in CFLAGS. Otherwise, it would cause ld to complain about the two different 791da177e4SLinus Torvalds# errnos. 8098105d47SPaolo 'Blaisorblade' Giarrusso# These apply to kernelspace only. 811da177e4SLinus Torvalds 82*d45e44d4Sakpm@osdl.orgKERNEL_DEFINES = -Derrno=kernel_errno -Dsigprocmask=kernel_sigprocmask \ 83*d45e44d4Sakpm@osdl.org -Dmktime=kernel_mktime $(ARCH_KERNEL_DEFINES) 84*d45e44d4Sakpm@osdl.orgCFLAGS += $(KERNEL_DEFINES) 851da177e4SLinus TorvaldsCFLAGS += $(call cc-option,-fno-unit-at-a-time,) 861da177e4SLinus Torvalds 871da177e4SLinus Torvalds# These are needed for clean and mrproper, since in that case .config is not 881da177e4SLinus Torvalds# included; the values here are meaningless 891da177e4SLinus Torvalds 901da177e4SLinus TorvaldsCONFIG_NEST_LEVEL ?= 0 911da177e4SLinus TorvaldsCONFIG_KERNEL_HALF_GIGS ?= 0 921da177e4SLinus Torvalds 931da177e4SLinus TorvaldsSIZE = (($(CONFIG_NEST_LEVEL) + $(CONFIG_KERNEL_HALF_GIGS)) * 0x20000000) 941da177e4SLinus Torvalds 954f193362SPaul SmithPHONY += linux 961da177e4SLinus Torvalds 971da177e4SLinus Torvaldsall: linux 981da177e4SLinus Torvalds 991da177e4SLinus Torvaldslinux: vmlinux 100a4b741e3SJeff Dike @echo ' LINK $@' 101cb8aa3d2SPaolo 'Blaisorblade' Giarrusso $(Q)ln -f $< $@ 1021da177e4SLinus Torvalds 1031da177e4SLinus Torvaldsdefine archhelp 1041da177e4SLinus Torvalds echo '* linux - Binary kernel image (./linux) - for backward' 1051da177e4SLinus Torvalds echo ' compatibility only, this creates a hard link to the' 1064b3f686dSMatt LaPlante echo ' real kernel binary, the "vmlinux" binary you' 1071da177e4SLinus Torvalds echo ' find in the kernel root.' 1081da177e4SLinus Torvaldsendef 1091da177e4SLinus Torvalds 110fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 11108b178ebSJeff Dike$(shell mkdir -p $(ARCH_DIR) && ln -fsn $(srctree)/$(ARCH_DIR)/Kconfig.$(SUBARCH) $(ARCH_DIR)/Kconfig.arch) 112fd7aab9cSAl Viroelse 11308b178ebSJeff Dike$(shell cd $(ARCH_DIR) && ln -sf Kconfig.$(SUBARCH) Kconfig.arch) 114fd7aab9cSAl Viroendif 1151da177e4SLinus Torvalds 116ecba97d4SAl Viroarchprepare: $(ARCH_SYMLINKS) $(ARCH_DIR)/include/user_constants.h 117ecba97d4SAl Viroprepare: $(ARCH_DIR)/include/kern_constants.h 1181da177e4SLinus Torvalds 1191da177e4SLinus TorvaldsLINK-$(CONFIG_LD_SCRIPT_STATIC) += -static 1201da177e4SLinus TorvaldsLINK-$(CONFIG_LD_SCRIPT_DYN) += -Wl,-rpath,/lib 1211da177e4SLinus Torvalds 122275e6e1eSPaolo 'Blaisorblade' GiarrussoCFLAGS_NO_HARDENING := $(call cc-option, -fno-PIC,) $(call cc-option, -fno-pic,) \ 123275e6e1eSPaolo 'Blaisorblade' Giarrusso $(call cc-option, -fno-stack-protector,) \ 124275e6e1eSPaolo 'Blaisorblade' Giarrusso $(call cc-option, -fno-stack-protector-all,) 125275e6e1eSPaolo 'Blaisorblade' Giarrusso 1261da177e4SLinus TorvaldsCPP_MODE-$(CONFIG_MODE_TT) := -DMODE_TT 1271da177e4SLinus TorvaldsCONFIG_KERNEL_STACK_ORDER ?= 2 1281da177e4SLinus TorvaldsSTACK_SIZE := $(shell echo $$[ 4096 * (1 << $(CONFIG_KERNEL_STACK_ORDER)) ] ) 1291da177e4SLinus Torvalds 1301da177e4SLinus Torvaldsifndef START 1311c30385aSPaolo 'Blaisorblade' Giarrusso START = $(shell echo $$[ $(TOP_ADDR) - $(SIZE) ] ) 1321da177e4SLinus Torvaldsendif 1331da177e4SLinus Torvalds 1341c30385aSPaolo 'Blaisorblade' GiarrussoCPPFLAGS_vmlinux.lds = -U$(SUBARCH) \ 1351da177e4SLinus Torvalds -DSTART=$(START) -DELF_ARCH=$(ELF_ARCH) \ 1361c30385aSPaolo 'Blaisorblade' Giarrusso -DELF_FORMAT="$(ELF_FORMAT)" $(CPP_MODE-y) \ 1371c30385aSPaolo 'Blaisorblade' Giarrusso -DKERNEL_STACK_SIZE=$(STACK_SIZE) \ 1387b99edc7SAl Viro -DUNMAP_PATH=arch/um/sys-$(SUBARCH)/unmap.o 1391da177e4SLinus Torvalds 1401da177e4SLinus Torvalds#The wrappers will select whether using "malloc" or the kernel allocator. 1411da177e4SLinus TorvaldsLINK_WRAPS = -Wl,--wrap,malloc -Wl,--wrap,free -Wl,--wrap,calloc 1421da177e4SLinus Torvalds 14320d00213SPaolo 'Blaisorblade' GiarrussoCFLAGS_vmlinux := $(LINK-y) $(LINK_WRAPS) 1441da177e4SLinus Torvaldsdefine cmd_vmlinux__ 1451da177e4SLinus Torvalds $(CC) $(CFLAGS_vmlinux) -o $@ \ 1461da177e4SLinus Torvalds -Wl,-T,$(vmlinux-lds) $(vmlinux-init) \ 1471da177e4SLinus Torvalds -Wl,--start-group $(vmlinux-main) -Wl,--end-group \ 148776cfebbSPaolo 'Blaisorblade' Giarrusso -lutil \ 1491da177e4SLinus Torvalds $(filter-out $(vmlinux-lds) $(vmlinux-init) $(vmlinux-main) \ 1501da177e4SLinus Torvalds FORCE ,$^) ; rm -f linux 1511da177e4SLinus Torvaldsendef 1521da177e4SLinus Torvalds 1531da177e4SLinus Torvalds#When cleaning we don't include .config, so we don't include 1541da177e4SLinus Torvalds#TT or skas makefiles and don't clean skas_ptregs.h. 1551da177e4SLinus TorvaldsCLEAN_FILES += linux x.i gmon.out $(ARCH_DIR)/include/uml-config.h \ 156ecba97d4SAl Viro $(ARCH_DIR)/include/user_constants.h \ 157ecba97d4SAl Viro $(ARCH_DIR)/include/kern_constants.h $(ARCH_DIR)/Kconfig.arch 1581da177e4SLinus Torvalds 159cc70a40bSAl ViroMRPROPER_FILES += $(ARCH_SYMLINKS) 1601da177e4SLinus Torvalds 1611da177e4SLinus Torvaldsarchclean: 1621da177e4SLinus Torvalds @find . \( -name '*.bb' -o -name '*.bbg' -o -name '*.da' \ 1631da177e4SLinus Torvalds -o -name '*.gcov' \) -type f -print | xargs rm -f 1641da177e4SLinus Torvalds 1651da177e4SLinus Torvalds$(SYMLINK_HEADERS): 1661da177e4SLinus Torvalds @echo ' SYMLINK $@' 167fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 16840dbb867SPaolo 'Blaisorblade' Giarrusso $(Q)mkdir -p $(objtree)/include/asm-um 1695cd10daaSPaolo 'Blaisorblade' Giarrusso $(Q)ln -fsn $(srctree)/include/asm-um/$(basename $(notdir $@))-$(SUBARCH)$(suffix $@) $@ 170fd7aab9cSAl Viroelse 1711da177e4SLinus Torvalds $(Q)cd $(TOPDIR)/$(dir $@) ; \ 1721da177e4SLinus Torvalds ln -sf $(basename $(notdir $@))-$(SUBARCH)$(suffix $@) $(notdir $@) 173fd7aab9cSAl Viroendif 1741da177e4SLinus Torvalds 1751da177e4SLinus Torvaldsinclude/asm-um/arch: 1761da177e4SLinus Torvalds @echo ' SYMLINK $@' 177fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 17840dbb867SPaolo 'Blaisorblade' Giarrusso $(Q)mkdir -p $(objtree)/include/asm-um 179fd7aab9cSAl Viro $(Q)ln -fsn $(srctree)/include/asm-$(SUBARCH) include/asm-um/arch 180fd7aab9cSAl Viroelse 1811da177e4SLinus Torvalds $(Q)cd $(TOPDIR)/include/asm-um && ln -sf ../asm-$(SUBARCH) arch 182fd7aab9cSAl Viroendif 1831da177e4SLinus Torvalds 184c6b7a1edSJeff Dike$(objtree)/$(ARCH_DIR)/include: 185c6b7a1edSJeff Dike @echo ' MKDIR $@' 186c6b7a1edSJeff Dike $(Q)mkdir -p $@ 187c6b7a1edSJeff Dike 188c6b7a1edSJeff Dike$(ARCH_DIR)/include/sysdep: $(objtree)/$(ARCH_DIR)/include 1891da177e4SLinus Torvalds @echo ' SYMLINK $@' 190fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 191ecba97d4SAl Viro $(Q)ln -fsn $(srctree)/$(ARCH_DIR)/include/sysdep-$(SUBARCH) $(ARCH_DIR)/include/sysdep 192fd7aab9cSAl Viroelse 1931da177e4SLinus Torvalds $(Q)cd $(ARCH_DIR)/include && ln -sf sysdep-$(SUBARCH) sysdep 194fd7aab9cSAl Viroendif 1951da177e4SLinus Torvalds 1961da177e4SLinus Torvalds$(ARCH_DIR)/os: 1971da177e4SLinus Torvalds @echo ' SYMLINK $@' 198fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 199fd7aab9cSAl Viro $(Q)ln -fsn $(srctree)/$(ARCH_DIR)/os-$(OS) $(ARCH_DIR)/os 200fd7aab9cSAl Viroelse 2011da177e4SLinus Torvalds $(Q)cd $(ARCH_DIR) && ln -sf os-$(OS) os 202fd7aab9cSAl Viroendif 2031da177e4SLinus Torvalds 2041da177e4SLinus Torvalds# Generated files 2051da177e4SLinus Torvaldsdefine filechk_umlconfig 2061da177e4SLinus Torvalds sed 's/ CONFIG/ UML_CONFIG/' 2071da177e4SLinus Torvaldsendef 2081da177e4SLinus Torvalds 2094ee189a9SJeff Dike$(ARCH_DIR)/include/uml-config.h : include/linux/autoconf.h 2104ee189a9SJeff Dike $(call filechk,umlconfig) 2114ee189a9SJeff Dike 212cb8aa3d2SPaolo 'Blaisorblade' Giarrusso$(ARCH_DIR)/sys-$(SUBARCH)/user-offsets.s: FORCE 213cb8aa3d2SPaolo 'Blaisorblade' Giarrusso $(Q)$(MAKE) $(build)=$(ARCH_DIR)/sys-$(SUBARCH) $@ 2144ee189a9SJeff Dike 215f64a227bSSam Ravnborgdefine filechk_gen-asm-offsets 216f64a227bSSam Ravnborg (set -e; \ 217f64a227bSSam Ravnborg echo "/*"; \ 218f64a227bSSam Ravnborg echo " * DO NOT MODIFY."; \ 219f64a227bSSam Ravnborg echo " *"; \ 220f64a227bSSam Ravnborg echo " * This file was generated by arch/$(ARCH)/Makefile"; \ 221f64a227bSSam Ravnborg echo " *"; \ 222f64a227bSSam Ravnborg echo " */"; \ 223f64a227bSSam Ravnborg echo ""; \ 224f64a227bSSam Ravnborg sed -ne "/^->/{s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; s:->::; p;}"; \ 225ecba97d4SAl Viro echo ""; ) 226f64a227bSSam Ravnborgendef 227f64a227bSSam Ravnborg 228cb8aa3d2SPaolo 'Blaisorblade' Giarrusso$(ARCH_DIR)/include/user_constants.h: $(ARCH_DIR)/sys-$(SUBARCH)/user-offsets.s 2298d0b9dc9SAl Viro $(call filechk,gen-asm-offsets) 2308d0b9dc9SAl Viro 231c6b7a1edSJeff Dike$(ARCH_DIR)/include/kern_constants.h: $(objtree)/$(ARCH_DIR)/include 2324ee189a9SJeff Dike @echo ' SYMLINK $@' 2334ee189a9SJeff Dike $(Q)ln -sf ../../../include/asm-um/asm-offsets.h $@ 2341da177e4SLinus Torvalds 235275e6e1eSPaolo 'Blaisorblade' Giarrussoexport SUBARCH USER_CFLAGS CFLAGS_NO_HARDENING OS 236