| OLD | NEW |
| (Empty) |
| 1 #!/bin/sh -e | |
| 2 # | |
| 3 # Copyright (c) 2005-2007 The OpenSSL Project. | |
| 4 # | |
| 5 # Depending on output file name, the script either embeds fingerprint | |
| 6 # into libcrypto.so or static application. "Static" refers to static | |
| 7 # libcrypto.a, not [necessarily] application per se. | |
| 8 # | |
| 9 # Even though this script is called fipsld, it expects C compiler | |
| 10 # command line syntax and $FIPSLD_CC or $CC environment variable set | |
| 11 # and can even be used to compile source files. | |
| 12 | |
| 13 #set -x | |
| 14 | |
| 15 CC=${FIPSLD_CC:-${CC}} | |
| 16 [ -n "${CC}" ] || { echo '$CC is not defined'; exit 1; } | |
| 17 | |
| 18 # Initially -c wasn't intended to be interpreted here, but it might | |
| 19 # make life easier for those who want to build FIPS-ified applications | |
| 20 # with minimal [if any] modifications to their Makefiles... | |
| 21 ( while [ "x$1" != "x" -a "x$1" != "x-c" -a "x$1" != "x-E" ]; do shift; done; | |
| 22 [ $# -ge 1 ] | |
| 23 ) && exec ${CC} "$@" | |
| 24 | |
| 25 TARGET=`(while [ "x$1" != "x" -a "x$1" != "x-o" ]; do shift; done; echo $2)` | |
| 26 | |
| 27 # If using an auto-tooled (autoconf/automake/libtool) project, | |
| 28 # configure will fail when testing the compiler or even performing | |
| 29 # simple checks. Pass-through to compiler directly if application is | |
| 30 # is not being linked with libcrypto, allowing auto-tooled applications | |
| 31 # to utilize fipsld (e.g. CC=/usr/local/ssl/bin/fipsld FIPSLD_CC=gcc | |
| 32 # ./configure && make). But keep in mind[!] that if certified code | |
| 33 # resides in a shared library, then fipsld *may not* be used and | |
| 34 # end-developer should not modify application configuration and build | |
| 35 # procedures. This is because in-core fingerprint and associated | |
| 36 # procedures are already embedded into and executed in shared library | |
| 37 # context. | |
| 38 case `basename "${TARGET}"` in | |
| 39 libcrypto*|libfips*|*.dll) ;; | |
| 40 *) case "$*" in | |
| 41 *libcrypto.a*|*-lcrypto*|*fipscanister.o*) ;; | |
| 42 *) exec ${CC} "$@" ;; | |
| 43 esac | |
| 44 esac | |
| 45 | |
| 46 [ -n "${TARGET}" ] || { echo 'no -o specified'; exit 1; } | |
| 47 | |
| 48 # Turn on debugging output? | |
| 49 ( while [ "x$1" != "x" -a "x$1" != "x-DDEBUG_FINGERPRINT_PREMAIN" ]; do shift;
done; | |
| 50 [ $# -ge 1 ] | |
| 51 ) && set -x | |
| 52 | |
| 53 THERE="`echo $0 | sed -e 's|[^/]*$||'`".. | |
| 54 | |
| 55 # fipscanister.o can appear in command line | |
| 56 CANISTER_O=`(while [ "x$1" != "x" ]; do case "$1" in *fipscanister.o) echo $1; e
xit;; esac; shift; done)` | |
| 57 if [ -z "${CANISTER_O}" ]; then | |
| 58 # If set, FIPSLIBDIR is location of installed validated FIPS module | |
| 59 if [ -n "${FIPSLIBDIR}" ]; then | |
| 60 CANISTER_O="${FIPSLIBDIR}/fipscanister.o" | |
| 61 elif [ -f "${THERE}/fips/fipscanister.o" ]; then | |
| 62 CANISTER_O="${THERE}/fips/fipscanister.o" | |
| 63 elif [ -f "${THERE}/lib/fipscanister.o" ]; then | |
| 64 CANISTER_O="${THERE}/lib/fipscanister.o" | |
| 65 fi | |
| 66 CANISTER_O_CMD="${CANISTER_O}" | |
| 67 fi | |
| 68 [ -f ${CANISTER_O} ] || { echo "unable to find ${CANISTER_O}"; exit 1; } | |
| 69 | |
| 70 PREMAIN_C=`dirname "${CANISTER_O}"`/fips_premain.c | |
| 71 | |
| 72 HMAC_KEY="etaonrishdlcupfm" | |
| 73 | |
| 74 case "`(uname -s) 2>/dev/null`" in | |
| 75 OSF1|IRIX*) _WL_PREMAIN="-Wl,-init,FINGERPRINT_premain" ;; | |
| 76 HP-UX) _WL_PREMAIN="-Wl,+init,FINGERPRINT_premain" ;; | |
| 77 AIX) _WL_PREMAIN="-Wl,-binitfini:FINGERPRINT_premain,-bnoobjreorder";
; | |
| 78 Darwin) ( while [ "x$1" != "x" -a "x$1" != "x-dynamiclib" ]; do shift;
done; | |
| 79 [ $# -ge 1 ] | |
| 80 ) && _WL_PREMAIN="-Wl,-init,_FINGERPRINT_premain" ;; | |
| 81 esac | |
| 82 | |
| 83 case "${TARGET}" in | |
| 84 [!/]*) TARGET=./${TARGET} ;; | |
| 85 esac | |
| 86 | |
| 87 case `basename "${TARGET}"` in | |
| 88 lib*|*.dll) # must be linking a shared lib... | |
| 89 # Shared lib creation can be taking place in the source | |
| 90 # directory only, but fipscanister.o can reside elsewhere... | |
| 91 FINGERTYPE="${THERE}/fips/fips_standalone_sha1" | |
| 92 | |
| 93 # verify fipspremain.c against its detached signature... | |
| 94 ${FINGERTYPE} "${PREMAIN_C}" | sed "s/(.*\//(/" | \ | |
| 95 diff -w "${PREMAIN_C}.sha1" - || \ | |
| 96 { echo "${PREMAIN_C} fingerprint mismatch"; exit 1; } | |
| 97 # verify fipscanister.o against its detached signature... | |
| 98 ${FINGERTYPE} "${CANISTER_O}" | sed "s/(.*\//(/" | \ | |
| 99 diff -w "${CANISTER_O}.sha1" - || \ | |
| 100 { echo "${CANISTER_O} fingerprint mismatch"; exit 1; } | |
| 101 | |
| 102 # Temporarily remove fipscanister.o from libcrypto.a! | |
| 103 # We are required to use the standalone copy... | |
| 104 if [ -f "${THERE}/libcrypto.a" ]; then | |
| 105 if ar d "${THERE}/libcrypto.a" fipscanister.o; then | |
| 106 (ranlib "${THERE}/libcrypto.a") 2>/dev/null || : | |
| 107 trap 'ar r "${THERE}/libcrypto.a" "${CANISTER_O}"; | |
| 108 (ranlib "${THERE}/libcrypto.a") 2>/dev/null || :; | |
| 109 sleep 1; | |
| 110 touch -c "${TARGET}"' 0 | |
| 111 fi | |
| 112 fi | |
| 113 | |
| 114 /bin/rm -f "${TARGET}" | |
| 115 ${CC} ${CANISTER_O_CMD:+"${CANISTER_O_CMD}"} \ | |
| 116 "${PREMAIN_C}" \ | |
| 117 ${_WL_PREMAIN} "$@" | |
| 118 | |
| 119 # generate signature... | |
| 120 if [ -z "${FIPS_SIG}" ]; then | |
| 121 SIG=`"${THERE}/fips/fips_premain_dso" "${TARGET}"` | |
| 122 else | |
| 123 SIG=`"${FIPS_SIG}" -dso "${TARGET}"` | |
| 124 fi | |
| 125 /bin/rm -f "${TARGET}" | |
| 126 if [ -z "${SIG}" ]; then | |
| 127 echo "unable to collect signature"; exit 1 | |
| 128 fi | |
| 129 | |
| 130 # recompile with signature... | |
| 131 ${CC} ${CANISTER_O_CMD:+"${CANISTER_O_CMD}"} \ | |
| 132 -DHMAC_SHA1_SIG=\"${SIG}\" "${PREMAIN_C}" \ | |
| 133 ${_WL_PREMAIN} "$@" | |
| 134 ;; | |
| 135 | |
| 136 *) # must be linking statically... | |
| 137 # Static linking can be taking place either in the source | |
| 138 # directory or off the installed binary target destination. | |
| 139 if [ -x "${THERE}/fips/fips_standalone_sha1" ]; then | |
| 140 FINGERTYPE="${THERE}/fips/fips_standalone_sha1" | |
| 141 else # Installed tree is expected to contain | |
| 142 # lib/fipscanister.o, lib/fipscanister.o.sha1 and | |
| 143 # lib/fips_premain.c [not to mention bin/openssl]. | |
| 144 FINGERTYPE="${THERE}/bin/openssl sha1 -hmac ${HMAC_KEY}" | |
| 145 fi | |
| 146 | |
| 147 # verify fipscanister.o against its detached signature... | |
| 148 ${FINGERTYPE} "${CANISTER_O}" | sed "s/(.*\//(/" | \ | |
| 149 diff -w "${CANISTER_O}.sha1" - || \ | |
| 150 { echo "${CANISTER_O} fingerprint mismatch"; exit 1; } | |
| 151 | |
| 152 # verify fips_premain.c against its detached signature... | |
| 153 ${FINGERTYPE} "${PREMAIN_C}" | sed "s/(.*\//(/" | \ | |
| 154 diff -w "${PREMAIN_C}.sha1" - || \ | |
| 155 { echo "${PREMAIN_C} fingerprint mismatch"; exit 1; } | |
| 156 | |
| 157 /bin/rm -f "${TARGET}" | |
| 158 ${CC} ${CANISTER_O_CMD:+"${CANISTER_O_CMD}"} \ | |
| 159 "${PREMAIN_C}" \ | |
| 160 ${_WL_PREMAIN} "$@" | |
| 161 | |
| 162 # generate signature... | |
| 163 if [ -z "${FIPS_SIG}" ]; then | |
| 164 SIG=`"${TARGET}"` | |
| 165 else | |
| 166 SIG=`"${FIPS_SIG}" -exe "${TARGET}"` | |
| 167 fi | |
| 168 /bin/rm -f "${TARGET}" | |
| 169 if [ -z "${SIG}" ]; then | |
| 170 echo "unable to collect signature"; exit 1 | |
| 171 fi | |
| 172 | |
| 173 # recompile with signature... | |
| 174 ${CC} ${CANISTER_O_CMD:+"${CANISTER_O_CMD}"} \ | |
| 175 -DHMAC_SHA1_SIG=\"${SIG}\" "${PREMAIN_C}" \ | |
| 176 ${_WL_PREMAIN} "$@" | |
| 177 ;; | |
| 178 esac | |
| OLD | NEW |