Skip to content

Commit

Permalink
Merge branch 'master' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
datagnss authored Oct 24, 2024
2 parents 7199133 + 92693e0 commit f9fac37
Show file tree
Hide file tree
Showing 41 changed files with 8,741 additions and 2,364 deletions.
2 changes: 1 addition & 1 deletion Tools/AP_Bootloader/board_types.txt
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ AP_HW_SKYSTARSH7HD 1075
AP_HW_PixSurveyA1 1076
AP_HW_AEROFOX_AIRSPEED 1077
AP_HW_ATOMRCF405 1078
AP_HW_CUBEPILOT_CANMOD 1079
AP_HW_CUBENODE 1079
AP_HW_AEROFOX_PMU 1080
AP_HW_JHEMCUGF16F405 1081
AP_HW_SPEEDYBEEF4V3 1082
Expand Down
9 changes: 9 additions & 0 deletions Tools/AP_Periph/AP_Periph.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -168,6 +168,15 @@ void AP_Periph_FW::init()
baro.init();
#endif

#ifdef HAL_PERIPH_ENABLE_IMU
if (g.imu_sample_rate) {
imu.init(g.imu_sample_rate);
if (imu.get_accel_count() > 0 || imu.get_gyro_count() > 0) {
hal.scheduler->thread_create(FUNCTOR_BIND_MEMBER(&AP_Periph_FW::can_imu_update, void), "IMU_UPDATE", 16384, AP_HAL::Scheduler::PRIORITY_CAN, 0);
}
}
#endif

#ifdef HAL_PERIPH_ENABLE_BATTERY
battery_lib.init();
#endif
Expand Down
9 changes: 9 additions & 0 deletions Tools/AP_Periph/AP_Periph.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#include <AP_GPS/AP_GPS.h>
#include <AP_Compass/AP_Compass.h>
#include <AP_Baro/AP_Baro.h>
#include <AP_InertialSensor/AP_InertialSensor.h>
#include "SRV_Channel/SRV_Channel.h"
#include <AP_Notify/AP_Notify.h>
#include <AP_Logger/AP_Logger.h>
Expand Down Expand Up @@ -173,6 +174,10 @@ class AP_Periph_FW {
void send_relposheading_msg();
void can_baro_update();
void can_airspeed_update();
#ifdef HAL_PERIPH_ENABLE_IMU
void can_imu_update();
#endif

#ifdef HAL_PERIPH_ENABLE_RANGEFINDER
void can_rangefinder_update();
#endif
Expand Down Expand Up @@ -230,6 +235,10 @@ class AP_Periph_FW {
AP_Baro baro;
#endif

#ifdef HAL_PERIPH_ENABLE_IMU
AP_InertialSensor imu;
#endif

#ifdef HAL_PERIPH_ENABLE_RPM
AP_RPM rpm_sensor;
uint32_t rpm_last_update_ms;
Expand Down
14 changes: 14 additions & 0 deletions Tools/AP_Periph/Parameters.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -723,6 +723,20 @@ const AP_Param::Info AP_Periph_FW::var_info[] = {
GSCALAR(esc_extended_telem_rate, "ESC_EXT_TLM_RATE", AP_PERIPH_ESC_TELEM_RATE_DEFAULT / 10),
#endif


#ifdef HAL_PERIPH_ENABLE_IMU
// @Param: IMU_SAMPLE_RATE
// @DisplayName: IMU Sample Rate
// @Description: IMU Sample Rate
// @Range: 0 1000
// @User: Standard
GSCALAR(imu_sample_rate, "INS_SAMPLE_RATE", 0),

// @Group: INS_
// @Path: ../libraries/AP_InertialSensor/AP_InertialSensor.cpp
GOBJECT(imu, "INS", AP_InertialSensor),
#endif

AP_VAREND
};

Expand Down
6 changes: 6 additions & 0 deletions Tools/AP_Periph/Parameters.h
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,8 @@ class Parameters {
k_param_rpm_msg_rate,
k_param_esc_rate,
k_param_esc_extended_telem_rate,
k_param_imu_sample_rate,
k_param_imu,
};

AP_Int16 format_version;
Expand Down Expand Up @@ -211,6 +213,10 @@ class Parameters {
AP_Int8 efi_port;
#endif

#ifdef HAL_PERIPH_ENABLE_IMU
AP_Int16 imu_sample_rate;
#endif

#if HAL_PERIPH_CAN_MIRROR
AP_Int8 can_mirror_ports;
#endif // HAL_PERIPH_CAN_MIRROR
Expand Down
50 changes: 50 additions & 0 deletions Tools/AP_Periph/imu.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
#include "AP_Periph.h"

#ifdef HAL_PERIPH_ENABLE_IMU
#include <dronecan_msgs.h>

extern const AP_HAL::HAL &hal;

/*
update CAN magnetometer
*/
void AP_Periph_FW::can_imu_update(void)
{
while (true) {
// sleep for a bit to avoid flooding the CPU
hal.scheduler->delay_microseconds(100);

imu.update();

if (!imu.healthy()) {
continue;
}

uavcan_equipment_ahrs_RawIMU pkt {};

Vector3f tmp;
imu.get_delta_velocity(tmp, pkt.integration_interval);
pkt.accelerometer_integral[0] = tmp.x;
pkt.accelerometer_integral[1] = tmp.y;
pkt.accelerometer_integral[2] = tmp.z;

imu.get_delta_angle(tmp, pkt.integration_interval);
pkt.rate_gyro_integral[0] = tmp.x;
pkt.rate_gyro_integral[1] = tmp.y;
pkt.rate_gyro_integral[2] = tmp.z;

tmp = imu.get_accel();
pkt.accelerometer_latest[0] = tmp.x;
pkt.accelerometer_latest[1] = tmp.y;
pkt.accelerometer_latest[2] = tmp.z;

uint8_t buffer[UAVCAN_EQUIPMENT_AHRS_RAWIMU_MAX_SIZE];
uint16_t total_size = uavcan_equipment_ahrs_RawIMU_encode(&pkt, buffer, !canfdout());
canard_broadcast(UAVCAN_EQUIPMENT_AHRS_RAWIMU_SIGNATURE,
UAVCAN_EQUIPMENT_AHRS_RAWIMU_ID,
CANARD_TRANSFER_PRIORITY_HIGH,
&buffer[0],
total_size);
}
}
#endif // HAL_PERIPH_ENABLE_IMU
2 changes: 2 additions & 0 deletions Tools/GIT_Test/GIT_Success.txt
Original file line number Diff line number Diff line change
Expand Up @@ -203,3 +203,5 @@ Amr
Tsuyoshi Arakawa
Naveen Kumar Kilaparthi
Amr Attia
Alessandro Martini
Eren Mert YİĞİT
Binary file added Tools/bootloaders/CubeNode-ETH_bl.bin
Binary file not shown.
Loading

0 comments on commit f9fac37

Please sign in to comment.