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