Annotation of 43BSDReno/sys/ufs/mfs_vnops.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1989 The Regents of the University of California.
                      3:  * All rights reserved.
                      4:  *
                      5:  * Redistribution is only permitted until one year after the first shipment
                      6:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
                      7:  * binary forms are permitted provided that: (1) source distributions retain
                      8:  * this entire copyright notice and comment, and (2) distributions including
                      9:  * binaries display the following acknowledgement:  This product includes
                     10:  * software developed by the University of California, Berkeley and its
                     11:  * contributors'' in the documentation or other materials provided with the
                     12:  * distribution and in all advertising materials mentioning features or use
                     13:  * of this software.  Neither the name of the University nor the names of
                     14:  * its contributors may be used to endorse or promote products derived from
                     15:  * this software without specific prior written permission.
                     16:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
                     17:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
                     18:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     19:  *
                     20:  *     @(#)mfs_vnops.c 7.18 (Berkeley) 7/2/90
                     21:  */
                     22: 
                     23: #include "param.h"
                     24: #include "time.h"
                     25: #include "kernel.h"
                     26: #include "proc.h"
                     27: #include "user.h"
                     28: #include "buf.h"
                     29: #include "vmmac.h"
                     30: #include "errno.h"
                     31: #include "map.h"
                     32: #include "vnode.h"
                     33: #include "../ufs/mfsnode.h"
                     34: #include "../ufs/mfsiom.h"
                     35: #include "machine/vmparam.h"
                     36: #include "machine/pte.h"
                     37: #include "machine/mtpr.h"
                     38: 
                     39: #if !defined(hp300) && !defined(i386)
                     40: static int mfsmap_want;                /* 1 => need kernel I/O resources */
                     41: struct map mfsmap[MFS_MAPSIZE];
                     42: extern char mfsiobuf[];
                     43: #endif
                     44: 
                     45: /*
                     46:  * mfs vnode operations.
                     47:  */
                     48: int    mfs_open(),
                     49:        mfs_strategy(),
                     50:        mfs_bmap(),
                     51:        mfs_ioctl(),
                     52:        mfs_close(),
                     53:        mfs_inactive(),
                     54:        mfs_print(),
                     55:        mfs_badop(),
                     56:        mfs_nullop();
                     57: 
                     58: struct vnodeops mfs_vnodeops = {
                     59:        mfs_badop,              /* lookup */
                     60:        mfs_badop,              /* create */
                     61:        mfs_badop,              /* mknod */
                     62:        mfs_open,               /* open */
                     63:        mfs_close,              /* close */
                     64:        mfs_badop,              /* access */
                     65:        mfs_badop,              /* getattr */
                     66:        mfs_badop,              /* setattr */
                     67:        mfs_badop,              /* read */
                     68:        mfs_badop,              /* write */
                     69:        mfs_ioctl,              /* ioctl */
                     70:        mfs_badop,              /* select */
                     71:        mfs_badop,              /* mmap */
                     72:        mfs_badop,              /* fsync */
                     73:        mfs_badop,              /* seek */
                     74:        mfs_badop,              /* remove */
                     75:        mfs_badop,              /* link */
                     76:        mfs_badop,              /* rename */
                     77:        mfs_badop,              /* mkdir */
                     78:        mfs_badop,              /* rmdir */
                     79:        mfs_badop,              /* symlink */
                     80:        mfs_badop,              /* readdir */
                     81:        mfs_badop,              /* readlink */
                     82:        mfs_badop,              /* abortop */
                     83:        mfs_inactive,           /* inactive */
                     84:        mfs_nullop,             /* reclaim */
                     85:        mfs_nullop,             /* lock */
                     86:        mfs_nullop,             /* unlock */
                     87:        mfs_bmap,               /* bmap */
                     88:        mfs_strategy,           /* strategy */
                     89:        mfs_print,              /* print */
                     90:        mfs_nullop,             /* islocked */
                     91: };
                     92: 
                     93: /*
                     94:  * Vnode Operations.
                     95:  *
                     96:  * Open called to allow memory filesystem to initialize and
                     97:  * validate before actual IO. Record our process identifier
                     98:  * so we can tell when we are doing I/O to ourself.
                     99:  */
                    100: /* ARGSUSED */
                    101: mfs_open(vp, mode, cred)
                    102:        register struct vnode *vp;
                    103:        int mode;
                    104:        struct ucred *cred;
                    105: {
                    106: 
                    107:        if (vp->v_type != VBLK) {
                    108:                panic("mfs_ioctl not VBLK");
                    109:                /* NOTREACHED */
                    110:        }
                    111:        return (0);
                    112: }
                    113: 
                    114: /*
                    115:  * Ioctl operation.
                    116:  */
                    117: /* ARGSUSED */
                    118: mfs_ioctl(vp, com, data, fflag, cred)
                    119:        struct vnode *vp;
                    120:        int com;
                    121:        caddr_t data;
                    122:        int fflag;
                    123:        struct ucred *cred;
                    124: {
                    125: 
                    126:        return (-1);
                    127: }
                    128: 
                    129: /*
                    130:  * Pass I/O requests to the memory filesystem process.
                    131:  */
                    132: mfs_strategy(bp)
                    133:        register struct buf *bp;
                    134: {
                    135:        register struct mfsnode *mfsp;
                    136:        struct vnode *vp;
                    137: 
                    138:        if (vfinddev(bp->b_dev, VBLK, &vp) || vp->v_usecount == 0)
                    139:                panic("mfs_strategy: bad dev");
                    140:        mfsp = VTOMFS(vp);
                    141:        if (mfsp->mfs_pid == u.u_procp->p_pid) {
                    142:                mfs_doio(bp, mfsp->mfs_baseoff);
                    143:        } else {
                    144:                bp->av_forw = mfsp->mfs_buflist;
                    145:                mfsp->mfs_buflist = bp;
                    146:                wakeup((caddr_t)vp);
                    147:        }
                    148:        return (0);
                    149: }
                    150: 
                    151: #if defined(vax) || defined(tahoe)
                    152: /*
                    153:  * Memory file system I/O.
                    154:  *
                    155:  * Essentially play ubasetup() and disk interrupt service routine by
                    156:  * doing the copies to or from the memfs process. If doing physio
                    157:  * (i.e. pagein), we must map the I/O through the kernel virtual
                    158:  * address space.
                    159:  */
                    160: mfs_doio(bp, base)
                    161:        register struct buf *bp;
                    162:        caddr_t base;
                    163: {
                    164:        register struct pte *pte, *ppte;
                    165:        register caddr_t vaddr;
                    166:        int off, npf, npf2, reg;
                    167:        caddr_t kernaddr, offset;
                    168: 
                    169:        /*
                    170:         * For phys I/O, map the b_addr into kernel virtual space using
                    171:         * the Mfsiomap pte's.
                    172:         */
                    173:        if ((bp->b_flags & B_PHYS) == 0) {
                    174:                kernaddr = bp->b_un.b_addr;
                    175:        } else {
                    176:                if (bp->b_flags & (B_PAGET | B_UAREA | B_DIRTY))
                    177:                        panic("swap on memfs?");
                    178:                off = (int)bp->b_un.b_addr & PGOFSET;
                    179:                npf = btoc(bp->b_bcount + off);
                    180:                /*
                    181:                 * Get some mapping page table entries
                    182:                 */
                    183:                while ((reg = rmalloc(mfsmap, (long)npf)) == 0) {
                    184:                        mfsmap_want++;
                    185:                        sleep((caddr_t)&mfsmap_want, PZERO-1);
                    186:                }
                    187:                reg--;
                    188:                pte = vtopte(bp->b_proc, btop(bp->b_un.b_addr));
                    189:                /*
                    190:                 * Do vmaccess() but with the Mfsiomap page table.
                    191:                 */
                    192:                ppte = &Mfsiomap[reg];
                    193:                vaddr = &mfsiobuf[reg * NBPG];
                    194:                kernaddr = vaddr + off;
                    195:                for (npf2 = npf; npf2; npf2--) {
                    196:                        mapin(ppte, (u_int)vaddr, pte->pg_pfnum,
                    197:                                (int)(PG_V|PG_KW));
                    198: #if defined(tahoe)
                    199:                        if ((bp->b_flags & B_READ) == 0)
                    200:                                mtpr(P1DC, vaddr);
                    201: #endif
                    202:                        ppte++;
                    203:                        pte++;
                    204:                        vaddr += NBPG;
                    205:                }
                    206:        }
                    207:        offset = base + (bp->b_blkno << DEV_BSHIFT);
                    208:        if (bp->b_flags & B_READ)
                    209:                bp->b_error = copyin(offset, kernaddr, bp->b_bcount);
                    210:        else
                    211:                bp->b_error = copyout(kernaddr, offset, bp->b_bcount);
                    212:        if (bp->b_error)
                    213:                bp->b_flags |= B_ERROR;
                    214:        /*
                    215:         * Release pte's used by physical I/O.
                    216:         */
                    217:        if (bp->b_flags & B_PHYS) {
                    218:                rmfree(mfsmap, (long)npf, (long)++reg);
                    219:                if (mfsmap_want) {
                    220:                        mfsmap_want = 0;
                    221:                        wakeup((caddr_t)&mfsmap_want);
                    222:                }
                    223:        }
                    224:        biodone(bp);
                    225: }
                    226: #endif /* vax || tahoe */
                    227: 
                    228: #if defined(hp300) || defined(i386)
                    229: /*
                    230:  * Memory file system I/O.
                    231:  *
                    232:  * Trivial on the HP since buffer has already been mapping into KVA space.
                    233:  */
                    234: mfs_doio(bp, base)
                    235:        register struct buf *bp;
                    236:        caddr_t base;
                    237: {
                    238:        base += (bp->b_blkno << DEV_BSHIFT);
                    239:        if (bp->b_flags & B_READ)
                    240:                bp->b_error = copyin(base, bp->b_un.b_addr, bp->b_bcount);
                    241:        else
                    242:                bp->b_error = copyout(bp->b_un.b_addr, base, bp->b_bcount);
                    243:        if (bp->b_error)
                    244:                bp->b_flags |= B_ERROR;
                    245:        biodone(bp);
                    246: }
                    247: #endif
                    248: 
                    249: /*
                    250:  * This is a noop, simply returning what one has been given.
                    251:  */
                    252: mfs_bmap(vp, bn, vpp, bnp)
                    253:        struct vnode *vp;
                    254:        daddr_t bn;
                    255:        struct vnode **vpp;
                    256:        daddr_t *bnp;
                    257: {
                    258: 
                    259:        if (vpp != NULL)
                    260:                *vpp = vp;
                    261:        if (bnp != NULL)
                    262:                *bnp = bn;
                    263:        return (0);
                    264: }
                    265: 
                    266: /*
                    267:  * Memory filesystem close routine
                    268:  */
                    269: /* ARGSUSED */
                    270: mfs_close(vp, flag, cred)
                    271:        register struct vnode *vp;
                    272:        int flag;
                    273:        struct ucred *cred;
                    274: {
                    275:        register struct mfsnode *mfsp = VTOMFS(vp);
                    276:        register struct buf *bp;
                    277: 
                    278:        /*
                    279:         * Finish any pending I/O requests.
                    280:         */
                    281:        while (bp = mfsp->mfs_buflist) {
                    282:                mfsp->mfs_buflist = bp->av_forw;
                    283:                mfs_doio(bp, mfsp->mfs_baseoff);
                    284:                wakeup((caddr_t)bp);
                    285:        }
                    286:        /*
                    287:         * On last close of a memory filesystem
                    288:         * we must invalidate any in core blocks, so that
                    289:         * we can, free up its vnode.
                    290:         */
                    291:        vflushbuf(vp, 0);
                    292:        if (vinvalbuf(vp, 1))
                    293:                return (0);
                    294:        /*
                    295:         * There should be no way to have any more uses of this
                    296:         * vnode, so if we find any other uses, it is a panic.
                    297:         */
                    298:        if (vp->v_usecount > 1)
                    299:                printf("mfs_close: ref count %d > 1\n", vp->v_usecount);
                    300:        if (vp->v_usecount > 1 || mfsp->mfs_buflist)
                    301:                panic("mfs_close");
                    302:        /*
                    303:         * Send a request to the filesystem server to exit.
                    304:         */
                    305:        mfsp->mfs_buflist = (struct buf *)(-1);
                    306:        wakeup((caddr_t)vp);
                    307:        return (0);
                    308: }
                    309: 
                    310: /*
                    311:  * Memory filesystem inactive routine
                    312:  */
                    313: /* ARGSUSED */
                    314: mfs_inactive(vp)
                    315:        struct vnode *vp;
                    316: {
                    317: 
                    318:        if (VTOMFS(vp)->mfs_buflist != (struct buf *)(-1))
                    319:                panic("mfs_inactive: not inactive");
                    320:        return (0);
                    321: }
                    322: 
                    323: /*
                    324:  * Print out the contents of an mfsnode.
                    325:  */
                    326: mfs_print(vp)
                    327:        struct vnode *vp;
                    328: {
                    329:        register struct mfsnode *mfsp = VTOMFS(vp);
                    330: 
                    331:        printf("tag VT_MFS, pid %d, base %d, size %d\n", mfsp->mfs_pid,
                    332:                mfsp->mfs_baseoff, mfsp->mfs_size);
                    333: }
                    334: 
                    335: /*
                    336:  * Block device bad operation
                    337:  */
                    338: mfs_badop()
                    339: {
                    340: 
                    341:        panic("mfs_badop called\n");
                    342:        /* NOTREACHED */
                    343: }
                    344: 
                    345: /*
                    346:  * Block device null operation
                    347:  */
                    348: mfs_nullop()
                    349: {
                    350: 
                    351:        return (0);
                    352: }
                    353: 
                    354: /*
                    355:  * Memory based filesystem initialization.
                    356:  */
                    357: mfs_init()
                    358: {
                    359: 
                    360: #if !defined(hp300) && !defined(i386)
                    361:        rminit(mfsmap, (long)MFS_MAPREG, (long)1, "mfs mapreg", MFS_MAPSIZE);
                    362: #endif
                    363: }

unix.superglobalmegacorp.com

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