Makefile 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. #
  2. # This file is included by the global makefile so that you can add your own
  3. # architecture-specific flags and dependencies.
  4. #
  5. # Copyright (C) 2002 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
  6. # Licensed under the GPL
  7. #
  8. ARCH_DIR := arch/um
  9. OS := $(shell uname -s)
  10. # We require bash because the vmlinux link and loader script cpp use bash
  11. # features.
  12. SHELL := /bin/bash
  13. filechk_gen_header = $<
  14. core-y += $(ARCH_DIR)/kernel/ \
  15. $(ARCH_DIR)/drivers/ \
  16. $(ARCH_DIR)/os-$(OS)/
  17. MODE_INCLUDE += -I$(srctree)/$(ARCH_DIR)/include/shared/skas
  18. include $(srctree)/$(ARCH_DIR)/Makefile-skas
  19. SHARED_HEADERS := $(ARCH_DIR)/include/shared
  20. ARCH_INCLUDE := -I$(srctree)/$(SHARED_HEADERS)
  21. ARCH_INCLUDE += -I$(srctree)/$(ARCH_DIR)/sys-$(SUBARCH)/shared
  22. ifneq ($(KBUILD_SRC),)
  23. ARCH_INCLUDE += -I$(SHARED_HEADERS)
  24. endif
  25. KBUILD_CPPFLAGS += -I$(srctree)/$(ARCH_DIR)/sys-$(SUBARCH)
  26. # -Dvmap=kernel_vmap prevents anything from referencing the libpcap.o symbol so
  27. # named - it's a common symbol in libpcap, so we get a binary which crashes.
  28. #
  29. # Same things for in6addr_loopback and mktime - found in libc. For these two we
  30. # only get link-time error, luckily.
  31. #
  32. # These apply to USER_CFLAGS to.
  33. KBUILD_CFLAGS += $(CFLAGS) $(CFLAGS-y) -D__arch_um__ -DSUBARCH=\"$(SUBARCH)\" \
  34. $(ARCH_INCLUDE) $(MODE_INCLUDE) -Dvmap=kernel_vmap \
  35. -Din6addr_loopback=kernel_in6addr_loopback \
  36. -Din6addr_any=kernel_in6addr_any
  37. KBUILD_AFLAGS += $(ARCH_INCLUDE)
  38. USER_CFLAGS = $(patsubst $(KERNEL_DEFINES),,$(patsubst -D__KERNEL__,,\
  39. $(patsubst -I%,,$(KBUILD_CFLAGS)))) $(ARCH_INCLUDE) $(MODE_INCLUDE) \
  40. $(filter -I%,$(CFLAGS)) -D_FILE_OFFSET_BITS=64
  41. include $(srctree)/$(ARCH_DIR)/Makefile-$(SUBARCH)
  42. #This will adjust *FLAGS accordingly to the platform.
  43. include $(srctree)/$(ARCH_DIR)/Makefile-os-$(OS)
  44. KBUILD_CPPFLAGS += -I$(srctree)/arch/$(HEADER_ARCH)/include
  45. # -Derrno=kernel_errno - This turns all kernel references to errno into
  46. # kernel_errno to separate them from the libc errno. This allows -fno-common
  47. # in KBUILD_CFLAGS. Otherwise, it would cause ld to complain about the two different
  48. # errnos.
  49. # These apply to kernelspace only.
  50. #
  51. # strip leading and trailing whitespace to make the USER_CFLAGS removal of these
  52. # defines more robust
  53. KERNEL_DEFINES = $(strip -Derrno=kernel_errno -Dsigprocmask=kernel_sigprocmask \
  54. -Dmktime=kernel_mktime $(ARCH_KERNEL_DEFINES))
  55. KBUILD_CFLAGS += $(KERNEL_DEFINES)
  56. PHONY += linux
  57. all: linux
  58. linux: vmlinux
  59. @echo ' LINK $@'
  60. $(Q)ln -f $< $@
  61. define archhelp
  62. echo '* linux - Binary kernel image (./linux) - for backward'
  63. echo ' compatibility only, this creates a hard link to the'
  64. echo ' real kernel binary, the "vmlinux" binary you'
  65. echo ' find in the kernel root.'
  66. endef
  67. KBUILD_KCONFIG := arch/um/Kconfig.$(HEADER_ARCH)
  68. archprepare: $(SHARED_HEADERS)/user_constants.h
  69. archprepare: $(SHARED_HEADERS)/kern_constants.h
  70. LINK-$(CONFIG_LD_SCRIPT_STATIC) += -static
  71. LINK-$(CONFIG_LD_SCRIPT_DYN) += -Wl,-rpath,/lib
  72. CFLAGS_NO_HARDENING := $(call cc-option, -fno-PIC,) $(call cc-option, -fno-pic,) \
  73. $(call cc-option, -fno-stack-protector,) \
  74. $(call cc-option, -fno-stack-protector-all,)
  75. # Options used by linker script
  76. export LDS_START := $(START)
  77. export LDS_ELF_ARCH := $(ELF_ARCH)
  78. export LDS_ELF_FORMAT := $(ELF_FORMAT)
  79. # The wrappers will select whether using "malloc" or the kernel allocator.
  80. LINK_WRAPS = -Wl,--wrap,malloc -Wl,--wrap,free -Wl,--wrap,calloc
  81. LD_FLAGS_CMDLINE = $(foreach opt,$(LDFLAGS),-Wl,$(opt))
  82. CFLAGS_vmlinux := $(LINK-y) $(LINK_WRAPS) $(LD_FLAGS_CMDLINE)
  83. define cmd_vmlinux__
  84. $(CC) $(CFLAGS_vmlinux) -o $@ \
  85. -Wl,-T,$(vmlinux-lds) $(vmlinux-init) \
  86. -Wl,--start-group $(vmlinux-main) -Wl,--end-group \
  87. -lutil \
  88. $(filter-out $(vmlinux-lds) $(vmlinux-init) $(vmlinux-main) vmlinux.o \
  89. FORCE ,$^) ; rm -f linux
  90. endef
  91. # When cleaning we don't include .config, so we don't include
  92. # TT or skas makefiles and don't clean skas_ptregs.h.
  93. CLEAN_FILES += linux x.i gmon.out \
  94. $(SHARED_HEADERS)/user_constants.h \
  95. $(SHARED_HEADERS)/kern_constants.h
  96. archclean:
  97. @find . \( -name '*.bb' -o -name '*.bbg' -o -name '*.da' \
  98. -o -name '*.gcov' \) -type f -print | xargs rm -f
  99. # Generated files
  100. $(ARCH_DIR)/sys-$(SUBARCH)/user-offsets.s: FORCE
  101. $(Q)$(MAKE) $(build)=$(ARCH_DIR)/sys-$(SUBARCH) $@
  102. define filechk_gen-asm-offsets
  103. (set -e; \
  104. echo "/*"; \
  105. echo " * DO NOT MODIFY."; \
  106. echo " *"; \
  107. echo " * This file was generated by arch/$(ARCH)/Makefile"; \
  108. echo " *"; \
  109. echo " */"; \
  110. echo ""; \
  111. sed -ne "/^->/{s:^->\([^ ]*\) [\$$#]*\([^ ]*\) \(.*\):#define \1 \2 /* \3 */:; s:->::; p;}"; \
  112. echo ""; )
  113. endef
  114. $(SHARED_HEADERS)/user_constants.h: $(ARCH_DIR)/sys-$(SUBARCH)/user-offsets.s
  115. $(call filechk,gen-asm-offsets)
  116. $(SHARED_HEADERS)/kern_constants.h:
  117. $(Q)mkdir -p $(dir $@)
  118. $(Q)echo '#include "../../../../include/generated/asm-offsets.h"' >$@
  119. export SUBARCH USER_CFLAGS CFLAGS_NO_HARDENING OS HEADER_ARCH DEV_NULL_PATH