[PATCH 2/3]: Remove perl from make headers_install

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Rob Landley <rob@xxxxxxxxxxx>
Remove perl from make headers_install by replacing a perl script (doinga simple regex search and replace) with a smaller and faster shell scriptimplementation.  The new shell script is a single for loop calling sed andpiping its output through unifdef to produce the target file.
Sam Ravnborg added this perl to 2.6.27.
Signed-off-by: Rob Landley <rob@xxxxxxxxxxx>---
 scripts/Makefile.headersinst |    6 ++-- scripts/headers_install.pl   |   46 --------------------------------- scripts/headers_install.sh   |   23 ++++++++++++++++ 3 files changed, 26 insertions(+), 49 deletions(-)
--- /dev/null	2008-11-21 04:46:41.000000000 -0600+++ b/scripts/headers_install.sh	2008-12-15 22:09:45.000000000 -0600@@ -0,0 +1,23 @@+#!/bin/bash++# Grab arguments++INDIR="$1"+shift+OUTDIR="$1"+shift+ARCH="$1"+shift++# Iterate through files listed on command line++for i in "$@"+do+	sed -r \+		-e 's/([ \t(])(__user|__force|__iomem)[ \t]/\1/g' \+		-e 's/__attribute_const__([ \t]|$)/\1/g' \+		-e 's@^#include <linux/compiler.h>@@' "$INDIR/$i" |+	scripts/unifdef -U__KERNEL__ - > "$OUTDIR/$i"+done++exit 0diff -r d9b501c91442 scripts/Makefile.headersinst--- a/scripts/Makefile.headersinst	Sun Dec 14 16:25:19 2008 -0800+++ b/scripts/Makefile.headersinst	Mon Dec 15 23:30:15 2008 -0600@@ -44,8 +44,8 @@ quiet_cmd_install = INSTALL $(printdir) ($(words $(all-files))\                             file$(if $(word 2, $(all-files)),s))       cmd_install = \-        $(PERL) $< $(srctree)/$(obj) $(install) $(SRCARCH) $(header-y); \-        $(PERL) $< $(objtree)/$(obj) $(install) $(SRCARCH) $(objhdr-y); \+		$(CONFIG_SHELL) $< $(srctree)/$(obj) $(install) $(SRCARCH) $(header-y); \+		$(CONFIG_SHELL) $< $(objtree)/$(obj) $(install) $(SRCARCH) $(objhdr-y); \         touch $@  quiet_cmd_remove = REMOVE  $(unwanted)@@ -64,7 +64,7 @@ 	@:  targets += $(install-file)-$(install-file): scripts/headers_install.pl $(input-files) FORCE+$(install-file): scripts/headers_install.sh $(input-files) FORCE 	$(if $(unwanted),$(call cmd,remove),) 	$(if $(wildcard $(dir $@)),,$(shell mkdir -p $(dir $@))) 	$(call if_changed,install)--- hg/scripts/headers_install.pl	2008-11-22 19:09:21.000000000 -0600+++ /dev/null	1970-01-01 00:00:00 -0600@@ -1,46 +0,0 @@-#!/usr/bin/perl -w-#-# headers_install prepare the listed header files for use in-# user space and copy the files to their destination.-#-# Usage: headers_install.pl readdir installdir arch [files...]-# readdir:    dir to open files-# installdir: dir to install the files-# arch:       current architecture-#             arch is used to force a reinstallation when the arch-#             changes because kbuild then detect a command line change.-# files:      list of files to check-#-# Step in preparation for users space:-# 1) Drop all use of compiler.h definitions-# 2) Drop include of compiler.h-# 3) Drop all sections defined out by __KERNEL__ (using unifdef)--use strict;--my ($readdir, $installdir, $arch, @files) = @ARGV;--my $unifdef = "scripts/unifdef -U__KERNEL__";--foreach my $file (@files) {-	local *INFILE;-	local *OUTFILE;-	my $tmpfile = "$installdir/$file.tmp";-	open(INFILE, "<$readdir/$file")-		or die "$readdir/$file: $!\n";-	open(OUTFILE, ">$tmpfile") or die "$tmpfile: $!\n";-	while (my $line = <INFILE>) {-		$line =~ s/([\s(])__user\s/$1/g;-		$line =~ s/([\s(])__force\s/$1/g;-		$line =~ s/([\s(])__iomem\s/$1/g;-		$line =~ s/\s__attribute_const__\s/ /g;-		$line =~ s/\s__attribute_const__$//g;-		$line =~ s/^#include <linux\/compiler.h>//;-		printf OUTFILE "%s", $line;-	}-	close OUTFILE;-	close INFILE;-	system $unifdef . " $tmpfile > $installdir/$file";-	unlink $tmpfile;-}-exit 0;ÿôèº{.nÇ+?·?®?­?+%?Ëÿ±éݶ¥?wÿº{.nÇ+?·¥?{±ýé?y×^wø§¶?¡Ü¨}©?²Æ zÚ&j:+v?¨þø¯ù®w¥þ?à2?Þ?¨è­Ú&¢)ß¡«a¶Úÿÿûàz¿äz¹Þ?ú+?ù???Ý¢jÿ?wèþf


[Index of Archives]     [Gstreamer Embedded]     [Linux MMC Devel]     [U-Boot V2]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux ARM Kernel]     [Linux OMAP]     [Linux SCSI]

  Powered by Linux