net: wireless: wcn36xx: fix potential NULL pointer dereference
If kmalloc fails wcn36xx_smd_rsp_process will attempt to dereference a NULL pointer. There might be a better error recovery then just printing an error, but printing an error message is better then the current behaviour. Signed-off-by: Michal Nazarewicz <mina86@mina86.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
		
					parent
					
						
							
								beae416b1f
							
						
					
				
			
			
				commit
				
					
						3469adb36c
					
				
			
		
					 1 changed files with 13 additions and 6 deletions
				
			
		|  | @ -2041,13 +2041,20 @@ static void wcn36xx_smd_rsp_process(struct wcn36xx *wcn, void *buf, size_t len) | |||
| 	case WCN36XX_HAL_DELETE_STA_CONTEXT_IND: | ||||
| 		mutex_lock(&wcn->hal_ind_mutex); | ||||
| 		msg_ind = kmalloc(sizeof(*msg_ind), GFP_KERNEL); | ||||
| 		msg_ind->msg_len = len; | ||||
| 		msg_ind->msg = kmalloc(len, GFP_KERNEL); | ||||
| 		memcpy(msg_ind->msg, buf, len); | ||||
| 		list_add_tail(&msg_ind->list, &wcn->hal_ind_queue); | ||||
| 		queue_work(wcn->hal_ind_wq, &wcn->hal_ind_work); | ||||
| 		wcn36xx_dbg(WCN36XX_DBG_HAL, "indication arrived\n"); | ||||
| 		if (msg_ind) { | ||||
| 			msg_ind->msg_len = len; | ||||
| 			msg_ind->msg = kmalloc(len, GFP_KERNEL); | ||||
| 			memcpy(msg_ind->msg, buf, len); | ||||
| 			list_add_tail(&msg_ind->list, &wcn->hal_ind_queue); | ||||
| 			queue_work(wcn->hal_ind_wq, &wcn->hal_ind_work); | ||||
| 			wcn36xx_dbg(WCN36XX_DBG_HAL, "indication arrived\n"); | ||||
| 		} | ||||
| 		mutex_unlock(&wcn->hal_ind_mutex); | ||||
| 		if (msg_ind) | ||||
| 			break; | ||||
| 		/* FIXME: Do something smarter then just printing an error. */ | ||||
| 		wcn36xx_err("Run out of memory while handling SMD_EVENT (%d)\n", | ||||
| 			    msg_header->msg_type); | ||||
| 		break; | ||||
| 	default: | ||||
| 		wcn36xx_err("SMD_EVENT (%d) not supported\n", | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Michal Nazarewicz
				Michal Nazarewicz