Annotation of researchv9/sys.vax/h/pte.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * VAX page table entry
                      3:  *
                      4:  * There are two major kinds of pte's: those which have ever existed (and are
                      5:  * thus either now in core or on the swap device), and those which have
                      6:  * never existed, but which will be filled on demand at first reference.
                      7:  * There is a structure describing each.  There is also an ancillary
                      8:  * structure used in page clustering.
                      9:  */
                     10: 
                     11: #ifndef LOCORE
                     12: struct pte
                     13: {
                     14: unsigned int   pg_pfnum:21,            /* core page frame number or 0 */
                     15:                :2,
                     16:                pg_vreadm:1,            /* modified since vread (or with _m) */
                     17:                pg_swapm:1,             /* have to write back to swap */
                     18:                pg_fod:1,               /* is fill on demand (=0) */
                     19:                pg_m:1,                 /* hardware maintained modified bit */
                     20:                pg_prot:4,              /* access control */
                     21:                pg_v:1;                 /* valid bit */
                     22: };
                     23: struct hpte
                     24: {
                     25: unsigned int   pg_pfnum:21,
                     26:                :2,
                     27:                pg_high:9;              /* special for clustering */
                     28: };
                     29: struct fpte
                     30: {
                     31: unsigned int   pg_blkno:20,            /* file system block number */
                     32:                pg_source:5,            /* TEXT or ZERO */
                     33:                pg_fod:1,               /* is fill on demand (=1) */
                     34:                :1,
                     35:                pg_prot:4,
                     36:                pg_v:1;
                     37: };
                     38: #endif
                     39: 
                     40: #define        PG_V            0x80000000
                     41: #define        PG_PROT         0x78000000
                     42: #define        PG_M            0x04000000
                     43: #define        PG_FOD          0x02000000
                     44: #define        PG_VREADM       0x00800000
                     45: #define        PG_PFNUM        0x001fffff
                     46: 
                     47: #define PG_FMIN                (NOFILE)
                     48: #define        PG_FZERO        (PG_FMIN)
                     49: #define        PG_FTEXT        (PG_FMIN+1)
                     50: #define        PG_FMAX         (PG_FTEXT)
                     51: 
                     52: #define        PG_NOACC        0
                     53: #define        PG_KW           0x10000000
                     54: #define        PG_KR           0x18000000
                     55: #define        PG_UW           0x20000000
                     56: #define        PG_URKW         0x70000000
                     57: #define        PG_URKR         0x78000000
                     58: 
                     59: /*
                     60:  * Pte related macros
                     61:  */
                     62: #define        dirty(pte)      ((pte)->pg_fod == 0 && (pte)->pg_pfnum && \
                     63:                            ((pte)->pg_m || (pte)->pg_swapm))
                     64: 
                     65: #ifndef LOCORE
                     66: #ifdef KERNEL
                     67: struct pte *vtopte();
                     68: 
                     69: /* utilities defined in locore.s */
                     70: extern struct pte Sysmap[];
                     71: extern struct pte Usrptmap[];
                     72: extern struct pte usrpt[];
                     73: extern struct pte Swapmap[];
                     74: extern struct pte Forkmap[];
                     75: extern struct pte Xswapmap[];
                     76: extern struct pte Xswap2map[];
                     77: extern struct pte Pushmap[];
                     78: extern struct pte Vfmap[];
                     79: extern struct pte mmap[];
                     80: extern struct pte msgbufmap[];
                     81: extern struct pte camap[];
                     82: extern struct pte Nexmap[][16];
                     83: extern struct pte Prusrmap[];
                     84: #endif
                     85: #endif

unix.superglobalmegacorp.com

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