mech_eap.git
10 years agoInterworking: Add support for using eap_proxy offload
Jouni Malinen [Wed, 19 Jun 2013 15:42:17 +0000 (18:42 +0300)]
Interworking: Add support for using eap_proxy offload

Fetch IMSI through eap_proxy for Interworking network selection if
needed.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoFix session timeout after ANQP dummy STA entry with SME-in-driver
Kyeyoon Park [Tue, 18 Jun 2013 14:40:51 +0000 (17:40 +0300)]
Fix session timeout after ANQP dummy STA entry with SME-in-driver

Upon association, disable the timer that removes the dummy STA. This
timer caused the STA that associates within 5 seconds of doing an ANQP
query to disassociate, thinking it's a dummy STA. Similar call was
already there for the SME/MLME-in-hostapd case in handle_auth(), but the
SME-in-driver case was not previously addressed.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agowpadebug: Add option to ignore SSL errors
Jouni Malinen [Fri, 7 Jun 2013 14:27:10 +0000 (17:27 +0300)]
wpadebug: Add option to ignore SSL errors

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoRemove CONFIG_NO_WPA2 build parameter
Jouni Malinen [Fri, 7 Jun 2013 17:13:25 +0000 (20:13 +0300)]
Remove CONFIG_NO_WPA2 build parameter

There is not much use for enabling WPA without WPA2 nowadays since most
networks have been upgraded to WPA2. Furthermore, the code size savings
from disabling just WPA2 are pretty small, so there is not much
justification for maintaining this build option. Remove it to get rid of
undesired complexity.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoRemove compiler warnings with CONFIG_NO_SCAN_PROCESSING
Jouni Malinen [Fri, 7 Jun 2013 17:04:56 +0000 (20:04 +0300)]
Remove compiler warnings with CONFIG_NO_SCAN_PROCESSING

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoRemove compiler warnings if TDLS is enabled without WPA2
Jouni Malinen [Fri, 7 Jun 2013 17:04:12 +0000 (20:04 +0300)]
Remove compiler warnings if TDLS is enabled without WPA2

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoFix WNM build without WPA2
Jouni Malinen [Fri, 7 Jun 2013 17:02:50 +0000 (20:02 +0300)]
Fix WNM build without WPA2

Commit ae8535b6e1a98ca40ce87650a4179851e7cd13a7 added a new function
wpa_sm_pmf_enabled() which is called from WNM code without ifdefs.
Define a dummy wrapper for this function to fix build if WPA2 is
disabled.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoFix build without WPA2 or EAP
Jouni Malinen [Fri, 7 Jun 2013 17:01:10 +0000 (20:01 +0300)]
Fix build without WPA2 or EAP

Commit 4033935dd9098938838d6d7934ceb65f92a1fa3c updated
pmksa_cache_flush() function arguments, but forgot to update the wrapper
function for cases where WPA2 or EAP has been disabled in the build.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoIBSS RSN: Implement disconnect() callback using sta_deauth()
Bharat Bhushan [Fri, 7 Jun 2013 10:07:17 +0000 (13:07 +0300)]
IBSS RSN: Implement disconnect() callback using sta_deauth()

This allows driver wrappers to implement disconnection of IBSS peers in
cases operations, e.g., GTK update, fail.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoP2P: Automatic channel selection at re-invocation of persistent GO
Wei-Jen Lin [Tue, 4 Jun 2013 23:03:26 +0000 (02:03 +0300)]
P2P: Automatic channel selection at re-invocation of persistent GO

If the driver wrapper supports best operation channel indication, the
p2p_group_add command can now use special values (freq=2 and freq=5) to
indicate that the re-invoked persistent GO is to be started on the
specified band.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoP2P: Modify wait time in INVITE state based on Tx status of INV-REQ
Vivek Natarajan [Mon, 3 Jun 2013 18:30:34 +0000 (21:30 +0300)]
P2P: Modify wait time in INVITE state based on Tx status of INV-REQ

In a noisy enviromment, some peers can be slow to respond to the
invitation request frames which may lead to unnecessary state timeout.
Increase this timeout to 350 ms to improve the probabilty of
successfully receiving the invitation response frames.

Signed-hostap: Vivek Natarajan <nataraja@qca.qualcomm.com>

10 years agonl80211: Use NL80211_ATTR_PEER_AID to set TDLS peer AID
Jouni Malinen [Thu, 30 May 2013 07:25:23 +0000 (10:25 +0300)]
nl80211: Use NL80211_ATTR_PEER_AID to set TDLS peer AID

This is needed for TDLS with VHT to allow partial AID to be set
correctly for the direct link frames. cfg80211 validation rules
prevented NL80211_ATTR_STA_AID from being used for this in set_station
case, so the new attribute is used instead.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoSynchronize with wireless-testing.git include/uapi/linux/nl80211.h
Jouni Malinen [Thu, 30 May 2013 07:22:47 +0000 (10:22 +0300)]
Synchronize with wireless-testing.git include/uapi/linux/nl80211.h

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agoAndroid: Add PMF support to hostapd build
Jouni Malinen [Wed, 29 May 2013 15:06:29 +0000 (18:06 +0300)]
Android: Add PMF support to hostapd build

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoWPS: Allow Device Password Id changes between PIN methods
Jouni Malinen [Mon, 27 May 2013 21:35:47 +0000 (00:35 +0300)]
WPS: Allow Device Password Id changes between PIN methods

Commit b4a17a6ea74b2ffba082e05c84730e979513042c added support for the
WPS Registrar to change the Device Password based on WSC specification
design. However, this added validation for Registrar behavior which
resulted in preventing a common P2P use case from working. Relax the
validation rules for builds with P2P enabled to allow the Enrollee (P2P
client) accepting M1/M2 changes in Device Password Id between Default
and Registrar-specified PIN.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agonl80211: Add debug print for set_supp_port operation
Jouni Malinen [Mon, 27 May 2013 17:32:54 +0000 (20:32 +0300)]
nl80211: Add debug print for set_supp_port operation

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agonl80211: Ignore deauth/disassoc event from old AP
Jouni Malinen [Mon, 27 May 2013 17:10:57 +0000 (20:10 +0300)]
nl80211: Ignore deauth/disassoc event from old AP

It looks like cfg80211 can deliver a deauth/disassoc event during some
roaming cases while we are already in progress with a new
authentication/association. This happens at least with FT protocol.
Avoid issues with such disconnection event resulting in core
wpa_supplicant stopping the new connection attempt by tracking
auth/assoc BSSID more carefully within driver_nl80211.c and filtering
out events that do not apply for the current AP.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agowlantest: Recognize hwsim_test packets
Jouni Malinen [Sun, 26 May 2013 19:19:52 +0000 (22:19 +0300)]
wlantest: Recognize hwsim_test packets

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agowlantest: Select correct TDLS context if multiple exists
Jouni Malinen [Sun, 26 May 2013 18:46:54 +0000 (21:46 +0300)]
wlantest: Select correct TDLS context if multiple exists

Some corner cases may result in both directions of TDLS tracking context
existing. If that is the case, the incorrect one may end up getting
picked when figuring out which TK to use for decryption or fix
statistics counter to increment. Fix this by preferring the context that
has TDLS link up.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agowlantest: Track TDLS setup nonces
Jouni Malinen [Sun, 26 May 2013 18:35:00 +0000 (21:35 +0300)]
wlantest: Track TDLS setup nonces

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agowlantest: Use add_note() to annotate frames
Jouni Malinen [Sun, 26 May 2013 17:58:50 +0000 (20:58 +0300)]
wlantest: Use add_note() to annotate frames

This adds debug information from wlantest into pcapng frame comments to
make the information more convenient to use, e.g., in Wireshark.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agowlantest: Add support for writing pcapng files
Jouni Malinen [Sun, 26 May 2013 16:39:48 +0000 (19:39 +0300)]
wlantest: Add support for writing pcapng files

The new -n<file> command line argument can be used to request wlantest
to write all read or captured frames into a pcapng file. This is similar
to the -w argument, but with pcapng allowing per-frame comments to be
embedded in the file.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agoFix ESS_DISASSOC ctrl_iface command parser
Jouni Malinen [Sat, 25 May 2013 16:55:32 +0000 (19:55 +0300)]
Fix ESS_DISASSOC ctrl_iface command parser

strchr can return NULL and that needs to be checked instead of what the
pointer could be pointing to.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agotests: Add test cases for Fast BSS Transition
Jouni Malinen [Fri, 24 May 2013 13:05:40 +0000 (16:05 +0300)]
tests: Add test cases for Fast BSS Transition

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agoFT: Fix TKIP group key configuration in FT protocol
Jouni Malinen [Fri, 24 May 2013 13:03:54 +0000 (16:03 +0300)]
FT: Fix TKIP group key configuration in FT protocol

The Michael MIC TX and RX keys needs to be swapped in the FT case just
like in all other TKIP key configuration cases. This fixes issues where
TKIP as group cipher resulted in Michael MIC failures being detected for
each received group-addressed frame after FT protocol use.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoStop TKIP countermeasures on FLUSH command
Jouni Malinen [Fri, 24 May 2013 13:02:58 +0000 (16:02 +0300)]
Stop TKIP countermeasures on FLUSH command

This is needed to get wpa_supplicant into clean state during testing if
a test case triggers countermeasures.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoDo not set driver MAC ACL unless driver supports this
Jouni Malinen [Fri, 24 May 2013 10:37:22 +0000 (13:37 +0300)]
Do not set driver MAC ACL unless driver supports this

This cleans up debug log by not including comments about failed
operations in case the operation is known to fail due to not being
supported by the driver.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agohostapd: Support MAC address based access control list
Vivek Natarajan [Thu, 23 May 2013 11:38:20 +0000 (14:38 +0300)]
hostapd: Support MAC address based access control list

Enable MAC address based ACL for the drivers which advertise
this capabilty with NL80211_ATTR_MAC_ACL_MAX. Either of blacklist
or whitelist is supported, though, not simultaneously.

Signed-hostap: Vivek Natarajan <nataraja@qca.qualcomm.com>

10 years agowpa_cli: Support tab completion with ifname= prefix
Jouni Malinen [Thu, 23 May 2013 17:35:02 +0000 (20:35 +0300)]
wpa_cli: Support tab completion with ifname= prefix

Enable tab completion for the cases where ifname= prefix is used in
interactive mode by skipping over that prefix before running through the
per-command completion routines. The ifname= prefix itself is also
covered by adding the possible interface names to the command list.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agowpa_cli: Allow IFNAME= prefix to be used
Jouni Malinen [Thu, 23 May 2013 17:04:17 +0000 (20:04 +0300)]
wpa_cli: Allow IFNAME= prefix to be used

Strip out the IFNAME=<ifname> prefix from commands before parsing them
through the normal processing and then add the prefix back to the
beginning of the actual control interface command to make per-interface
commands work through the global control interface without having to use
the 'raw' command.

Signed-hostap: Jouni Malinen <j@w1.fi>

10 years agoWNM: Make ESS Disassoc Imminent event more convenient to use
Jouni Malinen [Sat, 20 Apr 2013 23:48:10 +0000 (16:48 -0700)]
WNM: Make ESS Disassoc Imminent event more convenient to use

Define a proper event prefix and include additional information to allow
ESS Dissassociation Imminent event to be used in a wpa_cli action
script.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoWNM: Do not reject ESS Disassoc Imminent
Jouni Malinen [Thu, 23 May 2013 13:10:29 +0000 (16:10 +0300)]
WNM: Do not reject ESS Disassoc Imminent

This indication is not expected to include candidates, so do not reject
it based on that.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoWNM: Use defines for BSS Trans Mgmt field values
Jouni Malinen [Thu, 23 May 2013 13:07:10 +0000 (16:07 +0300)]
WNM: Use defines for BSS Trans Mgmt field values

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoWNM: Fix ess_disassoc timeout to be specified in TBTTs
Jouni Malinen [Thu, 23 May 2013 12:57:13 +0000 (15:57 +0300)]
WNM: Fix ess_disassoc timeout to be specified in TBTTs

This was previously claimed to be in ms, but the field in BSS Transition
Management Request frame is in number of TBTTs (beacon interval). Use
that unit in the ESS_DISASSOC control interface command to be able to
specify any value and just modify the timeout value to be calculated
based on beacon interval.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

10 years agoWNM: Remove PMKSA cache entry on ESS disassoc imminent notification
Jouni Malinen [Fri, 5 Apr 2013 15:55:32 +0000 (18:55 +0300)]
WNM: Remove PMKSA cache entry on ESS disassoc imminent notification

This is needed to avoid allowing the STA to reconnect using a cached
PMKSA. ESS disassoc imminent notification is normally used to indicate
that the STA session will be terminated and as such, requiring full
authentication through the authentication server after this is needed.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoTry to use fast-associate on ENABLE_NETWORK
Jouni Malinen [Tue, 21 May 2013 16:37:55 +0000 (19:37 +0300)]
Try to use fast-associate on ENABLE_NETWORK

This makes ENABLE_NETWORK behave similarily to SELECT_NETWORK by
allowing a scan to be skipped if recent scan results are available.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoFix already-associated detection with driver-based BSS selection
Jouni Malinen [Tue, 21 May 2013 16:34:00 +0000 (19:34 +0300)]
Fix already-associated detection with driver-based BSS selection

wpa_s->pending_bssid is all zeros during connection attempt when
driver-based BSS selection is used. Take this into account when
determining whether new scan results should trigger a connection based
on wpa_s->current_ssid, i.e., a connection attempt with the selected
network instead of selected BSS.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoP2P: Relax channel forcing for invitation processing with MCC support
Sean Lin [Wed, 22 May 2013 10:29:46 +0000 (13:29 +0300)]
P2P: Relax channel forcing for invitation processing with MCC support

When STA interface is connected and P2P interface gets invited in a
different channel from previous P2P group, the invitiation would fail
because of no common channel found. Fix this by using different logic
when device support multi channel concurrency.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoFix OKC-based PMKSA cache entry clearing
Jouni Malinen [Wed, 22 May 2013 10:24:30 +0000 (13:24 +0300)]
Fix OKC-based PMKSA cache entry clearing

Commit c3fea272747f738f5723fc577371fe03711d988f added a call to clear
all other PMKSA cache entries for the same network if the PMKSA cache
entry of the current AP changed. This was needed to fix OKC cases since
the other APs would likely use the new PMK in the future. However, this
ended up clearing entries in cases where that is not desired and this
resulted in needing additional full EAP authentication with networks
that did not support OKC if wpa_supplicant was configured to try to use
it.

Make PMKSA cache entry flushing more limited so that the other entries
are removed only if they used the old PMK that was replaced for the
current AP and only if that PMK had previously been used successfully
(i.e., opportunistic flag was already cleared back to 0 in
wpa_supplicant_key_neg_complete()). This is still enough to fix the
issue described in that older commit while not causing problems for
standard PMKSA caching operations even if OKC is enabled in
wpa_supplicant configuration.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agonl80211: Add couple of additional iftypes to debug prints
Jouni Malinen [Tue, 21 May 2013 13:51:06 +0000 (16:51 +0300)]
nl80211: Add couple of additional iftypes to debug prints

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoTDLS: Retry TDLS Setup Response more quickly
Sunil Dutt [Mon, 20 May 2013 10:07:24 +0000 (15:37 +0530)]
TDLS: Retry TDLS Setup Response more quickly

TDLS responder STA used to retransmit the TDLS Setup Response after 5
seconds if the TDLS Setup Confirm is not received. The initiator would
have enabled the TDLS link and started transmitting the data to the peer
on the TDLS link after transmitting the TDLS Setup Confirm frame. If the
TDLS Setup Confirm frame is not received by the receiver, the
transmissions from the initiator on the direct link would get failed for
the TDLS link not getting enabled on the receiver. This commit reduces
the data delivery failure duration by shortening the retry time of the
TDLS Setup Response frames. The retry limit of the TDLS Response frame
also is increased to ensure that the peer does not miss the frames in
the reduced time period.

Signed-hostap: Sunil Dutt <duttus@codeaurora.org>

11 years agoWNM: Add disassociation timeout processing for ESS_DISASSOC
Kyeyoon Park [Fri, 5 Apr 2013 15:41:26 +0000 (18:41 +0300)]
WNM: Add disassociation timeout processing for ESS_DISASSOC

The hostapd_cli ess_disassoc command now takes three arguments (STA MAC
address, timeout in ms, URL) and the STA is disconnected after the
specified timeout.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoGAS: Reduce query timeout to two seconds
Jouni Malinen [Sat, 20 Apr 2013 23:48:10 +0000 (16:48 -0700)]
GAS: Reduce query timeout to two seconds

The five second timeout for GAS queries is excessive and can result in
long waits in cases where APs are either misconfigured or frames are
lost.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoGAS: Assign new dialog token even if previous one is free
Jouni Malinen [Sun, 14 Apr 2013 20:23:50 +0000 (13:23 -0700)]
GAS: Assign new dialog token even if previous one is free

This makes the design more robust against unexpected duplicates since
each new GAS exchange gets a different dialog token compared to the
previous one.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoGAS: Ignore replays if previous frag_id without dropping GAS session
Jouni Malinen [Tue, 29 Jan 2013 15:33:34 +0000 (07:33 -0800)]
GAS: Ignore replays if previous frag_id without dropping GAS session

It looks like it may be possible for an older GAS response to get retransmitted
even after the first copy has been processed. While this should not really come
up all the way to wpa_supplicant due to sequence number being same (i.e.,
duplicate detection should from the frame), some cases have been observed where
this did cause issues. Drop such a frame silently without dropping the ongoing
GAS session to allow a frame with the next frag_id to be processed after this.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoAdd test code for fetching the last configured GTK
Jouni Malinen [Fri, 28 Oct 2011 11:39:44 +0000 (14:39 +0300)]
Add test code for fetching the last configured GTK

This can be useful for some test cases, so allow wpa_supplicant to be
built with special test functionality to expose the current (last
configured) GTK. This is disabled by default and can be enabled by
adding following line into .config:
CFLAGS += -DCONFIG_TESTING_GET_GTK

The GTK can then be fetched with "wpa_cli get gtk".

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoP2P: Direct global ctrl_iface commands automatically for P2P
Jouni Malinen [Sat, 18 May 2013 16:41:08 +0000 (19:41 +0300)]
P2P: Direct global ctrl_iface commands automatically for P2P

The P2P management operations like P2P_FIND and P2P_CONNECT are not
really specific to any network interface. These are P2P Device level
operations that are in more global device context. Allow those to be
sent through the global control interface without IFNAME parameter.

For now, these commands are directed within wpa_supplicant to the
network interface that initialized the global P2P context. This may
change in the future if a special context is added for P2P operations.
Anyway, such changes can now be done internally within wpa_supplicant
without affecting this global control interface design from external
view point.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoP2P: No duplicate AP-STA-CONNECTED/DISCONNECTED as global event
Jouni Malinen [Sat, 18 May 2013 16:18:31 +0000 (19:18 +0300)]
P2P: No duplicate AP-STA-CONNECTED/DISCONNECTED as global event

These events are sent as a special case to both the group interface and
"parent interface" (i.e., the interface that was used for managing P2P
negotiation). The latter is not really correct event, so get rid of it
with the new global control interface design where there is no need to
support legacy upper layer implementations.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoClean up AP-STA-CONNECTED/DISCONNECTED prints
Jouni Malinen [Sat, 18 May 2013 16:09:41 +0000 (19:09 +0300)]
Clean up AP-STA-CONNECTED/DISCONNECTED prints

Use shared code to print the parameters so that they do not need to be
generated four times separately.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoP2P: Mark P2P events global (not specific to interface)
Jouni Malinen [Sat, 18 May 2013 15:59:51 +0000 (18:59 +0300)]
P2P: Mark P2P events global (not specific to interface)

This removes the "IFNAME=<ifname> " prefix from P2P events that are
received through the global control interface since these events are not
really specific to any network interface, but the full device.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoP2P: Clean up debug prints
Jouni Malinen [Sat, 18 May 2013 15:47:36 +0000 (18:47 +0300)]
P2P: Clean up debug prints

Replace direct wpa_msg() calls with p2p_dbg(), p2p_info(), and p2p_err()
calls that use a new debug_print() callback to handle actual debug
printing outside the P2P module.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoP2P: Move p2p_find stopped event message into p2p_supplicant.c
Jouni Malinen [Sat, 18 May 2013 13:06:40 +0000 (16:06 +0300)]
P2P: Move p2p_find stopped event message into p2p_supplicant.c

This removes wpa_ctrl.h dependency from src/p2p/* and makes the P2P
events more consistent, i.e., everything that is aimed for upper layer
processing from the wpa_supplicant control interfaces is generated in
p2p_supplicant.c.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoAdd wpa_msg_global() for global events
Jouni Malinen [Sat, 18 May 2013 11:19:24 +0000 (14:19 +0300)]
Add wpa_msg_global() for global events

This function can be used instead of wpa_msg() and wpa_msg_ctrl() to
indicate that an event is not specific to a network interface.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoAllow global ctrl_iface monitors
Jouni Malinen [Sat, 18 May 2013 11:07:28 +0000 (14:07 +0300)]
Allow global ctrl_iface monitors

The ATTACH/DETACH mechanism to request event messages from
wpa_supplicant can now be used through the global control interface,
too. This results in events from all interfaces being delivered through
a single monitor socket. "IFNAME=<ifname> " prefix is used on events
that are specific to an interface.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agowpa_cli: Set buffer length the same as in wpa_supplicant_ctrl_iface_process()
Dmitry Shmidt [Tue, 30 Aug 2011 18:10:13 +0000 (11:10 -0700)]
wpa_cli: Set buffer length the same as in wpa_supplicant_ctrl_iface_process()

Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
11 years agoAdd band option (2.4 vs. 5) for filtering scans
Jouni Malinen [Fri, 9 Mar 2012 05:28:13 +0000 (21:28 -0800)]
Add band option (2.4 vs. 5) for filtering scans

This can be used to implement filtering of channels for scan and based
on that, for connection, purposes.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoAndroid: Clarify keystore include directories
Jouni Malinen [Sat, 18 May 2013 09:03:35 +0000 (12:03 +0300)]
Android: Clarify keystore include directories

This updates hostapd to build using the new keystore header file
location and adds a note that the old frameworks/base/cmds/keystore can
be removed at some point in the future when old Android releases do not
need to be supported.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoAndroid: Add a top level Android.mk
Jouni Malinen [Sat, 18 May 2013 08:55:32 +0000 (11:55 +0300)]
Android: Add a top level Android.mk

This allows the hostap.git repository version to be build as part of the
full Android platform build.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoAbstract and Android sockets for global ctrl_iface
Jouni Malinen [Sat, 18 May 2013 08:42:09 +0000 (11:42 +0300)]
Abstract and Android sockets for global ctrl_iface

The wpa_supplicant global control interface parameter can now be used to
explicitly specify an abstract UNIX domain socket (Linux specific
extension) with "@abstract:" prefix and an Android control socket with
"@android:" prefix.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agowpa_cli: Allow global interface to be used in interactive mode
Jouni Malinen [Sat, 18 May 2013 08:40:23 +0000 (11:40 +0300)]
wpa_cli: Allow global interface to be used in interactive mode

This is mostly a corner case at this point, but if wpa_cli was started
with global control interface connection (-g) and interactive mode,
per-interface control interface was tried to be opened with the
previously opened global ctrl_iface connection gettign leaked.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agowpa_supplicant: Add -G argument to specify global ctrl group
Jouni Malinen [Sat, 18 May 2013 08:00:05 +0000 (11:00 +0300)]
wpa_supplicant: Add -G argument to specify global ctrl group

The optional -G<group> command line argument can be used to specify the
group that can access the global control interface.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoAllow global ctrl_iface to be used for per-interface commands
Jouni Malinen [Sat, 18 May 2013 07:19:38 +0000 (10:19 +0300)]
Allow global ctrl_iface to be used for per-interface commands

"IFNAME=<ifname> " prefix can now be used on the wpa_supplicant global
control interface to direct a command to a specific interface instead of
having to use an interface specific control interface for this. This
allows a single socket to be used for controlling multiple virtual
interfaces.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoFT RRB: Fix a memory leak on error path
Jouni Malinen [Sat, 18 May 2013 06:49:26 +0000 (09:49 +0300)]
FT RRB: Fix a memory leak on error path

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoP2P: Use preferred channel list during GO creation
Suryadevara Sudheer [Fri, 17 May 2013 08:27:02 +0000 (11:27 +0300)]
P2P: Use preferred channel list during GO creation

This extends support for p2p_pref_Chan configuration parameter for
autonomous GO creation.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoP2P: Re-select channel in invitation case with peer info
Suryadevara Sudheer [Fri, 17 May 2013 08:18:02 +0000 (11:18 +0300)]
P2P: Re-select channel in invitation case with peer info

Allow invitation exchange to update operating channel selection after
peer channel list has been received similarly to how GO negotiation was
handled.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoP2P: Fix p2p_pref_chan setting from configuration file
Yufeng Wang [Fri, 17 May 2013 08:03:52 +0000 (11:03 +0300)]
P2P: Fix p2p_pref_chan setting from configuration file

Commit 21d996f775a2131bb0c73d6e18ca9b382f017057 added p2p_pref_chan as a
configuration file parameter, but included only the case of dynamically
setting this at runtime through the control interface SET command.
Complete this functionality by taking this value into use directly from
the configuration file, too.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agodbus: Terminate cleanly on messagebus shutdown
Daniel Gnoutcheff [Thu, 16 May 2013 17:47:28 +0000 (20:47 +0300)]
dbus: Terminate cleanly on messagebus shutdown

By default, dbus_connection_dispatch() will call _exit() if the bus
connection has been closed. This caused wpa_supplicant to terminate
without properly cleaning up after itself.

To ensure that we terminate cleanly when the messagebus terminates,
override the exit_on_disconnect behavior and install a filter to handle
libdbus's "Disconnected" signal.

[Bug 474]

Signed-hostap: Daniel Gnoutcheff <daniel@gnoutcheff.name>

11 years agoWNM: Enable CONFIG_WNM in Android.mk
Vinayak Kamath [Thu, 16 May 2013 14:51:18 +0000 (17:51 +0300)]
WNM: Enable CONFIG_WNM in Android.mk

Signed-hostap: Vinayak Kamath <vkamat@codeaurora.org>

11 years agoWNM: Add sending of BSS Transition Management Query
Vinayak Kamath [Thu, 16 May 2013 14:50:31 +0000 (17:50 +0300)]
WNM: Add sending of BSS Transition Management Query

The new control interface command can be used to send a
BSS Transition Management Query frame to the current AP.

Signed-hostap: Vinayak Kamath <vkamat@codeaurora.org>

11 years agoWNM: Add neighbor report processing for BSS Transition Management
Vinayak Kamath [Thu, 16 May 2013 14:48:59 +0000 (17:48 +0300)]
WNM: Add neighbor report processing for BSS Transition Management

Process the neighbor report received in BSS Management Request frames.

Signed-hostap: Vinayak Kamath <vkamat@codeaurora.org>

11 years agoWPS: Clear connection failure counts on WPS success
Jouni Malinen [Wed, 15 May 2013 14:33:50 +0000 (17:33 +0300)]
WPS: Clear connection failure counts on WPS success

The WPS provisioning case does not result in successful connection by
design and as such, this can result in networks getting temporarily
disabled. Avoid this by clearing the failure counts on WPS success.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoWPS NFC: Connect using learnt credential after NFC Tag read
Jouni Malinen [Wed, 15 May 2013 13:46:45 +0000 (16:46 +0300)]
WPS NFC: Connect using learnt credential after NFC Tag read

Instead of just adding the new network, prefer the network learnt from a
configuration token during the first connection attempt. This makes the
WPS NFC case behave similarly to the in-band provisioning cases if there
are more preferred networks in the scan results.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoedit: Fix libreadline history clearing with WPA_TRACE
Jouni Malinen [Tue, 14 May 2013 13:46:38 +0000 (16:46 +0300)]
edit: Fix libreadline history clearing with WPA_TRACE

The HIST_ENTRY and its variables are allocated within libreadline, so
they won't have the WPA_TRACE special header and cannot be freed with
os_free(). Use free() to avoid issues during wpa_cli termination if any
of the new commands added to the history are to be removed (e.g.,
set_network could include a password).

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agonl80211: Fix foreign address filtering for MLME frame events
Jouni Malinen [Mon, 13 May 2013 08:53:21 +0000 (11:53 +0300)]
nl80211: Fix foreign address filtering for MLME frame events

Commit 97279d8d1ad40bd7d884af8e2fc26dff0163331a started filtering MLME
frame events based on Address 1 (destination) field. This works fine for
frames sent to us, but it did filter out some corner cases where we
actually want to process an event based on a frame sent by us. The main
such case is deauthentication or disassociation triggered by something
external to wpa_supplicant in the system. Fix this by accepting events
for frames where either Address 1 or 2 (transmitter) matches the
interface address.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agowpadebug: Add broadcast intent receiver for Wi-Fi events
Jouni Malinen [Sun, 12 May 2013 18:06:59 +0000 (21:06 +0300)]
wpadebug: Add broadcast intent receiver for Wi-Fi events

This makes it easier to debug Android framework actions with all the
related broadcast intents being logged.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoMark interface disconnected on removal request
Jouni Malinen [Sun, 12 May 2013 16:16:35 +0000 (19:16 +0300)]
Mark interface disconnected on removal request

This cleans up debug log by not trying to process the disconnection
event as a failure that could result in blacklist addition and auto
connect attempt. These are pointless operations since the interface is
going to removed immediately after this.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoDo not try auto connect mechanism in disconnected state
Jouni Malinen [Sun, 12 May 2013 16:15:33 +0000 (19:15 +0300)]
Do not try auto connect mechanism in disconnected state

This cleans up debug log by not requesting the auto connect on
dissassociation event if we are already in disconnected state and would
not try to connect anyway.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoDo not add BSS to blacklist on local disconnection request
Jouni Malinen [Sun, 12 May 2013 16:12:29 +0000 (19:12 +0300)]
Do not add BSS to blacklist on local disconnection request

There is no point in marking a BSS temporarily blacklisted based on a
connection failure or disconnection case if that happens as a result of
a local request to disconnect. The blacklist entry could result on
unexpected BSS getting selected on the next connection attempt. In
addition, the code to try to find another BSS within the ESS could
result in scanning a single channel on the next attempt. Fix these
issues by handling the connection failure events only if we are not in
disconnected state (i.e., would try to reconnect after this
automatically).

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agowpadebug: Add a simple WebView activity
Jouni Malinen [Sat, 11 May 2013 18:01:46 +0000 (21:01 +0300)]
wpadebug: Add a simple WebView activity

This provides a simple web browser that can be started and stopped from
other apps or native applications.

This activity can be started with the following command:
am start -a android.action.MAIN -c android.intent.category.LAUNCHER \
    -n w1.fi.wpadebug/.WpaWebViewActivity -e w1.fi.wpadebug.URL <URL>

If <URL> is set to FINISH the activity is finished.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agotests: Allow hwsim_test and wlantest_cli to be used from PATH
Jouni Malinen [Sat, 11 May 2013 08:34:49 +0000 (11:34 +0300)]
tests: Allow hwsim_test and wlantest_cli to be used from PATH

This makes it easier to support some test environments where the
repository is shared between hosts.

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agowpadebug: Add forgotten installation step to documentation
Jouni Malinen [Sat, 11 May 2013 08:32:03 +0000 (11:32 +0300)]
wpadebug: Add forgotten installation step to documentation

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agotests: Use /var/run/hostapd-global to avoid socket file in work dir
Jouni Malinen [Fri, 10 May 2013 14:09:55 +0000 (17:09 +0300)]
tests: Use /var/run/hostapd-global to avoid socket file in work dir

This makes some cases more convenient with read-only file systems.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoDefer scan if connection is in progress on any of the shared interfaces
Deepthi Gowri [Fri, 10 May 2013 13:10:50 +0000 (16:10 +0300)]
Defer scan if connection is in progress on any of the shared interfaces

Scanning can delay concurrent operations considerably, so it is better
to avoid that while trying to connect on any of the virtual interfaces
that share the same radio.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agotls_openssl: Store TLS context per-connection
Paul Stewart [Thu, 9 May 2013 21:22:08 +0000 (00:22 +0300)]
tls_openssl: Store TLS context per-connection

Store context for each tls_init() caller, so events are generated for
the correct wpa_s instance. The tls_global variable is retained for
older OpenSSL implementations that may not have app-data for SSL_CTX.

Signed-hostap: Paul Stewart <pstew@chromium.org>

11 years agoRename hostapd_parse_rates() to a more generic int list parser
Simon Wunderlich [Thu, 9 May 2013 17:21:41 +0000 (20:21 +0300)]
Rename hostapd_parse_rates() to a more generic int list parser

This can be used with other integer lists than just rates.

Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agoDFS: Add ieee80211h hostapd configuration parameter
Simon Wunderlich [Thu, 9 May 2013 17:14:53 +0000 (20:14 +0300)]
DFS: Add ieee80211h hostapd configuration parameter

This patch is based on the original work by Boris Presman and
Victor Goldenshtein. Channel Switch Announcement support has been
removed and event handling as well as channel set handling was
changed, among various other changes.

Cc: Boris Presman <boris.presman@ti.com>
Cc: Victor Goldenshtein <victorg@ti.com>
Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agonl80211: Add driver_ops for stopping AP beaconing
Simon Wunderlich [Thu, 9 May 2013 17:06:33 +0000 (20:06 +0300)]
nl80211: Add driver_ops for stopping AP beaconing

This can be used to stop AP mode beaconing temporarily, e.g., in
response to a radar detected event.

This patch is based on the original work by Boris Presman and
Victor Goldenshtein. Channel Switch Announcement support has been
removed and event handling as well as channel set handling was
changed, among various other changes.

Cc: Boris Presman <boris.presman@ti.com>
Cc: Victor Goldenshtein <victorg@ti.com>
Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agonl80211: Add driver_ops for starting radar detection
Simon Wunderlich [Thu, 9 May 2013 17:05:01 +0000 (20:05 +0300)]
nl80211: Add driver_ops for starting radar detection

This patch is based on the original work by Boris Presman and
Victor Goldenshtein. Channel Switch Announcement support has been
removed and event handling as well as channel set handling was
changed, among various other changes.

Cc: Boris Presman <boris.presman@ti.com>
Cc: Victor Goldenshtein <victorg@ti.com>
Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agonl80211: Add channel flags for DFS state information
Simon Wunderlich [Thu, 9 May 2013 17:02:57 +0000 (20:02 +0300)]
nl80211: Add channel flags for DFS state information

This patch is based on the original work by Boris Presman and
Victor Goldenshtein. Channel Switch Announcement support has been
removed and event handling as well as channel set handling was
changed, among various other changes.

Cc: Boris Presman <boris.presman@ti.com>
Cc: Victor Goldenshtein <victorg@ti.com>
Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agonl80211: Add driver capability flag for radar detection
Simon Wunderlich [Thu, 9 May 2013 16:58:55 +0000 (19:58 +0300)]
nl80211: Add driver capability flag for radar detection

This patch is based on the original work by Boris Presman and
Victor Goldenshtein. Channel Switch Announcement support has been
removed and event handling as well as channel set handling was
changed, among various other changes.

Cc: Boris Presman <boris.presman@ti.com>
Cc: Victor Goldenshtein <victorg@ti.com>
Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agonl80211: Add driver events for radar detection
Simon Wunderlich [Thu, 9 May 2013 16:54:18 +0000 (19:54 +0300)]
nl80211: Add driver events for radar detection

This patch is based on the original work by Boris Presman and
Victor Goldenshtein. Channel Switch Announcement support has been
removed and event handling as well as channel set handling was
changed, among various other changes.

Cc: Boris Presman <boris.presman@ti.com>
Cc: Victor Goldenshtein <victorg@ti.com>
Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agoeloop: Allow to run event loop multiple times in a row
Simon Wunderlich [Thu, 9 May 2013 13:42:14 +0000 (16:42 +0300)]
eloop: Allow to run event loop multiple times in a row

DFS implementation requires to run an eventloop while monitoring
the Channel Availability Check (CAC). After that, the "real" event
loop is started, and should not fail doing so.

Signed-hostap: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>

11 years agowpa_supplicant: Allow vifs to scan only current channel
Ben Greear [Thu, 9 May 2013 09:43:40 +0000 (12:43 +0300)]
wpa_supplicant: Allow vifs to scan only current channel

If a VIF is already associated, then only scan on the associated
frequency if user requests such. This is a big help when using
lots of virtual stations.

Signed-hostap: Ben Greear <greearb@candelatech.com>
Signed-off-by: Ben Greear <greearb@candelatech.com>
11 years agosystemd: Fix systemd interface alias
Arend van Spriel [Thu, 9 May 2013 08:25:48 +0000 (11:25 +0300)]
systemd: Fix systemd interface alias

In the systemd interface templated the alias entry was specified
with wlan0 hard coded. Changing it to %i in this patch. [Bug 477]

Reported-by: zg <ml@mail.tsaitgaist.info>
Signed-hostap: Arend van Spriel <arend@broadcom.com>
Signed-off-by: Arend van Spriel <arend@broadcom.com>
11 years agoTry to set WPA-None key after IBSS-joined event
Jouni Malinen [Tue, 7 May 2013 15:14:56 +0000 (18:14 +0300)]
Try to set WPA-None key after IBSS-joined event

cfg80211 rejects the set_key operations before the IBSS network has been
fully formed, so add one more attempt to set the key for WPA-None at
IBSS joined driver event.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoUse cached driver capabilities instead of new fetch for each operation
Jouni Malinen [Tue, 7 May 2013 14:36:40 +0000 (17:36 +0300)]
Use cached driver capabilities instead of new fetch for each operation

There is no need to repeat the driver capability fetch for each
operation since we already cache driver flags in wpa_s->drv_flags.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoTDLS: Do not overwrite the reason code in the Tear Down Request
Sunil Dutt [Tue, 7 May 2013 13:27:31 +0000 (16:27 +0300)]
TDLS: Do not overwrite the reason code in the Tear Down Request

The reason code for the teardown request is overwritten for open
mode. This commit removes the code that does so by reverting parts
of commit 0cb12963b69abf493e456c8b2ed2b0be30ce11e7.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoAdd a configration parameter for sched_scan interval
Sheng Fang [Tue, 7 May 2013 09:41:14 +0000 (12:41 +0300)]
Add a configration parameter for sched_scan interval

The new sched_scan_interval parameter can be used to set the default
sched_scan interval, e.g., for power saving purposes.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>

11 years agoSynchronize with wireless-testing.git include/uapi/linux/nl80211.h
Jouni Malinen [Mon, 6 May 2013 12:59:49 +0000 (15:59 +0300)]
Synchronize with wireless-testing.git include/uapi/linux/nl80211.h

Signed-hostap: Jouni Malinen <j@w1.fi>

11 years agoTDLS: Move AID=1 workaround into driver_nl80211.c
Jouni Malinen [Mon, 6 May 2013 12:57:03 +0000 (15:57 +0300)]
TDLS: Move AID=1 workaround into driver_nl80211.c

The use of AID=1 for the nl80211 dummy STA case is specific to the
driver (cfg80211), so better move this into the driver wrapper instead
of generic TDLS implementation.

Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>