On Fri, Sep 20, 2013 at 09:54:07AM -0700, Darrick J. Wong wrote:
> On Fri, Sep 20, 2013 at 09:28:07AM +0100, Mel Gorman wrote:
> > On Fri, Sep 20, 2013 at 09:06:37AM +0100, Mel Gorman wrote:
> > > On Thu, Sep 19, 2013 at 08:06:02PM -0700, Darrick J. Wong wrote:
> > > > The "force" parameter in __blk_queue_bounce was being ignored, which 
> > > > means that
> > > > stable page snapshots are not always happening (on ext3).  This of 
> > > > course
> > > > leads to DIF disks reporting checksum errors, so fix this regression.
> > > > 
> > > > The regression was introduced in commit 6bc454d1 (bounce: Refactor
> > > > __blk_queue_bounce to not use bi_io_vec)
> > > > 
> > > > Reported-by: Mel Gorman <mgor...@suse.de>
> > > > Signed-off-by: Darrick J. Wong <darrick.w...@oracle.com>
> > > 
> > > I have no means of testing it but it looks right and thanks for checking
> > > DIF disks.
> > > 
> > > Acked-by: Mel Gorman <mgor...@suse.de>
> > > 
> > 
> > That said the two checks are now redundant. They could just be deleted
> > and depend entirely on the following check within the loop
> > 
> >                 if (page_to_pfn(page) <= queue_bounce_pfn(q) && !force)
> >                         continue;
> > 
> > with an update to the comment explaining that the check is for pages
> > below the bounce pfn or for bios that require stable writes
> 
> I'm under the impression that the point of the first looping-check is to avoid
> the bio_clone_bioset() if we're not going to bounce anything.  But I could be
> wrong. 

I doubt it, avoiding the clone makes sense and I was wrong about the
check being redundant anyway. Trying to do the clone within the loop
when the first bio that needs bouncing is encountered turns into a
mess.

-- 
Mel Gorman
SUSE Labs
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to