Makefile.fpc 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. #
  2. # Makefile.fpc for Free Pascal Compiler
  3. #
  4. [package]
  5. name=compiler
  6. version=1.9.0
  7. [target]
  8. dirs=utils
  9. [compiler]
  10. targetdir=$(CPU_UNITDIR)
  11. unitdir=$(COMPILERSOURCEDIR)
  12. includedir=$(PPC_TARGET)
  13. [require]
  14. packages=rtl
  15. tools=diff cmp
  16. [install]
  17. fpcpackage=y
  18. [default]
  19. fpcdir=..
  20. [prerules]
  21. # Don't export version it can change after the first compile
  22. unexport FPC_VERSION FPC_COMPILERINFO
  23. # Which platforms are ready for inclusion in the cycle
  24. CYCLETARGETS=i386 powerpc sparc
  25. # Allow ALPHA, POWERPC, M68K, I386 defines for target cpu
  26. ifdef ALPHA
  27. PPC_TARGET=alpha
  28. endif
  29. ifdef POWERPC
  30. PPC_TARGET=powerpc
  31. endif
  32. ifdef SPARC
  33. PPC_TARGET=sparc
  34. endif
  35. ifdef M68K
  36. PPC_TARGET=m68k
  37. endif
  38. ifdef I386
  39. PPC_TARGET=i386
  40. endif
  41. ifdef X86_64
  42. PPC_TARGET=x86_64
  43. endif
  44. # Default is to generate a compiler for the same
  45. # platform as CPU_TARGET (a native compiler)
  46. ifndef PPC_TARGET
  47. PPC_TARGET=$(CPU_TARGET)
  48. endif
  49. # Default is to generate a compiler for the same
  50. # target as OS_TARGET (a native compiler)
  51. ifndef PPC_OS
  52. PPC_OS=$(OS_TARGET)
  53. endif
  54. # Where to place the unit files.
  55. CPU_UNITDIR=.
  56. # RTL
  57. UTILSDIR=../utils
  58. # Directories containing compiler sources
  59. COMPILERSOURCEDIR=$(PPC_TARGET) systems
  60. # Utils used by compiler development/installation
  61. COMPILERUTILSDIR=utils
  62. # Default language for the compiler
  63. ifndef FPCLANG
  64. FPCLANG=e
  65. endif
  66. # Local defines for the compiler only
  67. ifndef LOCALDEF
  68. LOCALDEF=
  69. endif
  70. # Local options for the compiler only
  71. ifndef LOCALOPT
  72. LOCALOPT=$(OPT)
  73. endif
  74. # Options for the RTL only when cycling
  75. ifndef RTLOPTS
  76. RTLOPTS=$(OPT)
  77. endif
  78. # Message files
  79. MSGFILES=$(wildcard msg/error*.msg)
  80. # ppcSUFFIX
  81. ifeq ($(PPC_TARGET),i386)
  82. CPUSUF=386
  83. endif
  84. ifeq ($(PPC_TARGET),alpha)
  85. CPUSUF=axp
  86. endif
  87. ifeq ($(PPC_TARGET),m68k)
  88. CPUSUF=68k
  89. endif
  90. ifeq ($(PPC_TARGET),powerpc)
  91. CPUSUF=ppc
  92. endif
  93. ifeq ($(PPC_TARGET),sparc)
  94. CPUSUF=sparc
  95. endif
  96. ifeq ($(PPC_TARGET),x86_64)
  97. CPUSUF=x64
  98. endif
  99. # Do not define the default -d$(CPU_TARGET) because that
  100. # will conflict with our -d$(PPC_TARGET)
  101. NOCPUDEF=1
  102. # Define Unix also for Linux
  103. ifeq ($(OS_TARGET),linux)
  104. ifneq ($(findstring 1.0.,$(FPC_VERSION)),)
  105. override LOCALDEF+=-dUNIX
  106. endif
  107. endif
  108. ifeq ($(OS_TARGET),freebsd)
  109. ifneq ($(findstring 1.0.,$(FPC_VERSION)),)
  110. override LOCALDEF+=-dUNIX
  111. endif
  112. endif
  113. # Default message file
  114. MSGFILE=msg/error$(FPCLANG).msg
  115. # set correct defines (-d$(CPU_TARGET) is automaticly added in makefile.fpc)
  116. override LOCALDEF+=-d$(PPC_TARGET) -dGDB -dBROWSERLOG
  117. # i386 specific
  118. ifeq ($(PPC_TARGET),i386)
  119. override LOCALDEF+=-Fux86
  120. endif
  121. # x86_64 specific
  122. ifeq ($(PPC_TARGET),x86_64)
  123. override LOCALDEF+=-Fux86 -dNOOPT
  124. endif
  125. # PowerPC specific
  126. ifeq ($(PPC_TARGET),powerpc)
  127. override LOCALDEF+=-dNOOPT
  128. endif
  129. # m68k specific
  130. ifeq ($(PPC_TARGET),m68k)
  131. override LOCALDEF+=-dNOOPT
  132. endif
  133. # Sparc specific
  134. ifeq ($(PPC_TARGET),sparc)
  135. override LOCALDEF+=-dNOOPT
  136. endif
  137. # m68k specific with low stack
  138. ifeq ($(PPC_TARGET),m68k)
  139. ifeq ($(OS_TARGET),amiga)
  140. override LOCALDEF+=-Ct
  141. endif
  142. endif
  143. ifeq ($(PPC_TARGET),m68k)
  144. ifeq ($(OS_TARGET),amiga)
  145. override LOCALDEF+=-Ct
  146. endif
  147. endif
  148. PASDOC:=$(strip $(wildcard $(addsuffix /pasdoc.exe,$(SEARCHPATH))))
  149. ifeq ($(PASDOC),)
  150. PASDOC:=$(strip $(wildcard $(addsuffix /pasdoc,$(SEARCHPATH))))
  151. endif
  152. ifeq ($(PASDOC),)
  153. PASDOC:=../projects/pasdoc/bin/pasdoc
  154. else
  155. PASDOC:=$(firstword $(PASDOC))
  156. endif
  157. override LOCALOPT+=$(LOCALDEF)
  158. override FPCOPT:=$(LOCALOPT)
  159. [rules]
  160. #####################################################################
  161. # Setup Targets
  162. #####################################################################
  163. ifeq ($(OS_TARGET),win32)
  164. ifdef CMP
  165. override DIFF:=$(CMP) -i218
  166. endif
  167. # force try to smartlink for windows unit
  168. override COMPILER+=-XX
  169. endif
  170. # Used to avoid unnecessary steps in remake3
  171. ifdef DIFF
  172. ifdef OLDFPC
  173. DIFFRESULT:=$(shell $(DIFF) $(OLDFPC) $(FPC))
  174. else
  175. DIFFRESULT=Not equal
  176. endif
  177. else
  178. DIFFRESULT=No diff program
  179. endif
  180. #####################################################################
  181. # Setup os-independent filenames
  182. #####################################################################
  183. ifndef EXENAME
  184. EXENAME=ppc$(CPUSUF)$(EXEEXT)
  185. endif
  186. PPEXENAME=pp$(EXEEXT)
  187. TEMPNAME=ppc$(SRCEXEEXT)
  188. PPCROSSNAME=ppcross$(CPUSUF)$(SRCEXEEXT)
  189. TEMPNAME1=ppc1$(EXEEXT)
  190. TEMPNAME2=ppc2$(EXEEXT)
  191. TEMPNAME3=ppc3$(EXEEXT)
  192. MAKEDEP=ppdep$(EXEEXT)
  193. MSG2INC=./msg2inc$(EXEEXT)
  194. #####################################################################
  195. # CPU targets
  196. #####################################################################
  197. .PHONY: alpha i386 m68k powerpc sparc
  198. alpha:
  199. $(MAKE) PPC_TARGET=alpha CPU_UNITDIR=alpha all
  200. i386:
  201. $(MAKE) PPC_TARGET=i386 CPU_UNITDIR=i386 all
  202. m68k:
  203. $(MAKE) PPC_TARGET=m68k CPU_UNITDIR=m68k all
  204. powerpc:
  205. $(MAKE) PPC_TARGET=powerpc CPU_UNITDIR=powerpc all
  206. sparc:
  207. $(MAKE) PPC_TARGET=sparc CPU_UNITDIR=sparc all
  208. #####################################################################
  209. # Default makefile
  210. #####################################################################
  211. .PHONY: all compiler echotime ppuclean execlean clean distclean
  212. all: $(EXENAME) $(addsuffix _all,$(TARGET_DIRS))
  213. compiler: $(EXENAME)
  214. ifeq ($(MAKELEVEL),0)
  215. ifndef STARTTIME
  216. ifdef DATE
  217. STARTTIME:=$(shell $(DATE) +%T)
  218. else
  219. STARTTIME:=unknown
  220. endif
  221. endif
  222. endif
  223. export STARTTIME
  224. ifdef DATE
  225. ENDTIME=$(shell $(DATE) +%T)
  226. else
  227. ENDTIME:=unknown
  228. endif
  229. echotime:
  230. @echo Start $(STARTTIME) now $(ENDTIME)
  231. ppuclean:
  232. -$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)
  233. -$(DEL) $(addsuffix /*$(PPUEXT),$(COMPILERSOURCEDIR))
  234. execlean :
  235. -$(DEL) ppc386$(EXEEXT) ppcaxp$(EXEEXT) ppc68k$(EXEEXT) ppcppc$(EXEEXT) ppcsparc$(EXEEXT) $(EXENAME)
  236. $(addsuffix _clean,$(CYCLETARGETS)):
  237. -$(DEL) $(addprefix $(subst _clean,,$@)/,*$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT))
  238. -$(DEL) $(addprefix $(subst _clean,,$@)/,ppc386$(EXEEXT) ppcaxp$(EXEEXT) ppc68k$(EXEEXT) ppcppc$(EXEEXT) ppcppc$(EXEEXT) $(EXENAME))
  239. clean : execlean fpc_cleanall $(addsuffix _clean,$(TARGET_DIRS)) $(addsuffix _clean,$(CYCLETARGETS))
  240. distclean: execlean fpc_cleanall $(addsuffix _distclean,$(TARGET_DIRS))
  241. -$(DEL) $(PPCROSSNAME) $(TEMPNAME) $(TEMPNAME1) $(TEMPNAME2) $(TEMPNAME3) $(MSG2INC)
  242. #####################################################################
  243. # Include depencies
  244. #####################################################################
  245. $(MAKEDEP): $(UTILSDIR)/ppdep.pp
  246. $(COMPILER) $(UTILSDIR)/ppdep.pp
  247. $(COPY) $(UTILSDIR)/$(MAKEDEP) $(MAKEDEP)
  248. dependencies : $(MAKEDEP)
  249. $(MAKEDEP) pp.pas $(FPCOPTDEF) $(LOCALDEF) '-F$$(COMPILER) $$(LOCALOPT)' > depend
  250. ifdef USEDEPEND
  251. include depend
  252. endif
  253. #####################################################################
  254. # Make targets
  255. #####################################################################
  256. $(MSG2INC): $(COMPILERUTILSDIR)/msg2inc.pp
  257. $(COMPILER) -FE. $(COMPILERUTILSDIR)/msg2inc.pp
  258. # The msgtxt.inc only depends on the error?.msg file, not on msg2inc,
  259. # because that one will be new almost everytime
  260. msgtxt.inc: $(MSGFILE)
  261. $(MAKE) $(MSG2INC)
  262. $(MSG2INC) $(MSGFILE) msg msg
  263. msg: msgtxt.inc
  264. # Make only the compiler
  265. ifndef COMPLETE
  266. $(EXENAME) : $(wildcard *.pas) $(wildcard *.inc) msg \
  267. $(wildcard systems/*.pas) $(wilcard systems/*.inc) \
  268. $(wildcard $(PPC_TARGET)/*.pas) $(wildcard $(PPC_TARGET)/*.inc)
  269. $(COMPILER) pp.pas
  270. $(EXECPPAS)
  271. $(MOVE) $(COMPILER_TARGETDIR)/$(PPEXENAME) $(EXENAME)
  272. else
  273. $(EXENAME) : $(wildcard *.pas) $(wildcard *.inc) msg \
  274. $(wildcard systems/*.pas) $(wilcard systems/*.inc) \
  275. $(wildcard $(PPC_TARGET)/*.pas) $(wildcard $(PPC_TARGET)/*.inc)
  276. $(COMPILER) pp.pas
  277. $(EXECPPAS)
  278. $(COMPILER) pp.pas
  279. $(EXECPPAS)
  280. $(COMPILER) pp.pas
  281. $(EXECPPAS)
  282. $(MOVE) $(COMPILER_TARGETDIR)/$(PPEXENAME) $(EXENAME)
  283. endif
  284. tokens.dat : $(wildcard *.pas) $(wildcard *.inc)
  285. $(COMPILER) tokendat.pas
  286. ./tokendat
  287. #####################################################################
  288. # Cycle targets
  289. #
  290. # 1. Source CPU = Target CPU and Source OS = Target OS
  291. # Normal cycle
  292. # 2. Source CPU = Target CPU and Source OS <> Target OS
  293. # First source native compiler
  294. # Second target native compiler
  295. #
  296. # 3. Source CPU <> Target CPU
  297. # First source native compiler
  298. # Second cross compiler
  299. # Third target native compiler
  300. #
  301. #####################################################################
  302. ifeq ($(CPU_SOURCE),$(PPC_TARGET))
  303. ifeq ($(OS_SOURCE),$(OS_TARGET))
  304. ##########################
  305. # Normal cycle
  306. #
  307. ifndef DIFFRESULT
  308. next :
  309. @echo $(OLDFPC) and $(FPC) are equal
  310. $(COPY) $(FPC) $(EXENAME)
  311. else
  312. next :
  313. $(MAKE) execlean
  314. $(MAKE) -C $(UNITDIR_RTL) clean
  315. $(MAKE) -C $(UNITDIR_RTL) 'FPC=$(FPC)' 'OPT=$(RTLOPTS)'
  316. $(MAKE) clean
  317. $(MAKE) $(EXENAME)
  318. $(MAKE) echotime
  319. endif
  320. $(TEMPNAME1) : $(EXENAME)
  321. -$(DEL) $(TEMPNAME1)
  322. $(MOVE) $(EXENAME) $(TEMPNAME1)
  323. $(TEMPNAME2) : $(TEMPNAME1)
  324. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME1)' 'OLDFPC=' next
  325. -$(DEL) $(TEMPNAME2)
  326. $(MOVE) $(EXENAME) $(TEMPNAME2)
  327. $(TEMPNAME3) : $(TEMPNAME2)
  328. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME2)' 'OLDFPC=$(BASEDIR)/$(TEMPNAME1)' next
  329. -$(DEL) $(TEMPNAME3)
  330. $(MOVE) $(EXENAME) $(TEMPNAME3)
  331. # This target remakes the units with the currently made version
  332. remake: $(EXENAME)
  333. $(MOVE) $(EXENAME) $(TEMPNAME)
  334. $(MAKE) execlean
  335. $(MAKE) -C $(UNITDIR_RTL) clean
  336. $(MAKE) clean
  337. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME)' all
  338. remake3: $(TEMPNAME3)
  339. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME3)' 'OLDFPC=$(BASEDIR)/$(TEMPNAME2)' next
  340. $(DIFF) $(TEMPNAME3) $(EXENAME)
  341. cycle:
  342. $(MAKE) clean
  343. $(MAKE) -C $(UNITDIR_RTL) clean
  344. $(MAKE) -C $(UNITDIR_RTL) 'OPT=$(RTLOPTS)' all
  345. $(MAKE) remake3
  346. $(MAKE) $(addsuffix _all,$(TARGET_DIRS)) 'FPC=$(BASEDIR)/$(EXENAME)'
  347. $(MAKE) echotime
  348. else
  349. ##########################
  350. # Cross Target cycle
  351. #
  352. cycle:
  353. # ppc (source native)
  354. $(MAKE) OS_TARGET=$(OS_SOURCE) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 rtlclean rtl
  355. $(MAKE) OS_TARGET=$(OS_SOURCE) EXENAME=$(TEMPNAME) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 clean compiler
  356. # ppcross<ARCH> (source native)
  357. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME)' OS_TARGET=$(OS_SOURCE) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 rtlclean rtl
  358. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME)' OS_TARGET=$(OS_SOURCE) EXENAME=$(PPCROSSNAME) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 clean compiler
  359. # ppc<ARCH> (target native)
  360. $(MAKE) 'FPC=$(BASEDIR)/$(PPCROSSNAME)' rtlclean rtl
  361. $(MAKE) 'FPC=$(BASEDIR)/$(PPCROSSNAME)' clean compiler
  362. endif
  363. else
  364. ##########################
  365. # Cross CPU cycle
  366. #
  367. # ppc1 = native
  368. # ppc2 = cross running on this platform
  369. # ppc3/ppcXXX = native
  370. #
  371. cycle:
  372. # ppc (source native)
  373. $(MAKE) OS_TARGET=$(OS_SOURCE) CPU_TARGET=$(CPU_SOURCE) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 rtlclean rtl
  374. $(MAKE) OS_TARGET=$(OS_SOURCE) CPU_TARGET=$(CPU_SOURCE) EXENAME=$(TEMPNAME) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 clean compiler
  375. # ppcross<ARCH> (source native)
  376. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME)' OS_TARGET=$(OS_SOURCE) CPU_TARGET=$(CPU_SOURCE) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 rtlclean rtl
  377. $(MAKE) 'FPC=$(BASEDIR)/$(TEMPNAME)' OS_TARGET=$(OS_SOURCE) CPU_TARGET=$(CPU_SOURCE) PPC_TARGET=$(CPU_TARGET) EXENAME=$(PPCROSSNAME) CROSSBINDIR="" BINUTILSPREFIX="" CROSSCYCLEBOOTSTRAP=1 clean compiler
  378. # ppc<ARCH> (target native)
  379. $(MAKE) 'FPC=$(BASEDIR)/$(PPCROSSNAME)' rtlclean rtl
  380. $(MAKE) 'FPC=$(BASEDIR)/$(PPCROSSNAME)' clean compiler
  381. endif
  382. cycledep:
  383. $(MAKE) cycle USEDEPEND=1
  384. cvstest:
  385. $(MAKE) cycle 'LOCALOPT=-n -Se' 'RTLOPTS=-n -Se'
  386. ##########################
  387. # Full cycle
  388. #
  389. # 1. build a compiler using cycle
  390. # 2. remove all .ppufiles
  391. # 3. build all supported cross compilers except the
  392. # current PPC_TARGET which was already build
  393. #
  394. full: fullcycle
  395. fullcycle:
  396. $(MAKE) cycle
  397. $(MAKE) ppuclean
  398. $(MAKE) $(filter-out $(PPC_TARGET),$(CYCLETARGETS)) 'FPC=$(BASEDIR)/$(EXENAME)'
  399. #####################################################################
  400. # Docs
  401. #####################################################################
  402. htmldocs:
  403. $(PASDOC) -p -h -o html$(PATHSEP)$(PPC_TARGET) -d fpc -d gdb -d $(PPC_TARGET) -u $(PPC_TARGET) $(PPC_TARGET)$(PATHSEP)*.pas systems$(PATHSEP)*.pas *.pas
  404. #####################################################################
  405. # Installation
  406. #####################################################################
  407. .PHONY: quickinstall install installsym
  408. MSGINSTALLDIR=$(INSTALL_BASEDIR)/msg
  409. override PPEXEFILE:=$(wildcard $(EXENAME))
  410. ifdef UNIXINSTALLDIR
  411. ifdef CROSSCOMPILE
  412. PPCCPULOCATION= $(INSTALL_BINDIR)
  413. PPCCROSSLOCATION=$(INSTALL_BASEDIR)/cross/$(FULL_TARGET)
  414. else
  415. PPCCPULOCATION= $(INSTALL_BASEDIR)
  416. endif
  417. else
  418. ifdef CROSSCOMPILE
  419. PPCCPULOCATION= $(INSTALL_BINDIR)
  420. PPCCROSSLOCATION=$(INSTALL_BINDIR)/cross/$(FULL_TARGET)
  421. else
  422. PPCCPULOCATION= $(INSTALL_BINDIR)
  423. endif
  424. endif
  425. # This will only install the ppc386.exe, not the message files etc.
  426. quickinstall: $(addsuffix _install,$(TARGET_DIRS))
  427. # Install ppc386.exe
  428. ifneq ($(PPEXEFILE),)
  429. ifdef UPXPROG
  430. -$(UPXPROG) $(EXENAME)
  431. endif
  432. $(MKDIR) $(PPCCPULOCATION)
  433. $(INSTALLEXE) $(EXENAME) $(PPCCPULOCATION)
  434. ifdef CROSSCOMPILE
  435. $(MKDIR) $(PPCCROSSLOCATION)
  436. $(ECHO) $(PPCROSSNAME)
  437. $(ECHO $(PPCCROSSLOCATION)
  438. $(INSTALLEXE) $(PPCROSSNAME) $(PPCCROSSLOCATION)
  439. endif
  440. endif
  441. install: quickinstall
  442. ifdef UNIXINSTALLDIR
  443. $(MKDIR) $(INSTALL_BASEDIR)
  444. $(INSTALLEXE) $(COMPILERUTILSDIR)/samplecfg $(INSTALL_BASEDIR)/samplecfg
  445. endif
  446. $(MKDIR) $(MSGINSTALLDIR)
  447. $(INSTALL) $(MSGFILES) $(MSGINSTALLDIR)
  448. # this also installs the link /usr/bin/ppc386. The .deb does that later
  449. installsymlink: install
  450. ifdef UNIXINSTALLDIR
  451. $(MKDIR) $(INSTALL_BINDIR)
  452. ln -sf $(INSTALL_BASEDIR)/ppc386 $(INSTALL_BINDIR)/ppc386
  453. endif
  454. #####################################################################
  455. # RTL
  456. #####################################################################
  457. .PHONY: rtl rtlclean rtlinstall
  458. rtl:
  459. $(MAKE) -C $(UNITDIR_RTL) 'OPT=$(RTLOPTS)' all
  460. rtlclean:
  461. $(MAKE) -C $(UNITDIR_RTL) clean
  462. rtlinstall:
  463. $(MAKE) -C $(UNITDIR_RTL) install
  464. #####################################################################
  465. # local user configurable file
  466. # in makefile.loc you can add any desired target
  467. #####################################################################
  468. localmake:=$(strip $(wildcard makefile.loc))
  469. ifdef localmake
  470. include ./$(localmake)
  471. endif