123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- * System libcrypto.dylib and libssl.dylib are used by system ld on MacOS X.
- NOTE: The problem described here only applies when OpenSSL isn't built
- with shared library support (i.e. without the "shared" configuration
- option). If you build with shared library support, you will have no
- problems as long as you set up DYLD_LIBRARY_PATH properly at all times.
- This is really a misfeature in ld, which seems to look for .dylib libraries
- along the whole library path before it bothers looking for .a libraries. This
- means that -L switches won't matter unless OpenSSL is built with shared
- library support.
- The workaround may be to change the following lines in apps/Makefile and
- test/Makefile:
- LIBCRYPTO=-L.. -lcrypto
- LIBSSL=-L.. -lssl
- to:
- LIBCRYPTO=../libcrypto.a
- LIBSSL=../libssl.a
- It's possible that something similar is needed for shared library support
- as well. That hasn't been well tested yet.
- Another solution that many seem to recommend is to move the libraries
- /usr/lib/libcrypto.0.9.dylib, /usr/lib/libssl.0.9.dylib to a different
- directory, build and install OpenSSL and anything that depends on your
- build, then move libcrypto.0.9.dylib and libssl.0.9.dylib back to their
- original places. Note that the version numbers on those two libraries
- may differ on your machine.
- As long as Apple doesn't fix the problem with ld, this problem building
- OpenSSL will remain as is.
- * Parallell make leads to errors
- While running tests, running a parallell make is a bad idea. Many test
- scripts use the same name for output and input files, which means different
- will interfere with each other and lead to test failure.
- The solution is simple for now: don't run parallell make when testing.
- * Bugs in gcc 3.0 triggered
- According to a problem report, there are bugs in gcc 3.0 that are
- triggered by some of the code in OpenSSL, more specifically in
- PEM_get_EVP_CIPHER_INFO(). The triggering code is the following:
- header+=11;
- if (*header != '4') return(0); header++;
- if (*header != ',') return(0); header++;
- What happens is that gcc might optimize a little too agressively, and
- you end up with an extra incrementation when *header != '4'.
- We recommend that you upgrade gcc to as high a 3.x version as you can.
- * solaris64-sparcv9-cc SHA-1 performance with WorkShop 6 compiler.
- As subject suggests SHA-1 might perform poorly (4 times slower)
- if compiled with WorkShop 6 compiler and -xarch=v9. The cause for
- this seems to be the fact that compiler emits multiplication to
- perform shift operations:-( To work the problem around configure
- with './Configure solaris64-sparcv9-cc -DMD32_REG_T=int'.
- * Problems with hp-parisc2-cc target when used with "no-asm" flag
- When using the hp-parisc2-cc target, wrong bignum code is generated.
- This is due to the SIXTY_FOUR_BIT build being compiled with the +O3
- aggressive optimization.
- The problem manifests itself by the BN_kronecker test hanging in an
- endless loop. Reason: the BN_kronecker test calls BN_generate_prime()
- which itself hangs. The reason could be tracked down to the bn_mul_comba8()
- function in bn_asm.c. At some occasions the higher 32bit value of r[7]
- is off by 1 (meaning: calculated=shouldbe+1). Further analysis failed,
- as no debugger support possible at +O3 and additional fprintf()'s
- introduced fixed the bug, therefore it is most likely a bug in the
- optimizer.
- The bug was found in the BN_kronecker test but may also lead to
- failures in other parts of the code.
- (See Ticket #426.)
- Workaround: modify the target to +O2 when building with no-asm.
- * Poor support for AIX shared builds.
- do_aix-shared rule is not flexible enough to parameterize through a
- config-line. './Configure aix43-cc shared' is working, but not
- './Configure aix64-gcc shared'. In latter case make fails to create shared
- libraries. It's possible to build 64-bit shared libraries by running
- 'env OBJECT_MODE=64 make', but we need more elegant solution. Preferably one
- supporting even gcc shared builds. See RT#463 for background information.
- * Problems building shared libraries on SCO OpenServer Release 5.0.6
- with gcc 2.95.3
- The symptoms appear when running the test suite, more specifically
- test/ectest, with the following result:
- OSSL_LIBPATH="`cd ..; pwd`"; LD_LIBRARY_PATH="$OSSL_LIBPATH:$LD_LIBRARY_PATH"; DYLD_LIBRARY_PATH="$OSSL_LIBPATH:$DYLD_LIBRARY_PATH"; SHLIB_PATH="$OSSL_LIBPATH:$SHLIB_PATH"; LIBPATH="$OSSL_LIBPATH:$LIBPATH"; if [ "debug-sco5-gcc" = "Cygwin" ]; then PATH="${LIBPATH}:$PATH"; fi; export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; ./ectest
- ectest.c:186: ABORT
- The cause of the problem seems to be that isxdigit(), called from
- BN_hex2bn(), returns 0 on a perfectly legitimate hex digit. Further
- investigation shows that any of the isxxx() macros return 0 on any
- input. A direct look in the information array that the isxxx() use,
- called __ctype, shows that it contains all zeroes...
- Taking a look at the newly created libcrypto.so with nm, one can see
- that the variable __ctype is defined in libcrypto's .bss (which
- explains why it is filled with zeroes):
- $ nm -Pg libcrypto.so | grep __ctype
- __ctype B 0011659c
- __ctype2 U
- Curiously, __ctype2 is undefined, in spite of being declared in
- /usr/include/ctype.h in exactly the same way as __ctype.
- Any information helping to solve this issue would be deeply
- appreciated.
- NOTE: building non-shared doesn't come with this problem.
|