Makefile 82 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528
  1. # SPDX-License-Identifier: GPL-2.0+
  2. VERSION = 2024
  3. PATCHLEVEL = 07
  4. SUBLEVEL =
  5. EXTRAVERSION = -rc4
  6. NAME =
  7. # *DOCUMENTATION*
  8. # To see a list of typical targets execute "make help"
  9. # More info can be located in ./README
  10. # Comments in this file are targeted only to the developer, do not
  11. # expect to learn how to build the kernel reading this file.
  12. # Do not use make's built-in rules and variables
  13. # (this increases performance and avoids hard-to-debug behaviour)
  14. MAKEFLAGS += -rR
  15. # Determine target architecture for the sandbox
  16. include include/host_arch.h
  17. ifeq ("", "$(CROSS_COMPILE)")
  18. MK_ARCH="${shell uname -m}"
  19. else
  20. MK_ARCH="${shell echo $(CROSS_COMPILE) | sed -n 's/^[[:space:]]*\([^\/]*\/\)*\([^-]*\)-[^[:space:]]*/\2/p'}"
  21. endif
  22. unexport HOST_ARCH
  23. ifeq ("x86_64", $(MK_ARCH))
  24. export HOST_ARCH=$(HOST_ARCH_X86_64)
  25. else ifneq (,$(findstring $(MK_ARCH), "i386" "i486" "i586" "i686"))
  26. export HOST_ARCH=$(HOST_ARCH_X86)
  27. else ifneq (,$(findstring $(MK_ARCH), "aarch64" "armv8l"))
  28. export HOST_ARCH=$(HOST_ARCH_AARCH64)
  29. else ifneq (,$(findstring $(MK_ARCH), "arm" "armv7" "armv7a" "armv7l"))
  30. export HOST_ARCH=$(HOST_ARCH_ARM)
  31. else ifeq ("riscv32", $(MK_ARCH))
  32. export HOST_ARCH=$(HOST_ARCH_RISCV32)
  33. else ifeq ("riscv64", $(MK_ARCH))
  34. export HOST_ARCH=$(HOST_ARCH_RISCV64)
  35. endif
  36. undefine MK_ARCH
  37. # Avoid funny character set dependencies
  38. unexport LC_ALL
  39. LC_COLLATE=C
  40. LC_NUMERIC=C
  41. export LC_COLLATE LC_NUMERIC
  42. # Avoid interference with shell env settings
  43. unexport GREP_OPTIONS
  44. # We are using a recursive build, so we need to do a little thinking
  45. # to get the ordering right.
  46. #
  47. # Most importantly: sub-Makefiles should only ever modify files in
  48. # their own directory. If in some directory we have a dependency on
  49. # a file in another dir (which doesn't happen often, but it's often
  50. # unavoidable when linking the built-in.o targets which finally
  51. # turn into vmlinux), we will call a sub make in that other dir, and
  52. # after that we are sure that everything which is in that other dir
  53. # is now up to date.
  54. #
  55. # The only cases where we need to modify files which have global
  56. # effects are thus separated out and done before the recursive
  57. # descending is started. They are now explicitly listed as the
  58. # prepare rule.
  59. # Beautify output
  60. # ---------------------------------------------------------------------------
  61. #
  62. # Normally, we echo the whole command before executing it. By making
  63. # that echo $($(quiet)$(cmd)), we now have the possibility to set
  64. # $(quiet) to choose other forms of output instead, e.g.
  65. #
  66. # quiet_cmd_cc_o_c = Compiling $(RELDIR)/$@
  67. # cmd_cc_o_c = $(CC) $(c_flags) -c -o $@ $<
  68. #
  69. # If $(quiet) is empty, the whole command will be printed.
  70. # If it is set to "quiet_", only the short version will be printed.
  71. # If it is set to "silent_", nothing will be printed at all, since
  72. # the variable $(silent_cmd_cc_o_c) doesn't exist.
  73. #
  74. # A simple variant is to prefix commands with $(Q) - that's useful
  75. # for commands that shall be hidden in non-verbose mode.
  76. #
  77. # $(Q)ln $@ :<
  78. #
  79. # If KBUILD_VERBOSE equals 0 then the above command will be hidden.
  80. # If KBUILD_VERBOSE equals 1 then the above command is displayed.
  81. #
  82. # To put more focus on warnings, be less verbose as default
  83. # Use 'make V=1' to see the full commands
  84. ifeq ("$(origin V)", "command line")
  85. KBUILD_VERBOSE = $(V)
  86. endif
  87. ifndef KBUILD_VERBOSE
  88. KBUILD_VERBOSE = 0
  89. endif
  90. ifeq ($(KBUILD_VERBOSE),1)
  91. quiet =
  92. Q =
  93. else
  94. quiet=quiet_
  95. Q = @
  96. endif
  97. # If the user is running make -s (silent mode), suppress echoing of
  98. # commands
  99. ifneq ($(filter 4.%,$(MAKE_VERSION)),) # make-4
  100. ifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),)
  101. quiet=silent_
  102. endif
  103. else # make-3.8x
  104. ifneq ($(filter s% -s%,$(MAKEFLAGS)),)
  105. quiet=silent_
  106. endif
  107. endif
  108. export quiet Q KBUILD_VERBOSE
  109. # kbuild supports saving output files in a separate directory.
  110. # To locate output files in a separate directory two syntaxes are supported.
  111. # In both cases the working directory must be the root of the kernel src.
  112. # 1) O=
  113. # Use "make O=dir/to/store/output/files/"
  114. #
  115. # 2) Set KBUILD_OUTPUT
  116. # Set the environment variable KBUILD_OUTPUT to point to the directory
  117. # where the output files shall be placed.
  118. # export KBUILD_OUTPUT=dir/to/store/output/files/
  119. # make
  120. #
  121. # The O= assignment takes precedence over the KBUILD_OUTPUT environment
  122. # variable.
  123. # KBUILD_SRC is set on invocation of make in OBJ directory
  124. # KBUILD_SRC is not intended to be used by the regular user (for now)
  125. ifeq ($(KBUILD_SRC),)
  126. # OK, Make called in directory where kernel src resides
  127. # Do we want to locate output files in a separate directory?
  128. ifeq ("$(origin O)", "command line")
  129. KBUILD_OUTPUT := $(O)
  130. endif
  131. # That's our default target when none is given on the command line
  132. PHONY := _all
  133. _all:
  134. # Cancel implicit rules on top Makefile
  135. $(CURDIR)/Makefile Makefile: ;
  136. ifneq ($(KBUILD_OUTPUT),)
  137. # Invoke a second make in the output directory, passing relevant variables
  138. # check that the output directory actually exists
  139. saved-output := $(KBUILD_OUTPUT)
  140. KBUILD_OUTPUT := $(shell mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) \
  141. && /bin/pwd)
  142. $(if $(KBUILD_OUTPUT),, \
  143. $(error failed to create output directory "$(saved-output)"))
  144. # Look for make include files relative to root of kernel src
  145. #
  146. # This does not become effective immediately because MAKEFLAGS is re-parsed
  147. # once after the Makefile is read. It is OK since we are going to invoke
  148. # 'sub-make' below.
  149. MAKEFLAGS += --include-dir=$(CURDIR)
  150. PHONY += $(MAKECMDGOALS) sub-make
  151. $(filter-out _all sub-make $(CURDIR)/Makefile, $(MAKECMDGOALS)) _all: sub-make
  152. @:
  153. sub-make: FORCE
  154. $(Q)$(MAKE) -C $(KBUILD_OUTPUT) KBUILD_SRC=$(CURDIR) \
  155. -f $(CURDIR)/Makefile $(filter-out _all sub-make,$(MAKECMDGOALS))
  156. # Leave processing to above invocation of make
  157. skip-makefile := 1
  158. endif # ifneq ($(KBUILD_OUTPUT),)
  159. endif # ifeq ($(KBUILD_SRC),)
  160. # We process the rest of the Makefile if this is the final invocation of make
  161. ifeq ($(skip-makefile),)
  162. # Do not print "Entering directory ...",
  163. # but we want to display it when entering to the output directory
  164. # so that IDEs/editors are able to understand relative filenames.
  165. MAKEFLAGS += --no-print-directory
  166. # Call a source code checker (by default, "sparse") as part of the
  167. # C compilation.
  168. #
  169. # Use 'make C=1' to enable checking of only re-compiled files.
  170. # Use 'make C=2' to enable checking of *all* source files, regardless
  171. # of whether they are re-compiled or not.
  172. #
  173. # See the file "doc/sparse.txt" for more details, including
  174. # where to get the "sparse" utility.
  175. ifeq ("$(origin C)", "command line")
  176. KBUILD_CHECKSRC = $(C)
  177. endif
  178. ifndef KBUILD_CHECKSRC
  179. KBUILD_CHECKSRC = 0
  180. endif
  181. # Use make M=dir to specify directory of external module to build
  182. # Old syntax make ... SUBDIRS=$PWD is still supported
  183. # Setting the environment variable KBUILD_EXTMOD take precedence
  184. ifdef SUBDIRS
  185. KBUILD_EXTMOD ?= $(SUBDIRS)
  186. endif
  187. ifeq ("$(origin M)", "command line")
  188. KBUILD_EXTMOD := $(M)
  189. endif
  190. # If building an external module we do not care about the all: rule
  191. # but instead _all depend on modules
  192. PHONY += all
  193. ifeq ($(KBUILD_EXTMOD),)
  194. _all: all
  195. else
  196. _all: modules
  197. endif
  198. ifeq ($(KBUILD_SRC),)
  199. # building in the source tree
  200. srctree := .
  201. else
  202. ifeq ($(KBUILD_SRC)/,$(dir $(CURDIR)))
  203. # building in a subdirectory of the source tree
  204. srctree := ..
  205. else
  206. srctree := $(KBUILD_SRC)
  207. endif
  208. endif
  209. objtree := .
  210. src := $(srctree)
  211. obj := $(objtree)
  212. VPATH := $(srctree)$(if $(KBUILD_EXTMOD),:$(KBUILD_EXTMOD))
  213. export srctree objtree VPATH
  214. # Make sure CDPATH settings don't interfere
  215. unexport CDPATH
  216. #########################################################################
  217. HOSTARCH := $(shell uname -m | \
  218. sed -e s/i.86/x86/ \
  219. -e s/sun4u/sparc64/ \
  220. -e s/arm.*/arm/ \
  221. -e s/sa110/arm/ \
  222. -e s/ppc64/powerpc/ \
  223. -e s/ppc/powerpc/ \
  224. -e s/macppc/powerpc/\
  225. -e s/sh.*/sh/)
  226. HOSTOS := $(shell uname -s | tr '[:upper:]' '[:lower:]' | \
  227. sed -e 's/\(cygwin\).*/cygwin/')
  228. export HOSTARCH HOSTOS
  229. #########################################################################
  230. # set default to nothing for native builds
  231. ifeq ($(HOSTARCH),$(ARCH))
  232. CROSS_COMPILE ?=
  233. endif
  234. KCONFIG_CONFIG ?= .config
  235. export KCONFIG_CONFIG
  236. # SHELL used by kbuild
  237. CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
  238. else if [ -x /bin/bash ]; then echo /bin/bash; \
  239. else echo sh; fi ; fi)
  240. HOST_LFS_CFLAGS := $(shell getconf LFS_CFLAGS 2>/dev/null)
  241. HOST_LFS_LDFLAGS := $(shell getconf LFS_LDFLAGS 2>/dev/null)
  242. HOST_LFS_LIBS := $(shell getconf LFS_LIBS 2>/dev/null)
  243. HOSTCC = cc
  244. HOSTCXX = c++
  245. KBUILD_HOSTCFLAGS := -Wall -Wstrict-prototypes -O2 -fomit-frame-pointer \
  246. $(HOST_LFS_CFLAGS) $(HOSTCFLAGS)
  247. KBUILD_HOSTCXXFLAGS := -O2 $(HOST_LFS_CFLAGS) $(HOSTCXXFLAGS)
  248. KBUILD_HOSTLDFLAGS := $(HOST_LFS_LDFLAGS) $(HOSTLDFLAGS)
  249. KBUILD_HOSTLDLIBS := $(HOST_LFS_LIBS) $(HOSTLDLIBS)
  250. # With the move to GCC 6, we have implicitly upgraded our language
  251. # standard to GNU11 (see https://gcc.gnu.org/gcc-5/porting_to.html).
  252. # Some Linux distributions (including RHEL7, SLES13, Debian 8) still
  253. # have older compilers as their default, so we make it explicit for
  254. # these that our host tools are GNU11 (i.e. C11 w/ GNU extensions).
  255. CSTD_FLAG := -std=gnu11
  256. KBUILD_HOSTCFLAGS += $(CSTD_FLAG)
  257. ifeq ($(HOSTOS),cygwin)
  258. KBUILD_HOSTCFLAGS += -ansi
  259. endif
  260. # Mac OS X / Darwin's C preprocessor is Apple specific. It
  261. # generates numerous errors and warnings. We want to bypass it
  262. # and use GNU C's cpp. To do this we pass the -traditional-cpp
  263. # option to the compiler. Note that the -traditional-cpp flag
  264. # DOES NOT have the same semantics as GNU C's flag, all it does
  265. # is invoke the GNU preprocessor in stock ANSI/ISO C fashion.
  266. #
  267. # Apple's linker is similar, thanks to the new 2 stage linking
  268. # multiple symbol definitions are treated as errors, hence the
  269. # -multiply_defined suppress option to turn off this error.
  270. #
  271. ifeq ($(HOSTOS),darwin)
  272. # get major and minor product version (e.g. '10' and '6' for Snow Leopard)
  273. DARWIN_MAJOR_VERSION := $(shell sw_vers -productVersion | cut -f 1 -d '.')
  274. DARWIN_MINOR_VERSION := $(shell sw_vers -productVersion | cut -f 2 -d '.')
  275. os_x_before = $(shell if [ $(DARWIN_MAJOR_VERSION) -le $(1) -a \
  276. $(DARWIN_MINOR_VERSION) -le $(2) ] ; then echo "$(3)"; else echo "$(4)"; fi ;)
  277. os_x_after = $(shell if [ $(DARWIN_MAJOR_VERSION) -ge $(1) -a \
  278. $(DARWIN_MINOR_VERSION) -ge $(2) ] ; then echo "$(3)"; else echo "$(4)"; fi ;)
  279. # Snow Leopards build environment has no longer restrictions as described above
  280. HOSTCC = $(call os_x_before, 10, 5, "cc", "gcc")
  281. KBUILD_HOSTCFLAGS += $(call os_x_before, 10, 4, "-traditional-cpp")
  282. KBUILD_HOSTLDFLAGS += $(call os_x_before, 10, 5, "-multiply_defined suppress")
  283. # macOS Mojave (10.14.X)
  284. # Undefined symbols for architecture x86_64: "_PyArg_ParseTuple"
  285. KBUILD_HOSTLDFLAGS += $(call os_x_after, 10, 14, "-lpython -dynamclib", "")
  286. endif
  287. # Decide whether to build built-in, modular, or both.
  288. # Normally, just do built-in.
  289. KBUILD_MODULES :=
  290. KBUILD_BUILTIN := 1
  291. # If we have only "make modules", don't compile built-in objects.
  292. # When we're building modules with modversions, we need to consider
  293. # the built-in objects during the descend as well, in order to
  294. # make sure the checksums are up to date before we record them.
  295. ifeq ($(MAKECMDGOALS),modules)
  296. KBUILD_BUILTIN := $(if $(CONFIG_MODVERSIONS),1)
  297. endif
  298. # If we have "make <whatever> modules", compile modules
  299. # in addition to whatever we do anyway.
  300. # Just "make" or "make all" shall build modules as well
  301. # U-Boot does not need modules
  302. #ifneq ($(filter all _all modules,$(MAKECMDGOALS)),)
  303. # KBUILD_MODULES := 1
  304. #endif
  305. #ifeq ($(MAKECMDGOALS),)
  306. # KBUILD_MODULES := 1
  307. #endif
  308. # Check ths size of a binary:
  309. # Args:
  310. # $1: File to check
  311. # #2: Size limit in bytes (decimal or 0xhex)
  312. define size_check
  313. actual=$$( wc -c $1 | awk '{print $$1}'); \
  314. limit=$$( printf "%d" $2 ); \
  315. if test $$actual -gt $$limit; then \
  316. echo "$1 exceeds file size limit:" >&2; \
  317. echo " limit: $$(printf %#x $$limit) bytes" >&2; \
  318. echo " actual: $$(printf %#x $$actual) bytes" >&2; \
  319. echo " excess: $$(printf %#x $$((actual - limit))) bytes" >&2;\
  320. exit 1; \
  321. fi
  322. endef
  323. export size_check
  324. export KBUILD_MODULES KBUILD_BUILTIN
  325. export KBUILD_CHECKSRC KBUILD_SRC KBUILD_EXTMOD
  326. # We need some generic definitions (do not try to remake the file).
  327. scripts/Kbuild.include: ;
  328. include scripts/Kbuild.include
  329. # Make variables (CC, etc...)
  330. AS = $(CROSS_COMPILE)as
  331. # Always use GNU ld
  332. ifneq ($(shell $(CROSS_COMPILE)ld.bfd -v 2> /dev/null),)
  333. LD = $(CROSS_COMPILE)ld.bfd
  334. else
  335. LD = $(CROSS_COMPILE)ld
  336. endif
  337. CC = $(CROSS_COMPILE)gcc
  338. CPP = $(CC) -E
  339. AR = $(CROSS_COMPILE)ar
  340. NM = $(CROSS_COMPILE)nm
  341. LDR = $(CROSS_COMPILE)ldr
  342. STRIP = $(CROSS_COMPILE)strip
  343. OBJCOPY = $(CROSS_COMPILE)objcopy
  344. OBJDUMP = $(CROSS_COMPILE)objdump
  345. LEX = flex
  346. YACC = bison
  347. AWK = awk
  348. PERL = perl
  349. PYTHON ?= python
  350. PYTHON2 = python2
  351. PYTHON3 ?= python3
  352. # The devicetree compiler and pylibfdt are automatically built unless DTC is
  353. # provided. If DTC is provided, it is assumed the pylibfdt is available too.
  354. DTC_INTREE := $(objtree)/scripts/dtc/dtc
  355. DTC ?= $(DTC_INTREE)
  356. DTC_MIN_VERSION := 010406
  357. CHECK = sparse
  358. CHECKFLAGS := -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ \
  359. -Wbitwise -Wno-return-void -Wno-unknown-attribute \
  360. -D__CHECK_ENDIAN__ $(CF)
  361. KBUILD_CPPFLAGS := -D__KERNEL__ -D__UBOOT__
  362. KBUILD_CFLAGS := -Wall -Wstrict-prototypes \
  363. -Wno-format-security \
  364. -fno-builtin -ffreestanding $(CSTD_FLAG)
  365. KBUILD_CFLAGS += -fshort-wchar -fno-strict-aliasing
  366. KBUILD_AFLAGS := -D__ASSEMBLY__
  367. KBUILD_LDFLAGS :=
  368. ifeq ($(cc-name),clang)
  369. ifneq ($(CROSS_COMPILE),)
  370. CLANG_TARGET := --target=$(notdir $(CROSS_COMPILE:%-=%))
  371. LDPPFLAGS += $(CLANG_TARGET)
  372. GCC_TOOLCHAIN_DIR := $(dir $(shell which $(LD)))
  373. CLANG_PREFIX := --prefix=$(GCC_TOOLCHAIN_DIR)
  374. GCC_TOOLCHAIN := $(realpath $(GCC_TOOLCHAIN_DIR)/..)
  375. endif
  376. ifneq ($(GCC_TOOLCHAIN),)
  377. CLANG_GCC_TC := --gcc-toolchain=$(GCC_TOOLCHAIN)
  378. endif
  379. KBUILD_CFLAGS += $(CLANG_TARGET) $(CLANG_GCC_TC) $(CLANG_PREFIX)
  380. KBUILD_AFLAGS += $(CLANG_TARGET) $(CLANG_GCC_TC) $(CLANG_PREFIX)
  381. KBUILD_CFLAGS += $(call cc-option, -no-integrated-as)
  382. KBUILD_AFLAGS += $(call cc-option, -no-integrated-as)
  383. endif
  384. # Don't generate position independent code
  385. KBUILD_CFLAGS += $(call cc-option,-fno-PIE)
  386. KBUILD_AFLAGS += $(call cc-option,-fno-PIE)
  387. # Read UBOOTRELEASE from include/config/uboot.release (if it exists)
  388. UBOOTRELEASE = $(shell cat include/config/uboot.release 2> /dev/null)
  389. UBOOTVERSION = $(VERSION)$(if $(PATCHLEVEL),.$(PATCHLEVEL)$(if $(SUBLEVEL),.$(SUBLEVEL)))$(EXTRAVERSION)
  390. export VERSION PATCHLEVEL SUBLEVEL UBOOTRELEASE UBOOTVERSION
  391. export ARCH CPU BOARD VENDOR SOC CPUDIR BOARDDIR
  392. export CONFIG_SHELL HOSTCC KBUILD_HOSTCFLAGS CROSS_COMPILE AS LD CC
  393. export CPP AR NM LDR STRIP OBJCOPY OBJDUMP KBUILD_HOSTLDFLAGS KBUILD_HOSTLDLIBS
  394. export MAKE LEX YACC AWK PERL PYTHON PYTHON2 PYTHON3
  395. export HOSTCXX KBUILD_HOSTCXXFLAGS CHECK CHECKFLAGS DTC DTC_FLAGS
  396. export KBUILD_CPPFLAGS NOSTDINC_FLAGS UBOOTINCLUDE OBJCOPYFLAGS KBUILD_LDFLAGS
  397. export KBUILD_CFLAGS KBUILD_AFLAGS
  398. export CC_VERSION_TEXT := $(shell $(CC) --version | head -n 1)
  399. # When compiling out-of-tree modules, put MODVERDIR in the module
  400. # tree rather than in the kernel tree. The kernel tree might
  401. # even be read-only.
  402. export MODVERDIR := $(if $(KBUILD_EXTMOD),$(firstword $(KBUILD_EXTMOD))/).tmp_versions
  403. # Files to ignore in find ... statements
  404. export RCS_FIND_IGNORE := \( -name SCCS -o -name BitKeeper -o -name .svn -o \
  405. -name CVS -o -name .pc -o -name .hg -o -name .git \) \
  406. -prune -o
  407. export RCS_TAR_IGNORE := --exclude SCCS --exclude BitKeeper --exclude .svn \
  408. --exclude CVS --exclude .pc --exclude .hg --exclude .git
  409. export PYTHON_ENABLE
  410. # This is y if U-Boot should not build any Python tools or libraries. Typically
  411. # you would need to set this if those tools/libraries (typically binman and
  412. # pylibfdt) cannot be built by your environment and are provided separately.
  413. ifeq ($(NO_PYTHON),)
  414. PYTHON_ENABLE=y
  415. endif
  416. # ===========================================================================
  417. # Rules shared between *config targets and build targets
  418. # Basic helpers built in scripts/
  419. PHONY += scripts_basic
  420. scripts_basic:
  421. $(Q)$(MAKE) $(build)=scripts/basic
  422. $(Q)rm -f .tmp_quiet_recordmcount
  423. # To avoid any implicit rule to kick in, define an empty command.
  424. scripts/basic/%: scripts_basic ;
  425. PHONY += outputmakefile
  426. # outputmakefile generates a Makefile in the output directory, if using a
  427. # separate output directory. This allows convenient use of make in the
  428. # output directory.
  429. outputmakefile:
  430. ifneq ($(KBUILD_SRC),)
  431. $(Q)ln -fsn $(srctree) source
  432. $(Q)$(CONFIG_SHELL) $(srctree)/scripts/mkmakefile $(srctree)
  433. endif
  434. # To make sure we do not include .config for any of the *config targets
  435. # catch them early, and hand them over to scripts/kconfig/Makefile
  436. # It is allowed to specify more targets when calling make, including
  437. # mixing *config targets and build targets.
  438. # For example 'make oldconfig all'.
  439. # Detect when mixed targets is specified, and make a second invocation
  440. # of make so .config is not included in this case either (for *config).
  441. version_h := include/generated/version_autogenerated.h
  442. timestamp_h := include/generated/timestamp_autogenerated.h
  443. defaultenv_h := include/generated/defaultenv_autogenerated.h
  444. dt_h := include/generated/dt.h
  445. env_h := include/generated/environment.h
  446. no-dot-config-targets := clean clobber mrproper distclean \
  447. help %docs check% coccicheck \
  448. ubootversion backup tests check pcheck qcheck tcheck \
  449. pylint pylint_err _pip pip pip_test pip_release
  450. config-targets := 0
  451. mixed-targets := 0
  452. dot-config := 1
  453. ifneq ($(filter $(no-dot-config-targets), $(MAKECMDGOALS)),)
  454. ifeq ($(filter-out $(no-dot-config-targets), $(MAKECMDGOALS)),)
  455. dot-config := 0
  456. endif
  457. endif
  458. ifeq ($(KBUILD_EXTMOD),)
  459. ifneq ($(filter config %config,$(MAKECMDGOALS)),)
  460. config-targets := 1
  461. ifneq ($(words $(MAKECMDGOALS)),1)
  462. mixed-targets := 1
  463. endif
  464. endif
  465. endif
  466. ifeq ($(mixed-targets),1)
  467. # ===========================================================================
  468. # We're called with mixed targets (*config and build targets).
  469. # Handle them one by one.
  470. PHONY += $(MAKECMDGOALS) __build_one_by_one
  471. $(filter-out __build_one_by_one, $(MAKECMDGOALS)): __build_one_by_one
  472. @:
  473. __build_one_by_one:
  474. $(Q)set -e; \
  475. for i in $(MAKECMDGOALS); do \
  476. $(MAKE) -f $(srctree)/Makefile $$i; \
  477. done
  478. else
  479. ifeq ($(config-targets),1)
  480. # ===========================================================================
  481. # *config targets only - make sure prerequisites are updated, and descend
  482. # in scripts/kconfig to make the *config target
  483. KBUILD_DEFCONFIG := sandbox_defconfig
  484. export KBUILD_DEFCONFIG KBUILD_KCONFIG
  485. config: scripts_basic outputmakefile FORCE
  486. $(Q)$(MAKE) $(build)=scripts/kconfig $@
  487. %config: scripts_basic outputmakefile FORCE
  488. $(Q)$(MAKE) $(build)=scripts/kconfig $@
  489. else
  490. # ===========================================================================
  491. # Build targets only - this includes vmlinux, arch specific targets, clean
  492. # targets and others. In general all targets except *config targets.
  493. # Additional helpers built in scripts/
  494. # Carefully list dependencies so we do not try to build scripts twice
  495. # in parallel
  496. PHONY += scripts
  497. scripts: scripts_basic scripts_dtc include/config/auto.conf
  498. $(Q)$(MAKE) $(build)=$(@)
  499. ifeq ($(dot-config),1)
  500. # Read in config
  501. -include include/config/auto.conf
  502. # Read in dependencies to all Kconfig* files, make sure to run
  503. # oldconfig if changes are detected.
  504. -include include/config/auto.conf.cmd
  505. # To avoid any implicit rule to kick in, define an empty command
  506. $(KCONFIG_CONFIG) include/config/auto.conf.cmd: ;
  507. # If .config is newer than include/config/auto.conf, someone tinkered
  508. # with it and forgot to run make oldconfig.
  509. # if auto.conf.cmd is missing then we are probably in a cleaned tree so
  510. # we execute the config step to be sure to catch updated Kconfig files
  511. include/config/%.conf: $(KCONFIG_CONFIG) include/config/auto.conf.cmd
  512. $(Q)$(MAKE) -f $(srctree)/Makefile syncconfig
  513. @# If the following part fails, include/config/auto.conf should be
  514. @# deleted so "make silentoldconfig" will be re-run on the next build.
  515. $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.autoconf || \
  516. { rm -f include/config/auto.conf; false; }
  517. @# include/config.h has been updated after "make silentoldconfig".
  518. @# We need to touch include/config/auto.conf so it gets newer
  519. @# than include/config.h.
  520. @# Otherwise, 'make silentoldconfig' would be invoked twice.
  521. $(Q)touch include/config/auto.conf
  522. u-boot.cfg spl/u-boot.cfg tpl/u-boot.cfg:
  523. $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.autoconf $(@)
  524. -include include/autoconf.mk
  525. -include include/autoconf.mk.dep
  526. # We want to include arch/$(ARCH)/config.mk only when include/config/auto.conf
  527. # is up-to-date. When we switch to a different board configuration, old CONFIG
  528. # macros are still remaining in include/config/auto.conf. Without the following
  529. # gimmick, wrong config.mk would be included leading nasty warnings/errors.
  530. ifneq ($(wildcard $(KCONFIG_CONFIG)),)
  531. ifneq ($(wildcard include/config/auto.conf),)
  532. autoconf_is_old := $(shell find . -path ./$(KCONFIG_CONFIG) -newer \
  533. include/config/auto.conf)
  534. ifeq ($(autoconf_is_old),)
  535. include config.mk
  536. include arch/$(ARCH)/Makefile
  537. endif
  538. endif
  539. endif
  540. # These are set by the arch-specific config.mk. Make sure they are exported
  541. # so they can be used when building an EFI application.
  542. export EFI_LDS # Filename of EFI link script in arch/$(ARCH)/lib
  543. export EFI_CRT0 # Filename of EFI CRT0 in arch/$(ARCH)/lib
  544. export EFI_RELOC # Filename of EFU relocation code in arch/$(ARCH)/lib
  545. export CFLAGS_EFI # Compiler flags to add when building EFI app
  546. export CFLAGS_NON_EFI # Compiler flags to remove when building EFI app
  547. export EFI_TARGET # binutils target if EFI is natively supported
  548. export LTO_ENABLE
  549. # This is y if LTO is enabled for this build. See NO_LTO=1 to disable LTO
  550. ifeq ($(NO_LTO),)
  551. LTO_ENABLE=$(if $(CONFIG_LTO),y)
  552. endif
  553. # If board code explicitly specified LDSCRIPT or CONFIG_SYS_LDSCRIPT, use
  554. # that (or fail if absent). Otherwise, search for a linker script in a
  555. # standard location.
  556. ifndef LDSCRIPT
  557. #LDSCRIPT := $(srctree)/board/$(BOARDDIR)/u-boot.lds.debug
  558. ifdef CONFIG_SYS_LDSCRIPT
  559. # need to strip off double quotes
  560. LDSCRIPT := $(srctree)/$(CONFIG_SYS_LDSCRIPT:"%"=%)
  561. endif
  562. endif
  563. # If there is no specified link script, we look in a number of places for it
  564. ifndef LDSCRIPT
  565. ifeq ($(wildcard $(LDSCRIPT)),)
  566. LDSCRIPT := $(srctree)/board/$(BOARDDIR)/u-boot.lds
  567. endif
  568. ifeq ($(wildcard $(LDSCRIPT)),)
  569. LDSCRIPT := $(srctree)/$(CPUDIR)/u-boot.lds
  570. endif
  571. ifeq ($(wildcard $(LDSCRIPT)),)
  572. LDSCRIPT := $(srctree)/arch/$(ARCH)/cpu/u-boot.lds
  573. endif
  574. endif
  575. else
  576. # Dummy target needed, because used as prerequisite
  577. include/config/auto.conf: ;
  578. endif # $(dot-config)
  579. ifdef CONFIG_CC_OPTIMIZE_FOR_DEBUG
  580. KBUILD_HOSTCFLAGS := -Wall -Wstrict-prototypes -Og -g -fomit-frame-pointer \
  581. $(HOST_LFS_CFLAGS) $(HOSTCFLAGS)
  582. # Avoid false positives -Wmaybe-uninitialized
  583. # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=78394
  584. KBUILD_HOSTCFLAGS += -Wno-maybe-uninitialized
  585. KBUILD_HOSTCXXFLAGS := -Og -g $(HOST_LFS_CFLAGS) $(HOSTCXXFLAGS)
  586. endif
  587. #
  588. # Xtensa linker script cannot be preprocessed with -ansi because of
  589. # preprocessor operations on strings that don't make C identifiers.
  590. #
  591. ifeq ($(CONFIG_XTENSA),)
  592. LDPPFLAGS += -ansi
  593. endif
  594. ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
  595. KBUILD_CFLAGS += -Os
  596. endif
  597. ifdef CONFIG_CC_OPTIMIZE_FOR_SPEED
  598. KBUILD_CFLAGS += -O2
  599. endif
  600. ifdef CONFIG_CC_OPTIMIZE_FOR_DEBUG
  601. KBUILD_CFLAGS += -Og
  602. # Avoid false positives -Wmaybe-uninitialized
  603. # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=78394
  604. KBUILD_CFLAGS += -Wno-maybe-uninitialized
  605. endif
  606. LTO_CFLAGS :=
  607. LTO_FINAL_LDFLAGS :=
  608. export LTO_CFLAGS LTO_FINAL_LDFLAGS
  609. ifeq ($(LTO_ENABLE),y)
  610. ifeq ($(cc-name),clang)
  611. LTO_CFLAGS += -DLTO_ENABLE -flto
  612. LTO_FINAL_LDFLAGS += -flto
  613. AR = $(shell $(CC) -print-prog-name=llvm-ar)
  614. NM = $(shell $(CC) -print-prog-name=llvm-nm)
  615. else
  616. NPROC := $(shell nproc 2>/dev/null || echo 1)
  617. LTO_CFLAGS += -DLTO_ENABLE -flto=$(NPROC)
  618. LTO_FINAL_LDFLAGS += -fuse-linker-plugin -flto=$(NPROC)
  619. # use plugin aware tools
  620. AR = $(CROSS_COMPILE)gcc-ar
  621. NM = $(CROSS_COMPILE)gcc-nm
  622. endif
  623. CFLAGS_NON_EFI += $(LTO_CFLAGS)
  624. KBUILD_CFLAGS += $(LTO_CFLAGS)
  625. endif
  626. ifeq ($(CONFIG_STACKPROTECTOR),y)
  627. KBUILD_CFLAGS += $(call cc-option,-fstack-protector-strong)
  628. KBUILD_CFLAGS += $(call cc-option,-mstack-protector-guard=global)
  629. CFLAGS_EFI += $(call cc-option,-fno-stack-protector)
  630. else
  631. KBUILD_CFLAGS += $(call cc-option,-fno-stack-protector)
  632. endif
  633. KBUILD_CFLAGS += $(call cc-option,-fno-delete-null-pointer-checks)
  634. # disable pointer signed / unsigned warnings in gcc 4.0
  635. KBUILD_CFLAGS += -Wno-pointer-sign
  636. # disable stringop warnings in gcc 8+
  637. KBUILD_CFLAGS += $(call cc-disable-warning, stringop-truncation)
  638. KBUILD_CFLAGS += $(call cc-disable-warning, zero-length-bounds)
  639. KBUILD_CFLAGS += $(call cc-disable-warning, array-bounds)
  640. KBUILD_CFLAGS += $(call cc-disable-warning, stringop-overflow)
  641. # Enabled with W=2, disabled by default as noisy
  642. KBUILD_CFLAGS += $(call cc-disable-warning, maybe-uninitialized)
  643. # change __FILE__ to the relative path from the srctree
  644. KBUILD_CFLAGS += $(call cc-option,-fmacro-prefix-map=$(srctree)/=)
  645. KBUILD_CFLAGS += -gdwarf-4
  646. # $(KBUILD_AFLAGS) sets -g, which causes gcc to pass a suitable -g<format>
  647. # option to the assembler.
  648. KBUILD_AFLAGS += -gdwarf-4
  649. # Report stack usage if supported
  650. # ARC tools based on GCC 7.1 has an issue with stack usage
  651. # with naked functions, see commit message for more details
  652. ifndef CONFIG_ARC
  653. ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-stack-usage.sh $(CC)),y)
  654. KBUILD_CFLAGS += -fstack-usage
  655. endif
  656. endif
  657. KBUILD_CFLAGS += $(call cc-option,-Wno-format-nonliteral)
  658. KBUILD_CFLAGS += $(call cc-disable-warning, address-of-packed-member)
  659. ifdef CONFIG_CC_IS_CLANG
  660. KBUILD_CPPFLAGS += $(call cc-option,-Qunused-arguments,)
  661. KBUILD_CFLAGS += $(call cc-disable-warning, format-invalid-specifier)
  662. KBUILD_CFLAGS += $(call cc-disable-warning, gnu)
  663. KBUILD_CFLAGS += $(call cc-disable-warning, address-of-packed-member)
  664. # Quiet clang warning: comparison of unsigned expression < 0 is always false
  665. KBUILD_CFLAGS += $(call cc-disable-warning, tautological-compare)
  666. # CLANG uses a _MergedGlobals as optimization, but this breaks modpost, as the
  667. # source of a reference will be _MergedGlobals and not on of the whitelisted names.
  668. # See modpost pattern 2
  669. KBUILD_CFLAGS += $(call cc-option, -mno-global-merge,)
  670. KBUILD_CFLAGS += $(call cc-option, -fcatch-undefined-behavior)
  671. KBUILD_CFLAGS += $(call cc-disable-warning, deprecated-non-prototype)
  672. endif
  673. # These warnings generated too much noise in a regular build.
  674. # Use make W=1 to enable them (see scripts/Makefile.extrawarn)
  675. KBUILD_CFLAGS += $(call cc-disable-warning, unused-but-set-variable)
  676. # Prohibit date/time macros, which would make the build non-deterministic
  677. KBUILD_CFLAGS += $(call cc-option,-Werror=date-time)
  678. include scripts/Makefile.extrawarn
  679. # Add user supplied CPPFLAGS, AFLAGS and CFLAGS as the last assignments
  680. KBUILD_CPPFLAGS += $(KCPPFLAGS)
  681. KBUILD_AFLAGS += $(KAFLAGS)
  682. KBUILD_CFLAGS += $(KCFLAGS)
  683. KBUILD_LDFLAGS += -z noexecstack
  684. KBUILD_LDFLAGS += $(call ld-option,--no-warn-rwx-segments)
  685. KBUILD_HOSTCFLAGS += $(if $(CONFIG_TOOLS_DEBUG),-g)
  686. # Use UBOOTINCLUDE when you must reference the include/ directory.
  687. # Needed to be compatible with the O= option
  688. UBOOTINCLUDE := \
  689. -Iinclude \
  690. $(if $(KBUILD_SRC), -I$(srctree)/include) \
  691. $(if $(CONFIG_$(SPL_)SYS_THUMB_BUILD), \
  692. $(if $(CONFIG_HAS_THUMB2), \
  693. $(if $(CONFIG_CPU_V7M), \
  694. -I$(srctree)/arch/arm/thumb1/include), \
  695. -I$(srctree)/arch/arm/thumb1/include)) \
  696. -I$(srctree)/arch/$(ARCH)/include \
  697. -include $(srctree)/include/linux/kconfig.h \
  698. -I$(srctree)/dts/upstream/include
  699. NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
  700. # FIX ME
  701. cpp_flags := $(KBUILD_CPPFLAGS) $(PLATFORM_CPPFLAGS) $(UBOOTINCLUDE) \
  702. $(NOSTDINC_FLAGS)
  703. c_flags := $(KBUILD_CFLAGS) $(cpp_flags)
  704. #########################################################################
  705. # U-Boot objects....order is important (i.e. start must be first)
  706. HAVE_VENDOR_COMMON_LIB = $(if $(wildcard $(srctree)/board/$(VENDOR)/common/Makefile),y,n)
  707. libs-$(CONFIG_API) += api/
  708. libs-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/
  709. libs-y += boot/
  710. libs-$(CONFIG_CMDLINE) += cmd/
  711. libs-y += common/
  712. libs-$(CONFIG_OF_EMBED) += dts/
  713. libs-y += env/
  714. libs-y += lib/
  715. libs-y += fs/
  716. libs-y += net/
  717. libs-y += disk/
  718. libs-y += drivers/
  719. libs-$(CONFIG_SYS_FSL_DDR) += drivers/ddr/fsl/
  720. libs-$(CONFIG_SYS_FSL_MMDC) += drivers/ddr/fsl/
  721. libs-$(CONFIG_$(SPL_)ALTERA_SDRAM) += drivers/ddr/altera/
  722. libs-y += drivers/usb/cdns3/
  723. libs-y += drivers/usb/dwc3/
  724. libs-y += drivers/usb/common/
  725. libs-y += drivers/usb/emul/
  726. libs-y += drivers/usb/eth/
  727. libs-$(CONFIG_USB_DEVICE) += drivers/usb/gadget/
  728. libs-$(CONFIG_USB_GADGET) += drivers/usb/gadget/
  729. libs-$(CONFIG_USB_GADGET) += drivers/usb/gadget/udc/
  730. libs-y += drivers/usb/host/
  731. libs-y += drivers/usb/mtu3/
  732. libs-y += drivers/usb/musb/
  733. libs-y += drivers/usb/musb-new/
  734. libs-y += drivers/usb/isp1760/
  735. libs-y += drivers/usb/phy/
  736. libs-y += drivers/usb/ulpi/
  737. ifdef CONFIG_POST
  738. libs-y += post/
  739. endif
  740. libs-$(CONFIG_$(SPL_TPL_)UNIT_TEST) += test/
  741. libs-$(CONFIG_UT_ENV) += test/env/
  742. libs-$(CONFIG_UT_OPTEE) += test/optee/
  743. libs-$(CONFIG_UT_OVERLAY) += test/overlay/
  744. libs-y += $(if $(wildcard $(srctree)/board/$(BOARDDIR)/Makefile),board/$(BOARDDIR)/)
  745. libs-y := $(sort $(libs-y))
  746. u-boot-dirs := $(patsubst %/,%,$(filter %/, $(libs-y))) tools examples
  747. u-boot-alldirs := $(sort $(u-boot-dirs) $(patsubst %/,%,$(filter %/, $(libs-))))
  748. libs-y := $(patsubst %/, %/built-in.o, $(libs-y))
  749. u-boot-init := $(head-y)
  750. u-boot-main := $(libs-y)
  751. # Add GCC lib
  752. ifeq ($(CONFIG_USE_PRIVATE_LIBGCC),y)
  753. PLATFORM_LIBGCC = arch/$(ARCH)/lib/lib.a
  754. else
  755. ifndef CONFIG_CC_IS_CLANG
  756. PLATFORM_LIBGCC := -L $(shell dirname `$(CC) $(c_flags) -print-libgcc-file-name`) -lgcc
  757. endif
  758. endif
  759. PLATFORM_LIBS += $(PLATFORM_LIBGCC)
  760. ifdef CONFIG_CC_COVERAGE
  761. KBUILD_CFLAGS += --coverage
  762. PLATFORM_LIBGCC += -lgcov
  763. endif
  764. export PLATFORM_LIBS
  765. export PLATFORM_LIBGCC
  766. # Special flags for CPP when processing the linker script.
  767. # Pass the version down so we can handle backwards compatibility
  768. # on the fly.
  769. LDPPFLAGS += \
  770. -include $(srctree)/include/u-boot/u-boot.lds.h \
  771. -DCPUDIR=$(CPUDIR) \
  772. $(shell $(LD) --version | \
  773. sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p')
  774. #########################################################################
  775. #########################################################################
  776. ifneq ($(CONFIG_BOARD_SIZE_LIMIT),)
  777. BOARD_SIZE_CHECK= @ $(call size_check,$@,$(CONFIG_BOARD_SIZE_LIMIT))
  778. else
  779. BOARD_SIZE_CHECK =
  780. endif
  781. ifneq ($(CONFIG_SPL_SIZE_LIMIT),0x0)
  782. SPL_SIZE_CHECK = @$(call size_check,$@,$$(tools/spl_size_limit))
  783. else
  784. SPL_SIZE_CHECK =
  785. endif
  786. ifneq ($(CONFIG_TPL_SIZE_LIMIT),0x0)
  787. TPL_SIZE_CHECK = @$(call size_check,$@,$(CONFIG_TPL_SIZE_LIMIT))
  788. else
  789. TPL_SIZE_CHECK =
  790. endif
  791. ifneq ($(CONFIG_VPL_SIZE_LIMIT),0x0)
  792. VPL_SIZE_CHECK = @$(call size_check,$@,$(CONFIG_VPL_SIZE_LIMIT))
  793. else
  794. VPL_SIZE_CHECK =
  795. endif
  796. # Statically apply RELA-style relocations (currently arm64 only)
  797. # This is useful for arm64 where static relocation needs to be performed on
  798. # the raw binary, but certain simulators only accept an ELF file (but don't
  799. # do the relocation).
  800. ifneq ($(CONFIG_STATIC_RELA),)
  801. # $(2) is u-boot ELF, $(3) is u-boot bin, $(4) is text base
  802. quiet_cmd_static_rela = RELOC $@
  803. cmd_static_rela = \
  804. tools/relocate-rela $(3) $(2)
  805. else
  806. quiet_cmd_static_rela =
  807. cmd_static_rela =
  808. endif
  809. # Always append INPUTS so that arch config.mk's can add custom ones
  810. INPUTS-y += u-boot.srec u-boot.bin u-boot.sym System.map binary_size_check
  811. ifeq ($(CONFIG_SPL_FSL_PBL),y)
  812. INPUTS-$(CONFIG_RAMBOOT_PBL) += u-boot-with-spl-pbl.bin
  813. else
  814. ifneq ($(CONFIG_NXP_ESBC), y)
  815. # For Secure Boot The Image needs to be signed and Header must also
  816. # be included. So The image has to be built explicitly
  817. INPUTS-$(CONFIG_RAMBOOT_PBL) += u-boot.pbl
  818. endif
  819. endif
  820. INPUTS-$(CONFIG_SPL) += spl/u-boot-spl.bin
  821. ifeq ($(CONFIG_MX6)$(CONFIG_IMX_HAB), yy)
  822. INPUTS-$(CONFIG_SPL_FRAMEWORK) += u-boot-ivt.img
  823. else
  824. ifeq ($(CONFIG_MX7)$(CONFIG_IMX_HAB), yy)
  825. INPUTS-$(CONFIG_SPL_FRAMEWORK) += u-boot-ivt.img
  826. else
  827. INPUTS-$(CONFIG_SPL_FRAMEWORK) += u-boot.img
  828. endif
  829. endif
  830. INPUTS-$(CONFIG_TPL) += tpl/u-boot-tpl.bin
  831. INPUTS-$(CONFIG_VPL) += vpl/u-boot-vpl.bin
  832. # Allow omitting the .dtb output if it is not normally used
  833. INPUTS-$(CONFIG_OF_SEPARATE) += $(if $(CONFIG_OF_OMIT_DTB),dts/dt.dtb,u-boot.dtb)
  834. ifeq ($(CONFIG_SPL_FRAMEWORK),y)
  835. INPUTS-$(CONFIG_OF_SEPARATE) += u-boot-dtb.img
  836. endif
  837. INPUTS-$(CONFIG_SANDBOX) += u-boot.dtb
  838. ifneq ($(CONFIG_SPL_TARGET),)
  839. INPUTS-$(CONFIG_SPL) += $(CONFIG_SPL_TARGET:"%"=%)
  840. endif
  841. INPUTS-$(CONFIG_REMAKE_ELF) += u-boot.elf
  842. INPUTS-$(CONFIG_EFI_APP) += u-boot-app.efi
  843. INPUTS-$(CONFIG_EFI_STUB) += u-boot-payload.efi
  844. # Generate this input file for binman
  845. ifeq ($(CONFIG_SPL),)
  846. INPUTS-$(CONFIG_ARCH_MEDIATEK) += u-boot-mtk.bin
  847. endif
  848. # Add optional build target if defined in board/cpu/soc headers
  849. ifneq ($(CONFIG_BUILD_TARGET),)
  850. INPUTS-y += $(CONFIG_BUILD_TARGET:"%"=%)
  851. endif
  852. ifeq ($(CONFIG_INIT_SP_RELATIVE)$(CONFIG_OF_SEPARATE),yy)
  853. INPUTS-y += init_sp_bss_offset_check
  854. endif
  855. ifeq ($(CONFIG_ARCH_ROCKCHIP)_$(CONFIG_SPL_FRAMEWORK),y_)
  856. INPUTS-y += u-boot.img
  857. endif
  858. INPUTS-$(CONFIG_X86) += u-boot-x86-start16.bin u-boot-x86-reset16.bin \
  859. $(if $(CONFIG_SPL_X86_16BIT_INIT),spl/u-boot-spl.bin) \
  860. $(if $(CONFIG_TPL_X86_16BIT_INIT),tpl/u-boot-tpl.bin)
  861. LDFLAGS_u-boot += $(LDFLAGS_FINAL)
  862. # Avoid 'Not enough room for program headers' error on binutils 2.28 onwards.
  863. LDFLAGS_u-boot += $(call ld-option, --no-dynamic-linker)
  864. # ld.lld support
  865. LDFLAGS_u-boot += -z notext $(call ld-option,--apply-dynamic-relocs)
  866. LDFLAGS_u-boot += --build-id=none
  867. ifeq ($(CONFIG_ARC)$(CONFIG_NIOS2)$(CONFIG_X86)$(CONFIG_XTENSA),)
  868. LDFLAGS_u-boot += -Ttext $(CONFIG_TEXT_BASE)
  869. endif
  870. # make the checker run with the right architecture
  871. CHECKFLAGS += --arch=$(ARCH)
  872. # insure the checker run with the right endianness
  873. CHECKFLAGS += $(if $(CONFIG_CPU_BIG_ENDIAN),-mbig-endian,-mlittle-endian)
  874. # the checker needs the correct machine size
  875. CHECKFLAGS += $(if $(CONFIG_64BIT),-m64,-m32)
  876. # Normally we fill empty space with 0xff
  877. quiet_cmd_objcopy = OBJCOPY $@
  878. cmd_objcopy = $(OBJCOPY) --gap-fill=0xff $(OBJCOPYFLAGS) \
  879. $(OBJCOPYFLAGS_$(@F)) $< $@
  880. # Provide a version which does not do this, for use by EFI
  881. quiet_cmd_zobjcopy = OBJCOPY $@
  882. cmd_zobjcopy = $(OBJCOPY) $(OBJCOPYFLAGS) $(OBJCOPYFLAGS_$(@F)) $< $@
  883. quiet_cmd_efipayload = OBJCOPY $@
  884. cmd_efipayload = $(OBJCOPY) -I binary -O $(EFIPAYLOAD_BFDTARGET) -B $(EFIPAYLOAD_BFDARCH) $< $@
  885. MKIMAGEOUTPUT ?= /dev/null
  886. quiet_cmd_mkimage = MKIMAGE $@
  887. cmd_mkimage = $(objtree)/tools/mkimage $(MKIMAGEFLAGS_$(@F)) -d $< $@ \
  888. >$(MKIMAGEOUTPUT) $(if $(KBUILD_VERBOSE:0=), && cat $(MKIMAGEOUTPUT))
  889. quiet_cmd_mkfitimage = MKIMAGE $@
  890. cmd_mkfitimage = $(objtree)/tools/mkimage $(MKIMAGEFLAGS_$(@F)) \
  891. -f $(U_BOOT_ITS) -p $(CONFIG_FIT_EXTERNAL_OFFSET) $@ \
  892. >$(MKIMAGEOUTPUT) $(if $(KBUILD_VERBOSE:0=), && cat $(MKIMAGEOUTPUT))
  893. quiet_cmd_cat = CAT $@
  894. cmd_cat = cat $(filter-out $(PHONY), $^) > $@
  895. append = cat $(filter-out $< $(PHONY), $^) >> $@
  896. quiet_cmd_pad_cat = CAT $@
  897. cmd_pad_cat = $(cmd_objcopy) && $(append) || { rm -f $@; false; }
  898. quiet_cmd_lzma = LZMA $@
  899. cmd_lzma = lzma -c -z -k -9 $< > $@
  900. cfg: u-boot.cfg
  901. quiet_cmd_ofcheck = OFCHK $2
  902. cmd_ofcheck = $(srctree)/scripts/check-of.sh $2 \
  903. $(srctree)/scripts/of_allowlist.txt
  904. # Concat the value of all the CONFIGs (result is 'y' or 'yy', etc. )
  905. got = $(foreach cfg,$(1),$($(cfg)))
  906. # expected value 'y for each one
  907. expect = $(foreach cfg,$(1),y)
  908. # Show a deprecation message
  909. # Args:
  910. # 1: List of options to migrate to (e.g. "CONFIG_DM_MMC CONFIG_BLK")
  911. # 2: Name of component (e.g . "Ethernet drivers")
  912. # 3: Release deadline (e.g. "v202.07")
  913. # 4: Condition to require before checking (e.g. "$(CONFIG_NET)")
  914. # Note: Script avoids bash construct, hence the strange double 'if'
  915. # (patches welcome!)
  916. define deprecated
  917. @if [ -n "$(strip $(4))" ]; then if [ "$(got)" != "$(expect)" ]; then \
  918. echo >&2 "===================== WARNING ======================"; \
  919. echo >&2 "This board does not use $(firstword $(1)) (Driver Model"; \
  920. echo >&2 "for $(2)). Please update the board to use"; \
  921. echo >&2 "$(firstword $(1)) before the $(3) release. Failure to"; \
  922. echo >&2 "update by the deadline may result in board removal."; \
  923. echo >&2 "See doc/develop/driver-model/migration.rst for more info."; \
  924. echo >&2 "===================================================="; \
  925. fi; fi
  926. endef
  927. # Timestamp file to make sure that binman always runs
  928. .binman_stamp: $(INPUTS-y) FORCE
  929. ifeq ($(CONFIG_BINMAN),y)
  930. $(call if_changed,binman)
  931. endif
  932. @touch $@
  933. all: .binman_stamp
  934. ifeq ($(CONFIG_DEPRECATED),y)
  935. $(warning "You have deprecated configuration options enabled in your .config! Please check your configuration.")
  936. endif
  937. ifeq ($(CONFIG_OF_EMBED)$(CONFIG_EFI_APP),y)
  938. @echo >&2 "===================== WARNING ======================"
  939. @echo >&2 "CONFIG_OF_EMBED is enabled. This option should only"
  940. @echo >&2 "be used for debugging purposes. Please use"
  941. @echo >&2 "CONFIG_OF_SEPARATE for boards in mainline."
  942. @echo >&2 "See doc/develop/devicetree/control.rst for more info."
  943. @echo >&2 "===================================================="
  944. endif
  945. ifneq ($(CONFIG_SPL_FIT_GENERATOR),)
  946. @echo >&2 "===================== WARNING ======================"
  947. @echo >&2 "This board uses CONFIG_SPL_FIT_GENERATOR. Please migrate"
  948. @echo >&2 "to binman instead, to avoid the proliferation of"
  949. @echo >&2 "arch-specific scripts with no tests."
  950. @echo >&2 "===================================================="
  951. endif
  952. $(call deprecated,CONFIG_WDT,DM watchdog,v2019.10,\
  953. $(CONFIG_WATCHDOG)$(CONFIG_HW_WATCHDOG))
  954. $(call deprecated,CONFIG_DM_I2C,I2C drivers,v2022.04,$(CONFIG_SYS_I2C_LEGACY))
  955. @# CFG_SYS_TIMER_RATE has brackets in it for some boards which
  956. @# confuses this rule. Use if() to send just a single character which
  957. @# is enable to tell 'deprecated' that one of these symbols exists
  958. $(call deprecated,CONFIG_TIMER,Timer drivers,v2023.01,$(if $(strip $(CFG_SYS_TIMER_RATE)$(CFG_SYS_TIMER_COUNTER)),x))
  959. $(call deprecated,CONFIG_DM_SERIAL,Serial drivers,v2023.04,$(CONFIG_SERIAL))
  960. @# Check that this build does not override OF_HAS_PRIOR_STAGE by
  961. @# disabling OF_BOARD.
  962. $(call cmd,ofcheck,$(KCONFIG_CONFIG))
  963. PHONY += dtbs dtbs_check
  964. dtbs: dts/dt.dtb
  965. @:
  966. dts/dt.dtb: dtbs_prepare u-boot
  967. $(Q)$(MAKE) $(build)=dts dtbs
  968. dtbs_prepare: prepare3
  969. ifneq ($(filter dtbs_check, $(MAKECMDGOALS)),)
  970. export CHECK_DTBS=y
  971. endif
  972. ifneq ($(CHECK_DTBS),)
  973. dtbs_prepare: dt_binding_check
  974. endif
  975. dtbs_check: dt_binding_check dtbs
  976. DT_BINDING_DIR := dts/upstream/Bindings
  977. dt_binding_check: scripts_dtc
  978. $(Q)$(MAKE) $(build)=$(DT_BINDING_DIR) $(DT_BINDING_DIR)/processed-schema.json
  979. quiet_cmd_copy = COPY $@
  980. cmd_copy = cp $< $@
  981. ifeq ($(CONFIG_OF_UPSTREAM),y)
  982. ifeq ($(CONFIG_ARM64),y)
  983. dt_dir := dts/upstream/src/arm64
  984. else
  985. dt_dir := dts/upstream/src/$(ARCH)
  986. endif
  987. else
  988. dt_dir := arch/$(ARCH)/dts
  989. endif
  990. ifeq ($(CONFIG_MULTI_DTB_FIT),y)
  991. ifeq ($(CONFIG_MULTI_DTB_FIT_LZO),y)
  992. FINAL_DTB_CONTAINER = fit-dtb.blob.lzo
  993. else ifeq ($(CONFIG_MULTI_DTB_FIT_GZIP),y)
  994. FINAL_DTB_CONTAINER = fit-dtb.blob.gz
  995. else
  996. FINAL_DTB_CONTAINER = fit-dtb.blob
  997. endif
  998. fit-dtb.blob.gz: fit-dtb.blob
  999. @gzip -kf9 $< > $@
  1000. fit-dtb.blob.lzo: fit-dtb.blob
  1001. @lzop -f9 $< > $@
  1002. fit-dtb.blob: dts/dt.dtb FORCE
  1003. $(call if_changed,mkimage)
  1004. ifneq ($(SOURCE_DATE_EPOCH),)
  1005. touch -d @$(SOURCE_DATE_EPOCH) fit-dtb.blob
  1006. chmod 0600 fit-dtb.blob
  1007. endif
  1008. MKIMAGEFLAGS_fit-dtb.blob = -f auto -A $(ARCH) -T firmware -C none -O u-boot \
  1009. -a 0 -e 0 -E \
  1010. $(patsubst %,-b $(dt_dir)/%.dtb,$(subst ",,$(CONFIG_OF_LIST))) -d /dev/null
  1011. MKIMAGEFLAGS_fit-dtb.blob += -B 0x8
  1012. ifneq ($(EXT_DTB),)
  1013. u-boot-fit-dtb.bin: u-boot-nodtb.bin $(EXT_DTB)
  1014. $(call if_changed,cat)
  1015. else
  1016. u-boot-fit-dtb.bin: u-boot-nodtb.bin $(FINAL_DTB_CONTAINER)
  1017. $(call if_changed,cat)
  1018. endif
  1019. u-boot.bin: u-boot-fit-dtb.bin FORCE
  1020. $(call if_changed,copy)
  1021. ifneq ($(CONFIG_MPC85XX_HAVE_RESET_VECTOR)$(CONFIG_OF_SEPARATE),yy)
  1022. u-boot-dtb.bin: u-boot-nodtb.bin dts/dt.dtb FORCE
  1023. $(call if_changed,cat)
  1024. endif
  1025. else ifeq ($(CONFIG_OF_SEPARATE).$(CONFIG_OF_OMIT_DTB),y.)
  1026. ifneq ($(CONFIG_MPC85XX_HAVE_RESET_VECTOR)$(CONFIG_OF_SEPARATE),yy)
  1027. u-boot-dtb.bin: u-boot-nodtb.bin dts/dt.dtb FORCE
  1028. $(call if_changed,cat)
  1029. endif
  1030. u-boot.bin: u-boot-dtb.bin FORCE
  1031. $(call if_changed,copy)
  1032. else
  1033. u-boot.bin: u-boot-nodtb.bin FORCE
  1034. $(call if_changed,copy)
  1035. endif
  1036. # we call Makefile in arch/arm/mach-imx which
  1037. # has targets which are dependent on targets defined
  1038. # here. make could not resolve them and we must ensure
  1039. # that they are finished before calling imx targets
  1040. ifeq ($(CONFIG_MULTI_DTB_FIT),y)
  1041. IMX_DEPS = u-boot-fit-dtb.bin
  1042. endif
  1043. %.imx: $(IMX_DEPS) %.bin
  1044. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1045. $(BOARD_SIZE_CHECK)
  1046. %.vyb: %.imx
  1047. $(Q)$(MAKE) $(build)=arch/arm/cpu/armv7/vf610 $@
  1048. quiet_cmd_copy = COPY $@
  1049. cmd_copy = cp $< $@
  1050. u-boot.dtb: dts/dt.dtb
  1051. $(call cmd,copy)
  1052. OBJCOPYFLAGS_u-boot.hex := -O ihex
  1053. OBJCOPYFLAGS_u-boot.srec := -O srec
  1054. u-boot.hex u-boot.srec: u-boot FORCE
  1055. $(call if_changed,objcopy)
  1056. OBJCOPYFLAGS_u-boot-elf.srec := $(OBJCOPYFLAGS_u-boot.srec)
  1057. u-boot-elf.srec: u-boot.elf FORCE
  1058. $(call if_changed,objcopy)
  1059. OBJCOPYFLAGS_u-boot-spl.srec = $(OBJCOPYFLAGS_u-boot.srec)
  1060. spl/u-boot-spl.srec: spl/u-boot-spl FORCE
  1061. $(call if_changed,objcopy)
  1062. %.scif: %.srec
  1063. $(Q)$(MAKE) $(build)=arch/arm/mach-renesas $@
  1064. OBJCOPYFLAGS_u-boot-nodtb.bin := -O binary \
  1065. $(if $(CONFIG_X86_16BIT_INIT),-R .start16 -R .resetvec) \
  1066. $(if $(CONFIG_MPC85XX_HAVE_RESET_VECTOR),$(if $(CONFIG_OF_SEPARATE),-R .bootpg -R .resetvec))
  1067. binary_size_check: u-boot-nodtb.bin FORCE
  1068. @file_size=$(shell wc -c u-boot-nodtb.bin | awk '{ print $$1 }') ; \
  1069. map_size=$(shell cat u-boot.map | \
  1070. awk ' \
  1071. /_image_copy_start/ { start = $$1 } \
  1072. /_image_binary_end/ { end = $$1 } \
  1073. END { \
  1074. if (start != "" && end != "") \
  1075. print end " " start; \
  1076. }' \
  1077. | sh -c 'read end start && echo $$((end - start))'); \
  1078. if [ -n "$$map_size" ]; then \
  1079. if test $$map_size -ne $$file_size; then \
  1080. echo "u-boot.map shows a binary size of $$map_size" >&2 ; \
  1081. echo " but u-boot-nodtb.bin shows $$file_size" >&2 ; \
  1082. exit 1; \
  1083. fi; \
  1084. fi
  1085. ifeq ($(CONFIG_INIT_SP_RELATIVE)$(CONFIG_OF_SEPARATE),yy)
  1086. ifneq ($(CONFIG_SYS_MALLOC_F),)
  1087. subtract_sys_malloc_f_len = space=$$(($${space} - $(CONFIG_SYS_MALLOC_F_LEN)))
  1088. else
  1089. subtract_sys_malloc_f_len = true
  1090. endif
  1091. # The 1/4 margin below is somewhat arbitrary. The likely initial SP usage is
  1092. # so low that the DTB could probably use 90%+ of the available space, for
  1093. # current values of CONFIG_SYS_INIT_SP_BSS_OFFSET at least. However, let's be
  1094. # safe for now and tweak this later if space becomes tight.
  1095. # A rejected alternative would be to check that some absolute minimum stack
  1096. # space was available. However, since CONFIG_SYS_INIT_SP_BSS_OFFSET is
  1097. # deliberately build-specific, to take account of build-to-build stack usage
  1098. # differences due to different feature sets, there is no common absolute value
  1099. # to check against.
  1100. init_sp_bss_offset_check: u-boot.dtb FORCE
  1101. @dtb_size=$(shell wc -c u-boot.dtb | awk '{print $$1}') ; \
  1102. space=$(CONFIG_SYS_INIT_SP_BSS_OFFSET) ; \
  1103. $(subtract_sys_malloc_f_len) ; \
  1104. quarter_space=$$(($${space} / 4)) ; \
  1105. if [ $${dtb_size} -gt $${quarter_space} ]; then \
  1106. echo "u-boot.dtb is larger than 1 quarter of " >&2 ; \
  1107. echo "(CONFIG_SYS_INIT_SP_BSS_OFFSET - CONFIG_SYS_MALLOC_F_LEN)" >&2 ; \
  1108. exit 1 ; \
  1109. fi
  1110. endif
  1111. shell_cmd = { $(call echo-cmd,$(1)) $(cmd_$(1)); }
  1112. quiet_cmd_objcopy_uboot = OBJCOPY $@
  1113. ifdef cmd_static_rela
  1114. cmd_objcopy_uboot = $(cmd_objcopy) && $(call shell_cmd,static_rela,$<,$@,$(CONFIG_TEXT_BASE)) || { rm -f $@; false; }
  1115. else
  1116. cmd_objcopy_uboot = $(cmd_objcopy)
  1117. endif
  1118. u-boot-nodtb.bin: u-boot FORCE
  1119. $(call if_changed,objcopy_uboot)
  1120. $(BOARD_SIZE_CHECK)
  1121. u-boot.ldr: u-boot
  1122. $(CREATE_LDR_ENV)
  1123. $(LDR) -T $(CONFIG_LDR_CPU) -c $@ $< $(LDR_FLAGS)
  1124. $(BOARD_SIZE_CHECK)
  1125. # binman
  1126. # ---------------------------------------------------------------------------
  1127. # Use 'make BINMAN_DEBUG=1' to enable debugging
  1128. # Use 'make BINMAN_VERBOSE=3' to set vebosity level
  1129. default_dt := $(if $(DEVICE_TREE),$(DEVICE_TREE),$(CONFIG_DEFAULT_DEVICE_TREE))
  1130. quiet_cmd_binman = BINMAN $@
  1131. cmd_binman = $(srctree)/tools/binman/binman $(if $(BINMAN_DEBUG),-D) \
  1132. $(foreach f,$(BINMAN_TOOLPATHS),--toolpath $(f)) \
  1133. --toolpath $(objtree)/tools \
  1134. $(if $(BINMAN_VERBOSE),-v$(BINMAN_VERBOSE)) \
  1135. build -u -d u-boot.dtb -O . -m \
  1136. --allow-missing $(if $(BINMAN_ALLOW_MISSING),--ignore-missing) \
  1137. -I . -I $(srctree) -I $(srctree)/board/$(BOARDDIR) \
  1138. -I $(dt_dir) -a of-list=$(CONFIG_OF_LIST) \
  1139. $(foreach f,$(BINMAN_INDIRS),-I $(f)) \
  1140. -a atf-bl31-path=${BL31} \
  1141. -a tee-os-path=${TEE} \
  1142. -a ti-dm-path=${TI_DM} \
  1143. -a opensbi-path=${OPENSBI} \
  1144. -a default-dt=$(default_dt) \
  1145. -a scp-path=$(SCP) \
  1146. -a rockchip-tpl-path=$(ROCKCHIP_TPL) \
  1147. -a spl-bss-pad=$(if $(CONFIG_SPL_SEPARATE_BSS),,1) \
  1148. -a tpl-bss-pad=$(if $(CONFIG_TPL_SEPARATE_BSS),,1) \
  1149. -a spl-dtb=$(CONFIG_SPL_OF_REAL) \
  1150. -a tpl-dtb=$(CONFIG_TPL_OF_REAL) \
  1151. -a pre-load-key-path=${PRE_LOAD_KEY_PATH} \
  1152. $(BINMAN_$(@F))
  1153. OBJCOPYFLAGS_u-boot.ldr.hex := -I binary -O ihex
  1154. OBJCOPYFLAGS_u-boot.ldr.srec := -I binary -O srec
  1155. u-boot.ldr.hex u-boot.ldr.srec: u-boot.ldr FORCE
  1156. $(call if_changed,objcopy)
  1157. # Boards with more complex image requirements can provide an .its source file
  1158. # or a generator script
  1159. # NOTE: Please do not use this. We are migrating away from Makefile rules to use
  1160. # binman instead.
  1161. ifneq ($(CONFIG_SPL_FIT_SOURCE),"")
  1162. U_BOOT_ITS := u-boot.its
  1163. $(U_BOOT_ITS): $(subst ",,$(CONFIG_SPL_FIT_SOURCE))
  1164. $(call if_changed,copy)
  1165. else
  1166. ifneq ($(CONFIG_USE_SPL_FIT_GENERATOR),)
  1167. U_BOOT_ITS := u-boot.its
  1168. $(U_BOOT_ITS): $(U_BOOT_ITS_DEPS) FORCE
  1169. $(srctree)/$(CONFIG_SPL_FIT_GENERATOR) \
  1170. $(patsubst %,$(dt_dir)/%.dtb,$(subst ",,$(CONFIG_OF_LIST))) > $@
  1171. endif
  1172. endif
  1173. ifdef CONFIG_SPL_LOAD_FIT
  1174. MKIMAGEFLAGS_u-boot.img = -f auto -A $(ARCH) -T firmware -C none -O u-boot \
  1175. -a $(CONFIG_TEXT_BASE) -e $(CONFIG_SYS_UBOOT_START) \
  1176. -p $(CONFIG_FIT_EXTERNAL_OFFSET) \
  1177. -n "U-Boot $(UBOOTRELEASE) for $(BOARD) board" -E \
  1178. $(patsubst %,-b $(dt_dir)/%.dtb,$(subst ",,$(DEVICE_TREE))) \
  1179. $(patsubst %,-b $(dt_dir)/%.dtb,$(subst ",,$(CONFIG_OF_LIST))) \
  1180. $(patsubst %,-b $(dt_dir)/%.dtbo,$(subst ",,$(CONFIG_OF_OVERLAY_LIST)))
  1181. else
  1182. MKIMAGEFLAGS_u-boot.img = -A $(ARCH) -T firmware -C none -O u-boot \
  1183. -a $(CONFIG_TEXT_BASE) -e $(CONFIG_SYS_UBOOT_START) \
  1184. -n "U-Boot $(UBOOTRELEASE) for $(BOARD) board"
  1185. MKIMAGEFLAGS_u-boot-ivt.img = -A $(ARCH) -T firmware_ivt -C none -O u-boot \
  1186. -a $(CONFIG_TEXT_BASE) -e $(CONFIG_SYS_UBOOT_START) \
  1187. -n "U-Boot $(UBOOTRELEASE) for $(BOARD) board"
  1188. u-boot-ivt.img: MKIMAGEOUTPUT = u-boot-ivt.img.log
  1189. endif
  1190. MKIMAGEFLAGS_u-boot-dtb.img = $(MKIMAGEFLAGS_u-boot.img)
  1191. # Some boards have the kwbimage.cfg file written in advance, while some
  1192. # other boards generate it on the fly during the build in the build tree.
  1193. # Let's check if the file exists in the build tree first, otherwise we
  1194. # fall back to use the one in the source tree.
  1195. KWD_CONFIG_FILE = $(shell \
  1196. if [ -f $(objtree)/$(CONFIG_SYS_KWD_CONFIG:"%"=%) ]; then \
  1197. echo -n $(objtree)/$(CONFIG_SYS_KWD_CONFIG:"%"=%); \
  1198. else \
  1199. echo -n $(srctree)/$(CONFIG_SYS_KWD_CONFIG:"%"=%); \
  1200. fi)
  1201. MKIMAGEFLAGS_u-boot.kwb = -n $(KWD_CONFIG_FILE) \
  1202. -T kwbimage -a $(CONFIG_TEXT_BASE) -e $(CONFIG_TEXT_BASE)
  1203. MKIMAGEFLAGS_u-boot-with-spl.kwb = -n $(KWD_CONFIG_FILE) \
  1204. -T kwbimage -a $(CONFIG_TEXT_BASE) -e $(CONFIG_TEXT_BASE) \
  1205. $(if $(KEYDIR),-k $(KEYDIR))
  1206. MKIMAGEFLAGS_u-boot.pbl = -n $(srctree)/$(CONFIG_SYS_FSL_PBL_RCW:"%"=%) \
  1207. -R $(srctree)/$(CONFIG_SYS_FSL_PBL_PBI:"%"=%) -A $(ARCH) -T pblimage
  1208. UBOOT_BIN := u-boot.bin
  1209. MKIMAGEFLAGS_u-boot-lzma.img = -A $(ARCH) -T standalone -C lzma -O u-boot \
  1210. -a $(CONFIG_TEXT_BASE) -e $(CONFIG_SYS_UBOOT_START) \
  1211. -n "U-Boot $(UBOOTRELEASE) for $(BOARD) board"
  1212. u-boot.bin.lzma: u-boot.bin FORCE
  1213. $(call if_changed,lzma)
  1214. u-boot-lzma.img: u-boot.bin.lzma FORCE
  1215. $(call if_changed,mkimage)
  1216. u-boot-dtb.img u-boot.img u-boot.kwb u-boot.pbl u-boot-ivt.img: \
  1217. $(if $(CONFIG_SPL_LOAD_FIT),u-boot-nodtb.bin \
  1218. $(if $(CONFIG_OF_SEPARATE)$(CONFIG_OF_EMBED)$(CONFIG_SANDBOX),dts/dt.dtb) \
  1219. ,$(UBOOT_BIN)) FORCE
  1220. $(call if_changed,mkimage)
  1221. $(BOARD_SIZE_CHECK)
  1222. ifeq ($(CONFIG_SPL_LOAD_FIT_FULL),y)
  1223. MKIMAGEFLAGS_u-boot.itb =
  1224. else
  1225. MKIMAGEFLAGS_u-boot.itb = -E
  1226. endif
  1227. MKIMAGEFLAGS_u-boot.itb += -B 0x8
  1228. ifdef U_BOOT_ITS
  1229. u-boot.itb: u-boot-nodtb.bin \
  1230. $(if $(CONFIG_OF_SEPARATE)$(CONFIG_OF_EMBED)$(CONFIG_SANDBOX),dts/dt.dtb) \
  1231. $(if $(CONFIG_MULTI_DTB_FIT),$(FINAL_DTB_CONTAINER)) \
  1232. $(U_BOOT_ITS) FORCE
  1233. $(call if_changed,mkfitimage)
  1234. $(BOARD_SIZE_CHECK)
  1235. endif
  1236. u-boot-with-spl.kwb: u-boot.bin spl/u-boot-spl.bin FORCE
  1237. $(call if_changed,mkimage)
  1238. $(BOARD_SIZE_CHECK)
  1239. u-boot.dis: u-boot
  1240. $(OBJDUMP) -d $< > $@
  1241. ifneq ($(CONFIG_SPL_PAYLOAD),)
  1242. SPL_PAYLOAD := $(CONFIG_SPL_PAYLOAD:"%"=%)
  1243. else
  1244. SPL_PAYLOAD := u-boot.bin
  1245. endif
  1246. SPL_IMAGE := $(CONFIG_SPL_IMAGE:"%"=%)
  1247. OBJCOPYFLAGS_u-boot-with-spl.bin = -I binary -O binary \
  1248. --pad-to=$(CONFIG_SPL_PAD_TO)
  1249. u-boot-with-spl.bin: $(SPL_IMAGE) $(SPL_PAYLOAD) FORCE
  1250. $(call if_changed,pad_cat)
  1251. ifeq ($(CONFIG_ARCH_LPC32XX)$(CONFIG_SPL),yy)
  1252. MKIMAGEFLAGS_lpc32xx-spl.img = -T lpc32xximage -a $(CONFIG_SPL_TEXT_BASE)
  1253. lpc32xx-spl.img: spl/u-boot-spl.bin FORCE
  1254. $(call if_changed,mkimage)
  1255. OBJCOPYFLAGS_lpc32xx-boot-0.bin = -I binary -O binary --pad-to=$(CONFIG_SPL_PAD_TO)
  1256. lpc32xx-boot-0.bin: lpc32xx-spl.img FORCE
  1257. $(call if_changed,objcopy)
  1258. OBJCOPYFLAGS_lpc32xx-boot-1.bin = -I binary -O binary --pad-to=$(CONFIG_SPL_PAD_TO)
  1259. lpc32xx-boot-1.bin: lpc32xx-spl.img FORCE
  1260. $(call if_changed,objcopy)
  1261. lpc32xx-full.bin: lpc32xx-boot-0.bin lpc32xx-boot-1.bin u-boot.img FORCE
  1262. $(call if_changed,cat)
  1263. endif
  1264. OBJCOPYFLAGS_u-boot-with-tpl.bin = -I binary -O binary \
  1265. --pad-to=$(CONFIG_TPL_PAD_TO)
  1266. tpl/u-boot-with-tpl.bin: tpl/u-boot-tpl.bin u-boot.bin FORCE
  1267. $(call if_changed,pad_cat)
  1268. SPL: spl/u-boot-spl.bin FORCE
  1269. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1270. #ifeq ($(CONFIG_ARCH_IMX8M)$(CONFIG_ARCH_IMX8), y)
  1271. ifeq ($(CONFIG_SPL_LOAD_IMX_CONTAINER), y)
  1272. u-boot.cnt: u-boot.bin FORCE
  1273. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1274. flash.bin: spl/u-boot-spl.bin u-boot.cnt FORCE
  1275. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1276. else
  1277. ifeq ($(CONFIG_BINMAN),y)
  1278. flash.bin: spl/u-boot-spl.bin $(INPUTS-y) FORCE
  1279. $(call if_changed,binman)
  1280. else
  1281. flash.bin: spl/u-boot-spl.bin u-boot.itb FORCE
  1282. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1283. endif
  1284. endif
  1285. #endif
  1286. u-boot.uim: u-boot.bin FORCE
  1287. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1288. u-boot-nand.imx: u-boot.imx FORCE
  1289. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1290. u-boot-with-spl.imx u-boot-with-nand-spl.imx: SPL $(if $(CONFIG_OF_SEPARATE),u-boot.img,u-boot.uim) FORCE
  1291. $(Q)$(MAKE) $(build)=arch/arm/mach-imx $@
  1292. MKIMAGEFLAGS_u-boot.ubl = -n $(UBL_CONFIG) -T ublimage -e $(CONFIG_TEXT_BASE)
  1293. u-boot.ubl: u-boot-with-spl.bin FORCE
  1294. $(call if_changed,mkimage)
  1295. MKIMAGEFLAGS_u-boot-spl.ais = -s -n "/dev/null" \
  1296. -T aisimage -e $(CONFIG_SPL_TEXT_BASE)
  1297. spl/u-boot-spl.ais: spl/u-boot-spl.bin FORCE
  1298. $(call if_changed,mkimage)
  1299. OBJCOPYFLAGS_u-boot.ais = -I binary -O binary --pad-to=$(CONFIG_SPL_PAD_TO)
  1300. u-boot.ais: spl/u-boot-spl.ais u-boot.img FORCE
  1301. $(call if_changed,pad_cat)
  1302. u-boot-signed.sb: u-boot.bin spl/u-boot-spl.bin
  1303. $(Q)$(MAKE) $(build)=arch/arm/cpu/arm926ejs/mxs u-boot-signed.sb
  1304. u-boot.sb: u-boot.bin spl/u-boot-spl.bin
  1305. $(Q)$(MAKE) $(build)=arch/arm/cpu/arm926ejs/mxs u-boot.sb
  1306. MKIMAGEFLAGS_u-boot-spl.img = -A $(ARCH) -T firmware -C none \
  1307. -a $(CONFIG_SPL_TEXT_BASE) -e $(CONFIG_SPL_TEXT_BASE) -n XLOADER
  1308. spl/u-boot-spl.img: spl/u-boot-spl.bin FORCE
  1309. $(call if_changed,mkimage)
  1310. ifneq ($(CONFIG_ARCH_SOCFPGA),)
  1311. quiet_cmd_gensplx4 = GENSPLX4 $@
  1312. cmd_gensplx4 = $(OBJCOPY) -I binary -O binary --gap-fill=0x0 \
  1313. --pad-to=$(CONFIG_SPL_PAD_TO) \
  1314. spl/u-boot-spl.sfp spl/u-boot-spl.sfp && \
  1315. cat spl/u-boot-spl.sfp spl/u-boot-spl.sfp \
  1316. spl/u-boot-spl.sfp spl/u-boot-spl.sfp > $@ || { rm -f $@; false; }
  1317. spl/u-boot-splx4.sfp: spl/u-boot-spl.sfp FORCE
  1318. $(call if_changed,gensplx4)
  1319. quiet_cmd_socboot = SOCBOOT $@
  1320. cmd_socboot = cat spl/u-boot-splx4.sfp u-boot.img > $@ || { rm -f $@; false; }
  1321. u-boot-with-spl.sfp: spl/u-boot-splx4.sfp u-boot.img FORCE
  1322. $(call if_changed,socboot)
  1323. quiet_cmd_gensplpadx4 = GENSPLPADX4 $@
  1324. cmd_gensplpadx4 = dd if=/dev/zero of=spl/u-boot-spl.pad bs=64 count=1024 ; \
  1325. cat spl/u-boot-spl.sfp spl/u-boot-spl.pad \
  1326. spl/u-boot-spl.sfp spl/u-boot-spl.pad \
  1327. spl/u-boot-spl.sfp spl/u-boot-spl.pad \
  1328. spl/u-boot-spl.sfp spl/u-boot-spl.pad > $@ || \
  1329. { rm -f $@ spl/u-boot-spl.pad; false; }
  1330. u-boot-spl-padx4.sfp: spl/u-boot-spl.sfp FORCE
  1331. $(call if_changed,gensplpadx4)
  1332. quiet_cmd_socnandboot = SOCNANDBOOT $@
  1333. cmd_socnandboot = cat u-boot-spl-padx4.sfp u-boot.img > $@ || { rm -f $@; false; }
  1334. u-boot-with-nand-spl.sfp: u-boot-spl-padx4.sfp u-boot.img FORCE
  1335. $(call if_changed,socnandboot)
  1336. endif
  1337. ifeq ($(CONFIG_MPC85XX_HAVE_RESET_VECTOR)$(CONFIG_OF_SEPARATE),yy)
  1338. u-boot-dtb.bin: u-boot-nodtb.bin u-boot.dtb u-boot-br.bin FORCE
  1339. $(call if_changed,binman)
  1340. OBJCOPYFLAGS_u-boot-br.bin := -O binary -j .bootpg -j .resetvec
  1341. u-boot-br.bin: u-boot FORCE
  1342. $(call if_changed,objcopy)
  1343. endif
  1344. quiet_cmd_ldr = LD $@
  1345. cmd_ldr = $(LD) $(LDFLAGS_$(@F)) \
  1346. $(filter-out FORCE,$^) -o $@
  1347. ifdef CONFIG_X86
  1348. OBJCOPYFLAGS_u-boot-x86-start16.bin := -O binary -j .start16
  1349. u-boot-x86-start16.bin: u-boot FORCE
  1350. $(call if_changed,objcopy)
  1351. OBJCOPYFLAGS_u-boot-x86-reset16.bin := -O binary -j .resetvec
  1352. u-boot-x86-reset16.bin: u-boot FORCE
  1353. $(call if_changed,objcopy)
  1354. endif # CONFIG_X86
  1355. OBJCOPYFLAGS_u-boot-app.efi := $(OBJCOPYFLAGS_EFI)
  1356. u-boot-app.efi: u-boot FORCE
  1357. $(call if_changed,zobjcopy)
  1358. u-boot.bin.o: u-boot.bin FORCE
  1359. $(call if_changed,efipayload)
  1360. u-boot-payload.lds: $(LDSCRIPT_EFI) FORCE
  1361. $(call if_changed_dep,cpp_lds)
  1362. # Rule to link the EFI payload which contains a stub and a U-Boot binary
  1363. quiet_cmd_u-boot_payload ?= LD $@
  1364. cmd_u-boot_payload ?= $(LD) $(LDFLAGS_EFI_PAYLOAD) -o $@ \
  1365. -T u-boot-payload.lds arch/x86/cpu/call32.o \
  1366. lib/efi/efi.o lib/efi/efi_stub.o u-boot.bin.o \
  1367. $(addprefix arch/$(ARCH)/lib/,$(EFISTUB))
  1368. u-boot-payload: u-boot.bin.o u-boot-payload.lds FORCE
  1369. $(call if_changed,u-boot_payload)
  1370. OBJCOPYFLAGS_u-boot-payload.efi := $(OBJCOPYFLAGS_EFI)
  1371. u-boot-payload.efi: u-boot-payload FORCE
  1372. $(call if_changed,zobjcopy)
  1373. u-boot-img.bin: spl/u-boot-spl.bin u-boot.img FORCE
  1374. $(call if_changed,cat)
  1375. #Add a target to create boot binary having SPL binary in PBI format
  1376. #concatenated with u-boot binary. It is need by PowerPC SoC having
  1377. #internal SRAM <= 512KB.
  1378. MKIMAGEFLAGS_u-boot-spl.pbl = -n $(srctree)/$(CONFIG_SYS_FSL_PBL_RCW:"%"=%) \
  1379. -R $(srctree)/$(CONFIG_SYS_FSL_PBL_PBI:"%"=%) -T pblimage \
  1380. -A $(ARCH) -a $(CONFIG_SPL_TEXT_BASE)
  1381. spl/u-boot-spl.pbl: spl/u-boot-spl.bin FORCE
  1382. $(call if_changed,mkimage)
  1383. ifeq ($(ARCH),arm)
  1384. UBOOT_BINLOAD := u-boot.img
  1385. else
  1386. UBOOT_BINLOAD := u-boot.bin
  1387. endif
  1388. OBJCOPYFLAGS_u-boot-with-spl-pbl.bin = -I binary -O binary --pad-to=$(CONFIG_SPL_PAD_TO) \
  1389. --gap-fill=0xff
  1390. u-boot-with-spl-pbl.bin: spl/u-boot-spl.pbl $(UBOOT_BINLOAD) FORCE
  1391. $(call if_changed,pad_cat)
  1392. quiet_cmd_u-boot-elf ?= LD $@
  1393. cmd_u-boot-elf ?= $(LD) u-boot-elf.o -o $@ \
  1394. $(if $(CONFIG_SYS_BIG_ENDIAN),-EB,-EL) \
  1395. -T u-boot-elf.lds --defsym=$(CONFIG_PLATFORM_ELFENTRY)=$(CONFIG_TEXT_BASE) \
  1396. -Ttext=$(CONFIG_TEXT_BASE)
  1397. u-boot.elf: u-boot.bin u-boot-elf.lds
  1398. $(Q)$(OBJCOPY) -I binary $(PLATFORM_ELFFLAGS) $< u-boot-elf.o
  1399. $(call if_changed,u-boot-elf)
  1400. u-boot-elf.lds: arch/u-boot-elf.lds prepare FORCE
  1401. $(call if_changed_dep,cpp_lds)
  1402. # MediaTek's ARM-based u-boot needs a header to contains its load address
  1403. # which is parsed by the BootROM.
  1404. # If the SPL build is enabled, the header will be added to the spl binary,
  1405. # and the spl binary and the u-boot.img will be combined into one file.
  1406. # Otherwise the header will be added to the u-boot.bin directly.
  1407. ifeq ($(CONFIG_SPL),y)
  1408. spl/u-boot-spl-mtk.bin: spl/u-boot-spl
  1409. u-boot-mtk.bin: u-boot-with-spl.bin
  1410. $(call if_changed,copy)
  1411. else
  1412. MKIMAGEFLAGS_u-boot-mtk.bin = -T mtk_image \
  1413. -a $(CONFIG_TEXT_BASE) -e $(CONFIG_TEXT_BASE) \
  1414. -n "$(patsubst "%",%,$(CONFIG_MTK_BROM_HEADER_INFO))"
  1415. u-boot-mtk.bin: u-boot.bin FORCE
  1416. $(call if_changed,mkimage)
  1417. endif
  1418. quiet_cmd_endian_swap = SWAP $@
  1419. cmd_endian_swap = $(srctree)/tools/endian-swap.py $< $@
  1420. u-boot-swap.bin: u-boot.bin FORCE
  1421. $(call if_changed,endian_swap)
  1422. ARCH_POSTLINK := $(wildcard $(srctree)/arch/$(ARCH)/Makefile.postlink)
  1423. # Generate linker list symbols references to force compiler to not optimize
  1424. # them away when compiling with LTO
  1425. ifeq ($(LTO_ENABLE),y)
  1426. u-boot-keep-syms-lto := keep-syms-lto.o
  1427. u-boot-keep-syms-lto_c := $(patsubst %.o,%.c,$(u-boot-keep-syms-lto))
  1428. quiet_cmd_keep_syms_lto = KSL $@
  1429. cmd_keep_syms_lto = \
  1430. $(srctree)/scripts/gen_ll_addressable_symbols.sh $(NM) $^ > $@
  1431. quiet_cmd_keep_syms_lto_cc = KSLCC $@
  1432. cmd_keep_syms_lto_cc = \
  1433. $(CC) $(filter-out $(LTO_CFLAGS),$(c_flags)) -c -o $@ $<
  1434. $(u-boot-keep-syms-lto_c): $(u-boot-main)
  1435. $(call if_changed,keep_syms_lto)
  1436. $(u-boot-keep-syms-lto): $(u-boot-keep-syms-lto_c)
  1437. $(call if_changed,keep_syms_lto_cc)
  1438. else
  1439. u-boot-keep-syms-lto :=
  1440. endif
  1441. # Rule to link u-boot
  1442. # May be overridden by arch/$(ARCH)/config.mk
  1443. ifeq ($(LTO_ENABLE),y)
  1444. quiet_cmd_u-boot__ ?= LTO $@
  1445. cmd_u-boot__ ?= \
  1446. $(CC) -nostdlib -nostartfiles \
  1447. $(LTO_FINAL_LDFLAGS) $(c_flags) \
  1448. $(KBUILD_LDFLAGS:%=-Wl,%) $(LDFLAGS_u-boot:%=-Wl,%) -o $@ \
  1449. -T u-boot.lds $(u-boot-init) \
  1450. -Wl,--whole-archive \
  1451. $(u-boot-main) \
  1452. $(u-boot-keep-syms-lto) \
  1453. $(PLATFORM_LIBS) \
  1454. -Wl,--no-whole-archive \
  1455. -Wl,-Map,u-boot.map; \
  1456. $(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) $@, true)
  1457. else
  1458. quiet_cmd_u-boot__ ?= LD $@
  1459. cmd_u-boot__ ?= $(LD) $(KBUILD_LDFLAGS) $(LDFLAGS_u-boot) -o $@ \
  1460. -T u-boot.lds $(u-boot-init) \
  1461. --whole-archive \
  1462. $(u-boot-main) \
  1463. --no-whole-archive \
  1464. $(PLATFORM_LIBS) -Map u-boot.map; \
  1465. $(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) $@, true)
  1466. endif
  1467. quiet_cmd_smap = GEN common/system_map.o
  1468. cmd_smap = \
  1469. smap=`$(call SYSTEM_MAP,u-boot) | \
  1470. awk '$$2 ~ /[tTwW]/ {printf $$1 $$3 "\\\\000"}'` ; \
  1471. $(CC) $(c_flags) -DSYSTEM_MAP="\"$${smap}\"" \
  1472. -c $(srctree)/common/system_map.c -o common/system_map.o
  1473. u-boot: $(u-boot-init) $(u-boot-main) $(u-boot-keep-syms-lto) u-boot.lds FORCE
  1474. +$(call if_changed,u-boot__)
  1475. ifeq ($(CONFIG_KALLSYMS),y)
  1476. $(call cmd,smap)
  1477. $(call cmd,u-boot__) common/system_map.o
  1478. endif
  1479. ifeq ($(CONFIG_RISCV),y)
  1480. @tools/prelink-riscv $@
  1481. endif
  1482. quiet_cmd_sym ?= SYM $@
  1483. cmd_sym ?= $(OBJDUMP) -t $< > $@
  1484. u-boot.sym: u-boot FORCE
  1485. $(call if_changed,sym)
  1486. # Environment processing
  1487. # ---------------------------------------------------------------------------
  1488. # Directory where we expect the .env file, if it exists
  1489. ENV_DIR := $(srctree)/board/$(BOARDDIR)
  1490. # Basename of .env file, stripping quotes
  1491. ENV_SOURCE_FILE := $(CONFIG_ENV_SOURCE_FILE:"%"=%)
  1492. # Filename of .env file
  1493. ENV_FILE_CFG := $(ENV_DIR)/$(ENV_SOURCE_FILE).env
  1494. # Default filename, if CONFIG_ENV_SOURCE_FILE is empty
  1495. ENV_FILE_BOARD := $(ENV_DIR)/$(CONFIG_SYS_BOARD:"%"=%).env
  1496. # Select between the CONFIG_ENV_SOURCE_FILE and the default one
  1497. ENV_FILE := $(if $(ENV_SOURCE_FILE),$(ENV_FILE_CFG),$(wildcard $(ENV_FILE_BOARD)))
  1498. # Run the environment text file through the preprocessor, but only if it is
  1499. # non-empty, to save time and possible build errors if something is wonky with
  1500. # the board.
  1501. # If there is no ENV_FILE, produce an empty output file, to prevent a previous
  1502. # build's file being used in the case of in-tree builds.
  1503. quiet_cmd_gen_envp = ENVP $@
  1504. cmd_gen_envp = \
  1505. if [ -s "$(ENV_FILE)" ]; then \
  1506. $(CPP) -P $(CFLAGS) -x assembler-with-cpp -undef \
  1507. -D__ASSEMBLY__ \
  1508. -D__UBOOT_CONFIG__ \
  1509. -I . -I include -I $(srctree)/include \
  1510. -include linux/kconfig.h -include include/config.h \
  1511. -I$(srctree)/arch/$(ARCH)/include \
  1512. $< -o $@; \
  1513. else \
  1514. rm -f $@; \
  1515. touch $@ ; \
  1516. fi
  1517. include/generated/env.in: include/generated/env.txt
  1518. $(call cmd,gen_envp)
  1519. # Regenerate the environment if it changes
  1520. # We use 'wildcard' since the file is not required to exist (at present), in
  1521. # which case we don't want this dependency, but instead should create an empty
  1522. # file
  1523. # This rule is useful since it shows the source file for the environment
  1524. quiet_cmd_envc = ENVC $@
  1525. cmd_envc = \
  1526. if [ -f "$<" ]; then \
  1527. cat $< > $@; \
  1528. elif [ -n "$(ENV_SOURCE_FILE)" ]; then \
  1529. echo "Missing file $(ENV_FILE_CFG)"; \
  1530. else \
  1531. touch $@ ; \
  1532. fi
  1533. include/generated/env.txt: $(wildcard $(ENV_FILE)) include/generated/autoconf.h
  1534. $(call cmd,envc)
  1535. # Write out the resulting environment, converted to a C string
  1536. quiet_cmd_gen_envt = ENVT $@
  1537. cmd_gen_envt = \
  1538. awk -f $(srctree)/scripts/env2string.awk $< >$@
  1539. $(env_h): include/generated/env.in
  1540. $(call cmd,gen_envt)
  1541. # ---------------------------------------------------------------------------
  1542. # The actual objects are generated when descending,
  1543. # make sure no implicit rule kicks in
  1544. $(sort $(u-boot-init) $(u-boot-main)): $(u-boot-dirs) ;
  1545. # Handle descending into subdirectories listed in $(u-boot-dirs)
  1546. # Preset locale variables to speed up the build process. Limit locale
  1547. # tweaks to this spot to avoid wrong language settings when running
  1548. # make menuconfig etc.
  1549. # Error messages still appears in the original language
  1550. PHONY += $(u-boot-dirs)
  1551. $(u-boot-dirs): prepare scripts
  1552. $(Q)$(MAKE) $(build)=$@
  1553. tools: prepare
  1554. # The "tools" are needed early
  1555. $(filter-out tools, $(u-boot-dirs)): tools
  1556. # The "examples" conditionally depend on U-Boot (say, when USE_PRIVATE_LIBGCC
  1557. # is "yes"), so compile examples after U-Boot is compiled.
  1558. examples: $(filter-out examples, $(u-boot-dirs))
  1559. define filechk_uboot.release
  1560. echo "$(UBOOTVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
  1561. endef
  1562. # Store (new) UBOOTRELEASE string in include/config/uboot.release
  1563. include/config/uboot.release: include/config/auto.conf FORCE
  1564. $(call filechk,uboot.release)
  1565. # Things we need to do before we recursively start building the kernel
  1566. # or the modules are listed in "prepare".
  1567. # A multi level approach is used. prepareN is processed before prepareN-1.
  1568. # archprepare is used in arch Makefiles and when processed asm symlink,
  1569. # version.h and scripts_basic is processed / created.
  1570. # Listed in dependency order
  1571. PHONY += prepare archprepare prepare0 prepare1 prepare2 prepare3
  1572. # prepare3 is used to check if we are building in a separate output directory,
  1573. # and if so do:
  1574. # 1) Check that make has not been executed in the kernel src $(srctree)
  1575. prepare3: include/config/uboot.release
  1576. ifneq ($(KBUILD_SRC),)
  1577. @$(kecho) ' Using $(srctree) as source for U-Boot'
  1578. $(Q)if [ -f $(srctree)/.config -o -d $(srctree)/include/config ]; then \
  1579. echo >&2 " $(srctree) is not clean, please run 'make mrproper'"; \
  1580. echo >&2 " in the '$(srctree)' directory.";\
  1581. /bin/false; \
  1582. fi;
  1583. endif
  1584. # prepare2 creates a makefile if using a separate output directory
  1585. prepare2: prepare3 outputmakefile cfg
  1586. prepare1: prepare2 $(version_h) $(timestamp_h) $(dt_h) $(env_h) \
  1587. include/config/auto.conf
  1588. ifeq ($(wildcard $(LDSCRIPT)),)
  1589. @echo >&2 " Could not find linker script."
  1590. @/bin/false
  1591. endif
  1592. ifeq ($(CONFIG_USE_DEFAULT_ENV_FILE),y)
  1593. prepare1: $(defaultenv_h)
  1594. envtools: $(defaultenv_h)
  1595. endif
  1596. archprepare: prepare1 scripts_basic
  1597. prepare0: archprepare FORCE
  1598. $(Q)$(MAKE) $(build)=.
  1599. # All the preparing..
  1600. prepare: prepare0
  1601. # Generate some files
  1602. # ---------------------------------------------------------------------------
  1603. # Use sed to remove leading zeros from PATCHLEVEL to avoid using octal numbers
  1604. define filechk_version.h
  1605. (echo \#define PLAIN_VERSION \"$(UBOOTRELEASE)\"; \
  1606. echo \#define U_BOOT_VERSION \"U-Boot \" PLAIN_VERSION; \
  1607. echo \#define U_BOOT_VERSION_NUM $(VERSION); \
  1608. echo \#define U_BOOT_VERSION_NUM_PATCH $$(echo $(PATCHLEVEL) | \
  1609. sed -e "s/^0*//"); \
  1610. echo \#define HOST_ARCH $(HOST_ARCH); \
  1611. echo \#define CC_VERSION_STRING \"$$(LC_ALL=C $(CC) --version | head -n 1)\"; \
  1612. echo \#define LD_VERSION_STRING \"$$(LC_ALL=C $(LD) --version | head -n 1)\"; )
  1613. endef
  1614. # The SOURCE_DATE_EPOCH mechanism requires a date that behaves like GNU date.
  1615. # The BSD date on the other hand behaves different and would produce errors
  1616. # with the misused '-d' switch. Respect that and search a working date with
  1617. # well known pre- and suffixes for the GNU variant of date.
  1618. define filechk_timestamp.h
  1619. (if test -n "$${SOURCE_DATE_EPOCH}"; then \
  1620. SOURCE_DATE="@$${SOURCE_DATE_EPOCH}"; \
  1621. DATE=""; \
  1622. for date in gdate date.gnu date; do \
  1623. $${date} -u -d "$${SOURCE_DATE}" >/dev/null 2>&1 && DATE="$${date}"; \
  1624. done; \
  1625. if test -n "$${DATE}"; then \
  1626. LC_ALL=C $${DATE} -u -d "$${SOURCE_DATE}" +'#define U_BOOT_DATE "%b %d %C%y"'; \
  1627. LC_ALL=C $${DATE} -u -d "$${SOURCE_DATE}" +'#define U_BOOT_TIME "%T"'; \
  1628. LC_ALL=C $${DATE} -u -d "$${SOURCE_DATE}" +'#define U_BOOT_TZ "%z"'; \
  1629. LC_ALL=C $${DATE} -u -d "$${SOURCE_DATE}" +'#define U_BOOT_EPOCH %s'; \
  1630. else \
  1631. return 42; \
  1632. fi; \
  1633. else \
  1634. LC_ALL=C date +'#define U_BOOT_DATE "%b %d %C%y"'; \
  1635. LC_ALL=C date +'#define U_BOOT_TIME "%T"'; \
  1636. LC_ALL=C date +'#define U_BOOT_TZ "%z"'; \
  1637. LC_ALL=C date +'#define U_BOOT_EPOCH %s'; \
  1638. fi)
  1639. endef
  1640. define filechk_defaultenv.h
  1641. ( { grep -v '^#' | grep -v '^$$' || true ; echo '' ; } | \
  1642. tr '\n' '\0' | \
  1643. sed -e 's/\\\x0\s*//g' | \
  1644. xxd -i ; )
  1645. endef
  1646. define filechk_dt.h
  1647. (if test -n "$${DEVICE_TREE}"; then \
  1648. echo \#define DEVICE_TREE \"$(DEVICE_TREE)\"; \
  1649. else \
  1650. echo \#define DEVICE_TREE CONFIG_DEFAULT_DEVICE_TREE; \
  1651. fi)
  1652. endef
  1653. $(version_h): include/config/uboot.release FORCE
  1654. $(call filechk,version.h)
  1655. $(timestamp_h): $(srctree)/Makefile FORCE
  1656. $(call filechk,timestamp.h)
  1657. $(dt_h): $(srctree)/Makefile FORCE
  1658. $(call filechk,dt.h)
  1659. $(defaultenv_h): $(CONFIG_DEFAULT_ENV_FILE:"%"=%) FORCE
  1660. $(call filechk,defaultenv.h)
  1661. # ---------------------------------------------------------------------------
  1662. # Devicetree files
  1663. ifneq ($(wildcard $(srctree)/arch/$(SRCARCH)/boot/dts/),)
  1664. dtstree := arch/$(SRCARCH)/boot/dts
  1665. endif
  1666. ifneq ($(dtstree),)
  1667. %.dtb: prepare3 scripts_dtc
  1668. $(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@
  1669. PHONY += dtbs dtbs_install
  1670. dtbs: prepare3 scripts_dtc
  1671. $(Q)$(MAKE) $(build)=$(dtstree)
  1672. dtbs_install:
  1673. $(Q)$(MAKE) $(dtbinst)=$(dtstree)
  1674. endif
  1675. # Check dtc and pylibfdt, if DTC is provided, else build them
  1676. PHONY += scripts_dtc
  1677. scripts_dtc: scripts_basic
  1678. $(Q)if test "$(DTC)" = "$(DTC_INTREE)"; then \
  1679. $(MAKE) $(build)=scripts/dtc; \
  1680. else \
  1681. if ! $(DTC) -v >/dev/null; then \
  1682. echo '*** Failed to check dtc version: $(DTC)'; \
  1683. false; \
  1684. else \
  1685. if test "$(call dtc-version)" -lt $(DTC_MIN_VERSION); then \
  1686. echo '*** Your dtc is too old, please upgrade to dtc $(DTC_MIN_VERSION) or newer'; \
  1687. false; \
  1688. else \
  1689. if [ -n "$(CONFIG_PYLIBFDT)" ]; then \
  1690. if ! echo "import libfdt" | $(PYTHON3) 2>/dev/null; then \
  1691. echo '*** pylibfdt does not seem to be available with $(PYTHON3)'; \
  1692. false; \
  1693. fi; \
  1694. fi; \
  1695. fi; \
  1696. fi; \
  1697. fi
  1698. # ---------------------------------------------------------------------------
  1699. quiet_cmd_cpp_lds = LDS $@
  1700. cmd_cpp_lds = $(CPP) -Wp,-MD,$(depfile) $(cpp_flags) $(LDPPFLAGS) \
  1701. -D__ASSEMBLY__ -x assembler-with-cpp -std=c99 -P -o $@ $<
  1702. u-boot.lds: $(LDSCRIPT) prepare FORCE
  1703. $(call if_changed_dep,cpp_lds)
  1704. spl/u-boot-spl.bin: spl/u-boot-spl
  1705. @:
  1706. $(SPL_SIZE_CHECK)
  1707. spl/u-boot-spl-dtb.bin: spl/u-boot-spl
  1708. @:
  1709. spl/u-boot-spl-dtb.hex: spl/u-boot-spl
  1710. @:
  1711. spl/u-boot-spl: tools prepare $(if $(CONFIG_SPL_OF_CONTROL),dts/dt.dtb)
  1712. $(Q)$(MAKE) obj=spl -f $(srctree)/scripts/Makefile.spl all
  1713. spl/sunxi-spl.bin: spl/u-boot-spl
  1714. @:
  1715. spl/sunxi-spl-with-ecc.bin: spl/sunxi-spl.bin
  1716. @:
  1717. spl/u-boot-spl.sfp: spl/u-boot-spl
  1718. @:
  1719. spl/boot.bin: spl/u-boot-spl
  1720. @:
  1721. tpl/u-boot-tpl.bin: tpl/u-boot-tpl
  1722. @:
  1723. $(TPL_SIZE_CHECK)
  1724. tpl/u-boot-tpl: tools prepare $(if $(CONFIG_TPL_OF_CONTROL),dts/dt.dtb)
  1725. $(Q)$(MAKE) obj=tpl -f $(srctree)/scripts/Makefile.spl all
  1726. vpl/u-boot-vpl.bin: vpl/u-boot-vpl
  1727. @:
  1728. $(VPL_SIZE_CHECK)
  1729. vpl/u-boot-vpl: tools prepare $(if $(CONFIG_TPL_OF_CONTROL),dts/dt.dtb)
  1730. $(Q)$(MAKE) obj=vpl -f $(srctree)/scripts/Makefile.spl all
  1731. TAG_SUBDIRS := $(patsubst %,$(srctree)/%,$(u-boot-dirs) include)
  1732. FIND := find
  1733. FINDFLAGS := -L
  1734. tags ctags:
  1735. ctags -w -o ctags `$(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) \
  1736. -name '*.[chS]' -print`
  1737. ln -s ctags tags
  1738. etags:
  1739. etags -a -o etags `$(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) \
  1740. -name '*.[chS]' -print`
  1741. cscope:
  1742. $(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) -name '*.[chS]' -print > \
  1743. cscope.files
  1744. @find $(TAG_SUBDIRS) -name '*.[chS]' -type l -print | \
  1745. grep -xvf - cscope.files > cscope.files.no-symlinks; \
  1746. mv cscope.files.no-symlinks cscope.files
  1747. cscope -b -q -k
  1748. SYSTEM_MAP = \
  1749. $(NM) $1 | \
  1750. grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \
  1751. LC_ALL=C sort
  1752. System.map: u-boot
  1753. @$(call SYSTEM_MAP,$<) > $@
  1754. #########################################################################
  1755. # ARM relocations should all be R_ARM_RELATIVE (32-bit) or
  1756. # R_AARCH64_RELATIVE (64-bit).
  1757. checkarmreloc: u-boot
  1758. @RELOC="`$(CROSS_COMPILE)readelf -r -W $< | cut -d ' ' -f 4 | \
  1759. grep R_A | sort -u`"; \
  1760. if test "$$RELOC" != "R_ARM_RELATIVE" -a \
  1761. "$$RELOC" != "R_AARCH64_RELATIVE"; then \
  1762. echo "$< contains unexpected relocations: $$RELOC"; \
  1763. false; \
  1764. fi
  1765. tools/version.h: include/version.h
  1766. $(Q)mkdir -p $(dir $@)
  1767. $(call if_changed,copy)
  1768. envtools: u-boot-initial-env scripts_basic $(version_h) $(timestamp_h) tools/version.h
  1769. $(Q)$(MAKE) $(build)=tools/env
  1770. tools-only: export TOOLS_ONLY=y
  1771. tools-only: scripts_basic $(version_h) $(timestamp_h) tools/version.h
  1772. $(Q)$(MAKE) $(build)=tools
  1773. tools-all: export HOST_TOOLS_ALL=y
  1774. tools-all: envtools tools ;
  1775. cross_tools: export CROSS_BUILD_TOOLS=y
  1776. cross_tools: tools ;
  1777. .PHONY : CHANGELOG
  1778. CHANGELOG:
  1779. git log --no-merges U-Boot-1_1_5.. | \
  1780. unexpand -a | sed -e 's/\s\s*$$//' > $@
  1781. #########################################################################
  1782. ###
  1783. # Cleaning is done on three levels.
  1784. # make clean Delete most generated files
  1785. # Leave enough to build external modules
  1786. # make mrproper Delete the current configuration, and all generated files
  1787. # make distclean Remove editor backup files, patch leftover files and the like
  1788. # Directories & files removed with 'make clean'
  1789. CLEAN_DIRS += $(MODVERDIR) \
  1790. $(foreach d, spl tpl vpl, $(patsubst %,$d/%, \
  1791. $(filter-out include, $(shell ls -1 $d 2>/dev/null))))
  1792. CLEAN_FILES += include/autoconf.mk* include/bmp_logo.h include/bmp_logo_data.h \
  1793. include/config.h include/generated/env.* drivers/video/u_boot_logo.S \
  1794. tools/version.h u-boot* MLO* SPL System.map fit-dtb.blob* \
  1795. u-boot-ivt.img.log u-boot-dtb.imx.log SPL.log u-boot.imx.log \
  1796. lpc32xx-* bl31.c bl31.elf bl31_*.bin image.map tispl.bin* \
  1797. idbloader.img flash.bin flash.log defconfig keep-syms-lto.c \
  1798. mkimage-out.spl.mkimage mkimage.spl.mkimage imx-boot.map \
  1799. itb.fit.fit itb.fit.itb itb.map spl.map mkimage-out.rom.mkimage \
  1800. mkimage.rom.mkimage mkimage-in-simple-bin* rom.map simple-bin* \
  1801. idbloader-spi.img lib/efi_loader/helloworld_efi.S *.itb \
  1802. Test* capsule.*.efi-capsule capsule*.map
  1803. # Directories & files removed with 'make mrproper'
  1804. MRPROPER_DIRS += include/config include/generated spl tpl vpl \
  1805. .tmp_objdiff doc/output include/asm
  1806. # Remove include/asm symlink created by U-Boot before v2014.01
  1807. MRPROPER_FILES += .config .config.old include/autoconf.mk* include/config.h \
  1808. ctags etags tags TAGS cscope* GPATH GTAGS GRTAGS GSYMS \
  1809. drivers/video/fonts/*.S include/asm
  1810. # clean - Delete most, but leave enough to build external modules
  1811. #
  1812. clean: rm-dirs := $(CLEAN_DIRS)
  1813. clean: rm-files := $(CLEAN_FILES)
  1814. clean-dirs := $(foreach f,$(u-boot-alldirs),$(if $(wildcard $(srctree)/$f/Makefile),$f))
  1815. clean-dirs := $(addprefix _clean_, $(clean-dirs))
  1816. PHONY += $(clean-dirs) clean archclean
  1817. $(clean-dirs):
  1818. $(Q)$(MAKE) $(clean)=$(patsubst _clean_%,%,$@)
  1819. clean: $(clean-dirs)
  1820. $(call cmd,rmdirs)
  1821. $(call cmd,rmfiles)
  1822. @find $(if $(KBUILD_EXTMOD), $(KBUILD_EXTMOD), .) $(RCS_FIND_IGNORE) \
  1823. \( -name '*.[oas]' -o -name '*.ko' -o -name '.*.cmd' \
  1824. -o -name '*.ko.*' -o -name '*.su' -o -name '*.pyc' \
  1825. -o -name '*.dtb' -o -name '*.dtbo' \
  1826. -o -name '*.dtb.S' -o -name '*.dtbo.S' \
  1827. -o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \
  1828. -o -name '*.lex.c' -o -name '*.tab.[ch]' \
  1829. -o -name '*.asn1.[ch]' \
  1830. -o -name '*.symtypes' -o -name 'modules.order' \
  1831. -o -name modules.builtin -o -name '.tmp_*.o.*' \
  1832. -o -name 'dsdt_generated.aml' -o -name 'dsdt_generated.asl.tmp' \
  1833. -o -name 'dsdt_generated.c' \
  1834. -o -name 'generated_defconfig' \
  1835. -o -name '*.efi' -o -name '*.gcno' -o -name '*.so' \) \
  1836. -type f -print | xargs rm -f
  1837. # mrproper - Delete all generated files, including .config
  1838. #
  1839. mrproper: rm-dirs := $(wildcard $(MRPROPER_DIRS))
  1840. mrproper: rm-files := $(wildcard $(MRPROPER_FILES))
  1841. mrproper-dirs := $(addprefix _mrproper_,scripts)
  1842. PHONY += $(mrproper-dirs) mrproper archmrproper
  1843. $(mrproper-dirs):
  1844. $(Q)$(MAKE) $(clean)=$(patsubst _mrproper_%,%,$@)
  1845. mrproper: clean $(mrproper-dirs)
  1846. $(call cmd,rmdirs)
  1847. $(call cmd,rmfiles)
  1848. @rm -f arch/*/include/asm/arch
  1849. # distclean
  1850. #
  1851. PHONY += distclean
  1852. distclean: mrproper
  1853. @find $(srctree) $(RCS_FIND_IGNORE) \
  1854. \( -name '*.orig' -o -name '*.rej' -o -name '*~' \
  1855. -o -name '*.bak' -o -name '#*#' -o -name '.*.orig' \
  1856. -o -name '.*.rej' -o -name '*%' -o -name 'core' \
  1857. -o -name '*.pyc' \) \
  1858. -type f -print | xargs rm -f
  1859. @rm -f boards.cfg CHANGELOG
  1860. # See doc/develop/python_cq.rst
  1861. PHONY += pylint pylint_err
  1862. PYLINT_BASE := scripts/pylint.base
  1863. PYLINT_CUR := pylint.cur
  1864. PYLINT_DIFF := pylint.diff
  1865. pylint:
  1866. $(Q)echo "Running pylint on all files (summary in $(PYLINT_CUR); output in pylint.out/)"
  1867. $(Q)mkdir -p pylint.out
  1868. $(Q)rm -f pylint.out/out*
  1869. $(Q)find tools test -name "*.py" \
  1870. | xargs -n1 -P$(shell nproc 2>/dev/null || echo 1) \
  1871. sh -c 'pylint --reports=y --exit-zero -f parseable --ignore-imports=yes $$@ > pylint.out/$$(echo $$@ | tr / _ | sed s/.py//)' _
  1872. $(Q)rm -f $(PYLINT_CUR)
  1873. $(Q)( cd pylint.out; for f in *; do \
  1874. sed -ne "s/Your code has been rated at \([-0-9.]*\).*/$$f \1/p" $$f; \
  1875. done ) | sort > $(PYLINT_CUR)
  1876. $(Q)base=$$(mktemp) cur=$$(mktemp); cut -d' ' -f1 $(PYLINT_BASE) >$$base; \
  1877. cut -d' ' -f1 $(PYLINT_CUR) >$$cur; \
  1878. comm -3 $$base $$cur > $(PYLINT_DIFF); \
  1879. if [ -s $(PYLINT_DIFF) ]; then \
  1880. echo "Files have been added/removed. Try:\n\tcp $(PYLINT_CUR) $(PYLINT_BASE)"; \
  1881. echo; \
  1882. echo "Added files:"; \
  1883. comm -13 $$base $$cur; \
  1884. echo; \
  1885. echo "Removed files:"; \
  1886. comm -23 $$base $$cur; \
  1887. false; \
  1888. else \
  1889. rm $$base $$cur $(PYLINT_DIFF); \
  1890. fi
  1891. $(Q)bad=false; while read base_file base_val <&3 && read cur_file cur_val <&4; do \
  1892. if awk "BEGIN {exit !($$cur_val < $$base_val)}"; then \
  1893. echo "$$base_file: Score was $$base_val, now $$cur_val"; \
  1894. bad=true; fi; \
  1895. done 3<$(PYLINT_BASE) 4<$(PYLINT_CUR); \
  1896. if $$bad; then \
  1897. echo "Some files have regressed, please fix"; \
  1898. false; \
  1899. else \
  1900. echo "No pylint regressions"; \
  1901. fi
  1902. # Check for errors only
  1903. pylint_err:
  1904. $(Q)pylint -E -j 0 --ignore-imports=yes \
  1905. $(shell find tools test -name "*.py")
  1906. backup:
  1907. F=`basename $(srctree)` ; cd .. ; \
  1908. gtar --force-local -zcvf `LC_ALL=C date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
  1909. PHONY += _pip pip pip_release
  1910. pip_release: PIP_ARGS="--real"
  1911. pip_test: PIP_ARGS=""
  1912. pip: PIP_ARGS="-n"
  1913. pip pip_test pip_release: _pip
  1914. _pip:
  1915. scripts/make_pip.sh u_boot_pylib ${PIP_ARGS}
  1916. scripts/make_pip.sh patman ${PIP_ARGS}
  1917. scripts/make_pip.sh buildman ${PIP_ARGS}
  1918. scripts/make_pip.sh dtoc ${PIP_ARGS}
  1919. scripts/make_pip.sh binman ${PIP_ARGS}
  1920. help:
  1921. @echo 'Cleaning targets:'
  1922. @echo ' clean - Remove most generated files but keep the config'
  1923. @echo ' mrproper - Remove all generated files + config + various backup files'
  1924. @echo ' distclean - mrproper + remove editor backup and patch files'
  1925. @echo ''
  1926. @echo 'Configuration targets:'
  1927. @$(MAKE) -f $(srctree)/scripts/kconfig/Makefile help
  1928. @echo ''
  1929. @echo 'Test targets:'
  1930. @echo ''
  1931. @echo ' check - Run all automated tests that use sandbox'
  1932. @echo ' pcheck - Run quick automated tests in parallel'
  1933. @echo ' qcheck - Run quick automated tests that use sandbox'
  1934. @echo ' tcheck - Run quick automated tests on tools'
  1935. @echo ' pylint - Run pylint on all Python files'
  1936. @echo ''
  1937. @echo 'Other generic targets:'
  1938. @echo ' all - Build all necessary images depending on configuration'
  1939. @echo ' tests - Build U-Boot for sandbox and run tests'
  1940. @echo '* u-boot - Build the bare u-boot'
  1941. @echo ' dir/ - Build all files in dir and below'
  1942. @echo ' dir/file.[oisS] - Build specified target only'
  1943. @echo ' dir/file.lst - Build specified mixed source/assembly target only'
  1944. @echo ' (requires a recent binutils and recent build (System.map))'
  1945. @echo ' tags/ctags - Generate ctags file for editors'
  1946. @echo ' etags - Generate etags file for editors'
  1947. @echo ' cscope - Generate cscope index'
  1948. @echo ' ubootrelease - Output the release version string (use with make -s)'
  1949. @echo ' ubootversion - Output the version stored in Makefile (use with make -s)'
  1950. @echo " cfg - Don't build, just create the .cfg files"
  1951. @echo " envtools - Build only the target-side environment tools"
  1952. @echo ''
  1953. @echo 'PyPi / pip targets:'
  1954. @echo ' pip - Check building of PyPi packages'
  1955. @echo ' pip_test - Build PyPi pakages and upload to test server'
  1956. @echo ' pip_release - Build PyPi pakages and upload to release server'
  1957. @echo ''
  1958. @echo 'Static analysers'
  1959. @echo ' checkstack - Generate a list of stack hogs'
  1960. @echo ' coccicheck - Execute static code analysis with Coccinelle'
  1961. @echo ''
  1962. @echo 'Documentation targets:'
  1963. @$(MAKE) -f $(srctree)/doc/Makefile dochelp
  1964. @echo ''
  1965. @echo ' make V=0|1 [targets] 0 => quiet build (default), 1 => verbose build'
  1966. @echo ' make V=2 [targets] 2 => give reason for rebuild of target'
  1967. @echo ' make O=dir [targets] Locate all output files in "dir", including .config'
  1968. @echo ' make C=1 [targets] Check all c source with $$CHECK (sparse by default)'
  1969. @echo ' make C=2 [targets] Force check of all c source with $$CHECK'
  1970. @echo ' make RECORDMCOUNT_WARN=1 [targets] Warn about ignored mcount sections'
  1971. @echo ' make W=n [targets] Enable extra gcc checks, n=1,2,3 where'
  1972. @echo ' 1: warnings which may be relevant and do not occur too often'
  1973. @echo ' 2: warnings which occur quite often but may still be relevant'
  1974. @echo ' 3: more obscure warnings, can most likely be ignored'
  1975. @echo ' Multiple levels can be combined with W=12 or W=123'
  1976. @echo ''
  1977. @echo 'Execute "make" or "make all" to build all targets marked with [*] '
  1978. @echo 'For further info see the ./README file'
  1979. tests check:
  1980. $(srctree)/test/run
  1981. pcheck:
  1982. $(srctree)/test/run parallel
  1983. qcheck:
  1984. $(srctree)/test/run quick
  1985. tcheck:
  1986. $(srctree)/test/run tools
  1987. # Documentation targets
  1988. # ---------------------------------------------------------------------------
  1989. DOC_TARGETS := xmldocs latexdocs pdfdocs htmldocs epubdocs cleandocs \
  1990. linkcheckdocs dochelp refcheckdocs texinfodocs infodocs
  1991. PHONY += $(DOC_TARGETS)
  1992. $(DOC_TARGETS): scripts_basic FORCE
  1993. $(Q)$(MAKE) $(build)=doc $@
  1994. PHONY += checkstack ubootrelease ubootversion
  1995. checkstack:
  1996. $(OBJDUMP) -d u-boot $$(find . -name u-boot-spl) | \
  1997. $(PERL) $(src)/scripts/checkstack.pl $(ARCH)
  1998. ubootrelease:
  1999. @echo "$(UBOOTVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
  2000. ubootversion:
  2001. @echo $(UBOOTVERSION)
  2002. # Single targets
  2003. # ---------------------------------------------------------------------------
  2004. # Single targets are compatible with:
  2005. # - build with mixed source and output
  2006. # - build with separate output dir 'make O=...'
  2007. # - external modules
  2008. #
  2009. # target-dir => where to store outputfile
  2010. # build-dir => directory in kernel source tree to use
  2011. ifeq ($(KBUILD_EXTMOD),)
  2012. build-dir = $(patsubst %/,%,$(dir $@))
  2013. target-dir = $(dir $@)
  2014. else
  2015. zap-slash=$(filter-out .,$(patsubst %/,%,$(dir $@)))
  2016. build-dir = $(KBUILD_EXTMOD)$(if $(zap-slash),/$(zap-slash))
  2017. target-dir = $(if $(KBUILD_EXTMOD),$(dir $<),$(dir $@))
  2018. endif
  2019. %.s: %.c prepare scripts FORCE
  2020. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2021. %.i: %.c prepare scripts FORCE
  2022. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2023. %.o: %.c prepare scripts FORCE
  2024. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2025. %.lst: %.c prepare scripts FORCE
  2026. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2027. %.s: %.S prepare scripts FORCE
  2028. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2029. %.o: %.S prepare scripts FORCE
  2030. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2031. %.symtypes: %.c prepare scripts FORCE
  2032. $(Q)$(MAKE) $(build)=$(build-dir) $(target-dir)$(notdir $@)
  2033. # Modules
  2034. /: prepare scripts FORCE
  2035. $(cmd_crmodverdir)
  2036. $(Q)$(MAKE) KBUILD_MODULES=$(if $(CONFIG_MODULES),1) \
  2037. $(build)=$(build-dir)
  2038. %/: prepare scripts FORCE
  2039. $(cmd_crmodverdir)
  2040. $(Q)$(MAKE) KBUILD_MODULES=$(if $(CONFIG_MODULES),1) \
  2041. $(build)=$(build-dir)
  2042. %.ko: prepare scripts FORCE
  2043. $(cmd_crmodverdir)
  2044. $(Q)$(MAKE) KBUILD_MODULES=$(if $(CONFIG_MODULES),1) \
  2045. $(build)=$(build-dir) $(@:.ko=.o)
  2046. $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
  2047. quiet_cmd_genenv = GENENV $@
  2048. cmd_genenv = \
  2049. $(objtree)/tools/printinitialenv | \
  2050. sed -e '/^\s*$$/d' | \
  2051. sort -t '=' -k 1,1 -s -o $@
  2052. u-boot-initial-env: scripts_basic $(env_h) FORCE
  2053. $(Q)$(MAKE) $(build)=tools $(objtree)/tools/printinitialenv
  2054. $(call if_changed,genenv)
  2055. # Consistency checks
  2056. # ---------------------------------------------------------------------------
  2057. PHONY += coccicheck
  2058. coccicheck:
  2059. $(Q)$(CONFIG_SHELL) $(srctree)/scripts/$@
  2060. # FIXME Should go into a make.lib or something
  2061. # ===========================================================================
  2062. quiet_cmd_rmdirs = $(if $(wildcard $(rm-dirs)),CLEAN $(wildcard $(rm-dirs)))
  2063. cmd_rmdirs = rm -rf $(rm-dirs)
  2064. quiet_cmd_rmfiles = $(if $(wildcard $(rm-files)),CLEAN $(wildcard $(rm-files)))
  2065. cmd_rmfiles = rm -f $(rm-files)
  2066. # read all saved command lines
  2067. cmd_files := $(wildcard .*.cmd)
  2068. ifneq ($(cmd_files),)
  2069. $(cmd_files): ; # Do not try to update included dependency files
  2070. include $(cmd_files)
  2071. endif
  2072. endif #ifeq ($(config-targets),1)
  2073. endif #ifeq ($(mixed-targets),1)
  2074. endif # skip-makefile
  2075. PHONY += FORCE
  2076. FORCE:
  2077. # Declare the contents of the PHONY variable as phony. We keep that
  2078. # information in a variable so we can use it in if_changed and friends.
  2079. .PHONY: $(PHONY)