/* Copyright (C) 2003 Russ Cox, Massachusetts Institute of Technology */ /* See COPYRIGHT */ #include #include #include #include <9pclient.h> #include "fsimpl.h" long fspread(CFid *fid, void *buf, long n, vlong offset) { Fcall tx, rx; void *freep; uint msize; long nr; msize = fid->fs->msize - IOHDRSZ; if(n > msize) n = msize; tx.type = Tread; tx.fid = fid->fid; if(offset == -1){ qlock(&fid->lk); tx.offset = fid->offset; qunlock(&fid->lk); }else tx.offset = offset; tx.count = n; if(_fsrpc(fid->fs, &tx, &rx, &freep) < 0) return -1; if(rx.type == Rerror){ werrstr("%s", rx.ename); free(freep); return -1; } nr = rx.count; if(nr > n) nr = n; if(nr){ memmove(buf, rx.data, nr); if(offset == -1){ qlock(&fid->lk); fid->offset += nr; qunlock(&fid->lk); } } free(freep); return nr; } long fsread(CFid *fid, void *buf, long n) { return fspread(fid, buf, n, -1); } long fsreadn(CFid *fid, void *buf, long n) { long tot, nn; for(tot=0; tot