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