Annotation of XNU/bsd/dev/i386/conf.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
        !             3:  *
        !             4:  * @APPLE_LICENSE_HEADER_START@
        !             5:  * 
        !             6:  * The contents of this file constitute Original Code as defined in and
        !             7:  * are subject to the Apple Public Source License Version 1.1 (the
        !             8:  * "License").  You may not use this file except in compliance with the
        !             9:  * License.  Please obtain a copy of the License at
        !            10:  * http://www.apple.com/publicsource and read it before using this file.
        !            11:  * 
        !            12:  * This Original Code and all software distributed under the License are
        !            13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
        !            14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
        !            15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
        !            16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
        !            17:  * License for the specific language governing rights and limitations
        !            18:  * under the License.
        !            19:  * 
        !            20:  * @APPLE_LICENSE_HEADER_END@
        !            21:  */
        !            22: /*
        !            23:  * Copyright (c) 1997 by Apple Computer, Inc., all rights reserved
        !            24:  * Copyright (c) 1993 NeXT Computer, Inc.
        !            25:  *
        !            26:  * UNIX Device switch tables.
        !            27:  *
        !            28:  * HISTORY
        !            29:  *
        !            30:  * 30 July 1997 Umesh Vaishampayan ([email protected])
        !            31:  *     enabled file descriptor pseudo-device.
        !            32:  * 18 June 1993 ? at NeXT
        !            33:  *     Cleaned up a lot of stuff in this file.
        !            34:  */
        !            35: 
        !            36: #import <sys/param.h>
        !            37: #import <sys/systm.h>
        !            38: #import <sys/buf.h>
        !            39: #import <sys/ioctl.h>
        !            40: #import <sys/tty.h>
        !            41: #import <sys/conf.h>
        !            42: 
        !            43: 
        !            44: extern int     nulldev();
        !            45: 
        !            46: struct bdevsw  bdevsw[] =
        !            47: {
        !            48:        /*
        !            49:         *      For block devices, every other block of 8 slots is 
        !            50:         *      reserved to NeXT.  The other slots are available for
        !            51:         *      the user.  This way we can both add new entries without
        !            52:         *      running into each other.  Be sure to fill in NeXT's
        !            53:         *      8 reserved slots when you jump over us -- we'll do the
        !            54:         *      same for you.
        !            55:         */
        !            56: 
        !            57:        /* 0 - 7 are reserved to NeXT */
        !            58: 
        !            59:        NO_BDEVICE,                                                     /* 0*/
        !            60:        NO_BDEVICE,                                                     /* 1*/
        !            61:        NO_BDEVICE,                                                     /* 2*/
        !            62:        NO_BDEVICE,                                                     /* 3*/
        !            63:        NO_BDEVICE,                                                     /* 4*/
        !            64:        NO_BDEVICE,                                                     /* 5*/
        !            65:        NO_BDEVICE,                                                     /* 6*/
        !            66:        NO_BDEVICE,                                                     /* 7*/
        !            67: 
        !            68:        /* 8 - 15 are reserved to the user */
        !            69:        NO_BDEVICE,                                                     /* 8*/
        !            70:        NO_BDEVICE,                                                     /* 9*/
        !            71:        NO_BDEVICE,                                                     /*10*/
        !            72:        NO_BDEVICE,                                                     /*11*/
        !            73:        NO_BDEVICE,                                                     /*12*/
        !            74:        NO_BDEVICE,                                                     /*13*/
        !            75:        NO_BDEVICE,                                                     /*14*/
        !            76:        NO_BDEVICE,                                                     /*15*/
        !            77: 
        !            78:        /* 16 - 23 are reserved to NeXT */
        !            79:        NO_BDEVICE,                                                     /*16*/
        !            80:        NO_BDEVICE,                                                     /*17*/
        !            81:        NO_BDEVICE,                                                     /*18*/
        !            82:        NO_BDEVICE,                                                     /*18*/
        !            83:        NO_BDEVICE,                                                     /*20*/
        !            84:        NO_BDEVICE,                                                     /*21*/
        !            85:        NO_BDEVICE,                                                     /*22*/
        !            86:        NO_BDEVICE,                                                     /*23*/
        !            87: };
        !            88: 
        !            89: int    nblkdev = sizeof (bdevsw) / sizeof (bdevsw[0]);
        !            90: 
        !            91: extern struct tty *km_tty[];
        !            92: extern int     cnopen(),cnclose(),cnread(),cnwrite(),cnioctl(),
        !            93:                cnselect(),cngetc(), cnputc(dev_t dev, char c);
        !            94: extern int     kmopen(),kmclose(),kmread(),kmwrite(),kmioctl(),
        !            95:                kmgetc(), kmputc(dev_t dev, char c);
        !            96: extern int     sgopen(),sgclose(), sgioctl();
        !            97: #if notyet
        !            98: #import <vol.h>
        !            99: #endif
        !           100: #if NVOL > 0
        !           101: extern int     volopen(),volclose(),volioctl();
        !           102: #else
        !           103: #define        volopen         eno_opcl
        !           104: #define        volclose        eno_opcl
        !           105: #define        volioctl        eno_ioctl
        !           106: #endif
        !           107: 
        !           108: extern int     cttyopen(), cttyread(), cttywrite(), cttyioctl(), cttyselect();
        !           109: 
        !           110: extern int     mmread(),mmwrite();
        !           111: #define        mmselect        seltrue
        !           112: #define mmmmap         eno_mmap
        !           113: 
        !           114: #import <pty.h>
        !           115: #if NPTY > 0
        !           116: extern struct tty *pt_tty[];
        !           117: extern int     ptsopen(),ptsclose(),ptsread(),ptswrite(),ptsstop(),ptsputc();
        !           118: extern int     ptcopen(),ptcclose(),ptcread(),ptcwrite(),ptcselect(),
        !           119:                ptyioctl();
        !           120: #else
        !           121: #define ptsopen                eno_opcl
        !           122: #define ptsclose       eno_opcl
        !           123: #define ptsread                eno_rdwrt
        !           124: #define ptswrite       eno_rdwrt
        !           125: #define        ptsstop         nulldev
        !           126: #define ptsputc                nulldev
        !           127: 
        !           128: #define ptcopen                eno_opcl
        !           129: #define ptcclose       eno_opcl
        !           130: #define ptcread                eno_rdwrt
        !           131: #define ptcwrite       eno_rdwrt
        !           132: #define        ptcselect       eno_select
        !           133: #define ptyioctl       eno_ioctl
        !           134: #endif
        !           135: 
        !           136: extern int     logopen(),logclose(),logread(),logioctl(),logselect();
        !           137: extern int     fdesc_open(), fdesc_read(), fdesc_write(),
        !           138:                fdesc_ioctl(), fdesc_select();
        !           139: 
        !           140: extern int     seltrue();
        !           141: 
        !           142: extern int     bpfopen(), bpfclose(), bpfread(), bpfwrite(), bpfioctl(),
        !           143:                bpfpoll();
        !           144: 
        !           145: struct cdevsw  cdevsw[] =
        !           146: {
        !           147:        /*
        !           148:         *      For character devices, every other block of 16 slots is
        !           149:         *      reserved to NeXT.  The other slots are available for
        !           150:         *      the user.  This way we can both add new entries without
        !           151:         *      running into each other.  Be sure to fill in NeXT's
        !           152:         *      16 reserved slots when you jump over us -- we'll do the
        !           153:         *      same for you.
        !           154:         */
        !           155: 
        !           156:        /* 0 - 15 are reserved to NeXT */
        !           157: 
        !           158:     {
        !           159:        cnopen,         cnclose,        cnread,         cnwrite,        /* 0*/
        !           160:        cnioctl,        nulldev,        nulldev,        0,              cnselect,
        !           161:        eno_mmap,       eno_strat,      cngetc,         cnputc,         D_TTY
        !           162:     },
        !           163:     NO_CDEVICE,                                                                /* 1*/
        !           164:     {
        !           165:        cttyopen,       nulldev,        cttyread,       cttywrite,      /* 2*/
        !           166:        cttyioctl,      nulldev,        nulldev,        0,              cttyselect,
        !           167:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       D_TTY
        !           168:     },
        !           169:     {
        !           170:        nulldev,        nulldev,        mmread,         mmwrite,        /* 3*/
        !           171:        eno_ioctl,      nulldev,        nulldev,        0,              mmselect,
        !           172:        mmmmap,         eno_strat,      eno_getc,       eno_putc,       0
        !           173:     },
        !           174:     {
        !           175:        ptsopen,        ptsclose,       ptsread,        ptswrite,       /* 4*/
        !           176:        ptyioctl,       ptsstop,        nulldev,        pt_tty,         ttselect,
        !           177:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       D_TTY
        !           178:     },
        !           179:     {
        !           180:        ptcopen,        ptcclose,       ptcread,        ptcwrite,       /* 5*/
        !           181:        ptyioctl,       nulldev,        nulldev,        0,              ptcselect,
        !           182:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       D_TTY
        !           183:     },
        !           184:     {
        !           185:        logopen,        logclose,       logread,        eno_rdwrt,      /* 6*/
        !           186:        logioctl,       eno_stop,       nulldev,        0,              logselect,
        !           187:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       0
        !           188:     },
        !           189:     {
        !           190:        bpfopen,        bpfclose,       bpfread,        bpfwrite,       /* 7 */
        !           191:        bpfioctl,       nulldev,        nulldev,        NULL,           bpfpoll,
        !           192:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       0
        !           193:     },
        !           194:     NO_CDEVICE,                                                                /* 8*/
        !           195:     NO_CDEVICE,                                                                /* 9*/
        !           196:     NO_CDEVICE,                                                                /*10*/
        !           197:     NO_CDEVICE,                                                                /*11*/
        !           198:     {
        !           199:        kmopen,         kmclose,        kmread,         kmwrite,        /*12*/
        !           200:        kmioctl,        nulldev,        nulldev,        km_tty,         ttselect,
        !           201:        eno_mmap,       eno_strat,      kmgetc,         kmputc,         0
        !           202:     },
        !           203:     NO_CDEVICE,                                                                /*13*/
        !           204:     NO_CDEVICE,                                                                /*14*/
        !           205:     NO_CDEVICE,                                                                /*15*/
        !           206: 
        !           207:        /* 16 - 31 are reserved to the user */
        !           208:     NO_CDEVICE,                                                                /*16*/
        !           209:     NO_CDEVICE,                                                                /*17*/
        !           210:     NO_CDEVICE,                                                                /*18*/
        !           211:     NO_CDEVICE,                                                                /*19*/
        !           212:     NO_CDEVICE,                                                                /*20*/
        !           213:     NO_CDEVICE,                                                                /*21*/
        !           214:     NO_CDEVICE,                                                                /*22*/
        !           215:     NO_CDEVICE,                                                                /*23*/
        !           216:     NO_CDEVICE,                                                                /*24*/
        !           217:     NO_CDEVICE,                                                                /*25*/
        !           218:     NO_CDEVICE,                                                                /*26*/
        !           219:     NO_CDEVICE,                                                                /*27*/
        !           220:     NO_CDEVICE,                                                                /*28*/
        !           221:     NO_CDEVICE,                                                                /*29*/
        !           222:     NO_CDEVICE,                                                                /*30*/
        !           223:     NO_CDEVICE,                                                                /*31*/
        !           224: 
        !           225:        /* 32 - 47 are reserved to NeXT */
        !           226:     {
        !           227:        fdesc_open,     eno_opcl,       fdesc_read,     fdesc_write,    /*32*/
        !           228:        fdesc_ioctl,    eno_stop,       eno_reset,      0,              fdesc_select,
        !           229:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       0
        !           230:     },
        !           231: #if 1
        !           232:    NO_CDEVICE,
        !           233: #else
        !           234:     {
        !           235:        sgopen,         sgclose,        eno_rdwrt,      eno_rdwrt,      /*33*/
        !           236:        sgioctl,        eno_stop,       eno_reset,      0,              eno_select,
        !           237:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       D_TAPE
        !           238:     },
        !           239: #endif
        !           240:     NO_CDEVICE,                                                                /*34*/
        !           241:     NO_CDEVICE,                                                                /*35*/
        !           242:     NO_CDEVICE,                                                                /*36*/
        !           243:     NO_CDEVICE,                                                                /*37*/
        !           244:     NO_CDEVICE,                                                                /*38*/
        !           245:     NO_CDEVICE,                                                                /*39*/
        !           246:     NO_CDEVICE,                                                                /*40*/
        !           247:     NO_CDEVICE,                                                                /*41*/
        !           248:     {
        !           249:        volopen,        volclose,       eno_rdwrt,      eno_rdwrt,      /*42*/
        !           250:        volioctl,       eno_stop,       eno_reset,      0,              seltrue,
        !           251:        eno_mmap,       eno_strat,      eno_getc,       eno_putc,       0
        !           252:     },
        !           253: };
        !           254: int    nchrdev = sizeof (cdevsw) / sizeof (cdevsw[0]);
        !           255: 
        !           256: 
        !           257: #import        <sys/vnode.h> /* for VCHR and VBLK */
        !           258: /*
        !           259:  * return true if a disk
        !           260:  */
        !           261: int
        !           262: isdisk(dev, type)
        !           263:        dev_t dev;
        !           264:        int type;
        !           265: {
        !           266:        switch (major(dev)) {
        !           267:        case 1: /* fd: floppy */
        !           268:        case 6: /* sd: scsi disk */
        !           269:        case 3: /* ide:  */
        !           270:                if (type == VBLK)
        !           271:                        return(1);
        !           272:                break;
        !           273:        case 14:         /* sd: scsi disk */
        !           274:        case 41: /* fd: floppy */
        !           275:                if (type == VCHR)
        !           276:                        return(1);
        !           277:                break;
        !           278:        }
        !           279:        return(0);
        !           280: }
        !           281: 
        !           282: static int chrtoblktab[] = {
        !           283:        /* CHR*/        /* BLK*/        /* CHR*/        /* BLK*/
        !           284:        /*  0 */        NODEV,          /*  1 */        NODEV,
        !           285:        /*  2 */        NODEV,          /*  3 */        NODEV,
        !           286:        /*  4 */        NODEV,          /*  5 */        NODEV,
        !           287:        /*  6 */        NODEV,          /*  7 */        NODEV,
        !           288:        /*  8 */        NODEV,          /*  9 */        NODEV,
        !           289:        /* 10 */        NODEV,          /* 11 */        NODEV,
        !           290:        /* 12 */        NODEV,          /* 13 */        NODEV,
        !           291:        /* 14 */        6,              /* 15 */        NODEV,
        !           292:        /* 16 */        NODEV,          /* 17 */        NODEV,
        !           293:        /* 18 */        NODEV,          /* 19 */        NODEV,
        !           294:        /* 20 */        NODEV,          /* 21 */        NODEV,
        !           295:        /* 22 */        NODEV,          /* 23 */        NODEV,
        !           296:        /* 24 */        NODEV,          /* 25 */        NODEV,
        !           297:        /* 26 */        NODEV,          /* 27 */        NODEV,
        !           298:        /* 28 */        NODEV,          /* 29 */        NODEV,
        !           299:        /* 30 */        NODEV,          /* 31 */        NODEV,
        !           300:        /* 32 */        NODEV,          /* 33 */        NODEV,
        !           301:        /* 34 */        NODEV,          /* 35 */        NODEV,
        !           302:        /* 36 */        NODEV,          /* 37 */        NODEV,
        !           303:        /* 38 */        NODEV,          /* 39 */        NODEV,
        !           304:        /* 40 */        NODEV,          /* 41 */        1,
        !           305:        /* 42 */        NODEV,          /* 43 */        NODEV,
        !           306:        /* 44 */        NODEV,
        !           307: };
        !           308: 
        !           309: /*
        !           310:  * convert chr dev to blk dev
        !           311:  */
        !           312: dev_t
        !           313: chrtoblk(dev)
        !           314:        dev_t dev;
        !           315: {
        !           316:        int blkmaj;
        !           317: 
        !           318:        if (major(dev) >= nchrdev)
        !           319:                return(NODEV);
        !           320:        blkmaj = chrtoblktab[major(dev)];
        !           321:        if (blkmaj == NODEV)
        !           322:                return(NODEV);
        !           323:        return(makedev(blkmaj, minor(dev)));
        !           324: }
        !           325: 
        !           326: /*
        !           327:  * Returns true if dev is /dev/mem or /dev/kmem.
        !           328:  */
        !           329: int iskmemdev(dev)
        !           330:        dev_t dev;
        !           331: {
        !           332: 
        !           333:        return (major(dev) == 3 && minor(dev) < 2);
        !           334: }

unix.superglobalmegacorp.com

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