xref: /aosp_15_r20/frameworks/wilhelm/src/trace.h (revision bebae9c0e76121f8312ccb50385c080b3a0b023c)
1*bebae9c0SAndroid Build Coastguard Worker /*
2*bebae9c0SAndroid Build Coastguard Worker  * Copyright (C) 2010 The Android Open Source Project
3*bebae9c0SAndroid Build Coastguard Worker  *
4*bebae9c0SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*bebae9c0SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*bebae9c0SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*bebae9c0SAndroid Build Coastguard Worker  *
8*bebae9c0SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*bebae9c0SAndroid Build Coastguard Worker  *
10*bebae9c0SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*bebae9c0SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*bebae9c0SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*bebae9c0SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*bebae9c0SAndroid Build Coastguard Worker  * limitations under the License.
15*bebae9c0SAndroid Build Coastguard Worker  */
16*bebae9c0SAndroid Build Coastguard Worker 
17*bebae9c0SAndroid Build Coastguard Worker // Trace debugging
18*bebae9c0SAndroid Build Coastguard Worker 
19*bebae9c0SAndroid Build Coastguard Worker // Always defined, but may be a no-op if trace support is disabled at compile-time
20*bebae9c0SAndroid Build Coastguard Worker extern void slTraceSetEnabled(unsigned enabled);
21*bebae9c0SAndroid Build Coastguard Worker 
22*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_ENTER          0x1
23*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_LEAVE_FAILURE  0x2
24*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_LEAVE_VOID     0x4
25*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_LEAVE_SUCCESS  0x8
26*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_LEAVE          (SL_TRACE_LEAVE_FAILURE | SL_TRACE_LEAVE_VOID | \
27*bebae9c0SAndroid Build Coastguard Worker                                     SL_TRACE_LEAVE_SUCCESS)
28*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_ALL            (SL_TRACE_ENTER | SL_TRACE_LEAVE)
29*bebae9c0SAndroid Build Coastguard Worker #ifndef SL_TRACE_DEFAULT
30*bebae9c0SAndroid Build Coastguard Worker #define SL_TRACE_DEFAULT        (SL_TRACE_LEAVE_FAILURE)
31*bebae9c0SAndroid Build Coastguard Worker #endif
32*bebae9c0SAndroid Build Coastguard Worker 
33*bebae9c0SAndroid Build Coastguard Worker #ifndef USE_TRACE
34*bebae9c0SAndroid Build Coastguard Worker 
35*bebae9c0SAndroid Build Coastguard Worker #define SL_ENTER_GLOBAL SLresult result;
36*bebae9c0SAndroid Build Coastguard Worker #define SL_LEAVE_GLOBAL return result;
37*bebae9c0SAndroid Build Coastguard Worker #define SL_ENTER_INTERFACE SLresult result;
38*bebae9c0SAndroid Build Coastguard Worker #define SL_LEAVE_INTERFACE return result;
39*bebae9c0SAndroid Build Coastguard Worker #define SL_ENTER_INTERFACE_VOID
40*bebae9c0SAndroid Build Coastguard Worker #define SL_LEAVE_INTERFACE_VOID return;
41*bebae9c0SAndroid Build Coastguard Worker 
42*bebae9c0SAndroid Build Coastguard Worker #define XA_ENTER_GLOBAL XAresult result;
43*bebae9c0SAndroid Build Coastguard Worker #define XA_LEAVE_GLOBAL return result;
44*bebae9c0SAndroid Build Coastguard Worker #define XA_ENTER_INTERFACE XAresult result;
45*bebae9c0SAndroid Build Coastguard Worker #define XA_LEAVE_INTERFACE return result;
46*bebae9c0SAndroid Build Coastguard Worker 
47*bebae9c0SAndroid Build Coastguard Worker #else
48*bebae9c0SAndroid Build Coastguard Worker 
49*bebae9c0SAndroid Build Coastguard Worker extern void slTraceEnterGlobal(const char *function);
50*bebae9c0SAndroid Build Coastguard Worker extern void slTraceLeaveGlobal(const char *function, SLresult result);
51*bebae9c0SAndroid Build Coastguard Worker extern void slTraceEnterInterface(const char *function);
52*bebae9c0SAndroid Build Coastguard Worker extern void slTraceLeaveInterface(const char *function, SLresult result);
53*bebae9c0SAndroid Build Coastguard Worker extern void slTraceEnterInterfaceVoid(const char *function);
54*bebae9c0SAndroid Build Coastguard Worker extern void slTraceLeaveInterfaceVoid(const char *function);
55*bebae9c0SAndroid Build Coastguard Worker #define SL_ENTER_GLOBAL SLresult result; slTraceEnterGlobal(__FUNCTION__);
56*bebae9c0SAndroid Build Coastguard Worker #define SL_LEAVE_GLOBAL slTraceLeaveGlobal(__FUNCTION__, result); return result;
57*bebae9c0SAndroid Build Coastguard Worker #define SL_ENTER_INTERFACE SLresult result; slTraceEnterInterface(__FUNCTION__);
58*bebae9c0SAndroid Build Coastguard Worker #define SL_LEAVE_INTERFACE slTraceLeaveInterface(__FUNCTION__, result); return result;
59*bebae9c0SAndroid Build Coastguard Worker #define SL_ENTER_INTERFACE_VOID slTraceEnterInterfaceVoid(__FUNCTION__);
60*bebae9c0SAndroid Build Coastguard Worker #define SL_LEAVE_INTERFACE_VOID slTraceLeaveInterfaceVoid(__FUNCTION__); return;
61*bebae9c0SAndroid Build Coastguard Worker 
62*bebae9c0SAndroid Build Coastguard Worker #define XA_ENTER_GLOBAL XAresult result; slTraceEnterGlobal(__FUNCTION__);
63*bebae9c0SAndroid Build Coastguard Worker #define XA_LEAVE_GLOBAL slTraceLeaveGlobal(__FUNCTION__, result); return result;
64*bebae9c0SAndroid Build Coastguard Worker #define XA_ENTER_INTERFACE XAresult result; slTraceEnterInterface(__FUNCTION__);
65*bebae9c0SAndroid Build Coastguard Worker #define XA_LEAVE_INTERFACE slTraceLeaveInterface(__FUNCTION__, result); return result;
66*bebae9c0SAndroid Build Coastguard Worker 
67*bebae9c0SAndroid Build Coastguard Worker #endif
68