21 Oct, 2008

1 commit

  • * 'linux-next' of git://git.infradead.org/ubifs-2.6: (25 commits)
    UBIFS: fix ubifs_compress commentary
    UBIFS: amend printk
    UBIFS: do not read unnecessary bytes when unpacking bits
    UBIFS: check buffer length when scanning for LPT nodes
    UBIFS: correct condition to eliminate unecessary assignment
    UBIFS: add more debugging messages for LPT
    UBIFS: fix bulk-read handling uptodate pages
    UBIFS: improve garbage collection
    UBIFS: allow for sync_fs when read-only
    UBIFS: commit on sync_fs
    UBIFS: correct comment for commit_on_unmount
    UBIFS: update dbg_dump_inode
    UBIFS: fix commentary
    UBIFS: fix races in bit-fields
    UBIFS: ensure data read beyond i_size is zeroed out correctly
    UBIFS: correct key comparison
    UBIFS: use bit-fields when possible
    UBIFS: check data CRC when in error state
    UBIFS: improve znode splitting rules
    UBIFS: add no_chk_data_crc mount option
    ...

    Linus Torvalds
     

19 Oct, 2008

3 commits

  • Update the comment for ubifs_compress(), which incorrectly states that it
    returnsa success/failure indicator.

    Signed-off-by: Geert Uytterhoeven
    Signed-off-by: Artem Bityutskiy

    Geert Uytterhoeven
     
  • It is better to print "Reserved for root" than
    "Reserved pool size", because it is more obvious for users
    what this means.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • Fixes the following Oops:

    BUG: unable to handle kernel paging request at f8d24000
    IP: [] :ubifs:ubifs_unpack_bits+0xcd/0x231
    *pde = 34333067 *pte = 00000000
    Oops: 0000 [#1] PREEMPT SMP
    Modules linked in: deflate zlib_deflate lzo lzo_decompress lzo_compress
    ubifs ubi nandsim nand nand_ids nand_ecc mtd nfsd lockd sunrpc exportfs
    [last unloaded: nand_ecc]

    Pid: 7450, comm: sync Not tainted (2.6.27-rc8-ubifs-2.6 #27)
    EIP: 0060:[] EFLAGS: 00010206 CPU: 0
    EIP is at ubifs_unpack_bits+0xcd/0x231 [ubifs]
    EAX: 00000000 EBX: 00000000 ECX: d7e43dc0 EDX: 0000ff00
    ESI: 00000004 EDI: f8d23ffe EBP: d7e43db4 ESP: d7e43d8c
    DS: 007b ES: 007b FS: 00d8 GS: 0033 SS: 0068
    Process sync (pid: 7450, ti=d7e42000 task=eb6f9530 task.ti=d7e42000)
    Stack: 00000400 c0103db4 dc5e8090 d7e43dc0 d7e43dc0 d7e43dc4 0000001c 00000004
    f496d1e0 f8d23ffc d7e43dd4 f8ffac7e f8d23ffe 00000000 f8d23ffe f2b7af68
    f496d1e0 f8d23ffc d7e43e2c f8ffadc5 00000000 0001f000 00000000 c03b10a7
    Call Trace:
    [] ? restore_nocheck_notrace+0x0/0xe
    [] ? is_a_node+0x43/0x92 [ubifs]
    [] ? dbg_check_ltab+0xf8/0x5c9 [ubifs]
    [] ? mutex_lock_nested+0x1b2/0x2a0
    [] ? ubifs_lpt_start_commit+0x49/0xecb [ubifs]
    [] ? mutex_unlock+0xd/0xf
    [] ? ubifs_tnc_start_commit+0x1cf/0xef8 [ubifs]
    [] ? do_commit+0x18f/0x52d [ubifs]
    [] ? ubifs_run_commit+0x80/0xca [ubifs]
    [] ? ubifs_sync_fs+0xdb/0xf6 [ubifs]
    [] ? sync_filesystems+0xc6/0x10c
    [] ? do_sync+0x3b/0x6a
    [] ? sys_sync+0x12/0x18
    [] ? sysenter_do_call+0x12/0x35
    =======================
    Code: 4d ec 89 01 8b 45 e8 89 10 89 d8 89 f1 d3 e8 85 c0 74 07 29 d6 83 fe
    20 75 2a 89 d8 83 c4 1c 5b 5e 5f 5d c3 0f b6 57 01 c1 e2 08 b6 47 02
    c1 e0 10 09 c2 0f b6 07 09 c2 0f b
    EIP: [] ubifs_unpack_bits+0xcd/0x231 [ubifs] SS:ESP 0068:d7e43d8c
    ---[ end trace 1bbb4c407a6dd816 ]---

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     

14 Oct, 2008

1 commit

  • This is a much better version of a previous patch to make the parser
    tables constant. Rather than changing the typedef, we put the "const" in
    all the various places where its required, allowing the __initconst
    exception for nfsroot which was the cause of the previous trouble.

    This was posted for review some time ago and I believe its been in -mm
    since then.

    Signed-off-by: Steven Whitehouse
    Cc: Alexander Viro
    Signed-off-by: Linus Torvalds

    Steven Whitehouse
     

30 Sep, 2008

22 commits

  • 'is_a_node()' function was reading from a buffer before
    checking the buffer length, resulting in an OOPS as
    follows:

    BUG: unable to handle kernel paging request at f8f74002
    IP: [] :ubifs:ubifs_unpack_bits+0xca/0x233
    *pde = 19e95067 *pte = 00000000
    Oops: 0000 [#1] PREEMPT SMP
    Modules linked in: ubifs ubi mtdchar bio2mtd mtd brd video output
    [last unloaded: mtd]

    Pid: 6414, comm: integck Not tainted (2.6.27-rc6ubifs34 #23)
    EIP: 0060:[] EFLAGS: 00010246 CPU: 0
    EIP is at ubifs_unpack_bits+0xca/0x233 [ubifs]
    EAX: 00000000 EBX: f6090630 ECX: d9badcfc EDX: 00000000
    ESI: 00000004 EDI: f8f74002 EBP: d9badcec ESP: d9badcc0
    DS: 007b ES: 007b FS: 00d8 GS: 0033 SS: 0068
    Process integck (pid: 6414, ti=d9bac000 task=f727dae0 task.ti=d9bac000)
    Stack: 00000006 f7306240 00000002 00000000 d9badcfc d9badd00 0000001c 00000000
    f6090630 f6090630 f8f74000 d9badd10 f8fa1cc9 00000000 f8f74002 00000000
    f8f74002 f60fe128 f6090630 f8f74000 d9badd68 f8fa1e46 00000000 0001e000
    Call Trace:
    [] ? is_a_node+0x30/0x90 [ubifs]
    [] ? dbg_check_ltab+0x11d/0x5bd [ubifs]
    [] ? ubifs_lpt_start_commit+0x42/0xed3 [ubifs]
    [] ? mutex_unlock+0x8/0xa
    [] ? ubifs_tnc_start_commit+0x1c8/0xedb [ubifs]
    [] ? do_commit+0x187/0x523 [ubifs]
    [] ? mutex_unlock+0x8/0xa
    [] ? bud_wbuf_callback+0x22/0x28 [ubifs]
    [] ? ubifs_run_commit+0x76/0xc0 [ubifs]
    [] ? ubifs_sync_fs+0xd2/0xe6 [ubifs]
    [] ? vfs_quota_sync+0x0/0x17e
    [] ? quota_sync_sb+0x26/0xbb
    [] ? vfs_quota_sync+0x0/0x17e
    [] ? sync_dquots+0x22/0x12c
    [] ? __fsync_super+0x19/0x68
    [] ? fsync_super+0xb/0x19
    [] ? generic_shutdown_super+0x22/0xe7
    [] ? vfs_quota_off+0x0/0x5fd
    [] ? ubifs_kill_sb+0x31/0x35 [ubifs]
    [] ? deactivate_super+0x5e/0x71
    [] ? mntput_no_expire+0x82/0xe4
    [] ? sys_umount+0x4c/0x2f6
    [] ? sys_oldumount+0x19/0x1b
    [] ? sysenter_do_call+0x12/0x25
    =======================
    Code: c1 f8 03 8d 04 07 8b 4d e8 89 01 8b 45 e4 89 10 89 d8 89 f1 d3 e8 85 c0
    74 07 29 d6 83 fe 20 75 2a 89 d8 83 c4 20 5b 5e 5f 5d
    EIP: [] ubifs_unpack_bits+0xca/0x233 [ubifs] SS:ESP 0068:d9badcc0
    ---[ end trace 1f02572436518c13 ]---

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • Also add debugging checks for LPT size and separate
    out c->check_lpt_free from unrelated bitfields.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • Bulk-read skips uptodate pages but this was putting its
    array index out and causing it to treat subsequent pages
    as holes.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • Make garbage collection try to keep data nodes from the same
    inode together and in ascending order. This improves
    performance when reading those nodes especially when bulk-read
    is used.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • sync_fs can be called even if the file system is mounted
    read-only. Ensure the commit is not run in that case.

    Reported-by: Zoltan Sogor
    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • Commit the journal when the FS is sync'ed. This will make
    statfs provide better free space report. And we anyway
    advice our users to sync the FS if they want better statfs
    report.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • 'dbg_dump_inode()' is quite outdated and does not print all
    the fileds.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • Znode may refer both data nodes and indexing nodes

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • We cannot store bit-fields together if the processes which
    change them may race, unless we serialize them.

    Thus, move the nospc and nospc_rp bit-fields eway from
    the mount option/constant bit-fields, to avoid races.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • The comparison was working, but more by accident than design.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • The "bulk_read" and "no_chk_data_crc" have only 2 values -
    0 and 1. We already have bit-fields in corresponding data
    structers, so make "bulk_read" and "no_chk_data_crc"
    bit-fields as well.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • When UBIFS switches to R/O mode because of an error,
    it is reasonable to enable data CRC checking.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • When inserting into a full znode it is split into two
    znodes. Because data node keys are usually consecutive,
    it is better to try to keep them together. This patch
    does a better job of that.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • UBIFS read performance can be improved by skipping the CRC
    check when data nodes are read. This option can be used if
    the underlying media is considered to be highly reliable.
    Note that CRCs are always checked for metadata.

    Read speed on Arm platform with OneNAND goes from 19 MiB/s
    to 27 MiB/s with data CRC checking disabled.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • Some flash media are capable of reading sequentially at faster rates.
    UBIFS bulk-read facility is designed to take advantage of that, by
    reading in one go consecutive data nodes that are also located
    consecutively in the same LEB.

    Read speed on Arm platform with OneNAND goes from 17 MiB/s to
    19 MiB/s.

    Signed-off-by: Adrian Hunter

    Adrian Hunter
     
  • In case of error, the function kthread_create returns an ERR pointer,
    but never returns a NULL pointer. So a NULL test that comes before an
    IS_ERR test should be deleted.

    The semantic match that finds this problem is as follows:
    (http://www.emn.fr/x-info/coccinelle/)

    //
    @match_bad_null_test@
    expression x, E;
    statement S1,S2;
    @@
    x = kthread_create(...)
    ... when != x = E
    * if (x == NULL)
    S1 else S2
    //

    Signed-off-by: Julien Brunel
    Signed-off-by: Julia Lawall
    Signed-off-by: Artem Bityutskiy

    Julien Brunel
     
  • 'ubifs_get_lprops()' and 'ubifs_release_lprops()' basically wrap
    mutex lock and unlock. We have them because we want lprops subsystem
    be separate and as independent as possible. And we planned better
    locking rules for lprops.

    Anyway, because they are short, it is better to inline them.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • IS_ERR() macro already has unlikely(), so do not use constructions
    like 'if (unlikely(IS_ERR())'.

    Signed-off-by: Hirofumi Nakagawa
    Signed-off-by: Artem Bityutskiy

    Hirofumi Nakagawa
     
  • This commit adds a reserved pool size print and tweaks the
    prints to make them look nicer.

    It also fixes and cleans-up some comments.

    Additionally, it deletes some blank lines to make the code look
    a little nicer.

    In other words, nothing essential.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     

18 Sep, 2008

1 commit

  • fs/ubifs/dir.c:428: warning: format '%llu' expects type 'long long
    unsigned int', but argument 5 has type 'long unsigned int'

    fs/ubifs/debug.c:541: warning: format '%llu' expects type 'long long
    unsigned int', but argument 2 has type 'long unsigned int'

    Signed-off-by: Alexander Beregalov
    Signed-off-by: Artem Bityutskiy

    Alexander Beregalov
     

17 Sep, 2008

3 commits


06 Sep, 2008

2 commits

  • UBIFS does not really work correctly when fanout is 2,
    because of the way we manage the indexing tree. It may
    just become a list and UBIFS screws up.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • If fanout is 3, we have division by zero in
    'ubifs_read_superblock()':

    divide error: 0000 [#1] PREEMPT SMP

    Pid: 28744, comm: mount Not tainted (2.6.27-rc4-ubifs-2.6 #23)
    EIP: 0060:[] EFLAGS: 00010202 CPU: 0
    EIP is at ubifs_reported_space+0x2d/0x69 [ubifs]
    EAX: 00000000 EBX: 00000000 ECX: 00000000 EDX: 00000000
    ESI: 00000000 EDI: f0ae64b0 EBP: f1f9fcf4 ESP: f1f9fce0
    DS: 007b ES: 007b FS: 00d8 GS: 0033 SS: 0068

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     

03 Sep, 2008

1 commit


31 Aug, 2008

6 commits

  • UBIFS stores 16-bit UUID in the superblock, and it is a good
    idea to return part of it in 'f_fsid' filed of kstatfs structure.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • Since free space we report in statfs is file size which should
    fit to the FS - change the way we calculate free space and use
    leb_overhead instead of dark_wm in calculations.

    Results of "freespace" test (120MiB volume, 16KiB LEB size,
    512 bytes page size). Before the change:

    freespace: Test 1: fill the space we have 3 times
    freespace: was free: 85204992 bytes 81.3 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 11284480 bytes 10.8 MiB, wrote 13.2% more than predicted
    freespace: was free: 83554304 bytes 79.7 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 12935168 bytes 12.3 MiB, wrote 15.5% more than predicted
    freespace: was free: 83554304 bytes 79.7 MiB, wrote: 96493568 bytes 92.0 MiB, delta: 12939264 bytes 12.3 MiB, wrote 15.5% more than predicted
    freespace: Test 1 finished

    freespace: Test 2: gradually lessen amount of free space and fill the FS
    freespace: do 10 steps, lessen free space by 7596218 bytes 7.2 MiB each time
    freespace: was free: 78675968 bytes 75.0 MiB, wrote: 88903680 bytes 84.8 MiB, delta: 10227712 bytes 9.8 MiB, wrote 13.0% more than predicted
    freespace: was free: 72015872 bytes 68.7 MiB, wrote: 81514496 bytes 77.7 MiB, delta: 9498624 bytes 9.1 MiB, wrote 13.2% more than predicted
    freespace: was free: 63938560 bytes 61.0 MiB, wrote: 72589312 bytes 69.2 MiB, delta: 8650752 bytes 8.2 MiB, wrote 13.5% more than predicted
    freespace: was free: 56127488 bytes 53.5 MiB, wrote: 63762432 bytes 60.8 MiB, delta: 7634944 bytes 7.3 MiB, wrote 13.6% more than predicted
    freespace: was free: 48336896 bytes 46.1 MiB, wrote: 54935552 bytes 52.4 MiB, delta: 6598656 bytes 6.3 MiB, wrote 13.7% more than predicted
    freespace: was free: 40587264 bytes 38.7 MiB, wrote: 46157824 bytes 44.0 MiB, delta: 5570560 bytes 5.3 MiB, wrote 13.7% more than predicted
    freespace: was free: 32841728 bytes 31.3 MiB, wrote: 37384192 bytes 35.7 MiB, delta: 4542464 bytes 4.3 MiB, wrote 13.8% more than predicted
    freespace: was free: 25100288 bytes 23.9 MiB, wrote: 28618752 bytes 27.3 MiB, delta: 3518464 bytes 3.4 MiB, wrote 14.0% more than predicted
    freespace: was free: 17342464 bytes 16.5 MiB, wrote: 19841024 bytes 18.9 MiB, delta: 2498560 bytes 2.4 MiB, wrote 14.4% more than predicted
    freespace: was free: 9605120 bytes 9.2 MiB, wrote: 11063296 bytes 10.6 MiB, delta: 1458176 bytes 1.4 MiB, wrote 15.2% more than predicted
    freespace: Test 2 finished

    freespace: Test 3: gradually lessen amount of free space by trashing and fill the FS
    freespace: do 10 steps, lessen free space by 7606272 bytes 7.3 MiB each time
    freespace: trashing: was free: 83668992 bytes 79.8 MiB, need free: 7606272 bytes 7.3 MiB, files created: 248297, delete 225724 (90.9% of them)
    freespace: was free: 70803456 bytes 67.5 MiB, wrote: 82485248 bytes 78.7 MiB, delta: 11681792 bytes 11.1 MiB, wrote 16.5% more than predicted
    freespace: trashing: was free: 81080320 bytes 77.3 MiB, need free: 15212544 bytes 14.5 MiB, files created: 248711, delete 202047 (81.2% of them)
    freespace: was free: 59867136 bytes 57.1 MiB, wrote: 71897088 bytes 68.6 MiB, delta: 12029952 bytes 11.5 MiB, wrote 20.1% more than predicted
    freespace: trashing: was free: 82243584 bytes 78.4 MiB, need free: 22818816 bytes 21.8 MiB, files created: 248866, delete 179817 (72.3% of them)
    freespace: was free: 50905088 bytes 48.5 MiB, wrote: 63168512 bytes 60.2 MiB, delta: 12263424 bytes 11.7 MiB, wrote 24.1% more than predicted
    freespace: trashing: was free: 83402752 bytes 79.5 MiB, need free: 30425088 bytes 29.0 MiB, files created: 248920, delete 158114 (63.5% of them)
    freespace: was free: 42651648 bytes 40.7 MiB, wrote: 55406592 bytes 52.8 MiB, delta: 12754944 bytes 12.2 MiB, wrote 29.9% more than predicted
    freespace: trashing: was free: 84402176 bytes 80.5 MiB, need free: 38031360 bytes 36.3 MiB, files created: 248709, delete 136641 (54.9% of them)
    freespace: was free: 35233792 bytes 33.6 MiB, wrote: 48250880 bytes 46.0 MiB, delta: 13017088 bytes 12.4 MiB, wrote 36.9% more than predicted
    freespace: trashing: was free: 82530304 bytes 78.7 MiB, need free: 45637632 bytes 43.5 MiB, files created: 248778, delete 111208 (44.7% of them)
    freespace: was free: 27287552 bytes 26.0 MiB, wrote: 40267776 bytes 38.4 MiB, delta: 12980224 bytes 12.4 MiB, wrote 47.6% more than predicted
    freespace: trashing: was free: 85114880 bytes 81.2 MiB, need free: 53243904 bytes 50.8 MiB, files created: 248508, delete 93052 (37.4% of them)
    freespace: was free: 22437888 bytes 21.4 MiB, wrote: 35328000 bytes 33.7 MiB, delta: 12890112 bytes 12.3 MiB, wrote 57.4% more than predicted
    freespace: trashing: was free: 84103168 bytes 80.2 MiB, need free: 60850176 bytes 58.0 MiB, files created: 248637, delete 68743 (27.6% of them)
    freespace: was free: 15536128 bytes 14.8 MiB, wrote: 28319744 bytes 27.0 MiB, delta: 12783616 bytes 12.2 MiB, wrote 82.3% more than predicted
    freespace: trashing: was free: 84357120 bytes 80.4 MiB, need free: 68456448 bytes 65.3 MiB, files created: 248567, delete 46852 (18.8% of them)
    freespace: was free: 9015296 bytes 8.6 MiB, wrote: 22044672 bytes 21.0 MiB, delta: 13029376 bytes 12.4 MiB, wrote 144.5% more than predicted
    freespace: trashing: was free: 84942848 bytes 81.0 MiB, need free: 76062720 bytes 72.5 MiB, files created: 248636, delete 25993 (10.5% of them)
    freespace: was free: 6086656 bytes 5.8 MiB, wrote: 8331264 bytes 7.9 MiB, delta: 2244608 bytes 2.1 MiB, wrote 36.9% more than predicted
    freespace: Test 3 finished

    freespace: finished successfully

    After the change:

    freespace: Test 1: fill the space we have 3 times
    freespace: was free: 94048256 bytes 89.7 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 2441216 bytes 2.3 MiB, wrote 2.6% more than predicted
    freespace: was free: 92246016 bytes 88.0 MiB, wrote: 96493568 bytes 92.0 MiB, delta: 4247552 bytes 4.1 MiB, wrote 4.6% more than predicted
    freespace: was free: 92254208 bytes 88.0 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 4235264 bytes 4.0 MiB, wrote 4.6% more than predicted
    freespace: Test 1 finished

    freespace: Test 2: gradually lessen amount of free space and fill the FS
    freespace: do 10 steps, lessen free space by 8386001 bytes 8.0 MiB each time
    freespace: was free: 86605824 bytes 82.6 MiB, wrote: 88252416 bytes 84.2 MiB, delta: 1646592 bytes 1.6 MiB, wrote 1.9% more than predicted
    freespace: was free: 78667776 bytes 75.0 MiB, wrote: 80715776 bytes 77.0 MiB, delta: 2048000 bytes 2.0 MiB, wrote 2.6% more than predicted
    freespace: was free: 69615616 bytes 66.4 MiB, wrote: 71630848 bytes 68.3 MiB, delta: 2015232 bytes 1.9 MiB, wrote 2.9% more than predicted
    freespace: was free: 61018112 bytes 58.2 MiB, wrote: 62783488 bytes 59.9 MiB, delta: 1765376 bytes 1.7 MiB, wrote 2.9% more than predicted
    freespace: was free: 52424704 bytes 50.0 MiB, wrote: 53968896 bytes 51.5 MiB, delta: 1544192 bytes 1.5 MiB, wrote 2.9% more than predicted
    freespace: was free: 43880448 bytes 41.8 MiB, wrote: 45199360 bytes 43.1 MiB, delta: 1318912 bytes 1.3 MiB, wrote 3.0% more than predicted
    freespace: was free: 35332096 bytes 33.7 MiB, wrote: 36425728 bytes 34.7 MiB, delta: 1093632 bytes 1.0 MiB, wrote 3.1% more than predicted
    freespace: was free: 26771456 bytes 25.5 MiB, wrote: 27643904 bytes 26.4 MiB, delta: 872448 bytes 852.0 KiB, wrote 3.3% more than predicted
    freespace: was free: 18231296 bytes 17.4 MiB, wrote: 18878464 bytes 18.0 MiB, delta: 647168 bytes 632.0 KiB, wrote 3.5% more than predicted
    freespace: was free: 9674752 bytes 9.2 MiB, wrote: 10088448 bytes 9.6 MiB, delta: 413696 bytes 404.0 KiB, wrote 4.3% more than predicted
    freespace: Test 2 finished

    freespace: Test 3: gradually lessen amount of free space by trashing and fill the FS
    freespace: do 10 steps, lessen free space by 8397544 bytes 8.0 MiB each time
    freespace: trashing: was free: 92372992 bytes 88.1 MiB, need free: 8397552 bytes 8.0 MiB, files created: 248296, delete 225723 (90.9% of them)
    freespace: was free: 71909376 bytes 68.6 MiB, wrote: 82472960 bytes 78.7 MiB, delta: 10563584 bytes 10.1 MiB, wrote 14.7% more than predicted
    freespace: trashing: was free: 88989696 bytes 84.9 MiB, need free: 16795096 bytes 16.0 MiB, files created: 248794, delete 201838 (81.1% of them)
    freespace: was free: 60354560 bytes 57.6 MiB, wrote: 71782400 bytes 68.5 MiB, delta: 11427840 bytes 10.9 MiB, wrote 18.9% more than predicted
    freespace: trashing: was free: 90304512 bytes 86.1 MiB, need free: 25192640 bytes 24.0 MiB, files created: 248733, delete 179342 (72.1% of them)
    freespace: was free: 51187712 bytes 48.8 MiB, wrote: 62943232 bytes 60.0 MiB, delta: 11755520 bytes 11.2 MiB, wrote 23.0% more than predicted
    freespace: trashing: was free: 91209728 bytes 87.0 MiB, need free: 33590184 bytes 32.0 MiB, files created: 248779, delete 157160 (63.2% of them)
    freespace: was free: 42704896 bytes 40.7 MiB, wrote: 55050240 bytes 52.5 MiB, delta: 12345344 bytes 11.8 MiB, wrote 28.9% more than predicted
    freespace: trashing: was free: 92700672 bytes 88.4 MiB, need free: 41987728 bytes 40.0 MiB, files created: 248848, delete 136135 (54.7% of them)
    freespace: was free: 35250176 bytes 33.6 MiB, wrote: 48115712 bytes 45.9 MiB, delta: 12865536 bytes 12.3 MiB, wrote 36.5% more than predicted
    freespace: trashing: was free: 93986816 bytes 89.6 MiB, need free: 50385272 bytes 48.1 MiB, files created: 248723, delete 115385 (46.4% of them)
    freespace: was free: 29995008 bytes 28.6 MiB, wrote: 41582592 bytes 39.7 MiB, delta: 11587584 bytes 11.1 MiB, wrote 38.6% more than predicted
    freespace: trashing: was free: 91881472 bytes 87.6 MiB, need free: 58782816 bytes 56.1 MiB, files created: 248645, delete 89569 (36.0% of them)
    freespace: was free: 22511616 bytes 21.5 MiB, wrote: 34705408 bytes 33.1 MiB, delta: 12193792 bytes 11.6 MiB, wrote 54.2% more than predicted
    freespace: trashing: was free: 91774976 bytes 87.5 MiB, need free: 67180360 bytes 64.1 MiB, files created: 248580, delete 66616 (26.8% of them)
    freespace: was free: 16908288 bytes 16.1 MiB, wrote: 26898432 bytes 25.7 MiB, delta: 9990144 bytes 9.5 MiB, wrote 59.1% more than predicted
    freespace: trashing: was free: 92450816 bytes 88.2 MiB, need free: 75577904 bytes 72.1 MiB, files created: 248654, delete 45381 (18.3% of them)
    freespace: was free: 10170368 bytes 9.7 MiB, wrote: 19111936 bytes 18.2 MiB, delta: 8941568 bytes 8.5 MiB, wrote 87.9% more than predicted
    freespace: trashing: was free: 93282304 bytes 89.0 MiB, need free: 83975448 bytes 80.1 MiB, files created: 248513, delete 24794 (10.0% of them)
    freespace: was free: 3911680 bytes 3.7 MiB, wrote: 7872512 bytes 7.5 MiB, delta: 3960832 bytes 3.8 MiB, wrote 101.3% more than predicted
    freespace: Test 3 finished

    freespace: finished successfully

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • This is a preparational patch for the following statfs()
    report fix.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • We add this component at other similar places, but not in this
    one.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • The assertion was incorrect, because it did not take into
    account free space.

    This patch also amends the comments correspondingly, and
    cleans them up a little.

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy
     
  • Make free space calculation less pessimistic and more realistic,
    which in turn improves 'statfs()' reports. Now it lies by 10%-20%,
    instead of 20%-30% (10% more honest).

    Results of "freespace" test (120MiB volume, 16KiB LEB size,
    512 bytes page size). Before the change:

    freespace: Test 1: fill the space we have 3 times
    freespace: was free: 78274560 bytes 74.6 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 18214912 bytes 17.4 MiB, wrote 23.3% more than predicted
    freespace: was free: 76754944 bytes 73.2 MiB, wrote: 96493568 bytes 92.0 MiB, delta: 19738624 bytes 18.8 MiB, wrote 25.7% more than predicted
    freespace: was free: 76759040 bytes 73.2 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 19730432 bytes 18.8 MiB, wrote 25.7% more than predicted
    freespace: Test 1 finished

    freespace: Test 2: gradually lessen amount of free space and fill the FS
    freespace: do 10 steps, lessen free space by 6977722 bytes 6.7 MiB each time
    freespace: was free: 72273920 bytes 68.9 MiB, wrote: 88891392 bytes 84.8 MiB, delta: 16617472 bytes 15.8 MiB, wrote 23.0% more than predicted
    freespace: was free: 66154496 bytes 63.1 MiB, wrote: 81506304 bytes 77.7 MiB, delta: 15351808 bytes 14.6 MiB, wrote 23.2% more than predicted
    freespace: was free: 58732544 bytes 56.0 MiB, wrote: 72572928 bytes 69.2 MiB, delta: 13840384 bytes 13.2 MiB, wrote 23.6% more than predicted
    freespace: was free: 51552256 bytes 49.2 MiB, wrote: 63754240 bytes 60.8 MiB, delta: 12201984 bytes 11.6 MiB, wrote 23.7% more than predicted
    freespace: was free: 44404736 bytes 42.3 MiB, wrote: 54943744 bytes 52.4 MiB, delta: 10539008 bytes 10.1 MiB, wrote 23.7% more than predicted
    freespace: was free: 37285888 bytes 35.6 MiB, wrote: 46161920 bytes 44.0 MiB, delta: 8876032 bytes 8.5 MiB, wrote 23.8% more than predicted
    freespace: was free: 30171136 bytes 28.8 MiB, wrote: 37384192 bytes 35.7 MiB, delta: 7213056 bytes 6.9 MiB, wrote 23.9% more than predicted
    freespace: was free: 23048192 bytes 22.0 MiB, wrote: 28606464 bytes 27.3 MiB, delta: 5558272 bytes 5.3 MiB, wrote 24.1% more than predicted
    freespace: was free: 15941632 bytes 15.2 MiB, wrote: 19828736 bytes 18.9 MiB, delta: 3887104 bytes 3.7 MiB, wrote 24.4% more than predicted
    freespace: was free: 8830976 bytes 8.4 MiB, wrote: 11063296 bytes 10.6 MiB, delta: 2232320 bytes 2.1 MiB, wrote 25.3% more than predicted
    freespace: Test 2 finished

    freespace: Test 3: gradually lessen amount of free space by trashing and fill the FS
    freespace: do 10 steps, lessen free space by 6985541 bytes 6.7 MiB each time
    freespace: trashing: was free: 76840960 bytes 73.3 MiB, need free: 6985550 bytes 6.7 MiB, files created: 248311, delete 225737 (90.9% of them)
    freespace: was free: 65228800 bytes 62.2 MiB, wrote: 82530304 bytes 78.7 MiB, delta: 17301504 bytes 16.5 MiB, wrote 26.5% more than predicted
    freespace: trashing: was free: 74485760 bytes 71.0 MiB, need free: 13971091 bytes 13.3 MiB, files created: 248712, delete 202061 (81.2% of them)
    freespace: was free: 55025664 bytes 52.5 MiB, wrote: 71925760 bytes 68.6 MiB, delta: 16900096 bytes 16.1 MiB, wrote 30.7% more than predicted
    freespace: trashing: was free: 75550720 bytes 72.1 MiB, need free: 20956632 bytes 20.0 MiB, files created: 248849, delete 179822 (72.3% of them)
    freespace: was free: 46669824 bytes 44.5 MiB, wrote: 63197184 bytes 60.3 MiB, delta: 16527360 bytes 15.8 MiB, wrote 35.4% more than predicted
    freespace: trashing: was free: 76214272 bytes 72.7 MiB, need free: 27942173 bytes 26.6 MiB, files created: 248789, delete 157576 (63.3% of them)
    freespace: was free: 39129088 bytes 37.3 MiB, wrote: 55164928 bytes 52.6 MiB, delta: 16035840 bytes 15.3 MiB, wrote 41.0% more than predicted
    freespace: trashing: was free: 77398016 bytes 73.8 MiB, need free: 34927714 bytes 33.3 MiB, files created: 248711, delete 136474 (54.9% of them)
    freespace: was free: 32325632 bytes 30.8 MiB, wrote: 48234496 bytes 46.0 MiB, delta: 15908864 bytes 15.2 MiB, wrote 49.2% more than predicted
    freespace: trashing: was free: 75796480 bytes 72.3 MiB, need free: 41913255 bytes 40.0 MiB, files created: 248674, delete 111164 (44.7% of them)
    freespace: was free: 25079808 bytes 23.9 MiB, wrote: 40775680 bytes 38.9 MiB, delta: 15695872 bytes 15.0 MiB, wrote 62.6% more than predicted
    freespace: trashing: was free: 78209024 bytes 74.6 MiB, need free: 48898796 bytes 46.6 MiB, files created: 248708, delete 93207 (37.5% of them)
    freespace: was free: 20582400 bytes 19.6 MiB, wrote: 34844672 bytes 33.2 MiB, delta: 14262272 bytes 13.6 MiB, wrote 69.3% more than predicted
    freespace: trashing: was free: 77328384 bytes 73.7 MiB, need free: 55884337 bytes 53.3 MiB, files created: 248644, delete 68951 (27.7% of them)
    freespace: was free: 14368768 bytes 13.7 MiB, wrote: 28278784 bytes 27.0 MiB, delta: 13910016 bytes 13.3 MiB, wrote 96.8% more than predicted
    freespace: trashing: was free: 77434880 bytes 73.8 MiB, need free: 62869878 bytes 60.0 MiB, files created: 248640, delete 46767 (18.8% of them)
    freespace: was free: 8286208 bytes 7.9 MiB, wrote: 21811200 bytes 20.8 MiB, delta: 13524992 bytes 12.9 MiB, wrote 163.2% more than predicted
    freespace: trashing: was free: 77856768 bytes 74.2 MiB, need free: 69855419 bytes 66.6 MiB, files created: 248576, delete 25546 (10.3% of them)
    freespace: was free: 5570560 bytes 5.3 MiB, wrote: 8187904 bytes 7.8 MiB, delta: 2617344 bytes 2.5 MiB, wrote 47.0% more than predicted
    freespace: Test 3 finished

    freespace: finished successfully

    After the change:

    freespace: Test 1: fill the space we have 3 times
    freespace: was free: 85204992 bytes 81.3 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 11284480 bytes 10.8 MiB, wrote 13.2% more than predicted
    freespace: was free: 83554304 bytes 79.7 MiB, wrote: 96489472 bytes 92.0 MiB, delta: 12935168 bytes 12.3 MiB, wrote 15.5% more than predicted
    freespace: was free: 83554304 bytes 79.7 MiB, wrote: 96493568 bytes 92.0 MiB, delta: 12939264 bytes 12.3 MiB, wrote 15.5% more than predicted
    freespace: Test 1 finished

    freespace: Test 2: gradually lessen amount of free space and fill the FS
    freespace: do 10 steps, lessen free space by 7596218 bytes 7.2 MiB each time
    freespace: was free: 78675968 bytes 75.0 MiB, wrote: 88903680 bytes 84.8 MiB, delta: 10227712 bytes 9.8 MiB, wrote 13.0% more than predicted
    freespace: was free: 72015872 bytes 68.7 MiB, wrote: 81514496 bytes 77.7 MiB, delta: 9498624 bytes 9.1 MiB, wrote 13.2% more than predicted
    freespace: was free: 63938560 bytes 61.0 MiB, wrote: 72589312 bytes 69.2 MiB, delta: 8650752 bytes 8.2 MiB, wrote 13.5% more than predicted
    freespace: was free: 56127488 bytes 53.5 MiB, wrote: 63762432 bytes 60.8 MiB, delta: 7634944 bytes 7.3 MiB, wrote 13.6% more than predicted
    freespace: was free: 48336896 bytes 46.1 MiB, wrote: 54935552 bytes 52.4 MiB, delta: 6598656 bytes 6.3 MiB, wrote 13.7% more than predicted
    freespace: was free: 40587264 bytes 38.7 MiB, wrote: 46157824 bytes 44.0 MiB, delta: 5570560 bytes 5.3 MiB, wrote 13.7% more than predicted
    freespace: was free: 32841728 bytes 31.3 MiB, wrote: 37384192 bytes 35.7 MiB, delta: 4542464 bytes 4.3 MiB, wrote 13.8% more than predicted
    freespace: was free: 25100288 bytes 23.9 MiB, wrote: 28618752 bytes 27.3 MiB, delta: 3518464 bytes 3.4 MiB, wrote 14.0% more than predicted
    freespace: was free: 17342464 bytes 16.5 MiB, wrote: 19841024 bytes 18.9 MiB, delta: 2498560 bytes 2.4 MiB, wrote 14.4% more than predicted
    freespace: was free: 9605120 bytes 9.2 MiB, wrote: 11063296 bytes 10.6 MiB, delta: 1458176 bytes 1.4 MiB, wrote 15.2% more than predicted
    freespace: Test 2 finished

    freespace: Test 3: gradually lessen amount of free space by trashing and fill the FS
    freespace: do 10 steps, lessen free space by 7606272 bytes 7.3 MiB each time
    freespace: trashing: was free: 83668992 bytes 79.8 MiB, need free: 7606272 bytes 7.3 MiB, files created: 248297, delete 225724 (90.9% of them)
    freespace: was free: 70803456 bytes 67.5 MiB, wrote: 82485248 bytes 78.7 MiB, delta: 11681792 bytes 11.1 MiB, wrote 16.5% more than predicted
    freespace: trashing: was free: 81080320 bytes 77.3 MiB, need free: 15212544 bytes 14.5 MiB, files created: 248711, delete 202047 (81.2% of them)
    freespace: was free: 59867136 bytes 57.1 MiB, wrote: 71897088 bytes 68.6 MiB, delta: 12029952 bytes 11.5 MiB, wrote 20.1% more than predicted
    freespace: trashing: was free: 82243584 bytes 78.4 MiB, need free: 22818816 bytes 21.8 MiB, files created: 248866, delete 179817 (72.3% of them)
    freespace: was free: 50905088 bytes 48.5 MiB, wrote: 63168512 bytes 60.2 MiB, delta: 12263424 bytes 11.7 MiB, wrote 24.1% more than predicted
    freespace: trashing: was free: 83402752 bytes 79.5 MiB, need free: 30425088 bytes 29.0 MiB, files created: 248920, delete 158114 (63.5% of them)
    freespace: was free: 42651648 bytes 40.7 MiB, wrote: 55406592 bytes 52.8 MiB, delta: 12754944 bytes 12.2 MiB, wrote 29.9% more than predicted
    freespace: trashing: was free: 84402176 bytes 80.5 MiB, need free: 38031360 bytes 36.3 MiB, files created: 248709, delete 136641 (54.9% of them)
    freespace: was free: 35233792 bytes 33.6 MiB, wrote: 48250880 bytes 46.0 MiB, delta: 13017088 bytes 12.4 MiB, wrote 36.9% more than predicted
    freespace: trashing: was free: 82530304 bytes 78.7 MiB, need free: 45637632 bytes 43.5 MiB, files created: 248778, delete 111208 (44.7% of them)
    freespace: was free: 27287552 bytes 26.0 MiB, wrote: 40267776 bytes 38.4 MiB, delta: 12980224 bytes 12.4 MiB, wrote 47.6% more than predicted
    freespace: trashing: was free: 85114880 bytes 81.2 MiB, need free: 53243904 bytes 50.8 MiB, files created: 248508, delete 93052 (37.4% of them)
    freespace: was free: 22437888 bytes 21.4 MiB, wrote: 35328000 bytes 33.7 MiB, delta: 12890112 bytes 12.3 MiB, wrote 57.4% more than predicted
    freespace: trashing: was free: 84103168 bytes 80.2 MiB, need free: 60850176 bytes 58.0 MiB, files created: 248637, delete 68743 (27.6% of them)
    freespace: was free: 15536128 bytes 14.8 MiB, wrote: 28319744 bytes 27.0 MiB, delta: 12783616 bytes 12.2 MiB, wrote 82.3% more than predicted
    freespace: trashing: was free: 84357120 bytes 80.4 MiB, need free: 68456448 bytes 65.3 MiB, files created: 248567, delete 46852 (18.8% of them)
    freespace: was free: 9015296 bytes 8.6 MiB, wrote: 22044672 bytes 21.0 MiB, delta: 13029376 bytes 12.4 MiB, wrote 144.5% more than predicted
    freespace: trashing: was free: 84942848 bytes 81.0 MiB, need free: 76062720 bytes 72.5 MiB, files created: 248636, delete 25993 (10.5% of them)
    freespace: was free: 6086656 bytes 5.8 MiB, wrote: 8331264 bytes 7.9 MiB, delta: 2244608 bytes 2.1 MiB, wrote 36.9% more than predicted
    freespace: Test 3 finished

    freespace: finished successfully

    Signed-off-by: Artem Bityutskiy

    Artem Bityutskiy