Ext2FileObject

Struct Ext2FileObject 

Source
pub struct Ext2FileObject {
    inode_number: u32,
    file_id: u64,
    position: Mutex<u64>,
    size_override: Mutex<Option<usize>>,
    dirty: Mutex<bool>,
    filesystem: RwLock<Option<Weak<dyn FileSystemOperations>>>,
    mmap_backing: RwLock<Option<Box<[Page]>>>,
    mmap_backing_len: Mutex<usize>,
    mmap_ranges: RwLock<BTreeMap<usize, MmapRange>>,
}
Expand description

ext2 File Object

Handles file operations for regular files in the ext2 filesystem.

Fields§

§inode_number: u32

Inode number of the file

§file_id: u64

File ID

§position: Mutex<u64>

Current position in the file

§size_override: Mutex<Option<usize>>

Optional logical size override after in-memory writes (not yet flushed)

§dirty: Mutex<bool>

Dirty flag indicating in-memory changes not yet persisted to disk

§filesystem: RwLock<Option<Weak<dyn FileSystemOperations>>>

Weak reference to the filesystem

§mmap_backing: RwLock<Option<Box<[Page]>>>

Page-aligned backing for mmap operations (lazy initialized)

§mmap_backing_len: Mutex<usize>

Byte length of the mmap backing (file size snapshot)

§mmap_ranges: RwLock<BTreeMap<usize, MmapRange>>

Active mmap ranges keyed by starting virtual address

Implementations§

Source§

impl Ext2FileObject

Source

pub fn new(inode_number: u32, file_id: u64) -> Self

Create a new ext2 file object

Source

pub fn set_filesystem(&self, fs: Weak<dyn FileSystemOperations>)

Set the filesystem reference

Source

pub fn file_id(&self) -> u64

Get the file ID

Source

fn sync_to_disk(&self) -> Result<(), StreamError>

Flush current page-cache-backed content to disk.

Source

fn effective_size(&self, inode_size: usize) -> usize

Source

fn ensure_mmap_backing( &self, file_size: usize, required_size: usize, ) -> Result<(), StreamError>

Trait Implementations§

Source§

impl ControlOps for Ext2FileObject

Source§

fn control(&self, command: u32, arg: usize) -> Result<i32, &'static str>

Perform a control operation Read more
Source§

fn supported_control_commands(&self) -> Vec<(u32, &'static str)>

Get a list of supported control commands Read more
Source§

impl Debug for Ext2FileObject

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Drop for Ext2FileObject

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl FileObject for Ext2FileObject

Source§

fn metadata(&self) -> Result<FileMetadata, StreamError>

Get metadata about the file
Source§

fn read_at(&self, offset: u64, buffer: &mut [u8]) -> Result<usize, StreamError>

Read data from a specific offset without changing internal position Read more
Source§

fn write_at(&self, offset: u64, buffer: &[u8]) -> Result<usize, StreamError>

Write data to a specific offset without changing internal position Read more
Source§

fn truncate(&self, size: u64) -> Result<(), StreamError>

Truncate the file to the specified size Read more
Source§

fn seek(&self, whence: SeekFrom) -> Result<u64, StreamError>

Seek to a position in the file stream
Source§

fn as_any(&self) -> &dyn Any

Source§

fn sync(&self) -> Result<(), StreamError>

Synchronize file content to storage Read more
Source§

impl MemoryMappingOps for Ext2FileObject

Source§

fn get_mapping_info( &self, offset: usize, length: usize, ) -> Result<(usize, usize, bool), &'static str>

Get mapping information for a region of the object Read more
Source§

fn get_mapping_info_with( &self, offset: usize, length: usize, is_shared: bool, ) -> Result<(usize, usize, bool), &'static str>

Get mapping information with sharing intent. Read more
Source§

fn on_mapped( &self, _vaddr: usize, _paddr: usize, _length: usize, _offset: usize, )

Notification that a mapping has been created Read more
Source§

fn on_unmapped(&self, vaddr: usize, _length: usize)

Notification that a mapping has been removed Read more
Source§

fn supports_mmap(&self) -> bool

Check if memory mapping is supported Read more
Source§

fn resolve_fault( &self, access: &AccessKind, map: &VirtualMemoryMap, ) -> Result<ResolveFaultResult, ResolveFaultError>

Source§

fn mmap_owner_name(&self) -> String

Diagnostic helper: return a short owner name for logging Read more
Source§

impl PageCacheCapable for Ext2FileObject

Source§

fn cache_id(&self) -> CacheId

Returns a stable CacheId for this file for the lifetime of the underlying filesystem instance.
Source§

impl Selectable for Ext2FileObject

Source§

fn current_ready(&self, interest: ReadyInterest) -> ReadySet

Return current readiness for the given interest set.
Source§

fn wait_until_ready( &self, _interest: ReadyInterest, _trapframe: &mut Trapframe, _timeout_ticks: Option<u64>, ) -> SelectWaitOutcome

Block the current task using the provided trapframe until the interest becomes ready or the optional timeout (in ticks) expires. Read more
Source§

fn is_nonblocking(&self) -> bool

Query whether non-blocking I/O semantics are enabled on this object.
Source§

fn set_nonblocking(&self, _enabled: bool)

Enable or disable non-blocking I/O semantics on this object. Read more
Source§

impl StreamOps for Ext2FileObject

Source§

fn read(&self, buffer: &mut [u8]) -> Result<usize, StreamError>

Read data from the stream
Source§

fn write(&self, buffer: &[u8]) -> Result<usize, StreamError>

Write data to the stream

Auto Trait Implementations§

§

impl !Freeze for Ext2FileObject

§

impl !RefUnwindSafe for Ext2FileObject

§

impl Send for Ext2FileObject

§

impl Sync for Ext2FileObject

§

impl Unpin for Ext2FileObject

§

impl !UnwindSafe for Ext2FileObject

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.