shlib_wrap.sh 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #!/bin/sh
  2. # To test this OpenSSL version's applications against another version's
  3. # shared libraries, simply set
  4. #
  5. # OPENSSL_REGRESSION=/path/to/other/OpenSSL/build/tree
  6. if [ -n "$OPENSSL_REGRESSION" ]; then
  7. shlibwrap="$OPENSSL_REGRESSION/util/shlib_wrap.sh"
  8. if [ -x "$shlibwrap" ]; then
  9. # We clear OPENSSL_REGRESSION to avoid a loop, should the shlib_wrap.sh
  10. # we exec also support that mechanism...
  11. OPENSSL_REGRESSION= exec "$shlibwrap" "$@"
  12. else
  13. if [ -f "$shlibwrap" ]; then
  14. echo "Not permitted to run $shlibwrap" >&2
  15. else
  16. echo "No $shlibwrap, perhaps OPENSSL_REGRESSION isn't properly set?" >&2
  17. fi
  18. exit 1
  19. fi
  20. fi
  21. [ $# -ne 0 ] || set -x # debug mode without arguments:-)
  22. THERE="`echo $0 | sed -e 's|[^/]*$||' 2>/dev/null`.."
  23. [ -d "${THERE}" ] || exec "$@" # should never happen...
  24. LIBCRYPTOSO="${THERE}/libcrypto.so.1.1"
  25. LIBSSLSO="${THERE}/libssl.so.1.1"
  26. SYSNAME=`(uname -s) 2>/dev/null`;
  27. case "$SYSNAME" in
  28. SunOS|IRIX*)
  29. # SunOS and IRIX run-time linkers evaluate alternative
  30. # variables depending on target ABI...
  31. rld_var=LD_LIBRARY_PATH
  32. case "`(/usr/bin/file "$LIBCRYPTOSO") 2>/dev/null`" in
  33. *ELF\ 64*SPARC*|*ELF\ 64*AMD64*)
  34. [ -n "$LD_LIBRARY_PATH_64" ] && rld_var=LD_LIBRARY_PATH_64
  35. LD_PRELOAD_64="$LIBCRYPTOSO $LIBSSLSO"; export LD_PRELOAD_64
  36. preload_var=LD_PRELOAD_64
  37. ;;
  38. *ELF\ 32*SPARC*|*ELF\ 32*80386*)
  39. # We only need to change LD_PRELOAD_32 and LD_LIBRARY_PATH_32
  40. # on a multi-arch system. Otherwise, trust the fallbacks.
  41. if [ -f /lib/64/ld.so.1 ]; then
  42. [ -n "$LD_LIBRARY_PATH_32" ] && rld_var=LD_LIBRARY_PATH_32
  43. LD_PRELOAD_32="$LIBCRYPTOSO $LIBSSLSO"; export LD_PRELOAD_32
  44. preload_var=LD_PRELOAD_32
  45. fi
  46. ;;
  47. # Why are newly built .so's preloaded anyway? Because run-time
  48. # .so lookup path embedded into application takes precedence
  49. # over LD_LIBRARY_PATH and as result application ends up linking
  50. # to previously installed .so's. On IRIX instead of preloading
  51. # newly built .so's we trick run-time linker to fail to find
  52. # the installed .so by setting _RLD_ROOT variable.
  53. *ELF\ 32*MIPS*)
  54. #_RLD_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLD_LIST
  55. _RLD_ROOT=/no/such/dir; export _RLD_ROOT
  56. eval $rld_var=\"/usr/lib'${'$rld_var':+:$'$rld_var'}'\"
  57. preload_var=_RLD_LIST
  58. ;;
  59. *ELF\ N32*MIPS*)
  60. [ -n "$LD_LIBRARYN32_PATH" ] && rld_var=LD_LIBRARYN32_PATH
  61. #_RLDN32_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLDN32_LIST
  62. _RLDN32_ROOT=/no/such/dir; export _RLDN32_ROOT
  63. eval $rld_var=\"/usr/lib32'${'$rld_var':+:$'$rld_var'}'\"
  64. preload_var=_RLDN32_LIST
  65. ;;
  66. *ELF\ 64*MIPS*)
  67. [ -n "$LD_LIBRARY64_PATH" ] && rld_var=LD_LIBRARY64_PATH
  68. #_RLD64_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLD64_LIST
  69. _RLD64_ROOT=/no/such/dir; export _RLD64_ROOT
  70. eval $rld_var=\"/usr/lib64'${'$rld_var':+:$'$rld_var'}'\"
  71. preload_var=_RLD64_LIST
  72. ;;
  73. esac
  74. eval $rld_var=\"${THERE}'${'$rld_var':+:$'$rld_var'}'\"; export $rld_var
  75. unset rld_var
  76. ;;
  77. *) LD_LIBRARY_PATH="${THERE}:$LD_LIBRARY_PATH" # Linux, ELF HP-UX
  78. DYLD_LIBRARY_PATH="${THERE}:$DYLD_LIBRARY_PATH" # MacOS X
  79. SHLIB_PATH="${THERE}:$SHLIB_PATH" # legacy HP-UX
  80. LIBPATH="${THERE}:$LIBPATH" # AIX, OS/2
  81. export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH
  82. # Even though $PATH is adjusted [for Windows sake], it doesn't
  83. # necessarily does the trick. Trouble is that with introduction
  84. # of SafeDllSearchMode in XP/2003 it's more appropriate to copy
  85. # .DLLs in vicinity of executable, which is done elsewhere...
  86. if [ "$OSTYPE" != msdosdjgpp ]; then
  87. PATH="${THERE}:$PATH"; export PATH
  88. fi
  89. ;;
  90. esac
  91. cmd="$1"; [ -x "$cmd" ] || cmd="$cmd${EXE_EXT}"
  92. shift
  93. if [ $# -eq 0 ]; then
  94. exec "$cmd" # old sh, such as Tru64 4.x, fails to expand empty "$@"
  95. else
  96. exec "$cmd" "$@"
  97. fi