Files
Jungfraujoch/acquisition_device/FPGAAcquisitionDevice.h

58 lines
2.6 KiB
C++

// Copyright (2019-2023) Paul Scherrer Institute
#ifndef JUNGFRAUJOCH_FPGAACQUISITIONDEVICE_H
#define JUNGFRAUJOCH_FPGAACQUISITIONDEVICE_H
#include "AcquisitionDevice.h"
#include "../fpga/pcie_driver/ActionConfig.h"
class FPGAAcquisitionDevice : public AcquisitionDevice {
uint16_t data_collection_id = 0;
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(uint32_t modules, uint32_t storage_cells) = 0;
virtual void HW_LoadIntegrationMap(uint32_t modules) = 0;
virtual void HW_LoadInternalGeneratorFrame(uint32_t modules) = 0;
virtual bool HW_ReadMailbox(uint32_t values[16]) = 0;
virtual bool HW_SendWorkRequest(uint32_t handle) = 0;
virtual void HW_SetSpotFinderParameters(const SpotFinderParameters &params) = 0;
void StartSendingWorkRequests() override;
void Start(const DiffractionExperiment &experiment, uint32_t flag) override;
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(int16_t count_threshold, double snr_threshold) override;
};
#endif //JUNGFRAUJOCH_FPGAACQUISITIONDEVICE_H