FSUDAQ_Qt6/CustomThreads.h

145 lines
4.0 KiB
C
Raw Permalink Normal View History

2023-04-14 16:12:52 -04:00
#ifndef CUSTOMTHREADS_H
#define CUSTOMTHREADS_H
#include <QThread>
#include <QMutex>
#include <QWaitCondition>
2023-10-19 14:29:28 -04:00
#include <QMessageBox>
#include <QCoreApplication>
2023-04-14 16:12:52 -04:00
#include "macro.h"
#include "ClassDigitizer.h"
static QMutex digiMTX[MaxNBoards * MaxNPorts];
//^#===================================================== ReadData Thread
class ReadDataThread : public QThread {
Q_OBJECT
public:
ReadDataThread(Digitizer * dig, int digiID, QObject * parent = 0) : QThread(parent){
this->digi = dig;
this->ID = digiID;
isSaveData = false;
2023-04-19 16:21:14 -04:00
isScope = false;
readCount = 0;
stop = false;
2023-04-14 16:12:52 -04:00
}
void Stop() { this->stop = true;}
2023-04-19 16:21:14 -04:00
void SetSaveData(bool onOff) {this->isSaveData = onOff;}
void SetScopeMode(bool onOff) {this->isScope = onOff;}
void SetReadCountZero() {readCount = 0;}
unsigned long GetReadCount() const {return readCount;}
2023-04-14 16:12:52 -04:00
void run(){
stop = false;
readCount = 0;
2023-05-23 14:52:23 -04:00
clock_gettime(CLOCK_REALTIME, &t0);
2024-04-09 13:54:44 -04:00
// ta = t0;
2024-03-20 18:36:24 -04:00
t1 = t0;
digiMTX[ID].lock();
digi->ReadACQStatus();
digiMTX[ID].unlock();
printf("ReadDataThread for digi-%d running.\n", digi->GetSerialNumber());
do{
if( stop) break;
2023-04-14 16:12:52 -04:00
digiMTX[ID].lock();
int ret = digi->ReadData();
digiMTX[ID].unlock();
readCount ++;
2023-04-14 16:12:52 -04:00
if( stop) break;
2023-05-26 18:06:37 -04:00
if( ret == CAEN_DGTZ_Success && !stop){
2023-04-14 16:12:52 -04:00
digiMTX[ID].lock();
digi->GetData()->DecodeBuffer(!isScope, 0);
2023-04-19 16:21:14 -04:00
if( isSaveData ) digi->GetData()->SaveData();
2023-04-14 16:12:52 -04:00
digiMTX[ID].unlock();
}else{
2023-04-19 16:21:14 -04:00
printf("ReadDataThread::%s------------ ret : %d \n", __func__, ret);
digiMTX[ID].lock();
2023-05-12 16:06:32 -04:00
digi->StopACQ();
if( ret == CAEN_DGTZ_OutOfMemory ){
digi->WriteRegister(DPP::SoftwareClear_W, 1);
digi->GetData()->ClearData();
}
digiMTX[ID].unlock();
emit sendMsg("Digi-" + QString::number(digi->GetSerialNumber()) + " ACQ off.");
stop = true;
2023-05-12 16:06:32 -04:00
break;
2023-04-14 16:12:52 -04:00
}
2023-05-17 16:16:48 -04:00
2024-03-20 18:36:24 -04:00
clock_gettime(CLOCK_REALTIME, &t2);
if( t2.tv_sec - t1.tv_sec > 1 ){
digiMTX[ID].lock();
digi->ReadACQStatus();
digiMTX[ID].unlock();
2024-03-20 18:36:24 -04:00
t2 = t1;
// QCoreApplication::processEvents();
}
2024-04-09 13:54:44 -04:00
// if( isSaveData && !stop ) {
// clock_gettime(CLOCK_REALTIME, &tb);
// if( tb.tv_sec - ta.tv_sec > 2 ) {
// digiMTX[ID].lock();
// emit sendMsg("FileSize ("+ QString::number(digi->GetSerialNumber()) +"): " + QString::number(digi->GetData()->GetTotalFileSize()/1024./1024., 'f', 4) + " MB [" + QString::number(tb.tv_sec-t0.tv_sec) + " sec]");
// //emit sendMsg("FileSize ("+ QString::number(digi->GetSerialNumber()) +"): " + QString::number(digi->GetData()->GetTotalFileSize()/1024./1024., 'f', 4) + " MB [" + QString::number(tb.tv_sec-t0.tv_sec) + " sec] (" + QString::number(readCount) + ")");
// digiMTX[ID].unlock();
// // readCount = 0;
// ta = tb;
// }
// }
}while(!stop);
printf("ReadDataThread for digi-%d stopped.\n", digi->GetSerialNumber());
2023-04-14 16:12:52 -04:00
}
signals:
void sendMsg(const QString &msg);
private:
Digitizer * digi;
bool stop;
2023-04-14 16:12:52 -04:00
int ID;
2023-05-23 14:52:23 -04:00
timespec ta, tb, t1, t2, t0;
2023-04-14 16:12:52 -04:00
bool isSaveData;
2023-04-19 16:21:14 -04:00
bool isScope;
unsigned long readCount;
2023-04-14 16:12:52 -04:00
};
2023-04-19 16:21:14 -04:00
//^#======================================================= Timing Thread
class TimingThread : public QThread {
Q_OBJECT
public:
TimingThread(QObject * parent = 0 ) : QThread(parent){
waitTime = 20; // multiple of 100 mili sec
stop = false;
}
bool isStopped() const {return stop;}
void Stop() { this->stop = true;}
void SetWaitTimeinSec(float sec) {waitTime = sec * 10 ;}
float GetWaitTimeinSec() const {return waitTime/10.;}
void DoOnce() {emit timeUp();};
void run(){
unsigned int count = 0;
stop = false;
do{
usleep(100000);
count ++;
if( count % waitTime == 0){
emit timeUp();
}
}while(!stop);
}
signals:
void timeUp();
private:
bool stop;
unsigned int waitTime;
};
2023-04-14 16:12:52 -04:00
#endif