EM-ODP  3.7.0
Event Machine on ODP
env_sharedmem.h
1 /*
2  * Copyright (c) 2013-2019, Nokia Solutions and Networks
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in the
13  * documentation and/or other materials provided with the distribution.
14  * * Neither the name of the copyright holder nor the names of its
15  * contributors may be used to endorse or promote products derived
16  * from this software without specific prior written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30 
31 /*
32  * env helper include file - don't include this file directly,
33  * instead #include <environment.h>
34  */
35 
36 #ifndef _ENV_SHAREDMEM_H_
37 #define _ENV_SHAREDMEM_H_
38 
39 #pragma GCC visibility push(default)
40 
41 /**
42  * Shared memory allocation routines
43  */
44 
45 #define ENV_SHARED_NAMESIZE 32
46 
47 /**
48  * Reserve memory that can be shared by multiple processes.
49  *
50  * @param name Name of the shared memory block
51  * @param size Size requested by the user, actual size might be larger
52  *
53  * @note Not for use in the fast path, func call overhead might be too much.
54  * Buffers allocated at setup can be used in fast path processing though.
55  */
56 void *env_shared_reserve(const char *name, size_t size);
57 
58 /**
59  * Lookup shared memory previously reserved by env_shared_reserve().
60  *
61  * @param name Name of the shared memory block to look for
62  *
63  * @note Not for use in the fast path, func call overhead might be too much.
64  * Buffers allocated at setup can be used in fast path processing though.
65  *
66  * @see env_shared_reserve()
67  */
68 void *env_shared_lookup(const char *name);
69 
70 /**
71  * Allocate shared memory.
72  *
73  * @note Not for use in the fast path, func call overhead might be too much.
74  * Buffers allocated at setup can be used in fast path processing though.
75  */
76 void *env_shared_malloc(size_t size);
77 
78 /**
79  * Frees memory previously allocated by env_shared_reserve() or
80  * env_shared_malloc()
81  *
82  * @note Not for use in the fast path, func call overhead might be too much.
83  */
84 void env_shared_free(void *buf);
85 
86 #pragma GCC visibility pop
87 #endif /* _ENV_SHAREDMEM_H_ */