1*35238bceSAndroid Build Coastguard Worker #ifndef _DESINGLETON_H 2*35238bceSAndroid Build Coastguard Worker #define _DESINGLETON_H 3*35238bceSAndroid Build Coastguard Worker /*------------------------------------------------------------------------- 4*35238bceSAndroid Build Coastguard Worker * drawElements Thread Library 5*35238bceSAndroid Build Coastguard Worker * --------------------------- 6*35238bceSAndroid Build Coastguard Worker * 7*35238bceSAndroid Build Coastguard Worker * Copyright 2014 The Android Open Source Project 8*35238bceSAndroid Build Coastguard Worker * 9*35238bceSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 10*35238bceSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 11*35238bceSAndroid Build Coastguard Worker * You may obtain a copy of the License at 12*35238bceSAndroid Build Coastguard Worker * 13*35238bceSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 14*35238bceSAndroid Build Coastguard Worker * 15*35238bceSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 16*35238bceSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 17*35238bceSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 18*35238bceSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 19*35238bceSAndroid Build Coastguard Worker * limitations under the License. 20*35238bceSAndroid Build Coastguard Worker * 21*35238bceSAndroid Build Coastguard Worker *//*! 22*35238bceSAndroid Build Coastguard Worker * \file 23*35238bceSAndroid Build Coastguard Worker * \brief Thread-safe singleton. 24*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/ 25*35238bceSAndroid Build Coastguard Worker 26*35238bceSAndroid Build Coastguard Worker #include "deDefs.h" 27*35238bceSAndroid Build Coastguard Worker 28*35238bceSAndroid Build Coastguard Worker typedef enum deSingletonState_e 29*35238bceSAndroid Build Coastguard Worker { 30*35238bceSAndroid Build Coastguard Worker DE_SINGLETON_STATE_NOT_INITIALIZED = 0, 31*35238bceSAndroid Build Coastguard Worker DE_SINGLETON_STATE_INITIALIZING, 32*35238bceSAndroid Build Coastguard Worker DE_SINGLETON_STATE_INITIALIZED, 33*35238bceSAndroid Build Coastguard Worker 34*35238bceSAndroid Build Coastguard Worker DE_SINGLETON_STATE_LAST 35*35238bceSAndroid Build Coastguard Worker } deSingletonState; 36*35238bceSAndroid Build Coastguard Worker 37*35238bceSAndroid Build Coastguard Worker DE_BEGIN_EXTERN_C 38*35238bceSAndroid Build Coastguard Worker 39*35238bceSAndroid Build Coastguard Worker typedef void (*deSingletonConstructorFunc)(void *arg); 40*35238bceSAndroid Build Coastguard Worker 41*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*! 42*35238bceSAndroid Build Coastguard Worker * \brief Initialize singleton. 43*35238bceSAndroid Build Coastguard Worker * 44*35238bceSAndroid Build Coastguard Worker * This function ensures that singletonState = DE_SINGLETON_STATE_INITIALIZED 45*35238bceSAndroid Build Coastguard Worker * upon return. 46*35238bceSAndroid Build Coastguard Worker * 47*35238bceSAndroid Build Coastguard Worker * If current singleton state is DE_SINGLETON_NOT_INITIALIZED, constructor 48*35238bceSAndroid Build Coastguard Worker * function is called with the supplied argument (arg). 49*35238bceSAndroid Build Coastguard Worker * 50*35238bceSAndroid Build Coastguard Worker * It is guaranteed that constructor is called only once, even when multiple 51*35238bceSAndroid Build Coastguard Worker * concurrent calls are made to deInitSingleton(). 52*35238bceSAndroid Build Coastguard Worker * 53*35238bceSAndroid Build Coastguard Worker * Note that singletonState memory location must be initialized to 54*35238bceSAndroid Build Coastguard Worker * DE_SINGLETON_STATE_NOT_INITIALIZED prior to any calls to deInitSingleton(). 55*35238bceSAndroid Build Coastguard Worker * 56*35238bceSAndroid Build Coastguard Worker * \param singletonState Pointer to singleton state. 57*35238bceSAndroid Build Coastguard Worker * \param constructor Constructor function. 58*35238bceSAndroid Build Coastguard Worker * \param arg Generic arg pointer for constructor. 59*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/ 60*35238bceSAndroid Build Coastguard Worker void deInitSingleton(volatile deSingletonState *singletonState, deSingletonConstructorFunc constructor, void *arg); 61*35238bceSAndroid Build Coastguard Worker 62*35238bceSAndroid Build Coastguard Worker void deSingleton_selfTest(void); 63*35238bceSAndroid Build Coastguard Worker 64*35238bceSAndroid Build Coastguard Worker DE_END_EXTERN_C 65*35238bceSAndroid Build Coastguard Worker 66*35238bceSAndroid Build Coastguard Worker #endif /* _DESINGLETON_H */ 67