From d8bcc8f168b124671ca9315a1743534a0ca0bae8 Mon Sep 17 00:00:00 2001 From: "\"Steven J. Hill\"" Date: Sun, 14 Jan 2007 06:13:27 +0000 Subject: Add Samba to buildroot. --- package/samba/samba.mk | 119 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 119 insertions(+) create mode 100644 package/samba/samba.mk (limited to 'package/samba/samba.mk') diff --git a/package/samba/samba.mk b/package/samba/samba.mk new file mode 100644 index 000000000..b084b66b0 --- /dev/null +++ b/package/samba/samba.mk @@ -0,0 +1,119 @@ +############################################################# +# +# samba +# +############################################################# +SAMBA_VER:=3.0.23d +SAMBA_SOURCE:=samba-$(SAMBA_VER).tar.gz +SAMBA_SITE:=ftp://us1.samba.org/pub/samba/ +SAMBA_DIR:=$(BUILD_DIR)/samba-$(SAMBA_VER)/source +SAMBA_CAT:=$(ZCAT) +SAMBA_BINARY:=bin/smbd +SAMBA_TARGET_BINARY:=usr/sbin/smbd + +$(DL_DIR)/$(SAMBA_SOURCE): + $(WGET) -P $(DL_DIR) $(SAMBA_SITE)/$(SAMBA_SOURCE) + +$(SAMBA_DIR)/.unpacked: $(DL_DIR)/$(SAMBA_SOURCE) + $(SAMBA_CAT) $(DL_DIR)/$(SAMBA_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + toolchain/patch-kernel.sh `dirname $(SAMBA_DIR)` package/samba/ samba\*.patch + touch $(SAMBA_DIR)/.unpacked + +$(SAMBA_DIR)/.configured: $(SAMBA_DIR)/.unpacked + (cd $(SAMBA_DIR); rm -rf config.cache; \ + ./autogen.sh; \ + $(TARGET_CONFIGURE_OPTS) CC_FOR_BUILD="$(HOSTCC)" \ + CFLAGS="$(TARGET_CFLAGS)" \ + samba_cv_HAVE_GETTIMEOFDAY_TZ=yes \ + samba_cv_USE_SETREUID=yes \ + ./configure \ + --target=$(GNU_TARGET_NAME) \ + --host=$(GNU_TARGET_NAME) \ + --build=$(GNU_HOST_NAME) \ + --with-lockdir=/var/cache/samba \ + --with-piddir=/var/run \ + --with-privatedir=/etc/samba \ + --with-logfilebase=/var/log/samba \ + --with-configdir=/etc/samba \ + --without-ldap \ + --with-included-popt \ + --with-included-iniparser \ + --disable-cups \ + --disable-static \ + ); + touch $(SAMBA_DIR)/.configured + +$(SAMBA_DIR)/$(SAMBA_BINARY): $(SAMBA_DIR)/.configured + $(TARGET_CONFIGURE_OPTS) $(MAKE) CC=$(TARGET_CC) -C $(SAMBA_DIR) + +SAMBA_TARGETS_ := +SAMBA_TARGETS_y := + +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_CIFS) += usr/sbin/mount.cifs \ + usr/sbin/umount.cifs +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_EVENTLOGADM) += usr/bin/eventlogadm +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_NET) += usr/bin/net +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_NMBD) += usr/sbin/nmbd +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_NMBLOOKUP) += usr/bin/nmblookup +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_NTLM_AUTH) += usr/bin/ntlm_auth +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_PDBEDIT) += usr/bin/pdbedit +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_PROFILES) += usr/bin/profiles +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_RPCCLIENT) += usr/bin/rpcclient +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBCACLS) += usr/bin/smbcacls +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBCLIENT) += usr/bin/smbclient +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBCONTROL) += usr/bin/smbcontrol +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBCQUOTAS) += usr/bin/smbcquotas +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBGET) += usr/bin/smbget +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBPASSWD) += usr/bin/smbpasswd +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBSPOOL) += usr/bin/smbspool +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBSTATUS) += usr/bin/smbstatus +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SMBTREE) += usr/bin/smbtree +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_SWAT) += usr/sbin/swat +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_TDB) += usr/bin/tdbbackup \ + usr/bin/tdbdump \ + usr/bin/tdbtool +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_TESTPARM) += usr/bin/testparm +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_WINBINDD) += usr/sbin/winbindd +SAMBA_TARGETS_$(BR2_PACKAGE_SAMBA_WBINFO) += usr/bin/wbinfo + +$(TARGET_DIR)/$(SAMBA_TARGET_BINARY): $(SAMBA_DIR)/$(SAMBA_BINARY) + $(TARGET_CONFIGURE_OPTS) $(MAKE) CC=$(TARGET_CC) \ + prefix="${TARGET_DIR}/usr" \ + BASEDIR="${TARGET_DIR}/usr" \ + SBINDIR="${TARGET_DIR}/usr/sbin" \ + LOCKDIR="${TARGET_DIR}/var/cache/samba" \ + PRIVATEDIR="${TARGET_DIR}/etc/samba" \ + CONFIGDIR="${TARGET_DIR}/etc/samba" \ + VARDIR="${TARGET_DIR}/var/log/samba" \ + -C $(SAMBA_DIR) installservers installbin installcifsmount + for file in $(SAMBA_TARGETS_) ; do \ + rm -f $(TARGET_DIR)/$$file; \ + done + $(INSTALL) -m 0755 -D package/samba/init-samba $(TARGET_DIR)/etc/init.d/S91smb + @if [ ! -f $(TARGET_DIR)/etc/samba/smb.conf ] ; then \ + $(INSTALL) -m 0755 -D package/samba/simple.conf $(TARGET_DIR)/etc/samba/smb.conf; \ + fi; + rm -rf $(TARGET_DIR)/var/cache/samba + rm -rf $(TARGET_DIR)/var/lib/samba + +samba: uclibc $(TARGET_DIR)/$(SAMBA_TARGET_BINARY) + +samba-clean: + rm -f $(TARGET_DIR)/$(SAMBA_TARGET_BINARY) + for file in $(SAMBA_TARGETS_y) ; do \ + rm -f $(TARGET_DIR)/$$file; \ + done + rm -f $(TARGET_DIR)/etc/init.d/S91smb + rm -rf $(TARGET_DIR)/etc/samba + -$(MAKE) -C $(SAMBA_DIR) clean + +samba-dirclean: + rm -rf $(SAMBA_DIR) +############################################################# +# +# Toplevel Makefile options +# +############################################################# +ifeq ($(strip $(BR2_PACKAGE_SAMBA)),y) +TARGETS+=samba +endif -- cgit v1.2.3