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.
User avatar
Combuster
Member
Member
Posts: 9301
Joined: Wed Oct 18, 2006 3:45 am
Libera.chat IRC: [com]buster
Location: On the balcony, where I can actually keep 1½m distance
Contact:

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

Post by Combuster »

akasei wrote:O'rly? Find me bitmap font at 8x8 pixels :P
Why not stick to the VGA font? Easy.
"Certainly avoid yourself. He is a newbie and might not realize it. You'll hate his code deeply a few years down the road." - Sortie
[ My OS ] [ VDisk/SFS ]
User avatar
osdever
Member
Member
Posts: 492
Joined: Fri Apr 03, 2015 9:41 am
Contact:

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

Post by osdever »

akasei wrote:
catnikita255 wrote:Great. But font is ugly.
O'rly? Find me bitmap font at 8x8 pixels :P
Why 8x8? I have WIP Unicode 8x16 font support.
Developing U365.
Source:
only testing: http://gitlab.com/bps-projs/U365/tree/testing

OSDev newbies can copy any code from my repositories, just leave a notice that this code was written by U365 development team, not by you.
shmx
Member
Member
Posts: 68
Joined: Sat Jan 16, 2016 10:43 am

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

Post by shmx »

My school work. Now I have no time to engage in. Sorry, the English version does not exist.
Information devices:
Image
Image
Console command list:
Image
Kolibri API emulation:
Image
Nable
Member
Member
Posts: 453
Joined: Tue Nov 08, 2011 11:35 am

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

Post by Nable »

to shmx
This is pretty impressive! Could you give a link to the source code?
shmx
Member
Member
Posts: 68
Joined: Sat Jan 16, 2016 10:43 am

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

Post by shmx »

The source code is not open. At the moment, I am not ready to open the source code. I can show fragments of that's just you are interested (please write in PM). Actually, architecture of souce code is is very bad. I started to do it in 13 years. Now nothing can be correct (too much code). OS is written in C, compiler GCC (core), BCC(bootloader).
shmx
Member
Member
Posts: 68
Joined: Sat Jan 16, 2016 10:43 am

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

Post by shmx »

I started doing a second version in C++11. I did allocators physical memory, virtual memory, heap, multitasking, smp... I take into account all the mistakes of last version. No time to do it now.
apamment
Member
Member
Posts: 28
Joined: Thu Aug 20, 2015 9:02 pm
Contact:

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

Post by apamment »

Image

My OS working again! With wallpaper AND clocks! Lots of Clocks! YAY!
User avatar
osdever
Member
Member
Posts: 492
Joined: Fri Apr 03, 2015 9:41 am
Contact:

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

Post by osdever »

shmx wrote:My school work. Now I have no time to engage in. Sorry, the English version does not exist.
Information devices:
Image
Image
Console command list:
Image
Kolibri API emulation:
Image
You are also Russian?
Developing U365.
Source:
only testing: http://gitlab.com/bps-projs/U365/tree/testing

OSDev newbies can copy any code from my repositories, just leave a notice that this code was written by U365 development team, not by you.
shmx
Member
Member
Posts: 68
Joined: Sat Jan 16, 2016 10:43 am

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

Post by shmx »

catnikita255 wrote:You are also Russian?
Yes. Does it matter?
User avatar
Brendan
Member
Member
Posts: 8561
Joined: Sat Jan 15, 2005 12:00 am
Location: At his keyboard!
Contact:

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

Post by Brendan »

Hi,

My current boot code (very much subject to change)...

For 15-bpp:

Image

And for 8-bpp ("3:3:2"):

Image

Both of these images are generated for sRGB.

The code to generate these pictures involves:
  • Code to convert EDID into my own "Display Info Data" file format
  • Code to generate a list of video modes; including using VBE 3.0 "CRTC info" to construct video modes that perfectly match the "Display Info Data" file's video mode timings
  • Code to auto-select the best possible video mode (to suit the video card, display, OS, etc) using a whole bunch of heuristics
  • A "log output" boot module (the piece that actually generates the image and blits it to frame buffer), that's running in its own sandbox at CPL=3 in its own virtual address space
  • Temporary code to generate a background image (in 48-bpp device independent XYZ format).
  • Code to generate a routine at run-time, where the resulting routine does "48-bpp device independent XYZ -> device dependent RGB", including gamma correct dithering; that takes into account:
    • the display's primary colours
    • the display's white point
    • the display's gamma
    • how many colours the display can actually show
    • the video mode's pixel format
Other features of the (current) boot code are:
  • Support for "RAM fault tolerance" (avoiding previously found faulty pages, testing pages before use, etc)
  • Boot image/inital RAM disk decompression; with max. size of 1.5 GiB (decompressed), even if the OS failed to enable A20 and physical memory is completely fragmented
  • Digital signature checks on all executable code, TPM "static root of trust" for (future) remote attestation
  • CRC checks on all files used
  • Pre-boot environment abstraction (only the first stage boot loader knows/cares what the firmware is - easy to add support for UEFI or anything else later)
  • Full exception handling (and reporting register contents, etc at time of crash)
  • Support for headless systems (no monitors) and support for multiple monitors (if boot loader can setup frame buffers)
  • Lots of smaller things I've forgotten :)

Cheers,

Brendan
For all things; perfection is, and will always remain, impossible to achieve in practice. However; by striving for perfection we create things that are as perfect as practically possible. Let the pursuit of perfection be our guide.
Antti
Member
Member
Posts: 923
Joined: Thu Jul 05, 2012 5:12 am
Location: Finland

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

Post by Antti »

Questions for Brendan:

What kind of user options are allowed for setting the video mode? Is your auto-select heuristics subject to choose overly safe video modes? If users know that other unsafe video modes should work, are you allowing them to select those modes and possibly cause damage to their hardware? If there is a boot settings file or similar, is it possible to set a "override-all-heuristics" mode? Please note that it could still rule out "definitely-not-supported" cases. Perhaps it is all about how much uncertainty is allowed, e.g. you could say it is not possible to select a video mode with less than "50% reliablity" or something.

Is this the first time you generate a routine at run-time? Just a detail question, are you generating the run-time code by arranging instructions like data or like code? Perhaps this needs some clarification. Compare these two examples:

Code: Select all

section .text
Example:
        mov eax, 0x00C3C081                     ; eax = "rum-time code"

        ; Register eax contains code as "data"
        ;   "xor eax, eax"
        ;   "ret"

        mov [RunTimeReturnZero+0], eax          ; install "run-time code"
        ; Flush caches etc.

        call RunTimeReturnZero                  ; run "run-time code"
        ret                                     ; return 0x00000000


section .runtime

align 16
RunTimeReturnZero:  resb 16

Code: Select all

section .text
Example:
        mov ecx, (CodeBlock1.End-CodeBlock1)    ; ecx = size of code to copy
        mov esi, CodeBlock1                     ; ds:esi = source
        mov edi, RunTimeReturnZero+0            ; es:edi = destination
        cld                                     ; clear direction flag
        rep movsb                               ; copy "run-time code" as "code"
        ; Flush caches etc.

        call RunTimeReturnZero                  ; run "run-time code"
        ret                                     ; return 0x00000000


section .codepool

CodeBlock1:
        xor eax, eax                            ; eax = 0x00000000
        ret                                     ; return 0x00000000
.End:   ; nop


section .runtime

align 16
RunTimeReturnZero:  resb 16
Do you see the difference? The first one is more like "data" and the latter is more like "code". I did not explain my point very well but there is a little difference between these two approaches. The end result is the same.
User avatar
Roman
Member
Member
Posts: 568
Joined: Thu Mar 27, 2014 3:57 am
Location: Moscow, Russia
Contact:

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

Post by Roman »

Code: Select all

rum-time code
I declare this the typo of the day!
"If you don't fail at least 90 percent of the time, you're not aiming high enough."
- Alan Kay
User avatar
Brendan
Member
Member
Posts: 8561
Joined: Sat Jan 15, 2005 12:00 am
Location: At his keyboard!
Contact:

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

Post by Brendan »

Hi,
Antti wrote:What kind of user options are allowed for setting the video mode?
There's no user options for controlling the video mode.
Antti wrote:Is your auto-select heuristics subject to choose overly safe video modes?
If there's little/no information then there's a strong tendency towards 640*480. If there's information about the display but no information about the video card's video mode timing, then it's a little more relaxed. If there's information about the display and information about the video card's video mode timings; then you get the best possible compromise. However it also takes into account other things - for example; if the computer only has 64 MiB of free RAM then 1920*1600 can't be safe, because the OS would consume almost 50 MiB of RAM for buffers, etc and there wouldn't be enough RAM left to do anything else.
Antti wrote:If users know that other unsafe video modes should work, are you allowing them to select those modes and possibly cause damage to their hardware? If there is a boot settings file or similar, is it possible to set a "override-all-heuristics" mode? Please note that it could still rule out "definitely-not-supported" cases. Perhaps it is all about how much uncertainty is allowed, e.g. you could say it is not possible to select a video mode with less than "50% reliablity" or something.
The provision of these things is an admission that the system (hardware + software) failed to be fit for the purpose it was intended. It works without end user hassle/configuration, or it deserves to go in the trash. ;)
Antti wrote:Is this the first time you generate a routine at run-time?
It's not something I've done before (and not something that usually makes sense).
Antti wrote:Just a detail question, are you generating the run-time code by arranging instructions like data or like code? Perhaps this needs some clarification. Compare these two examples:
Antti wrote:Do you see the difference? The first one is more like "data" and the latter is more like "code". I did not explain my point very well but there is a little difference between these two approaches. The end result is the same.
It's more like the latter (instructions arranged like code).

More specifically, it's a set of "snippets", where each one has some instructions and then a list of things to patch (e.g. "replace the dword at offset 33 within this snippet with the redX multiplier", "replace the relative jump target at offset 22 with the correct displacement for the end of the first snippet", etc). It analyses everything, chooses which snippets to combine and builds a "snippet list"; then allocates RAM for the routine and generates it by concatenating the selected snippets and patching them. The end result is a routine that's typically between about 160 instructions and 220 instructions; that has very few branches and where most "variables" (horizontal resolution, address of dynamically allocated lookup tables, etc) are hard-coded immediate data.


Cheers,

Brendan
For all things; perfection is, and will always remain, impossible to achieve in practice. However; by striving for perfection we create things that are as perfect as practically possible. Let the pursuit of perfection be our guide.
User avatar
osdever
Member
Member
Posts: 492
Joined: Fri Apr 03, 2015 9:41 am
Contact:

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

Post by osdever »

shmx wrote:
catnikita255 wrote:You are also Russian?
Yes. Does it matter?
No. But your OS is very cool.
Developing U365.
Source:
only testing: http://gitlab.com/bps-projs/U365/tree/testing

OSDev newbies can copy any code from my repositories, just leave a notice that this code was written by U365 development team, not by you.
User avatar
SpyderTL
Member
Member
Posts: 1074
Joined: Sun Sep 19, 2010 10:05 pm

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

Post by SpyderTL »

Brendan wrote:Temporary code to generate a background image (in 48-bpp device independent XYZ format).
Code to generate a routine at run-time, where the resulting routine does "48-bpp device independent XYZ -> device dependent RGB", including gamma correct dithering; that takes into account:
Can you elaborate? I can't find any information about a 48 bit graphics format on the web. Did you create it yourself?
Project: OZone
Source: GitHub
Current Task: LIB/OBJ file support
"The more they overthink the plumbing, the easier it is to stop up the drain." - Montgomery Scott
Post Reply