Annotation of coherent/a/usr/include.b4ps2/sys/mmu.h, revision 1.1.1.1

1.1       root        1: /* (-lgl
                      2:  *     COHERENT Driver Kit Version 2.0
                      3:  *     Copyright (c) 1982, 1992 by Mark Williams Company.
                      4:  *     All rights reserved. May not be copied without permission.
                      5:  -lgl) */
                      6: #ifndef        MMU_H
                      7: #define        MMU_H
                      8: 
                      9: #ifdef _I386
                     10: #ifndef TYPES_H
                     11: #include <sys/types.h>
                     12: #endif
                     13: #ifndef UPROC_H
                     14: #include <sys/uproc.h>
                     15: #endif
                     16: 
                     17:        /* A click is a 4K byte paragraph.
                     18:         * a segment is a 4 megabyte paragraph (level 1 page table entry)
                     19:         */
                     20: 
                     21: #define UII_BASE       0x00400000L     /* base for sep I/D l.out text */
                     22: 
                     23: #define        SEG_ILL         0x00    /* The empty page table entry.  */
                     24: #define SEG_PRE                0x01    /* Present bit.                 */
                     25: #define        SEG_SRO         0x01    /* Read by system only.         */
                     26: #define        SEG_SRW         0x03    /* Read/Write by system only.   */
                     27: #define        SEG_RO          0x05    /* Read only by anybody.        */
                     28: #define        SEG_BITS        0x07    /* Permissions bits for a pte.  */
                     29: #define        SEG_RW          0x07    /* Read/Write by anybody.       */
                     30: #define        SEG_ACD         0x20    /* Page has been accessed.      */
                     31: #define        SEG_UPD         0x40    /* Page has been updated.       */
                     32: /*
                     33:  * SEG_NPL is for pages which are not from the sysmem pool.
                     34:  * This includes pages representing video memory attached to
                     35:  * user data.
                     36:  * The SEG_NPL bit is not a real page table entry flag, and so is
                     37:  * masked out when CPU page tables are loaded from process data.
                     38:  */
                     39: #define        SEG_NPL         0x80    /* Page is not in sysmem pool.  */
                     40: 
                     41: #define        DIR_RW          0x07 /* us=us0|us1; rw=rw0&rw1; Intel's sOOO logical*/
                     42: 
                     43: #define        SEG_386_UI      0x08    /* [ 0000 0000 .. FFFF FFFF ]           */
                     44: #define        SEG_386_UD      0x10
                     45: #define        SEG_386_KI      0x18
                     46: #define        SEG_386_KD      0x21    /* kernel data in ring 1                */
                     47: #define        SEG_286_UI      0x28
                     48: #define        SEG_286_UD      0x30
                     49: #define        SEG_TSS         0x38
                     50: #define        SEG_ROM         0x40
                     51: #define        SEG_VIDEOa      0x48
                     52: #define        SEG_VIDEOb      0x50
                     53: #define        SEG_386_II      0x58
                     54: #define        SEG_386_ID      0x60
                     55: #define        SEG_286_UII     0x68            /* UI -i */
                     56: #define        SEG_LDT         0x70
                     57: #define SEG_RNG0_STK   0x78    /* lower limit of 0xFFFFF000            */
                     58: #define SEG_RNG0_TXT   0x80
                     59: #define SEG_RNG1_STK   0x88
                     60: 
                     61: #define        SEG_VIRT        0x100           /* pseudo bit for kxcopy */
                     62: 
                     63: #define        R_USR           0x03            /* user privilege level         */
                     64: #define        SEG_PL          0x03            /* privilege level mask         */
                     65: 
                     66: #define        DPL_0           0x00            /* privilege level 0            */
                     67: #define        DPL_1           0x01            /* privilege level 1            */
                     68: #define        DPL_2           0x02            /* privilege level 2            */
                     69: #define        DPL_3           0x03            /* privilege level 3            */
                     70: 
                     71: /*
                     72:  * These addresses are all in clicks.
                     73:  */
                     74: #define        ROM             0xFFFC0 /* BIOS virtual address.                */
                     75: #define        VIDEOa          0xFFFB0 /* CGA video virtual address.           */
                     76: #define        VIDEOb          0xFFFA0 /* Mono video virtual address.          */
                     77: 
                     78: #define        PTABLE0_P       0x00001 /* Page directory physical address.     */
                     79: #define        PBASE           0x00002 /* Start of kernel, physical address.   */
                     80: 
                     81: #define        PTABLE0_V       0xFFFFE /* Page directory virtual address.      */
                     82: #define        PPTABLE1_V      0xFFFFC /* Virtual address of the page table
                     83:                                 * for the virtual page table.
                     84:                                 */
                     85: #define        WORK1           0xFFFFB /* Scratch page 1 virtual address.      */
                     86: #define        WORK0           0xFFFFA /* Scratch page 0 virtual address.      */
                     87: 
                     88: #define MAX_VADDR      ctob(VIDEOb)    /* Highest allocatable virtual address.  */
                     89: /*
                     90:  * Addresses in kernel data for the RAM disk are now in rm.c.
                     91:  * As of 92/06/25, they are
                     92:  *     RAM0    0x80000         Ram disk 0 virtual click address.
                     93:  *     RAM1    0x80800         Ram disk 1 virtual click address.
                     94:  *     RAMSIZE 0x00800         Number of clicks in each ram disk.
                     95:  */
                     96: 
                     97: #define        SBASE           0xFFC00 /* Start of kernel, virtual address.    */
                     98: #define        PTABLE1_V       0xFF800 /* Start of virtual page table.         */
                     99: 
                    100: /*
                    101:  * ptable0_v[] is the page directory (master page table).
                    102:  * ptable1_v[] is the virtual page table.
                    103:  */
                    104: #define        ptable0_v       ((long *)ctob(PTABLE0_V))
                    105: #define        ptable1_v       ((long *)ctob(PTABLE1_V))
                    106: 
                    107: 
                    108: #define        SZDT            8               /* size of a segment descriptor */
                    109: 
                    110: #define        clickseg(n)     (((long)n) << BPCSHIFT)
                    111: #define        segclick(n)     ((long)(n) >> BPCSHIFT)
                    112: 
                    113: #define        regread(n)      ptable0_v[(n)>>BPC1SHIFT]
                    114: #define        regload(n, v)   { ptable0_v[(n)>>BPC1SHIFT] = v; mmuupd(); }
                    115: 
                    116: #define        maparea(v) \
                    117:        { ptable1_v[WORK0-SBASE] = clickseg(v) | SEG_SRW; mmuupd(); }
                    118: 
                    119: #define        xmode(ty)       ((u.u_regl[DS]&0xffff) \
                    120:   == ((ty)==286 ? (SEG_286_UD|R_USR) : (SEG_386_UD|R_USR)))
                    121: #define        XMODE_286       ((u.u_regl[DS]&0xffff) == (SEG_286_UD|R_USR))
                    122: #define        XMODE_386       ((u.u_regl[DS]&0xffff) == (SEG_386_UD|R_USR))
                    123: #define        wdsize()        ((XMODE_286) ? sizeof(short) : sizeof(int))
                    124: 
                    125: /*
                    126:  * These macros assume segment size <= 4 megabytes.
                    127:  *
                    128:  * MAPIO:absolute page table address, offset ->
                    129:  *       relative page table click# (20 bits) ... offset (12 bits)
                    130:  * MAPIO converts (SEG.s_vmem, byte offset) to system global addr.
                    131:  */
                    132: #define        MAPIO(seg, off) (((seg)+((int)(off)>>BPCSHIFT) - sysmem.u.pbase) << \
                    133:                BPCSHIFT | ((off) & (NBPC-1)))
                    134: #define        P2P(addr) ((sysmem.u.pbase[btocrd(addr)]&~(NBPC-1)) |(addr&(NBPC-1)))
                    135: 
                    136: #define BUDDY(addr,size)       ((addr) ^ (1 << (size)))
                    137: #define        NBUDDY  12      /* segments of 2^NBUDDY 4 click chunks (16 megabytes) */
                    138: #define        SPLASH  3
                    139: #define        NDATA   4       /* process data segments                        */
                    140: #define        BLKSZ   2       /* log2 sizeof(BLOCKLIST)/sizeof(cseg_t)        */
                    141: SR     *loaded();
                    142: cseg_t *c_begin();
                    143: 
                    144: #define        INSERT2(t, p, pp) { \
                    145:        (p)->forw = (pp); \
                    146:        (p)->back = (pp)->back; \
                    147:        (pp)->back->forw = (p); \
                    148:        (pp)->back= (p); \
                    149:        }
                    150: 
                    151: #define        DELETE2(p) ((p)->forw->back = (p)->back, (p)->back->forw = \
                    152:        (p)->forw, (p)->forw = (p)->back = (p))
                    153: 
                    154: #define        INIT2(lp)       ((lp)->forw = (lp)->back = (lp))
                    155: 
                    156: typedef struct blocklist
                    157: {
                    158:        struct  blocklist       *back;
                    159:        struct  blocklist       *forw;
                    160:        int     kval;
                    161:        int     fill;                   /* sizeof(BLOCKLIST) :: power of 2 */
                    162: } BLOCKLIST;
                    163: 
                    164: #define        WCOUNT  32                      /* number of bits in an int */
                    165: #define        WSHIFT  5
                    166: 
                    167: typedef struct {
                    168:        union {
                    169:                BLOCKLIST *budtab;
                    170:                cseg_t  *pbase;
                    171:        } u;                            /* beginning of pointer area */
                    172:        int     budfree[1 << (NBUDDY-WSHIFT)];  
                    173:        BLOCKLIST bfree[NBUDDY];
                    174:        unsigned short  *tfree, *efree, *pfree;
                    175:                /* vector of page descriptors (base, end, current pointer) */
                    176:        unsigned short lo, hi;  /* valid physical memory (min,max) */
                    177:        vaddr_t vaddre;         /* end of system */
                    178: } SYSMEM;
                    179: 
                    180: extern SYSMEM  sysmem;
                    181: cseg_t *c_alloc();
                    182: cseg_t *c_extend();
                    183: BLOCKLIST      *arealloc();
                    184: 
                    185: /*
                    186:  * Declare and initialize an in-memory segment structure.
                    187:  */
                    188: #define        MAKESR(sr, seg) SEG seg; SR sr = { 0, 0, 0, &seg }
                    189: /*
                    190:  * Is 'p' a valid physical click address?
                    191:  */
                    192: #define        pvalid(p)       ((p) >= sysmem.lo && (p) < sysmem.hi)
                    193: /*
                    194:  * How many physical clicks are free for allocation?
                    195:  */
                    196: #define allocno()      (sysmem.pfree - sysmem.tfree)
                    197: 
                    198: /*
                    199:  * IS_POW2() works for negative n only if the CPU uses 2's complement.
                    200:  */
                    201: #define IS_POW2(n)     (!((n) & ((n) - 1)))    /* Is n a power of 2?  */
                    202: 
                    203: typedef struct {
                    204:        int     pid;
                    205:        int     r[SS+1];
                    206:        int     (*func)();
                    207:        int     a[5];
                    208:        int     res;
                    209:        int     err;
                    210: } EVENT;
                    211: #define        NEV     32
                    212: extern EVENT   evtab[NEV];
                    213: EVENT  *evtrap();
                    214: 
                    215: #else /* From here to EOF is for 286 kernels.  */
                    216: 
                    217: /*
                    218:  * The following macros facilitate independent access
                    219:  * to the selector and offset of a faddr_t (far *) pointer.
                    220:  */
                    221: #define        FP_OFF(f)       ( ((unsigned short *) &(f))[0] )
                    222: #define        FP_SEL(f)       ( ((unsigned short *) &(f))[1] )
                    223: 
                    224: #ifdef KERNEL
                    225: /*
                    226:  * The following selector accesses the global descriptor table.
                    227:  */
                    228: extern saddr_t gdtsel;
                    229: 
                    230: /*
                    231:  * The following functions manipulate virtual address translation tables.
                    232:  */
                    233: extern faddr_t ptov();         /* faddr_t ptov( paddr_t, fsize_t );    */
                    234: extern faddr_t ptovx();        /* faddr_t ptovx( paddr_t );            */
                    235: extern paddr_t vtop();         /* paddr_t vtop( faddr_t );             */
                    236: extern void    vrelse();       /* void    vrelse( faddr_t );           */
                    237: extern void    vremap();       /* void    vremap( SEG * );             */
                    238: #endif /* KERNEL */
                    239: 
                    240: #endif /* _I386 */
                    241: 
                    242: #endif /* MMU_H */

unix.superglobalmegacorp.com

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