PeerKey: Clean up EAPOL-Key Key Data processing on AP
This extends the earlier PeerKey station side design to be used on the AP side as well by passing pointer and already validated length from the caller rather than parsing the length again from the frame buffer. This avoids false warnings from static analyzer (CID 62870, CID 62871, CID 62872). Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
		
							parent
							
								
									d36f416926
								
							
						
					
					
						commit
						5c6787a6ca
					
				
					 3 changed files with 21 additions and 15 deletions
				
			
		|  | @ -79,15 +79,15 @@ static void wpa_smk_send_error(struct wpa_authenticator *wpa_auth, | |||
| 
 | ||||
| 
 | ||||
| void wpa_smk_m1(struct wpa_authenticator *wpa_auth, | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key) | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key, | ||||
| 		const u8 *key_data, size_t key_data_len) | ||||
| { | ||||
| 	struct wpa_eapol_ie_parse kde; | ||||
| 	struct wpa_stsl_search search; | ||||
| 	u8 *buf, *pos; | ||||
| 	size_t buf_len; | ||||
| 
 | ||||
| 	if (wpa_parse_kde_ies((const u8 *) (key + 1), | ||||
| 			      WPA_GET_BE16(key->key_data_length), &kde) < 0) { | ||||
| 	if (wpa_parse_kde_ies(key_data, key_data_len, &kde) < 0) { | ||||
| 		wpa_printf(MSG_INFO, "RSN: Failed to parse KDEs in SMK M1"); | ||||
| 		return; | ||||
| 	} | ||||
|  | @ -253,14 +253,14 @@ static void wpa_send_smk_m5(struct wpa_authenticator *wpa_auth, | |||
| 
 | ||||
| 
 | ||||
| void wpa_smk_m3(struct wpa_authenticator *wpa_auth, | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key) | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key, | ||||
| 		const u8 *key_data, size_t key_data_len) | ||||
| { | ||||
| 	struct wpa_eapol_ie_parse kde; | ||||
| 	struct wpa_stsl_search search; | ||||
| 	u8 smk[32], buf[ETH_ALEN + 8 + 2 * WPA_NONCE_LEN], *pos; | ||||
| 
 | ||||
| 	if (wpa_parse_kde_ies((const u8 *) (key + 1), | ||||
| 			      WPA_GET_BE16(key->key_data_length), &kde) < 0) { | ||||
| 	if (wpa_parse_kde_ies(key_data, key_data_len, &kde) < 0) { | ||||
| 		wpa_printf(MSG_INFO, "RSN: Failed to parse KDEs in SMK M3"); | ||||
| 		return; | ||||
| 	} | ||||
|  | @ -324,15 +324,15 @@ void wpa_smk_m3(struct wpa_authenticator *wpa_auth, | |||
| 
 | ||||
| 
 | ||||
| void wpa_smk_error(struct wpa_authenticator *wpa_auth, | ||||
| 		   struct wpa_state_machine *sm, struct wpa_eapol_key *key) | ||||
| 		   struct wpa_state_machine *sm, | ||||
| 		   const u8 *key_data, size_t key_data_len) | ||||
| { | ||||
| 	struct wpa_eapol_ie_parse kde; | ||||
| 	struct wpa_stsl_search search; | ||||
| 	struct rsn_error_kde error; | ||||
| 	u16 mui, error_type; | ||||
| 
 | ||||
| 	if (wpa_parse_kde_ies((const u8 *) (key + 1), | ||||
| 			      WPA_GET_BE16(key->key_data_length), &kde) < 0) { | ||||
| 	if (wpa_parse_kde_ies(key_data, key_data_len, &kde) < 0) { | ||||
| 		wpa_printf(MSG_INFO, "RSN: Failed to parse KDEs in SMK Error"); | ||||
| 		return; | ||||
| 	} | ||||
|  |  | |||
|  | @ -1239,7 +1239,8 @@ continue_processing: | |||
| 		 */ | ||||
| 		if (msg == SMK_ERROR) { | ||||
| #ifdef CONFIG_PEERKEY | ||||
| 			wpa_smk_error(wpa_auth, sm, key); | ||||
| 			wpa_smk_error(wpa_auth, sm, (const u8 *) (key + 1), | ||||
| 				      key_data_length); | ||||
| #endif /* CONFIG_PEERKEY */ | ||||
| 			return; | ||||
| 		} else if (key_info & WPA_KEY_INFO_ERROR) { | ||||
|  | @ -1254,7 +1255,8 @@ continue_processing: | |||
| 			wpa_request_new_ptk(sm); | ||||
| #ifdef CONFIG_PEERKEY | ||||
| 		} else if (msg == SMK_M1) { | ||||
| 			wpa_smk_m1(wpa_auth, sm, key); | ||||
| 			wpa_smk_m1(wpa_auth, sm, key, (const u8 *) (key + 1), | ||||
| 				   key_data_length); | ||||
| #endif /* CONFIG_PEERKEY */ | ||||
| 		} else if (key_data_length > 0 && | ||||
| 			   wpa_parse_kde_ies((const u8 *) (key + 1), | ||||
|  | @ -1296,7 +1298,8 @@ continue_processing: | |||
| 
 | ||||
| #ifdef CONFIG_PEERKEY | ||||
| 	if (msg == SMK_M3) { | ||||
| 		wpa_smk_m3(wpa_auth, sm, key); | ||||
| 		wpa_smk_m3(wpa_auth, sm, key, (const u8 *) (key + 1), | ||||
| 			   key_data_length); | ||||
| 		return; | ||||
| 	} | ||||
| #endif /* CONFIG_PEERKEY */ | ||||
|  |  | |||
|  | @ -230,11 +230,14 @@ int wpa_auth_for_each_auth(struct wpa_authenticator *wpa_auth, | |||
| int wpa_stsl_remove(struct wpa_authenticator *wpa_auth, | ||||
| 		    struct wpa_stsl_negotiation *neg); | ||||
| void wpa_smk_error(struct wpa_authenticator *wpa_auth, | ||||
| 		   struct wpa_state_machine *sm, struct wpa_eapol_key *key); | ||||
| 		   struct wpa_state_machine *sm, | ||||
| 		   const u8 *key_data, size_t key_data_len); | ||||
| void wpa_smk_m1(struct wpa_authenticator *wpa_auth, | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key); | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key, | ||||
| 		const u8 *key_data, size_t key_data_len); | ||||
| void wpa_smk_m3(struct wpa_authenticator *wpa_auth, | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key); | ||||
| 		struct wpa_state_machine *sm, struct wpa_eapol_key *key, | ||||
| 		const u8 *key_data, size_t key_data_len); | ||||
| #endif /* CONFIG_PEERKEY */ | ||||
| 
 | ||||
| #ifdef CONFIG_IEEE80211R | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Jouni Malinen
						Jouni Malinen