From dc6bda1123bb517b9471deabb9d20241f2b5118c Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Sun, 10 Feb 2013 16:25:20 +0200 Subject: [PATCH] WPS: Use alternating poll/listen for NFC peer discovery with nfcpy This is needed to find the NFC peer to avoid cases where both devices could be using the same operation. Signed-hostap: Jouni Malinen --- hostapd/wps-ap-nfc.py | 55 +++++++++++++++++++++--------- wpa_supplicant/examples/wps-nfc.py | 55 +++++++++++++++++++++--------- 2 files changed, 76 insertions(+), 34 deletions(-) diff --git a/hostapd/wps-ap-nfc.py b/hostapd/wps-ap-nfc.py index 4b2ca0237..342340d21 100755 --- a/hostapd/wps-ap-nfc.py +++ b/hostapd/wps-ap-nfc.py @@ -185,6 +185,34 @@ def wps_write_password_tag(clf): time.sleep(0.1) +def find_peer(clf): + while True: + if nfc.llcp.connected(): + print "LLCP connected" + general_bytes = nfc.llcp.startup({}) + peer = clf.listen(ord(os.urandom(1)) + 200, general_bytes) + if isinstance(peer, nfc.DEP): + print "listen -> DEP"; + if peer.general_bytes.startswith("Ffm"): + print "Found DEP" + return peer + print "mismatch in general_bytes" + print peer.general_bytes + + peer = clf.poll(general_bytes) + if isinstance(peer, nfc.DEP): + print "poll -> DEP"; + if peer.general_bytes.startswith("Ffm"): + print "Found DEP" + return peer + print "mismatch in general_bytes" + print peer.general_bytes + + if peer: + print "Found tag" + return peer + + def main(): clf = nfc.ContactlessFrontend() @@ -200,25 +228,18 @@ def main(): while True: print "Waiting for a tag or peer to be touched" - while True: - general_bytes = nfc.llcp.startup({}) - tag = clf.poll(general_bytes) - if tag == None: - continue + tag = find_peer(clf) + if isinstance(tag, nfc.DEP): + wps_handover_init(tag) + continue - if isinstance(tag, nfc.DEP): - wps_handover_init(tag) - break + if tag.ndef: + wps_tag_read(tag) + continue - if tag.ndef: - wps_tag_read(tag) - break - - if tag: - print "Not an NDEF tag - remove tag" - while tag.is_present: - time.sleep(0.1) - break + print "Not an NDEF tag - remove tag" + while tag.is_present: + time.sleep(0.1) except KeyboardInterrupt: raise SystemExit diff --git a/wpa_supplicant/examples/wps-nfc.py b/wpa_supplicant/examples/wps-nfc.py index aa386c2c6..dd0b2fd76 100755 --- a/wpa_supplicant/examples/wps-nfc.py +++ b/wpa_supplicant/examples/wps-nfc.py @@ -127,6 +127,34 @@ def wps_tag_read(tag): time.sleep(0.1) +def find_peer(clf): + while True: + if nfc.llcp.connected(): + print "LLCP connected" + general_bytes = nfc.llcp.startup({}) + peer = clf.listen(ord(os.urandom(1)) + 200, general_bytes) + if isinstance(peer, nfc.DEP): + print "listen -> DEP"; + if peer.general_bytes.startswith("Ffm"): + print "Found DEP" + return peer + print "mismatch in general_bytes" + print peer.general_bytes + + peer = clf.poll(general_bytes) + if isinstance(peer, nfc.DEP): + print "poll -> DEP"; + if peer.general_bytes.startswith("Ffm"): + print "Found DEP" + return peer + print "mismatch in general_bytes" + print peer.general_bytes + + if peer: + print "Found tag" + return peer + + def main(): clf = nfc.ContactlessFrontend() @@ -134,25 +162,18 @@ def main(): while True: print "Waiting for a tag or peer to be touched" - while True: - general_bytes = nfc.llcp.startup({}) - tag = clf.poll(general_bytes) - if tag == None: - continue + tag = find_peer(clf) + if isinstance(tag, nfc.DEP): + wps_handover_init(tag) + continue - if isinstance(tag, nfc.DEP): - wps_handover_init(tag) - break + if tag.ndef: + wps_tag_read(tag) + continue - if tag.ndef: - wps_tag_read(tag) - break - - if tag: - print "Not an NDEF tag - remove tag" - while tag.is_present: - time.sleep(0.1) - break + print "Not an NDEF tag - remove tag" + while tag.is_present: + time.sleep(0.1) except KeyboardInterrupt: raise SystemExit