From 01098eb113c2d7ea372f121993044f4eaf1f0adf Mon Sep 17 00:00:00 2001 From: Yifan Wu Date: Thu, 15 Apr 2021 12:09:22 +0800 Subject: [PATCH] Fixed a bug that the efs lock was not be held correctly --- easy-fs/src/efs.rs | 6 +++++- easy-fs/src/vfs.rs | 23 ++++++++++++++--------- 2 files changed, 19 insertions(+), 10 deletions(-) diff --git a/easy-fs/src/efs.rs b/easy-fs/src/efs.rs index 6b3db0fb..4cc541e4 100644 --- a/easy-fs/src/efs.rs +++ b/easy-fs/src/efs.rs @@ -112,8 +112,12 @@ impl EasyFileSystem { pub fn root_inode(efs: &Arc>) -> Inode { let block_device = Arc::clone(&efs.lock().block_device); + // acquire efs lock temporarily + let (block_id, block_offset) = efs.lock().get_disk_inode_pos(0); + // release efs lock Inode::new( - 0, + block_id, + block_offset, Arc::clone(efs), block_device, ) diff --git a/easy-fs/src/vfs.rs b/easy-fs/src/vfs.rs index 58f2be78..de4f41db 100644 --- a/easy-fs/src/vfs.rs +++ b/easy-fs/src/vfs.rs @@ -20,12 +20,13 @@ pub struct Inode { } impl Inode { + /// We should not acquire efs lock here. pub fn new( - inode_id: u32, + block_id: u32, + block_offset: usize, fs: Arc>, block_device: Arc, ) -> Self { - let (block_id, block_offset) = fs.lock().get_disk_inode_pos(inode_id); Self { block_id: block_id as usize, block_offset, @@ -74,12 +75,14 @@ impl Inode { } pub fn find(&self, name: &str) -> Option> { - let _ = self.fs.lock(); + let fs = self.fs.lock(); self.read_disk_inode(|disk_inode| { self.find_inode_id(name, disk_inode) .map(|inode_id| { + let (block_id, block_offset) = fs.get_disk_inode_pos(inode_id); Arc::new(Self::new( - inode_id, + block_id, + block_offset, self.fs.clone(), self.block_device.clone(), )) @@ -140,18 +143,20 @@ impl Inode { &self.block_device, ); }); - // release efs lock manually because we will acquire it again in Inode::new - drop(fs); + + let (block_id, block_offset) = fs.get_disk_inode_pos(new_inode_id); // return inode Some(Arc::new(Self::new( - new_inode_id, + block_id, + block_offset, self.fs.clone(), self.block_device.clone(), ))) + // release efs lock automatically by compiler } pub fn ls(&self) -> Vec { - let _ = self.fs.lock(); + let _fs = self.fs.lock(); self.read_disk_inode(|disk_inode| { let file_count = (disk_inode.size as usize) / DIRENT_SZ; let mut v: Vec = Vec::new(); @@ -172,7 +177,7 @@ impl Inode { } pub fn read_at(&self, offset: usize, buf: &mut [u8]) -> usize { - let _ = self.fs.lock(); + let _fs = self.fs.lock(); self.read_disk_inode(|disk_inode| { disk_inode.read_at(offset, buf, &self.block_device) })