| 1 | // Copyright (c) Microsoft Corporation. All rights reserved. | 
|---|
| 2 | // Licensed under the MIT license. | 
|---|
| 3 |  | 
|---|
| 4 | #include "thread.h" | 
|---|
| 5 |  | 
|---|
| 6 | namespace FASTER { | 
|---|
| 7 | namespace core { | 
|---|
| 8 |  | 
|---|
| 9 | /// The first thread will have index 0. | 
|---|
| 10 | std::atomic<uint32_t> Thread::next_index_{ 0 }; | 
|---|
| 11 |  | 
|---|
| 12 | /// No thread IDs have been used yet. | 
|---|
| 13 | std::atomic<bool> Thread::id_used_[kMaxNumThreads] = {}; | 
|---|
| 14 |  | 
|---|
| 15 | #ifdef COUNT_ACTIVE_THREADS | 
|---|
| 16 | std::atomic<int32_t> Thread::current_num_threads_ { 0 }; | 
|---|
| 17 | #endif | 
|---|
| 18 |  | 
|---|
| 19 | /// Give the new thread an ID. (In this implementation, threads get IDs when they are created, and | 
|---|
| 20 | /// release them when they are freed. We will eventually merge chkulk's improvements, from another | 
|---|
| 21 | /// branch, and then threads will get IDs on their first call to FasterKv::StartSession(), while | 
|---|
| 22 | /// still releasing IDs when they are freed.) | 
|---|
| 23 | thread_local Thread::ThreadId Thread::id_{}; | 
|---|
| 24 |  | 
|---|
| 25 | } | 
|---|
| 26 | } // namespace FASTER::core | 
|---|
| 27 |  | 
|---|