Annotation of researchv10dc/cmd/worm/oscsi/generic/readt.c, revision 1.1.1.1

1.1       root        1: #include       <stdio.h>
                      2: #include       "../scsi.h"
                      3: #include       "../scsish.h"
                      4: #include       "fns.h"
                      5: 
                      6: int
                      7: gen_readt(int niargs, int *iargs, int ncargs, char **cargs, char *err)
                      8: {
                      9:        struct scsi_cmd cmd;
                     10:        struct scsi_return ret;
                     11:        int n, i;
                     12:        unsigned long ns, ss;
                     13:        long bs, addr;
                     14:        long t1, t2;
                     15: 
                     16: #pragma ref ncargs
                     17: #pragma ref cargs
                     18: 
                     19:        if(niargs == 1)
                     20:                iargs[1] = 0;
                     21:        set10(cmd, 0x25, iargs[1]<<5, 0, 0, 0, 0, 0, 0, 0, 0);
                     22:        if(n = s_io(0, &cmd, 0, &ret, 8, err))
                     23:                return(n);
                     24:        ns = longat(&ret.data[0]);
                     25:        ss = longat(&ret.data[4]);
                     26:        bs = ss? sizeof(ret.data)/ss : 1;
                     27:        time(&t1);
                     28:        srand(t1);
                     29:        addr = nrand(ns-iargs[0])-1;
                     30:        printf("read(%d,%d): %d blocks @%d (chunk=%dx%d),", s_id, iargs[1], iargs[0], addr, bs, ss);
                     31:        fflush(stdout);
                     32:        time(&t1);
                     33:        for(i = iargs[0]; i > 0; i -= bs){
                     34:                set10(cmd, 0x28, iargs[1]<<5, addr>>24, addr>>16, addr>>8, addr,
                     35:                        0, 0, bs*0, 0);
                     36:                if(n = s_io(0, &cmd, 0, &ret, bs*ss, err))
                     37:                        return(n);
                     38:                addr += bs;
                     39:        }
                     40:        time(&t2);
                     41:        printf(" t=%ds (%.0fKB/s)\n", t2-t1, (iargs[0]*(float)ss/1024.)/((t1 == t2)? 1:t2-t1));
                     42:        return(0);
                     43: }

unix.superglobalmegacorp.com

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