/rtl-sdr-scanner-cpp

Primary LanguageC++GNU General Public License v3.0GPL-3.0

Introduction

This project contains sdr scanner written in c++ to scan and record multiple interesting frequencies bandwidth in the same time (eg. 108 MHz, 144 MHz, 440 Mhz, etc). This is possible by switching quickly between frequencies bandwidth.

Sdr scanner also allows you to record multiple transmissions simultaneously (if they are transmitted on the same band). For example, if one transmission is on 145.200 MHz and the other is on 145.600 MHz, the scanner will record and save both!

It also provides easy but very powerful web panel to explore recordings and spectrograms.

Supported devices

  • rtl-sdr
  • HackRF

Sample data collected

YouTube video (old version)

Spectrogram Transmission

Quickstart

Install docker

If you do not have docker installed, follow the instructions available at https://docs.docker.com/desktop/ to install docker and docker compose.

Run

Download sample configuration and docker file, then run it. Customize config.json to your needs.

mkdir -p sdr
cd sdr
wget https://github.com/shajen/rtl-sdr-scanner-cpp/raw/master/config.json
wget https://github.com/shajen/rtl-sdr-scanner-cpp/raw/master/docker-compose.yml
docker compose up

To update docker images to latest version type:

docker compose pull

Also remember to update docker-compose.yml and config.json.

Panel

Open http://localhost:8000/sdr/spectrograms/ and wait for data to collect.

Admin panel available at http://localhost:8000/admin/. Username: admin, password: password.

Important

Blacklist kernel modules

If you use rtl-sdr remember to blacklist rtl2832 modules. Then reboot system.

sudo nano /etc/modprobe.d/blacklist-rtl2832.conf
blacklist rtl2832
blacklist dvb_usb_rtl28xxu
blacklist rtl2832_sdr
blacklist rtl8xxxu

RaspberryPi

Docker version should work on RaspberryPi, but keep in mind that RaspberryPi is not powefull machine and is not good for sdr data processing. sdr device can produce 40 megabytes per second! It's a lot of data for RaspberryPi to processing in real time. It's a lot of data even for some desktop computers.

If you still want to do this, please replace the SD card with a fast one and make sure you have a strong version of RaspberryPi.

Better idea is to build sdr-scanner from sources via cmake and run natively on RaspberryPi. Next run sdr-monitor and mqtt-broker on any other machine (even in the cloud) and connect sdr-scanner to them (you have to set valid mqtt data in config.json and maybe manipulate in docker-compose.yml).

Noise learner

To auto-detect transmissions, sdr scanner has to learn noise level every run. It takes first n seconds (defined in config.json as noise_learning_time_seconds default is 30 seconds). So if any transmission will appear in this period it's may not be detected by scanner later.

Torn transmissions detector

Sdr scanner has feature to avoid recording torn transmission like below.

It takes first n seconds (defined in config.json as torn_transmission_learning_time_seconds default is 60 seconds) seconds.

Auto-recording

So sdr scanner starts auto-recording transsmions after noise_learning_time_seconds + torn_transmission_learning_time_seconds.

Required resources

Using this software with HackRF and sample rate 10 MHz and above needs strong PC. In most casies, Raspberry Pi will not be enough.

For example, HackRF with sample rate 20 Mhz generates about 40 MB of data every second, and processing it in real-time needs a strong CPU with multiple cores and some memory resources.

Config

All of the following examples should be used in the config.json file.

rtl-sdr

single frequency range

To scan single frequency range:

{
  "scanner_frequencies_ranges": [
    {
      "device_serial": "auto",
      "ranges": [
        {
          "start": 144000000,
          "stop": 146000000,
          "sample_rate": 2048000
        }
      ]
    }
  }
}

ppm and gain

To set ppm to 5 and gain to 49.6:

{
  "devices": {
    "rtl_sdr": {
      "ppm_error": 5,
      "tuner_gain": 49.6,
      "offset": 0
    }
  }
}

HackRF

single frequency range

To scan single frequency range:

{
  "scanner_frequencies_ranges": [
    {
      "device_serial": "auto",
      "ranges": [
        {
          "start": 430000000,
          "stop": 450000000,
          "sample_rate": 20480000
        }
      ]
    }
  }
}

gain

To set lna to 16 and gain to 42:

{
  "devices": {
    "hack_rf": {
      "lna_gain": 16,
      "vga_gain": 42,
      "offset": 0
    }
  }
}

Ignored frequencies

To ignore annoying frequency that you are not interested use ignored_frequencies. For example to ignore frequency 144 Mhz with width 20 kHz and 145.350 Mhz with width 50 kHz use:

{
  "ignored_frequencies": [
    {
      "frequency": 144000000,
      "bandwidth": 20000
    },
    {
      "frequency": 145350000,
      "bandwidth": 50000
    }
  ]
}

Use multipe devices

To use two dongles with serials 11111111 and 22222222:

{
  "scanner_frequencies_ranges": [
    {
      "device_serial": "11111111",
      "ranges": [
        {
          "start": 144000000,
          "stop": 146000000,
          "sample_rate": 2048000
        }
      ]
    },
    {
      "device_serial": "22222222",
      "ranges": [
        {
          "start": 440000000,
          "stop": 442000000,
          "sample_rate": 2048000
        }
      ]
    }
  ]
}

If you have multiple rtl-sdr dongles with the same serial you can change it with rtl_eeprom -s 12345678.

Scan multipe frequencies ranges

To scan 144 Mhz - 146 Mhz and 440 Mhz - 442 Mhz in the same time:

{
  "scanner_frequencies_ranges": [
    {
      "device_serial": "auto",
      "ranges": [
        {
          "start": 144000000,
          "stop": 146000000,
          "sample_rate": 2048000
        },
        {
          "start": 440000000,
          "stop": 442000000,
          "sample_rate": 2048000
        }
      ]
    }
  ]
}

Custom fft

It is possible to set custom fft on spectrogram.

{
  "scanner_frequencies_ranges": [
    {
      "device_serial": "auto",
      "ranges": [
        {
          "start": 144000000,
          "stop": 146000000,
          "sample_rate": 2048000,
          "fft": 16384
        }
      ]
    }
  ]
}

Debugging

If you have some problems with this software follow the steps to get debug log.

Set "console_log_level": "trace" in config.json.

Then run app normally by docker compose up. After the error run docker compose logs > logs.txt. Please attach logs.txt if you create a new issue. Do not paste logs directly to issue. Upload it to any file host service (https://file.io/, https://pastebin.com/ or any you like).

Timezone

If timezone detection not work correctly and it seems to use UTC instead your timezone please set timezone in host system. To set Europe/Warsaw type:

echo "Europe/Warsaw" > /etc/timezone

Advanced usage

Build from sources

CMake

Build

sudo apt-get install build-essential cmake ccache libfftw3-dev libspdlog-dev librtlsdr-dev libhackrf-dev libliquid-dev nlohmann-json3-dev libmosquitto-dev libgtest-dev libgmock-dev libboost-all-dev
git clone https://github.com/shajen/rtl-sdr-scanner-cpp sdr-scanner
cd sdr-scanner
cmake -B build -DCMAKE_BUILD_TYPE=Release .
cmake --build build -j$(nproc)

Run

./build/auto-sdr config.json

Docker

Build

git clone https://github.com/shajen/rtl-sdr-scanner-cpp sdr-scanner
cd sdr-scanner
docker build -t shajen/sdr-scanner -f Dockerfile .

Run

docker run --rm -it -v ${PWD}/config.json:/config.json --device /dev/bus/usb:/dev/bus/usb shajen/sdr-scanner

Distributed application system

It is possible to run every module (sdr-broker, sdr-scanner and sdr-monitor) on different machines and connect them. Please familiar with docker-compose.yml to do it.

Contributing

In general don't be afraid to send pull request. Use the "fork-and-pull" Git workflow.

  1. Fork the repo
  2. Clone the project to your own machine
  3. Commit changes to your own branch
  4. Push your work back up to your fork
  5. Submit a Pull request so that we can review your changes

NOTE: Be sure to merge the latest from upstream before making a pull request!

Donations

If you enjoy this project and want to thanks, please use follow link:

Support via PayPal

License

License