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_ */