dlm: adopt orphan locks
A process may exit, leaving an orphan lock in the lockspace. This adds the capability for another process to acquire the orphan lock. Acquiring the orphan just moves the lock from the orphan list onto the acquiring process's list of locks. An adopting process must specify the resource name and mode of the lock it wants to adopt. If a matching lock is found, the lock is moved to the caller's 's list of locks, and the lkid of the lock is returned like the lkid of a new lock. If an orphan with a different mode is found, then -EAGAIN is returned. If no orphan lock is found on the resource, then -ENOENT is returned. No async completion is used because the result is immediately available. Also, when orphans are purged, allow a zero nodeid to refer to the local nodeid so the caller does not need to look up the local nodeid. Signed-off-by: David Teigland <teigland@redhat.com>
This commit is contained in:
		
					parent
					
						
							
								206c5f60a3
							
						
					
				
			
			
				commit
				
					
						2ab4bd8ea3
					
				
			
		
					 4 changed files with 89 additions and 5 deletions
				
			
		|  | @ -114,7 +114,7 @@ | |||
|  * | ||||
|  * DLM_LKF_ORPHAN | ||||
|  * | ||||
|  * not yet implemented | ||||
|  * Acquire an orphan lock. | ||||
|  * | ||||
|  * DLM_LKF_ALTPR | ||||
|  * | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Teigland
				David Teigland