Program Listing for File ubx_sec_sig.hpp
↰ Return to documentation for file (include/ublox_dgnss_node/ubx/sec/ubx_sec_sig.hpp
)
// Copyright 2023 Australian Robotics Supplies & Technology
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef UBLOX_DGNSS_NODE__UBX__SEC__UBX_SEC_SIG_HPP_
#define UBLOX_DGNSS_NODE__UBX__SEC__UBX_SEC_SIG_HPP_
#include <unistd.h>
#include <memory>
#include <tuple>
#include <string>
#include <vector>
#include "ublox_dgnss_node/ubx/ubx.hpp"
#include "ublox_dgnss_node/ubx/utils.hpp"
namespace ubx::sec::sig
{
struct jam_flags_t
{
union {
x1_t all;
struct
{
u1_t jam_det_enabled : 1;
u1_t jamming_state : 2;
u1_t reserved : 5;
} bits;
};
};
struct spf_flags_t
{
union {
x1_t all;
struct
{
u1_t spf_det_enabled : 1;
u1_t spoofing_state : 3;
u1_t reserved : 4;
} bits;
};
};
struct sec_sig_flags_t
{
union {
x1_t all;
struct
{
u1_t jam_det_enabled : 1;
u1_t jam_state : 2;
u1_t spf_det_enabled : 1;
u1_t spf_state : 3;
u1_t reserved : 1;
} bits;
};
};
struct jam_state_cent_freq_t
{
union {
x4_t all;
struct
{
u4_t cent_freq : 24;
u1_t jammed : 1;
u1_t reserved : 7;
} bits;
};
};
class SecSigPayload : public UBXPayload
{
public:
static const msg_class_t MSG_CLASS = UBX_SEC;
static const msg_id_t MSG_ID = UBX_SEC_SIG;
u1_t version;
jam_flags_t jam_flags;
spf_flags_t spf_flags;
sec_sig_flags_t sec_sig_flags;
u1_t jam_num_cent_freqs;
std::vector<jam_state_cent_freq_t> jam_state_cent_freqs;
public:
SecSigPayload()
: UBXPayload(MSG_CLASS, MSG_ID)
{
}
SecSigPayload(ch_t * payload_polled, u2_t size)
: UBXPayload(MSG_CLASS, MSG_ID)
{
payload_.clear();
payload_.reserve(size);
payload_.resize(size);
memcpy(payload_.data(), payload_polled, size);
version = buf_offset<u1_t>(&payload_, 0);
if (version == 1) {
jam_flags.all = buf_offset<x1_t>(&payload_, 1);
spf_flags.all = buf_offset<x1_t>(&payload_, 2);
} else {
sec_sig_flags.all = buf_offset<x1_t>(&payload_, 1);
jam_flags.bits.jam_det_enabled = sec_sig_flags.bits.jam_det_enabled;
jam_flags.bits.jamming_state = sec_sig_flags.bits.jam_state;
spf_flags.bits.spf_det_enabled = sec_sig_flags.bits.spf_det_enabled;
spf_flags.bits.spoofing_state = sec_sig_flags.bits.spf_state;
}
jam_state_cent_freqs.clear();
jam_num_cent_freqs = 0;
if (version >= 2) {
jam_num_cent_freqs = buf_offset<u1_t>(&payload_, 3);
size_t offset = 4;
for (u1_t i = 0; i < jam_num_cent_freqs; ++i) {
jam_state_cent_freq_t jam_state_cent_freq;
jam_state_cent_freq.all = buf_offset<x4_t>(&payload_, offset);
jam_state_cent_freqs.push_back(jam_state_cent_freq);
offset += 4;
}
}
}
std::tuple<u1_t *, size_t> make_poll_payload()
{
payload_.clear();
return std::make_tuple(payload_.data(), payload_.size());
}
std::string to_string()
{
std::ostringstream oss;
oss << "version: " << static_cast<int>(version);
oss << ", jam_flags: {jam_det_enabled: " << static_cast<int>(jam_flags.bits.jam_det_enabled);
oss << ", jamming_state: " << static_cast<int>(jam_flags.bits.jamming_state) << "}";
oss << ", spf_flags: {spf_det_enabled: " << static_cast<int>(spf_flags.bits.spf_det_enabled);
oss << ", spoofing_state: " << static_cast<int>(spf_flags.bits.spoofing_state) << "}";
if (version >= 2) {
oss << ", jam_num_cent_freqs: " << static_cast<int>(jam_num_cent_freqs);
oss << " [";
for (size_t i = 0; i < jam_state_cent_freqs.size(); ++i) {
if (i > 1) {
oss << ", ";
}
oss << "{ " << i << ", ";
oss << static_cast<int64_t>(jam_state_cent_freqs[i].bits.cent_freq) << ", ";
oss << static_cast<bool>(jam_state_cent_freqs[i].bits.jammed);
oss << "}";
}
oss << "]";
}
return oss.str();
}
};
} // namespace ubx::sec::sig
#endif // UBLOX_DGNSS_NODE__UBX__SEC__UBX_SEC_SIG_HPP_