On 02/26/2013 01:24 AM, Robert Yang wrote:
===Contents===
   * Summary
   * Brief design
   * Test info
   * The rootfs generation time changes
   * The rootfs size changes

* Summary:
   The ext3 and ext4 rootfs generation relied on genext2fs and flipping
   some bits to "convert" the ext2 filesystem to ext3 and ext4 in the past,
   now we use the mkfs.ext3/ext4 to create the image, and use mkdebugfs.sh
   to copy the files to the image.

* Brief design:
   - Upgrade the e2fsprogs to the update to date version (the git
     repo) which contains the "symlink" command in debugfs shell that we
     need.
This should really be an RFC

This work was intended to be a step toward incorporating it into genext2fs directly. At this point we do not want to switch to the GIT version of e2fsprogs, there is an update to e2fsprogs pending on the patch queue that addes the symlink support (crossed with your request)

   - Replace the current genext2fs command with mkdebugfs.sh in
     image_types.bbclass.

The goal is to change genext2fs to support a rootfs option an not replace it with mkdebugfs.

   - The new steps to generate the root filesystem are:
     -> use "dd" command to make rootfs.ext* file
Why the dd?

     -> run "mkfs.ext* rootfs.ext*" to create the filesystem
     -> run the mkdebugfs.sh to generate the root filesystem




* Test info: (MACHINE = qemuarm, IMAGE_FSTYPES = "ext2 ext3 ext4 tar.bz2")
   $ bitbake core-image-minimal core-image-sato meta-toolchain-sdk 
core-image-sato-sdk
   $ runqemu runqemu qemuarm core-image-sato ext3
   $ runqemu runqemu qemuarm core-image-minimal ext3

   All of them are OK

What about booting an ext4 image, part of the goal of this was to enable ext4.


* The rootfs generation time changes
   - For a core-image-minimal generation (IMAGE_FSTYPES="tar.bz2 ext3"):

     Before:
     $ time bitbake core-image-minimal

     real    1m10.823s
     user    0m37.108s
     sys     0m15.894s

     After:
     $ time bitbake core-image-minimal

     real    1m17.501s
     user    0m29.304s
     sys     0m20.731s

     # 7 seconds lost.

   - For a core-image-sato generation (IMAGE_FSTYPES="tar.bz2 ext3"):

     Before:
     $ time bitbake core-image-sato

     real    11m10.645s
     user    2m43.503s
     sys     1m1.589s

     After:
     $ time bitbake core-image-sato

     real    11m53.131s
     user    3m18.988s
     sys     2m8.350s

     # 43 seconds lost.

* The rootfs size changes
   - The image size are the same by "ls -h", but different by "du -sh":
     (core-image-sato)

     $ ls -lh BEFORE.rootfs.ext3 AFTER.rootfs.ext3 | awk '{print $5"\t"$NF}'
     357M BEFORE.rootfs.ext3
     357M AFTER.rootfs.ext3

     $ du -sh BEFORE.rootfs.ext3 AFTER.rootfs.ext3
     238M    BEFORE.rootfs.ext3
     357M    AFTER.rootfs.ext3

     It seems that the genext2fs has optimized the rootfs generation.

// Robert

The following changes since commit 2cc4fe4a0874c42421b1bf3fa100160a9e60a9da:

   upstream_tracking.inc: Coonectivity and multimedia packages updates 
(2013-02-25 05:58:20 -0800)

are available in the git repository at:

   git://git.pokylinux.org/poky-contrib robert/e2fsprogs
   http://git.pokylinux.org/cgit.cgi/poky-contrib/log/?h=robert/e2fsprogs

Robert Yang (7):
   e2fsprogs: upgrade to the git version (rename only)
   e2fsprogs: upgrade to the git version
   e2fsprogs: add the original mkdebugfs.sh
   mkdebugfs.sh: convert the tab to 4 spaces
   mkdebugfs.sh: several fixes
   e2fsprogs: ship mkfsdebug.sh
   image_types.bbclass: replace genext2fs with mkdebugfs.sh

  meta/classes/image_types.bbclass                   | 45 +++++-------
  meta/recipes-devtools/e2fsprogs/e2fsprogs.inc      |  4 +-
  .../{e2fsprogs-1.42.6 => e2fsprogs}/acinclude.m4   |  0
  .../fallocate.patch                                |  0
  .../e2fsprogs/e2fsprogs/mkdebugfs.sh               | 82 ++++++++++++++++++++++
  .../{e2fsprogs-1.42.6 => e2fsprogs}/mkdir.patch    |  0
  .../remove.ldconfig.call.patch                     |  0
  .../{e2fsprogs_1.42.6.bb => e2fsprogs_git.bb}      |  6 +-
  8 files changed, 106 insertions(+), 31 deletions(-)
  rename meta/recipes-devtools/e2fsprogs/{e2fsprogs-1.42.6 => 
e2fsprogs}/acinclude.m4 (100%)
  rename meta/recipes-devtools/e2fsprogs/{e2fsprogs-1.42.6 => 
e2fsprogs}/fallocate.patch (100%)
  create mode 100644 meta/recipes-devtools/e2fsprogs/e2fsprogs/mkdebugfs.sh
  rename meta/recipes-devtools/e2fsprogs/{e2fsprogs-1.42.6 => 
e2fsprogs}/mkdir.patch (100%)
  rename meta/recipes-devtools/e2fsprogs/{e2fsprogs-1.42.6 => 
e2fsprogs}/remove.ldconfig.call.patch (100%)
  rename meta/recipes-devtools/e2fsprogs/{e2fsprogs_1.42.6.bb => 
e2fsprogs_git.bb} (92%)


_______________________________________________
Openembedded-core mailing list
[email protected]
http://lists.linuxtogo.org/cgi-bin/mailman/listinfo/openembedded-core

Reply via email to