11da177e4SLinus Torvalds# 21da177e4SLinus Torvalds# Copyright (C) 2002 Jeff Dike (jdike@karaya.com) 31da177e4SLinus Torvalds# Licensed under the GPL 41da177e4SLinus Torvalds# 51da177e4SLinus Torvalds 61da177e4SLinus TorvaldsARCH_DIR := arch/um 71da177e4SLinus TorvaldsOS := $(shell uname -s) 81da177e4SLinus Torvalds# We require bash because the vmlinux link and loader script cpp use bash 91da177e4SLinus Torvalds# features. 101da177e4SLinus TorvaldsSHELL := /bin/bash 111da177e4SLinus Torvalds 121da177e4SLinus Torvaldsfilechk_gen_header = $< 131da177e4SLinus Torvalds 141da177e4SLinus Torvaldscore-y += $(ARCH_DIR)/kernel/ \ 151da177e4SLinus Torvalds $(ARCH_DIR)/drivers/ \ 161da177e4SLinus Torvalds $(ARCH_DIR)/os-$(OS)/ 171da177e4SLinus Torvalds 181da177e4SLinus Torvalds# Have to precede the include because the included Makefiles reference them. 191da177e4SLinus TorvaldsSYMLINK_HEADERS := archparam.h system.h sigcontext.h processor.h ptrace.h \ 207c5131a5SBodo Stroesser module.h vm-flags.h elf.h 211da177e4SLinus TorvaldsSYMLINK_HEADERS := $(foreach header,$(SYMLINK_HEADERS),include/asm-um/$(header)) 221da177e4SLinus Torvalds 231da177e4SLinus Torvalds# XXX: The "os" symlink is only used by arch/um/include/os.h, which includes 241da177e4SLinus Torvalds# ../os/include/file.h 251da177e4SLinus Torvalds# 261da177e4SLinus Torvalds# These are cleaned up during mrproper. Please DO NOT fix it again, this is 271da177e4SLinus Torvalds# the Correct Thing(tm) to do! 281da177e4SLinus TorvaldsARCH_SYMLINKS = include/asm-um/arch $(ARCH_DIR)/include/sysdep $(ARCH_DIR)/os \ 291da177e4SLinus Torvalds $(SYMLINK_HEADERS) $(ARCH_DIR)/include/uml-config.h 301da177e4SLinus Torvalds 311da177e4SLinus TorvaldsGEN_HEADERS += $(ARCH_DIR)/include/task.h $(ARCH_DIR)/include/kern_constants.h 321da177e4SLinus Torvalds 331da177e4SLinus Torvaldsum-modes-$(CONFIG_MODE_TT) += tt 341da177e4SLinus Torvaldsum-modes-$(CONFIG_MODE_SKAS) += skas 351da177e4SLinus Torvalds 361da177e4SLinus TorvaldsMODE_INCLUDE += $(foreach mode,$(um-modes-y),\ 371da177e4SLinus Torvalds -I$(srctree)/$(ARCH_DIR)/kernel/$(mode)/include) 381da177e4SLinus Torvalds 391da177e4SLinus TorvaldsMAKEFILES-INCL += $(foreach mode,$(um-modes-y),\ 401da177e4SLinus Torvalds $(srctree)/$(ARCH_DIR)/Makefile-$(mode)) 411da177e4SLinus Torvalds 421da177e4SLinus Torvaldsifneq ($(MAKEFILES-INCL),) 431da177e4SLinus Torvalds include $(MAKEFILES-INCL) 441da177e4SLinus Torvaldsendif 451da177e4SLinus Torvalds 461da177e4SLinus TorvaldsARCH_INCLUDE := -I$(ARCH_DIR)/include 47fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 48fd7aab9cSAl ViroARCH_INCLUDE += -I$(ARCH_DIR)/include2 49fd7aab9cSAl ViroARCH_INCLUDE += -I$(srctree)/$(ARCH_DIR)/include 50fd7aab9cSAl ViroMRPROPER_DIRS += $(ARCH_DIR)/include2 51fd7aab9cSAl Viroendif 521da177e4SLinus TorvaldsSYS_DIR := $(ARCH_DIR)/include/sysdep-$(SUBARCH) 531da177e4SLinus Torvalds 54ecc354a9SPaolo 'Blaisorblade' Giarrusso# -Dvmap=kernel_vmap affects everything, and prevents anything from 55ecc354a9SPaolo 'Blaisorblade' Giarrusso# referencing the libpcap.o symbol so named. 56ecc354a9SPaolo 'Blaisorblade' Giarrusso 57ecc354a9SPaolo 'Blaisorblade' GiarrussoCFLAGS += $(CFLAGS-y) -D__arch_um__ -DSUBARCH=\"$(SUBARCH)\" \ 58ecc354a9SPaolo 'Blaisorblade' Giarrusso $(ARCH_INCLUDE) $(MODE_INCLUDE) -Dvmap=kernel_vmap 59ecc354a9SPaolo 'Blaisorblade' Giarrusso 60ecc354a9SPaolo 'Blaisorblade' GiarrussoUSER_CFLAGS := $(patsubst -I%,,$(CFLAGS)) 61ecc354a9SPaolo 'Blaisorblade' GiarrussoUSER_CFLAGS := $(patsubst -D__KERNEL__,,$(USER_CFLAGS)) $(ARCH_INCLUDE) \ 6220d00213SPaolo 'Blaisorblade' Giarrusso $(MODE_INCLUDE) 63ecc354a9SPaolo 'Blaisorblade' Giarrusso 641da177e4SLinus Torvalds# -Derrno=kernel_errno - This turns all kernel references to errno into 651da177e4SLinus Torvalds# kernel_errno to separate them from the libc errno. This allows -fno-common 661da177e4SLinus Torvalds# in CFLAGS. Otherwise, it would cause ld to complain about the two different 671da177e4SLinus Torvalds# errnos. 681da177e4SLinus Torvalds 691da177e4SLinus TorvaldsCFLAGS += -Derrno=kernel_errno -Dsigprocmask=kernel_sigprocmask 701da177e4SLinus TorvaldsCFLAGS += $(call cc-option,-fno-unit-at-a-time,) 711da177e4SLinus Torvalds 7220d00213SPaolo 'Blaisorblade' Giarrussoinclude $(srctree)/$(ARCH_DIR)/Makefile-$(SUBARCH) 7320d00213SPaolo 'Blaisorblade' Giarrusso 741da177e4SLinus Torvalds#This will adjust *FLAGS accordingly to the platform. 751da177e4SLinus Torvaldsinclude $(srctree)/$(ARCH_DIR)/Makefile-os-$(OS) 761da177e4SLinus Torvalds 771da177e4SLinus Torvalds# These are needed for clean and mrproper, since in that case .config is not 781da177e4SLinus Torvalds# included; the values here are meaningless 791da177e4SLinus Torvalds 801da177e4SLinus TorvaldsCONFIG_NEST_LEVEL ?= 0 811da177e4SLinus TorvaldsCONFIG_KERNEL_HALF_GIGS ?= 0 821da177e4SLinus Torvalds 831da177e4SLinus TorvaldsSIZE = (($(CONFIG_NEST_LEVEL) + $(CONFIG_KERNEL_HALF_GIGS)) * 0x20000000) 841da177e4SLinus Torvalds 851da177e4SLinus Torvaldsifeq ($(CONFIG_MODE_SKAS), y) 861da177e4SLinus Torvalds$(SYS_HEADERS) : $(ARCH_DIR)/include/skas_ptregs.h 871da177e4SLinus Torvaldsendif 881da177e4SLinus Torvalds 891da177e4SLinus Torvalds.PHONY: linux 901da177e4SLinus Torvalds 911da177e4SLinus Torvaldsall: linux 921da177e4SLinus Torvalds 931da177e4SLinus Torvaldslinux: vmlinux 941da177e4SLinus Torvalds ln -f $< $@ 951da177e4SLinus Torvalds 961da177e4SLinus Torvaldsdefine archhelp 971da177e4SLinus Torvalds echo '* linux - Binary kernel image (./linux) - for backward' 981da177e4SLinus Torvalds echo ' compatibility only, this creates a hard link to the' 991da177e4SLinus Torvalds echo ' real kernel binary, the the "vmlinux" binary you' 1001da177e4SLinus Torvalds echo ' find in the kernel root.' 1011da177e4SLinus Torvaldsendef 1021da177e4SLinus Torvalds 103fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 104fd7aab9cSAl Viro$(shell mkdir -p $(ARCH_DIR) && ln -fsn $(srctree)/$(ARCH_DIR)/Kconfig_$(SUBARCH) $(ARCH_DIR)/Kconfig_arch) 105fd7aab9cSAl ViroCLEAN_FILES += $(ARCH_DIR)/Kconfig_arch 106fd7aab9cSAl Viroelse 1071da177e4SLinus Torvalds$(shell cd $(ARCH_DIR) && ln -sf Kconfig_$(SUBARCH) Kconfig_arch) 108fd7aab9cSAl Viroendif 1091da177e4SLinus Torvalds 11003f81dc5SAl Viroprepare: $(ARCH_SYMLINKS) $(SYS_HEADERS) $(GEN_HEADERS) 1111da177e4SLinus Torvalds 1121da177e4SLinus TorvaldsLINK-$(CONFIG_LD_SCRIPT_STATIC) += -static 1131da177e4SLinus TorvaldsLINK-$(CONFIG_LD_SCRIPT_DYN) += -Wl,-rpath,/lib 1141da177e4SLinus Torvalds 1151da177e4SLinus TorvaldsCPP_MODE-$(CONFIG_MODE_TT) := -DMODE_TT 1161da177e4SLinus TorvaldsCONFIG_KERNEL_STACK_ORDER ?= 2 1171da177e4SLinus TorvaldsSTACK_SIZE := $(shell echo $$[ 4096 * (1 << $(CONFIG_KERNEL_STACK_ORDER)) ] ) 1181da177e4SLinus Torvalds 1191da177e4SLinus Torvaldsifndef START 1201c30385aSPaolo 'Blaisorblade' Giarrusso START = $(shell echo $$[ $(TOP_ADDR) - $(SIZE) ] ) 1211da177e4SLinus Torvaldsendif 1221da177e4SLinus Torvalds 1231c30385aSPaolo 'Blaisorblade' GiarrussoCPPFLAGS_vmlinux.lds = -U$(SUBARCH) \ 1241da177e4SLinus Torvalds -DSTART=$(START) -DELF_ARCH=$(ELF_ARCH) \ 1251c30385aSPaolo 'Blaisorblade' Giarrusso -DELF_FORMAT="$(ELF_FORMAT)" $(CPP_MODE-y) \ 1261c30385aSPaolo 'Blaisorblade' Giarrusso -DKERNEL_STACK_SIZE=$(STACK_SIZE) \ 1271c30385aSPaolo 'Blaisorblade' Giarrusso -DUNMAP_PATH=arch/um/sys-$(SUBARCH)/unmap_fin.o 1281da177e4SLinus Torvalds 1291da177e4SLinus Torvalds#The wrappers will select whether using "malloc" or the kernel allocator. 1301da177e4SLinus TorvaldsLINK_WRAPS = -Wl,--wrap,malloc -Wl,--wrap,free -Wl,--wrap,calloc 1311da177e4SLinus Torvalds 13220d00213SPaolo 'Blaisorblade' GiarrussoCFLAGS_vmlinux := $(LINK-y) $(LINK_WRAPS) 1331da177e4SLinus Torvaldsdefine cmd_vmlinux__ 1341da177e4SLinus Torvalds $(CC) $(CFLAGS_vmlinux) -o $@ \ 1351da177e4SLinus Torvalds -Wl,-T,$(vmlinux-lds) $(vmlinux-init) \ 1361da177e4SLinus Torvalds -Wl,--start-group $(vmlinux-main) -Wl,--end-group \ 137776cfebbSPaolo 'Blaisorblade' Giarrusso -lutil \ 1381da177e4SLinus Torvalds $(filter-out $(vmlinux-lds) $(vmlinux-init) $(vmlinux-main) \ 1391da177e4SLinus Torvalds FORCE ,$^) ; rm -f linux 1401da177e4SLinus Torvaldsendef 1411da177e4SLinus Torvalds 1421da177e4SLinus Torvalds#When cleaning we don't include .config, so we don't include 1431da177e4SLinus Torvalds#TT or skas makefiles and don't clean skas_ptregs.h. 1441da177e4SLinus TorvaldsCLEAN_FILES += linux x.i gmon.out $(ARCH_DIR)/include/uml-config.h \ 1458b8a9da5SPaolo 'Blaisorblade' Giarrusso $(GEN_HEADERS) $(ARCH_DIR)/include/skas_ptregs.h \ 1468b8a9da5SPaolo 'Blaisorblade' Giarrusso $(ARCH_DIR)/include/user_constants.h 1471da177e4SLinus Torvalds 1481da177e4SLinus TorvaldsMRPROPER_FILES += $(SYMLINK_HEADERS) $(ARCH_SYMLINKS) \ 1491da177e4SLinus Torvalds $(addprefix $(ARCH_DIR)/kernel/,$(KERN_SYMLINKS)) $(ARCH_DIR)/os \ 1501da177e4SLinus Torvalds $(ARCH_DIR)/Kconfig_arch 1511da177e4SLinus Torvalds 1521da177e4SLinus Torvaldsarchclean: 1531da177e4SLinus Torvalds $(Q)$(MAKE) $(clean)=$(ARCH_DIR)/util 1541da177e4SLinus Torvalds @find . \( -name '*.bb' -o -name '*.bbg' -o -name '*.da' \ 1551da177e4SLinus Torvalds -o -name '*.gcov' \) -type f -print | xargs rm -f 1561da177e4SLinus Torvalds 1571da177e4SLinus Torvalds$(SYMLINK_HEADERS): 1581da177e4SLinus Torvalds @echo ' SYMLINK $@' 159fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 160fd7aab9cSAl Viro ln -fsn $(srctree)/include/asm-um/$(basename $(notdir $@))-$(SUBARCH)$(suffix $@) $@ 161fd7aab9cSAl Viroelse 1621da177e4SLinus Torvalds $(Q)cd $(TOPDIR)/$(dir $@) ; \ 1631da177e4SLinus Torvalds ln -sf $(basename $(notdir $@))-$(SUBARCH)$(suffix $@) $(notdir $@) 164fd7aab9cSAl Viroendif 1651da177e4SLinus Torvalds 1661da177e4SLinus Torvaldsinclude/asm-um/arch: 1671da177e4SLinus Torvalds @echo ' SYMLINK $@' 168fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 169fd7aab9cSAl Viro $(Q)mkdir -p include/asm-um 170fd7aab9cSAl Viro $(Q)ln -fsn $(srctree)/include/asm-$(SUBARCH) include/asm-um/arch 171fd7aab9cSAl Viroelse 1721da177e4SLinus Torvalds $(Q)cd $(TOPDIR)/include/asm-um && ln -sf ../asm-$(SUBARCH) arch 173fd7aab9cSAl Viroendif 1741da177e4SLinus Torvalds 1751da177e4SLinus Torvalds$(ARCH_DIR)/include/sysdep: 1761da177e4SLinus Torvalds @echo ' SYMLINK $@' 177fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 178fd7aab9cSAl Viro $(Q)mkdir -p $(ARCH_DIR)/include 179fd7aab9cSAl Viro $(Q)mkdir -p $(ARCH_DIR)/include2 180fd7aab9cSAl Viro $(Q)ln -fsn sysdep-$(SUBARCH) $(ARCH_DIR)/include/sysdep 181fd7aab9cSAl Viro $(Q)ln -fsn $(srctree)/$(ARCH_DIR)/include/sysdep-$(SUBARCH) $(ARCH_DIR)/include2/sysdep 182fd7aab9cSAl Viroelse 1831da177e4SLinus Torvalds $(Q)cd $(ARCH_DIR)/include && ln -sf sysdep-$(SUBARCH) sysdep 184fd7aab9cSAl Viroendif 1851da177e4SLinus Torvalds 1861da177e4SLinus Torvalds$(ARCH_DIR)/os: 1871da177e4SLinus Torvalds @echo ' SYMLINK $@' 188fd7aab9cSAl Viroifneq ($(KBUILD_SRC),) 189fd7aab9cSAl Viro $(Q)ln -fsn $(srctree)/$(ARCH_DIR)/os-$(OS) $(ARCH_DIR)/os 190fd7aab9cSAl Viroelse 1911da177e4SLinus Torvalds $(Q)cd $(ARCH_DIR) && ln -sf os-$(OS) os 192fd7aab9cSAl Viroendif 1931da177e4SLinus Torvalds 1941da177e4SLinus Torvalds# Generated files 1951da177e4SLinus Torvaldsdefine filechk_umlconfig 1961da177e4SLinus Torvalds sed 's/ CONFIG/ UML_CONFIG/' 1971da177e4SLinus Torvaldsendef 1981da177e4SLinus Torvalds 1991da177e4SLinus Torvalds$(ARCH_DIR)/include/uml-config.h : include/linux/autoconf.h 2001da177e4SLinus Torvalds $(call filechk,umlconfig) 2011da177e4SLinus Torvalds 2028d0b9dc9SAl Viro$(ARCH_DIR)/user-offsets.s: $(ARCH_DIR)/sys-$(SUBARCH)/user-offsets.c 2038d0b9dc9SAl Viro $(CC) $(USER_CFLAGS) -S -o $@ $< 2048d0b9dc9SAl Viro 2058d0b9dc9SAl Viro$(ARCH_DIR)/user-offsets.h: $(ARCH_DIR)/user-offsets.s 2068d0b9dc9SAl Viro $(call filechk,gen-asm-offsets) 2078d0b9dc9SAl Viro 2088d0b9dc9SAl ViroCLEAN_FILES += $(ARCH_DIR)/user-offsets.s $(ARCH_DIR)/user-offsets.h 2098d0b9dc9SAl Viro 210a31769edSAl Viro$(ARCH_DIR)/kernel-offsets.s: $(ARCH_DIR)/sys-$(SUBARCH)/kernel-offsets.c \ 211a31769edSAl Viro $(ARCH_SYMLINKS) \ 212a31769edSAl Viro $(SYS_DIR)/sc.h \ 213a31769edSAl Viro include/asm include/linux/version.h \ 214a31769edSAl Viro include/config/MARKER \ 215a31769edSAl Viro $(ARCH_DIR)/include/user_constants.h 216a31769edSAl Viro $(CC) $(CFLAGS) $(NOSTDINC_FLAGS) $(CPPFLAGS) -S -o $@ $< 217a31769edSAl Viro 218a31769edSAl Viro$(ARCH_DIR)/kernel-offsets.h: $(ARCH_DIR)/kernel-offsets.s 219a31769edSAl Viro $(call filechk,gen-asm-offsets) 220a31769edSAl Viro 221a31769edSAl ViroCLEAN_FILES += $(ARCH_DIR)/kernel-offsets.s $(ARCH_DIR)/kernel-offsets.h 222a31769edSAl Viro 2231da177e4SLinus Torvalds$(ARCH_DIR)/include/task.h: $(ARCH_DIR)/util/mk_task 2241da177e4SLinus Torvalds $(call filechk,gen_header) 2251da177e4SLinus Torvalds 226fcddd72eSAl Viro$(ARCH_DIR)/include/user_constants.h: $(ARCH_DIR)/os-$(OS)/util/mk_user_constants 2271da177e4SLinus Torvalds $(call filechk,gen_header) 2281da177e4SLinus Torvalds 2291da177e4SLinus Torvalds$(ARCH_DIR)/include/kern_constants.h: $(ARCH_DIR)/util/mk_constants 2301da177e4SLinus Torvalds $(call filechk,gen_header) 2311da177e4SLinus Torvalds 2321da177e4SLinus Torvalds$(ARCH_DIR)/include/skas_ptregs.h: $(ARCH_DIR)/kernel/skas/util/mk_ptregs 2331da177e4SLinus Torvalds $(call filechk,gen_header) 2341da177e4SLinus Torvalds 235fcddd72eSAl Viro$(ARCH_DIR)/os-$(OS)/util/mk_user_constants: $(ARCH_DIR)/os-$(OS)/util FORCE ; 2361da177e4SLinus Torvalds 2371da177e4SLinus Torvalds$(ARCH_DIR)/util/mk_task $(ARCH_DIR)/util/mk_constants: $(ARCH_DIR)/include/user_constants.h $(ARCH_DIR)/util \ 2381da177e4SLinus Torvalds FORCE ; 2391da177e4SLinus Torvalds 2401da177e4SLinus Torvalds$(ARCH_DIR)/kernel/skas/util/mk_ptregs: $(ARCH_DIR)/kernel/skas/util FORCE ; 2411da177e4SLinus Torvalds 242da998a2aSAl Viro$(ARCH_DIR)/util: scripts_basic $(SYS_DIR)/sc.h $(ARCH_DIR)/kernel-offsets.h FORCE 2431da177e4SLinus Torvalds $(Q)$(MAKE) $(build)=$@ 2441da177e4SLinus Torvalds 2451cd3bc1cSAl Viro$(ARCH_DIR)/kernel/skas/util: scripts_basic $(ARCH_DIR)/user-offsets.h FORCE 2461da177e4SLinus Torvalds $(Q)$(MAKE) $(build)=$@ 2471da177e4SLinus Torvalds 248*b6b038a2SOlaf Hering$(ARCH_DIR)/os-$(OS)/util: scripts_basic $(ARCH_DIR)/user-offsets.h FORCE 2491da177e4SLinus Torvalds $(Q)$(MAKE) $(build)=$@ 2501da177e4SLinus Torvalds 2511da177e4SLinus Torvaldsexport SUBARCH USER_CFLAGS OS 252