fix dead lock in volume store dereference

Signed-off-by: Pei Su <sillyousu@gmail.com>
This commit is contained in:
Pei Su 2016-01-27 16:34:10 +08:00 committed by Tibor Vass
parent b6ea29fad3
commit 5dd0e5acb0
1 changed files with 1 additions and 1 deletions

View File

@ -293,6 +293,7 @@ func (s *VolumeStore) Dereference(v volume.Volume, ref string) {
defer s.locks.Unlock(v.Name())
s.globalLock.Lock()
defer s.globalLock.Unlock()
refs, exists := s.refs[v.Name()]
if !exists {
return
@ -303,7 +304,6 @@ func (s *VolumeStore) Dereference(v volume.Volume, ref string) {
s.refs[v.Name()] = append(s.refs[v.Name()][:i], s.refs[v.Name()][i+1:]...)
}
}
s.globalLock.Unlock()
}
// Refs gets the current list of refs for the given volume