1 ################################################################################
2 # Autotools package infrastructure
4 # This file implements an infrastructure that eases development of
5 # package .mk files for autotools packages. It should be used for all
6 # packages that use the autotools as their build system.
8 # See the Buildroot documentation for details on the usage of this
11 # In terms of implementation, this autotools infrastructure requires
12 # the .mk file to only specify metadata information about the
13 # package: name, version, download URL, etc.
15 # We still allow the package .mk file to override what the different
16 # steps are doing, if needed. For example, if <PKG>_BUILD_CMDS is
17 # already defined, it is used as the list of commands to perform to
18 # build the package, instead of the default autotools behaviour. The
19 # package can also define some post operation hooks.
21 ################################################################################
25 # Utility function to upgrade config.sub and config.guess files
27 # argument 1 : directory into which config.guess and config.sub need
28 # to be updated. Note that config.sub and config.guess are searched
29 # recursively in this directory.
32 for file in config.guess config.sub
; do \
33 for i in
$$(find
$(1) -name
$$file); do \
34 cp support
/gnuconfig
/$$file $$i; \
39 # This function generates the ac_cv_file_<foo> value for a given
40 # filename. This is needed to convince configure script doing
41 # AC_CHECK_FILE() tests that the file actually exists, since such
42 # tests cannot be done in a cross-compilation context. This function
43 # takes as argument the path of the file. An example usage is:
46 # $(call AUTOCONF_AC_CHECK_FILE_VAL,/dev/random)=yes
47 AUTOCONF_AC_CHECK_FILE_VAL
= ac_cv_file_
$(subst -,_
,$(subst /,_
,$(subst .
,_
,$(1))))
50 # Hook to update config.sub and config.guess if needed
52 define UPDATE_CONFIG_HOOK
53 @
$(call MESSAGE
,"Updating config.sub and config.guess")
54 $(call CONFIG_UPDATE
,$(@D
))
58 # Hook to patch libtool to make it work properly for cross-compilation
60 define LIBTOOL_PATCH_HOOK
61 @
$(call MESSAGE
,"Patching libtool")
62 $(Q
)for i in
`find $($(PKG)_SRCDIR) -name ltmain.sh`; do \
63 ltmain_version
=`sed -n '/^[ \t]*VERSION=/{s/^[ \t]*VERSION=//;p;q;}' $$i | \
64 sed -e 's/\([0-9]*\.[0-9]*\).*/\1/' -e 's/\"//'`; \
65 ltmain_patchlevel
=`sed -n '/^[ \t]*VERSION=/{s/^[ \t]*VERSION=//;p;q;}' $$i | \
66 sed -e 's/\([0-9]*\.[0-9]*\.*\)\([0-9]*\).*/\2/' -e 's/\"//'`; \
67 if
test $${ltmain_version} = '1.5'; then \
68 $(APPLY_PATCHES
) $${i
%/*} support
/libtool buildroot-libtool-v1.5.patch
; \
69 elif
test $${ltmain_version} = "2.2"; then\
70 $(APPLY_PATCHES
) $${i
%/*} support
/libtool buildroot-libtool-v2.2.patch
; \
71 elif
test $${ltmain_version} = "2.4"; then\
72 if
test $${ltmain_patchlevel
:-0} -gt
2; then\
73 $(APPLY_PATCHES
) $${i
%/*} support
/libtool buildroot-libtool-v2.4
.4.patch
; \
75 $(APPLY_PATCHES
) $${i
%/*} support
/libtool buildroot-libtool-v2.4.patch
; \
82 # Hook to gettextize the package if needed
84 define GETTEXTIZE_HOOK
85 @
$(call MESSAGE
,"Gettextizing")
86 $(Q
)cd
$($(PKG
)_SRCDIR
) && $(GETTEXTIZE
) $($(PKG
)_GETTEXTIZE_OPTS
)
90 # Hook to autoreconf the package if needed
92 define AUTORECONF_HOOK
93 @
$(call MESSAGE
,"Autoreconfiguring")
94 $(Q
)cd
$($(PKG
)_SRCDIR
) && $($(PKG
)_AUTORECONF_ENV
) $(AUTORECONF
) $($(PKG
)_AUTORECONF_OPTS
)
97 ################################################################################
98 # inner-autotools-package -- defines how the configuration, compilation and
99 # installation of an autotools package should be done, implements a
100 # few hooks to tune the build process for autotools specifities and
101 # calls the generic package infrastructure to generate the necessary
104 # argument 1 is the lowercase package name
105 # argument 2 is the uppercase package name, including a HOST_ prefix
107 # argument 3 is the uppercase package name, without the HOST_ prefix
109 # argument 4 is the type (target or host)
110 ################################################################################
112 define inner-autotools-package
114 ifndef $(2)_LIBTOOL_PATCH
115 ifdef $(3)_LIBTOOL_PATCH
116 $(2)_LIBTOOL_PATCH
= $$($(3)_LIBTOOL_PATCH
)
118 $(2)_LIBTOOL_PATCH ?
= YES
124 $(2)_MAKE
= $$($(3)_MAKE
)
126 $(2)_MAKE ?
= $$(MAKE
)
130 ifndef $(2)_AUTORECONF
131 ifdef $(3)_AUTORECONF
132 $(2)_AUTORECONF
= $$($(3)_AUTORECONF
)
134 $(2)_AUTORECONF ?
= NO
138 ifndef $(2)_GETTEXTIZE
139 ifdef $(3)_GETTEXTIZE
140 $(2)_GETTEXTIZE
= $$($(3)_GETTEXTIZE
)
142 $(2)_GETTEXTIZE ?
= NO
147 $(2)_GETTEXTIZE_OPTS ?
= $$($(3)_GETTEXTIZE_OPTS
)
151 $(2)_AUTORECONF_OPTS ?
= $$($(3)_AUTORECONF_OPTS
)
158 $(2)_INSTALL_OPTS ?
= install
159 $(2)_INSTALL_STAGING_OPTS ?
= DESTDIR
=$$(STAGING_DIR
) install
160 $(2)_INSTALL_TARGET_OPTS ?
= DESTDIR
=$$(TARGET_DIR
) install
162 # This must be repeated from inner-generic-package, otherwise we get an empty
163 # _DEPENDENCIES if _AUTORECONF is YES. Also filter the result of _AUTORECONF
164 # and _GETTEXTIZE away from the non-host rule
166 $(2)_DEPENDENCIES ?
= $$(filter-out host-automake host-autoconf host-libtool \
167 host-gettext host-skeleton host-toolchain
$(1),\
168 $$(patsubst host-host-
%,host-
%,$$(addprefix host-
,$$($(3)_DEPENDENCIES
))))
172 # Configure step. Only define it if not already defined by the package
173 # .mk file. And take care of the differences between host and target
176 ifndef $(2)_CONFIGURE_CMDS
179 # Configure package for target
180 define $(2)_CONFIGURE_CMDS
181 (cd
$$($$(PKG
)_SRCDIR
) && rm -rf config.cache
&& \
182 $$(TARGET_CONFIGURE_OPTS
) \
183 $$(TARGET_CONFIGURE_ARGS
) \
184 $$($$(PKG
)_CONF_ENV
) \
185 CONFIG_SITE
=/dev
/null \
187 --target
=$$(GNU_TARGET_NAME
) \
188 --host
=$$(GNU_TARGET_NAME
) \
189 --build
=$$(GNU_HOST_NAME
) \
193 --localstatedir
=/var \
194 --program-prefix
="" \
196 --disable-gtk-doc-html \
199 --disable-documentation \
202 --disable-dependency-tracking \
205 $$(SHARED_STATIC_LIBS_OPTS
) \
206 $$(QUIET
) $$($$(PKG
)_CONF_OPTS
) \
211 # Configure package for host
212 # disable all kind of documentation generation in the process,
213 # because it often relies on host tools which may or may not be
215 define $(2)_CONFIGURE_CMDS
216 (cd
$$($$(PKG
)_SRCDIR
) && rm -rf config.cache
; \
217 $$(HOST_CONFIGURE_OPTS
) \
218 CFLAGS
="$$(HOST_CFLAGS)" \
219 LDFLAGS
="$$(HOST_LDFLAGS)" \
220 $$($$(PKG
)_CONF_ENV
) \
221 CONFIG_SITE
=/dev
/null \
223 --prefix="$$(HOST_DIR)/usr" \
224 --sysconfdir
="$$(HOST_DIR)/etc" \
225 --localstatedir
="$$(HOST_DIR)/var" \
226 --enable-shared
--disable-static \
228 --disable-gtk-doc-html \
231 --disable-documentation \
235 --disable-dependency-tracking \
236 $$(QUIET
) $$($$(PKG
)_CONF_OPTS
) \
242 $(2)_POST_PATCH_HOOKS
+= UPDATE_CONFIG_HOOK
244 ifeq ($$($(2)_AUTORECONF
),YES
)
246 # This has to come before autoreconf
247 ifeq ($$($(2)_GETTEXTIZE
),YES
)
248 $(2)_PRE_CONFIGURE_HOOKS
+= GETTEXTIZE_HOOK
249 $(2)_DEPENDENCIES
+= host-gettext
251 $(2)_PRE_CONFIGURE_HOOKS
+= AUTORECONF_HOOK
252 # default values are not evaluated yet, so don't rely on this defaulting to YES
253 ifneq ($$($(2)_LIBTOOL_PATCH
),NO
)
254 $(2)_PRE_CONFIGURE_HOOKS
+= LIBTOOL_PATCH_HOOK
256 $(2)_DEPENDENCIES
+= host-automake host-autoconf host-libtool
258 else # ! AUTORECONF = YES
260 # default values are not evaluated yet, so don't rely on this defaulting to YES
261 ifneq ($$($(2)_LIBTOOL_PATCH
),NO
)
262 $(2)_POST_PATCH_HOOKS
+= LIBTOOL_PATCH_HOOK
268 # Build step. Only define it if not already defined by the package .mk
271 ifndef $(2)_BUILD_CMDS
273 define $(2)_BUILD_CMDS
274 $$(TARGET_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_MAKE_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
277 define $(2)_BUILD_CMDS
278 $$(HOST_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_MAKE_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
284 # Host installation step. Only define it if not already defined by the
287 ifndef $(2)_INSTALL_CMDS
288 define $(2)_INSTALL_CMDS
289 $$(HOST_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_INSTALL_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
294 # Staging installation step. Only define it if not already defined by
295 # the package .mk file.
297 ifndef $(2)_INSTALL_STAGING_CMDS
298 define $(2)_INSTALL_STAGING_CMDS
299 $$(TARGET_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_INSTALL_STAGING_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
304 # Target installation step. Only define it if not already defined by
305 # the package .mk file.
307 ifndef $(2)_INSTALL_TARGET_CMDS
308 define $(2)_INSTALL_TARGET_CMDS
309 $$(TARGET_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_INSTALL_TARGET_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
313 # Call the generic package infrastructure to generate the necessary
315 $(call inner-generic-package
,$(1),$(2),$(3),$(4))
319 ################################################################################
320 # autotools-package -- the target generator macro for autotools packages
321 ################################################################################
323 autotools-package
= $(call inner-autotools-package
,$(pkgname
),$(call UPPERCASE
,$(pkgname
)),$(call UPPERCASE
,$(pkgname
)),target
)
324 host-autotools-package
= $(call inner-autotools-package
,host-
$(pkgname
),$(call UPPERCASE
,host-
$(pkgname
)),$(call UPPERCASE
,$(pkgname
)),host
)