mirror of
https://github.com/vanhoefm/fragattacks.git
synced 2025-01-18 10:54:03 -05:00
P2PS: Save intended interface address after P2PS PD
One possible outcome of the P2PS PD is P2P GO/P2P Client. In this case, one peer becomes a P2P GO and the P2P Client joins it. Since multiple GOs may run simultaneously on the same P2P Device, the P2P Client should join using the intended interface address. To be able to find the device by the intended interface address, save it during the PD. Signed-off-by: Andrei Otcheretianski <andrei.otcheretianski@intel.com> Reviewed-by: Max Stepanov <Max.Stepanov@intel.com> Reviewed-by: Ilan Peer <ilan.peer@intel.com>
This commit is contained in:
parent
5cc6ec0f68
commit
b843a8b8a6
@ -53,6 +53,9 @@ struct p2p_device {
|
||||
* from Beacon/Probe Response), the interface address is stored here.
|
||||
* p2p_device_addr must still be set in such a case to the unique
|
||||
* identifier for the P2P Device.
|
||||
*
|
||||
* This field is also used during P2PS PD to store the intended GO
|
||||
* address of the peer.
|
||||
*/
|
||||
u8 interface_addr[ETH_ALEN];
|
||||
|
||||
|
@ -821,6 +821,10 @@ out:
|
||||
dev->wps_prov_info = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
if (msg.intended_addr)
|
||||
os_memcpy(dev->interface_addr,
|
||||
msg.intended_addr, ETH_ALEN);
|
||||
}
|
||||
}
|
||||
p2p_parse_free(&msg);
|
||||
@ -1120,6 +1124,8 @@ void p2p_process_prov_disc_resp(struct p2p_data *p2p, const u8 *sa,
|
||||
|
||||
/* Store the provisioning info */
|
||||
dev->wps_prov_info = msg.wps_config_methods;
|
||||
if (msg.intended_addr)
|
||||
os_memcpy(dev->interface_addr, msg.intended_addr, ETH_ALEN);
|
||||
|
||||
p2p_parse_free(&msg);
|
||||
success = 1;
|
||||
|
Loading…
Reference in New Issue
Block a user