author | etisserant |
Fri, 01 Feb 2008 18:01:36 +0100 | |
changeset 377 | bea5a1576cbd |
parent 376 | b082ffeef254 |
child 381 | 854c43cdc24a |
permissions | -rwxr-xr-x |
275
7d5130f2f8ab
fix problem sh. Replace with bash in configure script. For msys, there is a bash version to download.
greg
parents:
267
diff
changeset
|
1 |
#!/bin/bash |
0 | 2 |
|
3 |
# |
|
4 |
# Copyright (C) 2004 Edouard TISSERRANT, Laurent BESSARD |
|
5 |
# Based on Gabriel Gerhardsson's cacheprobe configure script. |
|
6 |
# |
|
7 |
# This file is part of CanFestival, a library implementing CanOpen Stack. |
|
8 |
# |
|
9 |
# This library is free software; you can redistribute it and/or |
|
10 |
# modify it under the terms of the GNU Lesser General Public |
|
11 |
# License as published by the Free Software Foundation; either |
|
12 |
# version 2.1 of the License, or (at your option) any later version. |
|
13 |
# |
|
14 |
# This library is distributed in the hope that it will be useful, |
|
15 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
16 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
17 |
# Lesser General Public License for more details. |
|
18 |
# |
|
19 |
# You should have received a copy of the GNU Lesser General Public |
|
20 |
# License along with this library; if not, write to the Free Software |
|
21 |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
22 |
# |
|
23 |
||
24 |
########################################################################### |
|
25 |
# DEFAULT CANFESTIVAL DEFINES # |
|
26 |
########################################################################### |
|
27 |
||
28 |
# Number of can bus to use |
|
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
29 |
MAX_CAN_BUS_ID=1 |
0 | 30 |
|
31 |
# max bytes to transmit by SDO Put 4 if you only support expedited transfert. |
|
360 | 32 |
#For a normal transfert, (usually for a string), put the maximum string size to transfer. |
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
33 |
SDO_MAX_LENGTH_TRANSFERT=32 |
0 | 34 |
|
35 |
# Number of SDO from differents nodes that the node can manage concurrently. |
|
360 | 36 |
#for a slave node, usually put 1. |
0 | 37 |
SDO_MAX_SIMULTANEOUS_TRANSFERTS=4 |
38 |
||
39 |
# Used for NMTable[bus][nodeId] |
|
40 |
# You can put less of 128 if on the netwo |
|
41 |
# are connected only smaller nodeId node. |
|
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
42 |
NMT_MAX_NODE_ID=128 |
0 | 43 |
|
44 |
#Timeout in milliseconds for SDO. |
|
45 |
# Comment the #define if not used (infinite wait for SDO response message) |
|
46 |
SDO_TIMEOUT_MS=3000 |
|
47 |
||
48 |
MAX_NB_TIMER=32 |
|
49 |
||
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
50 |
# Generic timers declaration defaults |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
51 |
US_TO_TIMEVAL_FACTOR= |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
52 |
TIMEVAL= |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
53 |
TIMEVAL_MAX= |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
54 |
|
0 | 55 |
# Default to little-endian |
56 |
CANOPEN_BIG_ENDIAN= |
|
57 |
||
284 | 58 |
# Max number of active errors managed in error_data structure. |
59 |
EMCY_MAX_ERRORS=8 |
|
60 |
||
360 | 61 |
#Timeout in milliseconds for LSS. |
62 |
LSS_TIMEOUT_MS=1000 |
|
63 |
#Timeout in milliseconds for LSS FastScan. |
|
64 |
LSS_FS_TIMEOUT_MS=100 |
|
65 |
||
0 | 66 |
########################################################################### |
67 |
# DEFAULT BUILD OPTIONS # |
|
68 |
########################################################################### |
|
69 |
||
70 |
# Leave empty for automatic detection |
|
71 |
CC= |
|
354 | 72 |
CXX= |
73 |
LD= |
|
0 | 74 |
|
75 |
#default target |
|
76 |
SUB_TARGET= |
|
77 |
||
78 |
# First compiler option - we will check if it exists |
|
79 |
CC1=gcc |
|
80 |
# Second compiler option - we will check if it exists |
|
81 |
CC2=cc |
|
82 |
||
83 |
# Install prefix |
|
84 |
SUB_PREFIX= |
|
85 |
||
86 |
# Used for C compiler test/detection |
|
87 |
CFLAGS= |
|
88 |
test=conftest |
|
89 |
rm -f $test $test.c |
|
90 |
||
278 | 91 |
if [ "$XENO_CONFIG" = "" ]; then |
190 | 92 |
XENO_CONFIG=/usr/xenomai/bin/xeno-config |
93 |
fi |
|
0 | 94 |
|
95 |
########################################################################### |
|
96 |
# ARGUMENTS PARSING # |
|
97 |
########################################################################### |
|
98 |
while [ $# -ge 1 ]; do |
|
99 |
optarg=`expr "x$1" : 'x[^=]*=\(.*\)'` |
|
100 |
||
101 |
case $1 in |
|
102 |
--cc=*) CC=$optarg;; |
|
341 | 103 |
--cxx=*) CXX=$optarg;; |
104 |
--ld=*) LD=$optarg;; |
|
0 | 105 |
--arch=*) SUB_ARCH_NAME=$optarg;; |
106 |
--os=*) SUB_OS_NAME=$optarg;; |
|
107 |
--prefix=*) SUB_PREFIX=$optarg;; |
|
108 |
--target=*) SUB_TARGET=$optarg;; |
|
109 |
--can=*) SUB_CAN_DRIVER=$optarg;; |
|
110 |
--timers=*) SUB_TIMERS_DRIVER=$optarg;; |
|
111 |
--disable-Ox) DISABLE_OPT=1; |
|
112 |
echo "On user request: Won't optimize with \"-Ox\"";; |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
113 |
--disable-dll) DISABLE_DLL=1; |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
114 |
echo "On user request: Won't create and link to dll";; |
343 | 115 |
--enable-lss) ENABLE_LSS=1; |
116 |
echo "On user request: LSS services enabled";; |
|
360 | 117 |
--enable-lss-fs) ENABLE_LSS_FS=1; |
118 |
echo "On user request: LSS FastScan service enabled";; |
|
195
1510dd61ead0
Added debug level opt in configure and re-enabled debug macros.
etisserant
parents:
190
diff
changeset
|
119 |
--debug=*) DEBUG=$optarg;; |
363
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
120 |
--MAX_CAN_BUS_ID=*) MAX_CAN_BUS_ID=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
121 |
--SDO_MAX_LENGTH_TRANSFERT=*) SDO_MAX_LENGTH_TRANSFERT=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
122 |
--SDO_MAX_SIMULTANEOUS_TRANSFERTS=*) SDO_MAX_SIMULTANEOUS_TRANSFERTS=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
123 |
--NMT_MAX_NODE_ID=*) NMT_MAX_NODE_ID=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
124 |
--SDO_TIMEOUT_MS=*) SDO_TIMEOUT_MS=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
125 |
--CANOPEN_BIG_ENDIAN=*) CANOPEN_BIG_ENDIAN=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
126 |
--MAX_NB_TIMER=*) MAX_NB_TIMER=$optarg;; |
40b351ab5a93
fixed configure command line constant specification bug. Thanks to Jorge.
etisserant
parents:
360
diff
changeset
|
127 |
--EMCY_MAX_ERRORS=*) EMCY_MAX_ERRORS=$optarg;; |
360 | 128 |
--LSS_TIMEOUT_MS=*) LSS_TIMEOUT_MS=$optarg;; |
129 |
--LSS_FS_TIMEOUT_MS=*) LSS_FS_TIMEOUT_MS=$optarg;; |
|
341 | 130 |
--help) |
131 |
echo "Usage: ./configure [options]" |
|
132 |
echo "Options:" |
|
133 |
echo " --cc=foo Use C compiler 'foo' instead of defaults ${CC1} or ${CC2}." |
|
134 |
echo " --cxx=foo Use C++ compiler 'foo' instead of defaults g++." |
|
135 |
echo " --ld=foo Use linker 'foo' instead of ld." |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
136 |
echo " --arch=foo Use architecture 'foo' instead of trying to autodetect." |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
137 |
echo " --os=foo Use operative system 'foo' instead of trying to autodetect." |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
138 |
echo " --prefix=foo Use prefix 'foo' instead of default ${SUB_PREFIX}." |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
139 |
echo " --target=foo Use 'foo' as build target." |
341 | 140 |
echo " \"unix\" for unix-like systems (Linux, Cygwin)" |
141 |
echo " \"win32\" for win32 systems (native, mingw or VC++)" |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
142 |
echo " \"hcs12\" for HCS12 micro-controller" |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
143 |
echo " --can=foo Use 'foo' as CAN driver" |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
144 |
echo " \"peak_linux\" use Linux build host installed Peak driver and library" |
341 | 145 |
echo " see http://www.peak-system.com/linux/" |
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
146 |
echo " \"peak_win32\" use win32 PcanLight Peak driver and library with Cygwin" |
341 | 147 |
echo " see http://www.peak-system.com/themen/download_gb.html" |
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
148 |
echo " \"virtual\" use unix pipe based virtual can driver" |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
149 |
echo " \"socket\" use socket-can " |
341 | 150 |
echo " see http://developer.berlios.de/projects/socketcan/" |
151 |
echo " \"lincan\" lincan driver" |
|
152 |
echo " see http://www.ocera.org/download/components/WP7/lincan-0.3.3.html" |
|
364 | 153 |
echo " \"can4linux\" can4linux driver" |
154 |
echo " see http://www.port.de/engl/canprod/hw_can4linux.html" |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
155 |
echo " --timers=foo Use 'foo' as TIMERS driver (can be either 'unix' or 'xeno')" |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
156 |
echo " --disable-dll Disable run-time dynamic linking of can, led and nvram drivers" |
343 | 157 |
echo " --enable-lss Enable the LSS services" |
360 | 158 |
echo " --enable-lss-fs Enable the LSS FastScan service" |
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
159 |
echo " --disable-Ox Disable gcc \"-Ox\" optimizations." |
329 | 160 |
echo " --debug=foo,foo,.. Enable debug messages, ERR -> only errors, WAR)." |
341 | 161 |
echo " \"PDO\" send errors and warnings through PDO messages" |
162 |
echo " \"ERR\" print errors only, to stdout" |
|
163 |
echo " \"WAR\" print errors and warnings, to stdout" |
|
164 |
echo " \"MSG\" print messages content, to stdout" |
|
0 | 165 |
echo |
166 |
echo "Stack compilation constants" |
|
167 |
echo " --MAX_CAN_BUS_ID [=1] Number of can bus to use" |
|
168 |
echo " --SDO_MAX_LENGTH_TRANSFERT [=32] max bytes to transmit by SDO" |
|
169 |
echo " --SDO_MAX_SIMULTANEOUS_TRANSFERTS [=4] Number of SDO that the node can manage concurrently" |
|
170 |
echo " --NMT_MAX_NODE_ID [=128] can be reduced to gain memory on small network" |
|
171 |
echo " --SDO_TIMEOUT_MS [=3000] Timeout in milliseconds for SDO (None to disable the feature)" |
|
284 | 172 |
echo " --EMCY_MAX_ERRORS [=8] Max number of active errors managed in error_data structure" |
360 | 173 |
echo " --LSS_TIMEOUT_MS [=1000] Timeout in milliseconds for LSS services." |
174 |
echo " LSS must be enabled with \"--enable-lss\"" |
|
175 |
echo " --LSS_FS_TIMEOUT_MS [=100] Timeout in milliseconds for LSS FastScan service." |
|
176 |
echo " LSS FastScan must be enabled with \"--enable-lss-fs\"" |
|
0 | 177 |
exit 0;; |
178 |
*) echo "Unknown argument ${1}"; exit -1;; |
|
179 |
esac |
|
180 |
||
181 |
shift |
|
182 |
done |
|
183 |
||
184 |
########################################################################### |
|
185 |
# GUESS OS/ARCH # |
|
186 |
########################################################################### |
|
187 |
||
188 |
if [ "$SUB_OS_NAME" = "" ]; then |
|
189 |
SUB_OS_NAME="`(uname -s | sed \"s/\//-/\" | sed \"s/_/-/\" \ |
|
190 |
| sed \"s/-.*//g\") 2>&1`" |
|
191 |
fi |
|
192 |
||
193 |
if [ "$SUB_ARCH_NAME" = "" ]; then |
|
194 |
if [ "$CC" = "" ]; then |
|
195 |
A_NAME="`(uname -m) 2>&1`" |
|
196 |
else |
|
197 |
A_NAME="`$CC -dumpmachine | sed 's:-.*::'`" |
|
198 |
fi |
|
199 |
fi |
|
200 |
||
201 |
# x86 |
|
341 | 202 |
if [ "$A_NAME" = "i386" -o "$A_NAME" = "i486" -o "$A_NAME" = "i586" -o "$A_NAME" = "i686" -o "$A_NAME" = "x86" ]; then |
0 | 203 |
SUB_ARCH_NAME=x86 |
204 |
fi |
|
205 |
||
206 |
# x86_64 |
|
207 |
if [ "$A_NAME" = "x86_64" ]; then |
|
208 |
SUB_ARCH_NAME=x86_64 |
|
209 |
fi |
|
210 |
||
211 |
# ppc |
|
212 |
if [ "$A_NAME" = "powerpc" ]; then |
|
213 |
SUB_ARCH_NAME=ppc |
|
214 |
fi |
|
215 |
||
216 |
# ppc64 |
|
217 |
if [ "$A_NAME" = "powerpc64" ]; then |
|
218 |
SUB_ARCH_NAME=ppc64 |
|
219 |
fi |
|
220 |
||
221 |
# arm |
|
222 |
if [ "$A_NAME" = "arm" ]; then |
|
223 |
SUB_ARCH_NAME=arm |
|
224 |
fi |
|
225 |
||
376
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
226 |
# mingw32 |
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
227 |
if [ "$A_NAME" = "mingw32" ]; then |
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
228 |
SUB_ARCH_NAME=mingw32 |
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
229 |
fi |
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
230 |
|
0 | 231 |
if [ "$SUB_ARCH_NAME" = "" ]; then |
232 |
echo "Error: could not detect what architecture this system is running!" |
|
233 |
echo "Please supply manually instead with \"--arch=foo\"" |
|
234 |
exit -1 |
|
235 |
fi |
|
236 |
||
376
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
237 |
echo "Host OS: ${SUB_OS_NAME}" |
b082ffeef254
little fix on arch detection when using mingw32-only compiler from within cygwin's bash
etisserant
parents:
364
diff
changeset
|
238 |
echo "Host arch: ${SUB_ARCH_NAME}" |
0 | 239 |
|
240 |
if [ "$SUB_ARCH_NAME" = "x86_64" -a "$CC" = "gcc" ]; then |
|
241 |
# Only if we are on x86_64 and using gcc |
|
242 |
# For shared library generation, it needs this |
|
243 |
SUB_PROG_CFLAGS=-fPIC |
|
244 |
fi |
|
245 |
||
200 | 246 |
if [ "$SUB_ARCH_NAME" = "ppc" -o "$SUB_ARCH_NAME" = "powerpc" ]; then |
247 |
# PowerPC uses big endian format |
|
248 |
CANOPEN_BIG_ENDIAN=1 |
|
249 |
fi |
|
250 |
||
0 | 251 |
########################################################################### |
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
252 |
# DEFAULT TARGET/DRIVERS GUESSING # |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
253 |
########################################################################### |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
254 |
# If target not specified, try to gess one |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
255 |
if [ "$SUB_TARGET" = "" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
256 |
if [ "$SUB_OS_NAME" = "CYGWIN" ]; then |
38 | 257 |
echo "Choosing unix (cygwin) target" |
258 |
SUB_TARGET=unix |
|
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
259 |
fi |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
260 |
if [ "$SUB_OS_NAME" = "Linux" ]; then |
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
261 |
echo "Choosing unix target" |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
262 |
SUB_TARGET=unix |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
263 |
fi |
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
264 |
if [ "$SUB_OS_NAME" = "MINGW32" ]; then |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
265 |
echo "Choosing windows target" |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
266 |
SUB_TARGET=win32 |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
267 |
fi |
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
268 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
269 |
|
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
270 |
# Try to gess can |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
271 |
if [ "$SUB_CAN_DRIVER" = "" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
272 |
if [ "$SUB_TARGET" = "unix" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
273 |
if [ -e /usr/lib/libpcan.so ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
274 |
echo "Choosing installed Peak driver as CAN driver." |
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
275 |
SUB_CAN_DRIVER=peak_linux |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
276 |
elif [ "$SUB_OS_NAME" = "CYGWIN" -a "PCAN_LIB" != "" ]; then |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
277 |
echo "Choosing installed Peak driver as CAN driver." |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
278 |
SUB_CAN_DRIVER=peak_win32 |
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
279 |
else |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
280 |
echo "Choosing virtual CAN driver." |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
281 |
SUB_CAN_DRIVER=virtual |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
282 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
283 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
284 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
285 |
|
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
286 |
# If target is unix, default timers also |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
287 |
if [ "$SUB_TARGET" = "unix" -a "$SUB_TIMERS_DRIVER" = "" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
288 |
echo "Choosing unix timers driver." |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
289 |
SUB_TIMERS_DRIVER=unix |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
290 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
291 |
|
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
292 |
# If target is windows, default timers also |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
293 |
if [ "$SUB_TARGET" = "win32" -a "$SUB_TIMERS_DRIVER" = "" ]; then |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
294 |
echo "Choosing windows timers driver." |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
295 |
SUB_TIMERS_DRIVER=win32 |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
296 |
fi |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
297 |
|
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
298 |
# Warn for unstalled peak driver if choosen |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
299 |
if [ "$SUB_CAN_DRIVER" = "peak" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
300 |
if [ ! -e /usr/lib/libpcan.so ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
301 |
echo "Peak driver hasn't been installed !" |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
302 |
exit -1 |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
303 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
304 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
305 |
|
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
306 |
########################################################################### |
0 | 307 |
# TARGET/DRIVER SPECIFIC CFLAGS and OPTIONS # |
308 |
########################################################################### |
|
309 |
if [ "$SUB_TARGET" = "hcs12" ]; then |
|
360 | 310 |
# Only if we want to compile for a C HCS12 |
81 | 311 |
# it is a big endian architecture. |
312 |
CANOPEN_BIG_ENDIAN=1 |
|
0 | 313 |
# search for gcc hcs12 compiler m6811-elf-gcc or m68hc12-gcc ? |
314 |
if [ "$CC" = "" ]; then |
|
315 |
which m6811-elf-gcc >/dev/null 2>&1 |
|
316 |
if (( $? )); then |
|
317 |
which m68hc12-gcc >/dev/null 2>&1 |
|
318 |
if (( $? )); then |
|
319 |
echo "Please use --cc flag to specify compiler" |
|
320 |
exit 0 |
|
321 |
else |
|
322 |
CC=m68hc12-gcc |
|
323 |
fi |
|
324 |
else |
|
325 |
CC=m6811-elf-gcc |
|
326 |
SUB_PROG_CFLAGS=-m68hc12 |
|
327 |
fi |
|
328 |
fi |
|
329 |
fi |
|
330 |
||
331 |
#### CAN_DRIVER #### |
|
332 |
||
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
333 |
if [ "$SUB_CAN_DRIVER" = "peak_linux" ]; then |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
334 |
SUB_CAN_DLL_CFLAGS=$SUB_CAN_DLL_CFLAGS\ -lpcan |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
335 |
fi |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
336 |
|
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
337 |
PW32DIR=drivers/can_peak_win32 |
38 | 338 |
if [ "$SUB_CAN_DRIVER" = "peak_win32" ]; then |
41
e70439f50539
First working cygwin/pcan_light commit. can_peak_win32.c is obfuscated.
etisserant
parents:
40
diff
changeset
|
339 |
if [ "$PCAN_HEADER" = "" -o "PCAN_LIB" = "" ]; then |
38 | 340 |
echo "!!! ERROR !!! Please set PCAN_LIB PCAN_HEADER [PCAN_INCLUDE] to appropriate paths ! " |
341 |
fi |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
342 |
SUB_CAN_DLL_CFLAGS=$SUB_CAN_DLL_CFLAGS\ -liberty\ \'$PCAN_LIB\' |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
343 |
echo "Converting PcanLib header files for gcc -> $PW32DIR/cancfg.h" |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
344 |
cat $PW32DIR/cancfg.h.head $PCAN_INCLUDE/$PCAN_HEADER > $PW32DIR/cancfg.h |
331 | 345 |
echo >> $PW32DIR/cancfg.h |
41
e70439f50539
First working cygwin/pcan_light commit. can_peak_win32.c is obfuscated.
etisserant
parents:
40
diff
changeset
|
346 |
# second port handling |
e70439f50539
First working cygwin/pcan_light commit. can_peak_win32.c is obfuscated.
etisserant
parents:
40
diff
changeset
|
347 |
if [ "$PCAN2_HEADER" != "" ]; then |
e70439f50539
First working cygwin/pcan_light commit. can_peak_win32.c is obfuscated.
etisserant
parents:
40
diff
changeset
|
348 |
echo "Stripping down second Pcan Light header " |
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
349 |
echo >> $PW32DIR/cancfg.h |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
350 |
echo "// Stripped PcanLight header to prevent typedef conflicts ">> $PW32DIR/cancfg.h |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
351 |
echo >> $PW32DIR/cancfg.h |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
352 |
grep __stdcall $PCAN_INCLUDE/$PCAN2_HEADER >> $PW32DIR/cancfg.h |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
353 |
echo '#define PCAN2_HEADER_' >> $PW32DIR/cancfg.h |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
354 |
SUB_CAN_DLL_CFLAGS=$SUB_CAN_DLL_CFLAGS\ \'$PCAN2_LIB\' |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
355 |
fi |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
356 |
if grep -q CANHwType $PW32DIR/cancfg.h ; then |
42
17f0ea205942
cygwin/pcan_light commit. Changes in configure for dual port handling.
etisserant
parents:
41
diff
changeset
|
357 |
echo "Peak Init HwType, IO_Port and IRQ will be passed in environment :" |
17f0ea205942
cygwin/pcan_light commit. Changes in configure for dual port handling.
etisserant
parents:
41
diff
changeset
|
358 |
echo " PCANHwType PCANIO_Port PCANInterupt" |
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
359 |
echo '#define extra_PCAN_init_params' >> $PW32DIR/cancfg.h |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
360 |
fi |
331 | 361 |
if ! grep -q CAN_Init $PW32DIR/cancfg.h ; then |
362 |
echo "Pcan Light header/lib is for second port of device only" |
|
363 |
echo "CAN_* calls redefined to CAN2_* " |
|
364 |
echo '#define CAN_Init CAN2_Init' >> $PW32DIR/cancfg.h |
|
365 |
echo '#define CAN_Read CAN2_Read' >> $PW32DIR/cancfg.h |
|
366 |
echo '#define CAN_Write CAN2_Write' >> $PW32DIR/cancfg.h |
|
367 |
echo '#define CAN_Close CAN2_Close' >> $PW32DIR/cancfg.h |
|
368 |
fi |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
369 |
cat $PW32DIR/cancfg.h.tail >> $PW32DIR/cancfg.h |
38 | 370 |
fi |
371 |
||
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
372 |
if [ "$SUB_CAN_DRIVER" = "none" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
373 |
SUB_CAN_DRIVER= |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
374 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
375 |
|
0 | 376 |
#### TIMERS_DRIVER #### |
377 |
||
378 |
if [ "$SUB_TIMERS_DRIVER" = "unix" ]; then |
|
38 | 379 |
if [ "$SUB_OS_NAME" != "CYGWIN" ]; then |
380 |
SUB_EXE_CFLAGS=$SUB_EXE_CFLAGS\ -lpthread\ -lrt |
|
381 |
fi |
|
0 | 382 |
fi |
383 |
||
384 |
if [ "$SUB_TIMERS_DRIVER" = "xeno" ]; then |
|
341 | 385 |
SUB_EXE_CFLAGS=$SUB_EXE_CFLAGS\ -lnative\ -lrtdm\ -L`$XENO_CONFIG --library-dir` |
0 | 386 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ `$XENO_CONFIG --xeno-cflags` |
47
8a1047ab51f4
SOCKET-CAN support added. Many thanks to Jan Kiszka !
etisserant
parents:
42
diff
changeset
|
387 |
RTCAN_SOCKET=1 |
0 | 388 |
fi |
389 |
||
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
390 |
if [ "$SUB_TIMERS_DRIVER" = "none" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
391 |
SUB_TIMERS_DRIVER= |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
392 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
393 |
|
0 | 394 |
########################################################################### |
354 | 395 |
# GUESS TOOLCHAIN # |
0 | 396 |
########################################################################### |
397 |
# If CC is empty, the user wanted automatic detection |
|
398 |
if [ "$CC" = "" ]; then |
|
399 |
# Check for second compiler, CC2 |
|
400 |
cat > $test.c <<EOF |
|
401 |
int main() { return 0; } |
|
402 |
EOF |
|
403 |
if test "`($CC2 -c $CFLAGS $test.c) 2>&1`" = ""; then |
|
404 |
DETECTCC=$CC2 |
|
405 |
echo "Checking for ${CC2}... Yes." |
|
406 |
else |
|
407 |
echo "Checking for ${CC2}... No." |
|
408 |
fi |
|
409 |
rm -f $test.c $test.o |
|
410 |
||
411 |
# Check for first compiler, CC1 |
|
412 |
cat > $test.c <<EOF |
|
413 |
int main() { return 0; } |
|
414 |
EOF |
|
415 |
if test "`($CC1 -c $CFLAGS $test.c) 2>&1`" = ""; then |
|
416 |
DETECTCC=$CC1 |
|
417 |
echo "Checking for ${CC1}... Yes." |
|
418 |
else |
|
419 |
echo "Checking for ${CC1}... No." |
|
420 |
fi |
|
421 |
rm -f $test.c $test.o |
|
422 |
CC=$DETECTCC |
|
423 |
fi |
|
424 |
# Check if we decided on a compiler after all |
|
425 |
if [ "$CC" = "" ]; then |
|
426 |
echo "Error: Could not find a C compiler" |
|
427 |
echo "Please supply the wanted compiler" |
|
428 |
exit -1 |
|
429 |
fi |
|
430 |
||
354 | 431 |
echo "Using ${CC} as a C compiler" |
0 | 432 |
|
433 |
SUB_BINUTILS_PREFIX=`echo "$CC" | sed 's/gcc$//'` |
|
434 |
||
354 | 435 |
if [ "$CXX" = "" ]; then |
436 |
CXX=${SUB_BINUTILS_PREFIX}g++ |
|
437 |
fi |
|
438 |
||
439 |
echo "Using ${CXX} as a C++ compiler" |
|
440 |
||
441 |
if [ "$SUB_TARGET" = "win32" ]; then |
|
442 |
# on cygwin/mingw, choose g++ as a linker for native target |
|
443 |
if [ "$LD" = "" ]; then |
|
444 |
LD=$CXX |
|
445 |
fi |
|
446 |
if [ "$SUB_OS_NAME" = "CYGWIN" ]; then |
|
447 |
SUB_PROG_CFLAGS="-mno-cygwin" |
|
448 |
fi |
|
449 |
fi |
|
450 |
||
451 |
if [ "$SUB_TARGET" = "unix" ]; then |
|
452 |
if [ "$LD" = "" ]; then |
|
453 |
LD=$CC |
|
454 |
fi |
|
455 |
fi |
|
456 |
||
457 |
echo "Using ${LD} as a linker" |
|
458 |
||
0 | 459 |
# Guess prefix as regard cross compiling target machine |
460 |
if [ "$SUB_PREFIX" = "" ]; then |
|
461 |
$CC -dumpspecs |grep -A 1 'cross_compile'|grep -q 1 |
|
462 |
if (( $? )); then |
|
463 |
SUB_PREFIX=/usr/local |
|
464 |
echo "Not cross-compiling. Will install in $SUB_PREFIX"; |
|
465 |
else |
|
466 |
SUB_PREFIX=/usr/`$CC -dumpmachine` |
|
467 |
echo "This is a cross-compiler. Will install in $SUB_PREFIX"; |
|
468 |
fi |
|
469 |
fi |
|
470 |
||
471 |
echo "Using prefix: ${SUB_PREFIX}" |
|
472 |
||
473 |
########################################################################### |
|
354 | 474 |
# GUESS DEPENDENCIES # |
475 |
########################################################################### |
|
476 |
||
477 |
if which wx-config >/dev/null 2>&1; then |
|
478 |
echo -n "Testing wxWidgets compiles ... " |
|
479 |
cat > /tmp/wx_test.cpp <<EOF |
|
480 |
#include "wx/wx.h" |
|
481 |
class MyApp : public wxApp |
|
482 |
{ |
|
483 |
}; |
|
484 |
IMPLEMENT_APP(MyApp) |
|
485 |
EOF |
|
486 |
if $CXX /tmp/wx_test.cpp `wx-config --cxxflags` `wx-config --libs` -o /tmp/wx_test >/dev/null 2>&1 ; then |
|
487 |
SUB_WX=1 |
|
488 |
echo "Yes" |
|
489 |
else |
|
490 |
SUB_WX=0 |
|
491 |
echo "No" |
|
492 |
fi |
|
493 |
rm -f /tmp/wx_test* |
|
494 |
else |
|
495 |
SUB_WX=0 |
|
496 |
echo "No wxWidgets available" |
|
497 |
fi |
|
498 |
||
499 |
########################################################################### |
|
0 | 500 |
# CANFESTIVAL DEFINES --> config.h # |
501 |
########################################################################### |
|
502 |
# Some CONSTANTS preparation |
|
503 |
||
504 |
# Create include/config.h with the relevant contents |
|
505 |
rm -f include/config.h |
|
77 | 506 |
echo "/* !!!!!!!!!! FILE GENERATED by configure. DO NOT EDIT !!!!!!!!!!*/" >> include/config.h |
507 |
echo "" >> include/config.h |
|
508 |
echo "/*"\ >> include/config.h |
|
0 | 509 |
echo "This file is part of CanFestival, a library implementing CanOpen Stack." >> include/config.h |
510 |
echo "" >> include/config.h |
|
511 |
echo "Copyright (C): Edouard TISSERANT and Francis DUPIN" >> include/config.h |
|
512 |
echo "See COPYING file for copyrights details." >> include/config.h |
|
513 |
echo "" >> include/config.h |
|
514 |
echo "This library is free software; you can redistribute it and/or" >> include/config.h |
|
515 |
echo "modify it under the terms of the GNU Lesser General Public" >> include/config.h |
|
516 |
echo "License as published by the Free Software Foundation; either" >> include/config.h |
|
517 |
echo "version 2.1 of the License, or (at your option) any later version." >> include/config.h |
|
518 |
echo "" >> include/config.h |
|
519 |
echo "This library is distributed in the hope that it will be useful," >> include/config.h |
|
520 |
echo "but WITHOUT ANY WARRANTY; without even the implied warranty of" >> include/config.h |
|
521 |
echo "MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU" >> include/config.h |
|
522 |
echo "Lesser General Public License for more details." >> include/config.h |
|
523 |
echo "" >> include/config.h |
|
524 |
echo "You should have received a copy of the GNU Lesser General Public" >> include/config.h |
|
525 |
echo "License along with this library; if not, write to the Free Software" >> include/config.h |
|
526 |
echo "Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA" >> include/config.h |
|
527 |
echo "*/" >> include/config.h |
|
528 |
echo "" >> include/config.h |
|
529 |
echo "#ifndef _CONFIG_H_" >> include/config.h |
|
530 |
echo "#define _CONFIG_H_" >> include/config.h |
|
531 |
echo "" >> include/config.h |
|
532 |
for i in \ |
|
533 |
MAX_CAN_BUS_ID\ |
|
534 |
SDO_MAX_LENGTH_TRANSFERT\ |
|
535 |
SDO_MAX_SIMULTANEOUS_TRANSFERTS\ |
|
536 |
NMT_MAX_NODE_ID\ |
|
537 |
SDO_TIMEOUT_MS\ |
|
538 |
MAX_NB_TIMER\ |
|
539 |
CANOPEN_BIG_ENDIAN\ |
|
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
540 |
US_TO_TIMEVAL_FACTOR\ |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
541 |
TIMEVAL\ |
47
8a1047ab51f4
SOCKET-CAN support added. Many thanks to Jan Kiszka !
etisserant
parents:
42
diff
changeset
|
542 |
TIMEVAL_MAX\ |
284 | 543 |
RTCAN_SOCKET\ |
360 | 544 |
EMCY_MAX_ERRORS\ |
545 |
LSS_TIMEOUT_MS\ |
|
546 |
LSS_FS_TIMEOUT_MS; do |
|
0 | 547 |
if [ "${!i}" = "" ]; then |
77 | 548 |
echo "/* $i is not defined */" >> include/config.h |
0 | 549 |
else |
550 |
echo "#define $i ${!i}" >> include/config.h |
|
551 |
fi |
|
552 |
done |
|
553 |
echo "" >> include/config.h |
|
91
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
554 |
|
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
555 |
for i in \ |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
556 |
SDO_MAX_SIMULTANEOUS_TRANSFERTS\ |
284 | 557 |
NMT_MAX_NODE_ID\ |
558 |
EMCY_MAX_ERRORS; do |
|
91
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
559 |
echo "#define REPEAT_"$i"_TIMES(repeat)\\">> include/config.h |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
560 |
times=${!i} |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
561 |
result="" |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
562 |
for (( j=0; j<times; j++ ));do |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
563 |
result="$result repeat" |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
564 |
done |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
565 |
echo $result >> include/config.h |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
566 |
done |
ed2612282988
- Better array initialization in data.h CANOPEN_NODE_DATA_INITIALIZER macro. Use a little hack with configure and config.h to create the "pure Ansi C" initializer.
etisserant
parents:
81
diff
changeset
|
567 |
|
0 | 568 |
echo "#endif /* _CONFIG_H_ */" >> include/config.h |
569 |
||
570 |
########################################################################### |
|
571 |
# DEBUG DEFINES/CFLAGS # |
|
572 |
########################################################################### |
|
329 | 573 |
|
574 |
save_ifs="$IFS"; IFS=',' |
|
575 |
||
576 |
for DEBUG_METHOD in $DEBUG; |
|
577 |
do |
|
578 |
IFS="$save_ifs" |
|
579 |
case $DEBUG_METHOD in |
|
580 |
ERR)ERR=1;; |
|
581 |
WAR)WAR=1;ERR=1;; |
|
582 |
MSG)MSG=1;; |
|
583 |
PDO)PDO=1;WAR=1;ERR=1;; |
|
584 |
*)echo "" |
|
585 |
echo "$DEBUG_METHOD is not a valid debug's method" |
|
586 |
echo "Possible Debug's methods are : \"ERR\", \"WAR\", \"MSG\", \"PDO\"" |
|
587 |
exit -1 |
|
588 |
;; |
|
589 |
esac |
|
590 |
done |
|
591 |
||
592 |
if [ $WAR ]; then |
|
593 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DDEBUG_WAR_CONSOLE_ON; |
|
594 |
fi |
|
595 |
||
596 |
if [ $ERR ]; then |
|
597 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DDEBUG_ERR_CONSOLE_ON; |
|
598 |
fi |
|
599 |
||
600 |
if [ $MSG ]; then |
|
601 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DDEBUG_MSG_CONSOLE_ON; |
|
602 |
fi |
|
603 |
||
604 |
if [ $PDO ]; then |
|
605 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DDEBUG_PDO_CONSOLE_ON; |
|
606 |
fi |
|
607 |
||
608 |
if [ $DEBUG ]; then |
|
609 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -g |
|
610 |
fi |
|
611 |
||
612 |
IFS="$save_ifs" |
|
0 | 613 |
|
614 |
if [ "$DISABLE_OPT" = "1" ]; then |
|
615 |
SUB_OPT_CFLAGS= |
|
616 |
else |
|
617 |
SUB_OPT_CFLAGS=\$\(OPT_CFLAGS\) |
|
618 |
fi |
|
619 |
||
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
620 |
if [ "$DISABLE_DLL" = "1" ]; then |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
621 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DNOT_USE_DYNAMIC_LOADING |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
622 |
SUB_ENABLE_DLL_DRIVERS=0 |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
623 |
else |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
624 |
SUB_ENABLE_DLL_DRIVERS=1 |
354 | 625 |
if [ "$SUB_TARGET" = "win32" ]; then |
351
fb106ad03770
fix SUB_EXE_CFLAGS in configure to link without "-ldl" when use MINGW
greg
parents:
343
diff
changeset
|
626 |
SUB_EXE_CFLAGS=$SUB_EXE_CFLAGS |
fb106ad03770
fix SUB_EXE_CFLAGS in configure to link without "-ldl" when use MINGW
greg
parents:
343
diff
changeset
|
627 |
else |
fb106ad03770
fix SUB_EXE_CFLAGS in configure to link without "-ldl" when use MINGW
greg
parents:
343
diff
changeset
|
628 |
SUB_EXE_CFLAGS=$SUB_EXE_CFLAGS\ -ldl |
fb106ad03770
fix SUB_EXE_CFLAGS in configure to link without "-ldl" when use MINGW
greg
parents:
343
diff
changeset
|
629 |
fi |
fb106ad03770
fix SUB_EXE_CFLAGS in configure to link without "-ldl" when use MINGW
greg
parents:
343
diff
changeset
|
630 |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
631 |
fi |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
632 |
|
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
633 |
|
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
634 |
if [ "$DISABLE_DLL" = "1" ]; then |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
635 |
SUB_EXE_CFLAGS=$SUB_EXE_CFLAGS\ $SUB_CAN_DLL_CFLAGS |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
636 |
fi |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
637 |
|
343 | 638 |
if [ $ENABLE_LSS ]; then |
639 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DCO_ENABLE_LSS; |
|
640 |
SUB_ENABLE_LSS=1 |
|
360 | 641 |
if [ $ENABLE_LSS_FS ]; then |
642 |
SUB_PROG_CFLAGS=$SUB_PROG_CFLAGS\ -DCO_ENABLE_LSS_FS; |
|
643 |
fi |
|
343 | 644 |
else |
645 |
SUB_ENABLE_LSS=0 |
|
646 |
fi |
|
647 |
||
0 | 648 |
########################################################################### |
649 |
# CREATE MAKEFILES # |
|
650 |
########################################################################### |
|
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
651 |
# General Makefiles |
0 | 652 |
MAKEFILES=Makefile.in\ |
653 |
\ src/Makefile.in\ |
|
654 |
\ drivers/Makefile.in\ |
|
655 |
\ objdictgen/Makefile.in\ |
|
279
9b69f2fabafe
added config.py.in, filled by configure, so that python program using objdictedit can gat compilation params. Reomved old dead files.
etisserant
parents:
278
diff
changeset
|
656 |
\ examples/Makefile.in\ |
9b69f2fabafe
added config.py.in, filled by configure, so that python program using objdictedit can gat compilation params. Reomved old dead files.
etisserant
parents:
278
diff
changeset
|
657 |
\ objdictgen/canfestival_config.py.in |
0 | 658 |
|
24
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
659 |
# Drivers dependent Makefiles |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
660 |
if [ "$SUB_TIMERS_DRIVER" != "" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
661 |
MAKEFILES=$MAKEFILES\ |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
662 |
\ drivers/timers_$SUB_TIMERS_DRIVER/Makefile.in |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
663 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
664 |
|
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
665 |
if [ "$SUB_CAN_DRIVER" != "" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
666 |
MAKEFILES=$MAKEFILES\ |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
667 |
\ drivers/can_$SUB_CAN_DRIVER/Makefile.in |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
668 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
669 |
|
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
670 |
# Target dependent Makefiles |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
671 |
MAKEFILES=$MAKEFILES\ drivers/$SUB_TARGET/Makefile.in |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
672 |
|
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
673 |
if [ "$SUB_TARGET" = "unix" ]; then |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
674 |
MAKEFILES=$MAKEFILES\ |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
675 |
\ examples/TestMasterSlave/Makefile.in |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
676 |
fi |
a9543d2ccd56
Linux and BSD now use "unix" target. Generic is for driverless compilation.
etisserant
parents:
15
diff
changeset
|
677 |
|
166
b6fbc1c59a44
Added a MicroMod Master sample in examples/TestMasterMicroMod. Fixed some SDO abort code and callback problem in sdo.c.
etisserant
parents:
145
diff
changeset
|
678 |
if [ "$SUB_TARGET" = "unix" ]; then |
b6fbc1c59a44
Added a MicroMod Master sample in examples/TestMasterMicroMod. Fixed some SDO abort code and callback problem in sdo.c.
etisserant
parents:
145
diff
changeset
|
679 |
MAKEFILES=$MAKEFILES\ |
b6fbc1c59a44
Added a MicroMod Master sample in examples/TestMasterMicroMod. Fixed some SDO abort code and callback problem in sdo.c.
etisserant
parents:
145
diff
changeset
|
680 |
\ examples/TestMasterMicroMod/Makefile.in |
b6fbc1c59a44
Added a MicroMod Master sample in examples/TestMasterMicroMod. Fixed some SDO abort code and callback problem in sdo.c.
etisserant
parents:
145
diff
changeset
|
681 |
fi |
b6fbc1c59a44
Added a MicroMod Master sample in examples/TestMasterMicroMod. Fixed some SDO abort code and callback problem in sdo.c.
etisserant
parents:
145
diff
changeset
|
682 |
|
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
683 |
if [ "$SUB_TARGET" = "win32" ]; then |
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
684 |
MAKEFILES=$MAKEFILES\ |
329 | 685 |
\ examples/TestMasterSlave/Makefile.in\ |
354 | 686 |
\ examples/TestMasterMicroMod/Makefile.in |
687 |
fi |
|
688 |
||
689 |
if [ "$SUB_WX" = "1" ]; then |
|
690 |
MAKEFILES=$MAKEFILES\ |
|
329 | 691 |
\ examples/DS401_Master/Makefile.in\ |
692 |
\ examples/DS401_Slave_Gui/Makefile.in |
|
693 |
fi |
|
267
96c688ebcde7
Add win32 target (--can=win32) to compile with msys and mingw32
greg
parents:
246
diff
changeset
|
694 |
|
0 | 695 |
if [ "$SUB_TARGET" = "hcs12" ]; then |
696 |
MAKEFILES=$MAKEFILES\ |
|
697 |
\ examples/gene_SYNC_HCS12/Makefile.in |
|
698 |
fi |
|
699 |
||
700 |
for makefile_in in $MAKEFILES; do |
|
701 |
makefile=`echo $makefile_in | sed 's:.in$::'` |
|
702 |
echo "Creating $makefile" |
|
703 |
sed < $makefile_in " |
|
704 |
s:SUB_CC:${CC}: |
|
329 | 705 |
s:SUB_CXX:${CXX}: |
706 |
s:SUB_LD:${LD}: |
|
0 | 707 |
s:SUB_PROG_CFLAGS:${SUB_PROG_CFLAGS}: |
708 |
s:SUB_EXE_CFLAGS:${SUB_EXE_CFLAGS}: |
|
709 |
s:SUB_PREFIX:${SUB_PREFIX}: |
|
710 |
s:SUB_OS_NAME:${SUB_OS_NAME}: |
|
711 |
s:SUB_ARCH_NAME:${SUB_ARCH_NAME}: |
|
712 |
s:SUB_OPT_CFLAGS:${SUB_OPT_CFLAGS}: |
|
713 |
s:SUB_TARGET:${SUB_TARGET}: |
|
714 |
s:SUB_BINUTILS_PREFIX:${SUB_BINUTILS_PREFIX}: |
|
715 |
s:SUB_TIMERS_DRIVER:timers_${SUB_TIMERS_DRIVER}: |
|
716 |
s:SUB_CAN_DRIVER:can_${SUB_CAN_DRIVER}: |
|
145
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
717 |
s:SUB_CAN_DLL_CFLAGS:${SUB_CAN_DLL_CFLAGS}: |
e747d2e26af0
Win32 Native support and dynamicaly loaded CAN drivers for Linux, Cygwin and Win32.
etisserant
parents:
93
diff
changeset
|
718 |
s:SUB_ENABLE_DLL_DRIVERS:${SUB_ENABLE_DLL_DRIVERS}: |
343 | 719 |
s:SUB_ENABLE_LSS:${SUB_ENABLE_LSS}: |
354 | 720 |
s:SUB_WX:${SUB_WX}: |
0 | 721 |
" > $makefile |
722 |
done |
|
723 |
||
724 |
echo "All done." |