Page 1 of 1
Why does MSVC generate SS traps itself?
Posted: Wed Nov 09, 2016 2:30 pm
by Ycep
Hey, I was wondering why do VS 2012 generates SST on this occasion:
I was troubling with my multitasking scheduler (which changes PIT IRQ) which, after its initialization sleep() generates SS traps, randomly(every second or third boot ends up into SST).
Through, code snippets with same code as sleep() function work fluently (NOT inline).
If it could help in any reason:
Code: Select all
void sleep(int16 ms)
{
uint need=ms+ticks;
while(need>ticks)
{
//nextTask(), or whatever it needs to be in future
}
}
I have runned BochsDbg and it shows on 23 bytes after sleep(), which somewhere around "while(need>ticks)". I'm really confused right now...
Re: Why does MSVC generate SS traps itself?
Posted: Thu Nov 10, 2016 2:04 am
by MollenOS
Your problem has to lie somewhere else, maybe in your task switching code instead, because the code itself would never cause any problems (except you should make ticks volatile, otherwise MSVC will optimize the loop to infinite loop instead)
Re: Why does MSVC generate SS traps itself?
Posted: Thu Nov 10, 2016 2:42 am
by iansjack
Debugging, and the Bochs log, should show you exactly where the code is faulting.
Re: Why does MSVC generate SS traps itself?
Posted: Thu Nov 10, 2016 3:58 am
by Ycep
iansjack wrote:Debugging, and the Bochs log, should show you exactly where the code is faulting.
Are you kidding me? Why didn't you readed my post?
MollenOs wrote:
Your problem has to lie somewhere else, maybe in your task switching code instead, because the code itself would never cause any problems (except you should make ticks volatile, otherwise MSVC will optimize the loop to infinite loop instead)
It is already volatile, but it happened
inside sleep(), not in interrupt.
I ask again, why would MSVC compiler put SST flags?
Re: Why does MSVC generate SS traps itself?
Posted: Thu Nov 10, 2016 4:12 am
by Octocontrabass
Lukand wrote:I have runned BochsDbg and it shows on 23 bytes after sleep(), which somewhere around "while(need>ticks)". I'm really confused right now...
What is the instruction? What are the contents of the segment descriptor caches when the fault occurs?
Re: Why does MSVC generate SS traps itself?
Posted: Thu Nov 10, 2016 4:34 am
by MollenOS
Lukand wrote:iansjack wrote:Debugging, and the Bochs log, should show you exactly where the code is faulting.
Are you kidding me? Why didn't you readed my post?
MollenOs wrote:
Your problem has to lie somewhere else, maybe in your task switching code instead, because the code itself would never cause any problems (except you should make ticks volatile, otherwise MSVC will optimize the loop to infinite loop instead)
It is already volatile, but it happened
inside sleep(), not in interrupt.
I ask again, why would MSVC compiler put SST flags?
But you see, no matter where it happens it might still be because of interrupts. If your task is returning from the scheduler (by switch_task or w/e you call it), and the data is incorrect, segments are incorrect or a stack is overwritten with invalid data (which in turn may cause the registers/segments you restore to be invalid), then it will fail at a seemingly innocent instruction, because that is the next instruction to be executed.
It's almost always because of your scheduler, interrupt or switch task code if your code fails randomly (or at innocent instructions). The fault does not lie with the sleep code. There is nothing in your sleep code that would cause an exception, and MSVC does not insert calls to exceptions randomly.
Re: Why does MSVC generate SS traps itself?
Posted: Thu Nov 10, 2016 4:40 am
by iansjack
Lukand wrote:Are you kidding me?
No.
You don't tell us what instruction caused the fault. What the contents of the registers are. What the contents of the stack are. You don't even bother to show us the relevant parts of the Bochs log. But you ask us to guess what you have done wrong.
I'm not kidding you, but I do seem to be overestimating your debugging ability.
Re: Why does MSVC generate SS traps itself?
Posted: Sun Nov 13, 2016 1:35 pm
by Ycep
Let us see... What the heck is problem there.
Code: Select all
_declspec(naked) void NewPitIrq()
{
_asm
{
inc [ticks]
}
if(ticks==ExecTime)
{
Thread thr=queue[Qbottom++];
if(thr.type==0)
{
thr.type=EXECUTING_THREAD;
if(ThreadAmount<17)ExecTime=ticks+Optimizer[ThreadAmount];
//TODO ThreadAmount>250
else ExecTime=ticks+1000/ThreadAmount;
curThread=thr;
}
}
_asm
{
mov dx, 0x20
mov al, 0x20
out dx, al
}
_asm
{
iretd
}
}
Oh mein Gott... I did not initialized Qbottom and Qtop.
Now it generates "Invalid opcode".
Re: Why does MSVC generate SS traps itself?
Posted: Mon Nov 14, 2016 6:19 am
by MollenOS
I would not use inline assembly for IRQ handlers, it's prone to disasters. Code your IRQ handlers in pure assembly, and instead make calls to extern C functions. But that is only the start of your problems..
You do not save the current context before doing anything and you don't restore. This means that your IRQ handler modifies almost all registers, destroying the state before the IRQ happens, and thus results in unexpected behavior when the Irq returns. The stack is ruined too because you never take into account that the Irq pushes variables onto the stack.
Re: Why does MSVC generate SS traps itself?
Posted: Mon Nov 14, 2016 8:44 am
by Ycep
MollenOS wrote:I would not use inline assembly for IRQ handlers, it's prone to disasters. Code your IRQ handlers in pure assembly, and instead make calls to extern C functions. But that is only the start of your problems..
You do not save the current context before doing anything and you don't restore. This means that your IRQ handler modifies almost all registers, destroying the state before the IRQ happens, and thus results in unexpected behavior when the Irq returns. The stack is ruined too because you never take into account that the Irq pushes variables onto the stack.
Thanks. I will stop a little bit with multithreading and go up to filesystems before I continue to mess around with it.