• Rainer Fiebig's avatar
    PM: hibernate: Do not subtract NR_FILE_MAPPED in minimum_image_size() · bdbc98ab
    Rainer Fiebig authored
    s2disk/s2both may fail unnecessarily and erratically if NR_FILE_MAPPED
    is high - for instance when using VMs with VirtualBox and perhaps VMware
    Player. In those situations s2disk becomes unreliable and therefore
    unusable.
    
    A typical scenario is: user issues a s2disk and it fails. User issues
    a second s2disk immediately after that and it succeeds.  And user
    wonders why.
    
    The problem is caused by minimum_image_size() in snapshot.c.  The
    value it returns is roughly 100% too high because NR_FILE_MAPPED is
    subtracted in its calculation.  Eventually the number of preallocated
    image pages is falsely too low.
    
    This doesn't matter as long as NR_FILE_MAPPED-values are in a normal
    range or in 32bit-environments as the code allows for allocation of
    additional pages from highmem.
    
    But with the high values generated by VirtualBox-VMs (a 2-GB-VM causes
    NR_FILE_MAPPED go up by 2 GB) it may lead to failure in 64bit-systems.
    
    Not subtracting NR_FILE_MAPPED in minimum_image_size() solves the
    problem.
    
    I've done at least hundreds of successful s2both/s2disk now on an
    x86_64 system (with and without VirtualBox) which gives me some
    confidence that this is right.  It has turned s2disk/s2both from
    unusable into 100% reliable.
    
    Link: https://bugzilla.kernel.org/show_bug.cgi?id=97201Signed-off-by: default avatarRainer Fiebig <jrf@mailbox.org>
    Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
    bdbc98ab
snapshot.c 71.5 KB