1 |
786 |
skrzyp |
dnl Process this file with autoconf to produce a configure script.
|
2 |
|
|
dnl ====================================================================
|
3 |
|
|
dnl
|
4 |
|
|
dnl configure.in
|
5 |
|
|
dnl
|
6 |
|
|
dnl Top-level configure script for eCos software.
|
7 |
|
|
dnl
|
8 |
|
|
dnl ====================================================================
|
9 |
|
|
dnl ####ECOSHOSTGPLCOPYRIGHTBEGIN####
|
10 |
|
|
dnl -------------------------------------------
|
11 |
|
|
dnl This file is part of the eCos host tools.
|
12 |
|
|
dnl Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
|
13 |
|
|
dnl
|
14 |
|
|
dnl This program is free software; you can redistribute it and/or modify
|
15 |
|
|
dnl it under the terms of the GNU General Public License as published by
|
16 |
|
|
dnl the Free Software Foundation; either version 2 or (at your option) any
|
17 |
|
|
dnl later version.
|
18 |
|
|
dnl
|
19 |
|
|
dnl This program is distributed in the hope that it will be useful, but
|
20 |
|
|
dnl WITHOUT ANY WARRANTY; without even the implied warranty of
|
21 |
|
|
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
22 |
|
|
dnl General Public License for more details.
|
23 |
|
|
dnl
|
24 |
|
|
dnl You should have received a copy of the GNU General Public License
|
25 |
|
|
dnl along with this program; if not, write to the
|
26 |
|
|
dnl Free Software Foundation, Inc., 51 Franklin Street,
|
27 |
|
|
dnl Fifth Floor, Boston, MA 02110-1301, USA.
|
28 |
|
|
dnl -------------------------------------------
|
29 |
|
|
dnl ####ECOSHOSTGPLCOPYRIGHTEND####
|
30 |
|
|
dnl ====================================================================
|
31 |
|
|
dnl#####DESCRIPTIONBEGIN####
|
32 |
|
|
dnl
|
33 |
|
|
dnl Author(s): bartv
|
34 |
|
|
dnl Contact(s): bartv
|
35 |
|
|
dnl Date: 1998/12/17
|
36 |
|
|
dnl Version: 0.01
|
37 |
|
|
dnl
|
38 |
|
|
dnl####DESCRIPTIONEND####
|
39 |
|
|
dnl ====================================================================
|
40 |
|
|
|
41 |
|
|
dnl eCos is a componentized architecture for deeply embedded systems.
|
42 |
|
|
dnl It requires a very different configuration system from typical
|
43 |
|
|
dnl autoconfiscated software such as the various GNU packages.
|
44 |
|
|
dnl
|
45 |
|
|
dnl The main eCos host-side software is autoconfiscated to some extent,
|
46 |
|
|
dnl in that the usual sequence of "configure;make;make install" will
|
47 |
|
|
dnl work under the right conditions. However it does not conform to
|
48 |
|
|
dnl the GNU coding standards in numerous ways, for example "make dist"
|
49 |
|
|
dnl will not work. The main eCos host-side software lives in the
|
50 |
|
|
dnl "host" subdirectory, and is built unconditionally.
|
51 |
|
|
dnl
|
52 |
|
|
dnl The eCos target-side software lives in the "packages" subdirectory,
|
53 |
|
|
dnl and is organized in numerous subdirectories corresponding to different
|
54 |
|
|
dnl packages and potentially different versions of each package. In the
|
55 |
|
|
dnl master repository managed by CVS there will only be one version of
|
56 |
|
|
dnl each package, "current", which simplifies things somewhat. Other
|
57 |
|
|
dnl repositories will not be quite so straightforward and require a
|
58 |
|
|
dnl suitable administration tool.
|
59 |
|
|
dnl
|
60 |
|
|
dnl The various eCos packages are not currently auto-confiscated.
|
61 |
|
|
dnl In particular building eCos requires the use of eCos configuration
|
62 |
|
|
dnl technology, not autoconf - there is simply no good way of handling
|
63 |
|
|
dnl a system as highly configurable as eCos using a few command-line
|
64 |
|
|
dnl options passed to "configure". There would also be serious confusion
|
65 |
|
|
dnl between host and target, especially when e.g. cross-compiling the
|
66 |
|
|
dnl host tools. However a possible future enhancement
|
67 |
|
|
dnl would involve making eCos releases via configure and make, thus
|
68 |
|
|
dnl allowing for a release process that combines building the various
|
69 |
|
|
dnl host-side tools such as gcc with creating eCos epk's for the various
|
70 |
|
|
dnl packages.
|
71 |
|
|
dnl
|
72 |
|
|
dnl A complication is that some of the eCos target-side packages also
|
73 |
|
|
dnl contain package-specific host-side support. For example the
|
74 |
|
|
dnl Linux synthetic target support uses special host-side software
|
75 |
|
|
dnl to provide I/O facilities: the architectural HAL package provdes
|
76 |
|
|
dnl generic support, the synthetic ethernet package extends this
|
77 |
|
|
dnl with ethernet support, and so on. Such package-specific host-side
|
78 |
|
|
dnl software does not belong in the main host subdirectory, that
|
79 |
|
|
dnl would make it very difficult to distribute new packages or
|
80 |
|
|
dnl new versions of a package. However keeping the code with the
|
81 |
|
|
dnl various packages makes building more complicated.
|
82 |
|
|
dnl
|
83 |
|
|
dnl 1) if the entire repository is managed by CVS or anoncvs, this
|
84 |
|
|
dnl configure script will search the packages tree for any packages
|
85 |
|
|
dnl that have host-side software that needs to be built -
|
86 |
|
|
dnl specifically, that have a file "configure" inside a "host"
|
87 |
|
|
dnl subdirectory in a version of a package.
|
88 |
|
|
dnl
|
89 |
|
|
dnl 2) if instead the repository contains additional packages
|
90 |
|
|
dnl installed as epk's and managed by an administration tool then
|
91 |
|
|
dnl it is the responsibility of that tool to let the users build
|
92 |
|
|
dnl and rebuild the host-side software as required, for whichever
|
93 |
|
|
dnl host platform or platforms are being used. In other words
|
94 |
|
|
dnl it is the responsibility of the admin tool to create a
|
95 |
|
|
dnl suitable build directory and run "configure; make; make install",
|
96 |
|
|
dnl usually as part of the installation process. Note that several
|
97 |
|
|
dnl versions of a package may be installed, and it is the
|
98 |
|
|
dnl responsibility of each package to take this into account
|
99 |
|
|
dnl (although the configure macros are aware of this to some extent,
|
100 |
|
|
dnl and will e.g. generate suitable install directory names).
|
101 |
|
|
dnl Also note that the top-level configure script will not pick
|
102 |
|
|
dnl up such packages because they will be versioned, i.e. the
|
103 |
|
|
dnl test for current/host/configure will fail because the
|
104 |
|
|
dnl version will not be "current".
|
105 |
|
|
dnl
|
106 |
|
|
dnl 3) as a special case it may be desirable to ship pre-built binaries
|
107 |
|
|
dnl of some of the package-specific software. It is not clear
|
108 |
|
|
dnl just what would be the best way of shipping these - putting
|
109 |
|
|
dnl them into the epk's would not be quite right because that would
|
110 |
|
|
dnl make the epk's host-specific rather than generic.
|
111 |
|
|
dnl
|
112 |
|
|
dnl There is an unresolved problem with possible dependencies between
|
113 |
|
|
dnl packages, if e.g. the host-side of the synthetic ethernet package could
|
114 |
|
|
dnl only be built after the architectural synthetic target package.
|
115 |
|
|
|
116 |
|
|
dnl Some of the eCos documentation is generic and lives in the "doc"
|
117 |
|
|
dnl subdirectory. Other eCos documentation is package-specific and lives
|
118 |
|
|
dnl in the appropriate package directory. At present there is no support
|
119 |
|
|
dnl for building the documentation via configure and make, but such
|
120 |
|
|
dnl support may be added in future.
|
121 |
|
|
dnl
|
122 |
|
|
dnl There is a subdirectory acsupport containing various files such
|
123 |
|
|
dnl as config.guess and install.sh that are common. This also contains
|
124 |
|
|
dnl an acinclude.m4 file with various macros that are useful for
|
125 |
|
|
dnl eCos.
|
126 |
|
|
|
127 |
|
|
dnl Generic initialization.
|
128 |
|
|
AC_INIT(acsupport/config.guess)
|
129 |
|
|
AC_CONFIG_AUX_DIR(acsupport)
|
130 |
|
|
AC_CANONICAL_HOST
|
131 |
|
|
AM_INIT_AUTOMAKE(eCos,2.0,0)
|
132 |
|
|
AM_MAINTAINER_MODE
|
133 |
|
|
|
134 |
|
|
dnl Detect attempts at cross-compilation. Usually this is the result
|
135 |
|
|
dnl of somebody failing to read the documentation or the README.host
|
136 |
|
|
dnl file.
|
137 |
|
|
if test "${target_alias}x" != "x" ; then
|
138 |
|
|
AC_MSG_ERROR("
|
139 |
|
|
================================================================
|
140 |
|
|
You have specified a target ${target_alias}.
|
141 |
|
|
This configure script is for building the eCos host-side support
|
142 |
|
|
tools which are independent of the target architecture. It is not
|
143 |
|
|
used for building eCos itself.
|
144 |
|
|
|
145 |
|
|
If your intention is to build eCos itself then you should first
|
146 |
|
|
read the relevant documentation starting with the User's Guide.
|
147 |
|
|
|
148 |
|
|
If your intention is to rebuild the host-side support tools then
|
149 |
|
|
there is no need to specify --target.
|
150 |
|
|
|
151 |
|
|
If your intention is to cross-compile the host-side support tools
|
152 |
|
|
then you should be using --host instead of --target.
|
153 |
|
|
================================================================
|
154 |
|
|
")
|
155 |
|
|
fi
|
156 |
|
|
|
157 |
|
|
dnl Make sure the source and build trees are kept separate.
|
158 |
|
|
ECOS_CHECK_BUILD_ne_SRC
|
159 |
|
|
|
160 |
|
|
dnl Nothing actually gets built in this directory, so there should be no
|
161 |
|
|
dnl need to worry about compiler flags etc. Instead, the problem is
|
162 |
|
|
dnl figuring out what should actually get built.
|
163 |
|
|
dnl
|
164 |
|
|
dnl 1) the host subdirectory should always get built, if it exists.
|
165 |
|
|
dnl With the 2.0 release system the directory gets moved to
|
166 |
|
|
dnl tools/src
|
167 |
|
|
|
168 |
|
|
if test -f "${srcdir}/host/configure" ; then
|
169 |
|
|
ecos_subdirs="host"
|
170 |
|
|
elif test -f "${srcdir}/tools/src/configure" ; then
|
171 |
|
|
ecos_subdirs="tools/src"
|
172 |
|
|
else
|
173 |
|
|
ecos_subdirs=""
|
174 |
|
|
fi
|
175 |
|
|
|
176 |
|
|
dnl 2) any package which has a configure script in a
|
177 |
|
|
dnl current/host subdirectory should also get built.
|
178 |
|
|
dnl
|
179 |
|
|
dnl Searching the directory tree is currently done by shell globbing.
|
180 |
|
|
dnl Invoking "find" with suitable arguments might be quicker, but
|
181 |
|
|
dnl less portable. On some hosts there may be problems with environmental
|
182 |
|
|
dnl limits if too many packages provide host-side software.
|
183 |
|
|
dnl
|
184 |
|
|
dnl Currently there is no ordering of packages, so e.g. a device
|
185 |
|
|
dnl driver's host-side support cannot depend on some HAL package
|
186 |
|
|
dnl because the latter may not have been built and installed yet.
|
187 |
|
|
dnl This is a good thing because packages are meant to be self-contained
|
188 |
|
|
dnl whenever possible. Interaction between packages is typically handled
|
189 |
|
|
dnl at the Tcl level at run-time, so there are no build-time complications.
|
190 |
|
|
|
191 |
|
|
AC_MSG_NOTICE([searching for configure scripts in eCos packages'
|
192 |
|
|
host subdirectories. This operation can take a long time.
|
193 |
|
|
If running on Windows and the eCos repository is accessed
|
194 |
|
|
over a network then it may take some hours.])
|
195 |
|
|
ecos_hostdirs=""
|
196 |
|
|
ecos_configure_scripts="${srcdir}/packages/*/*/host/configure"
|
197 |
|
|
ecos_configure_scripts="${ecos_configure_scripts} ${srcdir}/packages/*/*/*/host/configure"
|
198 |
|
|
ecos_configure_scripts="${ecos_configure_scripts} ${srcdir}/packages/*/*/*/*/host/configure"
|
199 |
|
|
ecos_configure_scripts="${ecos_configure_scripts} ${srcdir}/packages/*/*/*/*/*/host/configure"
|
200 |
|
|
ecos_configure_scripts="${ecos_configure_scripts} ${srcdir}/packages/*/*/*/*/*/*/host/configure"
|
201 |
|
|
for configure in ${ecos_configure_scripts}; do
|
202 |
|
|
if test -f ${configure}; then
|
203 |
|
|
dnl A configure script has been found in the source tree.
|
204 |
|
|
dnl First turn it into a directory, then replace the absolute path
|
205 |
|
|
dnl with a relative one.
|
206 |
|
|
hostdir=`dirname ${configure}`
|
207 |
|
|
hostdir=`echo ${hostdir} | sed -e "s:^${srcdir}/::"`
|
208 |
|
|
ecos_hostdirs="${ecos_hostdirs} ${hostdir}"
|
209 |
|
|
fi
|
210 |
|
|
done
|
211 |
|
|
AC_MSG_NOTICE([found configure scripts in
|
212 |
|
|
${ecos_hostdirs}])
|
213 |
|
|
ecos_subdirs="${ecos_subdirs} ${ecos_hostdirs}"
|
214 |
|
|
|
215 |
|
|
dnl Because the eCos directory layout does not conform to GNU conventions
|
216 |
|
|
dnl it is necessary to create various levels of intermediate directories.
|
217 |
|
|
dnl This happens via config.status, prior to the recursion into the
|
218 |
|
|
dnl appropriate directories.
|
219 |
|
|
AC_OUTPUT_COMMANDS([${CONFIG_SHELL-/bin/sh} ${ac_top_srcdir}/acsupport/mkinstalldirs ${REQUIRED_DIRS}],REQUIRED_DIRS="${ecos_subdirs}")
|
220 |
|
|
|
221 |
|
|
dnl This causes warnings with current versions of configure which
|
222 |
|
|
dnl want literal arguments. Since this script deliberately searches
|
223 |
|
|
dnl for subdirectories there is no obvious way to eliminate those
|
224 |
|
|
dnl warnings.
|
225 |
|
|
AC_CONFIG_SUBDIRS(${ecos_subdirs})
|
226 |
|
|
AC_OUTPUT(Makefile)
|