2020-02-02 22:08:34 +01:00
|
|
|
#!/bin/sh -e
|
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
# Copyright (c) 2019 Red Hat, Inc.
|
|
|
|
|
|
|
|
if [ $# != 2 ] && [ $# != 3 ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "Usage: $0 refdir newdir [warnonly]" >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
refdir=$1
|
|
|
|
newdir=$2
|
|
|
|
warnonly=${3:-}
|
|
|
|
ABIDIFF_OPTIONS="--suppr $(dirname $0)/libabigail.abignore --no-added-syms"
|
|
|
|
|
|
|
|
if [ ! -d $refdir ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "Error: reference directory '$refdir' does not exist." >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
incdir=$(find $refdir -type d -a -name include)
|
|
|
|
if [ -z "$incdir" ] || [ ! -e "$incdir" ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "WARNING: could not identify an include directory for $refdir, expect false positives..." >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
else
|
|
|
|
ABIDIFF_OPTIONS="$ABIDIFF_OPTIONS --headers-dir1 $incdir"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -d $newdir ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "Error: directory to check '$newdir' does not exist." >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
incdir2=$(find $newdir -type d -a -name include)
|
|
|
|
if [ -z "$incdir2" ] || [ ! -e "$incdir2" ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "WARNING: could not identify an include directory for $newdir, expect false positives..." >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
else
|
|
|
|
ABIDIFF_OPTIONS="$ABIDIFF_OPTIONS --headers-dir2 $incdir2"
|
|
|
|
fi
|
|
|
|
|
|
|
|
error=
|
|
|
|
for dump in $(find $refdir -name "*.dump"); do
|
|
|
|
name=$(basename $dump)
|
|
|
|
# skip glue drivers, example librte_pmd_mlx5_glue.dump
|
|
|
|
# We can't rely on a suppression rule for now:
|
|
|
|
# https://sourceware.org/bugzilla/show_bug.cgi?id=25480
|
2020-02-21 16:42:53 +01:00
|
|
|
if grep -qE "\<soname='[^']*_glue\.so\.[^']*'" $dump; then
|
|
|
|
echo "Skipped glue library $name."
|
|
|
|
continue
|
|
|
|
fi
|
2021-04-13 10:29:37 +02:00
|
|
|
if grep -qE "\<soname='librte_event_dlb\.so" $dump; then
|
|
|
|
echo "Skipped removed driver $name."
|
|
|
|
continue
|
|
|
|
fi
|
2020-02-02 22:08:34 +01:00
|
|
|
dump2=$(find $newdir -name $name)
|
|
|
|
if [ -z "$dump2" ] || [ ! -e "$dump2" ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "Error: cannot find $name in $newdir" >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
error=1
|
|
|
|
continue
|
|
|
|
fi
|
2020-07-08 11:40:46 +02:00
|
|
|
abidiff $ABIDIFF_OPTIONS $dump $dump2 || {
|
|
|
|
abiret=$?
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "Error: ABI issue reported for 'abidiff $ABIDIFF_OPTIONS $dump $dump2'" >&2
|
2020-02-02 22:08:34 +01:00
|
|
|
error=1
|
2020-07-08 11:40:46 +02:00
|
|
|
echo
|
|
|
|
if [ $(($abiret & 3)) -ne 0 ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "ABIDIFF_ERROR|ABIDIFF_USAGE_ERROR, this could be a script or environment issue." >&2
|
2020-07-08 11:40:46 +02:00
|
|
|
fi
|
|
|
|
if [ $(($abiret & 4)) -ne 0 ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "ABIDIFF_ABI_CHANGE, this change requires a review (abidiff flagged this as a potential issue)." >&2
|
2020-07-08 11:40:46 +02:00
|
|
|
fi
|
|
|
|
if [ $(($abiret & 8)) -ne 0 ]; then
|
2020-12-02 18:15:21 +01:00
|
|
|
echo "ABIDIFF_ABI_INCOMPATIBLE_CHANGE, this change breaks the ABI." >&2
|
2020-07-08 11:40:46 +02:00
|
|
|
fi
|
|
|
|
echo
|
|
|
|
}
|
2020-02-02 22:08:34 +01:00
|
|
|
done
|
|
|
|
|
|
|
|
[ -z "$error" ] || [ -n "$warnonly" ]
|