mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-10-31 08:44:41 +00:00 
			
		
		
		
	Drivers: hv: vmbus: release relid on error in vmbus_process_offer()
We want to simplify vmbus_onoffer_rescind() by not invoking hv_process_channel_removal(NULL, ...). Signed-off-by: Dexuan Cui <decui@microsoft.com> Signed-off-by: K. Y. Srinivasan <kys@microsoft.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
		
							parent
							
								
									34c6801e33
								
							
						
					
					
						commit
						f52078cf57
					
				
					 1 changed files with 15 additions and 6 deletions
				
			
		|  | @ -177,19 +177,22 @@ static void percpu_channel_deq(void *arg) | |||
| } | ||||
| 
 | ||||
| 
 | ||||
| void hv_process_channel_removal(struct vmbus_channel *channel, u32 relid) | ||||
| static void vmbus_release_relid(u32 relid) | ||||
| { | ||||
| 	struct vmbus_channel_relid_released msg; | ||||
| 	unsigned long flags; | ||||
| 	struct vmbus_channel *primary_channel; | ||||
| 
 | ||||
| 	memset(&msg, 0, sizeof(struct vmbus_channel_relid_released)); | ||||
| 	msg.child_relid = relid; | ||||
| 	msg.header.msgtype = CHANNELMSG_RELID_RELEASED; | ||||
| 	vmbus_post_msg(&msg, sizeof(struct vmbus_channel_relid_released)); | ||||
| } | ||||
| 
 | ||||
| 	if (channel == NULL) | ||||
| 		return; | ||||
| void hv_process_channel_removal(struct vmbus_channel *channel, u32 relid) | ||||
| { | ||||
| 	unsigned long flags; | ||||
| 	struct vmbus_channel *primary_channel; | ||||
| 
 | ||||
| 	vmbus_release_relid(relid); | ||||
| 
 | ||||
| 	BUG_ON(!channel->rescind); | ||||
| 
 | ||||
|  | @ -336,6 +339,8 @@ static void vmbus_process_offer(struct vmbus_channel *newchannel) | |||
| 	return; | ||||
| 
 | ||||
| err_deq_chan: | ||||
| 	vmbus_release_relid(newchannel->offermsg.child_relid); | ||||
| 
 | ||||
| 	spin_lock_irqsave(&vmbus_connection.channel_lock, flags); | ||||
| 	list_del(&newchannel->listentry); | ||||
| 	spin_unlock_irqrestore(&vmbus_connection.channel_lock, flags); | ||||
|  | @ -587,7 +592,11 @@ static void vmbus_onoffer_rescind(struct vmbus_channel_message_header *hdr) | |||
| 	channel = relid2channel(rescind->child_relid); | ||||
| 
 | ||||
| 	if (channel == NULL) { | ||||
| 		hv_process_channel_removal(NULL, rescind->child_relid); | ||||
| 		/*
 | ||||
| 		 * This is very impossible, because in | ||||
| 		 * vmbus_process_offer(), we have already invoked | ||||
| 		 * vmbus_release_relid() on error. | ||||
| 		 */ | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Dexuan Cui
						Dexuan Cui