xref: /linux/arch/um/Makefile (revision fd7aab9c1a4705ed45fe01a7ff108ce9823b0830)
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 \
201da177e4SLinus Torvalds	arch-signal.h module.h vm-flags.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
47*fd7aab9cSAl Viroifneq ($(KBUILD_SRC),)
48*fd7aab9cSAl ViroARCH_INCLUDE	+= -I$(ARCH_DIR)/include2
49*fd7aab9cSAl ViroARCH_INCLUDE	+= -I$(srctree)/$(ARCH_DIR)/include
50*fd7aab9cSAl ViroMRPROPER_DIRS	+= $(ARCH_DIR)/include2
51*fd7aab9cSAl Viroendif
521da177e4SLinus TorvaldsSYS_DIR		:= $(ARCH_DIR)/include/sysdep-$(SUBARCH)
531da177e4SLinus Torvalds
541da177e4SLinus Torvaldsinclude $(srctree)/$(ARCH_DIR)/Makefile-$(SUBARCH)
551da177e4SLinus Torvalds
561da177e4SLinus Torvaldscore-y += $(SUBARCH_CORE)
571da177e4SLinus Torvaldslibs-y += $(SUBARCH_LIBS)
581da177e4SLinus Torvalds
591da177e4SLinus Torvalds# -Derrno=kernel_errno - This turns all kernel references to errno into
601da177e4SLinus Torvalds# kernel_errno to separate them from the libc errno.  This allows -fno-common
611da177e4SLinus Torvalds# in CFLAGS.  Otherwise, it would cause ld to complain about the two different
621da177e4SLinus Torvalds# errnos.
631da177e4SLinus Torvalds
641da177e4SLinus TorvaldsCFLAGS += $(CFLAGS-y) -D__arch_um__ -DSUBARCH=\"$(SUBARCH)\" \
651da177e4SLinus Torvalds	$(ARCH_INCLUDE) $(MODE_INCLUDE)
661da177e4SLinus Torvalds
671da177e4SLinus TorvaldsUSER_CFLAGS := $(patsubst -I%,,$(CFLAGS))
681da177e4SLinus TorvaldsUSER_CFLAGS := $(patsubst -D__KERNEL__,,$(USER_CFLAGS)) $(ARCH_INCLUDE) \
691da177e4SLinus Torvalds	$(MODE_INCLUDE) $(ARCH_USER_CFLAGS)
701da177e4SLinus TorvaldsCFLAGS += -Derrno=kernel_errno -Dsigprocmask=kernel_sigprocmask
711da177e4SLinus TorvaldsCFLAGS += $(call cc-option,-fno-unit-at-a-time,)
721da177e4SLinus Torvalds
731da177e4SLinus Torvalds#This will adjust *FLAGS accordingly to the platform.
741da177e4SLinus Torvaldsinclude $(srctree)/$(ARCH_DIR)/Makefile-os-$(OS)
751da177e4SLinus Torvalds
761da177e4SLinus Torvalds# These are needed for clean and mrproper, since in that case .config is not
771da177e4SLinus Torvalds# included; the values here are meaningless
781da177e4SLinus Torvalds
791da177e4SLinus TorvaldsCONFIG_NEST_LEVEL ?= 0
801da177e4SLinus TorvaldsCONFIG_KERNEL_HALF_GIGS ?= 0
811da177e4SLinus Torvalds
821da177e4SLinus TorvaldsSIZE = (($(CONFIG_NEST_LEVEL) + $(CONFIG_KERNEL_HALF_GIGS)) * 0x20000000)
831da177e4SLinus Torvalds
841da177e4SLinus Torvaldsifeq ($(CONFIG_MODE_SKAS), y)
851da177e4SLinus Torvalds$(SYS_HEADERS) : $(ARCH_DIR)/include/skas_ptregs.h
861da177e4SLinus Torvaldsendif
871da177e4SLinus Torvalds
881da177e4SLinus Torvalds.PHONY: linux
891da177e4SLinus Torvalds
901da177e4SLinus Torvaldsall: linux
911da177e4SLinus Torvalds
921da177e4SLinus Torvaldslinux: vmlinux
931da177e4SLinus Torvalds	ln -f $< $@
941da177e4SLinus Torvalds
951da177e4SLinus Torvaldsdefine archhelp
961da177e4SLinus Torvalds  echo '* linux		- Binary kernel image (./linux) - for backward'
971da177e4SLinus Torvalds  echo '		   compatibility only, this creates a hard link to the'
981da177e4SLinus Torvalds  echo '		   real kernel binary, the the "vmlinux" binary you'
991da177e4SLinus Torvalds  echo '		   find in the kernel root.'
1001da177e4SLinus Torvaldsendef
1011da177e4SLinus Torvalds
102*fd7aab9cSAl Viroifneq ($(KBUILD_SRC),)
103*fd7aab9cSAl Viro$(shell mkdir -p $(ARCH_DIR) && ln -fsn $(srctree)/$(ARCH_DIR)/Kconfig_$(SUBARCH) $(ARCH_DIR)/Kconfig_arch)
104*fd7aab9cSAl ViroCLEAN_FILES += $(ARCH_DIR)/Kconfig_arch
105*fd7aab9cSAl Viroelse
1061da177e4SLinus Torvalds$(shell cd $(ARCH_DIR) && ln -sf Kconfig_$(SUBARCH) Kconfig_arch)
107*fd7aab9cSAl Viroendif
1081da177e4SLinus Torvalds
10903f81dc5SAl Viroprepare: $(ARCH_SYMLINKS) $(SYS_HEADERS) $(GEN_HEADERS)
1101da177e4SLinus Torvalds
1111da177e4SLinus TorvaldsLINK-$(CONFIG_LD_SCRIPT_STATIC) += -static
1121da177e4SLinus TorvaldsLINK-$(CONFIG_LD_SCRIPT_DYN) += -Wl,-rpath,/lib
1131da177e4SLinus Torvalds
1141da177e4SLinus TorvaldsCPP_MODE-$(CONFIG_MODE_TT) := -DMODE_TT
1151da177e4SLinus TorvaldsCONFIG_KERNEL_STACK_ORDER ?= 2
1161da177e4SLinus TorvaldsSTACK_SIZE := $(shell echo $$[ 4096 * (1 << $(CONFIG_KERNEL_STACK_ORDER)) ] )
1171da177e4SLinus Torvalds
1181da177e4SLinus Torvaldsifndef START
1191da177e4SLinus Torvalds  START = $$(($(TOP_ADDR) - $(SIZE)))
1201da177e4SLinus Torvaldsendif
1211da177e4SLinus Torvalds
1221da177e4SLinus TorvaldsCPPFLAGS_vmlinux.lds = $(shell echo -U$(SUBARCH) \
1231da177e4SLinus Torvalds	-DSTART=$(START) -DELF_ARCH=$(ELF_ARCH) \
1241da177e4SLinus Torvalds	-DELF_FORMAT=\"$(ELF_FORMAT)\" $(CPP_MODE-y) \
1251da177e4SLinus Torvalds	-DKERNEL_STACK_SIZE=$(STACK_SIZE))
1261da177e4SLinus Torvalds
1271da177e4SLinus Torvalds#The wrappers will select whether using "malloc" or the kernel allocator.
1281da177e4SLinus TorvaldsLINK_WRAPS = -Wl,--wrap,malloc -Wl,--wrap,free -Wl,--wrap,calloc
1291da177e4SLinus Torvalds
1301da177e4SLinus TorvaldsCFLAGS_vmlinux = $(LINK-y) $(LINK_WRAPS)
1311da177e4SLinus Torvaldsdefine cmd_vmlinux__
1321da177e4SLinus Torvalds	$(CC) $(CFLAGS_vmlinux) -o $@ \
1331da177e4SLinus Torvalds	-Wl,-T,$(vmlinux-lds) $(vmlinux-init) \
1341da177e4SLinus Torvalds	-Wl,--start-group $(vmlinux-main) -Wl,--end-group \
135776cfebbSPaolo 'Blaisorblade' Giarrusso	-lutil \
1361da177e4SLinus Torvalds	$(filter-out $(vmlinux-lds) $(vmlinux-init) $(vmlinux-main) \
1371da177e4SLinus Torvalds	FORCE ,$^) ; rm -f linux
1381da177e4SLinus Torvaldsendef
1391da177e4SLinus Torvalds
1401da177e4SLinus Torvalds#When cleaning we don't include .config, so we don't include
1411da177e4SLinus Torvalds#TT or skas makefiles and don't clean skas_ptregs.h.
1421da177e4SLinus TorvaldsCLEAN_FILES += linux x.i gmon.out $(ARCH_DIR)/include/uml-config.h \
1431da177e4SLinus Torvalds	$(GEN_HEADERS) $(ARCH_DIR)/include/skas_ptregs.h
1441da177e4SLinus Torvalds
1451da177e4SLinus TorvaldsMRPROPER_FILES += $(SYMLINK_HEADERS) $(ARCH_SYMLINKS) \
1461da177e4SLinus Torvalds	$(addprefix $(ARCH_DIR)/kernel/,$(KERN_SYMLINKS)) $(ARCH_DIR)/os \
1471da177e4SLinus Torvalds	$(ARCH_DIR)/Kconfig_arch
1481da177e4SLinus Torvalds
1491da177e4SLinus Torvaldsarchclean:
1501da177e4SLinus Torvalds	$(Q)$(MAKE) $(clean)=$(ARCH_DIR)/util
1511da177e4SLinus Torvalds	@find . \( -name '*.bb' -o -name '*.bbg' -o -name '*.da' \
1521da177e4SLinus Torvalds		-o -name '*.gcov' \) -type f -print | xargs rm -f
1531da177e4SLinus Torvalds
1541da177e4SLinus Torvalds$(SYMLINK_HEADERS):
1551da177e4SLinus Torvalds	@echo '  SYMLINK $@'
156*fd7aab9cSAl Viroifneq ($(KBUILD_SRC),)
157*fd7aab9cSAl Viro	ln -fsn $(srctree)/include/asm-um/$(basename $(notdir $@))-$(SUBARCH)$(suffix $@) $@
158*fd7aab9cSAl Viroelse
1591da177e4SLinus Torvalds	$(Q)cd $(TOPDIR)/$(dir $@) ; \
1601da177e4SLinus Torvalds	ln -sf $(basename $(notdir $@))-$(SUBARCH)$(suffix $@) $(notdir $@)
161*fd7aab9cSAl Viroendif
1621da177e4SLinus Torvalds
1631da177e4SLinus Torvaldsinclude/asm-um/arch:
1641da177e4SLinus Torvalds	@echo '  SYMLINK $@'
165*fd7aab9cSAl Viroifneq ($(KBUILD_SRC),)
166*fd7aab9cSAl Viro	$(Q)mkdir -p include/asm-um
167*fd7aab9cSAl Viro	$(Q)ln -fsn $(srctree)/include/asm-$(SUBARCH) include/asm-um/arch
168*fd7aab9cSAl Viroelse
1691da177e4SLinus Torvalds	$(Q)cd $(TOPDIR)/include/asm-um && ln -sf ../asm-$(SUBARCH) arch
170*fd7aab9cSAl Viroendif
1711da177e4SLinus Torvalds
1721da177e4SLinus Torvalds$(ARCH_DIR)/include/sysdep:
1731da177e4SLinus Torvalds	@echo '  SYMLINK $@'
174*fd7aab9cSAl Viroifneq ($(KBUILD_SRC),)
175*fd7aab9cSAl Viro	$(Q)mkdir -p $(ARCH_DIR)/include
176*fd7aab9cSAl Viro	$(Q)mkdir -p $(ARCH_DIR)/include2
177*fd7aab9cSAl Viro	$(Q)ln -fsn sysdep-$(SUBARCH) $(ARCH_DIR)/include/sysdep
178*fd7aab9cSAl Viro	$(Q)ln -fsn $(srctree)/$(ARCH_DIR)/include/sysdep-$(SUBARCH) $(ARCH_DIR)/include2/sysdep
179*fd7aab9cSAl Viroelse
1801da177e4SLinus Torvalds	$(Q)cd $(ARCH_DIR)/include && ln -sf sysdep-$(SUBARCH) sysdep
181*fd7aab9cSAl Viroendif
1821da177e4SLinus Torvalds
1831da177e4SLinus Torvalds$(ARCH_DIR)/os:
1841da177e4SLinus Torvalds	@echo '  SYMLINK $@'
185*fd7aab9cSAl Viroifneq ($(KBUILD_SRC),)
186*fd7aab9cSAl Viro	$(Q)ln -fsn $(srctree)/$(ARCH_DIR)/os-$(OS) $(ARCH_DIR)/os
187*fd7aab9cSAl Viroelse
1881da177e4SLinus Torvalds	$(Q)cd $(ARCH_DIR) && ln -sf os-$(OS) os
189*fd7aab9cSAl Viroendif
1901da177e4SLinus Torvalds
1911da177e4SLinus Torvalds# Generated files
1921da177e4SLinus Torvaldsdefine filechk_umlconfig
1931da177e4SLinus Torvalds	sed 's/ CONFIG/ UML_CONFIG/'
1941da177e4SLinus Torvaldsendef
1951da177e4SLinus Torvalds
1961da177e4SLinus Torvalds$(ARCH_DIR)/include/uml-config.h : include/linux/autoconf.h
1971da177e4SLinus Torvalds	$(call filechk,umlconfig)
1981da177e4SLinus Torvalds
1998d0b9dc9SAl Viro$(ARCH_DIR)/user-offsets.s: $(ARCH_DIR)/sys-$(SUBARCH)/user-offsets.c
2008d0b9dc9SAl Viro	$(CC) $(USER_CFLAGS) -S -o $@ $<
2018d0b9dc9SAl Viro
2028d0b9dc9SAl Viro$(ARCH_DIR)/user-offsets.h: $(ARCH_DIR)/user-offsets.s
2038d0b9dc9SAl Viro	$(call filechk,gen-asm-offsets)
2048d0b9dc9SAl Viro
2058d0b9dc9SAl ViroCLEAN_FILES += $(ARCH_DIR)/user-offsets.s  $(ARCH_DIR)/user-offsets.h
2068d0b9dc9SAl Viro
207a31769edSAl Viro$(ARCH_DIR)/kernel-offsets.s: $(ARCH_DIR)/sys-$(SUBARCH)/kernel-offsets.c \
208a31769edSAl Viro				   $(ARCH_SYMLINKS) \
209a31769edSAl Viro				   $(SYS_DIR)/sc.h \
210a31769edSAl Viro				   include/asm include/linux/version.h \
211a31769edSAl Viro				   include/config/MARKER \
212a31769edSAl Viro				   $(ARCH_DIR)/include/user_constants.h
213a31769edSAl Viro	$(CC) $(CFLAGS) $(NOSTDINC_FLAGS) $(CPPFLAGS) -S -o $@ $<
214a31769edSAl Viro
215a31769edSAl Viro$(ARCH_DIR)/kernel-offsets.h: $(ARCH_DIR)/kernel-offsets.s
216a31769edSAl Viro	$(call filechk,gen-asm-offsets)
217a31769edSAl Viro
218a31769edSAl ViroCLEAN_FILES += $(ARCH_DIR)/kernel-offsets.s  $(ARCH_DIR)/kernel-offsets.h
219a31769edSAl Viro
2201da177e4SLinus Torvalds$(ARCH_DIR)/include/task.h: $(ARCH_DIR)/util/mk_task
2211da177e4SLinus Torvalds	$(call filechk,gen_header)
2221da177e4SLinus Torvalds
223fcddd72eSAl Viro$(ARCH_DIR)/include/user_constants.h: $(ARCH_DIR)/os-$(OS)/util/mk_user_constants
2241da177e4SLinus Torvalds	$(call filechk,gen_header)
2251da177e4SLinus Torvalds
2261da177e4SLinus Torvalds$(ARCH_DIR)/include/kern_constants.h: $(ARCH_DIR)/util/mk_constants
2271da177e4SLinus Torvalds	$(call filechk,gen_header)
2281da177e4SLinus Torvalds
2291da177e4SLinus Torvalds$(ARCH_DIR)/include/skas_ptregs.h: $(ARCH_DIR)/kernel/skas/util/mk_ptregs
2301da177e4SLinus Torvalds	$(call filechk,gen_header)
2311da177e4SLinus Torvalds
232fcddd72eSAl Viro$(ARCH_DIR)/os-$(OS)/util/mk_user_constants: $(ARCH_DIR)/os-$(OS)/util FORCE ;
2331da177e4SLinus Torvalds
2341da177e4SLinus Torvalds$(ARCH_DIR)/util/mk_task $(ARCH_DIR)/util/mk_constants: $(ARCH_DIR)/include/user_constants.h $(ARCH_DIR)/util \
2351da177e4SLinus Torvalds	FORCE ;
2361da177e4SLinus Torvalds
2371da177e4SLinus Torvalds$(ARCH_DIR)/kernel/skas/util/mk_ptregs: $(ARCH_DIR)/kernel/skas/util FORCE ;
2381da177e4SLinus Torvalds
239da998a2aSAl Viro$(ARCH_DIR)/util: scripts_basic $(SYS_DIR)/sc.h $(ARCH_DIR)/kernel-offsets.h FORCE
2401da177e4SLinus Torvalds	$(Q)$(MAKE) $(build)=$@
2411da177e4SLinus Torvalds
2421cd3bc1cSAl Viro$(ARCH_DIR)/kernel/skas/util: scripts_basic $(ARCH_DIR)/user-offsets.h FORCE
2431da177e4SLinus Torvalds	$(Q)$(MAKE) $(build)=$@
2441da177e4SLinus Torvalds
245fcddd72eSAl Viro$(ARCH_DIR)/os-$(OS)/util: scripts_basic FORCE
2461da177e4SLinus Torvalds	$(Q)$(MAKE) $(build)=$@
2471da177e4SLinus Torvalds
2481da177e4SLinus Torvaldsexport SUBARCH USER_CFLAGS OS
249