2 Copyright (C) 2004-2008 Grame
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU Lesser General Public License as published by
6 the Free Software Foundation; either version 2.1 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 #ifndef __JackShmMem__
21 #define __JackShmMem__
24 #include "JackError.h"
25 #include "JackCompilerDeps.h"
27 #include <new> // GCC 4.0
31 #include "JackShmMem_os.h"
36 SERVER_EXPORT
void LockMemoryImp(void* ptr
, size_t size
);
37 SERVER_EXPORT
void InitLockMemoryImp(void* ptr
, size_t size
);
38 SERVER_EXPORT
void UnlockMemoryImp(void* ptr
, size_t size
);
39 SERVER_EXPORT
void LockAllMemory();
40 SERVER_EXPORT
void UnlockAllMemory();
51 JackMem(): fSize(gSize
)
58 void* operator new(size_t size
)
61 return calloc(1, size
);
64 void operator delete(void* ptr
, size_t size
)
71 LockMemoryImp(this, fSize
);
76 UnlockMemoryImp(this, fSize
);
84 A class which objects possibly want to be allocated in shared memory derives from this class.
91 jack_shm_info_t fInfo
;
102 char* GetShmAddress()
104 return (char*)fInfo
.ptr
.attached_at
;
109 LockMemoryImp(this, fInfo
.size
);
114 UnlockMemoryImp(this, fInfo
.size
);
120 \brief The base class for shared memory management.
122 A class which objects need to be allocated in shared memory derives from this class.
125 class SERVER_EXPORT JackShmMem
: public JackShmMemAble
135 void* operator new(size_t size
);
136 void* operator new(size_t size
, void* memory
);
138 void operator delete(void* p
, size_t size
);
139 void operator delete(void* p
);
144 \brief Pointer on shared memory segment in the client side.
148 class JackShmReadWritePtr
153 jack_shm_info_t fInfo
;
155 void Init(int index
, const char* server_name
= "default")
157 if (fInfo
.index
< 0 && index
>= 0) {
158 jack_log("JackShmReadWritePtr::Init %ld %ld", index
, fInfo
.index
);
159 if (jack_initialize_shm(server_name
) < 0)
162 if (jack_attach_shm(&fInfo
)) {
165 GetShmAddress()->LockMemory();
171 JackShmReadWritePtr()
174 fInfo
.ptr
.attached_at
= (char*)NULL
;
177 JackShmReadWritePtr(int index
, const char* server_name
)
179 Init(index
, server_name
);
182 ~JackShmReadWritePtr()
184 if (fInfo
.index
>= 0) {
185 jack_log("JackShmReadWritePtr::~JackShmReadWritePtr %ld", fInfo
.index
);
186 GetShmAddress()->UnlockMemory();
187 jack_release_shm(&fInfo
);
192 T
* operator->() const
194 return (T
*)fInfo
.ptr
.attached_at
;
199 return (T
*)fInfo
.ptr
.attached_at
;
202 JackShmReadWritePtr
& operator=(int index
)
208 void SetShmIndex(int index
, const char* server_name
)
210 Init(index
, server_name
);
220 return (T
*)fInfo
.ptr
.attached_at
;
225 \brief Pointer on shared memory segment in the client side: destroy the segment (used client control)
229 class JackShmReadWritePtr1
234 jack_shm_info_t fInfo
;
236 void Init(int index
, const char* server_name
= "default")
238 if (fInfo
.index
< 0 && index
>= 0) {
239 jack_log("JackShmReadWritePtr1::Init %ld %ld", index
, fInfo
.index
);
240 if (jack_initialize_shm(server_name
) < 0)
243 if (jack_attach_shm(&fInfo
)) {
247 nobody else needs to access this shared memory any more, so
248 destroy it. because we have our own attachment to it, it won't
249 vanish till we exit (and release it).
251 jack_destroy_shm(&fInfo
);
252 GetShmAddress()->LockMemory();
258 JackShmReadWritePtr1()
261 fInfo
.ptr
.attached_at
= NULL
;
264 JackShmReadWritePtr1(int index
, const char* server_name
)
266 Init(index
, server_name
);
269 ~JackShmReadWritePtr1()
271 if (fInfo
.index
>= 0) {
272 jack_log("JackShmReadWritePtr1::~JackShmReadWritePtr1 %ld", fInfo
.index
);
273 GetShmAddress()->UnlockMemory();
274 jack_release_shm(&fInfo
);
279 T
* operator->() const
281 return (T
*)fInfo
.ptr
.attached_at
;
286 return (T
*)fInfo
.ptr
.attached_at
;
289 JackShmReadWritePtr1
& operator=(int index
)
295 void SetShmIndex(int index
, const char* server_name
)
297 Init(index
, server_name
);
307 return (T
*)fInfo
.ptr
.attached_at
;
312 \brief Pointer on shared memory segment in the client side.
321 jack_shm_info_t fInfo
;
323 void Init(int index
, const char* server_name
= "default")
325 if (fInfo
.index
< 0 && index
>= 0) {
326 jack_log("JackShmPtrRead::Init %ld %ld", index
, fInfo
.index
);
327 if (jack_initialize_shm(server_name
) < 0)
330 if (jack_attach_shm_read(&fInfo
)) {
333 GetShmAddress()->LockMemory();
342 fInfo
.ptr
.attached_at
= NULL
;
345 JackShmReadPtr(int index
, const char* server_name
)
347 Init(index
, server_name
);
352 if (fInfo
.index
>= 0) {
353 jack_log("JackShmPtrRead::~JackShmPtrRead %ld", fInfo
.index
);
354 GetShmAddress()->UnlockMemory();
355 jack_release_shm(&fInfo
);
360 T
* operator->() const
362 return (T
*)fInfo
.ptr
.attached_at
;
367 return (T
*)fInfo
.ptr
.attached_at
;
370 JackShmReadPtr
& operator=(int index
)
376 void SetShmIndex(int index
, const char* server_name
)
378 Init(index
, server_name
);
388 return (T
*)fInfo
.ptr
.attached_at
;
393 } // end of namespace