dev:Eiger febl febr (#601)

* eiger: get febl and febr versions in versions command, also added in python
This commit is contained in:
Dhanya Thattil 2023-02-24 10:06:11 +01:00 committed by GitHub
parent 276dc52196
commit 48a684b95f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
25 changed files with 160 additions and 12 deletions

View File

@ -27,6 +27,7 @@ This document describes the differences between v7.0.0.rc1 and v6.1.2
========================== ==========================
- moench being made compatible with jungfrau 2.0 boards (jungfrau structure, away from ctb) - moench being made compatible with jungfrau 2.0 boards (jungfrau structure, away from ctb)
- eiger febl and feb in versions
2. On-board Detector Server Compatibility 2. On-board Detector Server Compatibility

View File

@ -1797,6 +1797,17 @@ class Detector(CppDetectorApi):
@property @property
def versions(self): def versions(self):
if self.type == detectorType.EIGER:
return {'type': self.type,
'package': self.packageversion,
'client': self.clientversion,
'firmware (Beb)': self.firmwareversion,
'firmware(Febl)': self.getFrontEndFirmwareVersion(slsDetectorDefs.fpgaPosition.FRONT_LEFT),
'firmware (Febr)': self.getFrontEndFirmwareVersion(slsDetectorDefs.fpgaPosition.FRONT_RIGHT),
'detectorserver': self.detectorserverversion,
'kernel': self.kernelversion,
'receiver': self.rx_version}
return {'type': self.type, return {'type': self.type,
'package': self.packageversion, 'package': self.packageversion,
'client': self.clientversion, 'client': self.clientversion,

View File

@ -61,6 +61,11 @@ void init_det(py::module &m) {
(Result<int64_t>(Detector::*)(sls::Positions) const) & (Result<int64_t>(Detector::*)(sls::Positions) const) &
Detector::getFirmwareVersion, Detector::getFirmwareVersion,
py::arg() = Positions{}); py::arg() = Positions{});
CppDetectorApi.def("getFrontEndFirmwareVersion",
(Result<int64_t>(Detector::*)(const defs::fpgaPosition,
sls::Positions) const) &
Detector::getFrontEndFirmwareVersion,
py::arg(), py::arg() = Positions{});
CppDetectorApi.def( CppDetectorApi.def(
"getDetectorServerVersion", "getDetectorServerVersion",
(Result<std::string>(Detector::*)(sls::Positions) const) & (Result<std::string>(Detector::*)(sls::Positions) const) &

View File

@ -286,6 +286,11 @@ void init_enums(py::module &m) {
.value("BOTTOM", slsDetectorDefs::portPosition::BOTTOM) .value("BOTTOM", slsDetectorDefs::portPosition::BOTTOM)
.export_values(); .export_values();
py::enum_<slsDetectorDefs::fpgaPosition>(Defs, "fpgaPosition")
.value("FRONT_LEFT", slsDetectorDefs::fpgaPosition::FRONT_LEFT)
.value("FRONT_RIGHT", slsDetectorDefs::fpgaPosition::FRONT_RIGHT)
.export_values();
py::enum_<slsDetectorDefs::streamingInterface>(Defs, "streamingInterface", py::enum_<slsDetectorDefs::streamingInterface>(Defs, "streamingInterface",
py::arithmetic()) py::arithmetic())
.value("NONE", slsDetectorDefs::streamingInterface::NONE) .value("NONE", slsDetectorDefs::streamingInterface::NONE)

View File

@ -2180,6 +2180,36 @@ int Feb_Control_GetRightFPGATemp() {
return (int)temperature; return (int)temperature;
} }
int64_t Feb_Control_GetFrontLeftFirmwareVersion() {
if (!Feb_Control_activated) {
return 0;
}
unsigned int value = 0;
if (!Feb_Interface_ReadRegister(Feb_Control_leftAddress, FEB_REG_STATUS,
&value)) {
LOG(logERROR, ("Trouble reading FEB_REG_STATUS reg to get left feb "
"fw version\n"));
return 0;
}
return ((value & FEB_REG_STATUS_FW_VERSION_MSK) >>
FEB_REG_STATUS_FW_VERSION_OFST);
}
int64_t Feb_Control_GetFrontRightFirmwareVersion() {
if (!Feb_Control_activated) {
return 0;
}
unsigned int value = 0;
if (!Feb_Interface_ReadRegister(Feb_Control_rightAddress, FEB_REG_STATUS,
&value)) {
LOG(logERROR, ("Trouble reading FEB_REG_STATUS reg to get right feb "
"fw version\n"));
return 0;
}
return ((value & FEB_REG_STATUS_FW_VERSION_MSK) >>
FEB_REG_STATUS_FW_VERSION_OFST);
}
int64_t Feb_Control_GetMeasuredPeriod() { int64_t Feb_Control_GetMeasuredPeriod() {
if (!Feb_Control_activated) { if (!Feb_Control_activated) {
return 0; return 0;

View File

@ -116,5 +116,7 @@ int Feb_Control_PrintCorrectedValues();
// adcs // adcs
int Feb_Control_GetLeftFPGATemp(); int Feb_Control_GetLeftFPGATemp();
int Feb_Control_GetRightFPGATemp(); int Feb_Control_GetRightFPGATemp();
int64_t Feb_Control_GetFrontLeftFirmwareVersion();
int64_t Feb_Control_GetFrontRightFirmwareVersion();
int64_t Feb_Control_GetMeasuredPeriod(); int64_t Feb_Control_GetMeasuredPeriod();
int64_t Feb_Control_GetSubMeasuredPeriod(); int64_t Feb_Control_GetSubMeasuredPeriod();

View File

@ -46,6 +46,8 @@
#define FEB_REG_STATUS_WAIT_FOR_TRGGR_MSK (0x00000001 << FEB_REG_STATUS_WAIT_FOR_TRGGR_OFST) #define FEB_REG_STATUS_WAIT_FOR_TRGGR_MSK (0x00000001 << FEB_REG_STATUS_WAIT_FOR_TRGGR_OFST)
#define FEB_REG_STATUS_ACQ_DONE_OFST (6) #define FEB_REG_STATUS_ACQ_DONE_OFST (6)
#define FEB_REG_STATUS_ACQ_DONE_MSK (0x00000001 << FEB_REG_STATUS_ACQ_DONE_OFST) #define FEB_REG_STATUS_ACQ_DONE_MSK (0x00000001 << FEB_REG_STATUS_ACQ_DONE_OFST)
#define FEB_REG_STATUS_FW_VERSION_OFST (8)
#define FEB_REG_STATUS_FW_VERSION_MSK (0x000000FF << FEB_REG_STATUS_FW_VERSION_OFST)
#define FEB_REG_STATUS_TEMP_OFST (16) #define FEB_REG_STATUS_TEMP_OFST (16)
#define FEB_REG_STATUS_TEMP_MSK (0x0000FFFF << FEB_REG_STATUS_TEMP_OFST) #define FEB_REG_STATUS_TEMP_MSK (0x0000FFFF << FEB_REG_STATUS_TEMP_OFST)

View File

@ -216,6 +216,27 @@ u_int64_t getFirmwareVersion() {
#endif #endif
} }
uint64_t getFrontEndFirmwareVersion(enum fpgaPosition fpgaPosition) {
uint64_t retval = 0;
#ifndef VIRTUAL
sharedMemory_lockLocalLink();
switch (fpgaPosition) {
case FRONT_LEFT:
retval = Feb_Control_GetFrontLeftFirmwareVersion(fpgaPosition);
break;
case FRONT_RIGHT:
retval = Feb_Control_GetFrontRightFirmwareVersion(fpgaPosition);
break;
default:
LOG(logERROR,
("unknown index for fpga position to read firmware version\n"));
retval = -1;
}
sharedMemory_unlockLocalLink();
#endif
return retval;
}
u_int64_t getFirmwareAPIVersion() { u_int64_t getFirmwareAPIVersion() {
#ifdef VIRTUAL #ifdef VIRTUAL
return 0; return 0;

View File

@ -78,6 +78,9 @@ int getTestImageMode();
// Ids // Ids
void getServerVersion(char *version); void getServerVersion(char *version);
u_int64_t getFirmwareVersion(); u_int64_t getFirmwareVersion();
#ifdef EIGERD
uint64_t getFrontEndFirmwareVersion(enum fpgaPosition fpgaPosition);
#endif
u_int64_t getFirmwareAPIVersion(); u_int64_t getFirmwareAPIVersion();
#ifndef EIGERD #ifndef EIGERD
void getHardwareVersion(char *version); void getHardwareVersion(char *version);

View File

@ -306,3 +306,4 @@ int get_module(int);
int get_synchronization(int); int get_synchronization(int);
int set_synchronization(int); int set_synchronization(int);
int get_hardware_version(int); int get_hardware_version(int);
int get_frontend_firmware_version(int);

View File

@ -471,6 +471,7 @@ void function_table() {
flist[F_GET_SYNCHRONIZATION] = &get_synchronization; flist[F_GET_SYNCHRONIZATION] = &get_synchronization;
flist[F_SET_SYNCHRONIZATION] = &set_synchronization; flist[F_SET_SYNCHRONIZATION] = &set_synchronization;
flist[F_GET_HARDWARE_VERSION] = &get_hardware_version; flist[F_GET_HARDWARE_VERSION] = &get_hardware_version;
flist[F_GET_FRONTEND_FIRMWARE_VERSION] = &get_frontend_firmware_version;
// check // check
if (NUM_DET_FUNCTIONS >= RECEIVER_ENUM_START) { if (NUM_DET_FUNCTIONS >= RECEIVER_ENUM_START) {
@ -10136,3 +10137,35 @@ int get_hardware_version(int file_des) {
#endif #endif
return Server_SendResult(file_des, OTHER, retvals, sizeof(retvals)); return Server_SendResult(file_des, OTHER, retvals, sizeof(retvals));
} }
int get_frontend_firmware_version(int file_des) {
ret = OK;
memset(mess, 0, sizeof(mess));
enum fpgaPosition arg = FRONT_LEFT;
int64_t retval = -1;
if (receiveData(file_des, &arg, sizeof(arg), INT32) < 0)
return printSocketReadError();
LOG(logDEBUG1, ("Getting front end firmware version: %s\n",
(arg == FRONT_LEFT ? "left" : "right")));
#if !defined(EIGERD)
functionNotImplemented();
#else
switch (arg) {
case FRONT_LEFT:
case FRONT_RIGHT:
break;
default:
modeNotImplemented("Fpga position Index", (int)arg);
break;
}
if (ret == OK) {
retval = getFrontEndFirmwareVersion(arg);
LOG(logDEBUG1,
("Front %s version retval: 0x%llx\n",
(arg == FRONT_LEFT ? "left" : "right"), (long long int)retval));
}
#endif
return Server_SendResult(file_des, INT64, &retval, sizeof(retval));
}

View File

@ -78,6 +78,11 @@ class Detector {
Result<int64_t> getFirmwareVersion(Positions pos = {}) const; Result<int64_t> getFirmwareVersion(Positions pos = {}) const;
/** [Eiger] Options: FRONT_LEFT, FRONT_RIGHT */
Result<int64_t>
getFrontEndFirmwareVersion(const defs::fpgaPosition fpgaPosition,
Positions pos = {}) const;
Result<std::string> getDetectorServerVersion(Positions pos = {}) const; Result<std::string> getDetectorServerVersion(Positions pos = {}) const;
/** [Jungfrau][Moench][Gotthard2][Myhten3][Gotthard][Ctb] */ /** [Jungfrau][Moench][Gotthard2][Myhten3][Gotthard][Ctb] */

View File

@ -276,25 +276,33 @@ std::string CmdProxy::Versions(int action) {
} }
bool eiger = (det->getDetectorType().squash() == defs::EIGER); bool eiger = (det->getDetectorType().squash() == defs::EIGER);
auto t = det->getFirmwareVersion(std::vector<int>{det_id}); auto t = det->getFirmwareVersion(std::vector<int>{det_id});
os << "\nType : " << OutString(det->getDetectorType()) os << "\nType : " << OutString(det->getDetectorType())
<< "\nRelease : " << det->getPackageVersion() << std::hex << "\nRelease : " << det->getPackageVersion() << std::hex
<< "\nClient : " << det->getClientVersion(); << "\nClient : " << det->getClientVersion();
os << "\nFirmware : ";
if (eiger) { if (eiger) {
os << OutString(t); os << "\nFirmware (Beb) : "
<< OutString(det->getFirmwareVersion(std::vector<int>{det_id}));
os << "\nFirmware (Febl) : "
<< OutString(det->getFrontEndFirmwareVersion(
defs::FRONT_LEFT, std::vector<int>{det_id}));
os << "\nFirmware (Febr) : "
<< OutString(det->getFrontEndFirmwareVersion(
defs::FRONT_RIGHT, std::vector<int>{det_id}));
} else { } else {
os << OutStringHex(t); os << "\nFirmware : "
<< OutStringHex(
det->getFirmwareVersion(std::vector<int>{det_id}));
} }
os << "\nServer : " os << "\nServer : "
<< OutString( << OutString(
det->getDetectorServerVersion(std::vector<int>{det_id})); det->getDetectorServerVersion(std::vector<int>{det_id}));
if (!eiger) if (!eiger)
os << "\nHardware : " os << "\nHardware : "
<< OutString(det->getHardwareVersion(std::vector<int>{det_id})); << OutString(det->getHardwareVersion(std::vector<int>{det_id}));
os << "\nKernel : " os << "\nKernel : "
<< OutString(det->getKernelVersion({std::vector<int>{det_id}})); << OutString(det->getKernelVersion({std::vector<int>{det_id}}));
if (det->getUseReceiverFlag().squash(true)) { if (det->getUseReceiverFlag().squash(true)) {
os << "\nReceiver : " os << "\nReceiver : "
<< OutString(det->getReceiverVersion(std::vector<int>{det_id})); << OutString(det->getReceiverVersion(std::vector<int>{det_id}));
} }
os << std::dec << '\n'; os << std::dec << '\n';

View File

@ -124,6 +124,13 @@ Result<int64_t> Detector::getFirmwareVersion(Positions pos) const {
return pimpl->Parallel(&Module::getFirmwareVersion, pos); return pimpl->Parallel(&Module::getFirmwareVersion, pos);
} }
Result<int64_t>
Detector::getFrontEndFirmwareVersion(const defs::fpgaPosition fpgaPosition,
Positions pos) const {
return pimpl->Parallel(&Module::getFrontEndFirmwareVersion, pos,
fpgaPosition);
}
Result<std::string> Detector::getDetectorServerVersion(Positions pos) const { Result<std::string> Detector::getDetectorServerVersion(Positions pos) const {
return pimpl->Parallel(&Module::getDetectorServerVersion, pos); return pimpl->Parallel(&Module::getDetectorServerVersion, pos);
} }

View File

@ -92,6 +92,12 @@ int64_t Module::getFirmwareVersion() const {
return sendToDetector<int64_t>(F_GET_FIRMWARE_VERSION); return sendToDetector<int64_t>(F_GET_FIRMWARE_VERSION);
} }
int64_t
Module::getFrontEndFirmwareVersion(const fpgaPosition fpgaPosition) const {
return sendToDetector<int64_t>(F_GET_FRONTEND_FIRMWARE_VERSION,
fpgaPosition);
}
std::string Module::getControlServerLongVersion() const { std::string Module::getControlServerLongVersion() const {
char retval[MAX_STR_LENGTH]{}; char retval[MAX_STR_LENGTH]{};
sendToDetector(F_GET_SERVER_VERSION, nullptr, retval); sendToDetector(F_GET_SERVER_VERSION, nullptr, retval);

View File

@ -90,6 +90,7 @@ class Module : public virtual slsDetectorDefs {
void setHostname(const std::string &hostname, const bool initialChecks); void setHostname(const std::string &hostname, const bool initialChecks);
int64_t getFirmwareVersion() const; int64_t getFirmwareVersion() const;
int64_t getFrontEndFirmwareVersion(const fpgaPosition fpgaPosition) const;
std::string getControlServerLongVersion() const; std::string getControlServerLongVersion() const;
std::string getStopServerLongVersion() const; std::string getStopServerLongVersion() const;
std::string getDetectorServerVersion() const; std::string getDetectorServerVersion() const;

View File

@ -445,6 +445,11 @@ typedef struct {
enum portPosition { LEFT, RIGHT, TOP, BOTTOM }; enum portPosition { LEFT, RIGHT, TOP, BOTTOM };
/**
* eiger fpga position
*/
enum fpgaPosition { FRONT_LEFT, FRONT_RIGHT };
#ifdef __cplusplus #ifdef __cplusplus
enum class streamingInterface { enum class streamingInterface {
#else #else

View File

@ -274,6 +274,7 @@ enum detFuncs {
F_GET_SYNCHRONIZATION, F_GET_SYNCHRONIZATION,
F_SET_SYNCHRONIZATION, F_SET_SYNCHRONIZATION,
F_GET_HARDWARE_VERSION, F_GET_HARDWARE_VERSION,
F_GET_FRONTEND_FIRMWARE_VERSION,
NUM_DET_FUNCTIONS, NUM_DET_FUNCTIONS,
RECEIVER_ENUM_START = 512, /**< detector function should not exceed this RECEIVER_ENUM_START = 512, /**< detector function should not exceed this
@ -653,6 +654,7 @@ const char* getFunctionNameFromEnum(enum detFuncs func) {
case F_GET_SYNCHRONIZATION: return "F_GET_SYNCHRONIZATION"; case F_GET_SYNCHRONIZATION: return "F_GET_SYNCHRONIZATION";
case F_SET_SYNCHRONIZATION: return "F_SET_SYNCHRONIZATION"; case F_SET_SYNCHRONIZATION: return "F_SET_SYNCHRONIZATION";
case F_GET_HARDWARE_VERSION: return "F_GET_HARDWARE_VERSION"; case F_GET_HARDWARE_VERSION: return "F_GET_HARDWARE_VERSION";
case F_GET_FRONTEND_FIRMWARE_VERSION: return "F_GET_FRONTEND_FIRMWARE_VERSION";
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";

View File

@ -7,7 +7,7 @@
#define APICTB "developer 0x221213" #define APICTB "developer 0x221213"
#define APIGOTTHARD2 "developer 0x221213" #define APIGOTTHARD2 "developer 0x221213"
#define APIJUNGFRAU "developer 0x221213" #define APIJUNGFRAU "developer 0x221213"
#define APIEIGER "developer 0x221213" #define APIEIGER "developer 0x221215"
#define APIMOENCH "developer 0x221215" #define APIMOENCH "developer 0x221215"
#define APIGOTTHARD "developer 0x230117" #define APIGOTTHARD "developer 0x230117"
#define APIMYTHEN3 "developer 0x230117" #define APIMYTHEN3 "developer 0x230117"