Makefile.org revision 111147
1## 2## Makefile for OpenSSL 3## 4 5VERSION= 6MAJOR= 7MINOR= 8SHLIB_VERSION_NUMBER= 9SHLIB_VERSION_HISTORY= 10SHLIB_MAJOR= 11SHLIB_MINOR= 12SHLIB_EXT= 13PLATFORM=dist 14OPTIONS= 15CONFIGURE_ARGS= 16SHLIB_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. 21HERE=. 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. 26INSTALL_PREFIX= 27INSTALLTOP=/usr/local/ssl 28 29# Do not edit this manually. Use Configure --openssldir=DIR do change this! 30OPENSSLDIR=/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 60CC= gcc 61#CFLAG= -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -m486 -Wall -Wuninitialized -DSHA1_ASM -DMD5_ASM -DRMD160_ASM 62CFLAG= -DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O3 -m486 -Wall -DSHA1_ASM -DMD5_ASM -DRMD160_ASM 63DEPFLAG= 64PEX_LIBS= 65EX_LIBS= 66EXE_EXT= 67ARFLAGS= 68AR=ar $(ARFLAGS) r 69RANLIB= ranlib 70PERL= perl 71TAR= tar 72TARFLAGS= --no-recursion 73MAKEDEPPROG=makedepend 74 75# We let the C compiler driver to take care of .s files. This is done in 76# order to be excused from maintaining a separate set of architecture 77# dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC 78# gcc, then the driver will automatically translate it to -xarch=v8plus 79# and pass it down to assembler. 80AS=$(CC) -c 81ASFLAGS=$(CFLAG) 82 83# Set BN_ASM to bn_asm.o if you want to use the C version 84BN_ASM= bn_asm.o 85#BN_ASM= bn_asm.o 86#BN_ASM= asm/bn86-elf.o # elf, linux-elf 87#BN_ASM= asm/bn86-sol.o # solaris 88#BN_ASM= asm/bn86-out.o # a.out, FreeBSD 89#BN_ASM= asm/bn86bsdi.o # bsdi 90#BN_ASM= asm/alpha.o # DEC Alpha 91#BN_ASM= asm/pa-risc2.o # HP-UX PA-RISC 92#BN_ASM= asm/r3000.o # SGI MIPS cpu 93#BN_ASM= asm/sparc.o # Sun solaris/SunOS 94#BN_ASM= asm/bn-win32.o # Windows 95/NT 95#BN_ASM= asm/x86w16.o # 16 bit code for Windows 3.1/DOS 96#BN_ASM= asm/x86w32.o # 32 bit code for Windows 3.1 97 98# For x86 assembler: Set PROCESSOR to 386 if you want to support 99# the 80386. 100PROCESSOR= 101 102# Set DES_ENC to des_enc.o if you want to use the C version 103#There are 4 x86 assember options. 104DES_ENC= asm/dx86-out.o asm/yx86-out.o 105#DES_ENC= des_enc.o fcrypt_b.o # C 106#DES_ENC= asm/dx86-elf.o asm/yx86-elf.o # elf 107#DES_ENC= asm/dx86-sol.o asm/yx86-sol.o # solaris 108#DES_ENC= asm/dx86-out.o asm/yx86-out.o # a.out, FreeBSD 109#DES_ENC= asm/dx86bsdi.o asm/yx86bsdi.o # bsdi 110 111# Set BF_ENC to bf_enc.o if you want to use the C version 112#There are 4 x86 assember options. 113BF_ENC= asm/bx86-out.o 114#BF_ENC= bf_enc.o 115#BF_ENC= asm/bx86-elf.o # elf 116#BF_ENC= asm/bx86-sol.o # solaris 117#BF_ENC= asm/bx86-out.o # a.out, FreeBSD 118#BF_ENC= asm/bx86bsdi.o # bsdi 119 120# Set CAST_ENC to c_enc.o if you want to use the C version 121#There are 4 x86 assember options. 122CAST_ENC= asm/cx86-out.o 123#CAST_ENC= c_enc.o 124#CAST_ENC= asm/cx86-elf.o # elf 125#CAST_ENC= asm/cx86-sol.o # solaris 126#CAST_ENC= asm/cx86-out.o # a.out, FreeBSD 127#CAST_ENC= asm/cx86bsdi.o # bsdi 128 129# Set RC4_ENC to rc4_enc.o if you want to use the C version 130#There are 4 x86 assember options. 131RC4_ENC= asm/rx86-out.o 132#RC4_ENC= rc4_enc.o 133#RC4_ENC= asm/rx86-elf.o # elf 134#RC4_ENC= asm/rx86-sol.o # solaris 135#RC4_ENC= asm/rx86-out.o # a.out, FreeBSD 136#RC4_ENC= asm/rx86bsdi.o # bsdi 137 138# Set RC5_ENC to rc5_enc.o if you want to use the C version 139#There are 4 x86 assember options. 140RC5_ENC= asm/r586-out.o 141#RC5_ENC= rc5_enc.o 142#RC5_ENC= asm/r586-elf.o # elf 143#RC5_ENC= asm/r586-sol.o # solaris 144#RC5_ENC= asm/r586-out.o # a.out, FreeBSD 145#RC5_ENC= asm/r586bsdi.o # bsdi 146 147# Also need MD5_ASM defined 148MD5_ASM_OBJ= asm/mx86-out.o 149#MD5_ASM_OBJ= asm/mx86-elf.o # elf 150#MD5_ASM_OBJ= asm/mx86-sol.o # solaris 151#MD5_ASM_OBJ= asm/mx86-out.o # a.out, FreeBSD 152#MD5_ASM_OBJ= asm/mx86bsdi.o # bsdi 153 154# Also need SHA1_ASM defined 155SHA1_ASM_OBJ= asm/sx86-out.o 156#SHA1_ASM_OBJ= asm/sx86-elf.o # elf 157#SHA1_ASM_OBJ= asm/sx86-sol.o # solaris 158#SHA1_ASM_OBJ= asm/sx86-out.o # a.out, FreeBSD 159#SHA1_ASM_OBJ= asm/sx86bsdi.o # bsdi 160 161# Also need RMD160_ASM defined 162RMD160_ASM_OBJ= asm/rm86-out.o 163#RMD160_ASM_OBJ= asm/rm86-elf.o # elf 164#RMD160_ASM_OBJ= asm/rm86-sol.o # solaris 165#RMD160_ASM_OBJ= asm/rm86-out.o # a.out, FreeBSD 166#RMD160_ASM_OBJ= asm/rm86bsdi.o # bsdi 167 168# KRB5 stuff 169KRB5_INCLUDES= 170LIBKRB5= 171 172# When we're prepared to use shared libraries in the programs we link here 173# we might set SHLIB_MARK to '$(SHARED_LIBS)'. 174SHLIB_MARK= 175 176DIRS= crypto ssl $(SHLIB_MARK) apps test tools 177SHLIBDIRS= crypto ssl 178 179# dirs in crypto to build 180SDIRS= \ 181 md2 md4 md5 sha mdc2 hmac ripemd \ 182 des rc2 rc4 rc5 idea bf cast \ 183 bn ec rsa dsa dh dso engine aes \ 184 buffer bio stack lhash rand err objects \ 185 evp asn1 pem x509 x509v3 conf txt_db pkcs7 pkcs12 comp ocsp ui krb5 186 187# tests to perform. "alltests" is a special word indicating that all tests 188# should be performed. 189TESTS = alltests 190 191MAKEFILE= Makefile.ssl 192MAKE= make -f Makefile.ssl 193 194MANDIR=$(OPENSSLDIR)/man 195MAN1=1 196MAN3=3 197SHELL=/bin/sh 198 199TOP= . 200ONEDIRS=out tmp 201EDIRS= times doc bugs util include certs ms shlib mt demos perl sf dep VMS 202WDIRS= windows 203LIBS= libcrypto.a libssl.a 204SHARED_CRYPTO=libcrypto$(SHLIB_EXT) 205SHARED_SSL=libssl$(SHLIB_EXT) 206SHARED_LIBS= 207SHARED_LIBS_LINK_EXTS= 208SHARED_LDFLAGS= 209 210GENERAL= Makefile 211BASENAME= openssl 212NAME= $(BASENAME)-$(VERSION) 213TARFILE= $(NAME).tar 214WTARFILE= $(NAME)-win.tar 215EXHEADER= e_os2.h 216HEADER= e_os.h 217 218# When we're prepared to use shared libraries in the programs we link here 219# we might remove 'clean-shared' from the targets to perform at this stage 220 221all: Makefile.ssl sub_all openssl.pc 222 223sub_all: 224 @for i in $(DIRS); \ 225 do \ 226 if [ -d "$$i" ]; then \ 227 (cd $$i && echo "making all in $$i..." && \ 228 $(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAGS='${ASFLAGS}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' all ) || exit 1; \ 229 else \ 230 $(MAKE) $$i; \ 231 fi; \ 232 done; 233 234libcrypto$(SHLIB_EXT): libcrypto.a 235 @if [ "$(SHLIB_TARGET)" != "" ]; then \ 236 $(MAKE) SHLIBDIRS=crypto build-shared; \ 237 else \ 238 echo "There's no support for shared libraries on this platform" >&2; \ 239 fi 240 241libssl$(SHLIB_EXT): libcrypto$(SHLIB_EXT) libssl.a 242 @if [ "$(SHLIB_TARGET)" != "" ]; then \ 243 $(MAKE) SHLIBDIRS=ssl SHLIBDEPS='-lcrypto' build-shared; \ 244 else \ 245 echo "There's no support for shared libraries on this platform" >&2; \ 246 fi 247 248clean-shared: 249 @for i in $(SHLIBDIRS); do \ 250 if [ -n "$(SHARED_LIBS_LINK_EXTS)" ]; then \ 251 tmp="$(SHARED_LIBS_LINK_EXTS)"; \ 252 for j in $${tmp:-x}; do \ 253 ( set -x; rm -f lib$$i$$j ); \ 254 done; \ 255 fi; \ 256 ( set -x; rm -f lib$$i$(SHLIB_EXT) ); \ 257 if [ "$(PLATFORM)" = "Cygwin" ]; then \ 258 ( set -x; rm -f cyg$$i-$(SHLIB_VERSION_NUMBER)$(SHLIB_EXT) lib$$i$(SHLIB_EXT).a ); \ 259 fi; \ 260 done 261 262link-shared: 263 @if [ -n "$(SHARED_LIBS_LINK_EXTS)" ]; then \ 264 tmp="$(SHARED_LIBS_LINK_EXTS)"; \ 265 for i in $(SHLIBDIRS); do \ 266 prev=lib$$i$(SHLIB_EXT); \ 267 for j in $${tmp:-x}; do \ 268 ( set -x; \ 269 rm -f lib$$i$$j; ln -s $$prev lib$$i$$j ); \ 270 prev=lib$$i$$j; \ 271 done; \ 272 done; \ 273 fi 274 275build-shared: clean-shared do_$(SHLIB_TARGET) link-shared 276 277do_bsd-gcc-shared: do_gnu-shared 278do_linux-shared: do_gnu-shared 279do_gnu-shared: 280 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 281 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 282 libs="$(LIBKRB5) $$libs"; \ 283 fi; \ 284 ( set -x; ${CC} ${SHARED_LDFLAGS} \ 285 -shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 286 -Wl,-soname=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 287 -Wl,-Bsymbolic \ 288 -Wl,--whole-archive lib$$i.a \ 289 -Wl,--no-whole-archive $$libs ${EX_LIBS} -lc ) || exit 1; \ 290 libs="-l$$i $$libs"; \ 291 done 292 293DETECT_GNU_LD=(${CC} -Wl,-V /dev/null 2>&1 | grep '^GNU ld' )>/dev/null 294 295# For Darwin AKA Mac OS/X (dyld) 296do_darwin-shared: 297 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 298 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 299 libs="$(LIBKRB5) $$libs"; \ 300 fi; \ 301 ( set -x; ${CC} --verbose -dynamiclib -o lib$$i${SHLIB_EXT} \ 302 lib$$i.a $$libs -all_load -current_version ${SHLIB_MAJOR}.${SHLIB_MINOR} \ 303 -compatibility_version ${SHLIB_MAJOR}.`echo ${SHLIB_MINOR} | cut -d. -f1` \ 304 -install_name ${INSTALLTOP}/lib/lib$$i${SHLIB_EXT} ) || exit 1; \ 305 libs="-l`basename $$i${SHLIB_EXT} .dylib` $$libs"; \ 306 echo "" ; \ 307 done 308 309do_cygwin-shared: 310 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 311 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 312 libs="$(LIBKRB5) $$libs"; \ 313 fi; \ 314 ( set -x; ${CC} -shared -o cyg$$i-$(SHLIB_VERSION_NUMBER).dll \ 315 -Wl,-Bsymbolic \ 316 -Wl,--whole-archive lib$$i.a \ 317 -Wl,--out-implib,lib$$i.dll.a \ 318 -Wl,--no-whole-archive $$libs ) || exit 1; \ 319 libs="-l$$i $$libs"; \ 320 done 321 322# This assumes that GNU utilities are *not* used 323do_alpha-osf1-shared: 324 if ${DETECT_GNU_LD}; then \ 325 $(MAKE) do_gnu-shared; \ 326 else \ 327 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 328 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 329 libs="$(LIBKRB5) $$libs"; \ 330 fi; \ 331 ( set -x; ${CC} ${SHARED_LDFLAGS} \ 332 -shared -o lib$$i.so \ 333 -set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \ 334 -all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \ 335 libs="-l$$i $$libs"; \ 336 done; \ 337 fi 338 339# This assumes that GNU utilities are *not* used 340# The difference between alpha-osf1-shared and tru64-shared is the `-msym' 341# option passed to the linker. 342do_tru64-shared: 343 if ${DETECT_GNU_LD}; then \ 344 $(MAKE) do_gnu-shared; \ 345 else \ 346 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 347 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 348 libs="$(LIBKRB5) $$libs"; \ 349 fi; \ 350 ( set -x; ${CC} ${SHARED_LDFLAGS} \ 351 -shared -msym -o lib$$i.so \ 352 -set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \ 353 -all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \ 354 libs="-l$$i $$libs"; \ 355 done; \ 356 fi 357 358# This assumes that GNU utilities are *not* used 359# The difference between tru64-shared and tru64-shared-rpath is the 360# -rpath ${INSTALLTOP}/lib passed to the linker. 361do_tru64-shared-rpath: 362 if ${DETECT_GNU_LD}; then \ 363 $(MAKE) do_gnu-shared; \ 364 else \ 365 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 366 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 367 libs="$(LIBKRB5) $$libs"; \ 368 fi; \ 369 ( set -x; ${CC} ${SHARED_LDFLAGS} \ 370 -shared -msym -o lib$$i.so \ 371 -rpath ${INSTALLTOP}/lib \ 372 -set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \ 373 -all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \ 374 libs="-l$$i $$libs"; \ 375 done; \ 376 fi 377 378 379# This assumes that GNU utilities are *not* used 380do_solaris-shared: 381 if ${DETECT_GNU_LD}; then \ 382 $(MAKE) do_gnu-shared; \ 383 else \ 384 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 385 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 386 libs="$(LIBKRB5) $$libs"; \ 387 fi; \ 388 ( PATH=/usr/ccs/bin:$$PATH ; export PATH; \ 389 MINUSZ='-z '; \ 390 (${CC} -v 2>&1 | grep gcc) > /dev/null && MINUSZ='-Wl,-z,'; \ 391 set -x; ${CC} ${SHARED_LDFLAGS} -G -dy -z text \ 392 -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 393 -h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 394 $${MINUSZ}allextract lib$$i.a $${MINUSZ}defaultextract \ 395 $$libs ${EX_LIBS} -lc ) || exit 1; \ 396 libs="-l$$i $$libs"; \ 397 done; \ 398 fi 399 400# OpenServer 5 native compilers used 401do_svr3-shared: 402 if ${DETECT_GNU_LD}; then \ 403 $(MAKE) do_gnu-shared; \ 404 else \ 405 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 406 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 407 libs="$(LIBKRB5) $$libs"; \ 408 fi; \ 409 ( PATH=/usr/ccs/bin:$$PATH ; export PATH; \ 410 find . -name "*.o" -print > allobjs ; \ 411 OBJS= ; export OBJS ; \ 412 for obj in `ar t lib$$i.a` ; do \ 413 OBJS="$${OBJS} `grep $$obj allobjs`" ; \ 414 done ; \ 415 set -x; ${CC} -G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 416 -h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 417 $${OBJS} $$libs ${EX_LIBS} ) || exit 1; \ 418 libs="-l$$i $$libs"; \ 419 done; \ 420 fi 421 422# UnixWare 7 and OpenUNIX 8 native compilers used 423do_svr5-shared: 424 if ${DETECT_GNU_LD}; then \ 425 $(MAKE) do_gnu-shared; \ 426 else \ 427 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 428 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 429 libs="$(LIBKRB5) $$libs"; \ 430 fi; \ 431 ( PATH=/usr/ccs/bin:$$PATH ; export PATH; \ 432 find . -name "*.o" -print > allobjs ; \ 433 OBJS= ; export OBJS ; \ 434 for obj in `ar t lib$$i.a` ; do \ 435 OBJS="$${OBJS} `grep $$obj allobjs`" ; \ 436 done ; \ 437 set -x; ${CC} ${SHARED_LDFLAGS} \ 438 -G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 439 -h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 440 $${OBJS} $$libs ${EX_LIBS} ) || exit 1; \ 441 libs="-l$$i $$libs"; \ 442 done; \ 443 fi 444 445# This assumes that GNU utilities are *not* used 446do_irix-shared: 447 if ${DETECT_GNU_LD}; then \ 448 $(MAKE) do_gnu-shared; \ 449 else \ 450 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 451 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 452 libs="$(LIBKRB5) $$libs"; \ 453 fi; \ 454 ( set -x; ${CC} ${SHARED_LDFLAGS} \ 455 -shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 456 -Wl,-soname,lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 457 -all lib$$i.a $$libs ${EX_LIBS} -lc) || exit 1; \ 458 libs="-l$$i $$libs"; \ 459 done; \ 460 fi 461 462# This assumes that GNU utilities are *not* used 463# HP-UX includes the full pathname of libs we depend on, so we would get 464# ./libcrypto (with ./ as path information) compiled into libssl, hence 465# we omit the SHLIBDEPS. Applications must be linked with -lssl -lcrypto 466# anyway. 467# The object modules are loaded from lib$i.a using the undocumented -Fl 468# option. 469# 470# WARNING: Until DSO is fixed to support a search path, we support SHLIB_PATH 471# by temporarily specifying "+s"! 472# 473do_hpux-shared: 474 for i in ${SHLIBDIRS}; do \ 475 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 476 libs="$(LIBKRB5) $$libs"; \ 477 fi; \ 478 ( set -x; /usr/ccs/bin/ld ${SHARED_LDFLAGS} \ 479 +vnocompatwarnings \ 480 -b -z +s \ 481 -o lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 482 +h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 483 -Fl lib$$i.a -ldld -lc ) || exit 1; \ 484 chmod a=rx lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR}; \ 485 done 486 487# This assumes that GNU utilities are *not* used 488# HP-UX includes the full pathname of libs we depend on, so we would get 489# ./libcrypto (with ./ as path information) compiled into libssl, hence 490# we omit the SHLIBDEPS. Applications must be linked with -lssl -lcrypto 491# anyway. 492# 493# HP-UX in 64bit mode has "+s" enabled by default; it will search for 494# shared libraries along LD_LIBRARY_PATH _and_ SHLIB_PATH. 495# 496do_hpux64-shared: 497 for i in ${SHLIBDIRS}; do \ 498 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 499 libs="$(LIBKRB5) $$libs"; \ 500 fi; \ 501 ( set -x; /usr/ccs/bin/ld ${SHARED_LDFLAGS} \ 502 -b -z \ 503 -o lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 504 +h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \ 505 +forceload lib$$i.a -ldl -lc ) || exit 1; \ 506 chmod a=rx lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR}; \ 507 done 508 509# The following method is said to work on all platforms. Tests will 510# determine if that's how it's gong to be used. 511# This assumes that for all but GNU systems, GNU utilities are *not* used. 512# ALLSYMSFLAGS would be: 513# GNU systems: --whole-archive 514# Tru64 Unix: -all 515# Solaris: -z allextract 516# Irix: -all 517# HP/UX-32bit: -Fl 518# HP/UX-64bit: +forceload 519# AIX: -bnogc 520# SHAREDFLAGS would be: 521# GNU systems: -shared -Wl,-soname=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} 522# Tru64 Unix: -shared \ 523# -set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" 524# Solaris: -G -h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} 525# Irix: -shared -Wl,-soname,lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} 526# HP/UX-32bit: +vnocompatwarnings -b -z +s \ 527# +h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} 528# HP/UX-64bit: -b -z +h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} 529# AIX: -G -bE:lib$$i.exp -bM:SRE 530# SHAREDCMD would be: 531# GNU systems: $(CC) 532# Tru64 Unix: $(CC) 533# Solaris: $(CC) 534# Irix: $(CC) 535# HP/UX-32bit: /usr/ccs/bin/ld 536# HP/UX-64bit: /usr/ccs/bin/ld 537# AIX: $(CC) 538ALLSYMSFLAG=-bnogc 539SHAREDFLAGS=${SHARED_LDFLAGS} -G -bE:lib$$i.exp -bM:SRE 540SHAREDCMD=$(CC) 541do_aix-shared: 542 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 543 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 544 libs="$(LIBKRB5) $$libs"; \ 545 fi; \ 546 ( set -x; \ 547 ld -r -o lib$$i.o $(ALLSYMSFLAG) lib$$i.a && \ 548 ( nm -Pg lib$$i.o | grep ' [BD] ' | cut -f1 -d' ' > lib$$i.exp; \ 549 $(SHAREDCMD) $(SHAREDFLAGS) \ 550 -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} lib$$i.o \ 551 $$libs ${EX_LIBS} ) ) \ 552 || exit 1; \ 553 libs="-l$$i $$libs"; \ 554 done 555 556do_reliantunix-shared: 557 libs='-L. ${SHLIBDEPS}'; for i in ${SHLIBDIRS}; do \ 558 if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \ 559 libs="$(LIBKRB5) $$libs"; \ 560 fi; \ 561 tmpdir=/tmp/openssl.$$$$ ; rm -rf $$tmpdir ; \ 562 ( set -x; \ 563 ( Opwd=`pwd` ; mkdir $$tmpdir || exit 1; \ 564 cd $$tmpdir || exit 1 ; ar x $$Opwd/lib$$i.a ; \ 565 ${CC} -G -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} *.o \ 566 ) || exit 1; \ 567 cp $$tmpdir/lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} . ; \ 568 ) || exit 1; \ 569 rm -rf $$tmpdir ; \ 570 libs="-l$$i $$libs"; \ 571 done 572 573openssl.pc: Makefile.ssl 574 @ ( echo 'prefix=$(INSTALLTOP)'; \ 575 echo 'exec_prefix=$${prefix}'; \ 576 echo 'libdir=$${exec_prefix}/lib'; \ 577 echo 'includedir=$${prefix}/include'; \ 578 echo ''; \ 579 echo 'Name: OpenSSL'; \ 580 echo 'Description: Secure Sockets Layer and cryptography libraries and tools'; \ 581 echo 'Version: '$(VERSION); \ 582 echo 'Requires: '; \ 583 echo 'Libs: -L$${libdir} -lssl -lcrypto $(LIBKRB5) $(EX_LIBS)'; \ 584 echo 'Cflags: -I$${includedir} $(KRB5_INCLUDES)' ) > openssl.pc 585 586Makefile.ssl: Makefile.org 587 @echo "Makefile.ssl is older than Makefile.org." 588 @echo "Reconfigure the source tree (via './config' or 'perl Configure'), please." 589 @false 590 591libclean: 592 rm -f *.a */lib */*/lib 593 594clean: 595 rm -f shlib/*.o *.o core a.out fluff *.map rehash.time testlog make.log cctest cctest.c 596 @for i in $(DIRS) ;\ 597 do \ 598 if [ -d "$$i" ]; then \ 599 (cd $$i && echo "making clean in $$i..." && \ 600 $(MAKE) SDIRS='${SDIRS}' clean ) || exit 1; \ 601 rm -f $(LIBS); \ 602 fi; \ 603 done; 604 rm -f openssl.pc 605 rm -f *.a *.o speed.* *.map *.so .pure core 606 rm -f $(TARFILE) 607 @for i in $(ONEDIRS) ;\ 608 do \ 609 rm -fr $$i/*; \ 610 done 611 612makefile.one: files 613 $(PERL) util/mk1mf.pl >makefile.one; \ 614 sh util/do_ms.sh 615 616files: 617 $(PERL) $(TOP)/util/files.pl Makefile.ssl > $(TOP)/MINFO 618 @for i in $(DIRS) ;\ 619 do \ 620 if [ -d "$$i" ]; then \ 621 (cd $$i && echo "making 'files' in $$i..." && \ 622 $(MAKE) SDIRS='${SDIRS}' PERL='${PERL}' files ) || exit 1; \ 623 fi; \ 624 done; 625 626links: 627 @$(TOP)/util/point.sh Makefile.ssl Makefile 628 @$(PERL) $(TOP)/util/mkdir-p.pl include/openssl 629 @$(PERL) $(TOP)/util/mklink.pl include/openssl $(EXHEADER) 630 @for i in $(DIRS); do \ 631 if [ -d "$$i" ]; then \ 632 (cd $$i && echo "making links in $$i..." && \ 633 $(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PERL='${PERL}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' links ) || exit 1; \ 634 fi; \ 635 done; 636 637gentests: 638 @(cd test && echo "generating dummy tests (if needed)..." && \ 639 $(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TESTS='${TESTS}' OPENSSL_DEBUG_MEMORY=on generate ); 640 641dclean: 642 rm -f *.bak 643 @for i in $(DIRS) ;\ 644 do \ 645 if [ -d "$$i" ]; then \ 646 (cd $$i && echo "making dclean in $$i..." && \ 647 $(MAKE) SDIRS='${SDIRS}' PERL='${PERL}' dclean ) || exit 1; \ 648 fi; \ 649 done; 650 651rehash: rehash.time 652rehash.time: certs 653 @(OPENSSL="`pwd`/apps/openssl"; OPENSSL_DEBUG_MEMORY=on; \ 654 export OPENSSL OPENSSL_DEBUG_MEMORY; \ 655 LD_LIBRARY_PATH="`pwd`"; DYLD_LIBRARY_PATH="`pwd`"; SHLIB_PATH="`pwd`"; LIBPATH="`pwd`"; \ 656 if [ "$(PLATFORM)" = "Cygwin" ]; then PATH="`pwd`:$$PATH"; fi; \ 657 export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; \ 658 $(PERL) tools/c_rehash certs) 659 touch rehash.time 660 661test: tests 662 663tests: rehash 664 @(cd test && echo "testing..." && \ 665 $(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TESTS='${TESTS}' OPENSSL_DEBUG_MEMORY=on tests ); 666 @LD_LIBRARY_PATH="`pwd`"; DYLD_LIBRARY_PATH="`pwd`"; SHLIB_PATH="`pwd`"; LIBPATH="`pwd`"; \ 667 if [ "$(PLATFORM)" = "Cygwin" ]; then PATH="`pwd`:$$PATH"; fi; \ 668 export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; \ 669 apps/openssl version -a 670 671report: 672 @$(PERL) util/selftest.pl 673 674depend: 675 @for i in $(DIRS) ;\ 676 do \ 677 if [ -d "$$i" ]; then \ 678 (cd $$i && echo "making dependencies $$i..." && \ 679 $(MAKE) SDIRS='${SDIRS}' CFLAG='${CFLAG}' DEPFLAG='${DEPFLAG}' MAKEDEPPROG='${MAKEDEPPROG}' KRB5_INCLUDES='${KRB5_INCLUDES}' PERL='${PERL}' depend ) || exit 1; \ 680 fi; \ 681 done; 682 683lint: 684 @for i in $(DIRS) ;\ 685 do \ 686 if [ -d "$$i" ]; then \ 687 (cd $$i && echo "making lint $$i..." && \ 688 $(MAKE) SDIRS='${SDIRS}' lint ) || exit 1; \ 689 fi; \ 690 done; 691 692tags: 693 @for i in $(DIRS) ;\ 694 do \ 695 if [ -d "$$i" ]; then \ 696 (cd $$i && echo "making tags $$i..." && \ 697 $(MAKE) SDIRS='${SDIRS}' tags ) || exit 1; \ 698 fi; \ 699 done; 700 701errors: 702 $(PERL) util/mkerr.pl -recurse -write 703 (cd crypto/engine; $(MAKE) PERL=$(PERL) errors) 704 705stacks: 706 $(PERL) util/mkstack.pl -write 707 708util/libeay.num:: 709 $(PERL) util/mkdef.pl crypto update 710 711util/ssleay.num:: 712 $(PERL) util/mkdef.pl ssl update 713 714crypto/objects/obj_dat.h: crypto/objects/obj_dat.pl crypto/objects/obj_mac.h 715 $(PERL) crypto/objects/obj_dat.pl crypto/objects/obj_mac.h crypto/objects/obj_dat.h 716crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num 717 $(PERL) crypto/objects/objects.pl crypto/objects/objects.txt crypto/objects/obj_mac.num crypto/objects/obj_mac.h 718 719TABLE: Configure 720 (echo 'Output of `Configure TABLE'"':"; \ 721 $(PERL) Configure TABLE) > TABLE 722 723update: depend errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h TABLE 724 725# Build distribution tar-file. As the list of files returned by "find" is 726# pretty long, on several platforms a "too many arguments" error or similar 727# would occur. Therefore the list of files is temporarily stored into a file 728# and read directly, requiring GNU-Tar. Call "make TAR=gtar dist" if the normal 729# tar does not support the --files-from option. 730tar: 731 find . -type d -print | xargs chmod 755 732 find . -type f -print | xargs chmod a+r 733 find . -type f -perm -0100 -print | xargs chmod a+x 734 find * \! -path CVS/\* \! -path \*/CVS/\* \! -name CVS \! -name .cvsignore \! -name STATUS \! -name TABLE | sort > ../$(TARFILE).list; \ 735 $(TAR) $(TARFLAGS) --files-from ../$(TARFILE).list -cvf - | \ 736 tardy --user_number=0 --user_name=openssl \ 737 --group_number=0 --group_name=openssl \ 738 --prefix=openssl-$(VERSION) - |\ 739 gzip --best >../$(TARFILE).gz; \ 740 rm -f ../$(TARFILE).list; \ 741 ls -l ../$(TARFILE).gz 742 743tar-snap: 744 @$(TAR) $(TARFLAGS) -cvf - \ 745 `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` |\ 746 tardy --user_number=0 --user_name=openssl \ 747 --group_number=0 --group_name=openssl \ 748 --prefix=openssl-$(VERSION) - > ../$(TARFILE);\ 749 ls -l ../$(TARFILE) 750 751dist: 752 $(PERL) Configure dist 753 @$(MAKE) dist_pem_h 754 @$(MAKE) SDIRS='${SDIRS}' clean 755 @$(MAKE) TAR='${TAR}' TARFLAGS='${TARFLAGS}' tar 756 757dist_pem_h: 758 (cd crypto/pem; $(MAKE) CC='${CC}' SDIRS='${SDIRS}' CFLAG='${CFLAG}' pem.h; $(MAKE) clean) 759 760install: all install_docs 761 @$(PERL) $(TOP)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin \ 762 $(INSTALL_PREFIX)$(INSTALLTOP)/lib \ 763 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig \ 764 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl \ 765 $(INSTALL_PREFIX)$(OPENSSLDIR)/misc \ 766 $(INSTALL_PREFIX)$(OPENSSLDIR)/certs \ 767 $(INSTALL_PREFIX)$(OPENSSLDIR)/private \ 768 $(INSTALL_PREFIX)$(OPENSSLDIR)/lib 769 @for i in $(EXHEADER) ;\ 770 do \ 771 (cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \ 772 chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \ 773 done; 774 @for i in $(DIRS) ;\ 775 do \ 776 if [ -d "$$i" ]; then \ 777 (cd $$i; echo "installing $$i..."; \ 778 $(MAKE) CC='${CC}' CFLAG='${CFLAG}' INSTALL_PREFIX='${INSTALL_PREFIX}' INSTALLTOP='${INSTALLTOP}' OPENSSLDIR='${OPENSSLDIR}' EX_LIBS='${EX_LIBS}' SDIRS='${SDIRS}' RANLIB='${RANLIB}' EXE_EXT='${EXE_EXT}' install ); \ 779 fi; \ 780 done 781 @for i in $(LIBS) ;\ 782 do \ 783 if [ -f "$$i" ]; then \ 784 ( echo installing $$i; \ 785 cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \ 786 $(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \ 787 chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \ 788 mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i ); \ 789 fi; \ 790 done; 791 @if [ -n "$(SHARED_LIBS)" ]; then \ 792 tmp="$(SHARED_LIBS)"; \ 793 for i in $${tmp:-x}; \ 794 do \ 795 if [ -f "$$i" -o -f "$$i.a" ]; then \ 796 ( echo installing $$i; \ 797 if [ "$(PLATFORM)" != "Cygwin" ]; then \ 798 cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \ 799 chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \ 800 mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \ 801 else \ 802 c=`echo $$i | sed 's/^lib\(.*\)\.dll/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \ 803 cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \ 804 chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \ 805 mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c; \ 806 cp $$i.a $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a.new; \ 807 chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a.new; \ 808 mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.a; \ 809 fi ); \ 810 fi; \ 811 done; \ 812 ( here="`pwd`"; \ 813 cd $(INSTALL_PREFIX)$(INSTALLTOP)/lib; \ 814 set $(MAKE); \ 815 $$1 -f $$here/Makefile link-shared ); \ 816 if [ "$(INSTALLTOP)" != "/usr" ]; then \ 817 echo 'OpenSSL shared libraries have been installed in:'; \ 818 echo ' $(INSTALLTOP)'; \ 819 echo ''; \ 820 sed -e '1,/^$$/d' doc/openssl-shared.txt; \ 821 fi; \ 822 fi 823 cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/lib/pkgconfig 824 825install_docs: 826 @$(PERL) $(TOP)/util/mkdir-p.pl \ 827 $(INSTALL_PREFIX)$(MANDIR)/man1 \ 828 $(INSTALL_PREFIX)$(MANDIR)/man3 \ 829 $(INSTALL_PREFIX)$(MANDIR)/man5 \ 830 $(INSTALL_PREFIX)$(MANDIR)/man7 831 @pod2man="`cd util; ./pod2mantest $(PERL)`"; \ 832 here="`pwd`"; \ 833 filecase=; \ 834 if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" ]; then \ 835 filecase=-i; \ 836 fi; \ 837 for i in doc/apps/*.pod; do \ 838 fn=`basename $$i .pod`; \ 839 if [ "$$fn" = "config" ]; then sec=5; else sec=1; fi; \ 840 echo "installing man$$sec/$$fn.$$sec"; \ 841 (cd `$(PERL) util/dirname.pl $$i`; \ 842 sh -c "$$pod2man \ 843 --section=$$sec --center=OpenSSL \ 844 --release=$(VERSION) `basename $$i`") \ 845 > $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$$sec; \ 846 $(PERL) util/extract-names.pl < $$i | \ 847 grep -v $$filecase "^$$fn\$$" | \ 848 (cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \ 849 while read n; do \ 850 $$here/util/point.sh $$fn.$$sec $$n.$$sec; \ 851 done); \ 852 done; \ 853 for i in doc/crypto/*.pod doc/ssl/*.pod; do \ 854 fn=`basename $$i .pod`; \ 855 if [ "$$fn" = "des_modes" ]; then sec=7; else sec=3; fi; \ 856 echo "installing man$$sec/$$fn.$$sec"; \ 857 (cd `$(PERL) util/dirname.pl $$i`; \ 858 sh -c "$$pod2man \ 859 --section=$$sec --center=OpenSSL \ 860 --release=$(VERSION) `basename $$i`") \ 861 > $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$$sec; \ 862 $(PERL) util/extract-names.pl < $$i | \ 863 grep -v $$filecase "^$$fn\$$" | \ 864 (cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \ 865 while read n; do \ 866 $$here/util/point.sh $$fn.$$sec $$n.$$sec; \ 867 done); \ 868 done 869 870# DO NOT DELETE THIS LINE -- make depend depends on it. 871