1*35238bceSAndroid Build Coastguard Worker #ifndef _DEDYNAMICLIBRARY_H 2*35238bceSAndroid Build Coastguard Worker #define _DEDYNAMICLIBRARY_H 3*35238bceSAndroid Build Coastguard Worker /*------------------------------------------------------------------------- 4*35238bceSAndroid Build Coastguard Worker * drawElements Utility 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 Dynamic link library abstraction. 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 DE_BEGIN_EXTERN_C 29*35238bceSAndroid Build Coastguard Worker 30*35238bceSAndroid Build Coastguard Worker /* Dynamic link library. */ 31*35238bceSAndroid Build Coastguard Worker typedef struct deDynamicLibrary_s deDynamicLibrary; 32*35238bceSAndroid Build Coastguard Worker 33*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*! 34*35238bceSAndroid Build Coastguard Worker * \brief Open dynamic library. 35*35238bceSAndroid Build Coastguard Worker * \param fileName Name or path to dynamic library. 36*35238bceSAndroid Build Coastguard Worker * \return Dynamic library handle, or DE_NULL on failure. 37*35238bceSAndroid Build Coastguard Worker * 38*35238bceSAndroid Build Coastguard Worker * This function opens and loads dynamic library to current process. 39*35238bceSAndroid Build Coastguard Worker * If library is already loaded, its reference count will be increased. 40*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/ 41*35238bceSAndroid Build Coastguard Worker deDynamicLibrary *deDynamicLibrary_open(const char *fileName); 42*35238bceSAndroid Build Coastguard Worker 43*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*! 44*35238bceSAndroid Build Coastguard Worker * \brief Load function symbol from dynamic library. 45*35238bceSAndroid Build Coastguard Worker * \param library Dynamic library 46*35238bceSAndroid Build Coastguard Worker * \param symbolName Name of function symbol 47*35238bceSAndroid Build Coastguard Worker * \return Function pointer or DE_NULL on failure 48*35238bceSAndroid Build Coastguard Worker * \note Returned pointers will be invalidated if dynamic library is 49*35238bceSAndroid Build Coastguard Worker * unloaded. 50*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/ 51*35238bceSAndroid Build Coastguard Worker deFunctionPtr deDynamicLibrary_getFunction(const deDynamicLibrary *library, const char *symbolName); 52*35238bceSAndroid Build Coastguard Worker 53*35238bceSAndroid Build Coastguard Worker /*--------------------------------------------------------------------*//*! 54*35238bceSAndroid Build Coastguard Worker * \brief Close dynamic library. 55*35238bceSAndroid Build Coastguard Worker * \param library Dynamic library 56*35238bceSAndroid Build Coastguard Worker * 57*35238bceSAndroid Build Coastguard Worker * Closing library handle decrements reference count. Library is unloaded 58*35238bceSAndroid Build Coastguard Worker * from process if reference count reaches zero. 59*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/ 60*35238bceSAndroid Build Coastguard Worker void deDynamicLibrary_close(deDynamicLibrary *library); 61*35238bceSAndroid Build Coastguard Worker 62*35238bceSAndroid Build Coastguard Worker DE_END_EXTERN_C 63*35238bceSAndroid Build Coastguard Worker 64*35238bceSAndroid Build Coastguard Worker #endif /* _DEDYNAMICLIBRARY_H */ 65