1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2025-10-25 01:50:21 -04:00
2024-04-14 11:41:00 +02:00
..
2022-05-24 22:51:29 +02:00
2024-04-14 11:41:00 +02:00

AMBE controller

Introduction

Control AMBE3000 serial a.k.a. DV serial devices or AMBE server addresses to use for AMBE digital voice processing.

DV serial devices are supported using the SerialDV library that is a mandatory requirement for this feature to be compiled. Therefore you have to compile and install SerialDV in your system. Please refer to this project Readme.md to compile and install SerialDV. f you install it in a custom location say /opt/install/serialdv you will need to add this define to the cmake command: -DSERIALDV_DIR=/opt/install/serialdv

To effectively use serial DV devices for AMBE decoding you will have to add at least one device to the list of AMBE devices (6) in use.

Although such serial devices work with a serial interface at 400 kb in practice maybe for other reasons they are capable of handling only one conversation at a time. The software will allocate the device dynamically to a conversation with an inactivity timeout of 1 second so that conversations do not get interrupted constantly making the audio output too choppy. In practice you will have to have as many devices listed in (6) as the number of conversations you would like to be handled in parallel.


⚠ With kernel 4.4.52 and maybe other 4.4 versions the default for FTDI devices (that is in the ftdi_sio kernel module) is not to set it as low latency. This results in the ThumbDV dongle not working anymore because its response is too slow to sustain the normal AMBE packets flow. The solution is to force low latency by changing the variable for your device (ex: /dev/ttyUSB0) as follows:

echo 1 | sudo tee /sys/bus/usb-serial/devices/ttyUSB0/latency_timer or sudo setserial /dev/ttyUSB0 low_latency

Newer kernels do not seem to have this issue.


Interface

AMBE controller GUI

1: AMBE server address and port or direct input

Use this freeflow text input box to specify either the address and port of an AMBE server in the form: <IPv4 address>:<port> or any directly attached physical device address.

2: Import above address or device

Import the address or device specified in (1) into the list of used devices. The system will try to open the device or contact the server and will add it to the list only if successful.

3: Remove in use device or address

When a device or address is selected in the in use list (6) push this button to remove it from the list. The corresponding resources will be released.

4: Refresh in use list

Checks the list of devices or addresses currently in use and update the in use list (6).

5: Empty in use list

Removes all devices or addresses in use. The in use list (6) is cleared consequently. This removes all AMBE devices related resources attached to the current instance of the SDRangel program. Therefore consecutive AMBE frames decoding will be handled by the mbelib library if available or no audio will be output.

6: In use list

List of devices or addresses currently in use for AMBE frames decoding by this feature.

Format is the device path or URL followed by a dash then the number of frames successfully decoded then a vertical bar then the number of frames that failed decoding. i.e:

<Device path> - <successful count>|<failed count>

7: Import serial device

Imports a serial device scanned in the list of available AMBE 3000 serial devices (10) in the in use list. If this device is already in the in use list then nothing happens and this is reported in the status text (11)

8: Import all serial devices

Imports all serial devices scanned in the list of available AMBE 3000 serial devices (9) in the in use list. If any device is already in the in use list then it is not added twice.

9: Refresh list of AMBE serial devices

Scans available AMBE 3000 serial devices and updates the list.

10: List of AMBE 3000 serial devices

List of AMBE 3000 connected to the system. Use button (9) to update the list.

11: Status text

A brief text reports the result of the current action.