Seastar
High performance C++ framework for concurrent servers
shard_id.hh
Go to the documentation of this file.
1 /*
2  * This file is open source software, licensed to you under the terms
3  * of the Apache License, Version 2.0 (the "License"). See the NOTICE file
4  * distributed with this work for additional information regarding copyright
5  * ownership. You may not use this file except in compliance with the License.
6  *
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing,
12  * software distributed under the License is distributed on an
13  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14  * KIND, either express or implied. See the License for the
15  * specific language governing permissions and limitations
16  * under the License.
17  */
18 /*
19  * Copyright 2023-present ScyllaDB
20  */
21 
22 #pragma once
23 
25 
26 namespace seastar {
27 
28 SEASTAR_MODULE_EXPORT_BEGIN
29 
30 using shard_id = unsigned;
31 
32 SEASTAR_MODULE_EXPORT_END
33 
34 namespace internal {
35 
36 #ifdef SEASTAR_BUILD_SHARED_LIBS
37 shard_id* this_shard_id_ptr() noexcept;
38 #else
39 inline shard_id* this_shard_id_ptr() noexcept {
40  static thread_local shard_id g_this_shard_id;
41  return &g_this_shard_id;
42 }
43 #endif
44 
45 } // namespace internal
46 
47 SEASTAR_MODULE_EXPORT_BEGIN
48 
50 inline shard_id this_shard_id() noexcept {
51  return *internal::this_shard_id_ptr();
52 }
53 
54 SEASTAR_MODULE_EXPORT_END
55 
56 
57 } // namespace seastar
Seastar API namespace.
Definition: abort_on_ebadf.hh:26
SEASTAR_MODULE_EXPORT_BEGIN shard_id this_shard_id() noexcept
Returns shard_id of the of the current shard.
Definition: shard_id.hh:50