mirror of
				https://git.kernel.org/pub/scm/network/wireless/iwd.git
				synced 2025-10-30 03:47:23 +01:00 
			
		
		
		
	wscutil: Add M4 builder
This commit is contained in:
		
							parent
							
								
									5322daa79a
								
							
						
					
					
						commit
						9c457de8d5
					
				| @ -1462,6 +1462,20 @@ static void build_rf_bands(struct wsc_attr_builder *builder, uint8_t rf_bands) | ||||
| 	wsc_attr_builder_put_u8(builder, rf_bands); | ||||
| } | ||||
| 
 | ||||
| static void build_r_hash1(struct wsc_attr_builder *builder, | ||||
| 							const uint8_t *r_hash1) | ||||
| { | ||||
| 	wsc_attr_builder_start_attr(builder, WSC_ATTR_R_HASH1); | ||||
| 	wsc_attr_builder_put_bytes(builder, r_hash1, 32); | ||||
| } | ||||
| 
 | ||||
| static void build_r_hash2(struct wsc_attr_builder *builder, | ||||
| 							const uint8_t *r_hash2) | ||||
| { | ||||
| 	wsc_attr_builder_start_attr(builder, WSC_ATTR_R_HASH2); | ||||
| 	wsc_attr_builder_put_bytes(builder, r_hash2, 32); | ||||
| } | ||||
| 
 | ||||
| static void build_serial_number(struct wsc_attr_builder *builder, | ||||
| 						const char *serial_number) | ||||
| { | ||||
| @ -1650,6 +1664,35 @@ done: | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| uint8_t *wsc_build_m4(const struct wsc_m4 *m4, const uint8_t *encrypted, | ||||
| 			size_t encrypted_len, size_t *out_len) | ||||
| { | ||||
| 	struct wsc_attr_builder *builder; | ||||
| 	uint8_t *ret; | ||||
| 
 | ||||
| 	builder = wsc_attr_builder_new(256); | ||||
| 	build_version(builder, 0x10); | ||||
| 	build_message_type(builder, WSC_MESSAGE_TYPE_M4); | ||||
| 	build_enrollee_nonce(builder, m4->enrollee_nonce); | ||||
| 	build_r_hash1(builder, m4->r_hash1); | ||||
| 	build_r_hash2(builder, m4->r_hash2); | ||||
| 
 | ||||
| 	wsc_attr_builder_start_attr(builder, WSC_ATTR_ENCRYPTED_SETTINGS); | ||||
| 	wsc_attr_builder_put_bytes(builder, encrypted, encrypted_len); | ||||
| 
 | ||||
| 	if (!m4->version2) | ||||
| 		goto done; | ||||
| 
 | ||||
| 	START_WFA_VENDOR_EXTENSION(); | ||||
| 
 | ||||
| done: | ||||
| 	build_authenticator(builder, m4->authenticator); | ||||
| 
 | ||||
| 	ret = wsc_attr_builder_free(builder, false, out_len); | ||||
| 	return ret; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| bool wsc_uuid_from_addr(const uint8_t addr[], uint8_t *out_uuid) | ||||
| { | ||||
| 	/* Reuse the NSID from WPA Supplicant for compatibility */ | ||||
|  | ||||
| @ -465,5 +465,7 @@ uint8_t *wsc_build_probe_request(const struct wsc_probe_request *probe_request, | ||||
| uint8_t *wsc_build_m1(const struct wsc_m1 *m1, size_t *out_len); | ||||
| uint8_t *wsc_build_m2(const struct wsc_m2 *m2, size_t *out_len); | ||||
| uint8_t *wsc_build_m3(const struct wsc_m3 *m3, size_t *out_len); | ||||
| uint8_t *wsc_build_m4(const struct wsc_m4 *m4, const uint8_t *encrypted, | ||||
| 			size_t encrypted_len, size_t *out_len); | ||||
| 
 | ||||
| bool wsc_uuid_from_addr(const uint8_t addr[], uint8_t *out_uuid); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Denis Kenzior
						Denis Kenzior