Annotation of 43BSDReno/sys/hp300/pte.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1988 University of Utah.
                      3:  * Copyright (c) 1982, 1986, 1990 The Regents of the University of California.
                      4:  * All rights reserved.
                      5:  *
                      6:  * This code is derived from software contributed to Berkeley by
                      7:  * the Systems Programming Group of the University of Utah Computer
                      8:  * Science Department.
                      9:  *
                     10:  * Redistribution is only permitted until one year after the first shipment
                     11:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
                     12:  * binary forms are permitted provided that: (1) source distributions retain
                     13:  * this entire copyright notice and comment, and (2) distributions including
                     14:  * binaries display the following acknowledgement:  This product includes
                     15:  * software developed by the University of California, Berkeley and its
                     16:  * contributors'' in the documentation or other materials provided with the
                     17:  * distribution and in all advertising materials mentioning features or use
                     18:  * of this software.  Neither the name of the University nor the names of
                     19:  * its contributors may be used to endorse or promote products derived from
                     20:  * this software without specific prior written permission.
                     21:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
                     22:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
                     23:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     24:  *
                     25:  * from: Utah $Hdr: pte.h 1.11 89/09/03$
                     26:  *
                     27:  *     @(#)pte.h       7.1 (Berkeley) 5/8/90
                     28:  */
                     29: 
                     30: /*
                     31:  * HP300 page table entry
                     32:  *
                     33:  * There are two major kinds of pte's: those which have ever existed (and are
                     34:  * thus either now in core or on the swap device), and those which have
                     35:  * never existed, but which will be filled on demand at first reference.
                     36:  * There is a structure describing each.  There is also an ancillary
                     37:  * structure used in page clustering.
                     38:  */
                     39: 
                     40: #ifndef LOCORE
                     41: struct ste
                     42: {
                     43: unsigned int   sg_pfnum:20,            /* page table frame number */
                     44:                :8,                     /* reserved at 0 */
                     45:                :1,                     /* reserved at 1 */
                     46:                sg_prot:1,              /* write protect bit */
                     47:                sg_v:2;                 /* valid bits */
                     48: };
                     49: 
                     50: struct pte
                     51: {
                     52: unsigned int   pg_pfnum:20,            /* page frame number or 0 */
                     53:                :3,
                     54:                pg_fod:1,               /* is fill on demand (=0) */
                     55:                :1,                     /* reserved at zero */
                     56:                pg_ci:1,                /* cache inhibit bit */
                     57:                :1,                     /* reserved at zero */
                     58:                pg_m:1,                 /* hardware modified (dirty) bit */
                     59:                pg_u:1,                 /* hardware used (reference) bit */
                     60:                pg_prot:1,              /* write protect bit */
                     61:                pg_v:2;                 /* valid bit */
                     62: };
                     63: 
                     64: /* not used */
                     65: struct hpte
                     66: {
                     67: unsigned int   pg_pfnum:20,
                     68:                pg_high:12;             /* special for clustering */
                     69: };
                     70: 
                     71: struct fpte
                     72: {
                     73: unsigned int   pg_blkno:22,            /* file system block number */
                     74:                pg_fileno:1,            /* file mapped from or TEXT or ZERO */
                     75:                pg_fod:1,               /* is fill on demand (=1) */
                     76:                :6,
                     77:                pg_v:2;
                     78: };
                     79: #endif
                     80: 
                     81: #define        SG_V            0x00000002
                     82: #define        SG_NV           0x00000000
                     83: #define        SG_PROT         0x00000004
                     84: #define        SG_RO           0x00000004
                     85: #define        SG_RW           0x00000000
                     86: #define        SG_FRAME        0xfffff000
                     87: #define        SG_IMASK        0xffc00000
                     88: #define        SG_PMASK        0x003ff000
                     89: #define        SG_ISHIFT       22
                     90: #define        SG_PSHIFT       12
                     91: 
                     92: #define        PG_V            0x00000001
                     93: #define        PG_NV           0x00000000
                     94: #define        PG_PROT         0x00000004
                     95: #define        PG_U            0x00000008
                     96: #define        PG_M            0x00000010
                     97: #define        PG_FOD          0x00000100
                     98: #define        PG_RO           0x00000004
                     99: #define        PG_RW           0x00000000
                    100: #define        PG_FRAME        0xfffff000
                    101: #define        PG_CI           0x00000040
                    102: #define        PG_PFNUM(x)     (((x) & PG_FRAME) >> PGSHIFT)
                    103: 
                    104: /*
                    105:  * Pseudo protections.
                    106:  * Note that PG_URKW is not defined intuitively, but it is currently only
                    107:  * used in vgetu() to initialize the u-area PTEs in the process address
                    108:  * space.  Since the kernel never accesses the u-area thru these we are ok.
                    109:  */
                    110: #define        PG_KW           PG_RW
                    111: #define        PG_URKR         PG_RO
                    112: #define        PG_URKW         PG_RO
                    113: #define        PG_UW           PG_RW
                    114: 
                    115: #define        PG_FZERO        0
                    116: #define        PG_FTEXT        1
                    117: #define        PG_FMAX         (PG_FTEXT)
                    118: 
                    119: /*
                    120:  * Pte related macros
                    121:  */
                    122: #define        dirty(pte)      ((pte)->pg_m)
                    123: 
                    124: /*
                    125:  * Kernel virtual address to page table entry and to physical address.
                    126:  */
                    127: #define        kvtopte(va) (&Sysmap[((unsigned)(va) &~ KERNBASE) >> PGSHIFT])
                    128: #define        ptetokv(pt) ((((struct pte *)(pt) - Sysmap) << PGSHIFT) | KERNBASE)
                    129: #define        kvtophys(x) ((kvtopte(x)->pg_pfnum << PGSHIFT) | ((int)(x) & PGOFSET))
                    130: 
                    131: #if defined(KERNEL) && !defined(LOCORE)
                    132: /* utilities defined in locore.s */
                    133: extern struct pte Sysmap[];
                    134: extern struct pte Usrptmap[];
                    135: extern struct pte usrpt[];
                    136: extern struct pte Swapmap[];
                    137: extern struct pte Forkmap[];
                    138: extern struct pte Xswapmap[];
                    139: extern struct pte Xswap2map[];
                    140: extern struct pte Pushmap[];
                    141: extern struct pte Vfmap[];
                    142: extern struct pte mmap[];
                    143: extern struct pte msgbufmap[];
                    144: extern struct pte kmempt[], ekmempt[];
                    145: extern struct ste Sysseg[];
                    146: #endif /* defined(KERNEL) && !defined(LOCORE) */

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.