SkillAgentSearch skills...

KernelxPipeline

When efficiency meets innovation

Install / Use

/learn @v-owen/KernelxPipeline
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

The Basekernel Operating System Kernel

Basekernel is a simple operating system kernel for research, teaching, and fun.

Basekernel is not a complete operating system, but it is a starting point for those who wish to study and develop new operating system code. If you want to build something different than Windows, Linux, or Multics, Basekernel may be a good place to try out your new ideas.

Basekernel can boot an Intel PC-compatible virtual machine in 32-bit protected mode, with support for VESA framebuffer graphics, ATA hard disks, ATAPI optical devices, process management, memory protection, simple graphics, and basic filesystem. From there, it's your job to write user-level programs and expand the system.

To be clear, this is raw low-level code, not a production system. If you want to hack code and learn about operating system, you will like Basekernel. If you are looking for a new OS to run on your laptop, then this is not what you want.

This project is led by Prof. Douglas Thain at the University of Notre Dame. A variety of students have contributed to the code, including Jack Mazanec, Douglas Smith, Ethan Williams, Jon Westhoff, and Kevin Wern.

To learn more, see the Basekernel Wiki.

Quick Start Instructions

If you are building on a Linux-X86 machine and have the QEMU virtual machine installed:

git clone https://github.com/dthain/basekernel
cd basekernel
make
qemu-system-i386 -cdrom basekernel.iso

And you should see something like this:

<img src=boot.png align=center>

After some initial boot messages, you will see the kernel shell prompt. This allows you to take some simple actions before running the first user level program. To automatically boot the first available filesystem, whether on cdrom or harddisk, run <tt>automount</tt>:

<pre> automount </pre>

Then use the <tt>list</tt> command to examine the root directory:

<pre> list / </pre>

And use the <tt>run</tt> command to run a program. For example, <tt>/bin/manager.exe</tt> runs a simple four-pane window manager with several tasks in parallel. (Use TAB to switch focus between programs, and tilde to cancel out of the window manager.)

<pre> run /bin/manager.exe </pre> <img src=screenshot-windows.png align=center>

Press TAB to change the focus between windows, and you can interact with each process in turn.

Cross-Compiling Instructions

If you are building on any other type of machine, you will probably need to build a cross-compiler using build-cross-compiler.sh and then edit Makefile.config to use the cross compiler binaries, then execute make to create basekernel.iso

Named PIPE Implementation in Basekernel

This project extends the existing PIPE mechanism in Basekernel to implement Named PIPEs (also known as FIFOs). Named PIPEs allow for inter-process communication between unrelated processes using a file system name.

Background

Basekernel already implements a basic PIPE mechanism with the following properties:

  • Unidirectional byte stream
  • Sequential data passing
  • No message boundaries
  • Blocking reads on empty PIPEs
  • End-of-file detection when write-end is closed
  • Blocking writes when PIPE is full
  • Potential segmentation of large writes

Named PIPE Features

The Named PIPE implementation builds upon the existing PIPE mechanism and adds the following features:

  1. File system representation: Named PIPEs have a name within the file system.
  2. Open and delete operations: Named PIPEs can be opened and deleted like regular files.
  3. Inter-process communication: Allows communication between unrelated processes using the file name.

Implementation Details

The Named PIPE implementation includes:

  1. Extension of the existing PIPE mechanism (kernel/pipe.h and kernel/pipe.c)
  2. File system integration for Named PIPEs
  3. Open and close operations for Named PIPEs
  4. Read and write operations maintaining PIPE semantics

Usage

To use a Named PIPE:

  1. Create a Named PIPE using a system call (e.g., mkfifo)
  2. Open the Named PIPE for reading or writing using its file system name
  3. Perform read and write operations as with regular PIPEs
  4. Close the Named PIPE when finished

Testing

A user-level test program (similar to user/test/pipetest.c) will be provided to demonstrate the functionality of Named PIPEs, including:

  1. Creating a Named PIPE
  2. Writing to the Named PIPE from one process
  3. Reading from the Named PIPE in another process
  4. Demonstrating inter-process communication

Future Work

  • Implement support for non-blocking I/O operations on Named PIPEs
  • Add support for multiple readers and writers on a single Named PIPE
  • Implement additional file system operations (e.g., permissions, ownership)

References

Related Skills

View on GitHub
GitHub Stars6
CategoryDevelopment
Updated9mo ago
Forks1

Languages

C

Security Score

77/100

Audited on Jun 15, 2025

No findings