summaryrefslogtreecommitdiff
path: root/fs.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs.c')
-rw-r--r--fs.c45
1 files changed, 13 insertions, 32 deletions
diff --git a/fs.c b/fs.c
index fbb4a8c..cf717a2 100644
--- a/fs.c
+++ b/fs.c
@@ -450,43 +450,24 @@ void
wdir(struct inode *dp, char *name, uint ino)
{
uint off;
- struct buf *bp = 0;
- struct dirent *ep = 0;
+ struct dirent de;
int i;
- int lb;
-
- if(dp->size % BSIZE)
- dp->size += (BSIZE - dp->size % BSIZE);
-
- for(off = 0; off < dp->size; off += BSIZE) {
- bp = bread(dp->dev, bmap(dp, off / BSIZE));
- for(ep = (struct dirent *) bp->data;
- ep < (struct dirent *) (bp->data + BSIZE);
- ep++){
- if(ep->inum == 0)
- goto found;
- }
- brelse(bp);
- }
- lb = dp->size / BSIZE;
- if (lb >= NDIRECT) {
- panic ("wdir: too many entries");
+
+ for(off = 0; off < dp->size; off += sizeof(de)){
+ if(readi(dp, (char *) &de, off, sizeof(de)) != sizeof(de))
+ panic("wdir read");
+ if(de.inum == 0)
+ break;
}
- dp->addrs[lb] = balloc(dp->dev);
- bp = bread(dp->dev, dp->addrs[lb]);
- memset(bp->data, 0, BSIZE);
- ep = (struct dirent *) (bp->data);
- dp->size += BSIZE;
- found:
- ep->inum = ino;
+ de.inum = ino;
for(i = 0; i < DIRSIZ && name[i]; i++)
- ep->name[i] = name[i];
+ de.name[i] = name[i];
for( ; i < DIRSIZ; i++)
- ep->name[i] = '\0';
- bwrite (bp, bmap(dp, off/BSIZE)); // write directory block
- brelse(bp);
- iupdate(dp);
+ de.name[i] = '\0';
+
+ if(writei(dp, (char *) &de, off, sizeof(de)) != sizeof(de))
+ panic("wdir write");
}
struct inode *