HITDAQ/hit2023v2_RMS/datareceiver.cpp

172 lines
4.7 KiB
C++

#include "datareceiver.h"
#include "dev_commands.h"
#include "helpers.h"
DataReceiver::DataReceiver(QObject *parent) : QObject(parent), dataBuffer(RECEIVER_BUFFER_SIZE)
{
connect(this, DataReceiver::sigInit, this, DataReceiver::onInit);
connect(this, DataReceiver::sigDeinit, this, DataReceiver::onDeinit);
connect(this, DataReceiver::sigConfigureEthSettings, this, DataReceiver::onConfigureEthSettings);
moveToThread(&thread);
thread.start();
init();
}
DataReceiver::~DataReceiver()
{
deinit();
thread.quit();
thread.wait();
}
//********************** Receiving data **************************
void DataReceiver::readData()
{
int size_received_bytes;
while ((size_received_bytes = dataSocket->readDatagram(tmpBuffer, DATA_PACKET_SIZE)) > 0)
{
//look if the packet isn't too short
int expected_size_bytes = ethBunch * (DATA_PACKET_HEADER_SIZE + DATA_SYNC_HEADER_SIZE + dmaBunch*DATA_BLOCK_SIZE);
if (size_received_bytes < expected_size_bytes)
continue;
for (int ethb = 0; ethb < ethBunch; ethb++)
{
int baseaddr = ethb * (DATA_PACKET_HEADER_SIZE + DATA_SYNC_HEADER_SIZE + dmaBunch*DATA_BLOCK_SIZE);
//check the header
if (BYTES2SHORT(tmpBuffer+baseaddr+0) != 0x5555)
continue;
if (BYTES2SHORT(tmpBuffer+baseaddr+2) != COMMAND_DATA_TRANSFER)
continue;
if ((BYTES2SHORT(tmpBuffer+baseaddr+4)*2) != (DATA_SYNC_HEADER_SIZE + dmaBunch*DATA_BLOCK_SIZE))
continue;
//read sync data;
SyncFrame sync;
sync.local_ctr = BYTES2SHORT(tmpBuffer+baseaddr+DATA_PACKET_HEADER_SIZE);
sync.global_ctr = BYTES2SHORT(tmpBuffer+baseaddr+DATA_PACKET_HEADER_SIZE+2);
sync.sma_state = BYTES2SHORT(tmpBuffer+baseaddr+DATA_PACKET_HEADER_SIZE+4);
sync.device_nr = devNr;
sync.data_ok = 1;
for (int dmab=0; dmab<dmaBunch; dmab++)
{
framesReceived++;
int baseaddr2 = baseaddr + dmab*DATA_BLOCK_SIZE;
if (outputEnabled)
{
BufferData data_to_push(sensorsPerBoard * DATA_SAMPLES_PER_SENSOR); //todo is this big enough
data_to_push.sync_frame = sync;
int baseaddr3 = baseaddr2 + DATA_PACKET_HEADER_SIZE + DATA_SYNC_HEADER_SIZE;
for (int s = 0; s < (sensorsPerBoard * DATA_SAMPLES_PER_SENSOR); s++)
data_to_push.sensor_data[s] = 65535 - BYTES2SHORT(tmpBuffer + baseaddr3 + 2*s);
for (int i = 0; i < DATA_RMS_SIZE/4; i++)
data_to_push.rms_data[i] = BYTES2INT(tmpBuffer + baseaddr3 + 2 * sensorsPerBoard * DATA_SAMPLES_PER_SENSOR + 4 * i); //what is baseaddr3?
dataBuffer.push(data_to_push);
framesFromLastSig++;
}
}
}
}
if (framesFromLastSig >= RECEIVER_FRAMES_PER_SIG)
{
framesFromLastSig = 0;
emit sigDataReady(this);
}
}
//********************** Internal slots ************************
void DataReceiver::onTimer()
{
frameRate = framesReceived * 1000 / RECEIVER_TIMER_PERIOD_MS;
framesReceived = 0;
}
void DataReceiver::onInit()
{
if (dataSocket == NULL)
{
dataSocket = new QUdpSocket(this);
connect(dataSocket, QUdpSocket::readyRead, this, DataReceiver::readData);
}
if (timer == NULL)
{
timer = new QTimer(this);
connect(timer, QTimer::timeout, this, onTimer);
timer->start(RECEIVER_TIMER_PERIOD_MS);
}
initSemaphore.release();
}
void DataReceiver::onDeinit()
{
if (dataSocket != NULL)
{
delete dataSocket;
dataSocket = NULL;
}
if (timer != NULL)
{
delete timer;
timer = NULL;
}
initSemaphore.release();
}
void DataReceiver::onConfigureEthSettings()
{
dataSocket->close();
dataSocket->bind(address, port);
}
//********************** Controlling DataReceiver************************
void DataReceiver::init()
{
emit sigInit();
initSemaphore.acquire(); //wait for initialization
}
void DataReceiver::deinit()
{
emit sigDeinit();
initSemaphore.acquire(); //wait for deinitialization
}
void DataReceiver::configureEthSettings(QHostAddress address_to_set, quint16 port_to_set)
{
address = address_to_set;
port = port_to_set;
emit sigConfigureEthSettings();
}
void DataReceiver::configureBunchSize(int dma, int eth)
{
dmaBunch = dma;
ethBunch = eth;
}
void DataReceiver::outputEnable (int en)
{
outputEnabled = en;
if (!en)
dataBuffer.clear();
}