NetBSD-5.0.2/sys/compat/irix/irix_prctl.h

/*	$NetBSD: irix_prctl.h,v 1.14 2008/04/28 20:23:41 martin Exp $ */

/*-
 * Copyright (c) 2001-2002 The NetBSD Foundation, Inc.
 * All rights reserved.
 *
 * This code is derived from software contributed to The NetBSD Foundation
 * by Emmanuel Dreyfus.
 *
 * 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 _IRIX_PRCTL_H_
#define _IRIX_PRCTL_H_

/* IRIX share group structure */
struct irix_share_group {
	LIST_HEAD(isg_head, irix_emuldata) isg_head;	/* list head */
	krwlock_t isg_lock;				/* list lock */
	int isg_refcount;
};

/*
 * List of shared vs unshared regions in the VM space. We need to maintain
 * this for all processes, not only processes belonging to a share group,
 * because a process can request a private mapping (MAP_LOCAL option to
 * mmap(2)) before becoming the member of a share group.
 */
struct irix_shared_regions_rec {
	vaddr_t	isrr_start;
	vsize_t	isrr_len;
	int	isrr_shared;	/* shared or not shared */
#define IRIX_ISRR_SHARED 1
#define IRIX_ISRR_PRIVATE 0
	LIST_ENTRY(irix_shared_regions_rec) isrr_list;
};

int irix_prda_init(struct proc *);
void irix_vm_sync(struct proc *);
int irix_vm_fault(struct proc *, vaddr_t, vm_prot_t);
void irix_isrr_insert(vaddr_t, vsize_t, int, struct proc *);

/* macro used to wrap irix_vm_sync calls */
#define IRIX_VM_SYNC(q,cmd)                                                   \
if (((struct irix_emuldata *)((q)->p_emuldata))->ied_share_group == NULL ||   \
    ((struct irix_emuldata *)((q)->p_emuldata))->ied_shareaddr == 0) {        \
	(cmd);                                                                \
} else {                                                                      \
	rw_enter(&((struct irix_emuldata *)                                   \
	    ((q)->p_emuldata))->ied_share_group->isg_lock, RW_WRITER);        \
	(cmd);                                                                \
	irix_vm_sync((q));                                                    \
	rw_exit(&((struct irix_emuldata *)                                    \
	    ((q)->p_emuldata))->ied_share_group->isg_lock);                   \
}

/* From IRIX's <sys/prctl.h> */

#define IRIX_PR_MAXPROCS	1
#define IRIX_PR_ISBLOCKED	2
#define IRIX_PR_SETSTACKSIZE	3
#define IRIX_PR_GETSTACKSIZE	4
#define IRIX_PR_MAXPPROCS	5
#define IRIX_PR_UNBLKONEXEC	6
#define IRIX_PR_SETEXITSIG	8
#define IRIX_PR_RESIDENT	9
#define IRIX_PR_ATTACHADDR	10
#define IRIX_PR_DETACHADDR	11
#define IRIX_PR_TERMCHILD	12
#define IRIX_PR_GETSHMASK	13
#define IRIX_PR_GETNSHARE	14
#define IRIX_PR_COREPID		15
#define IRIX_PR_ATTACHADDRPERM	16
#define IRIX_PR_PTHREADEXIT	17
#define IRIX_PR_SETABORTSIG	18
#define IRIX_PR_INIT_THREADS	20
#define IRIX_PR_THREAD_CTL	21
#define IRIX_PR_LASTSHEXIT	22

/* sproc flags */
#define IRIX_PR_SPROC		0x00000001
#define IRIX_PR_SFDS		0x00000002
#define IRIX_PR_SDIR		0x00000004
#define IRIX_PR_SUMASK		0x00000008
#define IRIX_PR_SULIMIT		0x00000010
#define IRIX_PR_SID		0x00000020
#define IRIX_PR_SADDR		0x00000040
#define IRIX_PR_THREADS		0x00000080
#define IRIX_PR_BLOCK		0x01000000
#define IRIX_PR_NOLIBC		0x02000000
#define IRIX_PR_EVENT		0x04000000

/* blockproc constants */
#define IRIX_PR_MAXBLOCKCNT	10000
#define IRIX_PR_MINBLOCKCNT	-10000

/* This is undocumented */
#define IRIX_PROCBLK_BLOCK	0
#define IRIX_PROCBLK_UNBLOCK	1
#define IRIX_PROCBLK_COUNT	2
#define IRIX_PROCBLK_BLOCKALL	3
#define IRIX_PROCBLK_UNBLOCKALL	4
#define IRIX_PROCBLK_COUNTALL	5
#define IRIX_PROCBLK_ONLYONE	-3

/* From <sys/prctl.h> */
#define IRIX_PRDA 		((struct prda *)0x00200000L)
struct irix_prda_sys {
	irix_pid_t	t_pid;
	uint32_t	t_hint;
	uint32_t	t_dlactseq;
	uint32_t	t_fpflags;
	uint32_t	t_prid;
	uint32_t	t_dlendseq;
	uint64_t	t_unused1[5];
	irix_pid_t	t_rpid;
	int32_t		t_resched;
	int32_t		t_syserror;
	int32_t		t_nid;
	int32_t		t_affinity_nid;
	uint32_t	t_unused2[5];
	uint32_t	t_cpu;
	uint32_t	t_flags;
	irix_k_sigset_t	t_hold;
};
struct irix_prda {
	char	unused[2048];
	union {
		char	fill[512];
		uint32_t rsvd[8];
	} sys2_prda;
	union {
		char fill[512];
	} lib2_prda;
	union {
		char fill[512];
	} usr2rda;
	union {
		struct irix_prda_sys prda_sys;
		char fill[128];
	} sys_prda;
	union {
		char fill[256];
	} lib_prda;
	union {
		char fill[128];
	} usr_prda;
};

#endif /* _IRIX_PRCTL_H_ */