// If it was a user, tell the thread handler
if(ErrorCode & 4) {
- Warning("User Pagefault: Instruction at %p accessed %p\n", Regs->eip, Addr);
+ Warning("User Pagefault: Instruction at %p accessed %p", Regs->eip, Addr);
+ __asm__ __volatile__ ("sti"); // Restart IRQs
Threads_SegFault(Addr);
return ;
}
Term->Text[ Term->WritePos ].Colour = Term->CurColour;
Term->WritePos --;
} while(Term->WritePos && i-- && Term->Text[ Term->WritePos ].Ch == '\0');
+ if(Term->Text[ Term->WritePos ].Ch != '\0')
+ Term->WritePos ++;
break;
default:
tThread *t = Threads_GetThread(TID);
int initStatus = t->Status;
int ret;
- while(t->Status == initStatus) Threads_Yield();
+
+ if(initStatus != THREAD_STAT_ZOMBIE)
+ while(t->Status == initStatus) {
+ Threads_Yield();
+ }
+
ret = t->RetStatus;
switch(t->Status)
{
Threads_Kill( Proc_GetCurThread(), (Uint)Status & 0xFF );
else
Threads_Kill( Threads_GetThread(TID), (Uint)Status & 0xFF );
+ for(;;) HALT(); // Just in case
}
/**
// Release spinlocks
RELEASE( &Thread->IsLocked ); // Released first so that it IS released
RELEASE( &giThreadListLock );
+
+ //Log("Thread %i went *hurk*", Thread->TID);
+
if(Status != -1) HALT();
}
void Threads_SegFault(tVAddr Addr)
{
//Threads_SendSignal( Proc_GetCurThread()->TID, SIGSEGV );
- Log("Thread #%i committed a segfault at address %p\n", Proc_GetCurThread()->TID, Addr);
- Threads_Exit( 0, 0 );
+ Warning("Thread #%i committed a segfault at address %p", Proc_GetCurThread()->TID, Addr);
+ Threads_Exit( 0, -1 );
}
// Read In Command Line\r
do {\r
read(_stdin, 1, &ch); // Read Character from stdin (read is a blocking call)\r
- // Ignore control characters\r
+ // Control characters\r
if(ch == '\x1B') {\r
read(_stdin, 1, &ch); // Read control character\r
switch(ch)\r
write(_stdout, 1, &ch);\r
continue;\r
}\r
+ // Tab\r
+ if(ch == '\t') {\r
+ //TODO: Implement Tab-Completion\r
+ //Currently just ignore tabs\r
+ continue;\r
+ }\r
+ \r
// Expand Buffer\r
if(len > space) {\r
space += 256;\r
if(uid == -1) printf("\n");
sUsername = GetUsername();
sPassword = GetPassword();
- printf("\n");
} while( (uid = ValidateUser(sUsername, sPassword)) == -1 );
printf("\n");