mirror of
https://git.openafs.org/openafs.git
synced 2025-01-19 07:20:11 +00:00
VOL_LOCK needed when traversing DiskPartitionList
VLockPartition sets VOL_LOCK, opens (perhaps creating) the lock file for a partition, and flock's it. VUnlockPartition, sets VOL_LOCK, and closes the lock file fd. VLockPartition is called from the salvager. Nothing ever calls VUnlockPartition. VPFullUnlock is called every 30 seconds, does NOT set VOL_LOCK, and happily closes any lock file fd it finds, breaking any lock set with flock. Other routines use the VOL_LOCK when traversing DiskPartitionList. Change-Id: I683547f574b1f760e72014f5d44ce3987f07b5df Reviewed-on: http://gerrit.openafs.org/1213 Reviewed-by: Dan Hyde <drh@umich.edu> Tested-by: Dan Hyde <drh@umich.edu> Reviewed-by: Derrick Brashear <shadow@dementia.org> Tested-by: Derrick Brashear <shadow@dementia.org>
This commit is contained in:
parent
028240329c
commit
105481d334
@ -134,7 +134,7 @@ static afs_int32 VolSetDate(struct rx_call *, afs_int32, afs_int32);
|
||||
|
||||
/* this call unlocks all of the partition locks we've set */
|
||||
int
|
||||
VPFullUnlock(void)
|
||||
VPFullUnlock_r(void)
|
||||
{
|
||||
register struct DiskPartition64 *tp;
|
||||
for (tp = DiskPartitionList; tp; tp = tp->next) {
|
||||
@ -146,6 +146,16 @@ VPFullUnlock(void)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int
|
||||
VPFullUnlock(void)
|
||||
{
|
||||
int code;
|
||||
VOL_LOCK;
|
||||
code = VPFullUnlock_r();
|
||||
VOL_UNLOCK;
|
||||
return code;
|
||||
}
|
||||
|
||||
/* get partition id from a name */
|
||||
afs_int32
|
||||
PartitionID(char *aname)
|
||||
|
Loading…
Reference in New Issue
Block a user