hawkw / mycelium

🍄 an alleged 'operating system'
https://mycelium.elizas.website
MIT License
532 stars 19 forks source link

HAL design #2

Open hawkw opened 4 years ago

hawkw commented 4 years ago

I think it would be great to write an interface layer that abstracts over platform-specific code, and then implement it for each architecture we want to target. We should probably design the interface first, based on the kernel's requirements, rather than writing a bunch of platform code & then trying to abstract over it — it seems easy to accidentally design an interface that basically reproduces a specific platform and requires others to jump through hoops to implement it.

Things we should include in such an interface:

hawkw commented 4 years ago

it would be cool to have a HAL library that drivers could also be written against, but see #3

iximeow commented 4 years ago

(unless we want to write our own bootloader which seems like an additional yakshave that should probably be avoided) hello, the bootloader-writer has logged on

i broadly agree though and really just think it would be fun to write a bootloader.

i'm also super not sure how much A or H the HAL should do, entirely because i've never thought about trying to interact with "storage" or "peripherals" before. my spiciest(?) take on this is that trying to fit hardware into a file model is not great and makes for extremely uninformative errors when something goes wrong. i want to know what parameter was invalid, or why it was invalid, not simply EINVAL.

i think this means the HAL would have to know about hardware-specific error modes, but i'm not sure if or how it applies to different interconnects (device X over usb vs pcie vs ...) at all

hawkw commented 4 years ago

i [...] really just think it would be fun to write a bootloader.

strong agree but i don't think we would get very far on a kernel if we decided to also do a bootloader. if we abstract over "boot info" we could always replace multiboot with ixiboot later.

i'm also super not sure how much A or H the HAL should do

so, you just want it to be a "Layer"? :P

trying to fit hardware into a file model is not great and makes for extremely uninformative errors when something goes wrong. i want to know what parameter was invalid, or why it was invalid, not simply EINVAL.

i think this means the HAL would have to know about hardware-specific error modes, but i'm not sure if or how it applies to different interconnects (device X over usb vs pcie vs ...) at all

mostly agree, but i don't think the HAL itself would have to be necessarily aware of hardware-specific error modes so much as provide an interface for returning richer errors defined by the hardware device; e.g.:

trait Hardware {
    type DeviceError: crate::Error;
}

(of course this code is wildly reductive, but imagine something like that but useful 😄)

hawkw commented 4 years ago

cc #8

hawkw commented 4 years ago

i started playing around with a pretty bad hal ages ago, most of this is probably garbage and shouldn't reused https://github.com/sos-os/hal9000/tree/master/hal9000/src

hawkw commented 4 years ago

basic HAL structure rough thoughts: