jf: timing info decoder (#987)

* timing_info_decoder command with options swissfel (default) and shine. added to python, command line generation, autocomplete, tostring, tests.
This commit is contained in:
2024-10-01 11:17:35 +02:00
committed by GitHub
parent 8a7ed30676
commit f43bb8eea4
33 changed files with 23282 additions and 20749 deletions

View File

@ -213,6 +213,9 @@
#define EXT_SIGNAL_MSK (0x00000001 << EXT_SIGNAL_OFST)
#define EXT_SYNC_OFST (4)
#define EXT_SYNC_MSK (0x00000001 << EXT_SYNC_OFST)
#define EXT_TIMING_INFO_DECODER_OFST (12)
#define EXT_TIMING_INFO_DECODER_MSK (0x00000001 << EXT_TIMING_INFO_DECODER_OFST)
/* Control Register */
#define CONTROL_REG (0x4F << MEM_MAP_SHIFT)

View File

@ -572,6 +572,7 @@ void setupDetector() {
#endif
setPedestalMode(DEFAULT_PEDESTAL_MODE, DEFAULT_PEDESTAL_FRAMES,
DEFAULT_PEDESTAL_LOOPS);
setTimingInfoDecoder(DEFAULT_TIMING_INFO_DECODER);
setElectronCollectionMode(DEFAULT_ELECTRON_COLLECTION_MODE);
}
@ -2616,6 +2617,41 @@ void setPedestalMode(int enable, uint8_t frames, uint16_t loops) {
}
}
int setTimingInfoDecoder(enum timingInfoDecoder val) {
switch (val) {
case SWISSFEL:
LOG(logINFO, ("Setting Timing Info Decoder to SWISSFEL\n"));
break;
case SHINE:
LOG(logINFO, ("Setting Timing Info Decoder to SHINE\n"));
break;
default:
LOG(logERROR, ("Unknown Timing Info Decoder %d\n", val));
return FAIL;
}
int decodeValue = (int)val;
uint32_t addr = EXT_SIGNAL_REG;
bus_w(addr, bus_r(addr) & ~EXT_TIMING_INFO_DECODER_MSK);
bus_w(addr, bus_r(addr) | ((decodeValue << EXT_TIMING_INFO_DECODER_OFST) &
EXT_TIMING_INFO_DECODER_MSK));
return OK;
}
int getTimingInfoDecoder(enum timingInfoDecoder *retval) {
int decodeValue = ((bus_r(EXT_SIGNAL_REG) & EXT_TIMING_INFO_DECODER_MSK) >>
EXT_TIMING_INFO_DECODER_OFST);
if (decodeValue == (int)SWISSFEL) {
*retval = SWISSFEL;
} else if (decodeValue == (int)SHINE) {
*retval = SHINE;
} else {
return FAIL;
}
return OK;
}
int getElectronCollectionMode() {
return ((bus_r(DAQ_REG) & DAQ_ELCTRN_CLLCTN_MDE_MSK) >>
DAQ_ELCTRN_CLLCTN_MDE_OFST);

View File

@ -5,8 +5,8 @@
#include "sls/sls_detector_defs.h"
#define MIN_REQRD_VRSN_T_RD_API 0x171220
#define REQRD_FRMWRE_VRSN_BOARD2 0x230920 // 1.0 pcb (version = 010)
#define REQRD_FRMWRE_VRSN 0x230921 // 2.0 pcb (version = 011)
#define REQRD_FRMWRE_VRSN_BOARD2 0x241001 // 1.0 pcb (version = 010)
#define REQRD_FRMWRE_VRSN 0x241001 // 2.0 pcb (version = 011)
#define NUM_HARDWARE_VERSIONS (2)
#define HARDWARE_VERSION_NUMBERS \
@ -59,6 +59,7 @@
#define DEFAULT_PEDESTAL_MODE (0)
#define DEFAULT_PEDESTAL_FRAMES (1)
#define DEFAULT_PEDESTAL_LOOPS (1)
#define DEFAULT_TIMING_INFO_DECODER (SWISSFEL)
#define DEFAULT_ELECTRON_COLLECTION_MODE (0)
#define HIGHVOLTAGE_MIN (60)