md/lock: ensure updates to page_attrs are properly locked.
authorNeilBrown <neilb@suse.de>
Tue, 22 Nov 2011 23:18:52 +0000 (10:18 +1100)
committerNeilBrown <neilb@suse.de>
Tue, 22 Nov 2011 23:18:52 +0000 (10:18 +1100)
commit7c8f4247986bb5c5fb1d5b1fad35461989fe8310
tree2c76f387184ac0cc587e66519536fc83e0f79553
parent257a4b42af7586fab4eaec7f04e6896b86551843
md/lock: ensure updates to page_attrs are properly locked.

Page attributes are set using __set_bit rather than set_bit as
it normally called under a spinlock so the extra atomicity is not
needed.

However there are two places where we might set or clear page
attributes without holding the spinlock.
So add the spinlock in those cases.

This might be the cause of occasional reports that bits a aren't
getting clear properly - theory is that BITMAP_PAGE_PENDING gets lost
when BITMAP_PAGE_NEEDWRITE is set or cleared.  This is an
inconvenience, not a threat to data safety.

Signed-off-by: NeilBrown <neilb@suse.de>
drivers/md/bitmap.c