/* $NetBSD: linux_shm.h,v 1.12 2008/04/28 20:23:44 martin Exp $ */ /*- * Copyright (c) 1995, 1998 The NetBSD Foundation, Inc. * All rights reserved. * * This code is derived from software contributed to The NetBSD Foundation * by Frank van der Linden and Eric Haszlakiewicz. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #ifndef _LINUX_SHM_H #define _LINUX_SHM_H #include /* * shm segment control structure */ struct linux_shmid_ds { struct linux_ipc_perm l_shm_perm; int l_shm_segsz; linux_time_t l_shm_atime; linux_time_t l_shm_dtime; linux_time_t l_shm_ctime; ushort l_shm_cpid; ushort l_shm_lpid; short l_shm_nattch; ushort l_private1; void *l_private2; void *l_private3; }; struct linux_shmid64_ds { struct linux_ipc64_perm l_shm_perm; size_t l_shm_segsz; linux_time_t l_shm_atime; #ifndef _LP64 u_long l____unused1; #endif linux_time_t l_shm_dtime; #ifndef _LP64 u_long l____unused2; #endif linux_time_t l_shm_ctime; #ifndef _LP64 u_long l____unused3; #endif int l_shm_cpid; int l_shm_lpid; u_long l_shm_nattch; u_long l___unused4; u_long l___unused5; }; struct linux_shminfo64 { u_long l_shmmax; u_long l_shmmin; u_long l_shmmni; u_long l_shmseg; u_long l_shmall; u_long l___unused1; u_long l___unused2; u_long l___unused3; u_long l___unused4; }; struct linux_shm_info { int l_used_ids; u_long l_shm_tot; u_long l_shm_rss; u_long l_shm_swp; u_long l_swap_attempts; u_long l_swap_successes; }; #define LINUX_SHM_RDONLY 0x1000 #define LINUX_SHM_RND 0x2000 #define LINUX_SHM_REMAP 0x4000 #define LINUX_SHM_LOCK 11 #define LINUX_SHM_UNLOCK 12 #define LINUX_SHM_STAT 13 #define LINUX_SHM_INFO 14 /* Pretend the sys_shmat and sys_shmctl syscalls are defined */ struct linux_sys_shmat_args { syscallarg(int) shmid; syscallarg(void *) shmaddr; syscallarg(int) shmflg; syscallarg(u_long *) raddr; }; struct linux_sys_shmctl_args { syscallarg(int) shmid; syscallarg(int) cmd; syscallarg(struct linux_shmid_ds *) buf; }; struct linux_sys_shmget_args { syscallarg(key_t) key; syscallarg(size_t) size; syscallarg(int) shmflg; }; #ifdef SYSVSHM #ifdef _KERNEL __BEGIN_DECLS int linux_sys_shmget(struct lwp *, const struct linux_sys_shmget_args *, register_t *); int linux_sys_shmat(struct lwp *, const struct linux_sys_shmat_args *, register_t *); int linux_sys_shmctl(struct lwp *, const struct linux_sys_shmctl_args *, register_t *); void linux_to_bsd_shmid_ds(struct linux_shmid_ds *, struct shmid_ds *); void linux_to_bsd_shmid64_ds(struct linux_shmid64_ds *, struct shmid_ds *); void bsd_to_linux_shmid_ds(struct shmid_ds *, struct linux_shmid_ds *); void bsd_to_linux_shmid64_ds(struct shmid_ds *, struct linux_shmid64_ds *); __END_DECLS #endif /* !_KERNEL */ #endif /* !SYSVSHM */ #endif /* !_LINUX_SHM_H */