/** * @file BNO08xRptCalGyro.cpp * @author Myles Parfeniuk */ #include "BNO08xRptCalGyro.hpp" /** * @brief Updates calibrated gyro data from decoded sensor event. * * @param sensor_val The sh2_SensorValue_t struct used in sh2_decodeSensorEvent() call. * * @return void, nothing to return */ void BNO08xRptCalGyro::update_data(sh2_SensorValue_t* sensor_val) { lock_user_data(); data = sensor_val->un.gyroscope; data.accuracy = static_cast(sensor_val->status); unlock_user_data(); if (rpt_bit & xEventGroupGetBits(sync_ctx->evt_grp_rpt_en)) signal_data_available(); } /** * @brief Grabs most recent gyroscope data (velocity), units are in rad/s. * * @return Struct containing requested data. */ bno08x_gyro_t BNO08xRptCalGyro::get() { lock_user_data(); bno08x_gyro_t rqdata = data; unlock_user_data(); return rqdata; }