Makefile.fpc 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489
  1. #
  2. # Makefile.fpc for Free Pascal Embedded RTL
  3. #
  4. [package]
  5. main=rtl
  6. [target]
  7. loaders=$(LOADERS)
  8. # not all targets include enough features to build all units so
  9. # the common units which are not compiled for all CPUs are stored in
  10. # CPU_SPECIFIC_COMMON_UNITS
  11. units=$(SYSTEMUNIT) $(CPU_UNITS) $(UUCHARUNIT) $(OBJPASUNIT) $(ISO7185UNIT) $(EXTPASUNIT) $(HEAPMGRUNIT) $(CONSOLEIOUNIT) $(CPU_SPECIFIC_COMMON_UNITS) \
  12. # $(MACPASUNIT) $(ISO7185UNIT) $(STRINGSUNIT)
  13. $(STRINGSUNIT) \
  14. $(SORTBASEUNIT) \
  15. $(DOSUNIT) \
  16. $(CTYPESUNIT) \
  17. $(CHARSETUNIT) $(CPALLUNIT) \
  18. $(SYSCONSTUNIT)
  19. #implicitunits=exeinfo $(CP_UNITS)
  20. #rsts=$(MATHUNIT) $(RTLCONSTSUNIT) $(TYPINFOUNIT) $(CLASSESUNIT) $(SYSCONSTUNIT)
  21. [require]
  22. nortl=y
  23. [install]
  24. fpcpackage=y
  25. [default]
  26. target=embedded
  27. [compiler]
  28. includedir=$(INC) $(PROCINC)
  29. sourcedir=$(INC) $(PROCINC) $(COMMON) $(ARCH)
  30. [prerules]
  31. RTL=..
  32. INC=$(RTL)/inc
  33. COMMON=$(RTL)/common
  34. PROCINC=$(RTL)/$(CPU_TARGET)
  35. UNITPREFIX=rtl
  36. LOADERS=
  37. ifeq ($(ARCH),mipsel)
  38. ifeq ($(SUBARCH),pic32mx)
  39. override LOADERS=startup
  40. endif
  41. endif
  42. ifdef RELEASE
  43. override FPCOPT+=-Ur
  44. endif
  45. CPU_UNITS=
  46. SYSINIT_UNITS=
  47. CPU_SPECIFIC_COMMON_UNITS=$(SYSUTILSUNIT) $(MATHUNIT) $(CLASSESUNIT) \
  48. $(FGLUNIT) $(MACPASUNIT) $(TYPINFOUNIT) $(TYPESUNIT) \
  49. $(RTLCONSTSUNIT) $(GETOPTSUNIT) $(LINEINFOUNIT) $(SOFTFPUUNIT)
  50. # Sysutils special deps
  51. SYSUTILS_DEPS_OS=$(HEAPMGRUNIT)$(PPUEXT)
  52. # Dos unit, local source
  53. DOSDIR=.
  54. # Dos unit uses objfpc mode
  55. DOS_DEPS_OS=$(OBJPASUNIT)$(PPUEXT)
  56. ifeq ($(ARCH),aarch64)
  57. CPU_SPECIFIC_COMMON_UNITS+=$(INTRINSICSUNIT)
  58. CPU_UNITS=$(RASPI3UNIT) $(MMIOUNIT) $(MAILBOXUNIT) $(RASPIUARTUNIT) $(GPIOUNIT)
  59. CPU_UNITS_DEFINED=1
  60. endif
  61. ifeq ($(ARCH),arm)
  62. CPU_SPECIFIC_COMMON_UNITS+=$(INTRINSICSUNIT)
  63. ifeq ($(SUBARCH),armv7m)
  64. CPU_UNITS=$(LM3FURYUNIT) $(LM3TEMPESTUNIT) $(STM32F10X_LDUNIT) $(STM32F10X_MDUNIT) $(STM32F10X_HDUNIT) \
  65. $(STM32F10X_XLUNIT) $(STM32F10X_CONNUNIT) $(STM32F10X_CLUNIT) $(LPC13XXUNIT) $(LPC1768UNIT) \
  66. $(SAM3X8EUNIT) $(XMC4500UNIT) $(CORTEXM3UNIT) $(CORTEXM4UNIT) # thumb2_bare
  67. CPU_UNITS_DEFINED=1
  68. endif
  69. ifeq ($(SUBARCH),armv7em)
  70. CPU_UNITS=$(LM4F120UNIT) $(XMC4500UNIT) $(MK20D5UNIT) $(MK20D7UNIT) $(MK22F51212UNIT) $(MK64F12UNIT) \
  71. $(STM32F401XXUNIT) $(STM32F407XXUNIT) $(STM32F411XEUNIT) $(STM32F429XXUNIT) $(STM32F446XXUNIT) \
  72. $(STM32F745UNIT) $(STM32F746UNIT) $(STM32F756UNIT) $(NRF52UNIT) $(CORTEXM3UNIT) $(CORTEXM4UNIT) $(CORTEXM7UNIT) \
  73. $(SAMD51P19AUNIT) # thumb2_bare
  74. CPU_UNITS_DEFINED=1
  75. endif
  76. ifeq ($(SUBARCH),armv4t)
  77. CPU_UNITS=$(LPC21X4UNIT) $(AT91SAM7X256UNIT) $(SC32442BUNIT)
  78. CPU_UNITS_DEFINED=1
  79. endif
  80. ifeq ($(SUBARCH),armv4)
  81. CPU_UNITS=$(LPC21X4UNIT) $(AT91SAM7X256UNIT) $(SC32442BUNIT)
  82. CPU_UNITS_DEFINED=1
  83. endif
  84. ifeq ($(SUBARCH),armv6m)
  85. CPU_UNITS=$(LPC8XXUNIT) $(LPC11XXUNIT) $(LPC122XUNIT) $(STM32F0XXUNIT) $(NRF51UNIT) $(CORTEXM0UNIT) $(RP2040UNIT)
  86. CPU_UNITS_DEFINED=1
  87. endif
  88. ifeq ($(SUBARCH),armv7a)
  89. CPU_UNITS=$(ALLWINNER_A20UNIT) $(RASPI2UNIT)
  90. CPU_UNITS_DEFINED=1
  91. endif
  92. ifeq ($(CPU_UNITS_DEFINED),)
  93. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  94. endif
  95. endif
  96. ifeq ($(ARCH),avr)
  97. CPU_SPECIFIC_COMMON_UNITS=$(INTRINSICSUNIT)
  98. ifeq ($(SUBARCH),avrtiny)
  99. CPU_UNITS=attiny4 attiny5 attiny9 attiny10 attiny20 attiny40 attiny102 attiny104
  100. CPU_UNITS_DEFINED=1
  101. endif
  102. ifeq ($(SUBARCH),avr1)
  103. CPU_UNITS=attiny11 attiny12 attiny15 attiny28
  104. CPU_UNITS_DEFINED=1
  105. endif
  106. ifeq ($(SUBARCH),avr2)
  107. CPU_UNITS=attiny26
  108. CPU_UNITS_DEFINED=1
  109. endif
  110. ifeq ($(SUBARCH),avr25)
  111. CPU_UNITS=at90usb82 attiny13 attiny13a attiny24 attiny24a attiny25 attiny43u attiny44 \
  112. attiny44a attiny45 attiny48 attiny84 attiny84a attiny85 attiny87 attiny88 \
  113. attiny261 attiny261a attiny441 attiny461 attiny461a attiny828 attiny841 \
  114. attiny861 attiny861a attiny2313 attiny2313a attiny4313
  115. CPU_UNITS_DEFINED=1
  116. endif
  117. ifeq ($(SUBARCH),avr35)
  118. CPU_UNITS=at90usb162 atmega8u2 atmega16u2 atmega32u2 attiny167 attiny1634
  119. CPU_UNITS_DEFINED=1
  120. endif
  121. ifeq ($(SUBARCH),avr4)
  122. CPU_UNITS=at90pwm1 at90pwm2b at90pwm3 at90pwm3b at90pwm81 ata6285 ata6286 atmega8 \
  123. atmega8a atmega8hva atmega48 atmega48a atmega48p atmega48pa atmega48pb \
  124. atmega88 atmega88a atmega88p atmega88pa atmega88pb atmega8515 atmega8535
  125. CPU_UNITS_DEFINED=1
  126. endif
  127. ifeq ($(SUBARCH),avr5)
  128. CPU_UNITS=avrsim at90can32 at90can64 at90pwm161 at90pwm216 at90pwm316 at90usb646 at90usb647 \
  129. atmega16 atmega16a atmega16hva atmega16hvb atmega16hvbrevb atmega16m1 \
  130. atmega16u4 atmega32 atmega32a atmega32c1 atmega32hvb atmega32hvbrevb atmega32m1 \
  131. atmega32u4 atmega64 atmega64a atmega64c1 atmega64hve2 atmega64m1 atmega64rfr2 \
  132. atmega162 atmega164a atmega164p atmega164pa atmega165a atmega165p atmega165pa \
  133. atmega168 atmega168a atmega168p atmega168pa atmega168pb atmega169a atmega169p \
  134. atmega169pa atmega324a atmega324p atmega324pa atmega324pb atmega325 atmega325a \
  135. atmega325p atmega325pa atmega328 atmega328p atmega328pb atmega329 atmega329a \
  136. atmega329p atmega329pa atmega406 atmega640 atmega644 atmega644a atmega644p \
  137. atmega644pa atmega644rfr2 atmega645 atmega645a atmega645p atmega649 atmega649a \
  138. atmega649p atmega3250 atmega3250a atmega3250p atmega3250pa atmega3290 \
  139. atmega3290a atmega3290p atmega3290pa atmega6450 atmega6450a atmega6450p \
  140. atmega6490 atmega6490a atmega6490p
  141. CPU_UNITS_DEFINED=1
  142. endif
  143. ifeq ($(SUBARCH),avr51)
  144. CPU_UNITS=at90can128 at90usb1286 at90usb1287 atmega128 atmega128a atmega128rfa1 \
  145. atmega128rfr2 atmega1280 atmega1281 atmega1284 atmega1284p atmega1284rfr2
  146. CPU_UNITS_DEFINED=1
  147. endif
  148. ifeq ($(SUBARCH),avr6)
  149. CPU_UNITS=avrsim atmega256rfr2 atmega2560 atmega2561 atmega2564rfr2
  150. CPU_UNITS_DEFINED=1
  151. endif
  152. ifeq ($(SUBARCH),avrxmega2)
  153. CPU_UNITS=atxmega8e5 atxmega16a4 atxmega16a4u atxmega16c4 atxmega16d4 atxmega16e5 \
  154. atxmega32a4 atxmega32a4u atxmega32c3 atxmega32c4 atxmega32d3 atxmega32d4 \
  155. atxmega32e5 avr64da28 avr64da28s avr64da32 avr64da32s avr64da48 avr64da48s \
  156. avr64da64 avr64da64s avr64db28 avr64db32 avr64db48 avr64db64 avr64dd14 \
  157. avr64dd20 avr64dd28 avr64dd32 avr64du28 avr64du32 avr64ea28 avr64ea32 \
  158. avr64ea48
  159. CPU_UNITS_DEFINED=1
  160. endif
  161. ifeq ($(SUBARCH),avrxmega3)
  162. CPU_UNITS=atmega808 atmega809 atmega1608 atmega1609 atmega3208 atmega3209 atmega4808 \
  163. atmega4809 attiny202 attiny204 attiny212 attiny214 attiny402 attiny404 \
  164. attiny406 attiny412 attiny414 attiny416 attiny416auto attiny417 attiny424 \
  165. attiny426 attiny427 attiny804 attiny806 attiny807 attiny814 attiny816 \
  166. attiny817 attiny824 attiny826 attiny827 attiny1604 attiny1606 attiny1607 \
  167. attiny1614 attiny1616 attiny1617 attiny1624 attiny1626 attiny1627 \
  168. attiny3216 attiny3217 attiny3224 attiny3226 attiny3227 avr16dd14 avr16dd20 \
  169. avr16dd28 avr16dd32 avr16du14 avr16du20 avr16du28 avr16du32 avr16ea28 \
  170. avr16ea32 avr16ea48 avr16eb14 avr16eb20 avr16eb28 avr16eb32 avr32da28 \
  171. avr32da28s avr32da32 avr32da32s avr32da48 avr32da48s avr32db28 avr32db32 \
  172. avr32db48 avr32dd14 avr32dd20 avr32dd28 avr32dd32 avr32du14 avr32du20 \
  173. avr32du28 avr32du32 avr32ea28 avr32ea32 avr32ea48 avr32eb14 avr32eb20 \
  174. avr32eb28 avr32eb32
  175. CPU_UNITS_DEFINED=1
  176. endif
  177. ifeq ($(SUBARCH),avrxmega4)
  178. CPU_UNITS=atxmega64a3 atxmega64a3u atxmega64a4u atxmega64b1 atxmega64b3 atxmega64c3 \
  179. atxmega64d3 atxmega64d4 avr128da28 avr128da28s avr128da32 avr128da32s \
  180. avr128da48 avr128da48s avr128da64 avr128da64s avr128db28 avr128db32 avr128db48 \
  181. avr128db64
  182. CPU_UNITS_DEFINED=1
  183. endif
  184. ifeq ($(SUBARCH),avrxmega5)
  185. CPU_UNITS=atxmega64a1 atxmega64a1u
  186. CPU_UNITS_DEFINED=1
  187. endif
  188. ifeq ($(SUBARCH),avrxmega6)
  189. CPU_UNITS=atxmega128a3 atxmega128a3u atxmega128b1 atxmega128b3 atxmega128c3 atxmega128d3 \
  190. atxmega128d4 atxmega192a3 atxmega192a3u atxmega192c3 atxmega192d3 atxmega256a3 \
  191. atxmega256a3b atxmega256a3bu atxmega256a3u atxmega256c3 atxmega256d3 atxmega384c3 \
  192. atxmega384d3
  193. CPU_UNITS_DEFINED=1
  194. endif
  195. ifeq ($(SUBARCH),avrxmega7)
  196. CPU_UNITS=atxmega128a1 atxmega128a1u atxmega128a4u
  197. CPU_UNITS_DEFINED=1
  198. endif
  199. ifeq ($(CPU_UNITS_DEFINED),)
  200. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  201. endif
  202. endif
  203. ifeq ($(ARCH),i386)
  204. CPU_UNITS=$(MULTIBOOTUNIT)
  205. CPU_UNITS_DEFINED=1
  206. ifeq ($(CPU_UNITS_DEFINED),)
  207. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  208. endif
  209. endif
  210. ifeq ($(ARCH),i8086)
  211. # Always include rtl.cfg config file for i8086
  212. override [email protected]
  213. CPU_SPECIFIC_COMMON_UNITS=
  214. endif
  215. ifeq ($(ARCH),z80)
  216. # Always include rtl.cfg config file for z80
  217. override [email protected]
  218. CPU_SPECIFIC_COMMON_UNITS=
  219. endif
  220. ifeq ($(ARCH),x86_64)
  221. # CPU_UNITS=$(MULTIBOOTUNIT)
  222. endif
  223. ifeq ($(ARCH),m68k)
  224. # CPU_UNITS=$(MULTIBOOTUNIT)
  225. endif
  226. ifeq ($(ARCH),mipsel)
  227. ifeq ($(SUBARCH),pic32mx)
  228. CPU_UNITS=pic32mx1xxfxxxb pic32mx2xxfxxxb pic32mx1xxfxxxc pic32mx2xxfxxxc pic32mx1xxfxxxd pic32mx2xxfxxxd pic32mx7x5fxxxl pic32mx7x5fxxxh
  229. CPU_UNITS_DEFINED=1
  230. endif
  231. ifeq ($(CPU_UNITS_DEFINED),)
  232. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  233. endif
  234. endif
  235. ifeq ($(ARCH),riscv32)
  236. CPU_SPECIFIC_COMMON_UNITS=$(SYSUTILSUNIT) $(MATHUNIT) $(CLASSESUNIT) $(FGLUNIT) $(MACPASUNIT) $(TYPINFOUNIT) $(TYPESUNIT) $(RTLCONSTSUNIT) $(GETOPTSUNIT) $(LINEINFOUNIT) $(INTRINSICSUNIT)
  237. ifeq ($(SUBARCH),rv32ec)
  238. override FPCOPT+=-Cprv32ec
  239. CPU_UNITS=CH32VxBootstrap
  240. CPU_UNITS_DEFINED=1
  241. endif
  242. ifeq ($(SUBARCH),rv32e)
  243. override FPCOPT+=-Cprv32e
  244. CPU_UNITS=CH32VxBootstrap
  245. CPU_UNITS_DEFINED=1
  246. endif
  247. ifeq ($(SUBARCH),rv32imac)
  248. override FPCOPT+=-Cprv32imac
  249. CPU_UNITS=CH32VxBootstrap $(GD32VF103XXUNIT)
  250. CPU_UNITS_DEFINED=1
  251. endif
  252. ifeq ($(SUBARCH),rv32imac_zicsr_zifencei)
  253. override FPCOPT+=-Cprv32imac
  254. CPU_UNITS=CH32VxBootstrap $(FE310G000UNIT) $(FE310G002UNIT)
  255. CPU_UNITS_DEFINED=1
  256. endif
  257. ifeq ($(SUBARCH),rv32i)
  258. override FPCOPT+=-Cprv32i
  259. CPU_UNITS=CH32VxBootstrap
  260. CPU_UNITS_DEFINED=1
  261. endif
  262. ifeq ($(CPU_UNITS_DEFINED),)
  263. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  264. endif
  265. endif
  266. ifeq ($(ARCH),riscv64)
  267. CPU_UNITS=
  268. CPU_UNITS_DEFINED=1
  269. ifeq ($(CPU_UNITS_DEFINED),)
  270. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  271. endif
  272. endif
  273. ifeq ($(ARCH),xtensa)
  274. ifeq ($(SUBARCH),lx106)
  275. CPU_UNITS=$(ESP8266UNIT)
  276. CPU_UNITS_DEFINED=1
  277. endif
  278. ifeq ($(CPU_UNITS_DEFINED),)
  279. $(error No CPUs enabled for given SUBARCH, pass either a SUBARCH or set CPU_UNITS_DEFINED=1 if you know what you are doing)
  280. endif
  281. endif
  282. ifeq ($(ARCH),wasm32)
  283. CPU_SPECIFIC_COMMON_UNITS:=$(filter-out $(SOFTFPUUNIT), $(filter-out $(LINEINFOUNIT), $(CPU_SPECIFIC_COMMON_UNITS)))
  284. endif
  285. # Paths
  286. OBJPASDIR=$(RTL)/objpas
  287. [rules]
  288. # .NOTPARALLEL:
  289. # Get the system independent include file names.
  290. # This will set the following variables :
  291. # SYSINCNAMES
  292. include $(INC)/makefile.inc
  293. SYSINCDEPS=$(addprefix $(INC)/,$(SYSINCNAMES))
  294. # Get the processor dependent include file names.
  295. # This will set the following variables :
  296. # CPUINCNAMES
  297. include $(PROCINC)/makefile.cpu
  298. SYSCPUDEPS=$(addprefix $(PROCINC)/,$(CPUINCNAMES))
  299. # Put system unit dependencies together.
  300. SYSDEPS=$(SYSINCDEPS) $(SYSCPUDEPS) $(INC)/softfpu.pp
  301. override FPC_SYSTEM_OPT += @system.cfg
  302. #
  303. # Loaders
  304. #
  305. startup$(OEXT) : $(CPU_TARGET)/startup.s
  306. $(AS) $(ASTARGET) -o $(UNITTARGETDIRPREFIX)startup$(OEXT) $(CPU_TARGET)/startup.s -mabi=32 -march=pic32mx -mtune=pic32mx -W -EL -msym32
  307. #
  308. # Base Units (System, $(STRINGSUNIT), os-dependent-base-unit)
  309. #
  310. CONSOLEIO_DEPS= consoleio.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  311. $(CONSOLEIO_DEPS_OS) $(CONSOLEIO_DEPS_CPU)
  312. consoleio$(PPUEXT) : $(CONSOLEIO_DEPS)
  313. $(COMPILER) $(CONSOLEIO_OPT) $<
  314. EmbeddedApi.ConsoleIO$(PPUEXT) : $(NSOSDIR)/EmbeddedApi.ConsoleIO.pp $(CONSOLEIO_DEPS)
  315. $(COMPILER) $(CONSOLEIO_OPT) -Fi. $<
  316. HEAPMGR_DEPS= heapmgr.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  317. $(HEAPMGR_DEPS_OS) $(HEAPMGR_DEPS_CPU)
  318. heapmgr$(PPUEXT) : $(HEAPMGR_DEPS)
  319. $(COMPILER) $(HEAPMGR_OPT) $<
  320. EmbeddedApi.HeapMGR$(PPUEXT) : $(NSOSDIR)/EmbeddedApi.HeapMGR.pp $(HEAPMGR_DEPS)
  321. $(COMPILER) $(HEAPMGR_OPT) -Fi. $<
  322. #
  323. # Unit specific rules
  324. #
  325. define CPU_UNITS_RULE
  326. ifndef FPC_DOTTEDUNITS
  327. $(1)$(PPUEXT): $(ARCH)/$(1).pp $(SYSTEMUNIT)$(PPUEXT) $(addsuffix $(PPUEXT),$(CPU_SPECIFIC_COMMON_UNITS))
  328. else
  329. $(eval UNIT_REG_NAME=$(subst EmbeddedApi.,,$(1)))
  330. $(eval UNIT_REG_NAME=$(subst ARMApi.,,$(UNIT_REG_NAME)))
  331. ifeq ($(ARCH),avr)
  332. # No dotted rules for AVR cpu yet
  333. $(1)$(PPUEXT): $(ARCH)/$(1).pp $(SYSTEMUNIT)$(PPUEXT) $(addsuffix $(PPUEXT),$(CPU_SPECIFIC_COMMON_UNITS))
  334. else
  335. # mipsel is also not yet in namespaced
  336. ifeq ($(ARCH),mipsel)
  337. $(1)$(PPUEXT): $(ARCH)/$(1).pp $(SYSTEMUNIT)$(PPUEXT) $(addsuffix $(PPUEXT),$(CPU_SPECIFIC_COMMON_UNITS))
  338. else
  339. $(1)$(PPUEXT): $(NSOSDIR)/$(ARCH)/$(1).pp $(ARCH)/$(UNIT_REG_NAME).pp $(SYSTEMUNIT)$(PPUEXT) $(addsuffix $(PPUEXT),$(CPU_SPECIFIC_COMMON_UNITS))
  340. endif
  341. endif
  342. endif
  343. endef
  344. $(foreach unit,$(CPU_UNITS),$(eval $(call CPU_UNITS_RULE,$(unit))))
  345. ifndef FPC_DOTTEDUNITS
  346. $(addsuffix $(PPUEXT),$(CPU_UNITS)):
  347. $(COMPILER) -g $<
  348. else
  349. $(addsuffix $(PPUEXT),$(CPU_UNITS)):
  350. $(COMPILER) -g -Fi$(OSDIR) -Fi$(OSDIR)/$(ARCH) $<
  351. endif
  352. # AVR specific units
  353. avrsim$(PPUEXT): $(ARCH)/avrsim.pp $(HEAPMGRUNIT)$(PPUEXT) $(CONSOLEIOUNIT)$(PPUEXT) $(SYSTEMUNIT)$(PPUEXT)
  354. $(COMPILER) $(ARCH)/avrsim.pp
  355. # i386 specific units
  356. MULTIBOOT_DEPS = $(ARCH)/multiboot.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  357. $(MULTIBOOT_DEPS_OS) $(MULTIBOOT_DEPS_CPU)
  358. multiboot$(PPUEXT) : $(MULTIBOOT_DEPS)
  359. $(COMPILER) $(MULTIBOOT_OPT) $<
  360. EmbeddedApi.multiboot$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.multiboot.pp $(MULTIBOOT_DEPS)
  361. $(COMPILER) $(MULTIBOOT_OPT) -Fi. -Fi$(ARCH) $<
  362. # ARM specific units
  363. #raspi2$(PPUEXT): $(ARCH)/raspi2.pp $(CONSOLEIOUNIT)$(PPUEXT) $(SYSTEMUNIT)$(PPUEXT)
  364. # $(COMPILER) $(ARCH)/raspi2.pp
  365. RASPI2_DEPS = $(ARCH)/raspi2.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  366. $(RASPI2_DEPS_OS) $(RASPI2_DEPS_CPU)
  367. raspi2$(PPUEXT) : $(RASPI2_DEPS)
  368. $(COMPILER) $(RASPI2_OPT) $<
  369. EmbeddedApi.Raspi2$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.Raspi2.pp $(RASPI2_DEPS)
  370. $(COMPILER) $(RASPI2_OPT) -Fi. -Fi$(ARCH) $<
  371. # AARCH64 specific units
  372. # gpio unit
  373. #
  374. GPIO_DEPS = $(ARCH)/gpio.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  375. $(GPIO_DEPS_OS) $(GPIO_DEPS_CPU)
  376. gpio$(PPUEXT) : $(GPIO_DEPS)
  377. $(COMPILER) $(GPIO_OPT) $<
  378. EmbeddedApi.gpio$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.gpio.pp $(GPIO_DEPS)
  379. $(COMPILER) $(GPIO_OPT) -Fi. -Fi$(ARCH) $<
  380. #mmio$(PPUEXT): $(ARCH)/mmio.pp $(SYSTEMUNIT)$(PPUEXT)
  381. # $(COMPILER) $(ARCH)/mailbox.pp
  382. MMIO_DEPS = $(ARCH)/mmio.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  383. $(MMIO_DEPS_OS) $(MMIO_DEPS_CPU)
  384. mmio$(PPUEXT) : $(MMIO_DEPS)
  385. $(COMPILER) $(MMIO_OPT) $<
  386. EmbeddedApi.mmio$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.mmio.pp $(MMIO_DEPS)
  387. $(COMPILER) $(MMIO_OPT) -Fi. -Fi$(ARCH) $<
  388. #mailbox$(PPUEXT): $(ARCH)/mailbox.pp mmio$(PPUEXT) $(SYSTEMUNIT)$(PPUEXT)
  389. # $(COMPILER) $(ARCH)/mailbox.pp
  390. MAILBOX_DEPS = $(ARCH)/mailbox.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) $(MMIOUNIT)$(PPUEXT) \
  391. $(MAILBOX_DEPS_OS) $(MAILBOX_DEPS_CPU)
  392. mailbox$(PPUEXT) : $(MAILBOX_DEPS)
  393. $(COMPILER) $(MAILBOX_OPT) $<
  394. EmbeddedApi.mailbox$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.mailbox.pp $(MAILBOX_DEPS)
  395. $(COMPILER) $(MAILBOX_OPT) -Fi. -Fi$(ARCH) $<
  396. #raspiuart$(PPUEXT): $(ARCH)/raspiuart.pp mmio$(PPUEXT) mailbox$(PPUEXT) gpio$(PPUEXT) $(SYSTEMUNIT)$(PPUEXT)
  397. # $(COMPILER) $(ARCH)/raspiuart.pp
  398. RASPIUART_DEPS = $(ARCH)/raspiuart.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  399. $(MAILBOXUNIT)$(PPUEXT) $(GPIOUNIT)$(PPUEXT) $(MMIOUNIT)$(PPUEXT) \
  400. $(RASPIUART_DEPS_OS) $(RASPIUART_DEPS_CPU)
  401. raspiuart$(PPUEXT) : $(RASPIUART_DEPS)
  402. $(COMPILER) $(RASPIUART_OPT) $<
  403. EmbeddedApi.raspiuart$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.raspiuart.pp $(RASPIUART_DEPS)
  404. $(COMPILER) $(RASPIUART_OPT) -Fi. -Fi$(ARCH) $<
  405. #raspi3$(PPUEXT): $(ARCH)/raspi3.pp $(CONSOLEIOUNIT)$(PPUEXT) mmio$(PPUEXT) mailbox$(PPUEXT) raspiuart$(PPUEXT) gpio$(PPUEXT) $(SYSTEMUNIT)$(PPUEXT)
  406. # $(COMPILER) $(ARCH)/raspi3.pp
  407. RASPI3_DEPS = $(ARCH)/raspi3.pp $(SYSTEMUNIT)$(PPUEXT) $(OBJPASUNIT)$(PPUEXT) \
  408. $(CONSOLEIOUNIT)$(PPUEXT) $(MAILBOXUNIT)$(PPUEXT) $(GPIOUNIT)$(PPUEXT) \
  409. $(MMIOUNIT)$(PPUEXT) $(RASPIUARTUNIT)$(PPUEXT) \
  410. $(RASPI3_DEPS_OS) $(RASPI3_DEPS_CPU)
  411. raspi3$(PPUEXT) : $(RASPI3_DEPS)
  412. $(COMPILER) $(RASPI3_OPT) $<
  413. EmbeddedApi.raspi3$(PPUEXT) : $(NSOSDIR)/$(ARCH)/EmbeddedApi.raspi3.pp $(RASPI3_DEPS)
  414. $(COMPILER) $(RASPI3_OPT) -Fi. -Fi$(ARCH) $<