- Patch from Thomas Lundquist to support lzma compressed ext2 rootfs.

This commit is contained in:
Bernhard Reutner-Fischer 2006-11-04 19:15:56 +00:00
parent 86d9fd0a37
commit a44651de6e
4 changed files with 86 additions and 28 deletions

View File

@ -1,14 +1,22 @@
config BR2_PACKAGE_LZMA config BR2_PACKAGE_LZMA_TARGET
bool "lzma" bool "Install lzma for the target system"
default n default n
help help
Compression utility. lzma utils on the target
http://tukaani.org/lzma/ http://tukaani.org/lzma/
config BR2_PACKAGE_LZMA_TARGET_HEADERS config BR2_PACKAGE_LZMA_TARGET_HEADERS
bool "lzma headers in target" bool "lzma headers in target"
default n default n
depends on BR2_PACKAGE_LZMA depends on BR2_PACKAGE_LZMA_TARGET
help help
Put headers files in the target. Put headers files in the target.
config BR2_PACKAGE_LZMA_HOST
bool "Install lzma for the host/build system"
default n
help
lzma utils on the host
http://tukaani.org/lzma/

View File

@ -6,7 +6,8 @@
LZMA_VER:=4.32.0beta3 LZMA_VER:=4.32.0beta3
LZMA_SOURCE:=lzma-$(LZMA_VER).tar.gz LZMA_SOURCE:=lzma-$(LZMA_VER).tar.gz
LZMA_SITE:=http://tukaani.org/lzma/ LZMA_SITE:=http://tukaani.org/lzma/
LZMA_DIR:=$(BUILD_DIR)/lzma-$(LZMA_VER) LZMA_HOST_DIR:=$(TOOL_BUILD_DIR)/lzma-$(LZMA_VER)
LZMA_TARGET_DIR:=$(BUILD_DIR)/lzma-$(LZMA_VER)
LZMA_CFLAGS:=$(TARGET_CFLAGS) LZMA_CFLAGS:=$(TARGET_CFLAGS)
ifeq ($(BR2_LARGEFILE),y) ifeq ($(BR2_LARGEFILE),y)
LZMA_CFLAGS+=-D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64 LZMA_CFLAGS+=-D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64
@ -18,13 +19,47 @@ endif
$(DL_DIR)/$(LZMA_SOURCE): $(DL_DIR)/$(LZMA_SOURCE):
$(WGET) -P $(DL_DIR) $(LZMA_SITE)/$(LZMA_SOURCE) $(WGET) -P $(DL_DIR) $(LZMA_SITE)/$(LZMA_SOURCE)
$(LZMA_DIR)/.source: $(DL_DIR)/$(LZMA_SOURCE) ######################################################################
$(ZCAT) $(DL_DIR)/$(LZMA_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - #
toolchain/patch-kernel.sh $(LZMA_DIR) package/lzma/ lzma\*.patch # lzma host
touch $(LZMA_DIR)/.source #
######################################################################
$(LZMA_DIR)/.configured: $(LZMA_DIR)/.source $(LZMA_HOST_DIR)/.source: $(DL_DIR)/$(LZMA_SOURCE)
(cd $(LZMA_DIR); rm -f config.cache ;\ zcat $(DL_DIR)/$(LZMA_SOURCE) | tar -C $(TOOL_BUILD_DIR) $(TAR_OPTIONS) -
toolchain/patch-kernel.sh $(LZMA_HOST_DIR) package/lzma/ lzma\*.patch
touch $(LZMA_HOST_DIR)/.source
$(LZMA_HOST_DIR)/.configured: $(LZMA_HOST_DIR)/.source
(cd $(LZMA_HOST_DIR); rm -f config.cache ;\
CC="$(HOSTCC)" \
./configure \
--prefix=/ \
);
touch $(LZMA_HOST_DIR)/.configured;
$(LZMA_HOST_DIR)/src/lzma/lzma: $(LZMA_HOST_DIR)/.configured
$(MAKE) -C $(LZMA_HOST_DIR) all
touch -c $@
$(STAGING_DIR)/bin/lzma: $(LZMA_HOST_DIR)/src/lzma/lzma
$(MAKE) DESTDIR=$(STAGING_DIR) -C $(LZMA_HOST_DIR) install
lzma-host: uclibc $(STAGING_DIR)/bin/lzma
######################################################################
#
# lzma target
#
######################################################################
$(LZMA_TARGET_DIR)/.source: $(DL_DIR)/$(LZMA_SOURCE)
zcat $(DL_DIR)/$(LZMA_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
toolchain/patch-kernel.sh $(LZMA_TARGET_DIR) package/lzma/ lzma\*.patch
touch $(LZMA_TARGET_DIR)/.source
$(LZMA_TARGET_DIR)/.configured: $(LZMA_TARGET_DIR)/.source
(cd $(LZMA_TARGET_DIR); rm -f config.cache ;\
$(TARGET_CONFIGURE_OPTS) \ $(TARGET_CONFIGURE_OPTS) \
CFLAGS="$(TARGET_CFLAGS) $(LZMA_CFLAGS)" \ CFLAGS="$(TARGET_CFLAGS) $(LZMA_CFLAGS)" \
ac_cv_func_malloc_0_nonnull=yes \ ac_cv_func_malloc_0_nonnull=yes \
@ -33,37 +68,33 @@ $(LZMA_DIR)/.configured: $(LZMA_DIR)/.source
--host=$(GNU_TARGET_NAME) \ --host=$(GNU_TARGET_NAME) \
--build=$(GNU_HOST_NAME) \ --build=$(GNU_HOST_NAME) \
--prefix=/usr \ --prefix=/usr \
--exec-prefix=$(STAGING_DIR)/usr/bin \ --exec-prefix=$(TARGET_DIR)/usr/bin \
--libdir=$(STAGING_DIR)/lib \ --libdir=$(TARGET_DIR)/lib \
--includedir=$(STAGING_DIR)/include \ --includedir=$(TARGET_DIR)/include \
--disable-debug \ --disable-debug \
$(DISABLE_NLS) \ $(DISABLE_NLS) \
$(LZMA_LARGEFILE) \ $(LZMA_LARGEFILE) \
); );
touch $(LZMA_DIR)/.configured; touch $(LZMA_TARGET_DIR)/.configured;
$(LZMA_DIR)/src/lzma/lzma: $(LZMA_DIR)/.configured $(LZMA_TARGET_DIR)/src/lzma/lzma: $(LZMA_TARGET_DIR)/.configured
$(MAKE) -C $(LZMA_DIR) all $(MAKE) -C $(LZMA_TARGET_DIR) all
touch -c $@ touch -c $@
$(STAGING_DIR)/bin/lzma: $(LZMA_DIR)/src/lzma/lzma $(TARGET_DIR)/usr/bin/lzma: $(LZMA_TARGET_DIR)/src/lzma/lzma
-cp -dpf $(LZMA_DIR)/src/lzma/lzma $(STAGING_DIR)/bin/; -cp -dpf $(LZMA_TARGET_DIR)/src/lzma/lzma $(TARGET_DIR)/bin/;
touch -c $(STAGING_DIR)/bin/lzma
$(TARGET_DIR)/bin/lzma: $(STAGING_DIR)/bin/lzma
cp -dpf $(STAGING_DIR)/bin/lzma $(TARGET_DIR)/bin/;
-$(STRIP) --strip-unneeded $(TARGET_DIR)/bin/lzma -$(STRIP) --strip-unneeded $(TARGET_DIR)/bin/lzma
touch -c $(TARGET_DIR)/bin/lzma touch -c $(TARGET_DIR)/bin/lzma
#lzma-headers: $(TARGET_DIR)/bin/lzma #lzma-headers: $(TARGET_DIR)/bin/lzma
lzma: uclibc $(TARGET_DIR)/bin/lzma lzma-target: uclibc $(TARGET_DIR)/usr/bin/lzma
lzma-source: $(DL_DIR)/$(LZMA_SOURCE) lzma-source: $(DL_DIR)/$(LZMA_SOURCE)
lzma-clean: lzma-clean:
rm -f $(TARGET_DIR)/bin/lzma rm -f $(TARGET_DIR)/usr/bin/lzma
-$(MAKE) -C $(LZMA_DIR) clean -$(MAKE) -C $(LZMA_TARGET_DIR) clean
lzma-dirclean: lzma-dirclean:
rm -rf $(LZMA_DIR) rm -rf $(LZMA_DIR)
@ -73,9 +104,14 @@ lzma-dirclean:
# Toplevel Makefile options # Toplevel Makefile options
# #
############################################################# #############################################################
ifeq ($(strip $(BR2_PACKAGE_LZMA)),y) ifeq ($(strip $(BR2_PACKAGE_LZMA_HOST)),y)
TARGETS+=lzma TARGETS+=lzma-host
endif endif
ifeq ($(strip $(BR2_PACKAGE_LZMA_TARGET)),y)
TARGETS+=lzma-target
endif
#ifeq ($(strip $(BR2_PACKAGE_LZMA_TARGET_HEADERS)),y) #ifeq ($(strip $(BR2_PACKAGE_LZMA_TARGET_HEADERS)),y)
#TARGETS+=lzma-headers #TARGETS+=lzma-headers
#endif #endif

View File

@ -34,6 +34,13 @@ config BR2_TARGET_ROOTFS_EXT2_GZ
depends on BR2_TARGET_ROOTFS_EXT2 depends on BR2_TARGET_ROOTFS_EXT2
default n default n
config BR2_TARGET_ROOTFS_EXT2_LZMA
bool "lzma the output file"
depends on BR2_TARGET_ROOTFS_EXT2
select BR2_PACKAGE_LZMA_HOST
default n
config BR2_TARGET_ROOTFS_EXT2_COPYTO config BR2_TARGET_ROOTFS_EXT2_COPYTO
string "also copy the image to..." string "also copy the image to..."
depends on BR2_TARGET_ROOTFS_EXT2 depends on BR2_TARGET_ROOTFS_EXT2

View File

@ -66,6 +66,10 @@ else
EXT2_TARGET := $(EXT2_BASE) EXT2_TARGET := $(EXT2_BASE)
endif endif
ifeq ($(strip $(BR2_TARGET_ROOTFS_EXT2_LZMA)),y)
EXT2_TARGET := $(EXT2_BASE).lzma
endif
$(EXT2_BASE): host-fakeroot makedevs genext2fs $(EXT2_BASE): host-fakeroot makedevs genext2fs
-@find $(TARGET_DIR) -type f -perm +111 | xargs $(STRIP) 2>/dev/null || true; -@find $(TARGET_DIR) -type f -perm +111 | xargs $(STRIP) 2>/dev/null || true;
@rm -rf $(TARGET_DIR)/usr/man @rm -rf $(TARGET_DIR)/usr/man
@ -102,6 +106,9 @@ endif
$(EXT2_BASE).gz: $(EXT2_BASE) $(EXT2_BASE).gz: $(EXT2_BASE)
@gzip --best -fv $(EXT2_BASE) @gzip --best -fv $(EXT2_BASE)
$(EXT2_BASE).lzma: lzma-host $(EXT2_BASE)
@$(STAGING_DIR)/bin/lzma -vc $(EXT2_BASE) > $(EXT2_BASE).lzma
EXT2_COPYTO := $(strip $(subst ",,$(BR2_TARGET_ROOTFS_EXT2_COPYTO))) EXT2_COPYTO := $(strip $(subst ",,$(BR2_TARGET_ROOTFS_EXT2_COPYTO)))
# " stupid syntax highlighting does not like unmatched quote from above line # " stupid syntax highlighting does not like unmatched quote from above line