Click here to Skip to main content
Click here to Skip to main content

Develop Your Own Operating System in C# or VB.NET

By , 12 Aug 2010
 
Prize winner in Competition "Best C# article of August 2010"

Introducing Cosmos

Cosmos (C# Open Source Managed Operating System) is an operating system development kit which uses Visual Studio as its development environment. Despite C# in the name, any .NET based language can be used including VB.NET, Fortran, Delphi Prism, IronPython, F# and more. Cosmos itself and the kernel routines are primarily written in C#, and thus the Cosmos name. Besides that, NOSMOS (.NET Open Source Managed Operating System) sounds stupid.

Cosmos is not an operating system in the traditional sense, but instead it is an "Operating System Kit", or as I like to say "Operating System Legos". Cosmos lets you create operating systems just as Visual Studio and C# normally let you create applications. Most users can write and boot their own operating system in just a few minutes, all using Visual Studio. Milestone 5 includes new features such as an integrated project type in Visual Studio, and an integrated debugger. You can debug your operating system directly from Visual Studio using breakpoints.

Cosmos is available in two distributions, the developer kit (dev kit), and the user kit. The dev kit is designed for users who want to work on Cosmos itself. The user kit is designed for those who are interested in building their own operating system and doing some Cosmos work. The dev kit might be thought of as the Cosmos SDK. Most users should start off with the user kit as it is not so overwhelming like the dev kit. This article focuses on the user kit.

Writing Your First Operating System

Create a new project as you would any C# project, but select Cosmos as the project type.

A starter project will be created. It looks very much like a standard C# console application.

Program.cs contains the boot and execution code. Instead of seeing a Windows console window, you will see the following:

This is your operating system running in VMWare Player! Cosmos can of course also be booted in VMWare Workstation, Hyper-V, Virtual PC, or on real hardware. But by default, Cosmos uses VMWare Player because it is both free, and reliable. Cosmos can even debug in Visual Studio, even when running on another machine.

Integrated Debugging

Debugging is a major issue with operating system development. The Cosmos team was not content enough to simply conquer building and deployment, we want to make developing operating system as easy as developing Windows applications. Debugging a Cosmos based operating system should feel very familiar to you. Let's modify our project a little bit to show the effect, and set a breakpoint.

Now run the project again.

Note that the execution stopped at "One"? That is because in Visual Studio, our project has stopped on a breakpoint. Simply press F5 to continue just as you would in a normal application!

In addition to breakpoints, Cosmos also supports step into (F11) as well. Trace over (F10) is not supported yet.

Debugger Communication

The debugger uses the serial port to communicate. Because of this, debugging only works with virtualization environments that support serial ports such as VMWare. QEMU supports serial ports as well, but its serial port implementation is seriously broken on Windows and makes debugging impossible using QEMU. To debug on real hardware, you must use a physical serial cable. In the future, Cosmos will also support debugging over Ethernet.

Extra Debugging

Cosmos supports some explicit methods that can be used to communicate with the debugger and use additional functionality. It is accessed using the Debugger class in the Cosmos.Debug namespace in the Cosmos.Kernel assembly. This assembly is used by all Cosmos projects.

Code Based Breakpoints

Debugger.Break();

Break can be used to issue a code based break. Visual Studio will break on the line after this statement.

Since Cosmos does not support conditional breaks in the IDE yet, code base breaks are very useful for implementing such. For example:

if (x == 5) {
    Debugger.Break();
}

Alternatively, you can call the .NET class library break:

System.Diagnostics.Debugger.Break();

Both functions will produce the same result.

Debug Output

Debug strings can be output to the debug window of the host. Because Cosmos does not support watches yet, this functionality can be very useful for watching variable values and for performing tracing without breakpoints.

Debugger.Send("Hello from Cosmos!");

When this line is executed, it will send a message over the debugging channel and it will appear in the Visual Studio output window.

What's the Catch?

There really is no catch. Everything I've shown here is functioning as seen. No mockups were used. However we still have a lot of work to go. Items of interest that are on our current task list include interfaces (necessary for foreach), file systems (partial support exists), threads, networking, and graphics. We have prototypes and experimentation for each, but none have been rolled into the mainline Cosmos development as of yet.

What Was That Syslinux Thing I Saw on Boot?

Cosmos does not run on Linux. A boot loader called Syslinux is used to boot Cosmos. After booting, Syslinux is not used. Syslinux is a bootloader and is not a Linux distro.

Obtaining Cosmos

License

This article, along with any associated source code and files, is licensed under The BSD License

About the Author

Chad Z. Hower aka Kudzu
Other
Cyprus Cyprus
Member
Chad Z. Hower, a.k.a. Kudzu
"Programming is an art form that fights back"
www.KudzuWorld.com
 
Formerly the Regional Developer Adviser (DPE) for Microsoft Middle East and Africa, he was responsible for 85 countries spanning 4 continents and 10 time zones. Now Chad is a Microsoft MVP.
 
Chad is the chair of several popular open source projects including Indy and Cosmos (C# Open Source Managed Operating System).
 
Chad is the author of the book Indy in Depth and has contributed to several other books on network communications and general programming.
 
Chad has lived in Canada, Cyprus, Switzerland, France, Jordan, Russia, Turkey, and the United States. Chad has visited more than 60 countries, visiting most of them several times.

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
QuestionCan I show a winform directly after the boot?memberHasitha_Dayarathna11 Feb '13 - 20:05 
GeneralMy vote of 5memberibrahim_ragab18 Jan '13 - 0:50 
GeneralRe: My vote of 5memberChad Z. Hower aka Kudzu12 Feb '13 - 3:30 
Question[My vote of 1] is this joke ??memberMember 963207717 Jan '13 - 23:36 
AnswerRe: [My vote of 1] is this joke ??memberMatthijs ter Woord18 Jan '13 - 0:42 
AnswerRe: [My vote of 1] is this joke ??memberibrahim_ragab18 Jan '13 - 0:49 
QuestionCan i install it as application for checking bootable cd and asking for pass on startupmemberRAHUL7775830 Jul '12 - 3:50 
AnswerRe: Can i install it as application for checking bootable cd and asking for pass on startupmemberMatthijs ter Woord30 Jul '12 - 4:19 
GeneralRe: Can i install it as application for checking bootable cd and asking for pass on startupmemberRAHUL7775830 Jul '12 - 4:27 
GeneralMy vote of 5memberMd. Rashidul Hasan Masum27 Jul '12 - 3:52 
wow
GeneralMy vote of 5memberKim Togo26 Jun '12 - 23:11 
GeneralMy vote of 5memberNithin Rudraswamy21 Jun '12 - 2:23 
GeneralMy vote of 5memberChintanhiremath10 Jun '12 - 19:40 
QuestionThis is very, very, very cool!memberZac Greve10 Apr '12 - 19:25 
QuestionSo it needs windows to run ?memberXmen W.K.3 Mar '12 - 5:49 
AnswerRe: So it needs windows to run ?memberHuntrCkr3 Mar '12 - 18:47 
GeneralRe: So it needs windows to run ?memberXmen W.K.3 Mar '12 - 21:31 
GeneralRe: So it needs windows to run ?memberMatthijs ter Woord3 Mar '12 - 22:09 
GeneralRe: So it needs windows to run ?memberXmen W.K.4 Mar '12 - 5:22 
GeneralMy vote of 5membermanoj kumar choubey1 Feb '12 - 19:13 
GeneralMy vote of 5memberCS140118 Oct '11 - 20:44 
Questionhow can i write or read from diskmemberjuanico1714 Oct '11 - 14:38 
AnswerRe: how can i write or read from diskmemberChad Z. Hower aka Kudzu17 Oct '11 - 13:18 
QuestionCOSMOS will not do anything [modified]memberKodemaster12318 Aug '11 - 18:12 
AnswerRe: COSMOS will not do anything... Yes it willmemberKodemaster12318 Aug '11 - 18:42 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web02 | 2.6.130516.1 | Last Updated 12 Aug 2010
Article Copyright 2010 by Chad Z. Hower aka Kudzu
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid