66 lines
3.0 KiB
C++
66 lines
3.0 KiB
C++
// Copyright (2019-2023) Paul Scherrer Institute
|
|
|
|
#ifndef JUNGFRAUJOCH_FPGAACQUISITIONDEVICE_H
|
|
#define JUNGFRAUJOCH_FPGAACQUISITIONDEVICE_H
|
|
|
|
#include "AcquisitionDevice.h"
|
|
#include "../fpga/include/jfjoch_fpga.h"
|
|
|
|
class FPGAAcquisitionDevice : public AcquisitionDevice {
|
|
uint16_t data_collection_id = 0;
|
|
|
|
uint32_t expected_descriptors_per_module = 1;
|
|
AcquisitionDeviceSource default_data_source = AcquisitionDeviceSource::MAC_100G;
|
|
|
|
virtual void FPGA_StartAction(const DiffractionExperiment &experiment) = 0;
|
|
virtual void FPGA_EndAction() = 0;
|
|
|
|
virtual void HW_WriteActionRegister(const DataCollectionConfig *job) = 0;
|
|
virtual void HW_ReadActionRegister(DataCollectionConfig *job) = 0;
|
|
virtual bool HW_IsIdle() const = 0;
|
|
void FillActionRegister(const DiffractionExperiment& x, DataCollectionConfig& job);
|
|
|
|
void Finalize() final;
|
|
|
|
std::future<void> read_work_completion_future;
|
|
void ReadWorkCompletionThread();
|
|
|
|
std::future<void> send_work_request_future;
|
|
volatile bool stop_work_requests = false;
|
|
void SendWorkRequestThread();
|
|
|
|
virtual void HW_LoadCalibration(const LoadCalibrationConfig &config) = 0;
|
|
void LoadCalibration(uint32_t handle);
|
|
virtual bool HW_ReadMailbox(uint32_t *values) = 0;
|
|
virtual bool HW_SendWorkRequest(uint32_t handle) = 0;
|
|
virtual void HW_SetSpotFinderParameters(const SpotFinderParameters ¶ms) = 0;
|
|
virtual void HW_SetDataSource(uint32_t val) = 0;
|
|
virtual uint32_t HW_GetDataSource() = 0;
|
|
void StartSendingWorkRequests() override;
|
|
void Start(const DiffractionExperiment &experiment, uint32_t flag) override;
|
|
void SetDataSource(AcquisitionDeviceSource id); // doesn't change default data
|
|
protected:
|
|
std::vector<uint16_t> internal_pkt_gen_frame;
|
|
explicit FPGAAcquisitionDevice(uint16_t data_stream);
|
|
virtual void HW_GetStatus(DataCollectionStatus *status) const = 0;
|
|
virtual void HW_GetEnvParams(DeviceStatus *status) const {
|
|
memset(status, 0, sizeof(DeviceStatus));
|
|
}
|
|
public:
|
|
void InitializeCalibration(const DiffractionExperiment &experiment, const JFCalibration &calib) override;
|
|
void InitializeIntegrationMap(const DiffractionExperiment &experiment, const std::vector<uint16_t> &v) override;
|
|
void InitializeIntegrationMap(const DiffractionExperiment &experiment, const std::vector<uint16_t> &v,
|
|
const std::vector<float> &weights) override;
|
|
|
|
void SetInternalGeneratorFrame(const std::vector<uint16_t> &v);
|
|
void SetInternalGeneratorFrameForAllModules(const std::vector<uint16_t> &v);
|
|
void SetInternalGeneratorFrame();
|
|
std::vector<uint16_t> GetInternalGeneratorFrame() const override;
|
|
void SetSpotFinderParameters(int32_t count_threshold, float snr_threshold) override;
|
|
AcquisitionDeviceSource GetDataSource() override;
|
|
void SetDefaultDataSource(AcquisitionDeviceSource id) override;
|
|
uint32_t GetExpectedDescriptorsPerModule() const override;
|
|
};
|
|
|
|
#endif //JUNGFRAUJOCH_FPGAACQUISITIONDEVICE_H
|