Makefile 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. SHELL := /bin/sh
  2. MAKEFLAGS += -rR
  3. MAKEFLAGS += --no-print-directory
  4. .PHONY: all
  5. all: x15
  6. VERSION = 0.1
  7. export VERSION
  8. COMMA := ,
  9. ifndef V
  10. V := 0
  11. endif
  12. # Use callable variables so that commands can be split into multiple
  13. # lines, but produce a single line when echoed. This makes copying
  14. # commands easy. It also makes them somewhat self-describing.
  15. ifeq ($(V),0)
  16. Q := @
  17. # $(call xbuild_action_print,<action_short_name>,<target>)
  18. define xbuild_action_print
  19. @printf " %-7s %s\n" $(1) $(2)
  20. @
  21. endef
  22. else ifneq ($(V),1)
  23. $(error invalid value for V)
  24. endif
  25. export Q
  26. # $(call xbuild_action_mkdir,<target>)
  27. define xbuild_action_mkdir
  28. $(Q)mkdir -p $(dir $(1))
  29. endef
  30. # $(call xbuild_action,<action>,<target>)
  31. define xbuild_action
  32. $(call xbuild_action_mkdir,$(2))
  33. $(call xbuild_action_print,$(1),$(2))
  34. endef
  35. define xbuild_kconfig_invoke
  36. $(Q)$(MAKE) -f $(SRCDIR)/$(KCONFIG_PATH)/Makefile $@
  37. endef
  38. define xbuild_gen_autoconf_h
  39. $(call xbuild_action,GEN,$@)cat $< \
  40. | sed -e 's/^\([^#]\)/#define \1/g' \
  41. -e 's/=/ /' \
  42. | grep '^#define' > $@
  43. endef
  44. # $(call xbuild_check_cc_option,<option>)
  45. define xbuild_check_cc_option
  46. $(shell printf "int main(void){ return 0; }\n" \
  47. | $(CC) -Wall -Werror -x c $(1) -c - -o /dev/null 2> /dev/null \
  48. && printf -- "%s" $(1))
  49. endef
  50. # $(call xbuild_replace_source_suffix,<suffix>,<file_names>)
  51. define xbuild_replace_source_suffix
  52. $(sort $(patsubst %.c,%.$(1),$(filter %.c,$(2))) \
  53. $(patsubst %.S,%.$(1),$(filter %.S,$(2))))
  54. endef
  55. define xbuild_compile
  56. $(call xbuild_action,CC,$@) \
  57. $(COMPILE) -MMD -MP -c -o $@ $<
  58. endef
  59. define xbuild_gen_linker_script
  60. $(call xbuild_action,LDS,$@) \
  61. $(CPP) $(XBUILD_CPPFLAGS) -MMD -MP \
  62. -MF $@.d -MT $@ -P -o $@ $<
  63. endef
  64. # $(call xbuild_link,<objects>)
  65. define xbuild_link
  66. $(call xbuild_action,LD,$@) \
  67. $(COMPILE) -o $@ $(1) $(XBUILD_LDFLAGS)
  68. endef
  69. XBUILD_GEN_SYMTAB = $(SRCDIR)/tools/gen_symtab.py
  70. XBUILD_GEN_SYMTAB_DEPS = $(XBUILD_GEN_SYMTAB)
  71. # $(call xbuild_gen_symtab)
  72. define xbuild_gen_symtab
  73. $(call xbuild_action,GEN,$@) \
  74. $(NM) -S -n $< | $(XBUILD_GEN_SYMTAB) > $@
  75. endef
  76. define xbuild_clean
  77. $(Q)rm -f x15 $(x15_NO_SYMTAB) \
  78. $(x15_OBJDEPS) $(x15_OBJECTS) \
  79. $(x15_SYMTAB_C) $(x15_SYMTAB_D) $(x15_SYMTAB_O) \
  80. $(x15_LDS_D) $(x15_LDS)
  81. endef
  82. define xbuild_distclean
  83. $(clean)
  84. $(Q)rm -f .config \
  85. .config.old \
  86. include/generated/autoconf.h \
  87. include/generated/autoconf.mk
  88. endef
  89. ARCH ?= $(shell uname -m | sed -e s/i.86/x86/ -e s/x86_64/x86/ )
  90. export ARCH
  91. SRCDIR := $(realpath $(dir $(realpath $(firstword $(MAKEFILE_LIST)))))
  92. VPATH := $(SRCDIR)
  93. export SRCDIR VPATH
  94. PREFIX ?= /usr/local
  95. DATAROOTDIR ?= share
  96. # Do not use MAKEFILE_LIST as its value is updated only on inclusion,
  97. # which makes it unsuitable as a rule dependency in most of the file.
  98. #
  99. # These additional Makefiles are included in order.
  100. MAKEFILE_INCLUDES := \
  101. $(SRCDIR)/arch/$(ARCH)/Makefile \
  102. $(SRCDIR)/doc/Makefile \
  103. $(SRCDIR)/kern/Makefile \
  104. $(SRCDIR)/test/Makefile \
  105. $(SRCDIR)/vm/Makefile
  106. ALL_MAKEFILES := $(MAKEFILE_LIST) $(MAKEFILE_INCLUDES)
  107. ifeq ($(words $(MAKECMDGOALS)),0)
  108. else ifeq ($(words $(MAKECMDGOALS)),1)
  109. else
  110. $(error up to one target may be given)
  111. endif
  112. KCONFIG_PATH := tools/kconfig
  113. # Export to Kconfig
  114. export KCONFIG_PATH
  115. HOSTCC := $(if $(shell type gcc 2>/dev/null),gcc,cc)
  116. HOSTCXX = g++
  117. HOSTCFLAGS := -g
  118. HOSTCXXFLAGS := -g
  119. # Export to Kconfig
  120. export HOSTCC HOSTCXX HOSTCFLAGS HOSTCXXFLAGS
  121. BOARDS := $(wildcard $(SRCDIR)/arch/$(ARCH)/configs/*_defconfig)
  122. BOARDS := $(sort $(notdir $(BOARDS)))
  123. .PHONY: help
  124. help:
  125. @printf 'Configuration targets:\n'
  126. @$(Q)$(MAKE) -f $(SRCDIR)/$(KCONFIG_PATH)/Makefile $@
  127. @printf '\n'
  128. @printf 'Cleaning targets:\n'
  129. @printf ' clean - Remove most generated files but keep configuration\n'
  130. @printf ' distclean - Remove all generated files\n'
  131. @printf '\n'
  132. @printf 'Build targets:\n'
  133. @printf ' all - Build all targets marked with [*]\n'
  134. @printf '* x15 - Build the kernel ELF image\n'
  135. @printf '\n'
  136. @printf 'Documentation targets:\n'
  137. @printf '* docs - Build all documentation\n'
  138. $(DOC_HELP)
  139. @printf '\n'
  140. @printf 'Installation targets:\n'
  141. @printf ' install - Install the kernel and documentation\n'
  142. @printf ' install-strip - Same as install but also strip the kernel\n'
  143. @printf ' install-x15 - Install the kernel only\n'
  144. @printf ' install-strip-x15 - Same as install-x15 but also strip the kernel\n'
  145. @printf ' install-docs - Install documentation files\n'
  146. $(DOC_INSTALL_HELP)
  147. @printf '\n'
  148. @printf 'Architecture specific targets ($(ARCH)):\n'
  149. @$(if $(BOARDS), \
  150. $(foreach b, $(BOARDS), \
  151. printf " %-24s - Build for %s\\n" $(b) $(subst _defconfig,,$(b));))
  152. @$(ARCH_HELP)
  153. @printf '\n'
  154. @printf 'Options:\n'
  155. @printf ' make V=0 - Quiet build\n'
  156. @printf ' make V=1 - Verbose build\n'
  157. @printf '\n'
  158. @printf 'Notes:\n'
  159. @printf '- One target at most may be specified.\n'
  160. @printf '- The compiler program and flags may be given at configuration time\n'
  161. @printf ' through the CC and CFLAGS variables respectively.\n'
  162. @printf '- Out-of-tree builds are performed with the following command:\n'
  163. @printf ' make -f path/to/src/Makefile [options] [target]\n'
  164. @printf '- The source directory must be completely clean for reliable out-of-tree builds.\n'
  165. @printf '- Use the DESTDIR and PREFIX variables to control installation, e.g.:\n'
  166. @printf ' make DESTDIR=/stagingroot PREFIX=/usr install\n'
  167. @printf '\n'
  168. @printf 'See README for more information.\n'
  169. # Don't create a %config pattern rule as it would conflict with .config
  170. KCONFIG_TARGETS := config nconfig menuconfig xconfig gconfig \
  171. allnoconfig allyesconfig alldefconfig randconfig \
  172. oldconfig olddefconfig defconfig savedefconfig \
  173. listnewconfig
  174. .PHONY: $(KCONFIG_TARGETS)
  175. $(KCONFIG_TARGETS):
  176. $(call xbuild_kconfig_invoke)
  177. %_defconfig:
  178. $(call xbuild_kconfig_invoke)
  179. include/generated/autoconf.h: .config $(ALL_MAKEFILES)
  180. $(call xbuild_gen_autoconf_h)
  181. -include .config
  182. ifdef CONFIG_COMPILER
  183. # Use printf to remove quotes
  184. CC := $(shell printf -- $(CONFIG_COMPILER))
  185. else
  186. CC := gcc
  187. endif
  188. # The CC variable is used by Kconfig to set the value of CONFIG_COMPILER.
  189. export CC
  190. TOOLCHAIN_NAME = $(shell printf "%s" $(CC) | rev | cut -s -d - -f 2- | rev)
  191. ifneq ($(TOOLCHAIN_NAME),)
  192. TOOLCHAIN_PREFIX = $(TOOLCHAIN_NAME)-
  193. endif
  194. CPP := $(CC) -E
  195. NM := $(TOOLCHAIN_PREFIX)nm
  196. OBJCOPY := $(TOOLCHAIN_PREFIX)objcopy
  197. CFLAGS ?= -O2 -g
  198. # Export to CONFIG_CFLAGS
  199. export CFLAGS
  200. XBUILD_CPPFLAGS :=
  201. XBUILD_CFLAGS :=
  202. XBUILD_CPPFLAGS += -pipe
  203. # Do not include headers from the hosted environment, but
  204. # do include headers from the compiler.
  205. XBUILD_CPPFLAGS += -nostdinc
  206. XBUILD_CPPFLAGS += -isystem $(shell $(CC) -print-file-name=include)
  207. XBUILD_CPPFLAGS += -std=gnu11
  208. XBUILD_CPPFLAGS += -ffreestanding
  209. XBUILD_CPPFLAGS += -include $(SRCDIR)/kern/config.h
  210. XBUILD_CPPFLAGS += -include include/generated/autoconf.h
  211. XBUILD_CPPFLAGS += -I$(SRCDIR)
  212. XBUILD_CPPFLAGS += -I$(SRCDIR)/include
  213. XBUILD_CPPFLAGS += -I$(SRCDIR)/arch/$(ARCH)
  214. ifndef CONFIG_ASSERT
  215. XBUILD_CPPFLAGS += -DNDEBUG
  216. endif
  217. XBUILD_CFLAGS += -fsigned-char
  218. XBUILD_CFLAGS += -fno-common
  219. # XXX Some assemblers consider the / symbol to denote comments. The --divide
  220. # option suppresses that behavior.
  221. XBUILD_CFLAGS += $(call xbuild_check_cc_option,-Wa$(COMMA)--divide)
  222. XBUILD_CFLAGS += -Wall
  223. XBUILD_CFLAGS += -Wextra
  224. XBUILD_CFLAGS += -Wshadow
  225. XBUILD_CFLAGS += -Wmissing-prototypes
  226. XBUILD_CFLAGS += -Wstrict-prototypes
  227. # XXX Temporary, until a single solution is adopted to silence these warnings.
  228. XBUILD_CFLAGS += -Wno-unneeded-internal-declaration
  229. XBUILD_CFLAGS += $(call xbuild_check_cc_option,-fno-PIE)
  230. XBUILD_CFLAGS += $(call xbuild_check_cc_option,-Qunused-arguments)
  231. XBUILD_LDFLAGS += -static -nostdlib -lgcc
  232. # Disable the build ID feature of the linker
  233. XBUILD_LDFLAGS += -Wl,--build-id=none
  234. x15_SOURCES-y :=
  235. x15_LDS_S := arch/$(ARCH)/x15.lds.S
  236. # Include the additional Makefiles here, as they may augment the build
  237. # variables.
  238. include $(MAKEFILE_INCLUDES)
  239. # Export to Kconfig.
  240. # Must be defined by the architecture-specific Makefile.
  241. export KCONFIG_DEFCONFIG
  242. ifdef CONFIG_COMPILER_OPTIONS
  243. # Use printf to remove quotes
  244. XBUILD_CFLAGS += $(shell printf -- $(CONFIG_COMPILER_OPTIONS))
  245. endif
  246. COMPILE := $(CC) $(XBUILD_CPPFLAGS) $(XBUILD_CFLAGS)
  247. # Don't change preprocessor and compiler flags from this point
  248. x15_NO_SYMTAB := .x15.no_symtab
  249. x15_SOURCES := $(x15_SOURCES-y)
  250. x15_OBJDEPS := $(call xbuild_replace_source_suffix,d,$(x15_SOURCES))
  251. x15_OBJECTS := $(call xbuild_replace_source_suffix,o,$(x15_SOURCES))
  252. x15_SYMTAB_C := .symtab.c
  253. x15_SYMTAB_D := $(call xbuild_replace_source_suffix,d,$(x15_SYMTAB_C))
  254. x15_SYMTAB_O := $(call xbuild_replace_source_suffix,o,$(x15_SYMTAB_C))
  255. x15_LDS := $(basename $(x15_LDS_S))
  256. x15_LDS_D := $(x15_LDS).d
  257. XBUILD_LDFLAGS += -Wl,--script=$(x15_LDS)
  258. define gen_sorted_init_ops
  259. $(call xbuild_action,GEN,$@) \
  260. $(SRCDIR)/tools/tsort_init_ops.sh "$(COMPILE)" "$@" $^
  261. endef
  262. .INTERMEDIATE: .x15.sorted_init_ops
  263. .x15.sorted_init_ops: $(filter %.c,$(x15_SOURCES)) include/generated/autoconf.h
  264. $(call gen_sorted_init_ops)
  265. # Adding the sorted initialization operations as a dependency allows checking
  266. # for loops at build time.
  267. x15_DEPS := $(x15_LDS) .x15.sorted_init_ops
  268. # Compiling produces dependency rules as a side-effect. When the dependency
  269. # rules file doesn't exist, the main source file is enough to trigger a
  270. # rebuild. Afterwards, the dependency rules file is included here and the
  271. # rules provide correct incremental compilation.
  272. -include $(x15_OBJDEPS) $(x15_LDS_D)
  273. %.o: %.c include/generated/autoconf.h
  274. $(xbuild_compile)
  275. %.o: %.S include/generated/autoconf.h
  276. $(xbuild_compile)
  277. %.lds: %.lds.S include/generated/autoconf.h
  278. $(xbuild_gen_linker_script)
  279. ifeq ($(CONFIG_SYMTAB),y)
  280. x15_FIRST_PASS := $(x15_NO_SYMTAB)
  281. else
  282. x15_FIRST_PASS := x15
  283. endif
  284. $(x15_FIRST_PASS): $(x15_OBJECTS) $(x15_DEPS)
  285. $(call xbuild_link,$(x15_OBJECTS))
  286. ifeq ($(CONFIG_SYMTAB),y)
  287. $(x15_SYMTAB_C): $(x15_FIRST_PASS) $(XBUILD_GEN_SYMTAB_DEPS)
  288. $(call xbuild_gen_symtab)
  289. x15: $(x15_NO_SYMTAB) $(x15_SYMTAB_O)
  290. $(call xbuild_link,$(x15_OBJECTS) $(x15_SYMTAB_O))
  291. endif
  292. .PHONY: install-x15
  293. install-x15:
  294. install -D -m 644 x15 $(DESTDIR)/boot/x15
  295. .PHONY: install-strip-x15
  296. install-strip-x15:
  297. install -s -D -m 644 x15 $(DESTDIR)/boot/x15
  298. .PHONY: install
  299. install: install-x15 install-docs
  300. .PHONY: install-strip
  301. install-strip: install-strip-x15 install-docs
  302. .PHONY: clean
  303. clean: clean-docs
  304. $(Q)$(MAKE) -f $(SRCDIR)/$(KCONFIG_PATH)/Makefile $@
  305. $(call xbuild_clean)
  306. .PHONY: distclean
  307. distclean: clean distclean-docs
  308. $(Q)$(MAKE) -f $(SRCDIR)/$(KCONFIG_PATH)/Makefile $@
  309. $(call xbuild_distclean)