[Buildroot] [PATCH v2] lsof: bump to 4.83
Michael Roth
mroth at nessie.de
Tue Apr 20 10:58:28 UTC 2010
Bumped lsof to version 4.83 and converted this package
to the generic package infrastructure.
Signed-off-by: Michael Roth <mroth at nessie.de>
---
package/lsof/README | 18 +++++
package/lsof/lsof-makefile.patch | 5 +-
package/lsof/lsof-noportmap.patch | 4 +-
package/lsof/lsof-norpc.patch | 13 +++
package/lsof/lsof-remove-susvlegacy-funcs.patch | 7 +-
package/lsof/lsof-uclibc.patch | 12 ---
package/lsof/lsof.mk | 93 ++++++++++------------
7 files changed, 80 insertions(+), 72 deletions(-)
create mode 100644 package/lsof/README
create mode 100644 package/lsof/lsof-norpc.patch
delete mode 100644 package/lsof/lsof-uclibc.patch
diff --git a/package/lsof/README b/package/lsof/README
new file mode 100644
index 0000000..e5fd970
--- /dev/null
+++ b/package/lsof/README
@@ -0,0 +1,18 @@
+Notes for future version dumps
+==============================
+
+lsof has an unconventional directory structure. Because of that you
+have to fiddle with the paths in the header of the patch files on
+version dumps.
+
+For example, a patch file header may look like this:
+
+ --- lsof_4.83.orig/lsof_4.83_src/lib/Makefile.skel 2001-02-13 03:12:22.000000000 +0100
+ +++ lsof_4.83/lsof_4.83_src/lib/Makefile.skel 2006-11-29 13:51:44.000000000 +0100
+
+To change to version 9.99 four occurrences of the old version number
+should be changed to the new one irrespective of the fact that
+strictly speaking only the lsof_X.XX_src parts have to be changed:
+
+ --- lsof_9.99.orig/lsof_9.99_src/lib/Makefile.skel 2001-02-13 03:12:22.000000000 +0100
+ +++ lsof_9.99/lsof_9.99_src/lib/Makefile.skel 2006-11-29 13:51:44.000000000 +0100
diff --git a/package/lsof/lsof-makefile.patch b/package/lsof/lsof-makefile.patch
index 2d4e9d4..091f0b7 100644
--- a/package/lsof/lsof-makefile.patch
+++ b/package/lsof/lsof-makefile.patch
@@ -1,6 +1,5 @@
-diff -ru lsof_4.81.orig/lsof_4.81_src/lib/Makefile.skel lsof_4.81/lsof_4.81_src/lib/Makefile.skel
---- lsof_4.81.orig/lsof_4.81_src/lib/Makefile.skel 2001-02-13 03:12:22.000000000 +0100
-+++ lsof_4.81/lsof_4.81_src/lib/Makefile.skel 2006-11-29 13:51:44.000000000 +0100
+--- lsof_4.83.orig/lsof_4.83_src/lib/Makefile.skel 2001-02-13 03:12:22.000000000 +0100
++++ lsof_4.83/lsof_4.83_src/lib/Makefile.skel 2006-11-29 13:51:44.000000000 +0100
@@ -21,8 +21,8 @@
all: ${LIB}
diff --git a/package/lsof/lsof-noportmap.patch b/package/lsof/lsof-noportmap.patch
index 4a37db4..9194d7b 100644
--- a/package/lsof/lsof-noportmap.patch
+++ b/package/lsof/lsof-noportmap.patch
@@ -1,5 +1,5 @@
---- lsof_4.81/lsof_4.81_src/print.orig.c 2006-08-23 13:37:43.000000000 -0600
-+++ lsof_4.81/lsof_4.81_src/print.c 2006-08-23 13:38:29.000000000 -0600
+--- lsof_4.83.orig/lsof_4.83_src/print.c 2006-08-23 13:37:43.000000000 -0600
++++ lsof_4.83/lsof_4.83_src/print.c 2006-08-23 13:38:29.000000000 -0600
@@ -148,6 +148,7 @@
static void
fill_portmap()
diff --git a/package/lsof/lsof-norpc.patch b/package/lsof/lsof-norpc.patch
new file mode 100644
index 0000000..f63e367
--- /dev/null
+++ b/package/lsof/lsof-norpc.patch
@@ -0,0 +1,13 @@
+--- lsof_4.83.orig/lsof_4.83_src/dialects/linux/dlsof.h 2010-04-19 13:31:48.247395489 +0200
++++ lsof_4.83/lsof_4.83_src/dialects/linux/dlsof.h 2010-04-19 13:32:07.512099998 +0200
+@@ -56,8 +56,10 @@
+ #include <linux/tcp.h>
+ # endif /* defined(GLIBCV) || defined(__UCLIBC__) */
+
++#if !defined __UCLIBC__ || (defined __UCLIBC__ && defined __UCLIBC_HAS_RPC__)
+ #include <rpc/rpc.h>
+ #include <rpc/pmap_prot.h>
++#endif
+
+ #if defined(HASSELINUX)
+ #include <selinux/selinux.h>
diff --git a/package/lsof/lsof-remove-susvlegacy-funcs.patch b/package/lsof/lsof-remove-susvlegacy-funcs.patch
index d1d9371..cf8730f 100644
--- a/package/lsof/lsof-remove-susvlegacy-funcs.patch
+++ b/package/lsof/lsof-remove-susvlegacy-funcs.patch
@@ -1,7 +1,6 @@
-diff -rdup lsof_4.81.orig/lsof_4.81_src/dialects/linux/machine.h lsof_4.81/lsof_4.81_src/dialects/linux/machine.h
---- lsof_4.81.orig/lsof_4.81_src/dialects/linux/machine.h 2007-04-24 18:20:58.000000000 +0200
-+++ lsof_4.81/lsof_4.81_src/dialects/linux/machine.h 2007-05-15 12:17:03.000000000 +0200
-@@ -616,6 +616,6 @@
+--- lsof_4.83.orig/lsof_4.83_src/dialects/linux/machine.h 2007-04-24 18:20:58.000000000 +0200
++++ lsof_4.83/lsof_4.83_src/dialects/linux/machine.h 2007-05-15 12:17:03.000000000 +0200
+@@ -625,6 +625,6 @@
* zeromem is a macro that uses bzero or memset.
*/
diff --git a/package/lsof/lsof-uclibc.patch b/package/lsof/lsof-uclibc.patch
deleted file mode 100644
index 797a0ce..0000000
--- a/package/lsof/lsof-uclibc.patch
+++ /dev/null
@@ -1,12 +0,0 @@
-diff -ru lsof_4.81.orig/lsof_4.81_src/dialects/linux/dlsof.h lsof_4.81/lsof_4.81_src/dialects/linux/dlsof.h
---- lsof_4.81.orig/lsof_4.81_src/dialects/linux/dlsof.h 2006-03-28 00:57:14.000000000 +0200
-+++ lsof_4.81/lsof_4.81_src/dialects/linux/dlsof.h 2006-11-29 14:03:07.000000000 +0100
-@@ -49,7 +49,7 @@
- #include <unistd.h>
- #include <netinet/in.h>
-
--# if defined(GLIBCV)
-+# if defined(GLIBCV) || defined __UCLIBC__
- #include <netinet/tcp.h>
- # else /* !defined(GLIBCV) */
- #include <linux/tcp.h>
diff --git a/package/lsof/lsof.mk b/package/lsof/lsof.mk
index 8deff15..b8618fe 100644
--- a/package/lsof/lsof.mk
+++ b/package/lsof/lsof.mk
@@ -3,68 +3,59 @@
# lsof
#
#############################################################
-LSOF_VERSION:=4.81
+LSOF_VERSION:=4.83
LSOF_SOURCE:=lsof_$(LSOF_VERSION).tar.bz2
LSOF_SITE:=ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/
-LSOF_CAT:=$(BZCAT)
-LSOF_DIR:=$(BUILD_DIR)/lsof_$(LSOF_VERSION)
-LSOF_BINARY:=lsof
-LSOF_TARGET_BINARY:=bin/lsof
-LSOF_INCLUDE:=$(STAGING_DIR)/usr/include
-BR2_LSOF_CFLAGS:=
-ifeq ($(BR2_LARGEFILE),)
-BR2_LSOF_CFLAGS+=-U_FILE_OFFSET_BITS
-endif
-ifeq ($(BR2_INET_IPV6),)
-BR2_LSOF_CFLAGS+=-UHASIPv6
-endif
+LSOF_SRC_TAR:=lsof_$(LSOF_VERSION)_src.tar
+LSOF_SRC_DIR:=lsof_$(LSOF_VERSION)_src
+LSOF_BINARY:=$(LSOF_SRC_DIR)/lsof
+LSOF_TARGET_BINARY:=$(TARGET_DIR)/bin/lsof
+LSOF_INCLUDE:=$(STAGING_DIR)/usr/include
-$(DL_DIR)/$(LSOF_SOURCE):
- $(call DOWNLOAD,$(LSOF_SITE),$(LSOF_SOURCE))
+LSOF_CFLAGS_n := # empty
+LSOF_CFLAGS_n$(BR2_LARGEFILE) += -U_FILE_OFFSET_BITS
+LSOF_CFLAGS_n$(BR2_INET_IPV6) += -UHASIPv6
+LSOF_CFLAGS := $(LSOF_CFLAGS_n)
-lsof-source: $(DL_DIR)/$(LSOF_SOURCE)
+LSOF_POST_EXTRACT_HOOKS := LSOF_EXTRACT_SOURCE_CMDS
-lsof-unpacked: $(LSOF_DIR)/.unpacked
+LSOF_POST_CONFIGURE_HOOKS_n := # empty
+LSOF_POST_CONFIGURE_HOOKS_n$(BR2_USE_WCHAR) += LSOF_CONFIGURE_NO_WCHAR_CMDS
+LSOF_POST_CONFIGURE_HOOKS_n$(BR2_ENABLE_LOCALE) += LSOF_CONFIGURE_NO_LOCALE_CMDS
+LSOF_POST_CONFIGURE_HOOKS := $(LSOF_POST_CONFIGURE_HOOKS_n)
-$(LSOF_DIR)/.unpacked: $(DL_DIR)/$(LSOF_SOURCE)
- $(LSOF_CAT) $(DL_DIR)/$(LSOF_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
- (cd $(LSOF_DIR);tar xf lsof_$(LSOF_VERSION)_src.tar;rm -f lsof_$(LSOF_VERSION)_src.tar)
- toolchain/patch-kernel.sh $(LSOF_DIR) package/lsof/ \*.patch
- touch $(LSOF_DIR)/.unpacked
+define LSOF_EXTRACT_SOURCE_CMDS
+ (cd $(@D); tar xf $(LSOF_SRC_TAR); rm -f $(LSOF_SRC_TAR))
+endef
-$(LSOF_DIR)/.configured: $(LSOF_DIR)/.unpacked
- (cd $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src; echo n | $(TARGET_CONFIGURE_OPTS) DEBUG="$(TARGET_CFLAGS) $(BR2_LSOF_CFLAGS)" LSOF_INCLUDE="$(LSOF_INCLUDE)" ./Configure linux)
- touch $(LSOF_DIR)/.configured
+define LSOF_CONFIGURE_CMDS
+ (cd $(@D)/$(LSOF_SRC_DIR); \
+ $(TARGET_CONFIGURE_OPTS) \
+ DEBUG="$(TARGET_CFLAGS) $(LSOF_CFLAGS)" \
+ LSOF_INCLUDE="$(LSOF_INCLUDE)" \
+ ./Configure -n linux)
+endef
-$(LSOF_DIR)/lsof_$(LSOF_VERSION)_src/$(LSOF_BINARY): $(LSOF_DIR)/.configured
-ifeq ($(BR2_USE_WCHAR),)
- $(SED) 's,^#define[[:space:]]*HASWIDECHAR.*,#undef HASWIDECHAR,' $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src/machine.h
- $(SED) 's,^#define[[:space:]]*WIDECHARINCL.*,,' $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src/machine.h
-endif
-ifeq ($(BR2_ENABLE_LOCALE),)
- $(SED) 's,^#define[[:space:]]*HASSETLOCALE.*,#undef HASSETLOCALE,' $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src/machine.h
-endif
- $(MAKE) $(TARGET_CONFIGURE_OPTS) DEBUG="$(TARGET_CFLAGS) $(BR2_LSOF_CFLAGS)" -C $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src
+define LSOF_CONFIGURE_NO_WCHAR_CMDS
+ $(SED) 's,^#define[[:space:]]*HASWIDECHAR.*,#undef HASWIDECHAR,' $(@D)/$(LSOF_SRC_DIR)/machine.h
+endef
-$(TARGET_DIR)/$(LSOF_TARGET_BINARY): $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src/$(LSOF_BINARY)
- cp $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src/$(LSOF_BINARY) $@
- $(STRIPCMD) $@
+define LSOF_CONFIGURE_NO_LOCALE_CMDS
+ $(SED) 's,^#define[[:space:]]*HASSETLOCALE.*,#undef HASSETLOCALE,' $(@D)/$(LSOF_SRC_DIR)/machine.h
+endef
-lsof: $(TARGET_DIR)/$(LSOF_TARGET_BINARY)
+define LSOF_BUILD_CMDS
+ $(MAKE) $(TARGET_CONFIGURE_OPTS) DEBUG="$(TARGET_CFLAGS) $(LSOF_CFLAGS)" -C $(@D)/$(LSOF_SRC_DIR)
+endef
-lsof-clean:
- -rm -f $(TARGET_DIR)/$(LSOF_TARGET_BINARY)
- -$(MAKE) -C $(LSOF_DIR)/lsof_$(LSOF_VERSION)_src clean
+define LSOF_INSTALL_TARGET_CMDS
+ cp -f $(@D)/$(LSOF_BINARY) $(LSOF_TARGET_BINARY)
+ $(STRIPCMD) $(STRIP_STRIP_UNNEEDED) $(LSOF_TARGET_BINARY)
+endef
-lsof-dirclean:
- rm -rf $(LSOF_DIR)
+define LSOF_UNINSTALL_TARGET_CMDS
+ -rm -f $(LSOF_TARGET_BINARY)
+endef
-#############################################################
-#
-# Toplevel Makefile options
-#
-#############################################################
-ifeq ($(BR2_PACKAGE_LSOF),y)
-TARGETS+=lsof
-endif
+$(eval $(call GENTARGETS,package,lsof))
--
1.6.4.4
More information about the buildroot
mailing list