Skip to content

Commit

Permalink
fix: use external precland if available during missions
Browse files Browse the repository at this point in the history
  • Loading branch information
asimopunov committed Aug 28, 2024
1 parent f3d58cd commit a35755e
Show file tree
Hide file tree
Showing 6 changed files with 36 additions and 17 deletions.
1 change: 1 addition & 0 deletions src/modules/navigator/mission.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -184,6 +184,7 @@ Mission::do_need_move_to_takeoff()
return false;
}


void Mission::setActiveMissionItems()
{
/* Get mission item that comes after current if available */
Expand Down
7 changes: 0 additions & 7 deletions src/modules/navigator/mission_base.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -357,13 +357,6 @@ MissionBase::on_active()
do_abort_landing();
}

if (_work_item_type == WorkItemType::WORK_ITEM_TYPE_PRECISION_LAND) {
_navigator->get_precland()->on_active();

} else if (_navigator->get_precland()->is_activated()) {
_navigator->get_precland()->on_inactivation();
}

updateAltToAvoidTerrainCollisionAndRepublishTriplet(_mission_item);
}

Expand Down
3 changes: 3 additions & 0 deletions src/modules/navigator/mission_base.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,9 @@
#include "mission_block.h"
#include "navigation.h"

#include <commander/px4_custom_mode.h>
#include <uORB/topics/vehicle_command.h>

using namespace time_literals;

class Navigator;
Expand Down
31 changes: 29 additions & 2 deletions src/modules/navigator/mission_block.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,32 @@

using matrix::wrap_pi;


static bool send_vehicle_command(const uint32_t cmd, const float param1 = NAN, const float param2 = NAN,
const float param3 = NAN, const float param4 = NAN, const double param5 = static_cast<double>(NAN),
const double param6 = static_cast<double>(NAN), const float param7 = NAN)
{
vehicle_command_s vcmd{};
vcmd.command = cmd;
vcmd.param1 = param1;
vcmd.param2 = param2;
vcmd.param3 = param3;
vcmd.param4 = param4;
vcmd.param5 = param5;
vcmd.param6 = param6;
vcmd.param7 = param7;

uORB::SubscriptionData<vehicle_status_s> vehicle_status_sub{ORB_ID(vehicle_status)};
vcmd.source_system = vehicle_status_sub.get().system_id;
vcmd.target_system = vehicle_status_sub.get().system_id;
vcmd.source_component = vehicle_status_sub.get().component_id;
vcmd.target_component = vehicle_status_sub.get().component_id;

uORB::Publication<vehicle_command_s> vcmd_pub{ORB_ID(vehicle_command)};
vcmd.timestamp = hrt_absolute_time();
return vcmd_pub.publish(vcmd);
}

MissionBlock::MissionBlock(Navigator *navigator, uint8_t navigator_state_id) :
NavigatorMode(navigator, navigator_state_id)
{
Expand Down Expand Up @@ -1004,12 +1030,13 @@ void MissionBlock::startPrecLand(uint16_t land_precision)
{
if (_mission_item.land_precision == 1) {
_navigator->get_precland()->set_mode(PrecLandMode::Opportunistic);
_navigator->get_precland()->on_activation();

} else { //_mission_item.land_precision == 2
_navigator->get_precland()->set_mode(PrecLandMode::Required);
_navigator->get_precland()->on_activation();
}

send_vehicle_command(vehicle_command_s::VEHICLE_CMD_DO_SET_MODE, 1, PX4_CUSTOM_MAIN_MODE_AUTO,
PX4_CUSTOM_SUB_MODE_AUTO_PRECLAND);
}

void MissionBlock::updateAltToAvoidTerrainCollisionAndRepublishTriplet(mission_item_s mission_item)
Expand Down
3 changes: 3 additions & 0 deletions src/modules/navigator/mission_block.h
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,9 @@
#include <uORB/topics/vehicle_global_position.h>
#include <uORB/topics/vtol_vehicle_status.h>

#include <commander/px4_custom_mode.h>
#include <uORB/topics/vehicle_command.h>

// cosine of maximal course error to exit loiter if exit course is enforced (fixed-wing only)
static constexpr float kCosineExitCourseThreshold = 0.99619f; // cos(5°)

Expand Down
8 changes: 0 additions & 8 deletions src/modules/navigator/rtl_direct.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -109,14 +109,6 @@ void RtlDirect::on_active()
// note: it may trigger multiple times during a RTL, as every time the altitude set is reset
updateAltToAvoidTerrainCollisionAndRepublishTriplet(_mission_item);
}

if (_rtl_state == RTLState::LAND && _param_rtl_pld_md.get() > 0) {
// Need to update the position and type on the current setpoint triplet.
_navigator->get_precland()->on_active();

} else if (_navigator->get_precland()->is_activated()) {
_navigator->get_precland()->on_inactivation();
}
}

void RtlDirect::setRtlPosition(PositionYawSetpoint rtl_position, loiter_point_s loiter_pos)
Expand Down

0 comments on commit a35755e

Please sign in to comment.