| Age | Commit message (Collapse) | Author | Files | Lines | |
|---|---|---|---|---|---|
| 7 days | kapi: move CPU to kapi | Felix Morgner | 11 | -106/+67 | |
| 7 days | fixup! kapi: move platform functions to CPU | Felix Morgner | 3 | -15/+7 | |
| 7 days | kapi: move platform functions to CPU | Felix Morgner | 9 | -127/+95 | |
| 8 days | ide: update neovim configuration | Felix Morgner | 1 | -4/+15 | |
| 8 days | kapi: restructure ACPI implementation | Felix Morgner | 12 | -239/+565 | |
| 9 days | kapi: return region pair for MMIO allocation | Felix Morgner | 4 | -18/+31 | |
| 9 days | x86_64: extend LAPIC initialization | Felix Morgner | 2 | -10/+76 | |
| 9 days | x86_64: fix CPU enumeration | Felix Morgner | 1 | -3/+2 | |
| 9 days | kapi/bus: fix eager initialization | Felix Morgner | 2 | -2/+9 | |
| 9 days | x86_64: only initialize BSP LAPIC | Felix Morgner | 3 | -11/+29 | |
| 9 days | x86_64: don't hardcode the LAPIC address | Felix Morgner | 1 | -11/+6 | |
| 9 days | x86_64: implement LAPIC initialization | Felix Morgner | 2 | -3/+36 | |
| 9 days | kernel: fix mmio allocator | Felix Morgner | 1 | -11/+15 | |
| 9 days | kapi: fix mmio initialization | Felix Morgner | 2 | -2/+5 | |
| 9 days | kapi: add basic support for MMIO mapping | Felix Morgner | 7 | -23/+228 | |
| 9 days | ide: clean up neovim configuration | Felix Morgner | 1 | -6/+7 | |
| 10 days | docs: remove old documentation | Felix Morgner | 90 | -545/+0 | |
| 10 days | ide: simplify overall configuration | Felix Morgner | 3 | -58/+42 | |
| 10 days | ide: enable debugging in neovim | Felix Morgner | 1 | -15/+94 | |
| 11 days | kernel/tests: fix link issue | Felix Morgner | 4 | -0/+106 | |
| 11 days | Merge branch 'fmorgner/develop-BA-FS26/apci' into develop-BA-FS26 | Felix Morgner | 32 | -107/+1043 | |
| This patchset introduces basic support for ACPI. Currently, the only user of that support is the CPU discovery subsystem. It uses the processed ACPI information to initialize CPU core devices and their associated local APICs. | |||||
| 11 days | kapi/platform: invert discovery dependencies | Felix Morgner | 3 | -23/+16 | |
| 11 days | qemu: enable multiple cores | Felix Morgner | 1 | -0/+4 | |
| 11 days | kernel: generalize CPU discovery | Felix Morgner | 9 | -80/+147 | |
| 11 days | kapi: extract more code to the kernel | Felix Morgner | 5 | -70/+114 | |
| 11 days | kernel/acpi: discover local interrupt controllers | Felix Morgner | 17 | -58/+386 | |
| 11 days | x86_64/devices: extract initialization code | Felix Morgner | 4 | -54/+85 | |
| 11 days | kernel/acpi: implement basic table discovery | Felix Morgner | 5 | -12/+127 | |
| 11 days | kapi: hook ACPI initialization up to boot process | Felix Morgner | 8 | -21/+186 | |
| 11 days | kapi: move independent implementation to kernel | Felix Morgner | 4 | -6/+5 | |
| 11 days | kapi: add basic ACPI support | Felix Morgner | 8 | -15/+205 | |
| 13 days | Merge branch 'windows-development-notes' into 'develop-BA-FS26' | Marcel Braun | 1 | -1/+13 | |
| add windows development notes See merge request teachos/kernel!21 | |||||
| 2026-04-02 | fix styling | Lukas Oesch | 1 | -4/+4 | |
| 2026-04-02 | add windows development notes | Lukas Oesch | 1 | -1/+13 | |
| 2026-04-02 | docs: begin breathe documentation | Felix Morgner | 20 | -52/+227 | |
| 2026-04-02 | Merge branch 'fmorgner/develop-BA-FS26/pit-device' into develop-BA-FS26 | Felix Morgner | 26 | -81/+1165 | |
| This changeset introduces a central device management system. The system comprises the following components: - kapi::devices::bus (type) A bus can be both a real (physically present inside the machine) or virtual (purely conceptual) bus. Busses form a hierarchy rooted in the virtual root_bus (accessible via `kapi::devices::get_root_bus`). Busses are derived from `kapi::devices::device`, and own devices. This means that a bus can be attached to another bus. This facilitates a uniform structure for device ownership. Each device needs to be attached to exactly one bus. Virtual devices, e.g. RAM disks, should be attached to the root root bus (via the `add_child` member function). Once a device, or bus, has been attached to a bus, it will be initialized (by means of a call to the `init` member function). Busses are responsible to initialize their children. If a bus has already been initialized, any newly attached children will automatically be initialized. During initialization, the `probe` member function of the bus under initialization weill be invoked. This allows a bus implementation to determine if the hardware, if any, is ready to be initialized and to also perform any required initialization steps. IMPORTANT: busses take ownership of their children in the form of a `unique_ptr`. - kapi::devices (namespace) The functions `allocate_major_number`, `register_device`, `unregister_device`, and `find_device` form the device manager. The device manager is responsible for keeping a record of active devices, allowing O(log n) lookup of devices by major and minor, and O(n) lookup by name. Additionally, the device manager is responsible for handing out major numbers (via `allocate_major_number`) and keeping track of active devices. When a child is attached to a bus, it will also automatically be registered with the device manager. Lookup of devices via the device manager can be achieved by means of either overload of `find_device`. Devices should never ask the manager directly for a major number. Instead, a controller should be used, which requests a major number per device "class" (as in kind, not language class). For example, a RAM disk controller may request a single major number for all RAM disks it is going to create. When the controller creates a new device of a given "class", e.g. a RAM disk, it should then supply that major number to the new device instance. IMPORTANT: the device manager does not own the active devices. Rather it holds a `flat_map` indexed by `pair{major, minor}` and resolving to `kstd::observer_ptr<device>`. - kstd::observer_ptr (type) An observer pointer is a simple vocabulary type to express the concept of having no ownership of the pointed-to object. In essence it is equivalent to a standard C-style pointer, but expresses semantics by virtue of being a separate type. | |||||
| 2026-04-02 | x86_64: ensure PIT is not overwhelmed on config | Felix Morgner | 3 | -5/+15 | |
| 2026-04-02 | devices: don't automatically allocate major numbers in ctors | Felix Morgner | 7 | -10/+18 | |
| 2026-04-02 | kapi/bus: ensure all devices get initialized | Felix Morgner | 1 | -1/+1 | |
| 2026-04-02 | kapi: allow for device searches | Felix Morgner | 3 | -1/+39 | |
| 2026-04-02 | x86_64: implement legacy PIT driver | Felix Morgner | 10 | -25/+146 | |
| 2026-04-02 | kapi: extract common bus code | Felix Morgner | 7 | -141/+66 | |
| 2026-04-02 | x86_64/devices: implement ISA bus stub | Felix Morgner | 9 | -3/+140 | |
| 2026-04-02 | kapi: add basic device subsystem | Felix Morgner | 7 | -0/+208 | |
| 2026-04-02 | kstd: make string formattable | Felix Morgner | 1 | -0/+13 | |
| 2026-04-02 | kstd: move observer_ptr to bits | Felix Morgner | 4 | -6/+8 | |
| 2026-04-02 | kstd/observer_ptr: extend test suite | Felix Morgner | 2 | -24/+149 | |
| 2026-04-02 | kstd/tests: extend operation tracker | Felix Morgner | 2 | -62/+128 | |
| 2026-04-02 | kstd: add some basic observer_ptr tests | Felix Morgner | 3 | -3/+239 | |
| 2026-04-02 | kstd: introduce observer_ptr | Felix Morgner | 2 | -1/+156 | |
