![]() |
Project
|
#include <DataProcessingDevice.h>
Inherits fair::mq::Device.
Public Member Functions | |
DataProcessingDevice (RunningDeviceRef ref, ServiceRegistry &, ProcessingPolicies &policies) | |
void | Init () final |
void | InitTask () final |
void | PreRun () final |
void | PostRun () final |
void | Reset () final |
void | ResetTask () final |
void | Run () final |
Static Public Member Functions | |
static void | doRun (ServiceRegistryRef) |
static void | doPrepare (ServiceRegistryRef) |
static void | handleData (ServiceRegistryRef, InputChannelInfo &) |
static bool | tryDispatchComputation (ServiceRegistryRef ref, std::vector< DataRelayer::RecordAction > &completed) |
Protected Member Functions | |
void | error (const char *msg) |
void | fillContext (DataProcessorContext &context, DeviceContext &deviceContext) |
A device actually carrying out all the DPL Data Processing needs.
Definition at line 77 of file DataProcessingDevice.h.
o2::framework::DataProcessingDevice::DataProcessingDevice | ( | RunningDeviceRef | ref, |
ServiceRegistry & | registry, | ||
ProcessingPolicies & | policies | ||
) |
This should post a message on the queue...
Definition at line 195 of file DataProcessingDevice.cxx.
|
static |
We drive the state loop ourself so that we will be able to support non-data triggers like those which are time based.
Sort channels by oldest possible timeframe and process them in such order.
Definition at line 1566 of file DataProcessingDevice.cxx.
|
static |
Besides flushing the queues we must make sure we do not have only timers as they do not need to be further processed.
Definition at line 1740 of file DataProcessingDevice.cxx.
Definition at line 2612 of file DataProcessingDevice.cxx.
|
protected |
Callback for the error handling FIXME: move erro handling to a service?
FIXME: we should pass the salt in, so that the message can access information which were stored in the stream.
FIXME: we should pass the salt in, so that the message can access information which were stored in the stream.
We must make sure there is no optional if we want to optimize the forwarding
Definition at line 1143 of file DataProcessingDevice.cxx.
|
static |
This is the inner loop of our framework. The actual implementation is divided in two parts. In the first one we define a set of lambdas which describe what is actually going to happen, hiding all the state boilerplate which the user does not need to care about at top level.
We have back pressure, therefore we do not process DomainInfo anymore. until the previous message are processed.
The oldest possible timeslice has changed. We can should therefore process it. Notice we do so only if the incoming data has been fully processed.
Definition at line 1878 of file DataProcessingDevice.cxx.
|
final |
This takes care of initialising the device from its specification. In particular it needs to:
Dump the configuration so that we can get it from the driver.
FIXME: we should pass the salt in, so that the message can access information which were stored in the stream.
FIXME: we should pass the salt in, so that the message can access information which were stored in the stream.
Convert a standard exception to a RuntimeErrorRef Notice how this will lose the backtrace information and report the exception coming from here.
Internal channels which will never create an actual message should be considered as in "Pull" mode, since we do not expect them to create any data.
Definition at line 418 of file DataProcessingDevice.cxx.
|
final |
Initialise the pollers
We now run an event loop also in InitTask. This is needed to:
Definition at line 1021 of file DataProcessingDevice.cxx.
|
final |
Definition at line 1305 of file DataProcessingDevice.cxx.
|
final |
Definition at line 1250 of file DataProcessingDevice.cxx.
|
final |
Definition at line 1323 of file DataProcessingDevice.cxx.
|
final |
Definition at line 1849 of file DataProcessingDevice.cxx.
|
final |
Decide which task to use
Cleanup messages which are still pending on exit.
Definition at line 1329 of file DataProcessingDevice.cxx.
|
static |
Convert a standard exception to a RuntimeErrorRef Notice how this will lose the backtrace information and report the exception coming from here.
Definition at line 2198 of file DataProcessingDevice.cxx.