mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-22 06:57:02 +00:00
Fix termination of TTFF test
This commit is contained in:
parent
cfb56d35d6
commit
381cf4fb3c
@ -316,6 +316,19 @@ void receive_msg()
|
||||
}
|
||||
}
|
||||
|
||||
double received_message;
|
||||
unsigned int priority;
|
||||
std::size_t received_size;
|
||||
// Receive a message (non-blocking)
|
||||
if (d_mq->try_receive(&received_message, sizeof(received_message), received_size, priority))
|
||||
{
|
||||
// Validate the size of the received message
|
||||
if (received_size == sizeof(double) && (received_message != 0) && (received_message != -1))
|
||||
{
|
||||
TTFF_v.push_back(received_message);
|
||||
LOG(INFO) << "Valid Time-To-First-Fix: " << received_message << " [s]";
|
||||
// Stop the receiver
|
||||
double stop_message = -200.0;
|
||||
const std::string queue_name_stop = "receiver_control_queue";
|
||||
std::unique_ptr<boost::interprocess::message_queue> d_mq_stop;
|
||||
bool queue_found2 = false;
|
||||
@ -333,20 +346,6 @@ void receive_msg()
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
||||
}
|
||||
}
|
||||
|
||||
double received_message;
|
||||
unsigned int priority;
|
||||
std::size_t received_size;
|
||||
// Receive a message (non-blocking)
|
||||
if (d_mq->try_receive(&received_message, sizeof(received_message), received_size, priority))
|
||||
{
|
||||
// Validate the size of the received message
|
||||
if (received_size == sizeof(double) && (received_message != 0) && (received_message != -1))
|
||||
{
|
||||
TTFF_v.push_back(received_message);
|
||||
LOG(INFO) << "Valid Time-To-First-Fix: " << received_message << " [s]";
|
||||
// Stop the receiver
|
||||
double stop_message = -200.0;
|
||||
d_mq_stop->send(&stop_message, sizeof(stop_message), 0);
|
||||
}
|
||||
if (received_size == sizeof(double) && std::abs(received_message - (-1.0)) < 10 * std::numeric_limits<double>::epsilon())
|
||||
@ -735,24 +734,21 @@ int main(int argc, char **argv)
|
||||
|
||||
// Terminate the queue thread
|
||||
const std::string queue_name = "gnss_sdr_ttff_message_queue";
|
||||
std::unique_ptr<boost::interprocess::message_queue> mq;
|
||||
bool queue_found = false;
|
||||
while (!queue_found)
|
||||
{
|
||||
try
|
||||
{
|
||||
// Attempt to open the message queue
|
||||
mq = std::make_unique<boost::interprocess::message_queue>(boost::interprocess::open_only, queue_name.c_str());
|
||||
queue_found = true; // Queue found
|
||||
}
|
||||
catch (const boost::interprocess::interprocess_exception &)
|
||||
{
|
||||
// Queue not found, wait and retry
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(100));
|
||||
}
|
||||
}
|
||||
boost::interprocess::message_queue::remove(queue_name.c_str());
|
||||
|
||||
// Create a new message queue
|
||||
auto mq = std::make_unique<boost::interprocess::message_queue>(
|
||||
boost::interprocess::create_only, // Create a new queue
|
||||
queue_name.c_str(), // Queue name
|
||||
10, // Maximum number of messages
|
||||
sizeof(double) // Maximum message size
|
||||
);
|
||||
double finish = -1.0;
|
||||
if (mq)
|
||||
{
|
||||
mq->send(&finish, sizeof(finish), 0);
|
||||
}
|
||||
receive_msg_thread.join();
|
||||
boost::interprocess::message_queue::remove(queue_name.c_str());
|
||||
|
||||
#if USE_GLOG_AND_GFLAGS
|
||||
|
Loading…
Reference in New Issue
Block a user