75e401f0e5
Build Packages / Unit tests (push) Successful in 1h31m59s
Build Packages / build:rpm (rocky8_nocuda) (push) Successful in 8m43s
Build Packages / build:rpm (rocky9_nocuda) (push) Successful in 10m5s
Build Packages / build:rpm (ubuntu2204_nocuda) (push) Successful in 9m27s
Build Packages / build:rpm (ubuntu2404_nocuda) (push) Successful in 8m56s
Build Packages / build:rpm (rocky8_sls9) (push) Successful in 9m24s
Build Packages / build:rpm (rocky9_sls9) (push) Successful in 10m27s
Build Packages / build:rpm (rocky8) (push) Successful in 9m20s
Build Packages / build:rpm (rocky9) (push) Successful in 10m50s
Build Packages / build:rpm (ubuntu2204) (push) Successful in 9m54s
Build Packages / build:rpm (ubuntu2404) (push) Successful in 8m38s
Build Packages / DIALS test (push) Successful in 12m13s
Build Packages / XDS test (durin plugin) (push) Successful in 7m8s
Build Packages / XDS test (JFJoch plugin) (push) Successful in 7m8s
Build Packages / XDS test (neggia plugin) (push) Successful in 7m50s
Build Packages / Generate python client (push) Successful in 16s
Build Packages / Build documentation (push) Successful in 50s
Build Packages / Create release (push) Skipped
This is an UNSTABLE release. It includes many experimental features, as well as many AI generated fixes. We recommend using rc.152 for production use. * jfjoch_broker: Add EXPERIMENTAL pixelrefine mode for image processing * jfjoch_broker: Allow to load user mask from 8-bit and 16-bit TIFF files * jfjoch_broker: Add ROI calculation in non-FPGA workflow * jfjoch_broker: Fixes to TCP image pusher * jfjoch_broker: Remove NUMA bindings * jfjoch_broker: Improvements to indexing * jfjoch_broker: For PSI EIGER, trimming energies are taken from the detector configuration (now compulsory) instead of hardcoded values * jfjoch_writer: Save ROI definitions and the per-pixel ROI bitmap in the master file; azimuthal ROIs support phi (angular) sectors * jfjoch_viewer: Major redesign with dockable panels and saved layouts, plus on-canvas creation/move/resize of box, circle and azimuthal ROIs * jfjoch_viewer: Run jfjoch_process reprocessing jobs from inside the GUI and overlay per-run results Reviewed-on: #63
131 lines
3.8 KiB
C++
131 lines
3.8 KiB
C++
// SPDX-FileCopyrightText: 2024 Filip Leonarski, Paul Scherrer Institute <filip.leonarski@psi.ch>
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
#include "PCIExpressDevice.h"
|
|
#include "../common/NetworkAddressConvert.h"
|
|
#define PCI_EXCEPT(x) try {x;} catch (const std::exception &e) { throw PCIeDeviceException(e.what()); }
|
|
|
|
PCIExpressDevice::PCIExpressDevice(uint16_t data_stream, uint16_t pci_slot) :
|
|
PCIExpressDevice(data_stream, "/dev/jfjoch" + std::to_string(pci_slot)) {}
|
|
|
|
PCIExpressDevice::PCIExpressDevice(uint16_t data_stream) :
|
|
PCIExpressDevice(data_stream, "/dev/jfjoch" + std::to_string(data_stream)) {}
|
|
|
|
PCIExpressDevice::PCIExpressDevice(uint16_t data_stream, const std::string &device_name)
|
|
: FPGAAcquisitionDevice(data_stream), dev(device_name, true) {
|
|
|
|
DataCollectionStatus status;
|
|
PCI_EXCEPT(status = dev.GetDataCollectionStatus())
|
|
|
|
max_modules = status.max_modules;
|
|
if (max_modules == 0)
|
|
throw JFJochException(JFJochExceptionCategory::PCIeError, "Max modules cannot be zero");
|
|
|
|
uint32_t num_buf = GetNumKernelBuffers();
|
|
|
|
buffer_device.resize(num_buf, nullptr);
|
|
try {
|
|
for (int i = 0; i < num_buf; i++)
|
|
buffer_device[i] = dev.MapKernelBuffer(i);
|
|
} catch (JFJochException &e) {
|
|
UnmapBuffers();
|
|
throw;
|
|
}
|
|
}
|
|
|
|
PCIExpressDevice::~PCIExpressDevice() {
|
|
UnmapBuffers();
|
|
}
|
|
|
|
void PCIExpressDevice::UnmapBuffers() {
|
|
for (auto &buf: buffer_device)
|
|
if (buf != nullptr) dev.UnmapKernelBuffer(buf);
|
|
}
|
|
|
|
bool PCIExpressDevice::HW_ReadMailbox(uint32_t *values) {
|
|
PCI_EXCEPT(return dev.ReadWorkCompletion(values);)
|
|
}
|
|
|
|
void PCIExpressDevice::Cancel() {
|
|
PCI_EXCEPT(dev.Cancel();)
|
|
}
|
|
|
|
bool PCIExpressDevice::HW_SendWorkRequest(uint32_t handle) {
|
|
PCI_EXCEPT(return dev.SendWorkRequest(handle);)
|
|
}
|
|
|
|
void PCIExpressDevice::FPGA_StartAction(const DiffractionExperiment &experiment) {
|
|
PCI_EXCEPT(dev.Start();)
|
|
}
|
|
|
|
void PCIExpressDevice::HW_RunInternalGenerator(const FrameGeneratorConfig &config) {
|
|
PCI_EXCEPT(dev.RunFrameGenerator(config);)
|
|
}
|
|
|
|
void PCIExpressDevice::FPGA_EndAction() {
|
|
PCI_EXCEPT(dev.End();)
|
|
}
|
|
|
|
bool PCIExpressDevice::HW_IsIdle() const {
|
|
PCI_EXCEPT(return dev.IsIdle();)
|
|
}
|
|
|
|
void PCIExpressDevice::HW_WriteActionRegister(const DataCollectionConfig *config) {
|
|
PCI_EXCEPT(dev.SetConfig(*config);)
|
|
}
|
|
|
|
void PCIExpressDevice::HW_ReadActionRegister(DataCollectionConfig *config) {
|
|
PCI_EXCEPT(*config = dev.GetConfig();)
|
|
}
|
|
|
|
std::string PCIExpressDevice::GetMACAddress() const {
|
|
PCI_EXCEPT(return MacAddressToStr(dev.GetMACAddress());)
|
|
}
|
|
|
|
uint32_t PCIExpressDevice::GetNumKernelBuffers() const {
|
|
PCI_EXCEPT(return dev.GetBufferCount();)
|
|
}
|
|
|
|
int32_t PCIExpressDevice::GetNUMANode() const {
|
|
PCI_EXCEPT(return dev.GetNumaNode();)
|
|
}
|
|
|
|
void PCIExpressDevice::SetIPv4Address(uint32_t ipv4_addr_network_order) {
|
|
PCI_EXCEPT(
|
|
// Configure all links with the same IPv4 address
|
|
auto dev_status = dev.GetDeviceStatus();
|
|
for (int i = 0; i < dev_status.eth_link_count; i++)
|
|
dev.SetIPv4Address(ipv4_addr_network_order, i);
|
|
dev.SetIPv4Address(ipv4_addr_network_order, NET_IF_FRAME_GENERATOR);
|
|
)
|
|
}
|
|
|
|
std::string PCIExpressDevice::GetIPv4Address() const {
|
|
PCI_EXCEPT(
|
|
return IPv4AddressToStr(dev.GetIPv4Address());
|
|
)
|
|
}
|
|
|
|
void PCIExpressDevice::HW_SetSpotFinderParameters(const SpotFinderParameters ¶ms) {
|
|
PCI_EXCEPT(
|
|
dev.SetSpotFinderParameters(params);
|
|
)
|
|
}
|
|
|
|
DeviceStatus PCIExpressDevice::GetDeviceStatus() const {
|
|
PCI_EXCEPT(
|
|
return dev.GetDeviceStatus();
|
|
)
|
|
}
|
|
|
|
DataCollectionStatus PCIExpressDevice::GetDataCollectionStatus() const {
|
|
PCI_EXCEPT(
|
|
return dev.GetDataCollectionStatus();
|
|
)
|
|
}
|
|
|
|
void PCIExpressDevice::HW_LoadCalibration(const LoadCalibrationConfig &config) {
|
|
PCI_EXCEPT(dev.LoadCalibration(config);)
|
|
}
|
|
|