As comment says, we should handle unaligned range rather than aligned
one.  This fixes a bug found by running xfstests #91.
Signed-off-by: Yongqiang Yang <xiaoqiangnk@gmail.com>
                 * to be updated with the contents of the block before
                 * we write the zeros on top of it.
                 */
-               if (!(from & (blocksize - 1)) ||
-                   !((from + length) & (blocksize - 1))) {
+               if ((from & (blocksize - 1)) ||
+                   ((from + length) & (blocksize - 1))) {
                        create_empty_buffers(page, blocksize, 0);
                } else {
                        /*