libfoedus-core
FOEDUS Core Library
thread_options.hpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014-2015, Hewlett-Packard Development Company, LP.
3  * This program is free software; you can redistribute it and/or modify it
4  * under the terms of the GNU General Public License as published by the Free
5  * Software Foundation; either version 2 of the License, or (at your option)
6  * any later version.
7  *
8  * This program is distributed in the hope that it will be useful, but WITHOUT
9  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
11  * more details. You should have received a copy of the GNU General Public
12  * License along with this program; if not, write to the Free Software
13  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
14  *
15  * HP designates this particular file as subject to the "Classpath" exception
16  * as provided by HP in the LICENSE.txt file that accompanied this code.
17  */
18 #ifndef FOEDUS_THREAD_THREAD_OPTIONS_HPP_
19 #define FOEDUS_THREAD_THREAD_OPTIONS_HPP_
20 #include "foedus/cxx11.hpp"
23 namespace foedus {
24 namespace thread {
35  ThreadOptions();
36 
43  uint16_t group_count_;
44 
51 
54 
59 
60  EXTERNALIZABLE(ThreadOptions);
61 
63  return group_count_ * thread_count_per_group_;
64  }
65 };
66 } // namespace thread
67 } // namespace foedus
68 #endif // FOEDUS_THREAD_THREAD_OPTIONS_HPP_
Set of options about threads and thread-groups.
uint8_t ThreadLocalOrdinal
Typedef for a local ID of Thread (core), which is NOT unique across NUMA nodes.
Definition: thread_id.hpp:58
ThreadPolicy
Thread policy for worker threads.
Definition: thread_id.hpp:166
ThreadOptions()
Constructs option values with default values.
Represents an object that can be written to and read from files/bytes in XML format.
Root package of FOEDUS (Fast Optimistic Engine for Data Unification Services).
Definition: assert_nd.hpp:44
Typedefs of ID types used in thread package.
ThreadPriority
Thread priority for worker threads.
Definition: thread_id.hpp:186
#define EXTERNALIZABLE(clazz)
Macro to declare/define essential methods for an externalizable class.
ThreadLocalOrdinal thread_count_per_group_
Number of Thread in each ThreadGroup.
bool overwrite_thread_schedule_
Whether to overwrite policy/priority of worker threads.
#define CXX11_FINAL
Used in public headers in place of "final" of C++11.
Definition: cxx11.hpp:131
ThreadPriority thread_priority_
Thread priority for worker threads.
uint16_t group_count_
Number of ThreadGroup in the engine.
uint16_t ThreadId
Typedef for a global ID of Thread (core), which is unique across NUMA nodes.
Definition: thread_id.hpp:80
ThreadId get_total_thread_count() const
ThreadPolicy thread_policy_
Thread policy for worker threads.