AWDL(Apple Wireless Direct Link) is a protocol, for wireless P2P communication. AWDL is designed to be low latency and high bandwidth, while requiring only one chip for AWDL and "normal" WiFi. This parser can read and write the network frames used by this protocol. For further information see this stackoverflow post.
- action
- MIF
- PSF
- data(coming soon)
- Arpa
- Version
- Synchronization parameters
- Channel sequence
- Election parameters
- Election parameters v2
- Synchronization tree
- Data path state
- HT capabilities
- IEEE 802.11 Container
- Service parameters
- Service response
The parser was designed to be able to run in low flash environments(i.e. ESP32, wasm). The listed time complexity refers to, if the parser runtime rises with input length. So O(1) means go ahead and O(n) means think before you parse. O(1) parsers are not benchmarked.
TLV | feature | Worst case time complexity |
---|---|---|
Arpa | dns_sd_tlvs | O(n) |
Service Parameters | dns_sd_tlvs | O(n) |
Service Respone | dns_sd_tlvs | min. O(n) |
Channel Sequence | sync_elect_tlvs | O(2n) |
ElectionParameters[V2] | sync_elect_tlvs | O(1) |
Synchronization Parameters | sync_elect_tlvs | O(1) |
Synchronization Tree | sync_elect_tlvs | O(n) |
HTCapabilities | data_tlvs | O(1) |
IEEE80211 Container | data_tlvs | O(n) |
Data Path State | data_tlvs | O(n) |
Version | version_tlv | O(1) |
Do note please, that although the parsers are not yet present, the features are. Also some parsers were bundled into one feature. (For more information on this refer to Milan Stute's dissertation.)
The library doesn't require any allocations, due to the author sacrificing parts of his sanity, to use Iterators everywhere. Allocations are only used for testing, to verify that the reported sizes match reality.
Although the actual parser was written by me, the reverse engineering of the AWDL protocol was conducted by Milan Stute and SeeMoo-Lab. So kudos to them...