diff --git a/Makefile.dep b/Makefile.dep index 006ad059dd9a22337808f8abcd14f33efc7bff69..9b01c11117a1443d3d76a90abc273a295deaccd4 100644 --- a/Makefile.dep +++ b/Makefile.dep @@ -5,6 +5,10 @@ OLD_USEPKG := $(sort $(USEPKG)) # include board dependencies -include $(RIOTBOARD)/$(BOARD)/Makefile.dep +# include external modules dependencies +# processed before RIOT ones to be evaluated before the 'default' rules. +-include $(EXTERNAL_MODULE_DIRS:%=%/Makefile.dep) + # pull dependencies from sys and drivers include $(RIOTBASE)/sys/Makefile.dep include $(RIOTBASE)/drivers/Makefile.dep diff --git a/Makefile.include b/Makefile.include index 6646a29bd1500001ce886586700047b8ba2ff5b7..2c1dd40102a3786607ea15d61afb4a51225fbd58 100644 --- a/Makefile.include +++ b/Makefile.include @@ -353,6 +353,9 @@ $(RIOTPKG)/%/Makefile.include:: $(USEPKG:%=$(RIOTPKG)/%/Makefile.include): FORCE -include $(USEPKG:%=$(RIOTPKG)/%/Makefile.include) +# include external modules configuration +-include $(EXTERNAL_MODULE_DIRS:%=%/Makefile.include) + # Deduplicate includes without sorting them # see https://stackoverflow.com/questions/16144115/makefile-remove-duplicate-words-without-sorting define uniq diff --git a/doc/doxygen/src/creating-modules.md b/doc/doxygen/src/creating-modules.md index 9ac037a485b8ee8c51a51cc37dcded6fddd4ffde..776024be7fa223df943790b3035041e0758f8592 100644 --- a/doc/doxygen/src/creating-modules.md +++ b/doc/doxygen/src/creating-modules.md @@ -67,8 +67,12 @@ their dependencies. Modules outside of RIOTBASE {#modules-outside-of-riotbase} =========================== Modules can be defined outside `RIOTBASE`. In addition to add it to `USEMODULE` -the user needs to add the path to the module to `EXTERNAL_MODULE_DIRS` and add -the include path to the API definitions to `INCLUDES`. +the user needs to add the module path to `EXTERNAL_MODULE_DIRS`. + +The external module can optionally define the following files: +* `Makefile.include` file to set global build configuration like `CFLAGS` or add + API headers include paths to the `USEMODULE_INCLUDES` variable. +* `Makefile.dep` file to set module dependencies Pseudomodules {#pseudomodules} =============