Annotation of 43BSDTahoe/sys/tahoe/machparam.h, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1982, 1986, 1988 Regents of the University of California.
                      3:  * All rights reserved.  The Berkeley software License Agreement
                      4:  * specifies the terms and conditions for redistribution.
                      5:  *
                      6:  *     @(#)machparam.h 7.1 (Berkeley) 5/21/88
                      7:  */
                      8: 
                      9: /*
                     10:  * Machine dependent constants for TAHOE.
                     11:  */
                     12: #define        MACHINE "tahoe"
                     13: 
                     14: #ifndef BYTE_ORDER
                     15: #include <machine/endian.h>
                     16: #endif
                     17: 
                     18: #define        CHAR_BIT        NBBY
                     19: #define        CHAR_MAX        0x7f
                     20: #define        CHAR_MIN        0x80
                     21: #define        CLK_TCK         60                      /* for times() */
                     22: #define        INT_MAX         0x7fffffff
                     23: #define        INT_MIN         0x80000000
                     24: #define        LONG_MAX        0x7fffffff
                     25: #define        LONG_MIN        0x80000000
                     26: #define        SCHAR_MAX       0x7f
                     27: #define        SCHAR_MIN       0x80
                     28: #define        SHRT_MAX        0x7fff
                     29: #define        SHRT_MIN        0x8000
                     30: #define        UCHAR_MAX       0xff
                     31: #define        UINT_MAX        0xffffffff
                     32: #define        ULONG_MAX       0xffffffff
                     33: #define        USHRT_MAX       0xffff
                     34: 
                     35: #define        NBPG            1024            /* bytes/page */
                     36: #define        PGOFSET         (NBPG-1)        /* byte offset into page */
                     37: #define        PGSHIFT         10              /* LOG2(NBPG) */
                     38: #define        NPTEPG          (NBPG/(sizeof (struct pte)))
                     39: 
                     40: #define        KERNBASE        0xc0000000      /* start of kernel virtual */
                     41: #define        BTOPKERNBASE    ((u_long)KERNBASE >> PGSHIFT)
                     42: 
                     43: #define        DEV_BSIZE       1024
                     44: #define        DEV_BSHIFT      10              /* log2(DEV_BSIZE) */
                     45: #define BLKDEV_IOSIZE  1024            /* NBPG for physical controllers */
                     46: #define        MAXPHYS         (64 * 1024)     /* max raw I/O transfer size */
                     47: 
                     48: #define        CLSIZE          1
                     49: #define        CLSIZELOG2      0
                     50: 
                     51: #define        SSIZE           2               /* initial stack size/NBPG */
                     52: #define        SINCR           2               /* increment of stack/NBPG */
                     53: #define        UPAGES          6               /* pages of u-area (2 stack pages) */
                     54: 
                     55: #define        MAXCKEY 255             /* maximal allowed code key */
                     56: #define        MAXDKEY 255             /* maximal allowed data key */
                     57: #define        NCKEY   (MAXCKEY+1)     /* # code keys, including 0 (reserved) */
                     58: #define        NDKEY   (MAXDKEY+1)     /* # data keys, including 0 (reserved) */
                     59: 
                     60: /*
                     61:  * Some macros for units conversion
                     62:  */
                     63: /* Core clicks (1024 bytes) to segments and vice versa */
                     64: #define        ctos(x) (x)
                     65: #define        stoc(x) (x)
                     66: 
                     67: /* Core clicks (1024 bytes) to disk blocks */
                     68: #define        ctod(x) (x)
                     69: #define        dtoc(x) (x)
                     70: #define        dtob(x) ((x)<<PGSHIFT)
                     71: 
                     72: /* clicks to bytes */
                     73: #define        ctob(x) ((x)<<PGSHIFT)
                     74: 
                     75: /* bytes to clicks */
                     76: #define        btoc(x) ((((unsigned)(x)+NBPG-1) >> PGSHIFT))
                     77: 
                     78: #define        btodb(bytes)                    /* calculates (bytes / DEV_BSIZE) */ \
                     79:        ((unsigned)(bytes) >> DEV_BSHIFT)
                     80: #define        dbtob(db)                       /* calculates (db * DEV_BSIZE) */ \
                     81:        ((unsigned)(db) << DEV_BSHIFT)
                     82: 
                     83: /*
                     84:  * Map a ``block device block'' to a file system block.
                     85:  * This should be device dependent, and will be if we
                     86:  * add an entry to cdevsw/bdevsw for that purpose.
                     87:  * For now though just use DEV_BSIZE.
                     88:  */
                     89: #define        bdbtofsb(bn)    ((bn) / (BLKDEV_IOSIZE/DEV_BSIZE))
                     90: 
                     91: /*
                     92:  * Macros to decode processor status word.
                     93:  */
                     94: #define        USERMODE(ps)    (((ps) & PSL_CURMOD) == PSL_CURMOD)
                     95: #define        BASEPRI(ps)     (((ps) & PSL_IPL) == 0)
                     96: 
                     97: #define        DELAY(n)        { register int N = 3*(n); while (--N > 0); }

unix.superglobalmegacorp.com

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