xref: /aosp_15_r20/external/grpc-grpc/include/grpc/support/cpu.h (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker /*
2*cc02d7e2SAndroid Build Coastguard Worker  *
3*cc02d7e2SAndroid Build Coastguard Worker  * Copyright 2015 gRPC authors.
4*cc02d7e2SAndroid Build Coastguard Worker  *
5*cc02d7e2SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
6*cc02d7e2SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
7*cc02d7e2SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
8*cc02d7e2SAndroid Build Coastguard Worker  *
9*cc02d7e2SAndroid Build Coastguard Worker  *     http://www.apache.org/licenses/LICENSE-2.0
10*cc02d7e2SAndroid Build Coastguard Worker  *
11*cc02d7e2SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
12*cc02d7e2SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
13*cc02d7e2SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*cc02d7e2SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
15*cc02d7e2SAndroid Build Coastguard Worker  * limitations under the License.
16*cc02d7e2SAndroid Build Coastguard Worker  *
17*cc02d7e2SAndroid Build Coastguard Worker  */
18*cc02d7e2SAndroid Build Coastguard Worker 
19*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPC_SUPPORT_CPU_H
20*cc02d7e2SAndroid Build Coastguard Worker #define GRPC_SUPPORT_CPU_H
21*cc02d7e2SAndroid Build Coastguard Worker 
22*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/support/port_platform.h>
23*cc02d7e2SAndroid Build Coastguard Worker 
24*cc02d7e2SAndroid Build Coastguard Worker #ifdef __cplusplus
25*cc02d7e2SAndroid Build Coastguard Worker extern "C" {
26*cc02d7e2SAndroid Build Coastguard Worker #endif
27*cc02d7e2SAndroid Build Coastguard Worker 
28*cc02d7e2SAndroid Build Coastguard Worker /** Interface providing CPU information for currently running system */
29*cc02d7e2SAndroid Build Coastguard Worker 
30*cc02d7e2SAndroid Build Coastguard Worker /** Return the number of CPU cores on the current system. Will return 0 if
31*cc02d7e2SAndroid Build Coastguard Worker    the information is not available. */
32*cc02d7e2SAndroid Build Coastguard Worker GPRAPI unsigned gpr_cpu_num_cores(void);
33*cc02d7e2SAndroid Build Coastguard Worker 
34*cc02d7e2SAndroid Build Coastguard Worker /** Return the CPU on which the current thread is executing; N.B. This should
35*cc02d7e2SAndroid Build Coastguard Worker    be considered advisory only - it is possible that the thread is switched
36*cc02d7e2SAndroid Build Coastguard Worker    to a different CPU at any time. Returns a value in range
37*cc02d7e2SAndroid Build Coastguard Worker    [0, gpr_cpu_num_cores() - 1] */
38*cc02d7e2SAndroid Build Coastguard Worker GPRAPI unsigned gpr_cpu_current_cpu(void);
39*cc02d7e2SAndroid Build Coastguard Worker 
40*cc02d7e2SAndroid Build Coastguard Worker #ifdef __cplusplus
41*cc02d7e2SAndroid Build Coastguard Worker }  // extern "C"
42*cc02d7e2SAndroid Build Coastguard Worker #endif
43*cc02d7e2SAndroid Build Coastguard Worker 
44*cc02d7e2SAndroid Build Coastguard Worker #endif /* GRPC_SUPPORT_CPU_H */
45