ardupilot/libraries/GCS_MAVLink/examples/routing/routing.cpp

106 lines
3.1 KiB
C++
Raw Normal View History

2014-12-16 19:28:56 -04:00
//
// Simple test for the GCS_MAVLink routing
//
#include <AP_HAL/AP_HAL.h>
#include <GCS_MAVLink/GCS.h>
#include <GCS_MAVLink/GCS_MAVLink.h>
#include <GCS_MAVLink/GCS_Dummy.h>
2019-04-04 07:49:44 -03:00
#include <AP_Common/AP_FWVersion.h>
#include <AP_SerialManager/AP_SerialManager.h>
2014-12-16 19:28:56 -04:00
void setup();
void loop();
const AP_HAL::HAL& hal = AP_HAL::get_HAL();
2014-12-16 19:28:56 -04:00
AP_SerialManager _serialmanager;
GCS_Dummy _gcs;
2014-12-16 19:28:56 -04:00
extern mavlink_system_t mavlink_system;
const AP_Param::GroupInfo GCS_MAVLINK_Parameters::var_info[] = {
2014-12-16 19:28:56 -04:00
AP_GROUPEND
};
static MAVLink_routing routing;
static mavlink_status_t status;
2014-12-16 19:28:56 -04:00
void setup(void)
{
2016-05-30 07:05:00 -03:00
hal.console->printf("routing test startup...");
gcs().init();
gcs().setup_console();
2014-12-16 19:28:56 -04:00
}
void loop(void)
{
uint16_t err_count = 0;
// incoming heartbeat
mavlink_message_t msg;
mavlink_heartbeat_t heartbeat = {0};
mavlink_msg_heartbeat_encode_status(3, 1, &status, &msg, &heartbeat);
2014-12-16 19:28:56 -04:00
GCS_MAVLINK *dummy_link = gcs().chan(0);
if (!routing.check_and_forward(*dummy_link, msg)) {
2014-12-16 19:28:56 -04:00
hal.console->printf("heartbeat should be processed locally\n");
err_count++;
}
// incoming non-targetted message
mavlink_attitude_t attitude = {0};
mavlink_msg_attitude_encode_status(3, 1, &status, &msg, &attitude);
if (!routing.check_and_forward(*dummy_link, msg)) {
2014-12-16 19:28:56 -04:00
hal.console->printf("attitude should be processed locally\n");
err_count++;
}
2016-05-12 13:51:11 -03:00
// incoming targeted message for someone else
2014-12-16 19:28:56 -04:00
mavlink_param_set_t param_set = {0};
param_set.target_system = mavlink_system.sysid+1;
param_set.target_component = mavlink_system.compid;
mavlink_msg_param_set_encode_status(3, 1, &status, &msg, &param_set);
if (routing.check_and_forward(*dummy_link, msg)) {
2014-12-16 19:28:56 -04:00
hal.console->printf("param set 1 should not be processed locally\n");
err_count++;
}
2016-05-12 13:51:11 -03:00
// incoming targeted message for us
2014-12-16 19:28:56 -04:00
param_set.target_system = mavlink_system.sysid;
param_set.target_component = mavlink_system.compid;
mavlink_msg_param_set_encode_status(3, 1, &status, &msg, &param_set);
if (!routing.check_and_forward(*dummy_link, msg)) {
2014-12-16 19:28:56 -04:00
hal.console->printf("param set 2 should be processed locally\n");
err_count++;
}
2016-05-12 13:51:11 -03:00
// incoming targeted message for our system, but other compid
2014-12-16 19:28:56 -04:00
// should be processed locally
param_set.target_system = mavlink_system.sysid;
param_set.target_component = mavlink_system.compid+1;
mavlink_msg_param_set_encode_status(3, 1, &status, &msg, &param_set);
if (!routing.check_and_forward(*dummy_link, msg)) {
2014-12-16 19:28:56 -04:00
hal.console->printf("param set 3 should be processed locally\n");
err_count++;
}
// incoming broadcast message should be processed locally
param_set.target_system = 0;
param_set.target_component = mavlink_system.compid+1;
mavlink_msg_param_set_encode_status(3, 1, &status, &msg, &param_set);
if (!routing.check_and_forward(*dummy_link, msg)) {
2014-12-16 19:28:56 -04:00
hal.console->printf("param set 4 should be processed locally\n");
err_count++;
}
if (err_count == 0) {
hal.console->printf("All OK\n");
}
hal.scheduler->delay(1000);
}
AP_HAL_MAIN();