use host opkg for installing packages in buildroot and ImageBuilder
SVN-Revision: 22372
This commit is contained in:
parent
4ee3ae96c2
commit
8c1d9afc40
4 changed files with 66 additions and 18 deletions
|
@ -1,17 +1,20 @@
|
||||||
#
|
#
|
||||||
# Copyright (C) 2006,2007 OpenWrt.org
|
# Copyright (C) 2006-2010 OpenWrt.org
|
||||||
#
|
#
|
||||||
# This is free software, licensed under the GNU General Public License v2.
|
# This is free software, licensed under the GNU General Public License v2.
|
||||||
# See /LICENSE for more information.
|
# See /LICENSE for more information.
|
||||||
#
|
#
|
||||||
|
|
||||||
# where to build (and put) .ipk packages
|
# where to build (and put) .ipk packages
|
||||||
IPKG:= \
|
OPKG:= \
|
||||||
IPKG_TMP=$(TMP_DIR)/ipkg \
|
IPKG_TMP=$(TMP_DIR)/ipkg \
|
||||||
IPKG_INSTROOT=$(TARGET_DIR) \
|
IPKG_INSTROOT=$(TARGET_DIR) \
|
||||||
IPKG_CONF_DIR=$(STAGING_DIR)/etc \
|
IPKG_CONF_DIR=$(STAGING_DIR)/etc \
|
||||||
IPKG_OFFLINE_ROOT=$(TARGET_DIR) \
|
IPKG_OFFLINE_ROOT=$(TARGET_DIR) \
|
||||||
$(SCRIPT_DIR)/ipkg -force-defaults -force-depends
|
$(STAGING_DIR_HOST)/bin/opkg \
|
||||||
|
-f $(STAGING_DIR)/etc/opkg.conf \
|
||||||
|
--force-depends \
|
||||||
|
--force-overwrite
|
||||||
|
|
||||||
# invoke ipkg-build with some default options
|
# invoke ipkg-build with some default options
|
||||||
IPKG_BUILD:= \
|
IPKG_BUILD:= \
|
||||||
|
@ -76,7 +79,7 @@ ifeq ($(DUMP),)
|
||||||
rm -rf $(STAGING_DIR_ROOT)/tmp-$(1)
|
rm -rf $(STAGING_DIR_ROOT)/tmp-$(1)
|
||||||
touch $$@
|
touch $$@
|
||||||
|
|
||||||
$$(IPKG_$(1)): $(STAGING_DIR)/etc/ipkg.conf $(STAMP_BUILT)
|
$$(IPKG_$(1)): $(STAGING_DIR)/etc/opkg.conf $(STAMP_BUILT)
|
||||||
@rm -f $(PACKAGE_DIR)/$(1)_*
|
@rm -f $(PACKAGE_DIR)/$(1)_*
|
||||||
rm -rf $$(IDIR_$(1))
|
rm -rf $$(IDIR_$(1))
|
||||||
mkdir -p $$(IDIR_$(1))/CONTROL
|
mkdir -p $$(IDIR_$(1))/CONTROL
|
||||||
|
@ -111,7 +114,8 @@ ifeq ($(DUMP),)
|
||||||
@[ -f $$(IPKG_$(1)) ] || false
|
@[ -f $$(IPKG_$(1)) ] || false
|
||||||
|
|
||||||
$$(INFO_$(1)): $$(IPKG_$(1))
|
$$(INFO_$(1)): $$(IPKG_$(1))
|
||||||
$(IPKG) install $$(IPKG_$(1))
|
@[ -d $(TARGET_DIR)/tmp ] || mkdir -p $(TARGET_DIR)/tmp
|
||||||
|
$(OPKG) install $$(IPKG_$(1))
|
||||||
|
|
||||||
$(1)-clean:
|
$(1)-clean:
|
||||||
rm -f $(PACKAGE_DIR)/$(1)_*
|
rm -f $(PACKAGE_DIR)/$(1)_*
|
||||||
|
@ -120,9 +124,11 @@ ifeq ($(DUMP),)
|
||||||
|
|
||||||
endef
|
endef
|
||||||
|
|
||||||
$(STAGING_DIR)/etc/ipkg.conf:
|
$(STAGING_DIR)/etc/opkg.conf:
|
||||||
mkdir -p $(STAGING_DIR)/etc
|
mkdir -p $(STAGING_DIR)/etc
|
||||||
echo "dest root /" > $(STAGING_DIR)/etc/ipkg.conf
|
( echo "dest root /" > $@; \
|
||||||
echo "option offline_root $(TARGET_DIR)" >> $(STAGING_DIR)/etc/ipkg.conf
|
echo "arch all 100" >> $@; \
|
||||||
|
echo "arch $(PKGARCH) 200" >> $@; \
|
||||||
|
echo "option offline_root $(TARGET_DIR)" >> $@ )
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -20,6 +20,9 @@ ifneq ($(IGNORE_ERRORS),)
|
||||||
$(curdir)/builddirs-ignore-compile:= $(if $(filter m y, $(IGNORE_ERRORS)),$(foreach m,$(IGNORE_ERRORS),$(package-$(m))),$(package-m))
|
$(curdir)/builddirs-ignore-compile:= $(if $(filter m y, $(IGNORE_ERRORS)),$(foreach m,$(IGNORE_ERRORS),$(package-$(m))),$(package-m))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
$(curdir)/opkghost: $(TMP_DIR)/.build
|
||||||
|
@-$(MAKE) package/opkg/host/install
|
||||||
|
|
||||||
$(curdir)/install:=$(curdir)/install-cleanup
|
$(curdir)/install:=$(curdir)/install-cleanup
|
||||||
|
|
||||||
$(curdir)/cleanup: $(TMP_DIR)/.build
|
$(curdir)/cleanup: $(TMP_DIR)/.build
|
||||||
|
@ -88,9 +91,10 @@ $(curdir)/index: FORCE
|
||||||
$(curdir)/flags-install:= -j1
|
$(curdir)/flags-install:= -j1
|
||||||
|
|
||||||
$(eval $(call stampfile,$(curdir),package,prereq,.config))
|
$(eval $(call stampfile,$(curdir),package,prereq,.config))
|
||||||
$(eval $(call stampfile,$(curdir),package,cleanup,$(TMP_DIR)/.build))
|
$(eval $(call stampfile,$(curdir),package,cleanup))
|
||||||
$(eval $(call stampfile,$(curdir),package,compile,$(TMP_DIR)/.build))
|
$(eval $(call stampfile,$(curdir),package,compile))
|
||||||
$(eval $(call stampfile,$(curdir),package,install,$(TMP_DIR)/.build))
|
$(eval $(call stampfile,$(curdir),package,opkghost))
|
||||||
$(eval $(call stampfile,$(curdir),package,rootfs-prepare,$(TMP_DIR)/.build))
|
$(eval $(call stampfile,$(curdir),package,install,$(STAGING_DIR)/stamp/.package_opkghost))
|
||||||
|
$(eval $(call stampfile,$(curdir),package,rootfs-prepare))
|
||||||
|
|
||||||
$(eval $(call subdir,$(curdir)))
|
$(eval $(call subdir,$(curdir)))
|
||||||
|
|
|
@ -18,7 +18,9 @@ PKG_SOURCE_SUBDIR:=opkg-$(PKG_VERSION)
|
||||||
PKG_SOURCE_URL:=http://opkg.googlecode.com/svn/trunk/
|
PKG_SOURCE_URL:=http://opkg.googlecode.com/svn/trunk/
|
||||||
PKG_SOURCE:=$(PKG_SOURCE_SUBDIR).tar.gz
|
PKG_SOURCE:=$(PKG_SOURCE_SUBDIR).tar.gz
|
||||||
PKG_FIXUP = libtool
|
PKG_FIXUP = libtool
|
||||||
|
|
||||||
include $(INCLUDE_DIR)/package.mk
|
include $(INCLUDE_DIR)/package.mk
|
||||||
|
include $(INCLUDE_DIR)/host-build.mk
|
||||||
|
|
||||||
define Package/opkg
|
define Package/opkg
|
||||||
SECTION:=base
|
SECTION:=base
|
||||||
|
@ -80,3 +82,25 @@ define Build/InstallDev
|
||||||
endef
|
endef
|
||||||
|
|
||||||
$(eval $(call BuildPackage,opkg))
|
$(eval $(call BuildPackage,opkg))
|
||||||
|
|
||||||
|
|
||||||
|
HOST_CONFIGURE_ARGS += \
|
||||||
|
--disable-curl \
|
||||||
|
--disable-gpg \
|
||||||
|
--with-opkgetcdir=/etc \
|
||||||
|
--with-opkglockfile=/tmp/opkg.lock
|
||||||
|
|
||||||
|
define Host/Configure
|
||||||
|
(cd $(HOST_BUILD_DIR); autoreconf -v --install || exit 1)
|
||||||
|
$(call Host/Configure/Default)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define Host/Compile
|
||||||
|
$(MAKE) -C $(HOST_BUILD_DIR) CC="$(HOSTCC)" all
|
||||||
|
endef
|
||||||
|
|
||||||
|
define Host/Install
|
||||||
|
$(INSTALL_BIN) $(HOST_BUILD_DIR)/src/opkg-cl $(STAGING_DIR_HOST)/bin/opkg
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call HostBuild))
|
||||||
|
|
|
@ -52,12 +52,15 @@ help: FORCE
|
||||||
|
|
||||||
# override variables from rules.mk
|
# override variables from rules.mk
|
||||||
PACKAGE_DIR:=$(TOPDIR)/packages
|
PACKAGE_DIR:=$(TOPDIR)/packages
|
||||||
IPKG:= \
|
OPKG:= \
|
||||||
IPKG_TMP="$(TOPDIR)/tmp/ipkgtmp" \
|
IPKG_TMP="$(TOPDIR)/tmp/ipkgtmp" \
|
||||||
IPKG_INSTROOT="$(TARGET_DIR)" \
|
IPKG_INSTROOT="$(TARGET_DIR)" \
|
||||||
IPKG_CONF_DIR="$(TOPDIR)/tmp" \
|
IPKG_CONF_DIR="$(TOPDIR)/tmp" \
|
||||||
IPKG_OFFLINE_ROOT="$(TARGET_DIR)" \
|
IPKG_OFFLINE_ROOT="$(TARGET_DIR)" \
|
||||||
$(SCRIPT_DIR)/ipkg -force-defaults
|
$(STAGING_DIR_HOST)/bin/opkg \
|
||||||
|
-f $(TOPDIR)/tmp/opkg.conf \
|
||||||
|
--force-depends \
|
||||||
|
--force-overwrite
|
||||||
|
|
||||||
define Profile
|
define Profile
|
||||||
$(eval $(call Profile/Default))
|
$(eval $(call Profile/Default))
|
||||||
|
@ -79,10 +82,18 @@ _call_info: FORCE
|
||||||
echo 'Available Profiles:'
|
echo 'Available Profiles:'
|
||||||
echo; $(PROFILE_LIST)
|
echo; $(PROFILE_LIST)
|
||||||
|
|
||||||
$(TOPDIR)/tmp/ipkg.conf: FORCE
|
$(TOPDIR)/tmp/opkg.conf: FORCE
|
||||||
@mkdir -p $(TOPDIR)/tmp
|
@mkdir -p $(TOPDIR)/tmp
|
||||||
|
@mkdir -p $(TARGET_DIR)/tmp
|
||||||
@echo 'dest root /' > $@
|
@echo 'dest root /' > $@
|
||||||
@echo 'src packages file:$(PACKAGE_DIR)' >> $@
|
@echo 'src packages file:$(PACKAGE_DIR)' >> $@
|
||||||
|
@echo 'arch all 100' >> $@
|
||||||
|
ifneq ($(CONFIG_TARGET_adm5120),y)
|
||||||
|
@echo 'arch $(BOARD) 200' >> $@
|
||||||
|
else
|
||||||
|
@echo 'arch $(BOARD)_$(ARCH) 200' >> $@
|
||||||
|
endif
|
||||||
|
@echo 'option offline_root $(TARGET_DIR)' >> $@
|
||||||
|
|
||||||
BUILD_PACKAGES:=$(sort $(DEFAULT_PACKAGES) $(USER_PACKAGES) $($(USER_PROFILE)_PACKAGES) kernel)
|
BUILD_PACKAGES:=$(sort $(DEFAULT_PACKAGES) $(USER_PACKAGES) $($(USER_PROFILE)_PACKAGES) kernel)
|
||||||
# "-pkgname" in the package list means remove "pkgname" from the package list
|
# "-pkgname" in the package list means remove "pkgname" from the package list
|
||||||
|
@ -102,18 +113,18 @@ endif
|
||||||
$(MAKE) package_postinst
|
$(MAKE) package_postinst
|
||||||
$(MAKE) build_image
|
$(MAKE) build_image
|
||||||
|
|
||||||
package_index: $(TOPDIR)/tmp/ipkg.conf FORCE
|
package_index: $(TOPDIR)/tmp/opkg.conf FORCE
|
||||||
@echo
|
@echo
|
||||||
@echo Building package index...
|
@echo Building package index...
|
||||||
(cd $(PACKAGE_DIR); $(SCRIPT_DIR)/ipkg-make-index.sh . > Packages && \
|
(cd $(PACKAGE_DIR); $(SCRIPT_DIR)/ipkg-make-index.sh . > Packages && \
|
||||||
gzip -9c Packages > Packages.gz \
|
gzip -9c Packages > Packages.gz \
|
||||||
) >/dev/null 2>/dev/null
|
) >/dev/null 2>/dev/null
|
||||||
$(IPKG) update
|
$(OPKG) update
|
||||||
|
|
||||||
package_install: FORCE
|
package_install: FORCE
|
||||||
@echo
|
@echo
|
||||||
@echo Installing packages...
|
@echo Installing packages...
|
||||||
$(IPKG) install $(BUILD_PACKAGES)
|
$(OPKG) install $(BUILD_PACKAGES)
|
||||||
|
|
||||||
copy_files: FORCE
|
copy_files: FORCE
|
||||||
@echo
|
@echo
|
||||||
|
@ -121,6 +132,9 @@ copy_files: FORCE
|
||||||
$(CP) $(USER_FILES)/* $(TARGET_DIR)/
|
$(CP) $(USER_FILES)/* $(TARGET_DIR)/
|
||||||
|
|
||||||
package_postinst: FORCE
|
package_postinst: FORCE
|
||||||
|
@echo
|
||||||
|
@echo Cleaning up
|
||||||
|
@rm -f $(TARGET_DIR)/tmp/opkg.lock
|
||||||
@echo
|
@echo
|
||||||
@echo Activating init scripts
|
@echo Activating init scripts
|
||||||
@( \
|
@( \
|
||||||
|
|
Loading…
Reference in a new issue