xv6-riscv-kernel/kernel/ramdisk.c

46 lines
945 B
C
Raw Permalink Normal View History

2019-05-31 17:45:42 +02:00
//
// ramdisk that uses the disk image loaded by qemu -initrd fs.img
2019-05-31 17:45:42 +02:00
//
#include "types.h"
#include "riscv.h"
#include "defs.h"
#include "param.h"
#include "memlayout.h"
#include "spinlock.h"
#include "sleeplock.h"
#include "fs.h"
#include "buf.h"
void
ramdiskinit(void)
{
}
// 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
ramdiskrw(struct buf *b)
{
if(!holdingsleep(&b->lock))
panic("ramdiskrw: buf not locked");
2024-06-15 16:55:06 +02:00
if((b->flags & (B_VALID | B_DIRTY)) == B_VALID)
2019-05-31 17:45:42 +02:00
panic("ramdiskrw: nothing to do");
if(b->blockno >= FSSIZE)
panic("ramdiskrw: blockno too big");
2024-06-15 16:55:06 +02:00
u64 diskaddr = b->blockno * BSIZE;
2019-05-31 17:45:42 +02:00
char *addr = (char *)RAMDISK + diskaddr;
2024-06-15 16:55:06 +02:00
if(b->flags & B_DIRTY) {
2019-05-31 17:45:42 +02:00
// write
memmove(addr, b->data, BSIZE);
b->flags &= ~B_DIRTY;
} else {
// read
memmove(b->data, addr, BSIZE);
b->flags |= B_VALID;
}
}