diff options
| -rw-r--r-- | meta/classes/image-mklibs.bbclass | 69 | ||||
| -rw-r--r-- | meta/conf/local.conf.sample | 12 |
2 files changed, 80 insertions, 1 deletions
diff --git a/meta/classes/image-mklibs.bbclass b/meta/classes/image-mklibs.bbclass new file mode 100644 index 0000000000..0e72b018c0 --- /dev/null +++ b/meta/classes/image-mklibs.bbclass | |||
| @@ -0,0 +1,69 @@ | |||
| 1 | do_rootfs[depends] += "mklibs-native:do_populate_sysroot" | ||
| 2 | |||
| 3 | IMAGE_PREPROCESS_COMMAND += "mklibs_optimize_image; " | ||
| 4 | |||
| 5 | mklibs_optimize_image_doit() { | ||
| 6 | rm -rf ${WORKDIR}/mklibs | ||
| 7 | mkdir -p ${WORKDIR}/mklibs/dest | ||
| 8 | cd ${IMAGE_ROOTFS} | ||
| 9 | du -bs > ${WORKDIR}/mklibs/du.before.mklibs.txt | ||
| 10 | for i in `find .`; do file $i; done \ | ||
| 11 | | grep ELF \ | ||
| 12 | | grep "LSB executable" \ | ||
| 13 | | grep "dynamically linked" \ | ||
| 14 | | sed "s/:.*//" \ | ||
| 15 | | sed "s+^\./++" \ | ||
| 16 | > ${WORKDIR}/mklibs/executables.list | ||
| 17 | |||
| 18 | case ${TARGET_ARCH} in | ||
| 19 | powerpc | mips ) | ||
| 20 | dynamic_loader="/lib/ld.so.1" | ||
| 21 | ;; | ||
| 22 | x86_64) | ||
| 23 | dynamic_loader="/lib/ld-linux-x86-64.so.2" | ||
| 24 | ;; | ||
| 25 | i586 ) | ||
| 26 | dynamic_loader="/lib/ld-linux.so.2" | ||
| 27 | ;; | ||
| 28 | arm ) | ||
| 29 | dynamic_loader="/lib/ld-linux.so.3" | ||
| 30 | ;; | ||
| 31 | * ) | ||
| 32 | dynamic_loader="/unknown_dynamic_linker" | ||
| 33 | ;; | ||
| 34 | esac | ||
| 35 | |||
| 36 | mklibs -v \ | ||
| 37 | --ldlib ${dynamic_loader} \ | ||
| 38 | --sysroot ${PKG_CONFIG_SYSROOT_DIR} \ | ||
| 39 | --root ${IMAGE_ROOTFS} \ | ||
| 40 | --target `echo ${TARGET_PREFIX} | sed 's/-$//' ` \ | ||
| 41 | -d ${WORKDIR}/mklibs/dest \ | ||
| 42 | `cat ${WORKDIR}/mklibs/executables.list` | ||
| 43 | |||
| 44 | cd ${WORKDIR}/mklibs/dest | ||
| 45 | for i in * | ||
| 46 | do | ||
| 47 | cp $i `find ${IMAGE_ROOTFS} -name $i` | ||
| 48 | done | ||
| 49 | |||
| 50 | cd ${IMAGE_ROOTFS} | ||
| 51 | du -bs > ${WORKDIR}/mklibs/du.after.mklibs.txt | ||
| 52 | |||
| 53 | echo rootfs size before mklibs optimization: `cat ${WORKDIR}/mklibs/du.before.mklibs.txt` | ||
| 54 | echo rootfs size after mklibs optimization: `cat ${WORKDIR}/mklibs/du.after.mklibs.txt` | ||
| 55 | } | ||
| 56 | |||
| 57 | mklibs_optimize_image() { | ||
| 58 | for img in ${MKLIBS_OPTIMIZED_IMAGES} | ||
| 59 | do | ||
| 60 | if [ "${img}" == "${PN}" ] || [ "${img}" == "all" ] | ||
| 61 | then | ||
| 62 | mklibs_optimize_image_doit | ||
| 63 | break | ||
| 64 | fi | ||
| 65 | done | ||
| 66 | } | ||
| 67 | |||
| 68 | |||
| 69 | EXPORT_FUNCTIONS mklibs_optimize_image | ||
diff --git a/meta/conf/local.conf.sample b/meta/conf/local.conf.sample index d9f7098f0c..d61aaebdd0 100644 --- a/meta/conf/local.conf.sample +++ b/meta/conf/local.conf.sample | |||
| @@ -73,10 +73,20 @@ EXTRA_IMAGE_FEATURES_mx31ads = "tools-testapps debug-tweaks" | |||
| 73 | #PACKAGE_CLASSES ?= "package_rpm package_deb package_ipk" | 73 | #PACKAGE_CLASSES ?= "package_rpm package_deb package_ipk" |
| 74 | PACKAGE_CLASSES ?= "package_rpm package_ipk" | 74 | PACKAGE_CLASSES ?= "package_rpm package_ipk" |
| 75 | 75 | ||
| 76 | # mklibs library size optimization is more useful to smaller images, | ||
| 77 | # and less useful for bigger images. Also mklibs library optimization can break the ABI compatibility, so should not be applied to the images which are tobe | ||
| 78 | # extended or upgraded later. | ||
| 79 | #This enabled mklibs library size optimization just for the specified image. | ||
| 80 | #MKLIBS_OPTIMIZED_IMAGES ?= "poky-image-minimal" | ||
| 81 | #This enable mklibs library size optimization will be for all the images. | ||
| 82 | #MKLIBS_OPTIMIZED_IMAGES ?= "all" | ||
| 83 | |||
| 76 | # A list of additional classes to use when building the system | 84 | # A list of additional classes to use when building the system |
| 85 | # include 'image-mklibs' to reduce shared library files size for an image | ||
| 77 | # include 'image-prelink' in order to prelink the filesystem image | 86 | # include 'image-prelink' in order to prelink the filesystem image |
| 78 | # include 'image-swab' to perform host system intrusion detection | 87 | # include 'image-swab' to perform host system intrusion detection |
| 79 | USER_CLASSES ?= "image-prelink" | 88 | # NOTE: if listing mklibs & prelink both, then make sure mklibs is before prelink |
| 89 | USER_CLASSES ?= "image-mklibs image-prelink" | ||
| 80 | 90 | ||
| 81 | # POKYMODE controls the characteristics of the generated packages/images by | 91 | # POKYMODE controls the characteristics of the generated packages/images by |
| 82 | # telling poky which type of toolchain to use. | 92 | # telling poky which type of toolchain to use. |
