All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCHv2] powerpc: comvert relocs_check to a shell script using grep
@ 2015-03-13  2:19 Stephen Rothwell
  2015-03-13 14:18 ` David Laight
  0 siblings, 1 reply; 3+ messages in thread
From: Stephen Rothwell @ 2015-03-13  2:19 UTC (permalink / raw)
  To: Michael Ellerman; +Cc: Paul Mackerras, linuxppc-dev

[-- Attachment #1: Type: text/plain, Size: 5052 bytes --]

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

Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
---

v2: address ShellCheck comments from Michael

 arch/powerpc/Makefile        |  4 +--
 arch/powerpc/relocs_check.pl | 66 --------------------------------------------
 arch/powerpc/relocs_check.sh | 59 +++++++++++++++++++++++++++++++++++++++
 3 files changed, 61 insertions(+), 68 deletions(-)
 delete mode 100755 arch/powerpc/relocs_check.pl
 create mode 100755 arch/powerpc/relocs_check.sh

diff --git a/arch/powerpc/Makefile b/arch/powerpc/Makefile
index 132d9c681d6a..1e868023b2c3 100644
--- a/arch/powerpc/Makefile
+++ b/arch/powerpc/Makefile
@@ -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
diff --git a/arch/powerpc/relocs_check.pl b/arch/powerpc/relocs_check.pl
deleted file mode 100755
index 3f46e8b9c56d..000000000000
--- a/arch/powerpc/relocs_check.pl
+++ /dev/null
@@ -1,66 +0,0 @@
-#!/usr/bin/perl
-
-# Copyright © 2009 IBM Corporation
-
-# This program is free software; you can redistribute it and/or
-# modify it under the terms of the GNU General Public License
-# as published by the Free Software Foundation; either version
-# 2 of the License, or (at your option) any later version.
-
-# This script checks the relocations of a vmlinux for "suspicious"
-# relocations.
-
-use strict;
-use warnings;
-
-if ($#ARGV != 1) {
-	die "$0 [path to objdump] [path to vmlinux]\n";
-}
-
-# 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 $_;
-
-	# Only look at relocation lines.
-	next if (!/\s+R_/);
-
-	# These relocations are okay
-	# On PPC64:
-	# 	R_PPC64_RELATIVE, R_PPC64_NONE, R_PPC64_ADDR64
-	# 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/);
-
-	# 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";
-}
diff --git a/arch/powerpc/relocs_check.sh b/arch/powerpc/relocs_check.sh
new file mode 100755
index 000000000000..182eae9cc40d
--- /dev/null
+++ b/arch/powerpc/relocs_check.sh
@@ -0,0 +1,59 @@
+#!/bin/sh
+
+# 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
+# as published by the Free Software Foundation; either version
+# 2 of the License, or (at your option) any later version.
+
+# This script checks the relocations of a vmlinux for "suspicious"
+# relocations.
+
+# based on relocs_check.pl
+# Copyright © 2009 IBM Corporation
+
+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.
+objdump="$1"
+vmlinux="$2"
+
+bad_relocs=$(
+"$objdump" -R "$vmlinux" |
+	# Only look at relocation lines.
+	grep -E '\<R_' |
+	# These relocations are okay
+	# On PPC64:
+	#	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
+	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 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
-- 
2.1.4

-- 
Cheers,
Stephen Rothwell                    sfr@canb.auug.org.au

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* RE: [PATCHv2] powerpc: comvert relocs_check to a shell script using grep
  2015-03-13  2:19 [PATCHv2] powerpc: comvert relocs_check to a shell script using grep Stephen Rothwell
@ 2015-03-13 14:18 ` David Laight
  2015-03-13 21:49   ` Stephen Rothwell
  0 siblings, 1 reply; 3+ messages in thread
From: David Laight @ 2015-03-13 14:18 UTC (permalink / raw)
  To: 'Stephen Rothwell', Michael Ellerman; +Cc: linuxppc-dev, Paul Mackerras

RnJvbTogU3RlcGhlbiBSb3Rod2VsbA0KPiBUaGlzIHJ1bnMgYSBiaXQgZmFzdGVyIGFuZCByZW1v
dmVzIGFub3RoZXIgdXNlIG9mIHBlcmwgZnJvbQ0KPiB0aGUga2VybmVsIGJ1aWxkLg0KLi4uDQo+
IGRpZmYgLS1naXQgYS9hcmNoL3Bvd2VycGMvcmVsb2NzX2NoZWNrLnNoIGIvYXJjaC9wb3dlcnBj
L3JlbG9jc19jaGVjay5zaA0KPiBuZXcgZmlsZSBtb2RlIDEwMDc1NQ0KPiBpbmRleCAwMDAwMDAw
MDAwMDAuLjE4MmVhZTljYzQwZA0KPiAtLS0gL2Rldi9udWxsDQo+ICsrKyBiL2FyY2gvcG93ZXJw
Yy9yZWxvY3NfY2hlY2suc2gNCj4gQEAgLTAsMCArMSw1OSBAQA0KPiArIyEvYmluL3NoDQouLi4N
Cj4gK2lmIFsgJHsjKn0gLWx0IDIgXTsgdGhlbg0KPiArCWVjaG8gIiQwIFtwYXRoIHRvIG9iamR1
bXBdIFtwYXRoIHRvIHZtbGludXhdIiAxPiYyDQo+ICsJZXhpdCAxDQo+ICtmaQ0KPiArDQo+ICsj
IEhhdmUgS2J1aWxkIHN1cHBseSB0aGUgcGF0aCB0byBvYmpkdW1wIHNvIHdlIGhhbmRsZSBjcm9z
cyBjb21waWxhdGlvbi4NCj4gK29iamR1bXA9IiQxIg0KPiArdm1saW51eD0iJDIiDQoNCkknbSBu
b3QgMTAwJSBzdXJlIG9mIHRoZSByZXF1aXJlbWVudHMgb24gL2Jpbi9zaCBmb3Iga2VybmVsIGJ1
aWxkcy4NCkJ1dCAkeyMqfSBpcyBwcm9iYWJseSBub3QgY29tcGxldGVseSBwb3J0YWJsZSAoYW5k
IG1heSBub3QgYmUgc2FmZQ0KaWYgdGhlcmUgYXJlIGVtYmVkZGVkIHNwYWNlcyBpbiB0aGUgYXJn
dW1lbnRzKS4NCg0KTWlnaHQgYmUgYmV0dGVyIHRvIGNoZWNrOg0KCWlmIFsgLXogIiRvYmpkdW1w
IiAtbyAteiAiJHZtbGludXgiIF0NCmluc3RlYWQuDQoNCk9yIGV2ZW46DQoJaWYgWyAhIC14ICIk
b2JqZHVtcCIgLW8gISAtciAiJHZtbGludXgiIF0NCg0KCURhdmlkDQoNCg==

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCHv2] powerpc: comvert relocs_check to a shell script using grep
  2015-03-13 14:18 ` David Laight
@ 2015-03-13 21:49   ` Stephen Rothwell
  0 siblings, 0 replies; 3+ messages in thread
From: Stephen Rothwell @ 2015-03-13 21:49 UTC (permalink / raw)
  To: David Laight; +Cc: Paul Mackerras, linuxppc-dev

[-- Attachment #1: Type: text/plain, Size: 1329 bytes --]

Hi David,

On Fri, 13 Mar 2015 14:18:10 +0000 David Laight <David.Laight@ACULAB.COM> wrote:
>
> From: Stephen Rothwell
> > This runs a bit faster and removes another use of perl from
> > the kernel build.
> ...
> > diff --git a/arch/powerpc/relocs_check.sh b/arch/powerpc/relocs_check.sh
> > new file mode 100755
> > index 000000000000..182eae9cc40d
> > --- /dev/null
> > +++ b/arch/powerpc/relocs_check.sh
> > @@ -0,0 +1,59 @@
> > +#!/bin/sh
> ...
> > +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.
> > +objdump="$1"
> > +vmlinux="$2"
> 
> I'm not 100% sure of the requirements on /bin/sh for kernel builds.
> But ${#*} is probably not completely portable (and may not be safe
> if there are embedded spaces in the arguments).

Oops, that is just wrong :-( ${#*} is undefined in Posix but is the
same as $# in bash.  It needs to be just $#.

> Might be better to check:
> 	if [ -z "$objdump" -o -z "$vmlinux" ]
> instead.
> 
> Or even:
> 	if [ ! -x "$objdump" -o ! -r "$vmlinux" ]

That last is a good idea as well.

I will do another version.

Thanks for catching that.
-- 
Cheers,
Stephen Rothwell                    sfr@canb.auug.org.au

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2015-03-13 21:49 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-03-13  2:19 [PATCHv2] powerpc: comvert relocs_check to a shell script using grep Stephen Rothwell
2015-03-13 14:18 ` David Laight
2015-03-13 21:49   ` Stephen Rothwell

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.