105 lines
3.6 KiB
C++
105 lines
3.6 KiB
C++
// Copyright (2019-2023) Paul Scherrer Institute
|
|
|
|
#include "HLSSimulatedDevice.h"
|
|
|
|
HLSSimulatedDevice::HLSSimulatedDevice(uint16_t data_stream, size_t in_frame_buffer_size_modules, int16_t numa_node)
|
|
: FPGAAcquisitionDevice(data_stream) {
|
|
mac_addr = 0xCCAA11223344;
|
|
ipv4_addr = 0x0132010A;
|
|
|
|
max_modules = MAX_MODULES_FPGA;
|
|
|
|
if (data_stream != 0)
|
|
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
|
|
"HLS simulation can only work with 1 data_stream, due to use of static variables");
|
|
MapBuffersStandard(in_frame_buffer_size_modules, numa_node);
|
|
|
|
|
|
device = std::make_unique<HLSDevice>(buffer_device);
|
|
}
|
|
|
|
void HLSSimulatedDevice::CreateFinalPacket(const DiffractionExperiment& experiment) {
|
|
device->CreateFinalPacket(experiment);
|
|
}
|
|
|
|
void HLSSimulatedDevice::CreateJFPacket(const DiffractionExperiment& experiment, uint64_t frame_number, uint32_t eth_packet,
|
|
uint32_t module_number, const uint16_t *data, int8_t adjust_axis, uint8_t user) {
|
|
device->CreateJFPacket(experiment, frame_number, eth_packet, module_number, data, adjust_axis, user);
|
|
}
|
|
|
|
void HLSSimulatedDevice::CreateJFPackets(const DiffractionExperiment& experiment, uint64_t frame_number_0, uint64_t frames,
|
|
uint32_t module_number, const uint16_t *data) {
|
|
for (uint64_t i = 0; i < frames; i++) {
|
|
for (int j = 0; j < 128; j++)
|
|
CreateJFPacket(experiment, frame_number_0 + i, j, module_number, data + (i * 128 + j) * 4096, 0, 0);
|
|
}
|
|
}
|
|
|
|
void HLSSimulatedDevice::CreateEIGERPacket(const DiffractionExperiment &experiment, uint64_t frame_number,
|
|
uint32_t eth_packet, uint32_t module_number, uint32_t col, uint32_t row,
|
|
const uint16_t *data) {
|
|
device->CreateEIGERPacket(experiment, frame_number, eth_packet, module_number, col, row, data);
|
|
}
|
|
|
|
void HLSSimulatedDevice::HW_ReadActionRegister(DataCollectionConfig *job) {
|
|
device->HW_ReadActionRegister(job);
|
|
}
|
|
|
|
void HLSSimulatedDevice::HW_WriteActionRegister(const DataCollectionConfig *job) {
|
|
device->HW_WriteActionRegister(job);
|
|
}
|
|
|
|
void HLSSimulatedDevice::FPGA_StartAction(const DiffractionExperiment &experiment) {
|
|
device->FPGA_StartAction(experiment);
|
|
}
|
|
|
|
void HLSSimulatedDevice::HW_RunInternalGenerator(const FrameGeneratorConfig &config) {
|
|
device->HW_RunInternalGenerator(config);
|
|
}
|
|
|
|
void HLSSimulatedDevice::FPGA_EndAction() {
|
|
device->FPGA_EndAction();
|
|
}
|
|
|
|
|
|
bool HLSSimulatedDevice::HW_ReadMailbox(uint32_t *values) {
|
|
return device->HW_ReadMailbox(values);
|
|
}
|
|
|
|
void HLSSimulatedDevice::Cancel() {
|
|
device->Cancel();
|
|
}
|
|
|
|
bool HLSSimulatedDevice::HW_IsIdle() const {
|
|
return device->HW_IsIdle();
|
|
}
|
|
|
|
|
|
bool HLSSimulatedDevice::HW_SendWorkRequest(uint32_t handle) {
|
|
return device->HW_SendWorkRequest(handle);
|
|
}
|
|
|
|
DataCollectionStatus HLSSimulatedDevice::GetDataCollectionStatus() const {
|
|
return device->GetDataCollectionStatus();
|
|
}
|
|
|
|
void HLSSimulatedDevice::HW_LoadCalibration(const LoadCalibrationConfig &config) {
|
|
device->HW_LoadCalibration(config);
|
|
}
|
|
|
|
void HLSSimulatedDevice::HW_SetSpotFinderParameters(const SpotFinderParameters ¶ms) {
|
|
device->HW_SetSpotFinderParameters(params);
|
|
}
|
|
|
|
void HLSSimulatedDevice::HW_SetDataSource(uint32_t val) {
|
|
device->HW_SetDataSource(val);
|
|
}
|
|
|
|
uint32_t HLSSimulatedDevice::HW_GetDataSource() {
|
|
return device->HW_GetDataSource();
|
|
}
|
|
|
|
void HLSSimulatedDevice::CreateXfelBunchIDPacket(double pulse_id, uint32_t event_code) {
|
|
device->CreateXfelBunchIDPacket(pulse_id, event_code);
|
|
}
|