Page 192 of 262

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

Posted: Sat Feb 11, 2017 2:37 am
by BrightLight
zesterer wrote: Presumably though it doesn't redraw on *every* update though? You'd end up redrawing a ridiculous number of times. I presume it's capped at something reasonable like 50-60Hz?
I meant, I copy my back buffer to the physical VBE frame buffer. My OS uses VBE to set the graphics modes, and so it has no way of knowing exactly the hardware refresh frequency, but I think 60 Hz is common enough to call standard. It copies the back buffer to the physical buffer whenever the back buffer has been changed, and I already mentioned when that is: whenever the mouse is moved, a window is dragged, or an application requests a redraw.
At the moment, I don't redraw a "ridiculous" number of times, and the performance is actually great on VirtualBox and VMware and OK on real hardware, but I could do some work on it still, to improve on QEMU without KVM.

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

Posted: Sun Feb 12, 2017 5:16 am
by Gigasoft
It is the job of the window manager to know where every window is and what parts of them need to be updated. You need some way to restrict painting to a region that the window manager will compute using information about the part of a window that is visible and the part that is invalid. That way, you can use your CPU time for other things than silly redraws of the entire screen just because the cursor moved. You can have the cursor as a special case, where the system saves what's underneath it before it is shown, and hides it by restoring the saved pixels. Remember to temporarily hide the cursor when a window is to be updated while the cursor is over it.

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

Posted: Sun Feb 12, 2017 5:45 am
by klange
prasoc wrote:one question however: what is the best way to achieve screen "updates"? do you have a ticker that updates once every 1/60th a second or something?
I've been meaning to write an article on window compositing, but jojo wrote a whole series of articles on general windowing and efficient updates and I think it's a good read for people new to the ideas.

Personally, my compositor has two threads: A rendering thread and a control thread. The control thread does all of the input management and talks to the clients. As part of that client communication, it collects screen update regions from clients - a client will tell the server it wants to mark a region of a window as "damaged", and the server will add that to a list. The render thread will combine all of the damage regions since the last screen update (~60Hz; ideally v-synced, but driver support just isn't there) and redraw those regions. Since I have a compositor with transparency, it needs to redraw everything from bottom to top that would fit within the affected regions - this happens in an off-screen buffer first. I then copy the same regions over to video memory.

Unrelated, here's a video of some menu updates in ToaruOS:


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

Posted: Wed Feb 15, 2017 9:39 pm
by VolTeK
Phenomenal as usual

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

Posted: Thu Feb 16, 2017 2:08 pm
by prasoc
klange wrote:
prasoc wrote:one question however: what is the best way to achieve screen "updates"? do you have a ticker that updates once every 1/60th a second or something?
I've been meaning to write an article on window compositing, but jojo wrote a whole series of articles on general windowing and efficient updates and I think it's a good read for people new to the ideas.

Personally, my compositor has two threads: A rendering thread and a control thread. The control thread does all of the input management and talks to the clients. As part of that client communication, it collects screen update regions from clients - a client will tell the server it wants to mark a region of a window as "damaged", and the server will add that to a list. The render thread will combine all of the damage regions since the last screen update (~60Hz; ideally v-synced, but driver support just isn't there) and redraw those regions. Since I have a compositor with transparency, it needs to redraw everything from bottom to top that would fit within the affected regions - this happens in an off-screen buffer first. I then copy the same regions over to video memory.

Unrelated, here's a video of some menu updates in ToaruOS:
thank you for the detailed reply, I have implemented a front and backbuffer but using memcpy on the full backbuffer every update is exceptionally slow! a separate "dirty" buffer would reduce the memory copy times huuuugely

Will have a look at those tutorials, quickly skimmed the article and it seems perfect for the hobbyist os developer :)

Also that video of ToaruOS is spectacular - the windowing system is something for me to aim towards 8)

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

Posted: Fri Feb 17, 2017 11:20 am
by Sik
Just a rough template for the interface, but the next thing I'm working on Indigo: a file dialog (in this case just acting as the usual file browser). Decided to go with this because 1) I can get away with this without a keyboard (at least the most barebones functionality) and 2) I better get off with full blown filesystem support instead of the bare minimum currently used to load programs.

Image

On that note, I need to sort out how to deal with file handles (especially how many to allow), since the kernel doesn't have that much memory alloted to itself.

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

Posted: Tue Feb 21, 2017 8:20 am
by zaval
Impressive and really inspiring, guys! I was staring at the thread several days. xD
I wish I could post here something similar, but my project can't even write into the serial port yet. :D
I am trying to create NT-like OS but as a first subproject of it, I'm working on a UEFI implementation for a couple of machines of two architectures, namely - MIPS and ARM. The OS itself is planned for x86 as well apart from those two. But now I'm messing around with the Beagle Bone Black armv7 SBC writing the first stages of UEFI PI spec (SEC, PEI). And once it is able to talk to the world I'll let you know.)

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

Posted: Wed Feb 22, 2017 8:59 am
by zesterer
Image

I've made a huge number of changes over the last 48 hours.

- I've added co-operative multi-tasking. Currently, only the VGA render task and the prompt are active
- I've started work on a very simple filesystem manager
- I've totally rewritten my kernel shell. It has tonnes of new features.
- I've generally just improved the look of the whole OS
- Many stability improvements internally

Very, very happy with Tupai at the moment.

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

Posted: Wed Feb 22, 2017 9:24 am
by Sik
Image

(´・ω・`)

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

Posted: Wed Feb 22, 2017 10:11 am
by Octacone
zesterer wrote:Image

I've made a huge number of changes over the last 48 hours.

- I've added co-operative multi-tasking. Currently, only the VGA render task and the prompt are active
- I've started work on a very simple filesystem manager
- I've totally rewritten my kernel shell. It has tonnes of new features.
- I've generally just improved the look of the whole OS
- Many stability improvements internally

Very, very happy with Tupai at the moment.
It is beautiful! =D> I really like the looks of it.
What is that font called?

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

Posted: Wed Feb 22, 2017 10:42 am
by zesterer
octacone wrote:It is beautiful! =D> I really like the looks of it.
What is that font called?
Thanks. Lat2-Terminus16 is the font. It's available by default on most Linux distributions.

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

Posted: Wed Feb 22, 2017 11:00 pm
by CorruptedByCPU
Cyjon OS fluent windows movement, now lets do some GUI :)

https://www.youtube.com/watch?v=wT9YeNqhD9Q

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

Posted: Fri Feb 24, 2017 12:55 am
by Sik
Wallpaper support! (though the internals still need some tweaking)

Image

The next work should be on the existing apps now so hopefully you won't have me flooding this thread for a while.

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

Posted: Fri Feb 24, 2017 8:36 am
by SpyderTL
Sik wrote:Wallpaper support! (though the internals still need some tweaking)

Image

The next work should be on the existing apps now so hopefully you won't have me flooding this thread for a while.
This... I want.

Please port to x86 so I can run this as my daily machine. Be sure not to increase the resolution.

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

Posted: Wed Mar 01, 2017 10:27 am
by MajickTek
I think it's amazing how much progress people have made over the years. Going through this thread (and the "when you're OS goes crazy" thread) just shows how far we've gotten.

Unfortunately, my OS is nowhere enough near completion to show here :x . Soon, though :D