flat assembler
Message board for the users of flat assembler.

Index > OS Construction > is this a worthy multitasking method?

Goto page 1, 2  Next
Author
Thread Post new topic Reply to topic
Gizmo



Joined: 19 Jul 2007
Posts: 25
Gizmo 27 Jul 2007, 16:41
I am attempting to make a 32bit pmode paging preemtive operating system (mainly for bragging rights and because the best way to know how something works is to make it).

I am formulating a plan that implements software based task switching where I use a timer to call an interupt that switches the stack and registers per thread as well as switching the page directory per process (user space->process->threads).

The interupt handler does:

Swaps the page directory back to the kernels page directory
(thread and process management structures exists only in kernel address space).

Saves all registers to the currently running thread's management structure and sets a time for the thread to wake up.

Enters a loop searching through the thread list inside of the process management structure for a thread whose wakeup time is less than the current time then loads the registers from this thread's structure and loads the page directory from the parent process's structure and finally exits the interrupt hander.

-If all threads inside of this process have been polled, we increment the process index and load that process's management structure and start the thread loop again.

-If all processes have been polled we start back at process 0 (kernel) and start the thread loop again.


Would this work?... Would this be efficient?

Will I need to change the tss values to put the kernel process in ring 0 and put the user mode processes in ring 3?
-if yes, does that still work in long mode when I move on in the future?
Post 27 Jul 2007, 16:41
View user's profile Send private message Reply with quote
Mac2004



Joined: 15 Dec 2003
Posts: 314
Mac2004 27 Jul 2007, 17:45
Hi Gizmo!

Quote:

-if yes, does that still work in long mode when I move on in the future?


Unfortunataly hardware multitasking is not supported in long mode. So the AMD64 manual says.
If you want to proceed to long mode as well, you'll have to do multitasking with software.

In others words: if you choose do PM multitasking by using the hardware, you would have to write LM multitasking all over again without the hardware.

regards
Mac2004
Post 27 Jul 2007, 17:45
View user's profile Send private message Reply with quote
Gizmo



Joined: 19 Jul 2007
Posts: 25
Gizmo 28 Jul 2007, 07:35
Thats what I am doing, software multitasking using a timer.
I just need reassurance that my plan would work thats all.
Post 28 Jul 2007, 07:35
View user's profile Send private message Reply with quote
Mac2004



Joined: 15 Dec 2003
Posts: 314
Mac2004 28 Jul 2007, 15:27
Have you obtained AMD64 and corresponding Intel system programming manuals? Reading them is very useful. Smile

regards
Mac2004
Post 28 Jul 2007, 15:27
View user's profile Send private message Reply with quote
mkriegel



Joined: 15 Jul 2007
Posts: 19
Location: Germany
mkriegel 28 Jul 2007, 15:39
On my opinion your concept will work on both, PMode and LMode. The only thing you should think about is a priority of threads, so that not each of them gets the same proceeding time.
Post 28 Jul 2007, 15:39
View user's profile Send private message Reply with quote
Gizmo



Joined: 19 Jul 2007
Posts: 25
Gizmo 28 Jul 2007, 19:17
The intel docs only discuss hardware task switching though- they say you have to use software task switching in long mode but offer no suggestions or examples.

I could adjust priority in real time perhaps by adjusting the sleep time issued to each thread after the timer interrupt thread switcher thingamabob, larger sleep times would devote less time to a thread leaving more time for other threads.

A question about unused processor cycles:
Lets say all of your threads have been put to sleep and their sleep time hasn't passed yet, how do you avoid waisting cpu cycles?
set timer and halt, when timer interrupts run task switcher again?
(for example battery saving mode on a laptop, or instances where the user is staring at a blank desktop and only certain drivers are running in a low priority message driven mode)
Post 28 Jul 2007, 19:17
View user's profile Send private message Reply with quote
mkriegel



Joined: 15 Jul 2007
Posts: 19
Location: Germany
mkriegel 28 Jul 2007, 19:41
Looking at windows task manager you will find a "Leerlaufprozess" (I don't know the english equivalent - sorry). That's why it seems to me that there is a waste of CPU cylces in Windows, too. But I don't know how you should make the CPU staying cool and not wasting power while no task needs it.

Maybe someone else has a good suggestion on what the CPU does when it does nothing.
Post 28 Jul 2007, 19:41
View user's profile Send private message Reply with quote
LocoDelAssembly
Your code has a bug


Joined: 06 May 2005
Posts: 4624
Location: Argentina
LocoDelAssembly 28 Jul 2007, 19:45
Quote:

"Leerlaufprozess" (I don't know the english equivalent - sorry)

It is System Idle Process. However this pseudo process spends its slices in halting state (HLT instruction) or anything else but it doesn't keep the processor busy, otherwise you would notice high CPU temperatures always and certainly that doesn't happens.
Post 28 Jul 2007, 19:45
View user's profile Send private message Reply with quote
Gizmo



Joined: 19 Jul 2007
Posts: 25
Gizmo 01 Aug 2007, 20:09
As I said above, I'm using a separate page table per process.

I'm wondering if I would even need to have paging for the kernel itself, if I
disabled paging during interupts, task switching, and other kernel sections to simplify things would it be a good idea since my kernel won't be big enough to benefit much from paging. (the processes will have paging, just not the kernel)

Also, if I'm using stack based task switching, do I need to create a single tss for the entire system or can I just avoid it?
... and in long mode?
Post 01 Aug 2007, 20:09
View user's profile Send private message Reply with quote
f0dder



Joined: 19 Feb 2004
Posts: 3175
Location: Denmark
f0dder 02 Aug 2007, 09:51
I wouldn't want to keep turning paging on/off... as for "my kernel won't be big enough to benefit much from paging.", protecting is benefit enough Smile

Iirc you need a single TSS to handle exceptions properly, but wouldn't know about long mode.
Post 02 Aug 2007, 09:51
View user's profile Send private message Visit poster's website Reply with quote
Dex4u



Joined: 08 Feb 2005
Posts: 1601
Location: web
Dex4u 02 Aug 2007, 14:09
I heard that paging needs to be on for LONG mode.
Post 02 Aug 2007, 14:09
View user's profile Send private message Reply with quote
mkriegel



Joined: 15 Jul 2007
Posts: 19
Location: Germany
mkriegel 02 Aug 2007, 17:23
That's right. But it is no problem. If u setup the pagetables continuous, you will not notice it in your OS. Than you have a real flat model. What I don't understand is, why segmentation is no longer supportet in Long mode.
Post 02 Aug 2007, 17:23
View user's profile Send private message Reply with quote
vid
Verbosity in development


Joined: 05 Sep 2003
Posts: 7105
Location: Slovakia
vid 02 Aug 2007, 17:30
Quote:
What I don't understand is, why segmentation is no longer supportet in Long mode.

Because it's not needed. For things that really can use segments (thread-specific info) you have FS and GS, that still work in 64bit mode.
Post 02 Aug 2007, 17:30
View user's profile Send private message Visit poster's website AIM Address MSN Messenger ICQ Number Reply with quote
Gizmo



Joined: 19 Jul 2007
Posts: 25
Gizmo 02 Aug 2007, 20:51
From what I understand, you can have just as good protection to segmentation by simply making separate page directories per task and leaving out everything you don't want that task to mess with or use the page flags.

(I have to use the from what I understand phrase because I just started learning asm last week...I guess you can say I am the guy who learns how to swim by diving off niagra falls in a barrel.)
Post 02 Aug 2007, 20:51
View user's profile Send private message Reply with quote
f0dder



Joined: 19 Feb 2004
Posts: 3175
Location: Denmark
f0dder 03 Aug 2007, 23:27
mkriegel wrote:
What I don't understand is, why segmentation is no longer supportet in Long mode.

Because segmentation hasn't been necessary nor desirable ever since paging was introduced with the 80386, but was kept because Intel wanted to be 100% backwards legacy compatible.

Gizmo wrote:
From what I understand, you can have just as good protection to segmentation by simply making separate page directories per task and leaving out everything you don't want that task to mess with or use the page flags.

Paging gives better and more fine-grained protection than segmentation, and can be used for other stuff as well Smile
Post 03 Aug 2007, 23:27
View user's profile Send private message Visit poster's website Reply with quote
mkriegel



Joined: 15 Jul 2007
Posts: 19
Location: Germany
mkriegel 06 Aug 2007, 15:24
So why do you have to Setup descriptor-tables when they are not needed. On my opinion they should remove ALL segmentation-stuff ore none of it. If it was available, it would be the choice of the developer.
Post 06 Aug 2007, 15:24
View user's profile Send private message Reply with quote
f0dder



Joined: 19 Feb 2004
Posts: 3175
Location: Denmark
f0dder 06 Aug 2007, 16:05
mkriegel wrote:
So why do you have to Setup descriptor-tables when they are not needed. On my opinion they should remove ALL segmentation-stuff ore none of it. If it was available, it would be the choice of the developer.

Because they wanted legacy support.

Intel should've scrapped their existing design with the 80386 and made some fundamental changes, it's the last chance they had, really... but they didn't, and after AMD insisted on introducing x86-64, we're stuck with the x86 patchwork for god knows how long.

_________________
Image - carpe noctem
Post 06 Aug 2007, 16:05
View user's profile Send private message Visit poster's website Reply with quote
rugxulo



Joined: 09 Aug 2005
Posts: 2341
Location: Usono (aka, USA)
rugxulo 06 Aug 2007, 16:44
f0dder, you're not "stuck" with anything, but you may not get any help / support from most people who "want" to use such things (even if you disagree). It's just one more thing to learn / fix and you have to rewrite everything. Sorry, but that sounds annoying. (Besides, there may be hardware support for 16-bit x86 stuff but nobody hardly uses it these days. But I guess you think such support "slows down" the computer, heh, doubtful.)

BTW, IBM had a huge foothold in the 286, making OS/2 support it explicitly for quite a while because they (supposedly) had sold a bunch of 'em. So, for someone like Intel to just stop making compatible processors, that would've slowed down the "computer evolution" tremendously! (Most people actually like the 386's new features and don't sweat it.)

It's not so easy to throw away everything old. People will complain (call them what you want, "Luddites" or just people who want stuff to keep working).

Compare the Atari 5200 (all alone) vs. Atari 7800 (also ran 2600 stuff). Or PS2 (also plays PS1) vs. XBox (uh, only their stuff?). Which would you rather have?
Post 06 Aug 2007, 16:44
View user's profile Send private message Visit poster's website Reply with quote
pfranz



Joined: 13 Jan 2007
Posts: 116
Location: Italy
pfranz 06 Aug 2007, 16:45
Oh yes, people only want their machines (apparently) run faster and their software still working. If you work for money, it's nearly impossible to introduce something new, especially in these days. Better to stick with one of the worst ideas born in the seventies: the x86 instruction set.
Does anybody know the status of a (quite good) idea born in 1997, that is EPIC instruction set and Itanium? This was developed with HP and would have been a fundamental change (I was surprised Intel had done something interesting), but I believe all people out there are still sleeping in their consumistic dreams and few of them are interested in it.

Edit after rugxulo: Itanium is fully compatible with today's processors, it's just that it's not particularly fast at emulating (especially the first versions). It could have been the chance to kick in something new without losing what we have now.
Post 06 Aug 2007, 16:45
View user's profile Send private message Reply with quote
f0dder



Joined: 19 Feb 2004
Posts: 3175
Location: Denmark
f0dder 07 Aug 2007, 10:52
rugxulo: 16bit legacy support might not "slow down" things, but it does require a bunch of transistors, and complicates the architecture. I would expect anybody that have played with kernel development to agree that intel should at least have dumped 286 pmode support in their 386 chips, instead of having such horrid data structures.

Yeah yeah, OS/2 and Win3.x supported 286pmode, cry me a river. The amount of legacy apps was pretty small compared to the huge mountain we have today, making it more or less impossible to abandon ship.

Microsoft made the same mistake with NT, they based the win32 API on the win16 API instead of thinking things through a bit, and keeping win16 solely as an emulated subsystem.

pfranz: original problem with the Itanium was they did x86 emulation in hardware, adding tons of complexity to the design (and transistor count), while in the end software emulation turned out to be faster... that, and of course pricing the chips solely for the high-end market, keeping it from getting a real break-through.

I had hoped that the move towards 64bit even on the desktop would mean a chance for a new system with a cleaner design (although not escaping windows), but AMD ruined that with x86-64.
Post 07 Aug 2007, 10:52
View user's profile Send private message Visit poster's website Reply with quote
Display posts from previous:
Post new topic Reply to topic

Jump to:  
Goto page 1, 2  Next

< Last Thread | Next Thread >
Forum Rules:
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


Copyright © 1999-2025, Tomasz Grysztar. Also on GitHub, YouTube.

Website powered by rwasa.