Coverage Report

Created: 2026-04-01 07:08

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/ntopng/include/ThreadPool.h
Line
Count
Source
1
/*
2
 *
3
 * (C) 2017-26 - ntop.org
4
 *
5
 *
6
 * This program is free software; you can redistribute it and/or modify
7
 * it under the terms of the GNU General Public License as published by
8
 * the Free Software Foundation; either version 3 of the License, or
9
 * (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software Foundation,
18
 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19
 *
20
 */
21
22
#ifndef _THREAD_POOL_H_
23
#define _THREAD_POOL_H_
24
25
#include "ntop_includes.h"
26
27
class ThreadPool {
28
 private:
29
  u_int16_t num_threads;
30
  bool terminating;
31
  pthread_cond_t condvar;
32
  Mutex* m;
33
#ifdef __linux__
34
  cpu_set_t affinity_mask;
35
#endif
36
37
  std::vector<pthread_t> threadsState;
38
  std::queue<QueuedThreadData*> threads;
39
40
  QueuedThreadData* dequeueJob(bool waitIfEmpty);
41
42
  /* Creates and starts a new pool thread */
43
  bool spawn();
44
  bool isQueueable(ThreadedActivityState cur_state);
45
46
 public:
47
  ThreadPool(char* comma_separated_affinity_mask = NULL);
48
  virtual ~ThreadPool();
49
50
  void shutdown();
51
0
  inline bool isTerminating() { return terminating; };
52
53
  void run();
54
  bool queueJob(ThreadedActivity* ta, char* path, NetworkInterface* iface,
55
                time_t scheduled_time, time_t deadline, PeriodicActivities* pa,
56
                bool hourly_daily_activity);
57
};
58
59
#endif /* _THREAD_POOL_H_ */