/********************************************//** * @file slsReceiverTCPIPInterface.cpp * @short interface between receiver and client ***********************************************/ #include "slsReceiverTCPIPInterface.h" #include "UDPInterface.h" #include "gitInfoReceiver.h" #include "slsReceiverUsers.h" #include "slsReceiver.h" #include //SIGINT #include //EXIT #include #include #include #include #include using namespace std; slsReceiverTCPIPInterface::~slsReceiverTCPIPInterface() { if(socket) delete socket; closeFile(0); } slsReceiverTCPIPInterface::slsReceiverTCPIPInterface(int &success, UDPInterface* rbase, int pn): myDetectorType(GOTTHARD), receiverBase(rbase), ret(OK), lockStatus(0), shortFrame(-1), packetsPerFrame(GOTTHARD_PACKETS_PER_FRAME), dynamicrange(16), socket(NULL), killTCPServerThread(0), tenGigaEnable(0), portNumber(DEFAULT_PORTNO+2){ int port_no=portNumber; if (pn>0) port_no = pn; success=OK; //create socket if(success == OK){ socket = new MySocketTCP(port_no); if (socket->getErrorStatus()) { success = FAIL; delete socket; socket=NULL; } else { portNumber=port_no; //initialize variables strcpy(socket->lastClientIP,"none"); strcpy(socket->thisClientIP,"none1"); strcpy(mess,"dummy message"); function_table(); #ifdef VERBOSE cout << "Function table assigned." << endl; #endif //Catch signal SIGINT to close files properly signal(SIGINT,staticCloseFile); } } } int slsReceiverTCPIPInterface::setPortNumber(int pn){ int p_number; MySocketTCP *oldsocket=NULL;; int sd=0; if (pn>0) { p_number = pn; if (p_number<1024) { sprintf(mess,"Too low port number %d\n", p_number); cout << mess << endl; } else { oldsocket=socket; socket = new MySocketTCP(p_number); if(socket){ sd = socket->getErrorStatus(); if (!sd){ portNumber=p_number; delete oldsocket; } else { cout << "Could not bind port " << p_number << endl; if (sd==-10) { cout << "Port "<< p_number << " already set" << endl; } else { delete socket; socket=oldsocket; } } } else { socket=oldsocket; } } } return portNumber; } int slsReceiverTCPIPInterface::start(){ cout << "Creating TCP Server Thread" << endl; killTCPServerThread = 0; if(pthread_create(&TCPServer_thread, NULL,startTCPServerThread, (void*) this)){ cout << "Could not create TCP Server thread" << endl; return FAIL; } //#ifdef VERBOSE cout << "TCP Server thread created successfully." << endl; //#endif return OK; } void slsReceiverTCPIPInterface::stop(){ cout << "Shutting down UDP Socket" << endl; if(receiverBase) receiverBase->shutDownUDPSockets(); cout << "Closing Files... " << endl; receiverBase->closeFile(); cout<<"Shutting down TCP Socket and TCP thread"<ShutDownSocket(); void* status; pthread_join(TCPServer_thread, &status); killTCPServerThread = 0; } void* slsReceiverTCPIPInterface::startTCPServerThread(void *this_pointer){ ((slsReceiverTCPIPInterface*)this_pointer)->startTCPServer(); return this_pointer; } void slsReceiverTCPIPInterface::startTCPServer(){ #ifdef VERYVERBOSE cout << "Starting Receiver TCP Server" << endl; #endif int v=slsReceiverDefs::OK; while(1) { #ifdef VERBOSE cout<< endl; #endif #ifdef VERY_VERBOSE cout << "Waiting for client call" << endl; #endif if(socket->Connect()>=0){ #ifdef VERY_VERBOSE cout << "Conenction accepted" << endl; #endif v = decode_function(); #ifdef VERY_VERBOSE cout << "function executed" << endl; #endif socket->Disconnect(); #ifdef VERY_VERBOSE cout << "connection closed" << endl; #endif } //if tcp command was to exit server if(v==GOODBYE){ cout << "Shutting down UDP Socket" << endl; if(receiverBase) receiverBase->shutDownUDPSockets(); cout << "Closing Files... " << endl; receiverBase->closeFile(); pthread_exit(NULL); } //if user entered exit if(killTCPServerThread) pthread_exit(NULL); } } int slsReceiverTCPIPInterface::function_table(){ for (int i=0;iReceiveDataOnly(&fnum,sizeof(fnum)); if (n <= 0) { #ifdef VERBOSE cout << "ERROR reading from socket " << n << ", " << fnum << endl; #endif return FAIL; } #ifdef VERBOSE else cout << "size of data received " << n <numberOfFunctions-1) fnum = numberOfFunctions-1; //calling function (this->*flist[fnum])(); if (ret==FAIL) cout << "Error executing the function = " << fnum << endl; return ret; } int slsReceiverTCPIPInterface::M_nofunc(){ ret=FAIL; sprintf(mess,"Unrecognized Function\n"); cout << mess << endl; socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(mess,sizeof(mess)); return GOODBYE; } void slsReceiverTCPIPInterface::closeFile(int p){ stop(); cout << "Goodbye!" << endl; exit(-1); } void slsReceiverTCPIPInterface::staticCloseFile(int p){ slsReceiverUsers::receiver->closeFile(p); } int slsReceiverTCPIPInterface::set_detector_type(){ ret=OK; int retval=FAIL; detectorType dr; strcpy(mess,"Could not set detector type range\n"); // receive arguments if(socket->ReceiveDataOnly(&dr,sizeof(dr)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ myDetectorType = dr; ret=receiverBase->setDetectorType(dr); retval = myDetectorType; } } //#ifdef VERBOSE if(ret!=FAIL) cout << "detector type" << dr << endl; else cout << mess << endl; //#endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_file_name() { ret=OK; char retval[MAX_STR_LENGTH]=""; char fName[MAX_STR_LENGTH]; strcpy(mess,"Could not set file name"); // receive arguments if(socket->ReceiveDataOnly(fName,MAX_STR_LENGTH) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else strcpy(retval,receiverBase->setFileName(fName)); } #ifdef VERBOSE if(ret!=FAIL) cout << "file name:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_file_dir() { ret=OK; char retval[MAX_STR_LENGTH]=""; char fPath[MAX_STR_LENGTH]; strcpy(mess,"Could not set file path\n"); // receive arguments if(socket->ReceiveDataOnly(fPath,MAX_STR_LENGTH) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; }/* else if((strlen(fPath))&&(receiverBase->getStatus()==RUNNING)){ strcpy(mess,"Can not set file path while receiver running\n"); ret = FAIL; }*/ else{ strcpy(retval,receiverBase->setFilePath(fPath)); // if file path doesnt exist if(strlen(fPath)) if (strcmp(retval,fPath)){ strcpy(mess,"receiver file path does not exist\n"); ret=FAIL; } } } #ifdef VERBOSE if(ret!=FAIL) cout << "file path:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } // LEO: do we need it in the base class? int slsReceiverTCPIPInterface::set_file_index() { ret=OK; int retval=-1; int index; strcpy(mess,"Could not set file index\n"); // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else retval=receiverBase->setFileIndex(index); } #ifdef VERBOSE if(ret!=FAIL) cout << "file index:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_frame_index() { ret=OK; int retval=-1; int index; strcpy(mess,"Could not set frame index\n"); // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else retval=receiverBase->setFrameIndexNeeded(index); } #ifdef VERBOSE if(ret!=FAIL) cout << "frame index:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } //LEO: is the client that commands the setup, or you just need the args? int slsReceiverTCPIPInterface::setup_udp(){ ret=OK; strcpy(mess,"could not set up udp connection"); char retval[MAX_STR_LENGTH]=""; char args[2][MAX_STR_LENGTH]; string temp; int udpport; char eth[MAX_STR_LENGTH]; // receive arguments if(socket->ReceiveDataOnly(args,sizeof(args)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(receiverBase->getStatus()==RUNNING){ ret = FAIL; strcpy(mess,"cannot set up udp when receiver is running\n"); } else{ //set up udp port sscanf(args[1],"%d",&udpport); receiverBase->setUDPPortNo(udpport); //setup udpip //get ethernet interface or IP to listen to temp = genericSocket::ipToName(args[0]); if(temp=="none"){ ret = FAIL; strcpy(mess, "failed to get ethernet interface or IP to listen to\n"); } else{ strcpy(eth,temp.c_str()); if (strchr(eth,'.')!=NULL) { strcpy(eth,""); ret = FAIL; } cout<<"eth:"<setEthernetInterface(eth); //get mac address from ethernet interface if (ret != FAIL) temp = genericSocket::nameToMac(eth); if ((temp=="00:00:00:00:00:00") || (ret == FAIL)){ ret = FAIL; strcpy(mess,"failed to get mac adddress to listen to\n"); cout << "mess:" << mess << endl; } else{ strcpy(retval,temp.c_str()); cout<<"mac:"<differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } int slsReceiverTCPIPInterface::start_receiver(){ ret=OK; ret=OK; enum runStatus s; char cstatus[15]; strcpy(mess,"Could not start receiver\n"); // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } /* else if(!strlen(receiverBase->getFilePath())){ strcpy(mess,"receiver not set up. set receiver ip again.\n"); ret = FAIL; } */ else { s = receiverBase->getStatus(); switch (s) { case ERROR: strcpy(cstatus,"error"); break; case WAITING: strcpy(cstatus,"waiting"); break; case RUNNING: strcpy(cstatus,"running"); break; case TRANSMITTING: strcpy(cstatus,"data"); break; case RUN_FINISHED: strcpy(cstatus,"finished"); break; default: strcpy(cstatus,"idle"); break; } if(s == IDLE) ret=receiverBase->startReceiver(mess); else{ sprintf(mess,"Cannot start Receiver as it is in %s state\n",cstatus); ret=FAIL; } } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL){ socket->SendDataOnly(mess,sizeof(mess)); } //return ok/fail return ret; } int slsReceiverTCPIPInterface::stop_receiver(){ ret=OK; strcpy(mess,"Could not stop receiver\n"); // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(receiverBase->getStatus()!=IDLE) ret=receiverBase->stopReceiver(); #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::get_status(){ ret=OK; enum runStatus retval; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS retval=receiverBase->getStatus(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::get_frames_caught(){ ret=OK; int retval=-1; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS retval=receiverBase->getTotalFramesCaught(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::get_frame_index(){ ret=OK; int retval=-1; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS retval=receiverBase->getAcquisitionIndex(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::reset_frames_caught(){ ret=OK; strcpy(mess,"Could not reset frames caught\n"); // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else receiverBase->resetTotalFramesCaught(); } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_short_frame() { ret=OK; int index=0; int retval=-100; strcpy(mess,"Could not set/reset short frame for receiver\n"); //does not exist for moench if(myDetectorType==MOENCH){ strcpy(mess,"can not set short frame for moench\n"); ret = FAIL; } // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(receiverBase->getStatus()==RUNNING){ strcpy(mess,"Cannot set short frame while status is running\n"); ret=FAIL; } else{ retval=receiverBase->setShortFrame(index); shortFrame = retval; if(shortFrame==-1) packetsPerFrame=GOTTHARD_PACKETS_PER_FRAME; else packetsPerFrame=GOTTHARD_SHORT_PACKETS_PER_FRAME; } } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::read_frame(){ switch(myDetectorType){ case MOENCH: return moench_read_frame(); case EIGER: return eiger_read_frame(); default: return gotthard_read_frame(); } } int slsReceiverTCPIPInterface::moench_read_frame(){ ret=OK; char fName[MAX_STR_LENGTH]=""; int arg = -1,i; int bufferSize = MOENCH_BUFFER_SIZE; int rnel = bufferSize/(sizeof(int)); int* retval = new int[rnel]; int* origVal = new int[rnel]; //all initialized to 0 for(i=0;igetFramesCaught()){ arg = -1; cout<<"haven't caught any frame yet"<getStartFrameIndex(); receiverBase->readFrame(fName,&raw,index); /**send garbage with -1 index to try again*/ if (raw == NULL){ arg = -1; #ifdef VERBOSE cout<<"data not ready for gui yet"<> MOENCH_FRAME_INDEX_OFFSET); uint32_t numPackets = MOENCH_PACKETS_PER_FRAME; //40 uint32_t onePacketSize = MOENCH_DATA_BYTES / MOENCH_PACKETS_PER_FRAME; //1280*40 / 40 = 1280 uint32_t packetDatabytes_row = onePacketSize * (MOENCH_BYTES_IN_ONE_ROW / MOENCH_BYTES_PER_ADC); //1280 * 4 = 5120 uint32_t partsPerFrame = onePacketSize / MOENCH_BYTES_PER_ADC; // 1280 / 80 = 16 uint32_t packetOffset = 0; int packetIndex,x,y; int iPacket = 0; offset = 4; while (iPacket < (int)numPackets){ #ifdef VERBOSE printf("iPacket:%d\n",iPacket);cout << endl; #endif //if missing packets, dont send to gui bindex = (*((uint32_t*)(((char*)origVal)+packetOffset))); if (bindex == 0xFFFFFFFF){ cout << "Missing Packet,Not sending to gui" << endl; index = startIndex - 1; break;//use continue and change index above if you want to display missing packets with 0 value anyway in gui } packetIndex = bindex & MOENCH_PACKET_INDEX_MASK; //cout<<"packetIndex:"<= 40) && (packetIndex < 0)) cout << "cannot decode packet index:" << packetIndex << endl; else{ x = packetIndex / 10; y = packetIndex % 10; #ifdef VERBOSE cout<<"x:"<differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL){ cout << "mess:" << mess << endl; socket->SendDataOnly(mess,sizeof(mess)); } else{ socket->SendDataOnly(fName,MAX_STR_LENGTH); socket->SendDataOnly(&arg,sizeof(arg)); socket->SendDataOnly(retval,MOENCH_DATA_BYTES); } //return ok/fail delete [] retval; delete [] origVal; delete [] raw; return ret; } int slsReceiverTCPIPInterface::gotthard_read_frame(){ ret=OK; char fName[MAX_STR_LENGTH]=""; int arg = -1,i; //retval is a full frame int bufferSize = GOTTHARD_BUFFER_SIZE; int rnel = bufferSize/(sizeof(int)); int* retval = new int[rnel]; int* origVal = new int[rnel]; //all initialized to 0 for(i=0;igetFramesCaught()){ arg=-1; cout<<"haven't caught any frame yet"<getStartFrameIndex(); receiverBase->readFrame(fName,&raw,index); /**send garbage with -1 index to try again*/ if (raw == NULL){ arg = -1; #ifdef VERBOSE cout<<"data not ready for gui yet"<> GOTTHARD_SHORT_FRAME_INDEX_OFFSET); #ifdef VERBOSE cout << "index:" << hex << index << endl; #endif }else{ bindex = ((uint32_t)(*((uint32_t*)raw)))+1; pindex = (bindex & GOTTHARD_PACKET_INDEX_MASK); index = ((bindex & GOTTHARD_FRAME_INDEX_MASK) >> GOTTHARD_FRAME_INDEX_OFFSET); bindex2 = ((uint32_t)(*((uint32_t*)((char*)(raw+onebuffersize)))))+1; pindex2 =(bindex2 & GOTTHARD_PACKET_INDEX_MASK); index2 =((bindex2 & GOTTHARD_FRAME_INDEX_MASK) >> GOTTHARD_FRAME_INDEX_OFFSET); #ifdef VERBOSE cout << "index1:" << hex << index << endl; cout << "index2:" << hex << index << endl; #endif } memcpy(origVal,raw,bufferSize); raw=NULL; //1 adc if(shortFrame!=-1){ if(bindex != 0xFFFFFFFF) memcpy((((char*)retval)+(GOTTHARD_SHORT_DATABYTES*shortFrame)),((char*) origVal)+4, GOTTHARD_SHORT_DATABYTES); else{ index = startIndex - 1; cout << "Missing Packet,Not sending to gui" << endl; } } //all adc else{ //ignore if half frame is missing if ((bindex != 0xFFFFFFFF) && (bindex2 != 0xFFFFFFFF)){ //should be same frame if (index == index2){ //ideal situation (should be odd, even(index+1)) if(!pindex){ memcpy(retval,((char*) origVal)+4, onedatasize); memcpy((((char*)retval)+onedatasize), ((char*) origVal)+10+onedatasize, onedatasize); } //swap to even,odd else{ memcpy((((char*)retval)+onedatasize),((char*) origVal)+4, onedatasize); memcpy(retval, ((char*) origVal)+10+onedatasize, onedatasize); index=index2; } }else cout << "different frames caught. frame1:"<< hex << index << ":"<differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL){ cout << "mess:" << mess << endl; socket->SendDataOnly(mess,sizeof(mess)); } else{ socket->SendDataOnly(fName,MAX_STR_LENGTH); socket->SendDataOnly(&arg,sizeof(arg)); socket->SendDataOnly(retval,GOTTHARD_DATA_BYTES); } delete [] retval; delete [] origVal; delete [] raw; return ret; } int slsReceiverTCPIPInterface::eiger_read_frame(){ ret=OK; char fName[MAX_STR_LENGTH]=""; int arg = -1,i; uint32_t index=0; int frameSize = EIGER_ONE_GIGA_ONE_PACKET_SIZE * packetsPerFrame; int dataSize = EIGER_ONE_GIGA_ONE_DATA_SIZE * packetsPerFrame; if(tenGigaEnable){ frameSize = EIGER_TEN_GIGA_ONE_PACKET_SIZE * packetsPerFrame; dataSize = EIGER_TEN_GIGA_ONE_DATA_SIZE * packetsPerFrame; } char* raw = new char[frameSize]; char* origVal = new char[frameSize]; char* retval = new char[dataSize]; strcpy(mess,"Could not read frame\n"); /* typedef struct{ unsigned char num1[4]; unsigned char num2[4]; } eiger_packet_header;*/ // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS /**send garbage with -1 index to try again*/ if(!receiverBase->getFramesCaught()){ arg=-1; #ifdef VERBOSE cout<<"haven't caught any frame yet"<readFrame(fName,&raw, index); #ifdef VERBOSE cout << "index:" << dec << index << endl; #endif /**send garbage with -1 index to try again*/ if (raw == NULL){ arg = -1; #ifdef VERBOSE cout<<"data not ready for gui yet"<> 8) & 0x00FF00FF00FF00FFULL ); temp = ((temp << 16) & 0xFFFF0000FFFF0000ULL ) | ((temp >> 16) & 0x0000FFFF0000FFFFULL ); temp = (temp << 32) | ((temp >> 32) & 0xFFFFFFFFULL); (*(((uint64_t*)retval)+i)) = temp; } /* ( (((val) >> 56) & 0x00000000000000FF) | (((val) >> 40) & 0x000000000000FF00) | \ (((val) >> 24) & 0x0000000000FF0000) | (((val) >> 8) & 0x00000000FF000000) | \ (((val) << 8) & 0x000000FF00000000) | (((val) << 24) & 0x0000FF0000000000) | \ (((val) << 40) & 0x00FF000000000000) | (((val) << 56) & 0xFF00000000000000) ) */ /* for(i=0;i<(1024*(16*dynamicrange)*2)/4;i++) (*(((uint32_t*)retval)+i)) = htonl((uint32_t)(*(((uint32_t*)retval)+i))); */ arg = index-1; } } #ifdef VERBOSE if(arg!=-1){ cout << "fName:" << fName << endl; cout << "findex:" << arg << endl; } #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL){ cout << "mess:" << mess << endl; socket->SendDataOnly(mess,sizeof(mess)); } else{ socket->SendDataOnly(fName,MAX_STR_LENGTH); socket->SendDataOnly(&arg,sizeof(arg)); socket->SendDataOnly(retval,dataSize); } delete [] retval; delete [] origVal; delete [] raw; return ret; } int slsReceiverTCPIPInterface::set_read_frequency(){ ret=OK; int retval=-1; int index; strcpy(mess,"Could not set receiver read frequency\n"); // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; }/* else if((receiverBase->getStatus()==RUNNING) && (index >= 0)){ ret = FAIL; strcpy(mess,"cannot set up receiver mode when receiver is running\n"); }*/ else retval=receiverBase->setNFrameToGui(index); } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::enable_file_write(){ ret=OK; int retval=-1; int enable; strcpy(mess,"Could not set/get enable file write\n"); // receive arguments if(socket->ReceiveDataOnly(&enable,sizeof(enable)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ if(enable >= 0) receiverBase->setEnableFileWrite(enable); retval=receiverBase->getEnableFileWrite(); if((enable!=-1)&&(enable!=retval)) ret=FAIL; } } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::get_id(){ ret=OK; int64_t retval=-1; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS retval = getReceiverVersion(); #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int64_t slsReceiverTCPIPInterface::getReceiverVersion(){ int64_t retval = SVNREV; retval= (retval <<32) | SVNDATE; return retval; } int slsReceiverTCPIPInterface::start_readout(){ ret=OK; enum runStatus retval; // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS receiverBase->startReadout(); retval = receiverBase->getStatus(); if((retval == TRANSMITTING) || (retval == RUN_FINISHED) || (retval == IDLE)) ret = OK; else ret = FAIL; #endif if(socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_timer() { ret=OK; int64_t retval = -1; int64_t index[2]; index[1] = -1; strcpy(mess,"Could not set acquisition period or frame number in receiver\n"); // receive arguments if(socket->ReceiveDataOnly(index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ if(index[0] == slsReceiverDefs::FRAME_PERIOD) retval=receiverBase->setAcquisitionPeriod(index[1]); else retval=receiverBase->setNumberOfFrames(index[1]); } } #ifdef VERBOSE if(ret!=FAIL){ if(index[0] == slsReceiverDefs::FRAME_PERIOD) cout << "acquisition period:" << retval << endl; else cout << "frame number:" << retval << endl; }else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::enable_compression() { ret=OK; int enable=-1; int retval=-100; strcpy(mess,"Could not enable/disable compression for receiver\n"); // receive arguments if(socket->ReceiveDataOnly(&enable,sizeof(enable)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if(enable >= 0){ if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(receiverBase->getStatus()==RUNNING){ strcpy(mess,"Cannot enable/disable compression while status is running\n"); ret=FAIL; } else ret = receiverBase->enableDataCompression(enable); } retval=receiverBase->getDataCompression(); } #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_detector_hostname() { ret=OK; char retval[MAX_STR_LENGTH]=""; char hostname[MAX_STR_LENGTH]=""; strcpy(mess,"Could not set detector hostname"); // receive arguments if(socket->ReceiveDataOnly(hostname,MAX_STR_LENGTH) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ receiverBase->initialize(hostname); strcpy(retval,receiverBase->getDetectorHostname()); } } #ifdef VERBOSE if(ret!=FAIL) cout << "hostname:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(retval,MAX_STR_LENGTH); //return ok/fail return ret; } //LEO: why the receiver should set the dynamic range? int slsReceiverTCPIPInterface::set_dynamic_range() { ret=OK; int retval=-1; int dr; strcpy(mess,"Could not set dynamic range\n"); // receive arguments if(socket->ReceiveDataOnly(&dr,sizeof(dr)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else if(myDetectorType == EIGER){ switch(dr){ case 4: case 8: case 16: case 32:break; default: sprintf(mess,"This dynamic range does not exist for eiger: %d\n",dr); ret=FAIL; break; } } if(ret!=FAIL){ retval=receiverBase->setDynamicRange(dr); dynamicrange = dr; if(myDetectorType == EIGER){ if(!tenGigaEnable) packetsPerFrame = EIGER_ONE_GIGA_CONSTANT * dynamicrange * EIGER_MAX_PORTS; else packetsPerFrame = EIGER_TEN_GIGA_CONSTANT * dynamicrange * EIGER_MAX_PORTS; } } } #ifdef VERBOSE if(ret!=FAIL) cout << "dynamic range" << dr << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::enable_overwrite() { ret=OK; int retval=-1; int index; strcpy(mess,"Could not enable/disable overwrite\n"); // receive arguments if(socket->ReceiveDataOnly(&index,sizeof(index)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ if(index >= 0) receiverBase->setEnableOverwrite(index); retval=receiverBase->getEnableOverwrite(); } } #ifdef VERBOSE if(ret!=FAIL) cout << "overwrite:" << retval << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::enable_tengiga() { ret=OK; int retval=-1; int val; strcpy(mess,"Could not enable/disable 10Gbe\n"); // receive arguments if(socket->ReceiveDataOnly(&val,sizeof(val)) < 0 ){ strcpy(mess,"Error reading from socket\n"); ret = FAIL; } // execute action if the arguments correctly arrived #ifdef SLS_RECEIVER_UDP_FUNCTIONS if (ret==OK) { if (lockStatus==1 && socket->differentClients==1){ sprintf(mess,"Receiver locked by %s\n", socket->lastClientIP); ret=FAIL; } else{ retval=receiverBase->enableTenGiga(val); if((val!=-1) && (val != retval)) ret = FAIL; else tenGigaEnable = retval; } } #ifdef VERBOSE if(ret!=FAIL) cout << "10Gbe:" << val << endl; else cout << mess << endl; #endif #endif if(ret==OK && socket->differentClients){ cout << "Force update" << endl; ret=FORCE_UPDATE; } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); socket->SendDataOnly(&retval,sizeof(retval)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::lock_receiver() { ret=OK; int lock; // receive arguments if(socket->ReceiveDataOnly(&lock,sizeof(lock)) < 0 ){ sprintf(mess,"Error reading from socket\n"); cout << "Error reading from socket (lock)" << endl; ret=FAIL; } // execute action if the arguments correctly arrived if(ret==OK){ if (lock>=0) { if (lockStatus==0 || strcmp(socket->lastClientIP,socket->thisClientIP)==0 || strcmp(socket->lastClientIP,"none")==0) { lockStatus=lock; strcpy(socket->lastClientIP,socket->thisClientIP); } else { ret=FAIL; sprintf(mess,"Receiver already locked by %s\n", socket->lastClientIP); } } } if (socket->differentClients && ret==OK) ret=FORCE_UPDATE; // send answer socket->SendDataOnly(&ret,sizeof(ret)); if (ret==FAIL) socket->SendDataOnly(mess,sizeof(mess)); else socket->SendDataOnly(&lockStatus,sizeof(lockStatus)); //return ok/fail return ret; } int slsReceiverTCPIPInterface::set_port() { ret=OK; MySocketTCP* mySocket=NULL; int sd=-1; enum runStatus p_type; /* just to get the input */ int p_number; // receive arguments if(socket->ReceiveDataOnly(&p_type,sizeof(p_type)) < 0 ){ strcpy(mess,"Error reading from socket\n"); cout << mess << endl; ret=FAIL; } if(socket->ReceiveDataOnly(&p_number,sizeof(p_number)) < 0 ){ strcpy(mess,"Error reading from socket\n"); cout << mess << endl; ret=FAIL; } // execute action if the arguments correctly arrived if (ret==OK) { if (socket->differentClients==1 && lockStatus==1 ) { ret=FAIL; sprintf(mess,"Detector locked by %s\n",socket->lastClientIP); } else { if (p_number<1024) { sprintf(mess,"Too low port number %d\n", p_number); cout << mess << endl; ret=FAIL; } cout << "set port " << p_type << " to " << p_number <getErrorStatus(); if (!sd){ ret=OK; if (mySocket->differentClients) ret=FORCE_UPDATE; } else { ret=FAIL; sprintf(mess,"Could not bind port %d\n", p_number); cout << mess << endl; if (sd==-10) { sprintf(mess,"Port %d already set\n", p_number); cout << mess << endl; } } } } // send answer socket->SendDataOnly(&ret,sizeof(ret)); if (ret==FAIL) { socket->SendDataOnly(mess,sizeof(mess)); } else { socket->SendDataOnly(&p_number,sizeof(p_number)); if(sd>=0){ socket->Disconnect(); delete socket; socket = mySocket; } } //return ok/fail return ret; } int slsReceiverTCPIPInterface::get_last_client_ip() { ret=OK; if (socket->differentClients ) ret=FORCE_UPDATE; socket->SendDataOnly(&ret,sizeof(ret)); socket->SendDataOnly(socket->lastClientIP,sizeof(socket->lastClientIP)); return ret; } int slsReceiverTCPIPInterface::send_update() { ret=OK; int ind; char path[MAX_STR_LENGTH]; socket->SendDataOnly(socket->lastClientIP,sizeof(socket->lastClientIP)); //index #ifdef SLS_RECEIVER_UDP_FUNCTIONS ind=receiverBase->getFileIndex(); socket->SendDataOnly(&ind,sizeof(ind)); #endif //filepath #ifdef SLS_RECEIVER_UDP_FUNCTIONS strcpy(path,receiverBase->getFilePath()); #endif socket->SendDataOnly(path,MAX_STR_LENGTH); //filename #ifdef SLS_RECEIVER_UDP_FUNCTIONS strcpy(path,receiverBase->getFileName()); #endif socket->SendDataOnly(path,MAX_STR_LENGTH); if (lockStatus==0) { strcpy(socket->lastClientIP,socket->thisClientIP); } return ret; } int slsReceiverTCPIPInterface::update_client() { ret=OK; socket->SendDataOnly(&ret,sizeof(ret)); return send_update(); } int slsReceiverTCPIPInterface::exit_server() { ret=GOODBYE; socket->SendDataOnly(&ret,sizeof(ret)); strcpy(mess,"closing server"); socket->SendDataOnly(mess,sizeof(mess)); cout << mess << endl; return ret; } int slsReceiverTCPIPInterface::exec_command() { ret = OK; char cmd[MAX_STR_LENGTH]; char answer[MAX_STR_LENGTH]; int sysret=0; // receive arguments if(socket->ReceiveDataOnly(cmd,MAX_STR_LENGTH) < 0 ){ sprintf(mess,"Error reading from socket\n"); ret=FAIL; } // execute action if the arguments correctly arrived if (ret==OK) { #ifdef VERBOSE cout << "executing command " << cmd << endl; #endif if (lockStatus==0 || socket->differentClients==0) sysret=system(cmd); //should be replaced by popen if (sysret==0) { strcpy(answer,"Succeeded\n"); if (lockStatus==1 && socket->differentClients==1) sprintf(answer,"Detector locked by %s\n", socket->lastClientIP); } else { strcpy(answer,"Failed\n"); ret=FAIL; } } else strcpy(answer,"Could not receive the command\n"); // send answer socket->SendDataOnly(&ret,sizeof(ret)); if(socket->SendDataOnly(answer,MAX_STR_LENGTH) < 0){ strcpy(mess,"Error writing to socket"); ret=FAIL; } //return ok/fail return ret; }