00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #ifndef Fennel_DeviceAccessSchedulerParams_Included
00025 #define Fennel_DeviceAccessSchedulerParams_Included
00026
00027 FENNEL_BEGIN_NAMESPACE
00028
00029 class ConfigMap;
00030
00035 class FENNEL_DEVICE_EXPORT DeviceAccessSchedulerParams
00036 {
00037 public:
00038 static ParamName paramSchedulerType;
00039 static ParamName paramThreadCount;
00040 static ParamName paramMaxRequests;
00041
00042 static ParamVal valThreadPoolScheduler;
00043 static ParamVal valIoCompletionPortScheduler;
00044 static ParamVal valAioPollingScheduler;
00045 static ParamVal valAioSignalScheduler;
00046 static ParamVal valAioLinuxScheduler;
00047
00051 enum SchedulerType {
00052 THREAD_POOL_SCHEDULER,
00053 IO_COMPLETION_PORT_SCHEDULER,
00054 AIO_POLLING_SCHEDULER,
00055 AIO_SIGNAL_SCHEDULER,
00056 AIO_LINUX_SCHEDULER
00057 };
00058
00062 SchedulerType schedulerType;
00063
00068 bool usingDefaultSchedulerType;
00069
00075 uint nThreads;
00076
00081 uint maxRequests;
00082
00086 DeviceAccessSchedulerParams();
00087
00091 void readConfig(ConfigMap const &configMap);
00092 };
00093
00094 FENNEL_END_NAMESPACE
00095
00096 #endif
00097
00098