What does your OS look like? (Screen Shots..)

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
jbanes
Posts: 12
Joined: Mon Dec 30, 2013 11:54 pm

Re: What does your OS look like? (Screen Shots..)

Post by jbanes »

All hail my mighty tutorial following skillz!
MyOS Screen.png
Hey, it's only 2 days of work! I'm sure by next week I'll be in 64 bit mode running Chrome. :shock: :? :^o :lol:
MadZarx
Member
Member
Posts: 85
Joined: Mon Apr 01, 2013 5:06 am
Location: CMOS :D

Re: What does your OS look like? (Screen Shots..)

Post by MadZarx »

jbanes wrote:All hail my mighty tutorial following skillz!

Hey, it's only 2 days of work! I'm sure by next week I'll be in 64 bit mode running Chrome. :shock: :? :^o :lol:
Dude OS development is not just copying and pasting code. You must know what are you writing and you must understand it. In future if any errors happen you will lose yourself in your copied codes and will never find the source of the error. Its better to write your own OS.

Good luck my friend :mrgreen:
jbanes
Posts: 12
Joined: Mon Dec 30, 2013 11:54 pm

Re: What does your OS look like? (Screen Shots..)

Post by jbanes »

MadZarx wrote:Dude OS development is not just copying and pasting code. You must know what are you writing and you must understand it. In future if any errors happen you will lose yourself in your copied codes and will never find the source of the error. Its better to write your own OS.
I hope you realize I was kidding? I stop to write an OS every few years to see how much farther I can get before I lose interest. What you see on the screen is me sharpening my skills. It's heavy on implementing info I've found on OSDEV, but plenty of the code is my own.

I'll be proceeding into an interactive system shortly. Already solved an issue with GRUB 2.0 on Windows, so I'm feeling pretty good about this go-round. :)
Good luck my friend :mrgreen:
Thank you much, sir!
MadZarx
Member
Member
Posts: 85
Joined: Mon Apr 01, 2013 5:06 am
Location: CMOS :D

Re: What does your OS look like? (Screen Shots..)

Post by MadZarx »

jbanes wrote: I hope you realize I was kidding? I stop to write an OS every few years to see how much farther I can get before I lose interest. What you see on the screen is me sharpening my skills. It's heavy on implementing info I've found on OSDEV, but plenty of the code is my own.
I'm so sorry if I misunderstood :idea: But I like your text UI and that table :D
jbanes
Posts: 12
Joined: Mon Dec 30, 2013 11:54 pm

Re: What does your OS look like? (Screen Shots..)

Post by jbanes »

MadZarx wrote:I'm so sorry if I misunderstood :idea: But I like your text UI and that table :D
No worries. Completely my fault. I should have been more clear on the status. That's what I get for trying to be funny. :)

'Nother screenshot is attached if anyone is interested. Not that much more to see. Still, quick breakdown:
  • There's a huge decode of the multiboot header that's already scrolled off screen. (It's really not that interesting.) The "Command line arguments" is the last chunk of the decode. Which is, predictably, blank.
  • You can see a decode of some BDA information I kinda-sorta care about.
  • Used the "float" trick to identify used ATA busses
  • Yeah, I just realized that VBE3.0 isn't supported by any virtualization software. That's ok, though. I really way too lazy to try linking in 16-bit segments. Better to put the code in a separate file and load it dynamically anyway. Or just skip the idea entirely and write some basic graphics drivers.
  • Scanned the master and the slave in PIO mode. You can tell the master in this case is actually a CDROM drive. (I love the CD-Boot idea for the tutorial, BTW. I expect it will be much better than the old virtual floppy disk days. Tons more space to work with!) The slave is a dud 122MB drive I attached to VirtualBox.
  • Fixed the cursor routine so you can see the cursor at the end there. Turns out one does need to be careful about what you write in the VGA color information byte when clearing a line. Doh!
  • I had totally forgotten about all the HEX code jokes developers put in this stuff. 0x2BADB002? 0x8086 as Intel's vendor code? 0xCAFE & 0xBEEF for VirtualBox PCI drivers? These guys would be really funny if I wasn't smacking my forehead so hard. (Well, ok. The Intel one is REALLY cool. =D> )
I'm currently working on getting everything in place for reading from the CDROM drive. If I can get file-accesses going, I'll have everything in place to move on to Stage #2. i.e. An interactive session that can load/link/execute programs.
Attachments
MyOS Screen 2.png
MadZarx
Member
Member
Posts: 85
Joined: Mon Apr 01, 2013 5:06 am
Location: CMOS :D

Re: What does your OS look like? (Screen Shots..)

Post by MadZarx »

jbanes wrote:
MadZarx wrote:I'm so sorry if I misunderstood :idea: But I like your text UI and that table :D
No worries. Completely my fault. I should have been more clear on the status. That's what I get for trying to be funny. :)

'Nother screenshot is attached if anyone is interested. Not that much more to see. Still, quick breakdown:
  • There's a huge decode of the multiboot header that's already scrolled off screen. (It's really not that interesting.) The "Command line arguments" is the last chunk of the decode. Which is, predictably, blank.
  • You can see a decode of some BDA information I kinda-sorta care about.
  • Used the "float" trick to identify used ATA busses
  • Yeah, I just realized that VBE3.0 isn't supported by any virtualization software. That's ok, though. I really way too lazy to try linking in 16-bit segments. Better to put the code in a separate file and load it dynamically anyway. Or just skip the idea entirely and write some basic graphics drivers.
  • Scanned the master and the slave in PIO mode. You can tell the master in this case is actually a CDROM drive. (I love the CD-Boot idea for the tutorial, BTW. I expect it will be much better than the old virtual floppy disk days. Tons more space to work with!) The slave is a dud 122MB drive I attached to VirtualBox.
  • Fixed the cursor routine so you can see the cursor at the end there. Turns out one does need to be careful about what you write in the VGA color information byte when clearing a line. Doh!
  • I had totally forgotten about all the HEX code jokes developers put in this stuff. 0x2BADB002? 0x8086 as Intel's vendor code? 0xCAFE & 0xBEEF for VirtualBox PCI drivers? These guys would be really funny if I wasn't smacking my forehead so hard. (Well, ok. The Intel one is REALLY cool. =D> )
I'm currently working on getting everything in place for reading from the CDROM drive. If I can get file-accesses going, I'll have everything in place to move on to Stage #2. i.e. An interactive session that can load/link/execute programs.
Its better to display information in a serial console. That way you can scroll up and see the logs. I prefer qemu serial console. Its much easier than others and just needs to write some bytes to a port to get it working :D

For graphics, it's better to forget about it until you have arrived to user land and you are able to load drivers. Then you must think about writing a native video card driver. Doing this in early stages (Writing a native video card driver or using VBE) is just waste of time. You must add support for resolutions and bit depths and must write a scalable font. So its better to just use text mode. Nothing is easier than copying 2 bytes to memory for displaying a character with nice colors :D

I'm currently working on a memory manager. Then I will write ATA drivers to be able to read from CDROM or HDD to load the other stuff.
But now I'm stuck in a physical memory manager :(

And yeah I love that hex numbers. They are funny specially the multiboot magic boot number, 0xbadb002 (bad boot :D :P)
CWood
Member
Member
Posts: 127
Joined: Sun Jun 20, 2010 1:21 pm

Re: What does your OS look like? (Screen Shots..)

Post by CWood »

Love the Intel code, but can't help feeling a twinge of disappointment, that it isn't 0x4004, or even 0x1101. A bit more obscure (especially 0x1101), but for people who know the history, infinitely more satisfying.</offtopic>
User avatar
Bender
Member
Member
Posts: 449
Joined: Wed Aug 21, 2013 3:53 am
Libera.chat IRC: bender|
Location: Asia, Singapore

Re: What does your OS look like? (Screen Shots..)

Post by Bender »

New feature in My OS. :D
It's called Night Mode and Day Mode.
Night Mode is activated after 6:00 P.M
Day Mode is activated after 6:00 A.M
I plan to add evening and afternoon mode.
No OS has this feature!
Image
"In a time of universal deceit - telling the truth is a revolutionary act." -- George Orwell
(R3X Runtime VM)(CHIP8 Interpreter OS)
jal
Member
Member
Posts: 1385
Joined: Wed Oct 31, 2007 9:09 am

Re: What does your OS look like? (Screen Shots..)

Post by jal »

sid123 wrote:New feature in My OS. :D
It's called Night Mode and Day Mode.
You mean, you actually use a computer when it's light outside? And you have windows in your room that let light shine through? Oh my...


JAL
User avatar
Bender
Member
Member
Posts: 449
Joined: Wed Aug 21, 2013 3:53 am
Libera.chat IRC: bender|
Location: Asia, Singapore

Re: What does your OS look like? (Screen Shots..)

Post by Bender »

You mean, you actually use a computer when it's light outside?
Image
And you have windows in your room that let light shine through?
Vitamin D is good for health......... Although the latest Windows have square and opaque Windows, which don't let light go through. However I have 7 Windows which are transparent.. (Try to look at the near the window buttons of the QEMU window in my screenshot, you can see light passing)
As for the picture I faked the time.
"In a time of universal deceit - telling the truth is a revolutionary act." -- George Orwell
(R3X Runtime VM)(CHIP8 Interpreter OS)
sandras
Member
Member
Posts: 146
Joined: Thu Nov 03, 2011 9:30 am

Re: What does your OS look like? (Screen Shots..)

Post by sandras »

sid123 wrote: It's called Night Mode and Day Mode.
Night Mode is activated after 6:00 P.M
Day Mode is activated after 6:00 A.M
I plan to add evening and afternoon mode.
No OS has this feature!
Well, you can use f.lux for something comparable. http://justgetflux.com/
greyOne
Member
Member
Posts: 58
Joined: Sun Feb 03, 2013 10:38 pm
Location: Canada

Re: What does your OS look like? (Screen Shots..)

Post by greyOne »

sid123 wrote:New feature in My OS. :D
It's called Night Mode and Day Mode.
Night Mode is activated after 6:00 P.M
Day Mode is activated after 6:00 A.M
I plan to add evening and afternoon mode.
No OS has this feature!
Actually my Garmin GPS has this feature.
jal
Member
Member
Posts: 1385
Joined: Wed Oct 31, 2007 9:09 am

Re: What does your OS look like? (Screen Shots..)

Post by jal »

I think Tom Toms also have it. And my built-in navigation even has a light sensor, used in combination with detection of car lights on/off. But I disgress...


JAL
greyOne
Member
Member
Posts: 58
Joined: Sun Feb 03, 2013 10:38 pm
Location: Canada

Re: What does your OS look like? (Screen Shots..)

Post by greyOne »

Image

I'm honestly not sure if this is great or stupid, but this is what is being done.
klange
Member
Member
Posts: 679
Joined: Wed Mar 30, 2011 12:31 am
Libera.chat IRC: klange
Discord: klange

Re: What does your OS look like? (Screen Shots..)

Post by klange »

I meant to post some of these last year, but then I hopped the Pacific and didn't have any time until I got back.

It's been a while since I've posted a screenshot that included elements of my development environment, but with a bunch of work I did over the past month or two I reenabled a serial console and hooked it up to my PTY interface (which I previously posted some shots of here). With that, I can now get a native shell in my host terminal - useful for those odd instances where my compositor crashes! Next on the docket is a new debugger so I can attach to frozen compositor sessions and see what went wrong, but in the meantime, here's the screenies (click for full size):

Image
The serial console actually opens to a special kernel shell. Unlike my old shell, it actually uses a hash table for command lookup, so it should remain rather speedy regardless of the commands I add. Since my kernel is still monolothic, this is all built-in to the kernel; maybe I'll get around to modules at some point, but it's not a pressing matter at the moment. From the kernel shell, a userspace shell (running /bin/sh) can be started, and from there you have basically the same environment as a terminal in the GUI. We can export the compositor endpoint name and start GUI apps from this shell. There are also functions to force a particular UID for the userspace shell, so I could run as a regular user instead of root, as well as some standard convenience functions. It's very reminiscent of my old kernel shell - I might even slap in some tab completion at some point.

Image
There is one minor problem with the userspace shell launched from the kernel serial console: It doesn't set some standard environment variables... particularly ones like $HOME, which things like Python kinda expect or they'll fall back to... well, functions I don't have in my Python `os` module. Meanwhile, the terminal in the GUI was a descendent of `glogin`, which sets those variables, so it can run Python just fine.

Image
Finally, the serial console also does some magic screen size detection on startup, so we can run curses/terminfo apps like vim and they'll show up properly. I had to export TERM=xterm-256color to get colors to show up, but that's expected.

It's not all that much more over what I showed last time, but it means that when I get a network stack, things like telnet or ssh should be fairly simple. It also means I have (potentially) a much better interface for debugging. As an added bonus, I added some configs to run "headless", booting straight into a shell without an active GUI, which is useful for when I just want to quickly test a command line app or new piece of kernel functionality.
Post Reply