Home | History | Annotate | Line # | Download | only in include
pcb.h revision 1.6.8.1
      1  1.6.8.1  joerg /*	$NetBSD: pcb.h,v 1.6.8.1 2007/11/27 19:35:33 joerg Exp $	*/
      2      1.1   fvdl 
      3      1.1   fvdl /*-
      4      1.1   fvdl  * Copyright (c) 1998 The NetBSD Foundation, Inc.
      5      1.1   fvdl  * All rights reserved.
      6      1.1   fvdl  *
      7      1.1   fvdl  * This code is derived from software contributed to The NetBSD Foundation
      8      1.1   fvdl  * by Charles M. Hannum.
      9      1.1   fvdl  *
     10      1.1   fvdl  * Redistribution and use in source and binary forms, with or without
     11      1.1   fvdl  * modification, are permitted provided that the following conditions
     12      1.1   fvdl  * are met:
     13      1.1   fvdl  * 1. Redistributions of source code must retain the above copyright
     14      1.1   fvdl  *    notice, this list of conditions and the following disclaimer.
     15      1.1   fvdl  * 2. Redistributions in binary form must reproduce the above copyright
     16      1.1   fvdl  *    notice, this list of conditions and the following disclaimer in the
     17      1.1   fvdl  *    documentation and/or other materials provided with the distribution.
     18      1.1   fvdl  * 3. All advertising materials mentioning features or use of this software
     19      1.1   fvdl  *    must display the following acknowledgement:
     20      1.1   fvdl  *        This product includes software developed by the NetBSD
     21      1.1   fvdl  *        Foundation, Inc. and its contributors.
     22      1.1   fvdl  * 4. Neither the name of The NetBSD Foundation nor the names of its
     23      1.1   fvdl  *    contributors may be used to endorse or promote products derived
     24      1.1   fvdl  *    from this software without specific prior written permission.
     25      1.1   fvdl  *
     26      1.1   fvdl  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27      1.1   fvdl  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28      1.1   fvdl  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29      1.1   fvdl  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     30      1.1   fvdl  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31      1.1   fvdl  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32      1.1   fvdl  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33      1.1   fvdl  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34      1.1   fvdl  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35      1.1   fvdl  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36      1.1   fvdl  * POSSIBILITY OF SUCH DAMAGE.
     37      1.1   fvdl  */
     38      1.1   fvdl 
     39      1.1   fvdl /*-
     40      1.1   fvdl  * Copyright (c) 1990 The Regents of the University of California.
     41      1.1   fvdl  * All rights reserved.
     42      1.1   fvdl  *
     43      1.1   fvdl  * This code is derived from software contributed to Berkeley by
     44      1.1   fvdl  * William Jolitz.
     45      1.1   fvdl  *
     46      1.1   fvdl  * Redistribution and use in source and binary forms, with or without
     47      1.1   fvdl  * modification, are permitted provided that the following conditions
     48      1.1   fvdl  * are met:
     49      1.1   fvdl  * 1. Redistributions of source code must retain the above copyright
     50      1.1   fvdl  *    notice, this list of conditions and the following disclaimer.
     51      1.1   fvdl  * 2. Redistributions in binary form must reproduce the above copyright
     52      1.1   fvdl  *    notice, this list of conditions and the following disclaimer in the
     53      1.1   fvdl  *    documentation and/or other materials provided with the distribution.
     54      1.2    agc  * 3. Neither the name of the University nor the names of its contributors
     55      1.1   fvdl  *    may be used to endorse or promote products derived from this software
     56      1.1   fvdl  *    without specific prior written permission.
     57      1.1   fvdl  *
     58      1.1   fvdl  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     59      1.1   fvdl  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     60      1.1   fvdl  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     61      1.1   fvdl  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     62      1.1   fvdl  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     63      1.1   fvdl  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     64      1.1   fvdl  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     65      1.1   fvdl  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     66      1.1   fvdl  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     67      1.1   fvdl  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     68      1.1   fvdl  * SUCH DAMAGE.
     69      1.1   fvdl  *
     70      1.1   fvdl  *	@(#)pcb.h	5.10 (Berkeley) 5/12/91
     71      1.1   fvdl  */
     72      1.1   fvdl 
     73      1.1   fvdl /*
     74      1.1   fvdl  * XXXfvdl these copyrights don't really match anymore
     75      1.1   fvdl  */
     76      1.1   fvdl 
     77      1.1   fvdl #ifndef _AMD64_PCB_H_
     78      1.1   fvdl #define _AMD64_PCB_H_
     79      1.1   fvdl 
     80      1.1   fvdl #include <sys/signal.h>
     81      1.1   fvdl 
     82      1.1   fvdl #include <machine/segments.h>
     83      1.1   fvdl #include <machine/tss.h>
     84      1.1   fvdl #include <machine/fpu.h>
     85      1.1   fvdl #include <machine/sysarch.h>
     86      1.1   fvdl 
     87      1.1   fvdl #define	NIOPORTS	1024		/* # of ports we allow to be mapped */
     88      1.1   fvdl 
     89      1.1   fvdl /*
     90      1.1   fvdl  * Please note that the pcb_savefpu field in struct below must be
     91      1.1   fvdl  * on a 16-byte boundary.
     92      1.1   fvdl  */
     93      1.1   fvdl struct pcb {
     94      1.1   fvdl 	/*
     95      1.1   fvdl 	 * XXXfvdl
     96      1.1   fvdl 	 * It's overkill to have a TSS here, as it's only needed
     97      1.1   fvdl 	 * for compatibility processes who use an I/O permission map.
     98      1.1   fvdl 	 * The pcb fields below are not in the TSS anymore (and there's
     99      1.1   fvdl 	 * not enough room in the TSS to store them all)
    100      1.1   fvdl 	 * Should just make this a pointer and allocate.
    101      1.1   fvdl 	 */
    102      1.1   fvdl 	struct	x86_64_tss pcb_tss;
    103  1.6.8.1  joerg 	int	  pcb_flags;
    104  1.6.8.1  joerg #define	PCB_USER_LDT	0x01		/* has user-set LDT */
    105  1.6.8.1  joerg #define PCB_GS64	0x02
    106  1.6.8.1  joerg #define PCB_FS64	0x04
    107  1.6.8.1  joerg 	int	  pcb_cr0;		/* saved image of CR0 */
    108  1.6.8.1  joerg 	u_int64_t pcb_cr2;		/* page fault address (CR2) */
    109      1.1   fvdl 	u_int64_t pcb_cr3;
    110      1.1   fvdl 	u_int64_t pcb_rsp;
    111      1.1   fvdl 	u_int64_t pcb_rbp;
    112      1.1   fvdl 	u_int64_t pcb_usersp;
    113      1.1   fvdl 	u_int64_t pcb_ldt_sel;
    114      1.1   fvdl 	struct	savefpu pcb_savefpu;	/* floating point state */
    115  1.6.8.1  joerg 	void     *pcb_onfault;		/* copyin/out fault recovery */
    116      1.1   fvdl 	struct cpu_info *pcb_fpcpu;	/* cpu holding our fp state. */
    117  1.6.8.1  joerg 	unsigned  pcb_iomap[NIOPORTS/32];	/* I/O bitmap */
    118  1.6.8.1  joerg 	uint64_t  pcb_gs;
    119  1.6.8.1  joerg 	uint64_t  pcb_fs;
    120      1.1   fvdl };
    121      1.1   fvdl 
    122      1.1   fvdl /*
    123      1.1   fvdl  * The pcb is augmented with machine-dependent additional data for
    124      1.1   fvdl  * core dumps. For the i386, there is nothing to add.
    125      1.1   fvdl  */
    126      1.1   fvdl struct md_coredump {
    127      1.1   fvdl 	long	md_pad[8];
    128      1.1   fvdl };
    129      1.1   fvdl 
    130      1.1   fvdl #endif /* _AMD64_PCB_H_ */
    131