Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a71aa05e authored by Stephen Rothwell's avatar Stephen Rothwell Committed by Michael Ellerman
Browse files

powerpc: Convert relocs_check to a shell script using grep



This runs a bit faster and removes another use of perl from
the kernel build.

Signed-off-by: default avatarStephen Rothwell <sfr@canb.auug.org.au>
Acked-By: default avatarTony Breeds <tony@bakeyournoodle.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent e4a9616c
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -248,10 +248,10 @@ boot := arch/$(ARCH)/boot

ifeq ($(CONFIG_RELOCATABLE),y)
quiet_cmd_relocs_check = CALL    $<
      cmd_relocs_check = perl $< "$(OBJDUMP)" "$(obj)/vmlinux"
      cmd_relocs_check = $(CONFIG_SHELL) $< "$(OBJDUMP)" "$(obj)/vmlinux"

PHONY += relocs_check
relocs_check: arch/powerpc/relocs_check.pl vmlinux
relocs_check: arch/powerpc/relocs_check.sh vmlinux
	$(call cmd,relocs_check)

zImage: relocs_check
+59 −0
Original line number Diff line number Diff line
#!/usr/bin/perl
#!/bin/sh

# Copyright © 2009 IBM Corporation
# Copyright © 2015 IBM Corporation

# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
@@ -10,57 +10,50 @@
# This script checks the relocations of a vmlinux for "suspicious"
# relocations.

use strict;
use warnings;
# based on relocs_check.pl
# Copyright © 2009 IBM Corporation

if ($#ARGV != 1) {
	die "$0 [path to objdump] [path to vmlinux]\n";
}
if [ $# -lt 2 ]; then
	echo "$0 [path to objdump] [path to vmlinux]" 1>&2
	exit 1
fi

# Have Kbuild supply the path to objdump so we handle cross compilation.
my $objdump = shift;
my $vmlinux = shift;
my $bad_relocs_count = 0;
my $bad_relocs = "";
my $old_binutils = 0;

open(FD, "$objdump -R $vmlinux|") or die;
while (<FD>) {
	study $_;
objdump="$1"
vmlinux="$2"

bad_relocs=$(
"$objdump" -R "$vmlinux" |
	# Only look at relocation lines.
	next if (!/\s+R_/);

	grep -E '\<R_' |
	# These relocations are okay
	# On PPC64:
	# 	R_PPC64_RELATIVE, R_PPC64_NONE, R_PPC64_ADDR64
	#	R_PPC64_RELATIVE, R_PPC64_NONE
	#	R_PPC64_ADDR64 mach_<name>
	# On PPC:
	#	R_PPC_RELATIVE, R_PPC_ADDR16_HI,
	#	R_PPC_ADDR16_HA,R_PPC_ADDR16_LO,
	#	R_PPC_NONE

	next if (/\bR_PPC64_RELATIVE\b/ or /\bR_PPC64_NONE\b/ or
	         /\bR_PPC64_ADDR64\s+mach_/);
	next if (/\bR_PPC_ADDR16_LO\b/ or /\bR_PPC_ADDR16_HI\b/ or
		 /\bR_PPC_ADDR16_HA\b/ or /\bR_PPC_RELATIVE\b/ or
		 /\bR_PPC_NONE\b/);
	grep -F -w -v 'R_PPC64_RELATIVE
R_PPC64_NONE
R_PPC_ADDR16_LO
R_PPC_ADDR16_HI
R_PPC_ADDR16_HA
R_PPC_RELATIVE
R_PPC_NONE' |
	grep -E -v '\<R_PPC64_ADDR64[[:space:]]+mach_'
)

if [ -z "$bad_relocs" ]; then
	exit 0
fi

num_bad=$(echo "$bad_relocs" | wc -l)
echo "WARNING: $num_bad bad relocations"
echo "$bad_relocs"

# If we see this type of relocation it's an idication that
# we /may/ be using an old version of binutils.
	if (/R_PPC64_UADDR64/) {
		$old_binutils++;
	}

	$bad_relocs_count++;
	$bad_relocs .= $_;
}

if ($bad_relocs_count) {
	print "WARNING: $bad_relocs_count bad relocations\n";
	print $bad_relocs;
}

if ($old_binutils) {
	print "WARNING: You need at least binutils >= 2.19 to build a ".
	      "CONFIG_RELOCATABLE kernel\n";
}
if echo "$bad_relocs" | grep -q -F -w R_PPC64_UADDR64; then
	echo "WARNING: You need at least binutils >= 2.19 to build a CONFIG_RELOCATABLE kernel"
fi