]>
Commit | Line | Data |
---|---|---|
1 | ## | |
2 | ## Makefile for OpenSSL | |
3 | ## | |
4 | ||
5 | VERSION= | |
6 | MAJOR= | |
7 | MINOR= | |
8 | SHLIB_VERSION_NUMBER= | |
9 | SHLIB_VERSION_HISTORY= | |
10 | SHLIB_MAJOR= | |
11 | SHLIB_MINOR= | |
12 | SHLIB_EXT= | |
13 | PLATFORM=dist | |
14 | OPTIONS= | |
15 | CONFIGURE_ARGS= | |
16 | SHLIB_TARGET= | |
17 | ||
18 | # HERE indicates where this Makefile lives. This can be used to indicate | |
19 | # where sub-Makefiles are expected to be. Currently has very limited usage, | |
20 | # and should probably not be bothered with at all. | |
21 | HERE=. | |
22 | ||
23 | # INSTALL_PREFIX is for package builders so that they can configure | |
24 | # for, say, /usr/ and yet have everything installed to /tmp/somedir/usr/. | |
25 | # Normally it is left empty. | |
26 | INSTALL_PREFIX= | |
27 | INSTALLTOP=/usr/local/ssl | |
28 | ||
29 | # Do not edit this manually. Use Configure --openssldir=DIR do change this! | |
30 | OPENSSLDIR=/usr/local/ssl | |
31 | ||
32 | # NO_IDEA - Define to build without the IDEA algorithm | |
33 | # NO_RC4 - Define to build without the RC4 algorithm | |
34 | # NO_RC2 - Define to build without the RC2 algorithm | |
35 | # THREADS - Define when building with threads, you will probably also need any | |
36 | # system defines as well, i.e. _REENTERANT for Solaris 2.[34] | |
37 | # TERMIO - Define the termio terminal subsystem, needed if sgtty is missing. | |
38 | # TERMIOS - Define the termios terminal subsystem, Silicon Graphics. | |
39 | # LONGCRYPT - Define to use HPUX 10.x's long password modification to crypt(3). | |
40 | # DEVRANDOM - Give this the value of the 'random device' if your OS supports | |
41 | # one. 32 bytes will be read from this when the random | |
42 | # number generator is initalised. | |
43 | # SSL_FORBID_ENULL - define if you want the server to be not able to use the | |
44 | # NULL encryption ciphers. | |
45 | # | |
46 | # LOCK_DEBUG - turns on lots of lock debug output :-) | |
47 | # REF_CHECK - turn on some xyz_free() assertions. | |
48 | # REF_PRINT - prints some stuff on structure free. | |
49 | # CRYPTO_MDEBUG - turns on my 'memory leak' detecting stuff | |
50 | # MFUNC - Make all Malloc/Free/Realloc calls call | |
51 | # CRYPTO_malloc/CRYPTO_free/CRYPTO_realloc which can be setup to | |
52 | # call application defined callbacks via CRYPTO_set_mem_functions() | |
53 | # MD5_ASM needs to be defined to use the x86 assembler for MD5 | |
54 | # SHA1_ASM needs to be defined to use the x86 assembler for SHA1 | |
55 | # RMD160_ASM needs to be defined to use the x86 assembler for RIPEMD160 | |
56 | # Do not define B_ENDIAN or L_ENDIAN if 'unsigned long' == 8. It must | |
57 | # equal 4. | |
58 | # PKCS1_CHECK - pkcs1 tests. | |
59 | ||
60 | CC= cc | |
61 | CFLAG= -O | |
62 | DEPFLAG= | |
63 | PEX_LIBS= | |
64 | EX_LIBS= | |
65 | EXE_EXT= | |
66 | ARFLAGS= | |
67 | AR=ar $(ARFLAGS) r | |
68 | RANLIB= ranlib | |
69 | NM= nm | |
70 | PERL= perl | |
71 | TAR= tar | |
72 | TARFLAGS= --no-recursion --record-size=10240 | |
73 | MAKEDEPPROG=makedepend | |
74 | LIBDIR=lib | |
75 | ||
76 | # We let the C compiler driver to take care of .s files. This is done in | |
77 | # order to be excused from maintaining a separate set of architecture | |
78 | # dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC | |
79 | # gcc, then the driver will automatically translate it to -xarch=v8plus | |
80 | # and pass it down to assembler. | |
81 | AS=$(CC) -c | |
82 | ASFLAG=$(CFLAG) | |
83 | ||
84 | # For x86 assembler: Set PROCESSOR to 386 if you want to support | |
85 | # the 80386. | |
86 | PROCESSOR= | |
87 | ||
88 | # CPUID module collects small commonly used assembler snippets | |
89 | CPUID_OBJ= | |
90 | BN_ASM= bn_asm.o | |
91 | DES_ENC= des_enc.o fcrypt_b.o | |
92 | AES_ENC= aes_core.o aes_cbc.o | |
93 | BF_ENC= bf_enc.o | |
94 | CAST_ENC= c_enc.o | |
95 | RC4_ENC= rc4_enc.o | |
96 | RC5_ENC= rc5_enc.o | |
97 | MD5_ASM_OBJ= | |
98 | SHA1_ASM_OBJ= | |
99 | RMD160_ASM_OBJ= | |
100 | WP_ASM_OBJ= | |
101 | CMLL_ENC= | |
102 | MODES_ASM_OBJ= | |
103 | ENGINES_ASM_OBJ= | |
104 | PERLASM_SCHEME= | |
105 | ||
106 | # KRB5 stuff | |
107 | KRB5_INCLUDES= | |
108 | LIBKRB5= | |
109 | ||
110 | # Zlib stuff | |
111 | ZLIB_INCLUDE= | |
112 | LIBZLIB= | |
113 | ||
114 | # TOP level FIPS install directory. | |
115 | FIPSDIR= | |
116 | ||
117 | # This is the location of fipscanister.o and friends. | |
118 | # The FIPS module build will place it $(INSTALLTOP)/lib | |
119 | # but since $(INSTALLTOP) can only take the default value | |
120 | # when the module is built it will be in /usr/local/ssl/lib | |
121 | # $(INSTALLTOP) for this build may be different so hard | |
122 | # code the path. | |
123 | ||
124 | FIPSLIBDIR= | |
125 | ||
126 | # The location of the library which contains fipscanister.o | |
127 | # normally it will be libcrypto unless fipsdso is set in which | |
128 | # case it will be libfips. If not compiling in FIPS mode at all | |
129 | # this is empty making it a useful test for a FIPS compile. | |
130 | ||
131 | FIPSCANLIB= | |
132 | ||
133 | # Shared library base address. Currently only used on Windows. | |
134 | # | |
135 | ||
136 | BASEADDR= | |
137 | ||
138 | DIRS= crypto ssl engines apps test tools | |
139 | ENGDIRS= ccgost | |
140 | SHLIBDIRS= crypto ssl | |
141 | ||
142 | # dirs in crypto to build | |
143 | SDIRS= \ | |
144 | objects \ | |
145 | md2 md4 md5 sha mdc2 hmac ripemd whrlpool \ | |
146 | des aes rc2 rc4 rc5 idea bf cast camellia seed modes \ | |
147 | bn ec rsa dsa ecdsa dh ecdh dso engine \ | |
148 | buffer bio stack lhash rand err \ | |
149 | evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5 \ | |
150 | cms pqueue ts jpake srp store cmac | |
151 | # keep in mind that the above list is adjusted by ./Configure | |
152 | # according to no-xxx arguments... | |
153 | ||
154 | # tests to perform. "alltests" is a special word indicating that all tests | |
155 | # should be performed. | |
156 | TESTS = alltests | |
157 | ||
158 | MAKEFILE= Makefile | |
159 | ||
160 | MANDIR=$(OPENSSLDIR)/man | |
161 | MAN1=1 | |
162 | MAN3=3 | |
163 | MANSUFFIX= | |
164 | HTMLSUFFIX=html | |
165 | HTMLDIR=$(OPENSSLDIR)/html | |
166 | SHELL=/bin/sh | |
167 | ||
168 | TOP= . | |
169 | ONEDIRS=out tmp | |
170 | EDIRS= times doc bugs util include certs ms shlib mt demos perl sf dep VMS | |
171 | WDIRS= windows | |
172 | LIBS= libcrypto.a libssl.a | |
173 | SHARED_CRYPTO=libcrypto$(SHLIB_EXT) | |
174 | SHARED_SSL=libssl$(SHLIB_EXT) | |
175 | SHARED_LIBS= | |
176 | SHARED_LIBS_LINK_EXTS= | |
177 | SHARED_LDFLAGS= | |
178 | ||
179 | GENERAL= Makefile | |
180 | BASENAME= openssl | |
181 | NAME= $(BASENAME)-$(VERSION) | |
182 | TARFILE= $(NAME).tar | |
183 | WTARFILE= $(NAME)-win.tar | |
184 | EXHEADER= e_os2.h | |
185 | HEADER= e_os.h | |
186 | ||
187 | all: Makefile build_all openssl.pc libssl.pc libcrypto.pc | |
188 | ||
189 | # as we stick to -e, CLEARENV ensures that local variables in lower | |
190 | # Makefiles remain local and variable. $${VAR+VAR} is tribute to Korn | |
191 | # shell, which [annoyingly enough] terminates unset with error if VAR | |
192 | # is not present:-( TOP= && unset TOP is tribute to HP-UX /bin/sh, | |
193 | # which terminates unset with error if no variable was present:-( | |
194 | CLEARENV= TOP= && unset TOP $${LIB+LIB} $${LIBS+LIBS} \ | |
195 | $${INCLUDE+INCLUDE} $${INCLUDES+INCLUDES} \ | |
196 | $${DIR+DIR} $${DIRS+DIRS} $${SRC+SRC} \ | |
197 | $${LIBSRC+LIBSRC} $${LIBOBJ+LIBOBJ} $${ALL+ALL} \ | |
198 | $${EXHEADER+EXHEADER} $${HEADER+HEADER} \ | |
199 | $${GENERAL+GENERAL} $${CFLAGS+CFLAGS} \ | |
200 | $${ASFLAGS+ASFLAGS} $${AFLAGS+AFLAGS} \ | |
201 | $${LDCMD+LDCMD} $${LDFLAGS+LDFLAGS} $${SCRIPTS+SCRIPTS} \ | |
202 | $${SHAREDCMD+SHAREDCMD} $${SHAREDFLAGS+SHAREDFLAGS} \ | |
203 | $${SHARED_LIB+SHARED_LIB} $${LIBEXTRAS+LIBEXTRAS} | |
204 | ||
205 | BUILDENV= PLATFORM='$(PLATFORM)' PROCESSOR='$(PROCESSOR)' \ | |
206 | CC='$(CC)' CFLAG='$(CFLAG)' \ | |
207 | AS='$(CC)' ASFLAG='$(CFLAG) -c' \ | |
208 | AR='$(AR)' NM='$(NM)' RANLIB='$(RANLIB)' \ | |
209 | CROSS_COMPILE='$(CROSS_COMPILE)' \ | |
210 | PERL='$(PERL)' ENGDIRS='$(ENGDIRS)' \ | |
211 | SDIRS='$(SDIRS)' LIBRPATH='$(INSTALLTOP)/$(LIBDIR)' \ | |
212 | INSTALL_PREFIX='$(INSTALL_PREFIX)' \ | |
213 | INSTALLTOP='$(INSTALLTOP)' OPENSSLDIR='$(OPENSSLDIR)' \ | |
214 | LIBDIR='$(LIBDIR)' \ | |
215 | MAKEDEPEND='$$$${TOP}/util/domd $$$${TOP} -MD $(MAKEDEPPROG)' \ | |
216 | DEPFLAG='-DOPENSSL_NO_DEPRECATED $(DEPFLAG)' \ | |
217 | MAKEDEPPROG='$(MAKEDEPPROG)' \ | |
218 | SHARED_LDFLAGS='$(SHARED_LDFLAGS)' \ | |
219 | KRB5_INCLUDES='$(KRB5_INCLUDES)' LIBKRB5='$(LIBKRB5)' \ | |
220 | ZLIB_INCLUDE='$(ZLIB_INCLUDE)' LIBZLIB='$(LIBZLIB)' \ | |
221 | EXE_EXT='$(EXE_EXT)' SHARED_LIBS='$(SHARED_LIBS)' \ | |
222 | SHLIB_EXT='$(SHLIB_EXT)' SHLIB_TARGET='$(SHLIB_TARGET)' \ | |
223 | PEX_LIBS='$(PEX_LIBS)' EX_LIBS='$(EX_LIBS)' \ | |
224 | CPUID_OBJ='$(CPUID_OBJ)' \ | |
225 | BN_ASM='$(BN_ASM)' DES_ENC='$(DES_ENC)' \ | |
226 | AES_ENC='$(AES_ENC)' CMLL_ENC='$(CMLL_ENC)' \ | |
227 | BF_ENC='$(BF_ENC)' CAST_ENC='$(CAST_ENC)' \ | |
228 | RC4_ENC='$(RC4_ENC)' RC5_ENC='$(RC5_ENC)' \ | |
229 | SHA1_ASM_OBJ='$(SHA1_ASM_OBJ)' \ | |
230 | MD5_ASM_OBJ='$(MD5_ASM_OBJ)' \ | |
231 | RMD160_ASM_OBJ='$(RMD160_ASM_OBJ)' \ | |
232 | WP_ASM_OBJ='$(WP_ASM_OBJ)' \ | |
233 | MODES_ASM_OBJ='$(MODES_ASM_OBJ)' \ | |
234 | ENGINES_ASM_OBJ='$(ENGINES_ASM_OBJ)' \ | |
235 | PERLASM_SCHEME='$(PERLASM_SCHEME)' \ | |
236 | FIPSLIBDIR='${FIPSLIBDIR}' \ | |
237 | FIPSDIR='${FIPSDIR}' \ | |
238 | FIPSCANLIB="$${FIPSCANLIB:-$(FIPSCANLIB)}" \ | |
239 | THIS=$${THIS:-$@} MAKEFILE=Makefile MAKEOVERRIDES= | |
240 | # MAKEOVERRIDES= effectively "equalizes" GNU-ish and SysV-ish make flavors, | |
241 | # which in turn eliminates ambiguities in variable treatment with -e. | |
242 | ||
243 | # BUILD_CMD is a generic macro to build a given target in a given | |
244 | # subdirectory. The target must be given through the shell variable | |
245 | # `target' and the subdirectory to build in must be given through `dir'. | |
246 | # This macro shouldn't be used directly, use RECURSIVE_BUILD_CMD or | |
247 | # BUILD_ONE_CMD instead. | |
248 | # | |
249 | # BUILD_ONE_CMD is a macro to build a given target in a given | |
250 | # subdirectory if that subdirectory is part of $(DIRS). It requires | |
251 | # exactly the same shell variables as BUILD_CMD. | |
252 | # | |
253 | # RECURSIVE_BUILD_CMD is a macro to build a given target in all | |
254 | # subdirectories defined in $(DIRS). It requires that the target | |
255 | # is given through the shell variable `target'. | |
256 | BUILD_CMD= if [ -d "$$dir" ]; then \ | |
257 | ( cd $$dir && echo "making $$target in $$dir..." && \ | |
258 | $(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. DIR=$$dir $$target \ | |
259 | ) || exit 1; \ | |
260 | fi | |
261 | RECURSIVE_BUILD_CMD=for dir in $(DIRS); do $(BUILD_CMD); done | |
262 | BUILD_ONE_CMD=\ | |
263 | if expr " $(DIRS) " : ".* $$dir " >/dev/null 2>&1; then \ | |
264 | $(BUILD_CMD); \ | |
265 | fi | |
266 | ||
267 | reflect: | |
268 | @[ -n "$(THIS)" ] && $(CLEARENV) && $(MAKE) $(THIS) -e $(BUILDENV) | |
269 | ||
270 | sub_all: build_all | |
271 | build_all: build_libs build_apps build_tests build_tools | |
272 | ||
273 | build_libs: build_crypto build_ssl build_engines | |
274 | ||
275 | build_crypto: | |
276 | @dir=crypto; target=all; $(BUILD_ONE_CMD) | |
277 | build_ssl: | |
278 | @dir=ssl; target=all; $(BUILD_ONE_CMD) | |
279 | build_engines: | |
280 | @dir=engines; target=all; $(BUILD_ONE_CMD) | |
281 | build_apps: | |
282 | @dir=apps; target=all; $(BUILD_ONE_CMD) | |
283 | build_tests: | |
284 | @dir=test; target=all; $(BUILD_ONE_CMD) | |
285 | build_tools: | |
286 | @dir=tools; target=all; $(BUILD_ONE_CMD) | |
287 | ||
288 | all_testapps: build_libs build_testapps | |
289 | build_testapps: | |
290 | @dir=crypto; target=testapps; $(BUILD_ONE_CMD) | |
291 | ||
292 | fips_premain_dso$(EXE_EXT): libcrypto.a | |
293 | [ -z "$(FIPSCANLIB)" ] || $(CC) $(CFLAG) -Iinclude \ | |
294 | -DFINGERPRINT_PREMAIN_DSO_LOAD -o $@ \ | |
295 | $(FIPSLIBDIR)fips_premain.c $(FIPSLIBDIR)fipscanister.o \ | |
296 | libcrypto.a $(EX_LIBS) | |
297 | ||
298 | libcrypto$(SHLIB_EXT): libcrypto.a fips_premain_dso$(EXE_EXT) | |
299 | @if [ "$(SHLIB_TARGET)" != "" ]; then \ | |
300 | if [ "$(FIPSCANLIB)" = "libcrypto" ]; then \ | |
301 | FIPSLD_LIBCRYPTO=libcrypto.a ; \ | |
302 | FIPSLD_CC="$(CC)"; CC=$(FIPSDIR)/bin/fipsld; \ | |
303 | export CC FIPSLD_CC FIPSLD_LIBCRYPTO; \ | |
304 | fi; \ | |
305 | $(MAKE) -e SHLIBDIRS=crypto build-shared; \ | |
306 | else \ | |
307 | echo "There's no support for shared libraries on this platform" >&2; \ | |
308 | exit 1; \ | |
309 | fi | |
310 | ||
311 | libssl$(SHLIB_EXT): libcrypto$(SHLIB_EXT) libssl.a | |
312 | @if [ "$(SHLIB_TARGET)" != "" ]; then \ | |
313 | $(MAKE) SHLIBDIRS=ssl SHLIBDEPS='-lcrypto' build-shared; \ | |
314 | else \ | |
315 | echo "There's no support for shared libraries on this platform" >&2; \ | |
316 | exit 1; \ | |
317 | fi | |
318 | ||
319 | clean-shared: | |
320 | @set -e; for i in $(SHLIBDIRS); do \ | |
321 | if [ -n "$(SHARED_LIBS_LINK_EXTS)" ]; then \ | |
322 | tmp="$(SHARED_LIBS_LINK_EXTS)"; \ | |
323 | for j in $${tmp:-x}; do \ | |
324 | ( set -x; rm -f lib$$i$$j ); \ | |
325 | done; \ | |
326 | fi; \ | |
327 | ( set -x; rm -f lib$$i$(SHLIB_EXT) ); \ | |
328 | if [ "$(PLATFORM)" = "Cygwin" ]; then \ | |
329 | ( set -x; rm -f cyg$$i$(SHLIB_EXT) lib$$i$(SHLIB_EXT).a ); \ | |
330 | fi; \ | |
331 | done | |
332 | ||
333 | link-shared: | |
334 | @ set -e; for i in $(SHLIBDIRS); do \ | |
335 | $(MAKE) -f $(HERE)/Makefile.shared -e $(BUILDENV) \ | |
336 | LIBNAME=$$i LIBVERSION=$(SHLIB_MAJOR).$(SHLIB_MINOR) \ | |
337 | LIBCOMPATVERSIONS=";$(SHLIB_VERSION_HISTORY)" \ | |
338 | symlink.$(SHLIB_TARGET); \ | |
339 | libs="$$libs -l$$i"; \ | |
340 | done | |
341 | ||
342 | build-shared: do_$(SHLIB_TARGET) link-shared | |
343 | ||
344 | do_$(SHLIB_TARGET): | |
345 | @ set -e; libs='-L. $(SHLIBDEPS)'; for i in $(SHLIBDIRS); do \ | |
346 | if [ "$$i" = "ssl" -a -n "$(LIBKRB5)" ]; then \ | |
347 | libs="$(LIBKRB5) $$libs"; \ | |
348 | fi; \ | |
349 | $(CLEARENV) && $(MAKE) -f Makefile.shared -e $(BUILDENV) \ | |
350 | LIBNAME=$$i LIBVERSION=$(SHLIB_MAJOR).$(SHLIB_MINOR) \ | |
351 | LIBCOMPATVERSIONS=";$(SHLIB_VERSION_HISTORY)" \ | |
352 | LIBDEPS="$$libs $(EX_LIBS)" \ | |
353 | link_a.$(SHLIB_TARGET); \ | |
354 | libs="-l$$i $$libs"; \ | |
355 | done | |
356 | ||
357 | libcrypto.pc: Makefile | |
358 | @ ( echo 'prefix=$(INSTALLTOP)'; \ | |
359 | echo 'exec_prefix=$${prefix}'; \ | |
360 | echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ | |
361 | echo 'includedir=$${prefix}/include'; \ | |
362 | echo ''; \ | |
363 | echo 'Name: OpenSSL-libcrypto'; \ | |
364 | echo 'Description: OpenSSL cryptography library'; \ | |
365 | echo 'Version: '$(VERSION); \ | |
366 | echo 'Requires: '; \ | |
367 | echo 'Libs: -L$${libdir} -lcrypto'; \ | |
368 | echo 'Libs.private: $(EX_LIBS)'; \ | |
369 | echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > libcrypto.pc | |
370 | ||
371 | libssl.pc: Makefile | |
372 | @ ( echo 'prefix=$(INSTALLTOP)'; \ | |
373 | echo 'exec_prefix=$${prefix}'; \ | |
374 | echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ | |
375 | echo 'includedir=$${prefix}/include'; \ | |
376 | echo ''; \ | |
377 | echo 'Name: OpenSSL'; \ | |
378 | echo 'Description: Secure Sockets Layer and cryptography libraries'; \ | |
379 | echo 'Version: '$(VERSION); \ | |
380 | echo 'Requires: '; \ | |
381 | echo 'Libs: -L$${libdir} -lssl -lcrypto'; \ | |
382 | echo 'Libs.private: $(EX_LIBS)'; \ | |
383 | echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > libssl.pc | |
384 | ||
385 | openssl.pc: Makefile | |
386 | @ ( echo 'prefix=$(INSTALLTOP)'; \ | |
387 | echo 'exec_prefix=$${prefix}'; \ | |
388 | echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ | |
389 | echo 'includedir=$${prefix}/include'; \ | |
390 | echo ''; \ | |
391 | echo 'Name: OpenSSL'; \ | |
392 | echo 'Description: Secure Sockets Layer and cryptography libraries and tools'; \ | |
393 | echo 'Version: '$(VERSION); \ | |
394 | echo 'Requires: '; \ | |
395 | echo 'Libs: -L$${libdir} -lssl -lcrypto'; \ | |
396 | echo 'Libs.private: $(EX_LIBS)'; \ | |
397 | echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > openssl.pc | |
398 | ||
399 | Makefile: Makefile.org Configure config | |
400 | @echo "Makefile is older than Makefile.org, Configure or config." | |
401 | @echo "Reconfigure the source tree (via './config' or 'perl Configure'), please." | |
402 | @false | |
403 | ||
404 | libclean: | |
405 | rm -f *.map *.so *.so.* *.dylib *.dll engines/*.so engines/*.dll engines/*.dylib *.a engines/*.a */lib */*/lib | |
406 | ||
407 | clean: libclean | |
408 | rm -f shlib/*.o *.o core a.out fluff rehash.time testlog make.log cctest cctest.c | |
409 | @set -e; target=clean; $(RECURSIVE_BUILD_CMD) | |
410 | rm -f $(LIBS) | |
411 | rm -f openssl.pc libssl.pc libcrypto.pc | |
412 | rm -f speed.* .pure | |
413 | rm -f $(TARFILE) | |
414 | @set -e; for i in $(ONEDIRS) ;\ | |
415 | do \ | |
416 | rm -fr $$i/*; \ | |
417 | done | |
418 | ||
419 | makefile.one: files | |
420 | $(PERL) util/mk1mf.pl >makefile.one; \ | |
421 | sh util/do_ms.sh | |
422 | ||
423 | files: | |
424 | $(PERL) $(TOP)/util/files.pl Makefile > $(TOP)/MINFO | |
425 | @set -e; target=files; $(RECURSIVE_BUILD_CMD) | |
426 | ||
427 | links: | |
428 | @$(PERL) $(TOP)/util/mkdir-p.pl include/openssl | |
429 | @$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER) | |
430 | @set -e; target=links; $(RECURSIVE_BUILD_CMD) | |
431 | ||
432 | gentests: | |
433 | @(cd test && echo "generating dummy tests (if needed)..." && \ | |
434 | $(CLEARENV) && $(MAKE) -e $(BUILDENV) TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on generate ); | |
435 | ||
436 | dclean: | |
437 | rm -rf *.bak include/openssl certs/.0 | |
438 | @set -e; target=dclean; $(RECURSIVE_BUILD_CMD) | |
439 | ||
440 | rehash: rehash.time | |
441 | rehash.time: certs apps | |
442 | @if [ -z "$(CROSS_COMPILE)" ]; then \ | |
443 | (OPENSSL="`pwd`/util/opensslwrap.sh"; \ | |
444 | [ -x "apps/openssl.exe" ] && OPENSSL="apps/openssl.exe" || :; \ | |
445 | OPENSSL_DEBUG_MEMORY=on; \ | |
446 | export OPENSSL OPENSSL_DEBUG_MEMORY; \ | |
447 | $(PERL) tools/c_rehash certs/demo) && \ | |
448 | touch rehash.time; \ | |
449 | else :; fi | |
450 | ||
451 | test: tests | |
452 | ||
453 | tests: rehash | |
454 | @(cd test && echo "testing..." && \ | |
455 | $(CLEARENV) && $(MAKE) -e $(BUILDENV) TOP=.. TESTS='$(TESTS)' OPENSSL_DEBUG_MEMORY=on OPENSSL_CONF=../apps/openssl.cnf tests ); | |
456 | OPENSSL_CONF=apps/openssl.cnf util/opensslwrap.sh version -a | |
457 | ||
458 | report: | |
459 | @$(PERL) util/selftest.pl | |
460 | ||
461 | depend: | |
462 | @set -e; target=depend; $(RECURSIVE_BUILD_CMD) | |
463 | ||
464 | lint: | |
465 | @set -e; target=lint; $(RECURSIVE_BUILD_CMD) | |
466 | ||
467 | tags: | |
468 | rm -f TAGS | |
469 | find . -name '[^.]*.[ch]' | xargs etags -a | |
470 | ||
471 | errors: | |
472 | $(PERL) util/ck_errf.pl -strict */*.c */*/*.c | |
473 | $(PERL) util/mkerr.pl -recurse -write | |
474 | (cd engines; $(MAKE) PERL=$(PERL) errors) | |
475 | ||
476 | stacks: | |
477 | $(PERL) util/mkstack.pl -write | |
478 | ||
479 | util/libeay.num:: | |
480 | $(PERL) util/mkdef.pl crypto update | |
481 | ||
482 | util/ssleay.num:: | |
483 | $(PERL) util/mkdef.pl ssl update | |
484 | ||
485 | crypto/objects/obj_dat.h: crypto/objects/obj_dat.pl crypto/objects/obj_mac.h | |
486 | $(PERL) crypto/objects/obj_dat.pl crypto/objects/obj_mac.h crypto/objects/obj_dat.h | |
487 | crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num | |
488 | $(PERL) crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num crypto/objects/obj_mac.h | |
489 | crypto/objects/obj_xref.h: crypto/objects/objxref.pl crypto/objects/obj_xref.txt crypto/objects/obj_mac.num | |
490 | $(PERL) crypto/objects/objxref.pl crypto/objects/obj_mac.num crypto/objects/obj_xref.txt >crypto/objects/obj_xref.h | |
491 | ||
492 | apps/openssl-vms.cnf: apps/openssl.cnf | |
493 | $(PERL) VMS/VMSify-conf.pl < apps/openssl.cnf > apps/openssl-vms.cnf | |
494 | ||
495 | crypto/bn/bn_prime.h: crypto/bn/bn_prime.pl | |
496 | $(PERL) crypto/bn/bn_prime.pl >crypto/bn/bn_prime.h | |
497 | ||
498 | ||
499 | TABLE: Configure | |
500 | (echo 'Output of `Configure TABLE'"':"; \ | |
501 | $(PERL) Configure TABLE) > TABLE | |
502 | ||
503 | update: errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h crypto/objects/obj_xref.h apps/openssl-vms.cnf crypto/bn/bn_prime.h TABLE depend | |
504 | ||
505 | # Build distribution tar-file. As the list of files returned by "find" is | |
506 | # pretty long, on several platforms a "too many arguments" error or similar | |
507 | # would occur. Therefore the list of files is temporarily stored into a file | |
508 | # and read directly, requiring GNU-Tar. Call "make TAR=gtar dist" if the normal | |
509 | # tar does not support the --files-from option. | |
510 | tar: | |
511 | find . -type d -print | xargs chmod 755 | |
512 | find . -type f -print | xargs chmod a+r | |
513 | find . -type f -perm -0100 -print | xargs chmod a+x | |
514 | find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE | sort > ../$(TARFILE).list; \ | |
515 | $(TAR) $(TARFLAGS) --files-from ../$(TARFILE).list -cvf - | \ | |
516 | tardy --user_number=0 --user_name=openssl \ | |
517 | --group_number=0 --group_name=openssl \ | |
518 | --prefix=openssl-$(VERSION) - |\ | |
519 | gzip --best >../$(TARFILE).gz; \ | |
520 | rm -f ../$(TARFILE).list; \ | |
521 | ls -l ../$(TARFILE).gz | |
522 | ||
523 | tar-snap: | |
524 | @$(TAR) $(TARFLAGS) -cvf - \ | |
525 | `find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE \! -name '*.o' \! -name '*.a' \! -name '*.so' \! -name '*.so.*' \! -name 'openssl' \! -name '*test' \! -name '.#*' \! -name '*~' | sort` |\ | |
526 | tardy --user_number=0 --user_name=openssl \ | |
527 | --group_number=0 --group_name=openssl \ | |
528 | --prefix=openssl-$(VERSION) - > ../$(TARFILE);\ | |
529 | ls -l ../$(TARFILE) | |
530 | ||
531 | dist: | |
532 | $(PERL) Configure dist | |
533 | @$(MAKE) dist_pem_h | |
534 | @$(MAKE) SDIRS='$(SDIRS)' clean | |
535 | @$(MAKE) TAR='$(TAR)' TARFLAGS='$(TARFLAGS)' tar | |
536 | ||
537 | dist_pem_h: | |
538 | (cd crypto/pem; $(MAKE) -e $(BUILDENV) pem.h; $(MAKE) clean) | |
539 | ||
540 | install: all install_docs install_sw | |
541 | ||
542 | install_sw: | |
543 | @$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \ | |
544 | $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR) \ | |
545 | $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines \ | |
546 | $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig \ | |
547 | $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \ | |
548 | $(INSTALL_PREFIX)$(OPENSSLDIR)/misc \ | |
549 | $(INSTALL_PREFIX)$(OPENSSLDIR)/certs \ | |
550 | $(INSTALL_PREFIX)$(OPENSSLDIR)/private | |
551 | @set -e; headerlist="$(EXHEADER)"; for i in $$headerlist;\ | |
552 | do \ | |
553 | (cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \ | |
554 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \ | |
555 | done; | |
556 | @set -e; target=install; $(RECURSIVE_BUILD_CMD) | |
557 | @set -e; liblist="$(LIBS)"; for i in $$liblist ;\ | |
558 | do \ | |
559 | if [ -f "$$i" ]; then \ | |
560 | ( echo installing $$i; \ | |
561 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
562 | $(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
563 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
564 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i ); \ | |
565 | fi; \ | |
566 | done; | |
567 | @set -e; if [ -n "$(SHARED_LIBS)" ]; then \ | |
568 | tmp="$(SHARED_LIBS)"; \ | |
569 | for i in $${tmp:-x}; \ | |
570 | do \ | |
571 | if [ -f "$$i" -o -f "$$i.a" ]; then \ | |
572 | ( echo installing $$i; \ | |
573 | if [ "$(PLATFORM)" != "Cygwin" ]; then \ | |
574 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
575 | chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
576 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i; \ | |
577 | else \ | |
578 | c=`echo $$i | sed 's/^lib\(.*\)\.dll\.a/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \ | |
579 | cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \ | |
580 | chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \ | |
581 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \ | |
582 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
583 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new; \ | |
584 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$i; \ | |
585 | fi ); \ | |
586 | if expr $(PLATFORM) : 'mingw' > /dev/null; then \ | |
587 | ( case $$i in \ | |
588 | *crypto*) i=libeay32.dll;; \ | |
589 | *ssl*) i=ssleay32.dll;; \ | |
590 | esac; \ | |
591 | echo installing $$i; \ | |
592 | cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \ | |
593 | chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \ | |
594 | mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i ); \ | |
595 | fi; \ | |
596 | fi; \ | |
597 | done; \ | |
598 | ( here="`pwd`"; \ | |
599 | cd $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR); \ | |
600 | $(MAKE) -f $$here/Makefile HERE="$$here" link-shared ); \ | |
601 | if [ "$(INSTALLTOP)" != "/usr" ]; then \ | |
602 | echo 'OpenSSL shared libraries have been installed in:'; \ | |
603 | echo ' $(INSTALLTOP)'; \ | |
604 | echo ''; \ | |
605 | sed -e '1,/^$$/d' doc/openssl-shared.txt; \ | |
606 | fi; \ | |
607 | fi | |
608 | cp libcrypto.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig | |
609 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc | |
610 | cp libssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig | |
611 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc | |
612 | cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig | |
613 | chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc | |
614 | ||
615 | install_html_docs: | |
616 | here="`pwd`"; \ | |
617 | for subdir in apps crypto ssl; do \ | |
618 | mkdir -p $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir; \ | |
619 | for i in doc/$$subdir/*.pod; do \ | |
620 | fn=`basename $$i .pod`; \ | |
621 | echo "installing html/$$fn.$(HTMLSUFFIX)"; \ | |
622 | cat $$i \ | |
623 | | sed -r 's/L<([^)]*)(\([0-9]\))?\|([^)]*)(\([0-9]\))?>/L<\1|\3>/g' \ | |
624 | | pod2html --podroot=doc --htmlroot=.. --podpath=apps:crypto:ssl \ | |
625 | | sed -r 's/<!DOCTYPE.*//g' \ | |
626 | > $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir/$$fn.$(HTMLSUFFIX); \ | |
627 | $(PERL) util/extract-names.pl < $$i | \ | |
628 | grep -v $$filecase "^$$fn\$$" | \ | |
629 | (cd $(INSTALL_PREFIX)$(HTMLDIR)/$$subdir; \ | |
630 | while read n; do \ | |
631 | PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$(HTMLSUFFIX) "$$n".$(HTMLSUFFIX); \ | |
632 | done); \ | |
633 | done; \ | |
634 | done | |
635 | ||
636 | install_docs: | |
637 | @$(PERL) $(TOP)/util/mkdir-p.pl \ | |
638 | $(INSTALL_PREFIX)$(MANDIR)/man1 \ | |
639 | $(INSTALL_PREFIX)$(MANDIR)/man3 \ | |
640 | $(INSTALL_PREFIX)$(MANDIR)/man5 \ | |
641 | $(INSTALL_PREFIX)$(MANDIR)/man7 | |
642 | @pod2man="`cd ./util; ./pod2mantest $(PERL)`"; \ | |
643 | here="`pwd`"; \ | |
644 | filecase=; \ | |
645 | if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" -o "$(PLATFORM)" = "mingw" ]; then \ | |
646 | filecase=-i; \ | |
647 | fi; \ | |
648 | set -e; for i in doc/apps/*.pod; do \ | |
649 | fn=`basename $$i .pod`; \ | |
650 | sec=`$(PERL) util/extract-section.pl 1 < $$i`; \ | |
651 | echo "installing man$$sec/$$fn.$${sec}$(MANSUFFIX)"; \ | |
652 | (cd `$(PERL) util/dirname.pl $$i`; \ | |
653 | sh -c "$$pod2man \ | |
654 | --section=$$sec --center=OpenSSL \ | |
655 | --release=$(VERSION) `basename $$i`") \ | |
656 | > $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \ | |
657 | $(PERL) util/extract-names.pl < $$i | \ | |
658 | (grep -v $$filecase "^$$fn\$$"; true) | \ | |
659 | (grep -v "[ ]"; true) | \ | |
660 | (cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \ | |
661 | while read n; do \ | |
662 | PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \ | |
663 | done); \ | |
664 | done; \ | |
665 | set -e; for i in doc/crypto/*.pod doc/ssl/*.pod; do \ | |
666 | fn=`basename $$i .pod`; \ | |
667 | sec=`$(PERL) util/extract-section.pl 3 < $$i`; \ | |
668 | echo "installing man$$sec/$$fn.$${sec}$(MANSUFFIX)"; \ | |
669 | (cd `$(PERL) util/dirname.pl $$i`; \ | |
670 | sh -c "$$pod2man \ | |
671 | --section=$$sec --center=OpenSSL \ | |
672 | --release=$(VERSION) `basename $$i`") \ | |
673 | > $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \ | |
674 | $(PERL) util/extract-names.pl < $$i | \ | |
675 | (grep -v $$filecase "^$$fn\$$"; true) | \ | |
676 | (grep -v "[ ]"; true) | \ | |
677 | (cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \ | |
678 | while read n; do \ | |
679 | PLATFORM=$(PLATFORM) $$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \ | |
680 | done); \ | |
681 | done | |
682 | ||
683 | # DO NOT DELETE THIS LINE -- make depend depends on it. |