/*      $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 <sys/shm.h>

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