xv6-riscv-kernel/memide.c

61 lines
1.2 KiB
C
Raw Normal View History

2011-01-11 19:54:23 +01:00
// Fake IDE disk; stores blocks in memory.
// Useful for running kernel without scratch disk.
#include "types.h"
#include "defs.h"
#include "param.h"
#include "mmu.h"
#include "proc.h"
#include "x86.h"
#include "traps.h"
#include "spinlock.h"
#include "sleeplock.h"
#include "fs.h"
2011-01-11 19:54:23 +01:00
#include "buf.h"
extern uchar _binary_fs_img_start[], _binary_fs_img_size[];
static int disksize;
static uchar *memdisk;
void
ideinit(void)
{
memdisk = _binary_fs_img_start;
disksize = (uint)_binary_fs_img_size/BSIZE;
2011-01-11 19:54:23 +01:00
}
// Interrupt handler.
void
ideintr(void)
{
// no-op
}
// Sync buf with disk.
2011-01-11 19:54:23 +01:00
// If B_DIRTY is set, write buf to disk, clear B_DIRTY, set B_VALID.
// Else if B_VALID is not set, read buf from disk, set B_VALID.
void
iderw(struct buf *b)
{
uchar *p;
2016-09-13 20:51:44 +02:00
if(!holdingsleep(&b->lock))
panic("iderw: buf not locked");
2011-01-11 19:54:23 +01:00
if((b->flags & (B_VALID|B_DIRTY)) == B_VALID)
panic("iderw: nothing to do");
if(b->dev != 1)
panic("iderw: request not for disk 1");
if(b->blockno >= disksize)
panic("iderw: block out of range");
2011-01-11 19:54:23 +01:00
p = memdisk + b->blockno*BSIZE;
2011-01-11 19:54:23 +01:00
if(b->flags & B_DIRTY){
b->flags &= ~B_DIRTY;
memmove(p, b->data, BSIZE);
2011-01-11 19:54:23 +01:00
} else
memmove(b->data, p, BSIZE);
2011-01-11 19:54:23 +01:00
b->flags |= B_VALID;
}