Added debug to Threads_GetNext
[tpg/acess2.git] / Kernel / threads.c
index 1ccac9f..bb0ec73 100644 (file)
@@ -93,7 +93,12 @@ void Threads_Init()
                cur->ThreadName = "Idle Thread";
                Threads_SetTickets(0);  // Never called randomly
                cur->Quantum = 1;       // 1 slice quantum
-               for(;;) __asm__ __volatile__ ("hlt");   // Just yeilds
+               HALT();
+               for(;;) {
+                       //Log("---- Idle");
+                       //Threads_Dump();
+                       HALT(); // Just yeilds
+               }
        }
        #endif
        
@@ -137,6 +142,8 @@ void Threads_SetTickets(int Num)
  */
 int Threads_WaitTID(int TID, int *status)
 {
+       Threads_Dump();
+       
        // Any Child
        if(TID == -1) {
                
@@ -333,7 +340,7 @@ void Threads_Kill(tThread *Thread, int Status)
  */
 void Threads_Yield()
 {
-       Proc_GetCurThread()->Quantum = 0;
+       Proc_GetCurThread()->Remaining = 0;
        HALT();
 }
 
@@ -346,7 +353,7 @@ void Threads_Sleep()
        tThread *cur = Proc_GetCurThread();
        tThread *thread;
        
-       //Log("Proc_Sleep: %i going to sleep", gCurrentThread->TID);
+       Log("Proc_Sleep: %i going to sleep", cur->TID);
        
        // Acquire Spinlock
        LOCK( &giThreadListLock );
@@ -528,6 +535,8 @@ tThread *Threads_GetNextToRun(int CPU)
                return gActiveThreads;
        }
        
+       Log("giNumActiveThreads=%i,giTotalTickets=%i",
+               giNumActiveThreads, giTotalTickets);
        // Get the ticket number
        ticket = number = rand() % giTotalTickets;
        

UCC git Repository :: git.ucc.asn.au