parent
8860f1e4a3
commit
e7657356a2
@ -0,0 +1,32 @@
|
||||
//! Custom nonstandard syscalls
|
||||
use rcore_memory::memory_set::handler::Linear;
|
||||
use rcore_memory::memory_set::MemoryAttr;
|
||||
use super::*;
|
||||
use crate::drivers::bus::pci;
|
||||
|
||||
pub fn sys_map_pci_device(vendor: usize, product: usize) -> SysResult {
|
||||
info!(
|
||||
"map_pci_device: vendor: {}, product: {}",
|
||||
vendor, product
|
||||
);
|
||||
if let Some(tag) = pci::find_device(vendor as u32, product as u32) {
|
||||
// Get BAR0 memory
|
||||
if let Some((base, len)) = unsafe { tag.get_bar_mem(0) } {
|
||||
let mut proc = process();
|
||||
let virt_addr = proc.memory_set.find_free_area(0, len);
|
||||
let attr = MemoryAttr::default().user();
|
||||
proc.memory_set.push(
|
||||
virt_addr,
|
||||
virt_addr + len,
|
||||
attr,
|
||||
Linear::new(base as isize - virt_addr as isize),
|
||||
"pci",
|
||||
);
|
||||
Ok(virt_addr)
|
||||
} else {
|
||||
Err(SysError::ENOENT)
|
||||
}
|
||||
} else {
|
||||
Err(SysError::ENOENT)
|
||||
}
|
||||
}
|
Loading…
Reference in new issue