Skip to content

This software aims to replicate the capabilities of the SmartRF Packet Sniffer 2 from Texas Instruments, but through a terminal on Linux.

License

Notifications You must be signed in to change notification settings

AcenoTecnologia/tuxniffer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Tuxniffer

This software aims to replicate the capabilities of the SmartRF Packet Sniffer 2 from Texas Instruments, but through a terminal on Linux.

Table of Contents

Overview

The SmartRF Packet Sniffer 2 from Texas Instruments is a useful tool for sniffing packet data using some of their devices. It can save sniffed packets to a .pcap files and send packets through a pipe for live view. It also support multiple devices to be connected at once.

Texas Instruments also provides, with the SmartRF Packet Sniffer 2, Wireshark plugins to interpret the packets (see how to configure Wireshark on Windows here). However, despite these plugins being semi-compatible with Linux, they only make it available for Windows. This software also has instructions for using those plugins on Linux.

Features

This software is capable of:

  • Sniffing network packets sent by Texas Instruments family CC13XX, CC26XX and Launchpad.
  • Supporting multiple devices simultaneously with different Radio Modes each.
  • Storing packets in a .pcap file that can be opened using Wireshark.
  • Viewing packets live in Wireshark through pipes.
  • Configuring Radio Mode for different packet types per device.
  • Configuring the time interval between file generations.
  • Splitting device data into different files/ pipes or merging it into a single file.
  • Support for .YAML config file and CLI usage.

Build Instructions

Folder Creation

Create a directory named build:

mkdir build
cd build

Run CMake

From within the build directory, run:

cmake ..

Build the Project

Now, you can build your project using:

cmake --build .

Specify Debug Mode

By default, CMake builds in Release mode. To build in Debug mode, specify the build type when running cmake:

cmake -DCMAKE_BUILD_TYPE=Debug ..

Then build the project as usual:

cmake --build .

The binary file is now stored in build/bin.

Compiling on Windows

While this project is not meant to be used on Windows, it is compatible with Visual Studio C++ Compiler (MSVC). To import this repository as a VS project: Open VS -> Open Local Folder -> Select the tuxniffer folder -> Right click on the CMakeLists.txt -> Delete Cache and Reconfigure -> Select x64 release or debug option at tob bar -> Select tuxniffer.exe -> Execute the build/ compilation step by clicking the green arrow. If you find any errors during this step check Microsoft official instructions to import CMake projects into Visual Studio.

Usage

CLI

Usage: .build/bin/tuxniffer -p <port> -m <mode> -c <channel> [options]

Options:

  • -h, --help: Show help message and exit.
  • -l, --list_radio: Show radio mode table and exit.
  • -p, --port: Serial port to connect to (required).
  • -m, --radio_mode: Radio mode to use (required).
  • -c, --channel: Channel to use (required).
  • -n, --name: Pipe name / log file name (.pcap).
  • -P, --path: Path to save log file.
  • -r, --reset_period: Log file reset period (none | hourly | daily | weekly | monthly).
  • -t, --time_duration: Sniffing duration in seconds. Runs indefinitely when missing.
  • -i, --input: Input config file.

Usage Example:

./tuxniffer -p /dev/ttyUSB0 -m 20 -c 20 -n sniffer -r hourly

Using this software through the CLI has some limitations:

  • You can only define one device;
  • You can only define a single base name for the .pcap file and the pipe;
  • You can't disable the .pcap or pipe log;

.YAML Config File

## List of devices that you want to sniff. At least one device is required.
devices:                #required
  - port: /dev/ttyACM0  #required
    radio_mode: 20      #required
    channel: 20         #required
# - port: /dev/ttyACM2  
#   radio_mode: 20      
#   channel: 25         

## Optional log parameters. Values below are the default ones.
# log:
#   enabled: true             # Set false to not create a .pcap log file.
#   path: ./                  # Path to save log file.
#   base_name: aceno          # Log file name.
#   splitDevicesLog: false    # Set true to create a separete log file for each device ([name]_[device_id].pcap).
#   resetPeriod: none         # Log file reset period  (none | hourly | daily | weekly | monthly).

## Optional pipe parameters. Values below are the default ones.
# pipe:
#   enabled: true             # Set false to not create a pipe.
#   name: aceno               # Pipe file name.
#   path: /tmp/               # Path to save pipe file. On Windows the path name is ignored because the only path is \\.\pipe\.
#   splitDevicesPipe: false   # Set true to create a separete log file for each device ([name]_[device_id]).

## Optional time in seconds to execute the sniffer. When -1 runs indefinitely (default).
# duration: -1

You can add more devices to the list, but for each one, you need to set valid values for all three required parameters (port, radio mode, and channel). For log and pipe options, you can only set the parameters you want to change.

This example is also presented in the config.yaml file.

Usage Example:

./tuxniffer -i config.yaml

Note: when the parameter -i is used, other CLI parameters are ignored.

Radio Mode TableN

This program currently supports the following Radio Modes for different kinds of packets:

Mode Name Supported Channels Radio Mode
IEEE 802.15.4g - GFSK 50 Kbps - 915 MHz 0-128 0
IEEE 802.15.4g - GFSK 50 Kbps - 868 MHz 0-33 1
IEEE 802.15.4g - GFSK 50 Kbps - 433 MHz 0-6 2
IEEE 802.15.4g - Simplelink Long Range 5 Kbps - 915 MHz 0-128 3
IEEE 802.15.4g - Simplelink Long Range 5 Kbps - 868 MHz 0-33 4
IEEE 802.15.4g - Simplelink Long Range 5 Kbps - 433 MHz 0-6 5
IEEE 802.15.4g - GFSK 50 Kbps Wi-SUN PHY #1a (ID 1) - 868 MHz 0-128 6
IEEE 802.15.4g - GFSK 50 Kbps Wi-SUN PHY #1b (ID 2) - 915 MHz 0-128 7
IEEE 802.15.4g - GFSK 100 Kbps Wi-SUN PHY #2a (ID 3) - 868 MHz 0-128 8
IEEE 802.15.4g - GFSK 100 Kbps Wi-SUN PHY #2b (ID 4) - 915 MHz 0-128 9
IEEE 802.15.4g - GFSK 150 Kbps Wi-SUN PHY #3 (ID 5) - 868 MHz 0-128 10
IEEE 802.15.4g - GFSK 200 Kbps Wi-SUN PHY #4a (ID 6) - 915 MHz 0-128 11
IEEE 802.15.4g - GFSK 200 Kbps Wi-SUN PHY #4b (ID 7) - 915 MHz 0-128 12
IEEE 802.15.4g - GFSK 100 Kbps ZigBee R23 - 868 MHz 0-128 13
IEEE 802.15.4g - GFSK 500 Kbps ZigBee R23 - 868 MHz 0-128 14
IEEE 802.15.4g - GFSK 200 Kbps - 915 MHz 0-63 15
Generic - GFSK 50 Kbps - 868 MHz 0 16
Generic - GFSK 50 Kbps - 433 MHz 0 17
Generic - Simplelink Long Range 5 Kbps - 868 MHz 0 18
Generic - Simplelink Long Range 5 Kbps - 433 MHz 0 19
IEEE 802.15.4 - O-QPSK - 2405 MHz 11-26 20
BLE - BLE 1 Mbps - 2402 MHz 37,38,39 21

Using with Wireshark

Wireshark recieving packets

Compiling Wireshark plugins on Linux

The PLUGINS.md file contains instructions for compiling the plugins developed by Texas Instruments.

Using Wireshark with pipes

This software allows live packet viewing using Pipes. To access the pipe use:

wireshark -k -i /<path>/<to>/<pipe_name>

You can also select your pipe file path in Wireshark -> Capture -> Manage interfaces -> Pipes.

Wireshark doesn't need to be open at the start of the sniffer execution. The sniffer will store a queue of packets during its running time, and as long as Wireshark is open while the sniffer is running, the packets will be sent in order to it.

Use Cases

The file TESTING.md has a list of cases for basic, intermediate and advanced uses. This file also contains a list of tests with defined inputs and expected outputs that should be checked.

Compatibility

  • This software was compiled using gcc version 11.4.0 (Ubuntu 11.4.0-1ubuntu1~22.04).
  • Boards used for testing during development:
    Board Chip ID Chip Rev FW ID FW Rev
    CC1352P1 5313 21 50 A1
    CC1352P7-1 5313 0 51 A1
  • Firmware used: sniffer_fw version 1.10.0 (avaiable on the installation folder of the SmartRF Packet Sniffer 2 on C:\Program Files (x86)\Texas Instruments\SmartRF Tools\SmartRF Packet Sniffer 2\sniffer_fw)

Texas Instruments Custom Packet Format

Texas Instruments sends packets to Wireshark in a specific way:

  • The first layer is a IPv4 packet (with fake IP addresses);
  • The second layer is a UDP packet (with a fake port);
  • The third layer is the "TI Radio Packet Info", that contains details about COMs, frequency, PHYs, RSSI and FCS;
  • The forth layer can be other Packet Info layer (like BLE Packet Info), or the data layer (IEEE 802.15.4, BLE, ...);

The first two layers are used only to send the "TI Radio Packet Info" by the original SmartRF Packet Sniffer 2 software and contain fake data, thus, it does not impact the data layer nor represent real IP addresses and ports.

Texas Instruments Documentation Issues

During development it was found some inconsistencies between the sniffer documentation presented by Texas Instruments and the device functioning (tested on the CC1352P1 and CC1352P7-1):

  • The baudrate presented in the documentation is 921600, but the firmware source code uses 3000000.
  • Despite showing a state machine with a PAUSED state in the documentation, the firmware source code doesn't have one. Therefore, neither pause and resume commands exists.
  • The PHY code informed by the documentation for IEEE 802.15.4 2.4 GHz band O-QPSK is 0x11, but in reality it is 0x12.
  • This happens because the SmartRF Packet Sniffer 2 by Texas Instruments has a Radio Configuration for IEEE 802.15.4 915 MHz GSFK 200 kbps after 0x0C, which causes a offset of 1 to all subsequent values. This configuration is not on the reference/ documentation, but can be selected on the software. The Radio Mode table bellow is already fixed.
  • The packet response documentation also informs that the response frame data payload has the format: Timestamp (6B) | Payload (0-2047B) | RSSI (1B) | Status (1B). But, in reality is Timestamp (6B) | Separator (1B) | Payload (0-2047B) | RSSI (1B) | Status (1B). It was not found the usage of the Separator. However, neither considering it as Timestamp or Payload work. The Timestamp gets incorrect and the Payload doesn't match the FCS at the end of the frame (last 2B of payload).
  • While this software was developed using the CC1352P7-1 model, the CC1352P1 model was also used for tests and validation. A issue found is that on Windows, with the original SmartRF Packet Sniffer 2, the CC1352P1 could not run any 2.4GHz modes, despite having support. The solution for this issue can be found here.

Known Issues

  • Currently, when a pipe connection is closed, all pipes stop and need to be reconnected. The workaround is to open again all pipes. When a pipe is closed it stops writing to it and stores new packets in the queue, so no data is lost.
  • Pipes cannot be interrupted and reconnected on Windows. Currently there is not workaround this issue. If a pipe disconnects on Windows it is necessary to start the program over.

Dependencies

fkYAML - Header Only Library for parsing YAML file format (MIT License - Used on main.cpp).

About

This software aims to replicate the capabilities of the SmartRF Packet Sniffer 2 from Texas Instruments, but through a terminal on Linux.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published