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)_DIR) -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 patch
-i support
/libtool
/buildroot-libtool-v1.5.patch
$${i}; \
69 elif
test $${ltmain_version} = "2.2"; then\
70 patch
-i support
/libtool
/buildroot-libtool-v2.2.patch
$${i}; \
71 elif
test $${ltmain_version} = "2.4"; then\
72 if
test $${ltmain_patchlevel
:-0} -gt
2; then\
73 patch
-i support
/libtool
/buildroot-libtool-v2.4
.4.patch
$${i}; \
75 patch
-i support
/libtool
/buildroot-libtool-v2.4.patch
$${i}; \
82 # Hook to patch common issue with configure on powerpc64{,le} failing
83 # to detect shared library support:
85 define CONFIGURE_FIX_POWERPC64_HOOK
86 @
$(call MESSAGE
,"Checking configure (powerpc64/powerpc64le)")
87 support
/scripts
/fix-configure-powerpc64.sh
$($(PKG
)_DIR
)
91 # Hook to gettextize the package if needed
93 define GETTEXTIZE_HOOK
94 @
$(call MESSAGE
,"Gettextizing")
95 $(Q
)cd
$($(PKG
)_SRCDIR
) && $(GETTEXTIZE
) $($(PKG
)_GETTEXTIZE_OPTS
)
99 # Hook to autoreconf the package if needed
101 define AUTORECONF_HOOK
102 @
$(call MESSAGE
,"Autoreconfiguring")
103 $(Q
)cd
$($(PKG
)_SRCDIR
) && $($(PKG
)_AUTORECONF_ENV
) $(AUTORECONF
) $($(PKG
)_AUTORECONF_OPTS
)
106 ################################################################################
107 # inner-autotools-package -- defines how the configuration, compilation and
108 # installation of an autotools package should be done, implements a
109 # few hooks to tune the build process for autotools specifities and
110 # calls the generic package infrastructure to generate the necessary
113 # argument 1 is the lowercase package name
114 # argument 2 is the uppercase package name, including a HOST_ prefix
116 # argument 3 is the uppercase package name, without the HOST_ prefix
118 # argument 4 is the type (target or host)
119 ################################################################################
121 define inner-autotools-package
123 ifndef $(2)_LIBTOOL_PATCH
124 ifdef $(3)_LIBTOOL_PATCH
125 $(2)_LIBTOOL_PATCH
= $$($(3)_LIBTOOL_PATCH
)
127 $(2)_LIBTOOL_PATCH ?
= YES
133 $(2)_MAKE
= $$($(3)_MAKE
)
135 $(2)_MAKE ?
= $$(MAKE
)
139 ifndef $(2)_AUTORECONF
140 ifdef $(3)_AUTORECONF
141 $(2)_AUTORECONF
= $$($(3)_AUTORECONF
)
143 $(2)_AUTORECONF ?
= NO
147 ifndef $(2)_GETTEXTIZE
148 ifdef $(3)_GETTEXTIZE
149 $(2)_GETTEXTIZE
= $$($(3)_GETTEXTIZE
)
151 $(2)_GETTEXTIZE ?
= NO
156 $(2)_GETTEXTIZE_OPTS ?
= $$($(3)_GETTEXTIZE_OPTS
)
160 $(2)_AUTORECONF_OPTS ?
= $$($(3)_AUTORECONF_OPTS
)
167 $(2)_INSTALL_OPTS ?
= install
168 $(2)_INSTALL_STAGING_OPTS ?
= DESTDIR
=$$(STAGING_DIR
) install
169 $(2)_INSTALL_TARGET_OPTS ?
= DESTDIR
=$$(TARGET_DIR
) install
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
267 # Append a configure hook if building for a powerpc64 (or powerpc64le) arch.
268 # Must be added after other pre-configure hooks that might regenerate the
269 # configure script and overwrite the changes made here.
270 ifneq ($$(filter powerpc64
%,$$(if
$$(filter target
,$(4)),$$(ARCH
),$$(HOSTARCH
))),)
271 $(2)_PRE_CONFIGURE_HOOKS
+= CONFIGURE_FIX_POWERPC64_HOOK
275 # Build step. Only define it if not already defined by the package .mk
278 ifndef $(2)_BUILD_CMDS
280 define $(2)_BUILD_CMDS
281 $$(TARGET_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_MAKE_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
284 define $(2)_BUILD_CMDS
285 $$(HOST_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_MAKE_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
291 # Host installation step. Only define it if not already defined by the
294 ifndef $(2)_INSTALL_CMDS
295 define $(2)_INSTALL_CMDS
296 $$(HOST_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_INSTALL_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
301 # Staging installation step. Only define it if not already defined by
302 # the package .mk file.
304 ifndef $(2)_INSTALL_STAGING_CMDS
305 define $(2)_INSTALL_STAGING_CMDS
306 $$(TARGET_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_INSTALL_STAGING_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
311 # Target installation step. Only define it if not already defined by
312 # the package .mk file.
314 ifndef $(2)_INSTALL_TARGET_CMDS
315 define $(2)_INSTALL_TARGET_CMDS
316 $$(TARGET_MAKE_ENV
) $$($$(PKG
)_MAKE_ENV
) $$($$(PKG
)_MAKE
) $$($$(PKG
)_INSTALL_TARGET_OPTS
) -C
$$($$(PKG
)_SRCDIR
)
320 # Call the generic package infrastructure to generate the necessary
322 $(call inner-generic-package
,$(1),$(2),$(3),$(4))
326 ################################################################################
327 # autotools-package -- the target generator macro for autotools packages
328 ################################################################################
330 autotools-package
= $(call inner-autotools-package
,$(pkgname
),$(call UPPERCASE
,$(pkgname
)),$(call UPPERCASE
,$(pkgname
)),target
)
331 host-autotools-package
= $(call inner-autotools-package
,host-
$(pkgname
),$(call UPPERCASE
,host-
$(pkgname
)),$(call UPPERCASE
,$(pkgname
)),host
)