Blame SOURCES/redhat-rpm-config-9.1.0-fix-ksym-requires-generation.patch

76c1b9
Index: redhat-rpm-config-9.1.0/find-requires.ksyms
76c1b9
===================================================================
76c1b9
--- redhat-rpm-config-9.1.0.orig/find-requires.ksyms	2018-08-24 09:55:19.094210445 +0200
76c1b9
+++ redhat-rpm-config-9.1.0/find-requires.ksyms	2018-09-14 12:40:34.744601952 +0200
76c1b9
@@ -12,8 +12,8 @@
76c1b9
     if [[ -n $(nm "$@" | sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p') ]]; then
76c1b9
         nm "$@" \
76c1b9
         | sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p' \
76c1b9
-        | awk --non-decimal-data '{printf("0x%08x\t%s\n", $1, $2)}' \
76c1b9
-        | LC_ALL=C sort -k2,2 -u
76c1b9
+        | awk --non-decimal-data '{printf("%s:0x%08x\n", $2, $1)}' \
76c1b9
+        | LC_ALL=C sort -k1,1 -u
76c1b9
     else
76c1b9
         ELFRODATA=$(readelf -R .rodata "$@" | awk '/0x/{printf $2$3$4$5}')
76c1b9
         if [[ -n $(readelf -h "$@" | grep "little endian") ]]; then
76c1b9
@@ -24,8 +24,8 @@
76c1b9
         for sym in $(nm "$@" | sed -r -ne 's:^0*([0-9a-f]+) R __crc_(.+):0x\1 \2:p'); do
76c1b9
             echo $sym $RODATA
76c1b9
         done \
76c1b9
-        | awk --non-decimal-data '{printf("0x%08s\t%s\n", substr($3,($1*2)+1,8), $2)}' \
76c1b9
-        | LC_ALL=C sort -k2,2 -u
76c1b9
+        | awk --non-decimal-data '{printf("%s:0x%08s\n", $2, substr($3,($1*2)+1,8))}' \
76c1b9
+        | LC_ALL=C sort -k1,1 -u
76c1b9
     fi
76c1b9
 }
76c1b9
 
76c1b9
@@ -36,15 +36,15 @@
76c1b9
         /sbin/modprobe --dump-modversions "$module" \
76c1b9
         | awk --non-decimal-data '
76c1b9
             BEGIN { FS = "\t" ; OFS = "\t" }
76c1b9
-            {printf("0x%08x\t%s\n", $1, $2)}' \
76c1b9
+            {printf("%s:0x%08x\n", $2, $1)}' \
76c1b9
         | sed -r -e 's:$:\t'"$1"':'
76c1b9
     done \
76c1b9
-    | LC_ALL=C sort -k2,2 -u
76c1b9
+    | LC_ALL=C sort -k1,1 -u
76c1b9
 }
76c1b9
 
76c1b9
 # Filter out requirements fulfilled by the module itself.
76c1b9
 mod_requires() {
76c1b9
-    LC_ALL=C join -t $'\t' -j 2 -v 1 \
76c1b9
+    LC_ALL=C join -t $'\t' -j 1 -v 1 \
76c1b9
         <(all_requires "$@") \
76c1b9
         <(all_provides "$@") \
76c1b9
     | LC_ALL=C sort -k1,1 -u
76c1b9
@@ -55,6 +55,8 @@
76c1b9
     exit 0
76c1b9
 fi
76c1b9
 
76c1b9
+export LC_ALL=C
76c1b9
+
76c1b9
 check_kabi() {
76c1b9
     arch=$(uname -m)
76c1b9
     kabi_file="/lib/modules/kabi-current/kabi_whitelist_$arch"
76c1b9
@@ -107,22 +109,24 @@
76c1b9
 
76c1b9
     cat /usr/src/kernels/$kernel/Module.symvers | awk '
76c1b9
         BEGIN { FS = "\t" ; OFS = "\t" }
76c1b9
-        { print $2 "\t" $1 }
76c1b9
+        { print $2 ":" $1 }
76c1b9
     ' \
76c1b9
     | sed -r -e 's:$:\t'"$kernel"':' \
76c1b9
     | LC_ALL=C sort -k1,1 -u > $symvers
76c1b9
 
76c1b9
     # Symbols matching with the kernel get a "kernel" dependency
76c1b9
-    LC_ALL=C join -t $'\t' -j 1 $symvers <(mod_requires "${modules[@]}") | LC_ALL=C sort -u \
76c1b9
-    | awk '{ FS = "\t" ; OFS = "\t" } { print "kernel(" $1 ") = " $2 }'
76c1b9
+    mod_req=$(mktemp -t mod_req.XXXXX)
76c1b9
+    mod_requires "${modules[@]}" > "$mod_req"
76c1b9
+    LC_ALL=C join -t $'\t' -j 1 $symvers "$mod_req" | LC_ALL=C sort -u \
76c1b9
+    | awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print "kernel(" $1 ") = " $2 }'
76c1b9
 
76c1b9
     # Symbols from elsewhere get a "ksym" dependency
76c1b9
-    LC_ALL=C join -t $'\t' -j 1 -v 2 $symvers <(mod_requires "${modules[@]}") | LC_ALL=C sort -u \
76c1b9
-    | awk '{ FS = "\t" ; OFS = "\t" } { print "ksym(" $1 ") = " $2 }'
76c1b9
+    LC_ALL=C join -t $'\t' -j 1 -v 2 $symvers "$mod_req" | LC_ALL=C sort -u \
76c1b9
+    | awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print "ksym(" $1 ") = " $2 }'
76c1b9
 
76c1b9
     # Check kABI if the kabi-whitelists package is installed
76c1b9
     # Do this last so we can try to output this error at the end
76c1b9
-    kabi_check_symbols=($(LC_ALL=C join -t $'\t' -j 1 $symvers <(mod_requires "${modules[@]}") | LC_ALL=C sort -u \
76c1b9
-    | awk '{ FS = "\t" ; OFS = "\t" } { print $1 }'))
76c1b9
+    kabi_check_symbols=($(LC_ALL=C join -t $'\t' -j 1 $symvers "$mod_req" | LC_ALL=C sort -u \
76c1b9
+    | awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print $1 }'))
76c1b9
     check_kabi "${kabi_check_symbols[@]}"
76c1b9
 fi