mirror of
https://github.com/asterinas/asterinas.git
synced 2025-06-24 18:03:25 +00:00
Do release_range_locks
in Drop
This commit is contained in:
committed by
Tate, Hongliang Tian
parent
50924d6693
commit
293f1ff4c9
@ -1,7 +1,5 @@
|
|||||||
// SPDX-License-Identifier: MPL-2.0
|
// SPDX-License-Identifier: MPL-2.0
|
||||||
|
|
||||||
#![expect(unused_variables)]
|
|
||||||
|
|
||||||
use core::sync::atomic::{AtomicU8, Ordering};
|
use core::sync::atomic::{AtomicU8, Ordering};
|
||||||
|
|
||||||
use aster_util::slot_vec::SlotVec;
|
use aster_util::slot_vec::SlotVec;
|
||||||
@ -10,7 +8,6 @@ use ostd::sync::RwArc;
|
|||||||
use super::{
|
use super::{
|
||||||
file_handle::FileLike,
|
file_handle::FileLike,
|
||||||
fs_resolver::{FsPath, FsResolver, AT_FDCWD},
|
fs_resolver::{FsPath, FsResolver, AT_FDCWD},
|
||||||
inode_handle::InodeHandle,
|
|
||||||
utils::{AccessMode, InodeMode},
|
utils::{AccessMode, InodeMode},
|
||||||
};
|
};
|
||||||
use crate::{
|
use crate::{
|
||||||
@ -130,12 +127,7 @@ impl FileTable {
|
|||||||
self.notify_fd_events(&events);
|
self.notify_fd_events(&events);
|
||||||
removed_entry.notify_fd_events(&events);
|
removed_entry.notify_fd_events(&events);
|
||||||
|
|
||||||
let closed_file = removed_entry.file;
|
Some(removed_entry.file)
|
||||||
if let Some(closed_inode_file) = closed_file.downcast_ref::<InodeHandle>() {
|
|
||||||
// FIXME: Operation below should not hold any mutex if `self` is protected by a spinlock externally
|
|
||||||
closed_inode_file.release_range_locks();
|
|
||||||
}
|
|
||||||
Some(closed_file)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn close_all(&mut self) -> Vec<Arc<dyn FileLike>> {
|
pub fn close_all(&mut self) -> Vec<Arc<dyn FileLike>> {
|
||||||
@ -168,11 +160,7 @@ impl FileTable {
|
|||||||
let events = FdEvents::Close(fd);
|
let events = FdEvents::Close(fd);
|
||||||
self.notify_fd_events(&events);
|
self.notify_fd_events(&events);
|
||||||
removed_entry.notify_fd_events(&events);
|
removed_entry.notify_fd_events(&events);
|
||||||
closed_files.push(removed_entry.file.clone());
|
closed_files.push(removed_entry.file);
|
||||||
if let Some(inode_file) = removed_entry.file.downcast_ref::<InodeHandle>() {
|
|
||||||
// FIXME: Operation below should not hold any mutex if `self` is protected by a spinlock externally
|
|
||||||
inode_file.release_range_locks();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
closed_files
|
closed_files
|
||||||
@ -412,7 +400,7 @@ impl OwnerObserver {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Observer<IoEvents> for OwnerObserver {
|
impl Observer<IoEvents> for OwnerObserver {
|
||||||
fn on_events(&self, events: &IoEvents) {
|
fn on_events(&self, _events: &IoEvents) {
|
||||||
if self.file.status_flags().contains(StatusFlags::O_ASYNC)
|
if self.file.status_flags().contains(StatusFlags::O_ASYNC)
|
||||||
&& let Some(process) = self.owner.upgrade()
|
&& let Some(process) = self.owner.upgrade()
|
||||||
{
|
{
|
||||||
|
@ -387,6 +387,7 @@ impl<R> InodeHandle<R> {
|
|||||||
|
|
||||||
impl<R> Drop for InodeHandle<R> {
|
impl<R> Drop for InodeHandle<R> {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
|
self.release_range_locks();
|
||||||
self.unlock_flock();
|
self.unlock_flock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user