xref: /aosp_15_r20/external/deqp/framework/delibs/deutil/deDynamicLibrary.h (revision 35238bce31c2a825756842865a792f8cf7f89930)
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