xv6 crash

xv6 crash

实验要求:
  探索xv6的log功能。主要就是创建1个crash,然后观察recover的过程。xv6的log重点是将文件系统所有的磁盘更新操作原子化,比如在创建1个文件时涉及到在目录中添加新入口,并标记新文件的inode为使用中。如果没有log的话,在两次操作之间发送1个crash会导致重启后文件系统处于不正确状态。
实验步骤:
1、修改log.c如下:

xv6 crash

2、修改recover_from_log函数如下:
xv6 crash

3、修改Makefile如下:
xv6 crash

4、删除xv6-public文件夹中fs.img文件
5、进行测试,运行xv6,并在shell里创建1个文件,将发送panic:
xv6 crash

6、重新运行xc6,查看文件的内容,也会发生panic:
xv6 crash

7、恢复recover_from_log函数:
xv6 crash

8、再次启动xv6,再次读入a,没有crash现象:
xv6 crash