| // workqueue-internal.h -- internal work queue header for gold -*- C++ -*- |
| |
| // Copyright (C) 2006-2022 Free Software Foundation, Inc. |
| // Written by Ian Lance Taylor <iant@google.com>. |
| |
| // This file is part of gold. |
| |
| // This program is free software; you can redistribute it and/or modify |
| // it under the terms of the GNU General Public License as published by |
| // the Free Software Foundation; either version 3 of the License, or |
| // (at your option) any later version. |
| |
| // This program is distributed in the hope that it will be useful, |
| // but WITHOUT ANY WARRANTY; without even the implied warranty of |
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| // GNU General Public License for more details. |
| |
| // You should have received a copy of the GNU General Public License |
| // along with this program; if not, write to the Free Software |
| // Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, |
| // MA 02110-1301, USA. |
| |
| #ifndef GOLD_WORKQUEUE_INTERNAL_H |
| #define GOLD_WORKQUEUE_INTERNAL_H |
| |
| #include <queue> |
| #include <csignal> |
| |
| #include "gold-threads.h" |
| #include "workqueue.h" |
| |
| // This is an internal header file for different gold workqueue |
| // implementations. |
| |
| namespace gold |
| { |
| |
| class Workqueue_thread; |
| |
| // The Workqueue_threader abstract class. This is the interface used |
| // by the general workqueue code to manage threads. |
| |
| class Workqueue_threader |
| { |
| public: |
| Workqueue_threader(Workqueue* workqueue) |
| : workqueue_(workqueue) |
| { } |
| virtual ~Workqueue_threader() |
| { } |
| |
| // Set the number of threads to use. This is ignored when not using |
| // threads. |
| virtual void |
| set_thread_count(int) = 0; |
| |
| // Return whether to cancel the current thread. |
| virtual bool |
| should_cancel_thread(int thread_number) = 0; |
| |
| protected: |
| // Get the Workqueue. |
| Workqueue* |
| get_workqueue() |
| { return this->workqueue_; } |
| |
| private: |
| // The Workqueue. |
| Workqueue* workqueue_; |
| }; |
| |
| // The threaded instantiation of Workqueue_threader. |
| |
| class Workqueue_threader_threadpool : public Workqueue_threader |
| { |
| public: |
| Workqueue_threader_threadpool(Workqueue*); |
| |
| ~Workqueue_threader_threadpool(); |
| |
| // Set the thread count. |
| void |
| set_thread_count(int); |
| |
| // Return whether to cancel a thread. |
| bool |
| should_cancel_thread(int thread_number); |
| |
| // Process all tasks. This keeps running until told to cancel. |
| void |
| process(int thread_number) |
| { this->get_workqueue()->process(thread_number); } |
| |
| private: |
| // This is set if we need to check the thread count. |
| volatile sig_atomic_t check_thread_count_; |
| |
| // Lock for the remaining members. |
| Lock lock_; |
| // The number of threads we want to create. This is set to zero |
| // when all threads should exit. |
| int desired_thread_count_; |
| // The number of threads currently running. |
| int threads_; |
| }; |
| |
| } // End namespace gold. |
| |
| #endif // !defined(GOLD_WORKQUEUE_INTERNAL_H) |