Annotation of researchv10no/sys/os/rdwri.c, revision 1.1.1.1

1.1       root        1: #include "sys/param.h"
                      2: #include "sys/inode.h"
                      3: #include "sys/user.h"
                      4: #include "sys/conf.h"
                      5: #include "sys/buf.h"
                      6: 
                      7: /*
                      8:  * Read the file corresponding to
                      9:  * the inode pointed at by the argument.
                     10:  * The actual read arguments are found
                     11:  * in the variables:
                     12:  *     u_base          core address for destination
                     13:  *     u_offset        byte offset in file
                     14:  *     u_count         number of bytes to read
                     15:  *     u_segflg        read to kernel/user
                     16:  */
                     17: readi(ip)
                     18: register struct inode *ip;
                     19: {
                     20: 
                     21:        if(u.u_count == 0)
                     22:                return;
                     23:        ip->i_flag |= IACC;
                     24:        if (ip->i_sptr) {
                     25:                u.u_nbadio = 0; /* approximates a bad-count per stream */
                     26:                stread(ip);
                     27:                return;
                     28:        }
                     29:        (*fstypsw[ip->i_fstyp]->t_read)(ip);
                     30: }
                     31: 
                     32: /*
                     33:  * Write the file corresponding to
                     34:  * the inode pointed at by the argument.
                     35:  * The actual write arguments are found
                     36:  * in the variables:
                     37:  *     u_base          core address for source
                     38:  *     u_offset        byte offset in file
                     39:  *     u_count         number of bytes to write
                     40:  *     u_segflg        write to kernel/user/user I
                     41:  */
                     42: 
                     43: writei(ip)
                     44: register struct inode *ip;
                     45: {
                     46: 
                     47:        if (ip->i_sptr) {
                     48:                ip->i_flag |= IUPD|ICHG;
                     49:                stwrite(ip);
                     50:                return;
                     51:        }
                     52:        (*fstypsw[ip->i_fstyp]->t_write)(ip);
                     53: }
                     54: 
                     55: /*
                     56:  * Return the logical maximum
                     57:  * of the 2 arguments.
                     58:  */
                     59: unsigned
                     60: max(a, b)
                     61: unsigned a, b;
                     62: {
                     63: 
                     64:        if(a > b)
                     65:                return(a);
                     66:        return(b);
                     67: }
                     68: 
                     69: /*
                     70:  * Return the logical minimum
                     71:  * of the 2 arguments.
                     72:  */
                     73: unsigned
                     74: min(a, b)
                     75: unsigned a, b;
                     76: {
                     77: 
                     78:        if(a < b)
                     79:                return(a);
                     80:        return(b);
                     81: }
                     82: 
                     83: /*
                     84:  * Move n bytes at byte location
                     85:  * &bp->b_un.b_addr[o] to/from (flag) the
                     86:  * user/kernel (u.segflg) area starting at u.base.
                     87:  * Update all the arguments by the number
                     88:  * of bytes moved.
                     89:  *
                     90:  * Botchy VAX-ism: believes user I and user D are the same
                     91:  */
                     92: iomove(cp, n, flag)
                     93:        register caddr_t cp;
                     94:        register unsigned n;
                     95: {
                     96:        register int t;
                     97: 
                     98:        if (n==0)
                     99:                return;
                    100:        if (u.u_segflg != SEGSYS) {
                    101:                if (flag==B_WRITE)
                    102:                        t = copyin(u.u_base, (caddr_t)cp, n);
                    103:                else
                    104:                        t = copyout((caddr_t)cp, u.u_base, n);
                    105:                if (t) {
                    106:                        u.u_error = EFAULT;
                    107:                        return;
                    108:                }
                    109:        } else
                    110:                if (flag == B_WRITE)
                    111:                        bcopy(u.u_base, (caddr_t)cp, n);
                    112:                else
                    113:                        bcopy((caddr_t)cp, u.u_base, n);
                    114:        u.u_base += n;
                    115:        u.u_offset = Lladd(u.u_offset, n);
                    116:        u.u_count -= n;
                    117: }

unix.superglobalmegacorp.com

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