mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-06-13 21:37:13 +02:00
merge conflict fix
This commit is contained in:
@ -2396,90 +2396,86 @@ int slsDetector::digitalTest( digitalTestMode mode, int imod){
|
||||
|
||||
int slsDetector::writeRegister(int addr, int val){
|
||||
|
||||
|
||||
int retval;
|
||||
int fnum=F_WRITE_REGISTER;
|
||||
int ret=FAIL;
|
||||
|
||||
char mess[MAX_STR_LENGTH]="";
|
||||
|
||||
int arg[2];
|
||||
arg[0]=addr;
|
||||
arg[1]=val;
|
||||
|
||||
int retval=-1;
|
||||
int fnum=F_WRITE_REGISTER;
|
||||
int ret=FAIL;
|
||||
char mess[MAX_STR_LENGTH]="";
|
||||
int arg[2];
|
||||
arg[0]=addr;
|
||||
arg[1]=val;
|
||||
|
||||
#ifdef VERBOSE
|
||||
std::cout<< std::endl;
|
||||
std::cout<< "Writing to register "<< hex<<addr << " data " << hex<<val << std::endl;
|
||||
std::cout<< std::endl;
|
||||
std::cout<< "Writing to register "<< hex<<addr << " data " << hex<<val << std::endl;
|
||||
#endif
|
||||
if (thisDetector->onlineFlag==ONLINE_FLAG) {
|
||||
if (connectControl() == OK){
|
||||
controlSocket->SendDataOnly(&fnum,sizeof(fnum));
|
||||
controlSocket->SendDataOnly(arg,sizeof(arg));
|
||||
controlSocket->ReceiveDataOnly(&ret,sizeof(ret));
|
||||
if (ret!=FAIL)
|
||||
controlSocket->ReceiveDataOnly(&retval,sizeof(retval));
|
||||
else {
|
||||
controlSocket->ReceiveDataOnly(mess,sizeof(mess));
|
||||
std::cout<< "Detector returned error: " << mess << std::endl;
|
||||
}
|
||||
disconnectControl();
|
||||
if (ret==FORCE_UPDATE)
|
||||
updateDetector();
|
||||
}
|
||||
}
|
||||
if (thisDetector->onlineFlag==ONLINE_FLAG) {
|
||||
if (connectControl() == OK){
|
||||
controlSocket->SendDataOnly(&fnum,sizeof(fnum));
|
||||
controlSocket->SendDataOnly(arg,sizeof(arg));
|
||||
controlSocket->ReceiveDataOnly(&ret,sizeof(ret));
|
||||
if (ret!=FAIL)
|
||||
controlSocket->ReceiveDataOnly(&retval,sizeof(retval));
|
||||
else {
|
||||
controlSocket->ReceiveDataOnly(mess,sizeof(mess));
|
||||
std::cout<< "Detector returned error: " << mess << std::endl;
|
||||
}
|
||||
disconnectControl();
|
||||
if (ret==FORCE_UPDATE)
|
||||
updateDetector();
|
||||
}
|
||||
}
|
||||
#ifdef VERBOSE
|
||||
std::cout<< "Register returned "<< retval << std::endl;
|
||||
std::cout<< "Register returned "<< retval << std::endl;
|
||||
#endif
|
||||
if (ret==FAIL) {
|
||||
std::cout<< "Write to register failed " << std::endl;
|
||||
}
|
||||
return retval;
|
||||
if (ret==FAIL) {
|
||||
std::cout<< "Write to register failed " << std::endl;
|
||||
setErrorMask((getErrorMask())|(REGISER_WRITE_READ));
|
||||
}
|
||||
|
||||
return retval;
|
||||
}
|
||||
|
||||
};
|
||||
/* write or read register */
|
||||
|
||||
int slsDetector::writeAdcRegister(int addr, int val){
|
||||
|
||||
int retval=-1;
|
||||
int fnum=F_WRITE_ADC_REG;
|
||||
int ret=FAIL;
|
||||
char mess[MAX_STR_LENGTH]="";
|
||||
|
||||
int retval;
|
||||
int fnum=F_WRITE_ADC_REG;
|
||||
int ret=FAIL;
|
||||
|
||||
char mess[MAX_STR_LENGTH]="";
|
||||
|
||||
int arg[2];
|
||||
arg[0]=addr;
|
||||
arg[1]=val;
|
||||
int arg[2];
|
||||
arg[0]=addr;
|
||||
arg[1]=val;
|
||||
|
||||
|
||||
#ifdef VERBOSE
|
||||
std::cout<< std::endl;
|
||||
std::cout<< "Writing to adc register "<< hex<<addr << " data " << hex<<val << std::endl;
|
||||
std::cout<< std::endl;
|
||||
std::cout<< "Writing to adc register "<< hex<<addr << " data " << hex<<val << std::endl;
|
||||
#endif
|
||||
if (thisDetector->onlineFlag==ONLINE_FLAG) {
|
||||
if (connectControl() == OK){
|
||||
controlSocket->SendDataOnly(&fnum,sizeof(fnum));
|
||||
controlSocket->SendDataOnly(arg,sizeof(arg));
|
||||
controlSocket->ReceiveDataOnly(&ret,sizeof(ret));
|
||||
if (ret!=FAIL)
|
||||
controlSocket->ReceiveDataOnly(&retval,sizeof(retval));
|
||||
else {
|
||||
controlSocket->ReceiveDataOnly(mess,sizeof(mess));
|
||||
std::cout<< "Detector returned error: " << mess << std::endl;
|
||||
}
|
||||
disconnectControl();
|
||||
if (ret==FORCE_UPDATE)
|
||||
updateDetector();
|
||||
}
|
||||
}
|
||||
if (thisDetector->onlineFlag==ONLINE_FLAG) {
|
||||
if (connectControl() == OK){
|
||||
controlSocket->SendDataOnly(&fnum,sizeof(fnum));
|
||||
controlSocket->SendDataOnly(arg,sizeof(arg));
|
||||
controlSocket->ReceiveDataOnly(&ret,sizeof(ret));
|
||||
if (ret!=FAIL)
|
||||
controlSocket->ReceiveDataOnly(&retval,sizeof(retval));
|
||||
else {
|
||||
controlSocket->ReceiveDataOnly(mess,sizeof(mess));
|
||||
std::cout<< "Detector returned error: " << mess << std::endl;
|
||||
}
|
||||
disconnectControl();
|
||||
if (ret==FORCE_UPDATE)
|
||||
updateDetector();
|
||||
}
|
||||
}
|
||||
#ifdef VERBOSE
|
||||
std::cout<< "ADC Register returned "<< retval << std::endl;
|
||||
std::cout<< "ADC Register returned "<< retval << std::endl;
|
||||
#endif
|
||||
if (ret==FAIL) {
|
||||
std::cout<< "Write ADC to register failed " << std::endl;
|
||||
}
|
||||
return retval;
|
||||
if (ret==FAIL) {
|
||||
std::cout<< "Write ADC to register failed " << std::endl;
|
||||
setErrorMask((getErrorMask())|(REGISER_WRITE_READ));
|
||||
}
|
||||
return retval;
|
||||
|
||||
};
|
||||
|
||||
@ -2488,49 +2484,81 @@ int slsDetector::writeAdcRegister(int addr, int val){
|
||||
|
||||
int slsDetector::readRegister(int addr){
|
||||
|
||||
|
||||
int retval;
|
||||
int fnum=F_READ_REGISTER;
|
||||
int ret=FAIL;
|
||||
|
||||
char mess[MAX_STR_LENGTH]="";
|
||||
|
||||
int arg;
|
||||
arg=addr;
|
||||
int retval=-1;
|
||||
int fnum=F_READ_REGISTER;
|
||||
int ret=FAIL;
|
||||
char mess[MAX_STR_LENGTH]="";
|
||||
int arg;
|
||||
arg=addr;
|
||||
|
||||
|
||||
#ifdef VERBOSE
|
||||
std::cout<< std::endl;
|
||||
std::cout<< "Reading register "<< hex<<addr << std::endl;
|
||||
std::cout<< std::endl;
|
||||
std::cout<< "Reading register "<< hex<<addr << std::endl;
|
||||
#endif
|
||||
if (thisDetector->onlineFlag==ONLINE_FLAG) {
|
||||
// if (connectControl() == OK){
|
||||
if (stopSocket) {
|
||||
if (connectStop() == OK) {
|
||||
stopSocket->SendDataOnly(&fnum,sizeof(fnum));
|
||||
stopSocket->SendDataOnly(&arg,sizeof(arg));
|
||||
stopSocket->ReceiveDataOnly(&ret,sizeof(ret));
|
||||
if (ret!=FAIL)
|
||||
stopSocket->ReceiveDataOnly(&retval,sizeof(retval));
|
||||
else {
|
||||
stopSocket->ReceiveDataOnly(mess,sizeof(mess));
|
||||
std::cout<< "Detector returned error: " << mess << std::endl;
|
||||
}
|
||||
disconnectStop();
|
||||
// if (ret==FORCE_UPDATE)
|
||||
// updateDetector();
|
||||
}
|
||||
}
|
||||
}
|
||||
if (thisDetector->onlineFlag==ONLINE_FLAG) {
|
||||
// if (connectControl() == OK){
|
||||
if (stopSocket) {
|
||||
if (connectStop() == OK) {
|
||||
stopSocket->SendDataOnly(&fnum,sizeof(fnum));
|
||||
stopSocket->SendDataOnly(&arg,sizeof(arg));
|
||||
stopSocket->ReceiveDataOnly(&ret,sizeof(ret));
|
||||
if (ret!=FAIL)
|
||||
stopSocket->ReceiveDataOnly(&retval,sizeof(retval));
|
||||
else {
|
||||
stopSocket->ReceiveDataOnly(mess,sizeof(mess));
|
||||
std::cout<< "Detector returned error: " << mess << std::endl;
|
||||
}
|
||||
disconnectStop();
|
||||
}
|
||||
}
|
||||
}
|
||||
#ifdef VERBOSE
|
||||
std::cout<< "Register returned "<< retval << std::endl;
|
||||
std::cout<< "Register returned "<< retval << std::endl;
|
||||
#endif
|
||||
if (ret==FAIL) {
|
||||
std::cout<< "Read register failed " << std::endl;
|
||||
}
|
||||
return retval;
|
||||
if (ret==FAIL) {
|
||||
std::cout<< "Read register failed " << std::endl;
|
||||
setErrorMask((getErrorMask())|(REGISER_WRITE_READ));
|
||||
}
|
||||
return retval;
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
int slsDetector::setBit(int addr, int n) {
|
||||
if (n<0 || n>31) {
|
||||
std::cout << "Bit number out of Range" << std:: endl;
|
||||
setErrorMask((getErrorMask())|(REGISER_WRITE_READ));
|
||||
}
|
||||
|
||||
// normal bit range
|
||||
else {
|
||||
int val = readRegister(addr);
|
||||
if (val != -1) {
|
||||
writeRegister(addr,val | 1<<n);
|
||||
}
|
||||
}
|
||||
|
||||
return readRegister(addr);
|
||||
}
|
||||
|
||||
|
||||
int slsDetector::clearBit(int addr, int n) {
|
||||
if (n<0 || n>31) {
|
||||
std::cout << "Bit number out of Range" << std:: endl;
|
||||
setErrorMask((getErrorMask())|(REGISER_WRITE_READ));
|
||||
}
|
||||
|
||||
// normal bit range
|
||||
else {
|
||||
int val = readRegister(addr);
|
||||
if (val != -1) {
|
||||
writeRegister(addr,val & ~(1<<n));
|
||||
}
|
||||
}
|
||||
|
||||
return readRegister(addr);
|
||||
}
|
||||
|
||||
|
||||
// Expert initialization functions
|
||||
|
Reference in New Issue
Block a user