summaryrefslogtreecommitdiff
path: root/SOURCES/check-kabi
diff options
context:
space:
mode:
authorJan200101 <sentrycraft123@gmail.com>2020-11-03 17:22:33 +0100
committerJan200101 <sentrycraft123@gmail.com>2020-12-05 19:40:07 +0100
commit341c2b7474ae9534963c9001cae5b8e6ecefe0f2 (patch)
treede02864eb15585e56915d9e9c987c3675fa4f4ff /SOURCES/check-kabi
parent7fa28673e01cd07016a83be8169a0bd46ba63a04 (diff)
downloadkernel-fsync-341c2b7474ae9534963c9001cae5b8e6ecefe0f2.tar.gz
kernel-fsync-341c2b7474ae9534963c9001cae5b8e6ecefe0f2.zip
kernel 5.8.17
Diffstat (limited to 'SOURCES/check-kabi')
-rwxr-xr-x[-rw-r--r--]SOURCES/check-kabi149
1 files changed, 149 insertions, 0 deletions
diff --git a/SOURCES/check-kabi b/SOURCES/check-kabi
index e69de29..f9d4dcb 100644..100755
--- a/SOURCES/check-kabi
+++ b/SOURCES/check-kabi
@@ -0,0 +1,149 @@
+#!/usr/bin/python3
+#
+# check-kabi - Red Hat kABI reference checking tool
+#
+# We use this script to check against reference Module.kabi files.
+#
+# Author: Jon Masters <jcm@redhat.com>
+# Copyright (C) 2007-2009 Red Hat, Inc.
+#
+# This software may be freely redistributed under the terms of the GNU
+# General Public License (GPL).
+
+# Changelog:
+#
+# 2018/06/01 - Update for python3 by Petr Oros.
+# 2009/08/15 - Updated for use in RHEL6.
+# 2007/06/13 - Initial rewrite in python by Jon Masters.
+
+__author__ = "Jon Masters <jcm@redhat.com>"
+__version__ = "2.0"
+__date__ = "2009/08/15"
+__copyright__ = "Copyright (C) 2007-2009 Red Hat, Inc"
+__license__ = "GPL"
+
+import getopt
+import string
+import sys
+
+true = 1
+false = 0
+
+
+def load_symvers(symvers, filename):
+ """Load a Module.symvers file."""
+
+ symvers_file = open(filename, "r")
+
+ while true:
+ in_line = symvers_file.readline()
+ if in_line == "":
+ break
+ if in_line == "\n":
+ continue
+ checksum, symbol, directory, type = in_line.split()
+
+ symvers[symbol] = in_line[0:-1]
+
+
+def load_kabi(kabi, filename):
+ """Load a Module.kabi file."""
+
+ kabi_file = open(filename, "r")
+
+ while true:
+ in_line = kabi_file.readline()
+ if in_line == "":
+ break
+ if in_line == "\n":
+ continue
+ checksum, symbol, directory, type = in_line.split()
+
+ kabi[symbol] = in_line[0:-1]
+
+
+def check_kabi(symvers, kabi):
+ """Check Module.kabi and Module.symvers files."""
+
+ fail = 0
+ warn = 0
+ changed_symbols = []
+ moved_symbols = []
+
+ for symbol in kabi:
+ abi_hash, abi_sym, abi_dir, abi_type = kabi[symbol].split()
+ if symbol in symvers:
+ sym_hash, sym_sym, sym_dir, sym_type = symvers[symbol].split()
+ if abi_hash != sym_hash:
+ fail = 1
+ changed_symbols.append(symbol)
+
+ if abi_dir != sym_dir:
+ warn = 1
+ moved_symbols.append(symbol)
+ else:
+ fail = 1
+ changed_symbols.append(symbol)
+
+ if fail:
+ print("*** ERROR - ABI BREAKAGE WAS DETECTED ***")
+ print("")
+ print("The following symbols have been changed (this will cause an ABI breakage):")
+ print("")
+ for symbol in changed_symbols:
+ print(symbol)
+ print("")
+
+ if warn:
+ print("*** WARNING - ABI SYMBOLS MOVED ***")
+ print("")
+ print("The following symbols moved (typically caused by moving a symbol from being")
+ print("provided by the kernel vmlinux out to a loadable module):")
+ print("")
+ for symbol in moved_symbols:
+ print(symbol)
+ print("")
+
+ """Halt the build, if we got errors and/or warnings. In either case,
+ double-checkig is required to avoid introducing / concealing
+ KABI inconsistencies."""
+ if fail or warn:
+ sys.exit(1)
+ sys.exit(0)
+
+
+def usage():
+ print("""
+check-kabi: check Module.kabi and Module.symvers files.
+
+ check-kabi [ -k Module.kabi ] [ -s Module.symvers ]
+
+""")
+
+
+if __name__ == "__main__":
+
+ symvers_file = ""
+ kabi_file = ""
+
+ opts, args = getopt.getopt(sys.argv[1:], 'hk:s:')
+
+ for o, v in opts:
+ if o == "-s":
+ symvers_file = v
+ if o == "-h":
+ usage()
+ sys.exit(0)
+ if o == "-k":
+ kabi_file = v
+
+ if (symvers_file == "") or (kabi_file == ""):
+ usage()
+ sys.exit(1)
+
+ symvers = {}
+ kabi = {}
+
+ load_symvers(symvers, symvers_file)
+ load_kabi(kabi, kabi_file)
+ check_kabi(symvers, kabi)