|
|
пре 5 година | |
|---|---|---|
| .. | ||
| components | пре 5 година | |
| main | пре 5 година | |
| CMakeLists.txt | пре 5 година | |
| Makefile | пре 5 година | |
| README.md | пре 5 година | |
| partitions_example.csv | пре 5 година | |
| sdkconfig.defaults | пре 5 година | |
| sniffer-esp32-pcap.png | пре 7 година | |
| Supported Targets | ESP32 | ESP32-S2 |
|---|
(See the README.md file in the upper level 'examples' directory for more information about examples.)
This example demonstrates basic usage of WiFi sniffer mode by saving packets into SD card with pcap format. We can send pcap file to host via JTAG interface as well.
For more information about pcap, please go to wikipedia.
This example is based on console component. For more information about console, please refer to console guide.
To run this example, you should have one ESP32 dev board integrated with a SD card slot (e.g ESP-WROVER-KIT) or just connect ESP32-DevKitC to a SD card breakout board. If you want to send packets to host, make sure to connect ESP32 to some kind of JTAG adapter.
Open the project configuration menu (idf.py menuconfig). Then go into Example Configuration menu.
Store command history in flash if you want to save command history into flash (recommend).Select destination to store pcap file menu item.
SD Card means saving packets (pcap format) into the SD card you plug in.JTAG (App Trace) means sending packets (pcap format) to host via JTAG interface. This feature depends on app trace component.SD card mount point in the filesystem menu item. This configuration only takes effect when you choose to save packets into SD card.Max name length of pcap file menu item.Length of sniffer work queue menu item.Stack size of sniffer task menu item.Length of sniffer work queue menu item.idf.py -p PORT flash monitor
(Replace PORT with name of the serial port.)
(To exit the serial monitor, type Ctrl-].)
See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects.
sniffer Command Usagesniffer [-f ][-i ] [-F ]... [-c ][--stop] Capture specific packet and store in pcap format -f, --file= name of the file storing the packets in pcap format -i, --interface= which interface to capture packet -F, --filter= filter parameters -c, --channel= communication channel to use
--stop stop running snifferThe
sniffercommand support some important options as follow:
-f: Specify the name of file who will store the packets, default value issniffer, and the resulting file name will be like “snifferX.pcap”, here ‘X’ shows the file’s order.-i: Specify the interface to sniffer packets, currently only supportwlan-c:Specify the channel to sniffer packet-F: Specify the filter condition, currently only support following filter conditions, you can select any number of them
- mgmt: Management packets
- data: Data packets
- ctrl: Control packets
- misc: Other packets
- mpdu: MPDU packets
- ampdu: AMPDU packets
--stop: Stop sniffer jobMount SD Card
======================================================= | Steps to sniffer WiFi packets | | | | 1. Enter 'help' to check all commands' usage | | 2. Enter 'mount <device>' to mount filesystem | | 3. Enter 'sniffer' to start capture packets | | 4. Enter 'unmount <device>' to unmount filesystem | | | ======================================================= esp32> mount sd I (158912) example: Initializing SD card I (158912) example: Using SDMMC peripheral I (158912) gpio: GPIO[13]| InputEn: 0| OutputEn: 1| OpenDrain: 0| Pullup: 0| Pulldown: 0| Intr:0 Name: SA16G Type: SDHC/SDXC Speed: 20 MHz Size: 14832MBStart Sniffer
esp32> sniffer -f sniffer-example -i wlan -c 2 I (8946) cmd_sniffer: open file successfully W (8966) phy_init: failed to load RF calibration data (0x1102), falling back to full calibration I (9176) phy: phy_version: 4100, 6fa5e27, Jan 25 2019, 17:02:06, 0, 2 I (9186) wifi: ic_enable_sniffer I (9196) cmd_sniffer: start WiFi promiscuous ok esp32> sniffer --stop I (31456) wifi: ic_disable_sniffer I (31456) wifi: flush txq I (31456) wifi: stop sw txq I (31456) wifi: lmac stop hw txq I (31456) cmd_sniffer: stop WiFi promiscuous okUnmount SD Card
esp32> unmount sd I (248800) example: Card unmountedSteps for sending packets to host via JTAG interface
- Select
JTAG (App Trace)as the destination of pcap files.- Build & Flash with
idf.py -p PORT flash- Connect JTAG, run OpenOCD (for more information about how-to please refer to JTAG Debugging).
- Telnet to localhost with 4444 port:
telnet localhost 4444.- In the telnet session, run command like
esp32 apptrace start file://sniffer-esp32.pcap 1 -1 20(more information about this command, please refer to apptrace command).- Run the example, start sniffer with command
sniffer(you don't need to specify the filename, because it has been set in step5).- Stop sniffer by entering command
sniffer --stopin the example console.- Stop tracing by entering command
esp32 apptrace stopin the telnet session.Open PCap File in Wireshark
Troubleshooting
- Make sure you have pluged in your SD card and mount it into filesystem before doing sniffer work or you will get error message like “Create file /sdcard/sniffer0.pcap failed”.
- To protect the SD card, we recommand you to execute command
unmount sdbefore you plug out your SD card.- Make sure to run
esp32 apptracecommand before or immediately after a new sniffer task started when you try this example with JTAG. Otherwise the console will issue warning messagewaiting for apptrace establishedevery 1 second. If the apptrace communication doesn't be established within 10 seconds (can be altered by macroSNIFFER_APPTRACE_RETRY), this sniffer command will failed with an error messagewaiting for apptrace established timeout.(For any technical queries, please open an issue on GitHub. We will get back to you as soon as possible.)