MMDVM-based Digital Voice Modem Host Software
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Go to file
Bryan Biedenkapp 842c17c985
more very very experimental PDU AMBT support;
4 years ago
dmr continue implementing DFSI; remove some header information (it was included incorrectly some cases); 4 years ago
edac fix data types; 5 years ago
host limit RCON password to 64 characters; fix issue where dedicated control channels in VOC mode would ignore network traffic; 4 years ago
lookups continue implementing DFSI; remove some header information (it was included incorrectly some cases); 4 years ago
modem cleanup message; 4 years ago
network convert RPTC to JSON; 4 years ago
p25 more very very experimental PDU AMBT support; 4 years ago
yaml fix compiler warnings about exception polymorhism; enforce some fixed mode rules for hotspots; fix potential buffer overflow; 4 years ago
.gitattributes inital commit from private repo to public; 6 years ago
.gitignore update .gitignore to ignore compiled binaries; 4 years ago
DVMHost.sln inital commit from private repo to public; 6 years ago
DVMHost.vcxproj initial commits of DFSI; 4 years ago
DVMHost.vcxproj.filters initial commits of DFSI; 4 years ago
Defines.h fix incorrect handling of channel number as decimal in setup; enhance setup to make it more comprehensive (essentially all "system" configuration parameters can be modified in setup mode); add support to calibration to set the FDMA preambles, P25 correlation count, DMR Rx Delay as well as setting the Rx and Tx frequency offsets; 4 years ago
HostMain.cpp implement a "setup" mode allowing the channel LCN information to be much more easily set; 4 years ago
HostMain.h inital commit from private repo to public; 6 years ago
LICENSE.md inital commit from private repo to public; 6 years ago
Log.cpp apply upstream updates to UDPSocket; 5 years ago
Log.h implement a "setup" mode allowing the channel LCN information to be much more easily set; 4 years ago
Makefile fix missing cleanups of dfsi directory; fix uncorrected define typos; 4 years ago
Makefile.arm fix missing cleanups of dfsi directory; fix uncorrected define typos; 4 years ago
Makefile.rpi-arm fix missing cleanups of dfsi directory; fix uncorrected define typos; 4 years ago
Mutex.cpp inital commit from private repo to public; 6 years ago
Mutex.h apply upstream updates to UDPSocket; 5 years ago
README.md update README.md; 4 years ago
RSSI.dat inital commit from private repo to public; 6 years ago
RingBuffer.h inital commit from private repo to public; 6 years ago
StopWatch.cpp inital commit from private repo to public; 6 years ago
StopWatch.h apply upstream updates to UDPSocket; 5 years ago
Thread.cpp inital commit from private repo to public; 6 years ago
Thread.h apply upstream updates to UDPSocket; 5 years ago
Timer.cpp inital commit from private repo to public; 6 years ago
Timer.h inital commit from private repo to public; 6 years ago
Utils.cpp fix issue that caused an assertion crash when resetting the modem; store the DataHeader data during DMR traffic for future use; 5 years ago
Utils.h minor alteration to some debug/trace and logging; 5 years ago
config.example.yml ensure location data is some default value (like Antarctica?); 4 years ago
cpp.hint inital commit from private repo to public; 6 years ago
iden_channel_calc.py better support simplex channel selection via iden table; update iden_channel_calc.py helper to support doing conversion to channel no and FROM channel no; 5 years ago
iden_table.example.dat rename files so that people who want to run dvmhost from the source repo don't blow away their files; 4 years ago
rid_acl.example.dat rename files so that people who want to run dvmhost from the source repo don't blow away their files; 4 years ago
tg_acl.example.dat rename files so that people who want to run dvmhost from the source repo don't blow away their files; 4 years ago

README.md

Digital Voice Modem Host

The DVM Host software provides the host computer implementation of a mixed-mode DMR/P25 or dedicated-mode DMR or P25 repeater system that talks to the actual modem hardware. The host software; is the portion of a complete Over-The-Air modem implementation that performs the data processing, decision making and FEC correction for a digital repeater.

This project is a direct fork of the MMDVMHost (https://github.com/g4klx/MMDVMHost) project, and combines the MMDVMCal (https://github.com/g4klx/MMDVMCal) project into a single package.

Building

Please see the various Makefile included in the project for more information. (All following information assumes familiarity with the standard Linux make system.)

The DVM Host software does not have any specific library dependancies and is written to be as library-free as possible. A basic GCC install is usually all thats needed to compile.

  • Makefile - This makefile is used for building binaries for the native installed GCC.
  • Makefile.arm - This makefile is used for cross-compiling for a ARM platform.
  • Makefile.rpi-arm - This makefile is used for cross-compiling for a Raspberry Pi.

Use the make command to build the software.

  • For RPi using Debian/Ubuntu OS install the standard ARM embedded toolchain (typically arm-gcc-none-eabi).
    1. Switch to "/opt" and checkout https://github.com/raspberrypi/tools.git.

Configuration

When first setting up a DVM instance, it is required to properly set the "Logical Channel ID" (or LCN ID) data and then calibrate the modem.

Initial Setup

  1. Edit config.yml and ensure the settings for the modem are correct, find the "modem" section in "system". Check that the uart protocol has the appropriate UART port and port speed set (the config.yml defaults to /dev/ttyUSB0 and 115200).
  2. Start dvmhost as follows: /path/to/dvmhost -c /path/to/config.yml --setup. This will start the dvmhost setup mode.
  3. Set the channel ID using the "i" command. This will select the identity table bandplan entry to use for frequency selection. The bandplan information is contained within the iden_table.dat file. The identity table information will also appear during dvmhost startup like this:
M: ... (HOST) Channel Id 0: BaseFrequency = 851006250Hz, TXOffsetMhz = -45.000000MHz, BandwidthKhz = 12.500000KHz, SpaceKhz = 6.250000KHz
M: ... (HOST) Channel Id 1: BaseFrequency = 762006250Hz, TXOffsetMhz = 30.000000MHz, BandwidthKhz = 12.500000KHz, SpaceKhz = 6.250000KHz
M: ... (HOST) Channel Id 15: BaseFrequency = 935001250Hz, TXOffsetMhz = -39.000000MHz, BandwidthKhz = 12.500000KHz, SpaceKhz = 6.250000KHz
M: ... (HOST) Channel Id 2: BaseFrequency = 450000000Hz, TXOffsetMhz = 5.000000MHz, BandwidthKhz = 12.500000KHz, SpaceKhz = 6.250000KHz
  1. Set the channel number using either the "c" or "f" command. The "f" command is recommended as it will automatically calculate the appropriate channel number from the DVM's transmit frequency.
  2. Save the configuration using "s" and quit setup mode with "q".

Transmit Calibration

  1. Start dvmhost as follows: /path/to/dvmhost -c /path/to/config.yml --cal. This will start the dvmhost calibration mode. The best way to calibrate the DVM is to use a radio from which you can receive and transmit the appropriate test patterns (for example using ASTRO25 Tuner and an XTS radio to use the "Bit Error Rate" functions under Performance Testing).
  2. Depending on which protocol you are calibration with, enter DMR BS 1031 Hz Test Pattern (M) or P25 1011 Hz Test Pattern (NAC293 ID1 TG1) (P).
  3. Ensure the TXLevel is set to 50 (it should be by default, "`" will display current values, use "T" [increase] and "t" [decrease] if necessary to set it to 50).
  4. If the hardware in use has a TX potentiometer, set it to the to minimum level.
  5. Start Tx (press spacebar to toggle Tx).
  6. While observing the BER via whatever means available, adjust the TX potentiometer for the lowest received BER. If necessary also adjust the software TXLevel for some fine tuning with the "T" (increase) and "t" (decrease).
  7. Stop Tx (press spacebar to toggle Tx).
  8. Save the configuration using "s" and quit calibration mode with "q".

Receive Calibration

  1. Start dvmhost as follows: /path/to/dvmhost -c /path/to/config.yml --cal. This will start the dvmhost calibration mode. The best way to calibrate the DVM is to use a radio from which you can receive and transmit the appropriate test patterns (for example using ASTRO25 Tuner and an XTS radio to use the "Transmitter Test Pattern" functions under Performance Testing).
  2. Depending on which protocol you are calibration with, enter DMR BS 1031 Hz Test Pattern (M) or P25 1011 Hz Test Pattern (P).
  3. Ensure the RXLevel is set to 50 (it should be by default, "`" will display current values, use "R" [increase] and "r" [decrease] if necessary to set it to 50).
  4. If the hardware in use has a RX potentiometer, set it to the to minimum level. (If using something like the RepeaterBuilder STM32 board, decrease both the coarse and fine potentiometers to minimum level.)
  5. Depending on which protocol you are calibration with, enter DMR MS 1031 Hz Test Pattern (J) or P25 1011 Hz Test Pattern (j).
  6. While observing the BER via the calibration console, adjust the RX potentiometer(s) for the lowest received BER. If necessary also adjust the software RXLevel for some fine tuning with the "R" (increase) and "r" (decrease).
  7. Save the configuration using "s" and quit calibration mode with "q".

Calibration Notes

  • During Transmit Calibration, it may be necessary to adjust the symbol levels directly. Normally this isn't required as the DVM will just work, but some radios require some fine adjustment of the symbol levels, this is exposed in the calibration mode.
  • Unusually high BER >10% and other various receive problems may be due to the radio/hotspot being off frequency and requiring some adjustment. Even a slight frequency drift can be catastrophic for proper digital modulation. The recommendation is to ensure the interfaced radio does not have an overall reference frequency drift > +/- 150hz. An unusually high BER can also be explained by DC level offsets in the signal paths, or issues with the FM deviation levels on the interfaced radio being too high or too low.

Notes

Some extra notes for those who are using the Raspberry Pi, default Raspbian OS or Debian OS installations. You will not be able to flash or access the STM32 modem unless you do some things beforehand.

  1. Disable the Bluetooth services. Bluetooth will share the GPIO serial interface on /dev/ttyAMA0. On Rasbian OS or Debian OS, this is done by: systemctl disable bluetooth
  2. The default Rasbian OS and Debian OS will have a getty instance listening on /dev/ttyAMA0. This can conflict with the STM32, and is best if disabled. On Rasbian OS or Debian OS, this is done by: systemctl disable serial-getty@ttyAMA0.service
  3. There's a default boot option which is also listening on the GPIO serial interface. This must be disabled. Open the /boot/config.txt file in your favorite editor (vi or pico) and change it from:

console=serial0,115200 console=tty1 root=PARTUUID=[this is dynamic per partition] rootfstype=ext4 elevator=deadline fsck.repair=yes rootwait

to

console=tty1 root=PARTUUID=[this is dynamic per partition] rootfstype=ext4 elevator=deadline fsck.repair=yes rootwait

All thats being done is to remove the console=serial0,115200 part. Do not change anything else. Save the file, then reboot.

License

This project is licensed under the GPLv2 License - see the LICENSE.md file for details. Use of this project is intended, strictly for amateur and educational use ONLY. Any other use is at the risk of user and all commercial purposes are strictly forbidden.

Powered by TurnKey Linux.