mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-22 03:40:04 +02:00
veotalg for g2
This commit is contained in:
parent
af16ad4040
commit
e02493d4e4
@ -90,8 +90,14 @@
|
|||||||
|
|
||||||
#define CONFIG_VETO_ENBL_OFST (0)
|
#define CONFIG_VETO_ENBL_OFST (0)
|
||||||
#define CONFIG_VETO_ENBL_MSK (0x00000001 << CONFIG_VETO_ENBL_OFST)
|
#define CONFIG_VETO_ENBL_MSK (0x00000001 << CONFIG_VETO_ENBL_OFST)
|
||||||
|
#define CONFIG_VETO_CH_3GB_ALG_OFST (8)
|
||||||
|
#define CONFIG_VETO_CH_3GB_ALG_MSK (0x00000007 << CONFIG_VETO_CH_3GB_ALG_OFST)
|
||||||
|
#define CONFIG_VETO_CH_3GB_ALG_DEFAULT_VAL ((0x0 << CONFIG_VETO_CH_3GB_ALG_OFST) & CONFIG_VETO_CH_3GB_ALG_MSK)
|
||||||
#define CONFIG_VETO_CH_3GB_ENBL_OFST (11)
|
#define CONFIG_VETO_CH_3GB_ENBL_OFST (11)
|
||||||
#define CONFIG_VETO_CH_3GB_ENBL_MSK (0x00000001 << CONFIG_VETO_CH_3GB_ENBL_OFST)
|
#define CONFIG_VETO_CH_3GB_ENBL_MSK (0x00000001 << CONFIG_VETO_CH_3GB_ENBL_OFST)
|
||||||
|
#define CONFIG_VETO_CH_10GB_ALG_OFST (12)
|
||||||
|
#define CONFIG_VETO_CH_10GB_ALG_MSK (0x00000007 << CONFIG_VETO_CH_10GB_ALG_OFST)
|
||||||
|
#define CONFIG_VETO_CH_10GB_ALG_DEFAULT_VAL ((0x0 << CONFIG_VETO_CH_10GB_ALG_OFST) & CONFIG_VETO_CH_10GB_ALG_MSK)
|
||||||
#define CONFIG_VETO_CH_10GB_ENBL_OFST (15)
|
#define CONFIG_VETO_CH_10GB_ENBL_OFST (15)
|
||||||
#define CONFIG_VETO_CH_10GB_ENBL_MSK (0x00000001 << CONFIG_VETO_CH_10GB_ENBL_OFST)
|
#define CONFIG_VETO_CH_10GB_ENBL_MSK (0x00000001 << CONFIG_VETO_CH_10GB_ENBL_OFST)
|
||||||
|
|
||||||
|
@ -2595,6 +2595,36 @@ int getVetoStream() {
|
|||||||
return ((bus_r(CONFIG_REG) & CONFIG_VETO_CH_3GB_ENBL_MSK) ? 1 : 0);
|
return ((bus_r(CONFIG_REG) & CONFIG_VETO_CH_3GB_ENBL_MSK) ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum vetoAlgorithm getVetoAlgorithm(enum ethernetInterface interface) {
|
||||||
|
// 3gbe
|
||||||
|
if (interface == I3GBE) {
|
||||||
|
int retval = ((bus_r(CONFIG_REG) & CONFIG_VETO_CH_3GB_ALG_MSK) >>
|
||||||
|
CONFIG_VETO_CH_3GB_ALG_OFST);
|
||||||
|
switch (retval) {
|
||||||
|
// more to follow
|
||||||
|
case CONFIG_VETO_CH_3GB_ALG_DEFAULT_VAL:
|
||||||
|
return DEFAULT_ALGORITHM;
|
||||||
|
default:
|
||||||
|
LOG(logERROR, ("unknown algorithm %d for 3gbe\n", retval));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 10gbe
|
||||||
|
int retval = ((bus_r(CONFIG_REG) & CONFIG_VETO_CH_10GB_ALG_MSK) >>
|
||||||
|
CONFIG_VETO_CH_10GB_ALG_OFST);
|
||||||
|
switch (retval) {
|
||||||
|
// more to follow
|
||||||
|
case CONFIG_VETO_CH_10GB_ALG_DEFAULT_VAL:
|
||||||
|
return DEFAULT_ALGORITHM;
|
||||||
|
default:
|
||||||
|
LOG(logERROR, ("unknown algorithm %d for 3gbe\n", retval));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void setVetoAlgorithm(enum ethernetInterface interface,
|
||||||
|
enum vetoAlgorithm alg) {}
|
||||||
|
|
||||||
void setBadChannels(int nch, int *channels) {
|
void setBadChannels(int nch, int *channels) {
|
||||||
LOG(logINFO, ("Setting %d bad channels\n", nch));
|
LOG(logINFO, ("Setting %d bad channels\n", nch));
|
||||||
|
|
||||||
|
@ -542,6 +542,8 @@ void setVeto(int enable);
|
|||||||
int getVeto();
|
int getVeto();
|
||||||
void setVetoStream(int value);
|
void setVetoStream(int value);
|
||||||
int getVetoStream();
|
int getVetoStream();
|
||||||
|
enum vetoAlgorithm getVetoAlgorithm(enum ethernetInterface interface);
|
||||||
|
void setVetoAlgorithm(enum ethernetInterface interface, enum vetoAlgorithm alg);
|
||||||
void setBadChannels(int nch, int *channels);
|
void setBadChannels(int nch, int *channels);
|
||||||
int *getBadChannels(int *nch);
|
int *getBadChannels(int *nch);
|
||||||
#endif
|
#endif
|
||||||
|
@ -249,3 +249,5 @@ int get_all_threshold_energy(int);
|
|||||||
int get_master(int);
|
int get_master(int);
|
||||||
int get_veto_stream(int);
|
int get_veto_stream(int);
|
||||||
int set_veto_stream(int);
|
int set_veto_stream(int);
|
||||||
|
int get_veto_algorithm(int);
|
||||||
|
int set_veto_algorithm(int);
|
@ -371,6 +371,8 @@ void function_table() {
|
|||||||
flist[F_GET_MASTER] = &get_master;
|
flist[F_GET_MASTER] = &get_master;
|
||||||
flist[F_GET_VETO_STREAM] = &get_veto_stream;
|
flist[F_GET_VETO_STREAM] = &get_veto_stream;
|
||||||
flist[F_SET_VETO_STREAM] = &set_veto_stream;
|
flist[F_SET_VETO_STREAM] = &set_veto_stream;
|
||||||
|
flist[F_GET_VETO_ALGORITHM] = &get_veto_algorithm;
|
||||||
|
flist[F_SET_VETO_ALGORITHM] = &set_veto_algorithm;
|
||||||
|
|
||||||
// check
|
// check
|
||||||
if (NUM_DET_FUNCTIONS >= RECEIVER_ENUM_START) {
|
if (NUM_DET_FUNCTIONS >= RECEIVER_ENUM_START) {
|
||||||
@ -8457,3 +8459,70 @@ int set_veto_stream(int file_des) {
|
|||||||
#endif
|
#endif
|
||||||
return Server_SendResult(file_des, INT32, NULL, 0);
|
return Server_SendResult(file_des, INT32, NULL, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int get_veto_algorithm(int file_des) {
|
||||||
|
ret = OK;
|
||||||
|
memset(mess, 0, sizeof(mess));
|
||||||
|
enum ethernetInterface arg = NONE;
|
||||||
|
enum vetoAlgorithm retval = DEFAULT_ALGORITHM;
|
||||||
|
if (receiveData(file_des, &arg, sizeof(arg), INT32) < 0)
|
||||||
|
return printSocketReadError();
|
||||||
|
|
||||||
|
LOG(logDEBUG1, ("Getting veto algorithm for interface %d\n", arg));
|
||||||
|
|
||||||
|
#ifndef GOTTHARD2D
|
||||||
|
functionNotImplemented();
|
||||||
|
#else
|
||||||
|
// get only
|
||||||
|
if (arg != I3GBE && arg != I10GBE) {
|
||||||
|
ret = FAIL;
|
||||||
|
sprintf(mess, "Could not get vetoalgorithm. Invalid interface %d.\n",
|
||||||
|
arg);
|
||||||
|
LOG(logERROR, (mess));
|
||||||
|
} else {
|
||||||
|
retval = getVetoAlgorithm(arg);
|
||||||
|
LOG(logDEBUG1, ("vetoalgorithm retval: %u\n", retval));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return Server_SendResult(file_des, INT32, &retval, sizeof(retval));
|
||||||
|
}
|
||||||
|
|
||||||
|
int set_veto_algorithm(int file_des) {
|
||||||
|
ret = OK;
|
||||||
|
memset(mess, 0, sizeof(mess));
|
||||||
|
int args[2] = {-1, -1};
|
||||||
|
if (receiveData(file_des, args, sizeof(args), INT32) < 0)
|
||||||
|
return printSocketReadError();
|
||||||
|
|
||||||
|
enum vetoAlgorithm alg = args[0];
|
||||||
|
enum ethernetInterface interface = args[1];
|
||||||
|
LOG(logINFO, ("Setting vetoalgorithm (interface: %d): %u\n", (int)interface,
|
||||||
|
(int)alg));
|
||||||
|
|
||||||
|
#ifndef GOTTHARD2D
|
||||||
|
functionNotImplemented();
|
||||||
|
#else
|
||||||
|
// only set
|
||||||
|
if (Server_VerifyLock() == OK) {
|
||||||
|
if (interface != I3GBE && interface != I10GBE) {
|
||||||
|
ret = FAIL;
|
||||||
|
sprintf(mess,
|
||||||
|
"Could not set vetoalgorithm. Invalid interface %d.\n",
|
||||||
|
interface);
|
||||||
|
LOG(logERROR, (mess));
|
||||||
|
} else if (alg != DEFAULT_ALGORITHM) {
|
||||||
|
ret = FAIL;
|
||||||
|
sprintf(mess,
|
||||||
|
"Could not set vetoalgorithm. Invalid algorithm %d.\n",
|
||||||
|
alg);
|
||||||
|
LOG(logERROR, (mess));
|
||||||
|
} else {
|
||||||
|
setVetoAlgorithm(alg, interface);
|
||||||
|
int retval = getVetoAlgorithm(interface);
|
||||||
|
LOG(logDEBUG1, ("vetoalgorithm retval: %u\n", retval));
|
||||||
|
validate(alg, retval, "set veto algorithm", DEC);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return Server_SendResult(file_des, INT32, NULL, 0);
|
||||||
|
}
|
@ -1825,7 +1825,19 @@ std::string CmdProxy::VetoStreaming(int action) {
|
|||||||
if (args.empty()) {
|
if (args.empty()) {
|
||||||
WrongNumberOfParameters(1);
|
WrongNumberOfParameters(1);
|
||||||
}
|
}
|
||||||
defs::ethernetInterface interface = GetVetoInterface(true);
|
defs::ethernetInterface interface = defs::ethernetInterface::NONE;
|
||||||
|
for (const auto &arg : args) {
|
||||||
|
if (arg == "none") {
|
||||||
|
if (args.size() > 1) {
|
||||||
|
throw sls::RuntimeError(
|
||||||
|
std::string(
|
||||||
|
"cannot have other arguments with 'none'. args: ") +
|
||||||
|
ToString(args));
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
interface = interface | (StringTo<defs::ethernetInterface>(arg));
|
||||||
|
}
|
||||||
det->setVetoStream(interface, std::vector<int>{det_id});
|
det->setVetoStream(interface, std::vector<int>{det_id});
|
||||||
os << ToString(interface) << '\n';
|
os << ToString(interface) << '\n';
|
||||||
} else {
|
} else {
|
||||||
@ -1834,48 +1846,36 @@ std::string CmdProxy::VetoStreaming(int action) {
|
|||||||
return os.str();
|
return os.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
defs::ethernetInterface CmdProxy::GetVetoInterface(bool isNoneAllowed) {
|
|
||||||
defs::ethernetInterface interface = defs::ethernetInterface::NONE;
|
|
||||||
for (const auto &arg : args) {
|
|
||||||
if (arg == "none") {
|
|
||||||
if (!isNoneAllowed) {
|
|
||||||
throw sls::RuntimeError("Must specifiy an interface");
|
|
||||||
} else {
|
|
||||||
if (args.size() > 1) {
|
|
||||||
throw sls::RuntimeError(
|
|
||||||
std::string(
|
|
||||||
"cannot have other arguments with 'none'. args: ") +
|
|
||||||
ToString(args));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
interface = interface | (StringTo<defs::ethernetInterface>(arg));
|
|
||||||
}
|
|
||||||
return interface;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string CmdProxy::VetoAlgorithm(int action) {
|
std::string CmdProxy::VetoAlgorithm(int action) {
|
||||||
std::ostringstream os;
|
std::ostringstream os;
|
||||||
os << cmd << ' ';
|
os << cmd << ' ';
|
||||||
if (action == defs::HELP_ACTION) {
|
if (action == defs::HELP_ACTION) {
|
||||||
os << "[default] [3gbe|10gbe|...]\n\t[Gotthard2] Set the veto "
|
os << "[default] [3gbe|10gbe]\n\t[Gotthard2] Set the veto "
|
||||||
"algorithm."
|
"algorithm."
|
||||||
<< '\n';
|
<< '\n';
|
||||||
} else if (action == defs::GET_ACTION) {
|
} else if (action == defs::GET_ACTION) {
|
||||||
if (args.size() < 1) {
|
if (args.size() != 1) {
|
||||||
WrongNumberOfParameters(1);
|
WrongNumberOfParameters(1);
|
||||||
}
|
}
|
||||||
defs::ethernetInterface interface = GetVetoInterface(false);
|
defs::ethernetInterface interface =
|
||||||
|
StringTo<defs::ethernetInterface>(args[0]);
|
||||||
|
if (interface == defs::ethernetInterface::NONE) {
|
||||||
|
throw sls::RuntimeError(
|
||||||
|
"Must specify an interface to set algorithm");
|
||||||
|
}
|
||||||
auto t = det->getVetoAlgorithm(interface, std::vector<int>{det_id});
|
auto t = det->getVetoAlgorithm(interface, std::vector<int>{det_id});
|
||||||
os << OutString(t) << ' ' << ToString(interface) << '\n';
|
os << OutString(t) << ' ' << ToString(interface) << '\n';
|
||||||
} else if (action == defs::PUT_ACTION) {
|
} else if (action == defs::PUT_ACTION) {
|
||||||
if (args.size() < 2) {
|
if (args.size() != 2) {
|
||||||
WrongNumberOfParameters(2);
|
WrongNumberOfParameters(2);
|
||||||
}
|
}
|
||||||
defs::vetoAlgorithm alg = StringTo<defs::vetoAlgorithm>(args[0]);
|
defs::vetoAlgorithm alg = StringTo<defs::vetoAlgorithm>(args[0]);
|
||||||
args.erase(args.begin());
|
defs::ethernetInterface interface =
|
||||||
defs::ethernetInterface interface = GetVetoInterface(false);
|
StringTo<defs::ethernetInterface>(args[1]);
|
||||||
|
if (interface == defs::ethernetInterface::NONE) {
|
||||||
|
throw sls::RuntimeError(
|
||||||
|
"Must specify an interface to set algorithm");
|
||||||
|
}
|
||||||
det->setVetoAlgorithm(alg, interface, std::vector<int>{det_id});
|
det->setVetoAlgorithm(alg, interface, std::vector<int>{det_id});
|
||||||
os << ToString(alg) << ' ' << ToString(interface) << '\n';
|
os << ToString(alg) << ' ' << ToString(interface) << '\n';
|
||||||
} else {
|
} else {
|
||||||
|
@ -1135,7 +1135,6 @@ class CmdProxy {
|
|||||||
std::string VetoFile(int action);
|
std::string VetoFile(int action);
|
||||||
std::string BurstMode(int action);
|
std::string BurstMode(int action);
|
||||||
std::string VetoStreaming(int action);
|
std::string VetoStreaming(int action);
|
||||||
defs::ethernetInterface GetVetoInterface(bool isNoneAllowed);
|
|
||||||
std::string VetoAlgorithm(int action);
|
std::string VetoAlgorithm(int action);
|
||||||
std::string ConfigureADC(int action);
|
std::string ConfigureADC(int action);
|
||||||
std::string BadChannels(int action);
|
std::string BadChannels(int action);
|
||||||
|
@ -1878,15 +1878,17 @@ void Module::setVetoStream(const bool value) {
|
|||||||
sendToDetector(F_SET_VETO_STREAM, static_cast<int>(value), nullptr);
|
sendToDetector(F_SET_VETO_STREAM, static_cast<int>(value), nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
slsDetectorDefs::vetoAlgorithm
|
slsDetectorDefs::vetoAlgorithm Module::getVetoAlgorithm(
|
||||||
Module::getVetoAlgorithm(const slsDetectorDefs::ethernetInterface) const {
|
const slsDetectorDefs::ethernetInterface interface) const {
|
||||||
return alg_;
|
return sendToDetector<vetoAlgorithm>(F_GET_VETO_ALGORITHM,
|
||||||
|
static_cast<int>(interface));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Module::setVetoAlgorithm(
|
void Module::setVetoAlgorithm(
|
||||||
const slsDetectorDefs::vetoAlgorithm alg,
|
const slsDetectorDefs::vetoAlgorithm alg,
|
||||||
const slsDetectorDefs::ethernetInterface interface) {
|
const slsDetectorDefs::ethernetInterface interface) {
|
||||||
alg_ = alg;
|
int args[]{static_cast<int>(alg), static_cast<int>(interface)};
|
||||||
|
sendToDetector(F_SET_VETO_ALGORITHM, args, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
int Module::getADCConfiguration(const int chipIndex, const int adcIndex) const {
|
int Module::getADCConfiguration(const int chipIndex, const int adcIndex) const {
|
||||||
|
@ -409,7 +409,7 @@ class Module : public virtual slsDetectorDefs {
|
|||||||
bool getVetoStream() const;
|
bool getVetoStream() const;
|
||||||
void setVetoStream(const bool value);
|
void setVetoStream(const bool value);
|
||||||
slsDetectorDefs::vetoAlgorithm
|
slsDetectorDefs::vetoAlgorithm
|
||||||
getVetoAlgorithm(const slsDetectorDefs::ethernetInterface) const;
|
getVetoAlgorithm(const slsDetectorDefs::ethernetInterface interface) const;
|
||||||
void setVetoAlgorithm(const slsDetectorDefs::vetoAlgorithm alg,
|
void setVetoAlgorithm(const slsDetectorDefs::vetoAlgorithm alg,
|
||||||
const slsDetectorDefs::ethernetInterface interface);
|
const slsDetectorDefs::ethernetInterface interface);
|
||||||
int getADCConfiguration(const int chipIndex, const int adcIndex) const;
|
int getADCConfiguration(const int chipIndex, const int adcIndex) const;
|
||||||
@ -725,7 +725,6 @@ class Module : public virtual slsDetectorDefs {
|
|||||||
|
|
||||||
const int moduleId;
|
const int moduleId;
|
||||||
mutable sls::SharedMemory<sharedSlsDetector> shm{0, 0};
|
mutable sls::SharedMemory<sharedSlsDetector> shm{0, 0};
|
||||||
slsDetectorDefs::vetoAlgorithm alg_{slsDetectorDefs::DEFAULT_ALGORITHM};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sls
|
} // namespace sls
|
@ -714,17 +714,9 @@ TEST_CASE("vetoalg", "[.cmd]") {
|
|||||||
proxy.Call("vetoalg", {"10gbe"}, -1, GET, oss);
|
proxy.Call("vetoalg", {"10gbe"}, -1, GET, oss);
|
||||||
REQUIRE(oss.str() == "vetoalg default 10gbe\n");
|
REQUIRE(oss.str() == "vetoalg default 10gbe\n");
|
||||||
}
|
}
|
||||||
{
|
REQUIRE_THROWS(
|
||||||
std::ostringstream oss;
|
proxy.Call("vetoalg", {"default", "3gbe", "10gbe"}, -1, PUT));
|
||||||
proxy.Call("vetoalg", {"default", "3gbe", "10gbe"}, -1, PUT, oss);
|
REQUIRE_THROWS(proxy.Call("vetoalg", {"default", "none"}, -1, PUT));
|
||||||
REQUIRE(oss.str() == "vetoalg default 3gbe, 10gbe\n");
|
|
||||||
}
|
|
||||||
{
|
|
||||||
std::ostringstream oss;
|
|
||||||
proxy.Call("vetoalg", {"3gbe", "10gbe"}, -1, GET, oss);
|
|
||||||
REQUIRE(oss.str() == "vetoalg default 3gbe, 10gbe\n");
|
|
||||||
}
|
|
||||||
REQUIRE_THROWS(proxy.Call("vetostream", {"3gbe", "none"}, -1, PUT));
|
|
||||||
for (int i = 0; i != det.size(); ++i) {
|
for (int i = 0; i != det.size(); ++i) {
|
||||||
det.setVetoAlgorithm(prev_val_3g[i], defs::ethernetInterface::I3GBE,
|
det.setVetoAlgorithm(prev_val_3g[i], defs::ethernetInterface::I3GBE,
|
||||||
{i});
|
{i});
|
||||||
|
@ -223,6 +223,8 @@ enum detFuncs {
|
|||||||
F_GET_MASTER,
|
F_GET_MASTER,
|
||||||
F_GET_VETO_STREAM,
|
F_GET_VETO_STREAM,
|
||||||
F_SET_VETO_STREAM,
|
F_SET_VETO_STREAM,
|
||||||
|
F_GET_VETO_ALGORITHM,
|
||||||
|
F_SET_VETO_ALGORITHM,
|
||||||
|
|
||||||
NUM_DET_FUNCTIONS,
|
NUM_DET_FUNCTIONS,
|
||||||
RECEIVER_ENUM_START = 256, /**< detector function should not exceed this
|
RECEIVER_ENUM_START = 256, /**< detector function should not exceed this
|
||||||
@ -552,7 +554,8 @@ const char* getFunctionNameFromEnum(enum detFuncs func) {
|
|||||||
case F_GET_MASTER: return "F_GET_MASTER";
|
case F_GET_MASTER: return "F_GET_MASTER";
|
||||||
case F_GET_VETO_STREAM: return "F_GET_VETO_STREAM";
|
case F_GET_VETO_STREAM: return "F_GET_VETO_STREAM";
|
||||||
case F_SET_VETO_STREAM: return "F_SET_VETO_STREAM";
|
case F_SET_VETO_STREAM: return "F_SET_VETO_STREAM";
|
||||||
|
case F_GET_VETO_ALGORITHM: return "F_GET_VETO_ALGORITHM";
|
||||||
|
case F_SET_VETO_ALGORITHM: return "F_SET_VETO_ALGORITHM";
|
||||||
|
|
||||||
case NUM_DET_FUNCTIONS: return "NUM_DET_FUNCTIONS";
|
case NUM_DET_FUNCTIONS: return "NUM_DET_FUNCTIONS";
|
||||||
case RECEIVER_ENUM_START: return "RECEIVER_ENUM_START";
|
case RECEIVER_ENUM_START: return "RECEIVER_ENUM_START";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user