HomeGuides
Log In
Guides

Communication with devices

VSM can communicate with Vehicle over different communication channels Currently supported channels are below:

Serial port configuration

VSM which communicates with vehicles via serial ports should define at least one serial port, otherwise, VSM will not try to connect to the vehicles. Port name and baud rate should be both defined.

Port name.
Required
• Name: connection.serial.[index].name = [regular expression]
• Description: Ports that should be used to connect to the vehicles by the given VSM. Port names are defined by a [regular expression] which can be used to define just a single port or create a port filtering regular expression. Expression is case insensitive on Windows. [index] is an arbitrary port indexing name.
• Example:

connection.serial.1.name = /dev/ttyUSB[0-9]+|com[0-9]+

• Example:

connection.serial.2.name = com42

Port baud rate.
Required

• Name: connection.serial.[index].baud.[baud index] = [baud]
• Description: Baud rate for port opening. [baud index] is an optional arbitrary name used when it is necessary to open the same serial port using multiple baud rates. [index] is an arbitrary port indexing name.
• Example:

connection.serial.1.baud.1 = 9600

• Example:

connection.serial.1.baud.2 = 57600

• Example:

connection.serial.2.baud = 38400

Excluded port name.
Optional

• Name: connection.serial.exclude.[exclude index] = [regular expression]
• Description: Ports that should not be used for vehicle access by this VSM. Port names are defined by a [regular expression] which can be used to define just a single port or create a port filtering regular expression. The filter is case-insensitive on Windows. [exclude index] is an arbitrary indexing name used when more than one exclude name is defined.
• Example:

connection.serial.exclude.1 = /dev/ttyS.∗

• Example:

connection.serial.exclude = com1

Serial port arbiter.
Optional

• Name: connection.serial.use_arbiter = [yes|no]
• Description: Enable (yes) or disable (no) serial port access arbitration between VSMs running on the same machine. It is recommended to have it enabled to avoid situations when multiple VSMs try to open the same port simultaneously.
• Default: yes
• Example:

connection.serial.use_arbiter = no

Outgoing TCP connection configuration

VSM can be configured to connect to the vehicle via TCP. VSM will try to establish a connection to the specified address:port.
Used to connect to vehicle simulator or when the vehicle is equipped with a WiFi adapter.

Remote TCP port.
Required

• Name: connection.tcp_out.[index].port = [port number]
• Description: Remote port to connect to.
• Example:

connection.tcp_out.1.port = 5762

IP-address for outgoing TCP connection.
Required

• Name: connection.tcp_out.[index].address = [IP-address]
• Description: IP-address of the vehicle to connect to.
• Example:

connection.tcp_out.1.address = 10.0.0.111

Incoming TCP connection configuration

VSM can be configured to listen for incoming TCP connections from the vehicle. Multiple vehicles are supported on the same port.
Used to connect to a vehicle equipped with a WiFi adapter.

Local listening TCP port.
Required

• Name: connection.tcp_in.[index].local_port = [port number]
• Description: Remote port to connect to.
• Example:

connection.tcp_in.1.local_port = 5762

Local IP address.
Optional

• Name: connection.tcp_in.[index].local_address = [IP-address]
• Description: Local IP address to bind to.
• Default: 0.0.0.0 (all interfaces)
• Example:

connection.tcp_in.1.local_address = 127.0.0.1

Outgoing UDP connection configuration

VSM can be configured to connect to the vehicle via UDP. VSM will try to establish a UDP connection to the specified address:port.

Remote IP address for UDP.
Required

• Name: connection.udp_out.[index].address = [IP-address]
• Description: Remote IP-address to send outgoing UDP packets to.
• Example:

connection.udp_out.1.address = 192.168.1.1

Remote UDP port.
Required

• Name: connection.udp_out.[index].port = [port number]
• Description: Remote UDP port to send outgoing packets to.
• Example: connection.udp_out.1.port = 14551

connection.udp_out.1.port = 14551

Local IP-address for UDP.
Optional

• Name: connection.udp_out.[index].local_address = [IP-address]
• Description: Local IP address to bind to.
• Default: 0.0.0.0 (bind to all interfaces)
• Example:

connection.udp_out.1.local_address = 0.0.0.0

Local UDP port.
Optional

• Name: connection.udp_out.[index].local_port = [port number]
• Description: Local UDP port to listen for incoming packets on.
• Default: 0 (bind to random port)
• Example:

connection.udp_out.1.local_port = 14550

Incoming UDP connection configuration

VSM can be configured to listen for UDP connections from the vehicle. The vehicle must be actively sending heartbeat/telemetry on a specified UDP port before it can be detected by VSM. VSM will automatically detect multiple vehicles on the same port. This is very useful for "drone swarm" setups as there is no need to specify a connector for each vehicle and no need to know the IP address of each vehicle in advance.

Local UDP port.
Required

• Name: connection.udp_in.[index].local_port = [port number]
• Description: Local UDP port to listen for incoming packets on.
• Example:

connection.udp_in.1.local_port = 14550

Local IP-address for UDP.
Optional

• Name: connection.udp_in.[index].local_address = [IP-address]
• Description: Local ip address to bind to.
• Default: 0.0.0.0 (bind to all interfaces)
• Example: connection.udp_in.1.local_address = 0.0.0.0

connection.udp_in.1.local_address = 0.0.0.0

Incoming UDP connection configuration (any peer)

This connection type is similar to "udp_in" with the exception that all incoming traffic will be received as one stream. It is used for special-purpose connections and cannot be used to connect vehicles.

Local UDP port.
Required

• Name: connection.udp_any.[index].local_port = [port number]
• Description: Local UDP port to listen for incoming packets on.
• Example:

connection.udp_any.1.local_port = 14550

Local IP-address for UDP.
Optional

• Name: connection.udp_any.[index].local_address = [IP-address]
• Description: Local ip address to bind to.
• Default: 0.0.0.0 (bind to all interfaces)
• Example: connection.udp_any.1.local_address = 0.0.0.0

connection.udp_any.1.local_address = 0.0.0.0

Named pipes

VSM is able to communicate with vehicles over the named pipe. The pipe must already exist.

• Name: connection.pipe.[index].port = pipe_name
• Description: Pipe name
• Example:

connection.pipe.1.name = \\pipe\my_named_pipe

Proxy configuration

VSM is able to communicate with vehicles via proxy service which redirects dataflow received from vehicles through TCP connection to VSM and vice versa using a specific protocol. In other words, the proxy service appears as a router between vehicles and VSM. At the moment there is one implementation of proxy in UgCS called XBee Connector, which retranslates data from the ZigBee network to the respective VSM.

IP-address for proxy.
Required

• Name: connection.proxy.[index].address = [IP-address]
• Description: IP-address to connect proxy to. Specify local or remote addresses.
• Example:

connection.proxy.1.address = 127.0.0.1

TCP port for proxy.
Required

• Name: connection.proxy.[index].port = [port number]
• Description: TCP port to be connected with proxy through. Should be the same as in the configuration on the proxy side.
• Example:

connection.proxy.1.port = 5566