asterinas/kernel/src/device/pty/mod.rs

49 lines
1.3 KiB
Rust

// SPDX-License-Identifier: MPL-2.0
use crate::{
fs::{
devpts::DevPts,
fs_resolver::{FsPath, FsResolver},
path::Dentry,
utils::{Inode, InodeMode, InodeType},
},
prelude::*,
};
#[allow(clippy::module_inception)]
mod pty;
pub use pty::{PtyMaster, PtySlave};
use spin::Once;
static DEV_PTS: Once<Dentry> = Once::new();
pub fn init() -> Result<()> {
let fs = FsResolver::new();
let dev = fs.lookup(&FsPath::try_from("/dev")?)?;
// Create the "pts" directory and mount devpts on it.
let devpts_dentry =
dev.new_fs_child("pts", InodeType::Dir, InodeMode::from_bits_truncate(0o755))?;
let devpts_mount_node = devpts_dentry.mount(DevPts::new())?;
let devpts = Dentry::new_fs_root(devpts_mount_node.clone());
DEV_PTS.call_once(|| devpts);
// Create the "ptmx" symlink.
let ptmx = dev.new_fs_child(
"ptmx",
InodeType::SymLink,
InodeMode::from_bits_truncate(0o777),
)?;
ptmx.inode().write_link("pts/ptmx")?;
Ok(())
}
pub fn new_pty_pair(index: u32, ptmx: Arc<dyn Inode>) -> Result<(Arc<PtyMaster>, Arc<PtySlave>)> {
debug!("pty index = {}", index);
let master = PtyMaster::new(ptmx, index);
let slave = PtySlave::new(&master);
Ok((master, slave))
}