Message ID | 1387206223-1670-1-git-send-email-steve.capper@linaro.org (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Mon, Dec 16, 2013 at 03:03:43PM +0000, Steve Capper wrote: > When given a compound high page, __flush_dcache_page will only flush > the first page of the compound page repeatedly rather than the entire > set of constituent pages. > > This patch corrects the logic such that all constituent pages are now > flushed. Since this probably wants to go to -stable, it's worth mentioning the commit which introduced it in the commit text. > Signed-off-by: Steve Capper <steve.capper@linaro.org> > --- > V2: style change use page + i rather than separate struct *cpage > --- Acked-by: Will Deacon <will.deacon@arm.com> Cheers Steve. Will
On Mon, Dec 16, 2013 at 03:54:04PM +0000, Will Deacon wrote: > On Mon, Dec 16, 2013 at 03:03:43PM +0000, Steve Capper wrote: > > When given a compound high page, __flush_dcache_page will only flush > > the first page of the compound page repeatedly rather than the entire > > set of constituent pages. > > > > This patch corrects the logic such that all constituent pages are now > > flushed. > > Since this probably wants to go to -stable, it's worth mentioning the commit > which introduced it in the commit text. > > > Signed-off-by: Steve Capper <steve.capper@linaro.org> > > --- > > V2: style change use page + i rather than separate struct *cpage > > --- > > Acked-by: Will Deacon <will.deacon@arm.com> > > Cheers Steve. > > Will Ta Will, That's in Russell's system as: 7923/1
diff --git a/arch/arm/mm/flush.c b/arch/arm/mm/flush.c index 6d5ba9a..3387e60 100644 --- a/arch/arm/mm/flush.c +++ b/arch/arm/mm/flush.c @@ -175,16 +175,16 @@ void __flush_dcache_page(struct address_space *mapping, struct page *page) unsigned long i; if (cache_is_vipt_nonaliasing()) { for (i = 0; i < (1 << compound_order(page)); i++) { - void *addr = kmap_atomic(page); + void *addr = kmap_atomic(page + i); __cpuc_flush_dcache_area(addr, PAGE_SIZE); kunmap_atomic(addr); } } else { for (i = 0; i < (1 << compound_order(page)); i++) { - void *addr = kmap_high_get(page); + void *addr = kmap_high_get(page + i); if (addr) { __cpuc_flush_dcache_area(addr, PAGE_SIZE); - kunmap_high(page); + kunmap_high(page + i); } } }
When given a compound high page, __flush_dcache_page will only flush the first page of the compound page repeatedly rather than the entire set of constituent pages. This patch corrects the logic such that all constituent pages are now flushed. Signed-off-by: Steve Capper <steve.capper@linaro.org> --- V2: style change use page + i rather than separate struct *cpage --- arch/arm/mm/flush.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-)