Partial cacheline flush problems on ARM and MIPS

Ian Lepore freebsd at damnhippie.dyndns.org
Tue Aug 28 14:31:28 UTC 2012


On Mon, 2012-08-27 at 09:57 -0600, Warner Losh wrote:
> >> I don't think the cache line problem can be solved with bounce
> buffers.  Trying to accommodate broken drivers is what lead us to this
> spot.  We need to fix the broken drivers.  If that's impossible, then
> the best we can do is have the driver set a 'always bounce' flag in
> the tag it creates and use that to always bounce for operations
> through that tag.
> > 
> > So you'd be okay with a driver setting a flag that says "always
> bounce"
> > but not okay with the busdma layer bouncing only when it's actually
> > necessary?  I'm confused -- do you think the busdma layer will be
> unable
> > to detect when it's necessary unless directed from the outside?
> 
> Actually, it is good you are confused.  I was wrong when I said I'd be
> happy with a flag that says always bounce. The reason is that the
> driver can do this all the time for those cases like the at91 mci
> driver does. 

After studying the busdma implementation code and pondering this some
more, I now understand why the automatic bouncing that I think is the
ideal solution to this is so hard to accomplish.  I'm not sure
"Impossible" is the right description, but I'm afraid that in the long
run "impractical" might turn out to be the case.  I'm going to think all
this over for a few days, maybe do a bit of actual paying work, before
revisiting it.

-- Ian



More information about the freebsd-arm mailing list