Commit c7a6d35e authored by Shaohua Li's avatar Shaohua Li Committed by NeilBrown

raid5: fix a race of stripe count check

I hit another BUG_ON with e240c183. In __get_priority_stripe(),
stripe count equals to 0 initially. Between atomic_inc and BUG_ON,
get_active_stripe() finds the stripe. So the stripe count isn't 1 any more.

V2: keeps the BUG_ON suggested by Neil.
Signed-off-by: default avatarShaohua Li <shli@fusionio.com>
Signed-off-by: default avatarNeilBrown <neilb@suse.de>
parent e240c183
...@@ -4370,8 +4370,7 @@ static struct stripe_head *__get_priority_stripe(struct r5conf *conf, int group) ...@@ -4370,8 +4370,7 @@ static struct stripe_head *__get_priority_stripe(struct r5conf *conf, int group)
sh->group = NULL; sh->group = NULL;
} }
list_del_init(&sh->lru); list_del_init(&sh->lru);
atomic_inc(&sh->count); BUG_ON(atomic_inc_return(&sh->count) != 1);
BUG_ON(atomic_read(&sh->count) != 1);
return sh; return sh;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment