2025-12-10 14:14:31 +00:00
|
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
|
|
|
|
|
|
use aster_util::printer::VmPrinter;
|
|
|
|
|
|
|
|
|
|
use super::TidDirOps;
|
|
|
|
|
use crate::{
|
|
|
|
|
fs::{
|
|
|
|
|
procfs::template::{FileOps, ProcFileBuilder},
|
|
|
|
|
utils::{Inode, mkmod},
|
|
|
|
|
},
|
|
|
|
|
prelude::*,
|
2026-01-22 03:49:15 +00:00
|
|
|
process::{Process, posix_thread::AsPosixThread},
|
2025-12-15 03:35:09 +00:00
|
|
|
vm::vmar::{VMAR_CAP_ADDR, VMAR_LOWEST_ADDR},
|
2025-12-10 14:14:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/// Represents the inode at `/proc/[pid]/task/[tid]/maps` (and also `/proc/[pid]/maps`).
|
|
|
|
|
pub struct MapsFileOps(Arc<Process>);
|
|
|
|
|
|
|
|
|
|
impl MapsFileOps {
|
|
|
|
|
pub fn new_inode(dir: &TidDirOps, parent: Weak<dyn Inode>) -> Arc<dyn Inode> {
|
|
|
|
|
let process_ref = dir.process_ref.clone();
|
|
|
|
|
// Reference: <https://elixir.bootlin.com/linux/v6.16.5/source/fs/proc/base.c#L3343>
|
|
|
|
|
ProcFileBuilder::new(Self(process_ref), mkmod!(a+r))
|
|
|
|
|
.parent(parent)
|
|
|
|
|
.build()
|
|
|
|
|
.unwrap()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
impl FileOps for MapsFileOps {
|
|
|
|
|
fn read_at(&self, offset: usize, writer: &mut VmWriter) -> Result<usize> {
|
|
|
|
|
let mut printer = VmPrinter::new_skip(writer, offset);
|
|
|
|
|
|
|
|
|
|
let vmar_guard = self.0.lock_vmar();
|
|
|
|
|
let Some(vmar) = vmar_guard.as_ref() else {
|
|
|
|
|
return_errno_with_message!(Errno::ESRCH, "the process has exited");
|
|
|
|
|
};
|
|
|
|
|
|
2026-01-22 03:49:15 +00:00
|
|
|
let current = current_thread!();
|
|
|
|
|
let fs_ref = current.as_posix_thread().unwrap().read_fs();
|
|
|
|
|
let path_resolver = fs_ref.resolver().read();
|
2025-12-10 14:14:31 +00:00
|
|
|
|
2025-12-15 03:35:09 +00:00
|
|
|
let guard = vmar.query(VMAR_LOWEST_ADDR..VMAR_CAP_ADDR);
|
2025-12-10 14:14:31 +00:00
|
|
|
for vm_mapping in guard.iter() {
|
2026-01-22 03:49:15 +00:00
|
|
|
vm_mapping.print_to_maps(&mut printer, vmar, &path_resolver)?;
|
2025-12-10 14:14:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Ok(printer.bytes_written())
|
|
|
|
|
}
|
|
|
|
|
}
|