summaryrefslogtreecommitdiff
path: root/include/shm.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/shm.h')
-rw-r--r--include/shm.h85
1 files changed, 43 insertions, 42 deletions
diff --git a/include/shm.h b/include/shm.h
index 8103ce9..950e735 100644
--- a/include/shm.h
+++ b/include/shm.h
@@ -5,12 +5,12 @@
#include <sys/types.h>
#include <jack/types.h>
-#define MAX_SERVERS 8 /* maximum concurrent servers */
-#define MAX_SHM_ID 256 /* generally about 16 per server */
-#define JACK_SERVER_NAME_SIZE 256 /* maximum length of server name */
-#define JACK_SHM_MAGIC 0x4a41434b /* shm magic number: "JACK" */
-#define JACK_SHM_NULL_INDEX -1 /* NULL SHM index */
-#define JACK_SHM_REGISTRY_INDEX -2 /* pseudo SHM index for registry */
+#define MAX_SERVERS 8 /* maximum concurrent servers */
+#define MAX_SHM_ID 256 /* generally about 16 per server */
+#define JACK_SERVER_NAME_SIZE 256 /* maximum length of server name */
+#define JACK_SHM_MAGIC 0x4a41434b /* shm magic number: "JACK" */
+#define JACK_SHM_NULL_INDEX -1 /* NULL SHM index */
+#define JACK_SHM_REGISTRY_INDEX -2 /* pseudo SHM index for registry */
/* On Mac OS X, SHM_NAME_MAX is the maximum length of a shared memory
@@ -21,21 +21,21 @@
#ifndef SHM_NAME_MAX
#define SHM_NAME_MAX NAME_MAX
#endif
-typedef char shm_name_t[SHM_NAME_MAX];
+typedef char shm_name_t[SHM_NAME_MAX];
typedef shm_name_t jack_shm_id_t;
#else /* System V SHM */
-typedef int jack_shm_id_t;
+typedef int jack_shm_id_t;
#endif /* SHM type */
/* shared memory type */
typedef enum {
- shm_POSIX = 1, /* POSIX shared memory */
- shm_SYSV = 2 /* System V shared memory */
+ shm_POSIX = 1, /* POSIX shared memory */
+ shm_SYSV = 2 /* System V shared memory */
} jack_shmtype_t;
typedef int16_t jack_shm_registry_index_t;
-/**
+/**
* A structure holding information about shared memory allocated by
* JACK. this persists across invocations of JACK, and can be used by
* multiple JACK servers. It contains no pointers and is valid across
@@ -45,31 +45,31 @@ typedef int16_t jack_shm_registry_index_t;
* server names, followed by an array of segment registry entries.
*/
typedef struct _jack_shm_server {
- pid_t pid; /* process ID */
- char name[JACK_SERVER_NAME_SIZE];
+ pid_t pid; /* process ID */
+ char name[JACK_SERVER_NAME_SIZE];
} jack_shm_server_t;
typedef struct _jack_shm_header {
- uint32_t magic; /* magic number */
- uint16_t protocol; /* JACK protocol version */
- jack_shmtype_t type; /* shm type */
- jack_shmsize_t size; /* total registry segment size */
- jack_shmsize_t hdr_len; /* size of header */
- jack_shmsize_t entry_len; /* size of registry entry */
- jack_shm_server_t server[MAX_SERVERS]; /* current server array */
+ uint32_t magic; /* magic number */
+ uint16_t protocol; /* JACK protocol version */
+ jack_shmtype_t type; /* shm type */
+ jack_shmsize_t size; /* total registry segment size */
+ jack_shmsize_t hdr_len; /* size of header */
+ jack_shmsize_t entry_len; /* size of registry entry */
+ jack_shm_server_t server[MAX_SERVERS]; /* current server array */
} jack_shm_header_t;
typedef struct _jack_shm_registry {
- jack_shm_registry_index_t index; /* offset into the registry */
- pid_t allocator; /* PID that created shm segment */
- jack_shmsize_t size; /* for POSIX unattach */
- jack_shm_id_t id; /* API specific, see above */
+ jack_shm_registry_index_t index; /* offset into the registry */
+ pid_t allocator; /* PID that created shm segment */
+ jack_shmsize_t size; /* for POSIX unattach */
+ jack_shm_id_t id; /* API specific, see above */
} jack_shm_registry_t;
-#define JACK_SHM_REGISTRY_SIZE (sizeof (jack_shm_header_t) \
- + sizeof (jack_shm_registry_t) * MAX_SHM_ID)
+#define JACK_SHM_REGISTRY_SIZE (sizeof(jack_shm_header_t) \
+ + sizeof(jack_shm_registry_t) * MAX_SHM_ID)
-/**
+/**
* a structure holding information about shared memory
* allocated by JACK. this version is valid only
* for a given address space. It contains a pointer
@@ -77,34 +77,35 @@ typedef struct _jack_shm_registry {
* attached to the address space.
*/
typedef struct _jack_shm_info {
- jack_shm_registry_index_t index; /* offset into the registry */
- void *attached_at; /* address where attached */
+ jack_shm_registry_index_t index; /* offset into the registry */
+ void *attached_at; /* address where attached */
} jack_shm_info_t;
/* utility functions used only within JACK */
-extern void jack_shm_copy_from_registry (jack_shm_info_t*,
+extern void jack_shm_copy_from_registry (jack_shm_info_t *,
jack_shm_registry_index_t);
-extern void jack_shm_copy_to_registry (jack_shm_info_t*,
- jack_shm_registry_index_t*);
+extern void jack_shm_copy_to_registry(jack_shm_info_t*,
+ jack_shm_registry_index_t*);
extern void jack_release_shm_info (jack_shm_registry_index_t);
-static inline char* jack_shm_addr (jack_shm_info_t* si) {
+static inline char* jack_shm_addr (jack_shm_info_t* si)
+{
return si->attached_at;
}
/* here beginneth the API */
-extern int jack_register_server (const char *server_name, int new_registry);
-extern void jack_unregister_server (const char *server_name);
+extern int jack_register_server(const char *server_name, int new_registry);
+extern void jack_unregister_server(const char *server_name);
-extern int jack_initialize_shm (const char *server_name);
-extern int jack_cleanup_shm (void);
+extern int jack_initialize_shm(const char *server_name);
+extern int jack_cleanup_shm(void);
-extern int jack_shmalloc (jack_shmsize_t size, jack_shm_info_t* result);
-extern void jack_release_shm (jack_shm_info_t*);
-extern void jack_destroy_shm (jack_shm_info_t*);
-extern int jack_attach_shm (jack_shm_info_t*);
-extern int jack_resize_shm (jack_shm_info_t*, jack_shmsize_t size);
+extern int jack_shmalloc(jack_shmsize_t size, jack_shm_info_t* result);
+extern void jack_release_shm(jack_shm_info_t*);
+extern void jack_destroy_shm(jack_shm_info_t*);
+extern int jack_attach_shm(jack_shm_info_t*);
+extern int jack_resize_shm(jack_shm_info_t*, jack_shmsize_t size);
#endif /* __jack_shm_h__ */