]> git.ipfire.org Git - thirdparty/hostap.git/commitdiff
AOSP: Some P2P connection-in-progress changes
authorJouni Malinen <j@w1.fi>
Fri, 1 Nov 2013 10:21:43 +0000 (12:21 +0200)
committerJouni Malinen <j@w1.fi>
Sun, 26 Oct 2014 16:08:58 +0000 (18:08 +0200)
These came in as part of this AOSP commit:

commit 2fb777c379ad560c309c54b96c2c13291da23f54
Author: Dmitry Shmidt <dimitrysh@google.com>
Date:   Wed May 2 12:29:53 2012 -0700

    wpa_supplicant: Update to Version 0.8.26 from BRCM

    - Add interface command
    - Improve scan handling during P2P

    BUG: b/6324527, b/6427094

    Change-Id: I4425f44d2a15de0725ba4a1b42cc56e10954b314
Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
src/p2p/p2p.c

index 654e0104a056b5c2065f0c0b55e60101dbb25966..941629bc9edd9b3777d8e3b21aab6eb78c654a89 100644 (file)
@@ -48,6 +48,32 @@ static void p2p_scan_timeout(void *eloop_ctx, void *timeout_ctx);
 
 #define P2P_PEER_EXPIRATION_INTERVAL (P2P_PEER_EXPIRATION_AGE / 2)
 
+#ifdef ANDROID_P2P
+int p2p_connection_in_progress(struct p2p_data *p2p)
+{
+       int ret = 0;
+
+       switch (p2p->state) {
+               case P2P_CONNECT:
+               case P2P_CONNECT_LISTEN:
+               case P2P_GO_NEG:
+               case P2P_WAIT_PEER_CONNECT:
+               case P2P_WAIT_PEER_IDLE:
+               case P2P_PROVISIONING:
+               case P2P_INVITE:
+               case P2P_INVITE_LISTEN:
+                       ret = 1;
+                       break;
+
+               default:
+                       wpa_printf(MSG_DEBUG, "p2p_connection_in_progress state %d", p2p->state);
+                       ret = 0;
+       }
+
+       return ret;
+}
+#endif
+
 static void p2p_expire_peers(struct p2p_data *p2p)
 {
        struct p2p_device *dev, *n;
@@ -93,6 +119,13 @@ static void p2p_expire_peers(struct p2p_data *p2p)
                        continue;
                }
 
+#ifdef ANDROID_P2P
+               /* If Connection is in progress, don't expire the peer
+               */
+               if (p2p_connection_in_progress(p2p))
+                       continue;
+#endif
+
                p2p_dbg(p2p, "Expiring old peer entry " MACSTR,
                        MAC2STR(dev->info.p2p_device_addr));