Skip to content

Commit

Permalink
Move retry loop/sleep/wakeup in bio.c into sleeping locks
Browse files Browse the repository at this point in the history
  • Loading branch information
kaashoek committed Sep 12, 2016
1 parent 6670d3b commit 2adb7c2
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 28 deletions.
56 changes: 29 additions & 27 deletions bio.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@ binit(void)
for(b = bcache.buf; b < bcache.buf+NBUF; b++){
b->next = bcache.head.next;
b->prev = &bcache.head;
b->dev = -1;
initsleeplock(&b->lock, "buffer");
bcache.head.next->prev = b;
bcache.head.next = b;
Expand All @@ -66,33 +65,33 @@ bget(uint dev, uint blockno)

acquire(&bcache.lock);

//cprintf("bget %d\n", blockno);
loop:
// cprintf("bget %d\n", blockno);
// Is the block already cached?
for(b = bcache.head.next; b != &bcache.head; b = b->next){
if(b->dev == dev && b->blockno == blockno){
if(!holdingsleep(&b->lock)) {
acquiresleep(&b->lock);
//cprintf("return buffer %p for blk %d\n", b - bcache.buf, blockno);
release(&bcache.lock);
return b;
}
sleep(b, &bcache.lock);
goto loop;
//cprintf("bget %d; get sleep lock for buffer %p\n", blockno, b - bcache.buf);
b->refcnt++;
release(&bcache.lock);
acquiresleep(&b->lock);
//cprintf("bget: return buffer %p for blk %d\n", b - bcache.buf, blockno);
return b;
}
}

// Not cached; recycle some non-locked and clean buffer.
// Not cached; recycle some unused buffer and clean buffer
// "clean" because B_DIRTY and not locked means log.c
// hasn't yet committed the changes to the buffer.
for(b = bcache.head.prev; b != &bcache.head; b = b->prev){
if(!holdingsleep(&b->lock) && (b->flags & B_DIRTY) == 0){
if(b->refcnt == 0 && (b->flags & B_DIRTY) == 0) {
// cprintf("bget %d; use %p for %d\n", b - bcache.buf, blockno);
b->dev = dev;
b->blockno = blockno;
b->flags = 0; // XXX
acquiresleep(&b->lock);
//cprintf("return buffer %p for blk %d\n", b - bcache.buf, blockno);
b->flags = 0;
b->refcnt = 1;
release(&bcache.lock);
acquiresleep(&b->lock);
// cprintf("bget: return buffer %p for blk %d\n", b - bcache.buf, blockno);
return b;
}
}
Expand All @@ -116,7 +115,7 @@ bread(uint dev, uint blockno)
void
bwrite(struct buf *b)
{
if(b->lock.locked == 0)
if(!holdingsleep(&b->lock))
panic("bwrite");
b->flags |= B_DIRTY;
iderw(b);
Expand All @@ -127,20 +126,23 @@ bwrite(struct buf *b)
void
brelse(struct buf *b)
{
if(b->lock.locked == 0)
if(!holdingsleep(&b->lock))
panic("brelse");

acquire(&bcache.lock);

b->next->prev = b->prev;
b->prev->next = b->next;
b->next = bcache.head.next;
b->prev = &bcache.head;
bcache.head.next->prev = b;
bcache.head.next = b;
releasesleep(&b->lock);
wakeup(b);

acquire(&bcache.lock);
b->refcnt--;
if (b->refcnt == 0) {
// no one is waiting for it.
b->next->prev = b->prev;
b->prev->next = b->next;
b->next = bcache.head.next;
b->prev = &bcache.head;
bcache.head.next->prev = b;
bcache.head.next = b;
}

release(&bcache.lock);
}
//PAGEBREAK!
Expand Down
1 change: 1 addition & 0 deletions buf.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ struct buf {
uint dev;
uint blockno;
struct sleeplock lock;
uint refcnt;
struct buf *prev; // LRU cache list
struct buf *next;
struct buf *qnext; // disk queue
Expand Down
2 changes: 1 addition & 1 deletion defs.h
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ void popcli(void);

// sleeplock.c
void acquiresleep(struct sleeplock*);
void releasesleep(struct sleeplock*);
void releasesleep(struct sleeplock*);
int holdingsleep(struct sleeplock*);
void initsleeplock(struct sleeplock*, char*);

Expand Down

0 comments on commit 2adb7c2

Please sign in to comment.