forked from koniifer/ableos
More work on the psuedo STD lib and IPC
This commit is contained in:
parent
1ae1d2ceac
commit
080bb8b188
|
@ -47,6 +47,7 @@ pub fn handler(vm: &mut Vm) {
|
||||||
let buff_id = arch::hardware_random_u64();
|
let buff_id = arch::hardware_random_u64();
|
||||||
buffs.insert(buff_id, abc);
|
buffs.insert(buff_id, abc);
|
||||||
debug!("Buffer ID: {}", buff_id);
|
debug!("Buffer ID: {}", buff_id);
|
||||||
|
vm.registers[1] = hbvm::value::Value(buff_id);
|
||||||
}
|
}
|
||||||
2 => {
|
2 => {
|
||||||
// Delete buffer
|
// Delete buffer
|
||||||
|
@ -66,14 +67,31 @@ pub fn handler(vm: &mut Vm) {
|
||||||
match buffer_id {
|
match buffer_id {
|
||||||
1 => {
|
1 => {
|
||||||
log_msg_handler(vm, mem_addr, length);
|
log_msg_handler(vm, mem_addr, length);
|
||||||
// error!("Logging via IPC isn't quite ready")
|
|
||||||
}
|
}
|
||||||
buffer_id => {
|
buffer_id => {
|
||||||
info!("Message has been sent to {}", buffer_id)
|
let mut buffs = IPC_BUFFERS.lock();
|
||||||
|
let mut buff = buffs.get_mut(&buffer_id).unwrap();
|
||||||
|
let mut msg_vec = vec![];
|
||||||
|
|
||||||
|
for x in 0..(length as isize) {
|
||||||
|
let xyz = mem_addr as *const u8;
|
||||||
|
let value = unsafe { xyz.offset(x).read() };
|
||||||
|
msg_vec.push(value);
|
||||||
|
}
|
||||||
|
buff.push(msg_vec.clone());
|
||||||
|
info!("Message {:?} has been sent to {}", msg_vec, buffer_id);
|
||||||
|
drop(buffs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// 4
|
4 => {
|
||||||
|
let r2 = vm.registers[2].cast::<u64>();
|
||||||
|
|
||||||
|
let mut buffs = IPC_BUFFERS.lock();
|
||||||
|
let mut buff = buffs.get_mut(&r2).unwrap();
|
||||||
|
let msg = buff.pop();
|
||||||
|
info!("Recieve {:?} from Buffer({})", msg, r2);
|
||||||
|
}
|
||||||
// 5
|
// 5
|
||||||
_ => {
|
_ => {
|
||||||
log::error!("Syscall unknown {:?}", r1);
|
log::error!("Syscall unknown {:?}", r1);
|
||||||
|
@ -108,6 +126,7 @@ fn log_msg_handler(vm: &mut Vm, mem_addr: u64, length: usize) -> Result<(), LogE
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
pub enum LogError {
|
pub enum LogError {
|
||||||
InvalidLogFormat,
|
InvalidLogFormat,
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,8 +11,8 @@ pub enum BufferTypes {
|
||||||
}
|
}
|
||||||
/// Interproccess buffer
|
/// Interproccess buffer
|
||||||
pub struct IpcBuffer {
|
pub struct IpcBuffer {
|
||||||
protocol: Protocol,
|
pub protocol: Protocol,
|
||||||
buffer: BufferTypes,
|
pub buffer: BufferTypes,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IpcBuffer {
|
impl IpcBuffer {
|
||||||
|
@ -48,6 +48,24 @@ impl IpcBuffer {
|
||||||
pub fn validate_messages(&mut self) -> Result<(), IpcError> {
|
pub fn validate_messages(&mut self) -> Result<(), IpcError> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
pub fn push(&mut self, msg: Message) {
|
||||||
|
match &self.buffer {
|
||||||
|
BufferTypes::Unbound(buff) => buff.push(msg.clone()),
|
||||||
|
BufferTypes::Bound(buff) => {
|
||||||
|
let _ = buff.push(msg.clone());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
pub fn pop(&mut self) -> Message {
|
||||||
|
let msg = match &self.buffer {
|
||||||
|
BufferTypes::Unbound(buff) => buff.pop(),
|
||||||
|
BufferTypes::Bound(buff) => buff.pop(),
|
||||||
|
};
|
||||||
|
match msg {
|
||||||
|
Some(msg) => return msg,
|
||||||
|
None => panic!("Recieving msg error. No messages!"),
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/// Interprocess Communication Errors
|
/// Interprocess Communication Errors
|
||||||
pub enum IpcError {
|
pub enum IpcError {
|
||||||
|
|
|
@ -2,7 +2,11 @@
|
||||||
|
|
||||||
use {hashbrown::HashMap, hbvm::mem::Address};
|
use {hashbrown::HashMap, hbvm::mem::Address};
|
||||||
|
|
||||||
use crate::{capabilities, holeybytes::ExecThread, ipc::buffer::IpcBuffer};
|
use crate::{
|
||||||
|
capabilities,
|
||||||
|
holeybytes::ExecThread,
|
||||||
|
ipc::buffer::{self, IpcBuffer},
|
||||||
|
};
|
||||||
// use crate::arch::sloop;
|
// use crate::arch::sloop;
|
||||||
use {
|
use {
|
||||||
crate::{
|
crate::{
|
||||||
|
@ -68,7 +72,13 @@ pub static DEVICE_TREE: Lazy<Mutex<DeviceTree>> = Lazy::new(|| {
|
||||||
use alloc::vec::Vec;
|
use alloc::vec::Vec;
|
||||||
pub type IpcBuffers = HashMap<u64, IpcBuffer>;
|
pub type IpcBuffers = HashMap<u64, IpcBuffer>;
|
||||||
pub static IPC_BUFFERS: Lazy<Mutex<IpcBuffers>> = Lazy::new(|| {
|
pub static IPC_BUFFERS: Lazy<Mutex<IpcBuffers>> = Lazy::new(|| {
|
||||||
let bufs = HashMap::new();
|
let mut bufs = HashMap::new();
|
||||||
|
let log_buffer = IpcBuffer::new(false, 0);
|
||||||
|
let file_buffer = IpcBuffer::new(false, 0);
|
||||||
|
|
||||||
|
bufs.insert(1, log_buffer);
|
||||||
|
bufs.insert(2, file_buffer);
|
||||||
|
|
||||||
Mutex::new(bufs)
|
Mutex::new(bufs)
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
fn ipc_send(buffer_id, mem_addr, length){
|
fn ipc_send(buffer_id, mem_addr, length){
|
||||||
// set the ecall
|
// set the ecall
|
||||||
li8(r1, 3);
|
li8(r1, 3);
|
||||||
|
@ -8,11 +7,33 @@ fn ipc_send(buffer_id, mem_addr, length){
|
||||||
// set the length
|
// set the length
|
||||||
li64(r4, length);
|
li64(r4, length);
|
||||||
// ecall
|
// ecall
|
||||||
eca();
|
eca();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
fn ipc_recv(buffer_id){
|
||||||
|
li8(r1, 4);
|
||||||
|
eca();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
fn ipc_make_bound_buffer(length) {
|
||||||
|
li8(r1, 1);
|
||||||
|
li8(r2, 1);
|
||||||
|
li64(r3, length);
|
||||||
|
eca();
|
||||||
|
|
||||||
|
// The ipc buffer id is in r1
|
||||||
}
|
}
|
||||||
|
|
||||||
private fn log(log_level, string){
|
private fn log(log_level, string){
|
||||||
|
// This is NOT the final format
|
||||||
let str = data::str(string + log_level);
|
let str = data::str(string + log_level);
|
||||||
|
|
||||||
|
// 1 byte for the log level
|
||||||
|
// 8 bytes for the length to the message
|
||||||
|
// 8 bytes for the pointer to the string
|
||||||
|
|
||||||
ipc_send(1, str, str.len);
|
ipc_send(1, str, str.len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,3 +44,10 @@ fn Info(string) {log(2, string);}
|
||||||
// because of this all of the log levels are upper case
|
// because of this all of the log levels are upper case
|
||||||
fn Debug(string) {log(3, string);}
|
fn Debug(string) {log(3, string);}
|
||||||
fn Trace(string) {log(4, string);}
|
fn Trace(string) {log(4, string);}
|
||||||
|
|
||||||
|
|
||||||
|
fn open(string_path){
|
||||||
|
let file_path = data::str("Meow meow meow bark bark bark");
|
||||||
|
ipc_send(2, file_path, file_path.len);
|
||||||
|
}
|
||||||
|
fn write(){}
|
|
@ -1,3 +1,3 @@
|
||||||
li8 (r1, 0x69);
|
li8 (r1, 2);
|
||||||
// eca ();
|
eca ();
|
||||||
tx ();
|
tx ();
|
||||||
|
|
|
@ -2,10 +2,13 @@ import "repbuild/hblib/std" as std;
|
||||||
|
|
||||||
fn main(){
|
fn main(){
|
||||||
std::Error(":+)");
|
std::Error(":+)");
|
||||||
std::Debug("ABC");
|
|
||||||
std::Info("Hello, world!");
|
|
||||||
std::Trace("Trace Deez");
|
|
||||||
std::Warn("Your mom fell in a well!");
|
std::Warn("Your mom fell in a well!");
|
||||||
|
std::Info("Hello, world!");
|
||||||
|
std::Debug("XYZ");
|
||||||
|
std::Trace("Trace Deez");
|
||||||
|
|
||||||
|
// let ret = std::open("/file.hbf");
|
||||||
|
// std::Info("" + ret);
|
||||||
|
|
||||||
tx();
|
tx();
|
||||||
}
|
}
|
||||||
|
|
13
repbuild/holeybytes/vfs.rhai
Normal file
13
repbuild/holeybytes/vfs.rhai
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
/// Act as a shim of a virtual file system that recieves one message from buffer 2
|
||||||
|
import "repbuild/hblib/std" as std;
|
||||||
|
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
|
||||||
|
// jmp here
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
main();
|
||||||
|
tx();
|
19
repbuild/holeybytes/vfs_test.rhai
Normal file
19
repbuild/holeybytes/vfs_test.rhai
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
import "repbuild/hblib/std" as std;
|
||||||
|
|
||||||
|
fn main(){
|
||||||
|
std::Info("Trying to open a file.");
|
||||||
|
// let ret = std::open("/file.hbf");
|
||||||
|
// std::Info("File return " + ret);
|
||||||
|
|
||||||
|
std::ipc_make_bound_buffer(1000);
|
||||||
|
|
||||||
|
let str = data::str("ABC XYZ");
|
||||||
|
std::ipc_send(2, str, str.len);
|
||||||
|
|
||||||
|
std::ipc_recv(2);
|
||||||
|
|
||||||
|
|
||||||
|
tx();
|
||||||
|
}
|
||||||
|
|
||||||
|
main();
|
|
@ -26,3 +26,6 @@ TERM_BACKDROP=008080
|
||||||
|
|
||||||
MODULE_PATH=boot:///main.hbf
|
MODULE_PATH=boot:///main.hbf
|
||||||
MODULE_CMDLINE=""
|
MODULE_CMDLINE=""
|
||||||
|
|
||||||
|
MODULE_PATH=boot:///vfs_test.hbf
|
||||||
|
MODULE_CMDLINE=""
|
|
@ -162,6 +162,11 @@ fn get_fs() -> Result<FileSystem<impl ReadWriteSeek>, io::Error> {
|
||||||
&mut fs.root_dir().create_file("main.hbf")?,
|
&mut fs.root_dir().create_file("main.hbf")?,
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
|
io::copy(
|
||||||
|
&mut File::open("target/holeybytes/vfs_test.hbf")?,
|
||||||
|
&mut fs.root_dir().create_file("vfs_test.hbf")?,
|
||||||
|
)?;
|
||||||
|
|
||||||
drop(bootdir);
|
drop(bootdir);
|
||||||
Ok(fs)
|
Ok(fs)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue