#!/bin/sh # # Copyright The Mbed TLS Contributors # SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later # # Purpose # # Show external links in built libraries (X509 or TLS) or modules. This is # usually done to list Crypto dependencies or to check modules' # interdependencies. # # Usage: # - build the library with debug symbols and the config you're interested in # (default, full minus MBEDTLS_USE_PSA_CRYPTO, full, etc.) # - launch this script with 1 or more arguments depending on the analysis' goal: # - if only 1 argument is used (which is the name of the used config, # ex: full), then the analysis is done on libmbedx509 and libmbedtls # libraries by default # - if multiple arguments are provided, then modules' names (ex: pk, # pkparse, pkwrite, etc) are expected after the 1st one and the analysis # will be done on those modules instead of the libraries. set -eu # list mbedtls_ symbols of a given type in a static library syms() { TYPE="$1" FILE="$2" nm "$FILE" | sed -n "s/[0-9a-f ]*${TYPE} \(mbedtls_.*\)/\1/p" | sort -u } # Check if the provided name refers to a module or library and return the # same path with proper extension get_file_with_extension() { BASE=$1 if [ -f $BASE.o ]; then echo $BASE.o elif [ -f $BASE.a ]; then echo $BASE.a fi } # create listings for the given library list() { NAME="$1" FILE=$(get_file_with_extension "library/${NAME}") PREF="${CONFIG}-$NAME" syms '[TRrD]' $FILE > ${PREF}-defined syms U $FILE > ${PREF}-unresolved diff ${PREF}-defined ${PREF}-unresolved \ | sed -n 's/^> //p' > ${PREF}-external sed 's/mbedtls_\([^_]*\).*/\1/' ${PREF}-external \ | uniq -c | sort -rn > ${PREF}-modules rm ${PREF}-defined ${PREF}-unresolved } CONFIG="${1:-unknown}" # List of modules to check is provided as parameters if [ $# -gt 1 ]; then shift 1 ITEMS_TO_CHECK="$@" else ITEMS_TO_CHECK="libmbedx509 libmbedtls" fi for ITEM in $ITEMS_TO_CHECK; do list $ITEM done