diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2003-11-19 18:50:23 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2003-11-19 18:50:23 +0000 |
commit | a6df500f7daacc08cd7c66f4212cb6ab6cbe803e (patch) | |
tree | f81a85de384145f0d97d3f717f54359b00800e3f /winsup/cygwin/cygserver_shm.h | |
parent | 282113ba894449ed17e85b296cf0760d5206ac8d (diff) | |
download | cygnal-a6df500f7daacc08cd7c66f4212cb6ab6cbe803e.tar.gz cygnal-a6df500f7daacc08cd7c66f4212cb6ab6cbe803e.tar.bz2 cygnal-a6df500f7daacc08cd7c66f4212cb6ab6cbe803e.zip |
* cygserver.h (client_request::request_code_t): Add
CYGSERVER_REQUEST_MSG and CYGSERVER_REQUEST_SEM.
(admininstrator_group_sid): Add extern declaration.
* cygserver_ipc.h: Rewrite.
* cygserver_msg.h: New file.
* cygserver_sem.h: New file.
* cygserver_shm.h: More or less rewrite.
* cygwin.din: Add msgctl, msgget, msgrcv, msgsnd, semctl, semget and
semop.
* msg.cc: Rewrite.
* safe_memory.h: Remove.
* sem.cc: Rewrite.
* shm.cc: Rewrite.
* include/cygwin/ipc.h: Use appropriate guard.
(struct ipc_perm): Add seq.
(IPCID_TO_IX): New define from BSD.
(IPCID_TO_SEQ): Ditto.
(IXSEQ_TO_IPCID): Ditto.
(IPC_R): Ditto.
(IPC_W): Ditto.
(IPC_M): Ditto.
* include/cygwin/msg.h: Use appropriate guard. #ifdef _KERNEL all stuff
not explicitely defined by SUSv3. Use signed types in structs to match
types used in BSD.
(msgqnum_t): Define unsigned.
(msglen_t): Ditto.
(struct msqid_ds): Add msg_first and msg_last.
(struct msginfo): Remove msgpool. Add msgssz and msgseg.
* include/cygwin/sem.h: Use appropriate guard. #ifdef _KERNEL all stuff
not explicitely defined by SUSv3. Use signed types in structs to match
types used in BSD.
(SEM_UNDO): Define appropriately.
(struct semid_ds): Add sem_base.
(struct seminfo): Add semmap and semusz.
(SEM_A): New define from BSD.
(SEM_R): Ditto.
(SEM_ALLOC): Ditto.
(union semun): Define.
* include/cygwin/shm.h: Use appropriate guard. #ifdef _KERNEL all stuff
not explicitely defined by SUSv3. Use signed types in structs to match
types used in BSD.
(SHMLBA): Define using cygwin_internal(CW_GET_SHMLBA) call.
(struct shmid_ds): Add shm_internal.
(struct shm_info): Rename shm_ids to used_ids as in BSD. Add define
for shm_ids.
* include/cygwin/sysproto.h: New file.
* include/cygwin/version.h: Bump API minor number.
* include/sys/ipc.h: New file.
* include/sys/msg.h: New file.
* include/sys/queue.h: New file from BSD.
* include/sys/sem.h: New file.
* include/sys/shm.h: New file.
* include/sys/sysproto.h: New file.
Diffstat (limited to 'winsup/cygwin/cygserver_shm.h')
-rw-r--r-- | winsup/cygwin/cygserver_shm.h | 135 |
1 files changed, 43 insertions, 92 deletions
diff --git a/winsup/cygwin/cygserver_shm.h b/winsup/cygwin/cygserver_shm.h index 55f3bbe36..e7d02959e 100644 --- a/winsup/cygwin/cygserver_shm.h +++ b/winsup/cygwin/cygserver_shm.h @@ -1,9 +1,6 @@ /* cygserver_shm.h: Single unix specification IPC interface for Cygwin. - Copyright 2002 Red Hat, Inc. - - Written by Conrad Scott <conrad.scott@dsl.pipex.com>. - Based on code by Robert Collins <robert.collins@hotmail.com>. + Copyright 2003 Red Hat, Inc. This file is part of Cygwin. @@ -15,38 +12,14 @@ details. */ #define __CYGSERVER_SHM_H__ #include <sys/types.h> +#include <sys/sysproto.h> +#ifndef _KERNEL +#define _KERNEL 1 +#endif #include <cygwin/shm.h> -#include <assert.h> -#include <limits.h> - -#include "cygserver_ipc.h" - #include "cygserver.h" - -/*---------------------------------------------------------------------------* - * Values for the shminfo entries. - * - * Nb. The values are segregated between two enums so that the `small' - * values aren't promoted to `unsigned long' equivalents. - *---------------------------------------------------------------------------*/ - -enum - { - SHMMAX = ULONG_MAX, - SHMSEG = ULONG_MAX, - SHMALL = ULONG_MAX - }; - -enum - { - SHMMIN = 1, - SHMMNI = IPCMNI // Must be <= IPCMNI. - }; - -/*---------------------------------------------------------------------------* - * class client_request_shm - *---------------------------------------------------------------------------*/ +#include "cygserver_ipc.h" #ifndef __INSIDE_CYGWIN__ class transport_layer_base; @@ -63,85 +36,63 @@ public: SHMOP_shmat, SHMOP_shmctl, SHMOP_shmdt, - SHMOP_shmget + SHMOP_shmget, + SHMOP_shmfork /* Called on fixup_after_fork */ }; -#ifdef __INSIDE_CYGWIN__ - client_request_shm (int shmid, int shmflg); // shmat - client_request_shm (int shmid, int cmd, const struct shmid_ds *); // shmctl - client_request_shm (int shmid); // shmdt - client_request_shm (key_t, size_t, int shmflg); // shmget -#endif - - // Accessors for out parameters. - - int shmid () const - { - assert (!error_code ()); - return _parameters.out.shmid; - } - - HANDLE hFileMap () const - { - assert (!error_code ()); - return _parameters.out.hFileMap; - } - - const struct shmid_ds & ds () const - { - assert (!error_code ()); - return _parameters.out.ds; - } - - const struct shminfo & shminfo () const - { - assert (!error_code ()); - return _parameters.out.shminfo; - } - - const struct shm_info & shm_info () const - { - assert (!error_code ()); - return _parameters.out.shm_info; - } - private: union { struct { shmop_t shmop; - key_t key; - size_t size; - int shmflg; - int shmid; - int cmd; - pid_t cygpid; - DWORD winpid; - __uid32_t uid; - __gid32_t gid; - struct shmid_ds ds; + proc ipcblk; + struct shmat_args atargs; + struct shmctl_args ctlargs; + struct shmdt_args dtargs; + struct shmget_args getargs; + struct proc forkargs; } in; struct { - int shmid; - union - { - HANDLE hFileMap; - struct shmid_ds ds; - struct shminfo shminfo; - struct shm_info shm_info; + union { + int ret; + vm_offset_t ptr; }; + vm_object_t obj; } out; } _parameters; #ifndef __INSIDE_CYGWIN__ client_request_shm (); + virtual void serve (transport_layer_base *, process_cache *); #endif -#ifndef __INSIDE_CYGWIN__ - virtual void serve (transport_layer_base *, process_cache *); +public: + +#ifdef __INSIDE_CYGWIN__ + client_request_shm (int, const void *, int); // shmat + client_request_shm (int, int, struct shmid_ds *); // shmctl + client_request_shm (const void *); // shmdt + client_request_shm (key_t, size_t, int); // shmget + client_request_shm (proc *); // shmfork #endif + + int retval (void) const { return _parameters.out.ret; } + void *ptrval (void) const { return (void *)_parameters.out.ptr; } + vm_object_t objval (void) const { return _parameters.out.obj; } }; +#ifndef __INSIDE_CYGWIN__ +void shminit (void); +int shmunload (void); +void shmexit_myhook (struct vmspace *vm); +int cygwin_shmfork_myhook (struct thread *, struct proc *); + +int shmat (struct thread *, struct shmat_args *); +int shmctl (struct thread *, struct shmctl_args *); +int shmdt (struct thread *, struct shmdt_args *); +int shmget (struct thread *, struct shmget_args *); +#endif + #endif /* __CYGSERVER_SHM_H__ */ |