Commit ed6bdad8 authored by Peter Korsgaard's avatar Peter Korsgaard
Browse files

vsftpd: convert to gentargets, bump version and fix build



vsftpd didn't build, and wasn't using the gentargets infrastructure.

Signed-off-by: default avatarPeter Korsgaard <jacmet@sunsite.dk>
parent a0b6710b
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -33,7 +33,7 @@
	pcre, php, prboom, radvd, qt, samba, sdl_mixer, sdl_sound,
	shared-mime-info, speex, sqlite, squashfs, strace, taglib,
	tcpdump, thttpd, tiff, tn5250, udev, udpcast, usbmount,
	usbutils, which, xlib_libX11, zlib
	usbutils, vsftpd, which, xlib_libX11, zlib

	Deprecated packages: hotplug, lzma

+0 −15
Original line number Diff line number Diff line
--- vsftpd-2.0.5/sysdeputil.c.orig	2008-10-06 15:24:42.000000000 -0600
+++ vsftpd-2.0.5/sysdeputil.c	2008-10-06 15:35:35.000000000 -0600
@@ -159,7 +159,12 @@
 #include <linux/capability.h>
 #include <errno.h>
 #include <syscall.h>
+/* try to handle kernel header versions correctly (2.4 and >= 2.6.18) */
+#ifndef capset
+#define capset(head,data) syscall(__NR_capset,head,data)
+#else
 _syscall2(int, capset, cap_user_header_t, header, const cap_user_data_t, data)
+#endif /* capset */
 /* Gross HACK to avoid warnings - linux headers overlap glibc headers */
 #undef __NFDBITS
 #undef __FDMASK
+0 −19
Original line number Diff line number Diff line
diff -rdup vsftpd-2.0.5.orig/sysutil.c vsftpd-2.0.5/sysutil.c
--- vsftpd-2.0.5.orig/sysutil.c	2006-07-03 18:26:40.000000000 +0200
+++ vsftpd-2.0.5/sysutil.c	2006-12-14 15:13:15.000000000 +0100
@@ -16,11 +16,15 @@
 #include "utility.h"
 #include "tunables.h"
 
+#include <features.h>
+
+#if !defined __UCLIBC__ || (defined __UCLIBC__ && defined __UCLIBC_HAS_LFS__)
 /* Activate 64-bit file support on Linux/32bit plus others */
 #define _FILE_OFFSET_BITS 64
 #define _LARGEFILE_SOURCE 1
 #define _LARGEFILE64_SOURCE 1
 #define _LARGE_FILES 1
+#endif
 
 /* For Linux, this adds nothing :-) */
 #include "port/porting_junk.h"
+27 −0
Original line number Diff line number Diff line
[PATCH] vsftpd: don't enforce largefile support

In Buildroot we enable/disable largefile support globally, and pass the
correct defines in CFLAGS, so don't enforce it unconditionally.

Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
---
 sysutil.c |    6 ------
 1 file changed, 6 deletions(-)

Index: vsftpd-2.3.2/sysutil.c
===================================================================
--- vsftpd-2.3.2.orig/sysutil.c
+++ vsftpd-2.3.2/sysutil.c
@@ -17,12 +17,6 @@
 #include "tunables.h"
 #include "sysdeputil.h"
 
-/* Activate 64-bit file support on Linux/32bit plus others */
-#define _FILE_OFFSET_BITS 64
-#define _LARGEFILE_SOURCE 1
-#define _LARGEFILE64_SOURCE 1
-#define _LARGE_FILES 1
-
 /* For Linux, this adds nothing :-) */
 #include "port/porting_junk.h"
 
+38 −65
Original line number Diff line number Diff line
@@ -3,74 +3,47 @@
# vsftpd
#
#############################################################
VSFTPD_VERSION:=2.0.7
VSFTPD_SOURCE:=vsftpd-$(VSFTPD_VERSION).tar.gz
VSFTPD_SITE:=ftp://vsftpd.beasts.org/users/cevans
VSFTPD_DIR:=$(BUILD_DIR)/vsftpd-$(VSFTPD_VERSION)
VSFTPD_CAT:=$(ZCAT)
VSFTPD_BINARY:=vsftpd
VSFTPD_TARGET_BINARY:=usr/sbin/vsftpd
VSFTPD_VERSION = 2.3.2
VSFTPD_SOURCE = vsftpd-$(VSFTPD_VERSION).tar.gz
VSFTPD_SITE = ftp://vsftpd.beasts.org/users/cevans

ifeq ($(BR2_PACKAGE_OPENSSL),y)
VSFTPD_LIBS:=-lcrypt -lssl
else
VSFTPD_LIBS:=-lcrypt
endif

$(DL_DIR)/$(VSFTPD_SOURCE):
	 $(call DOWNLOAD,$(VSFTPD_SITE),$(VSFTPD_SOURCE))
VSFTPD_LIBS = -lcrypt

vsftpd-source: $(DL_DIR)/$(VSFTPD_SOURCE)
define VSFTPD_ENABLE_SSL
	$(SED) 's/.*VSF_BUILD_SSL/#define VSF_BUILD_SSL/' $(@D)/builddefs.h
endef

$(VSFTPD_DIR)/.unpacked: $(DL_DIR)/$(VSFTPD_SOURCE)
	$(VSFTPD_CAT) $(DL_DIR)/$(VSFTPD_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
	toolchain/patch-kernel.sh $(VSFTPD_DIR) package/vsftpd/ vsftpd\*.patch
	touch $@

$(VSFTPD_DIR)/.configured: $(VSFTPD_DIR)/.unpacked
ifeq ($(BR2_PACKAGE_OPENSSL),y)
	$(SED) 's,#undef[[:space:]]*VSF_BUILD_SSL.*,#define VSF_BUILD_SSL,g' $(VSFTPD_DIR)/builddefs.h
else
	$(SED) 's,#define[[:space:]]*VSF_BUILD_SSL.*,#undef VSF_BUILD_SSL,g' $(VSFTPD_DIR)/builddefs.h
endif
ifneq ($(findstring uclibc,$(BR2_GNU_TARGET_SUFFIX)),)
	$(SED) 's,#define[[:space:]]*VSF_BUILDDEFS_H.*,#define VSF_BUILDDEFS_H\n#define __UCLIBC__,g' $(VSFTPD_DIR)/builddefs.h
	$(SED) 's,.*__UCLIBC_HAS_LFS__.*,,g' $(VSFTPD_DIR)/builddefs.h
ifeq ($(BR2_LARGEFILE),y)
	$(SED) 's,#define[[:space:]]*VSF_BUILDDEFS_H.*,#define VSF_BUILDDEFS_H\n#define __UCLIBC_HAS_LFS__,g' $(VSFTPD_DIR)/builddefs.h
VSFTPD_DEPENDENCIES += openssl
VSFTPD_LIBS += -lssl
VSFTPD_POST_CONFIGURE_HOOKS += VSFTPD_ENABLE_SSL
endif
else # not uclibc
	$(SED) 's,.*__UCLIBC_.*,,g' $(VSFTPD_DIR)/builddefs.h
endif
	touch $@


$(VSFTPD_DIR)/$(VSFTPD_BINARY): $(VSFTPD_DIR)/.configured
	$(MAKE) CC="$(TARGET_CC)" CFLAGS="$(TARGET_CFLAGS)" LIBS="$(VSFTPD_LIBS)" -C $(VSFTPD_DIR)
	touch -c $@

$(TARGET_DIR)/$(VSFTPD_TARGET_BINARY): $(VSFTPD_DIR)/$(VSFTPD_BINARY)
	cp -dpf $< $@
	$(INSTALL) -D -m 0755 package/vsftpd/vsftpd-init $(TARGET_DIR)/etc/init.d/S70vsftpd

ifeq ($(BR2_PACKAGE_OPENSSL),y)
vsftpd: openssl $(TARGET_DIR)/$(VSFTPD_TARGET_BINARY)
else
vsftpd: $(TARGET_DIR)/$(VSFTPD_TARGET_BINARY)
endif

vsftpd-clean:
	-$(MAKE) -C $(VSFTPD_DIR) clean
	rm -f $(TARGET_DIR)/$(VSFTPD_TARGET_BINARY)

vsftpd-dirclean:
	rm -rf $(VSFTPD_DIR)

#############################################################
#
# Toplevel Makefile options
#
#############################################################
ifeq ($(BR2_PACKAGE_VSFTPD),y)
TARGETS+=vsftpd
endif
define VSFTPD_BUILD_CMDS
	$(MAKE) CC="$(TARGET_CC)" CFLAGS="$(TARGET_CFLAGS)" \
		LDFLAGS="$(TARGET_LDFLAGS)" LIBS="$(VSFTPD_LIBS)" -C $(@D)
endef

define VSFTPD_INSTALL_TARGET_CMDS
	install -D -m 755 $(@D)/vsftpd $(TARGET_DIR)/usr/sbin/vsftpd
	install -D -m 644 $(@D)/vsftpd.8 \
		$(TARGET_DIR)/usr/share/man/man8/vsftpd.8
	install -D -m 644 $(@D)/vsftpd.conf.5 \
		$(TARGET_DIR)/usr/share/man/man5/vsftpd.conf.5
	test -f $(TARGET_DIR)/etc/init.d/S70vsftpd || \
		$(INSTALL) -D -m 755 package/vsftpd/vsftpd-init \
			$(TARGET_DIR)/etc/init.d/S70vsftpd
endef

define VSFTPD_UNINSTALL_TARGET_CMDS
	rm -f $(TARGET_DIR)/usr/sbin/vsftpd
	rm -f $(TARGET_DIR)/usr/share/man/man8/vsftpd.8
	rm -f $(TARGET_DIR)/usr/share/man/man5/vsftpd.conf.5
	rm -f $(TARGET_DIR)/etc/init.d/S70vsftpd
endef

define VSFTPD_CLEAN_CMDS
	-$(MAKE) -C $(@D) clean
endef

$(eval $(call GENTARGETS,package,vsftpd))