Palacios Public Git Repository

To checkout Palacios execute

  git clone http://v3vee.org/palacios/palacios.web/palacios.git
This will give you the master branch. You probably want the devel branch or one of the release branches. To switch to the devel branch, simply execute
  cd palacios
  git checkout --track -b devel origin/devel
The other branches are similar.


removed debugging
[palacios.git] / palacios / src / geekos / lowlevel.asm
index f90212c..30979de 100644 (file)
@@ -2,7 +2,7 @@
 ; Low level interrupt/thread handling code for GeekOS.
 ; Copyright (c) 2001,2003,2004 David H. Hovemeyer <daveho@cs.umd.edu>
 ; Copyright (c) 2003, Jeffrey K. Hollingsworth <hollings@cs.umd.edu>
-; $Revision: 1.2 $
+; $Revision: 1.8 $
 
 ; This is free software.  You are permitted to use,
 ; redistribute, and modify it as specified in the file "COPYING".
@@ -126,6 +126,10 @@ IMPORT Make_Runnable
 ; Function to activate a new user context (if needed).
 IMPORT Switch_To_User_Context
 
+; Debug functions
+IMPORT SerialPrintHex
+IMPORT SerialPutChar
+
 ; Sizes of interrupt handler entry points for interrupts with
 ; and without error codes.  The code in idt.c uses this
 ; information to infer the layout of the table of interrupt
@@ -171,7 +175,9 @@ EXPORT cpuid_edx
 EXPORT Set_MSR
 EXPORT Get_MSR
 
+
 EXPORT Get_CR2
+EXPORT Get_CR3
 
 
 EXPORT Proc_test
@@ -279,9 +285,15 @@ cpuid_edx:
        push    ebp
        mov     ebp, esp
        push    edx
+       push    ecx
+       push    ebx
+
        mov     eax, [ebp + 8]
        cpuid
        mov     eax, edx
+
+       pop     ebx
+       pop     ecx
        pop     edx
        pop     ebp
        ret
@@ -294,11 +306,17 @@ align 8
 cpuid_ecx:
        push    ebp
        mov     ebp, esp
+       push    edx
        push    ecx
+       push    ebx
+
        mov     eax, [ebp + 8]
        cpuid
        mov     eax, ecx
+
+       pop     ebx
        pop     ecx
+       pop     edx
        pop     ebp
        ret
 
@@ -307,8 +325,19 @@ cpuid_ecx:
 ;
 align 8
 cpuid_eax:
+       push    ebp
+       mov     ebp, esp
+       push    edx
+       push    ecx
+       push    ebx
+
        mov     eax, [esp+4]
        cpuid
+
+       pop     ebx
+       pop     ecx
+       pop     edx
+       pop     ebp
        ret
 
 ;
@@ -350,6 +379,7 @@ Get_MSR:
 
 
 
+
 align 8
 Get_CR2:
        mov     eax, cr2
@@ -357,6 +387,11 @@ Get_CR2:
 
 
 align 8
+Get_CR3:
+       mov     eax, cr3
+       ret
+
+align 8
 Proc_test:
        push    ebp
        mov     ebp, esp
@@ -390,6 +425,17 @@ Handle_Interrupt:
        mov     esi, [esp+REG_SKIP]     ; get interrupt number
        mov     ebx, [eax+esi*4]        ; get address of handler function
 
+;      push    esi
+;      call    SerialPrintHex
+;      pop     esi
+
+;      push    eax
+;      mov     eax, 0xa
+;      push    eax
+;      call    SerialPutChar
+;      pop     eax
+;      pop     eax
+
        ; Call the handler.
        ; The argument passed is a pointer to an Interrupt_State struct,
        ; which describes the stack layout for all interrupts.
@@ -426,12 +472,64 @@ Handle_Interrupt:
        mov     [g_needReschedule], dword 0
 
 .restore:
+
+;      push    ebp
+;      mov     ebp, esp
+;      pusha   
+;
+;      mov     eax, 0xa
+;      push    eax
+;      call    SerialPutChar
+;      pop     eax
+;      mov     eax, 0xa
+;      push    eax
+;      call    SerialPutChar
+;      pop     eax
+;
+;        mov     ecx, 4
+;        mov     edx, 24 
+;
+;.loop:
+;      mov     eax, [ebp + ecx]
+;            
+;        push    eax
+;      call    SerialPrintHex
+;      pop     eax
+;
+;      mov     eax, 0xa
+;      push    eax
+;      call    SerialPutChar
+;      pop     eax
+;        
+;        add     ecx, 4
+;      dec     edx
+;      jnz     .loop
+;
+;
+;      popa
+;      pop     ebp
+       
        ; Activate the user context, if necessary.
        Activate_User_Context
 
        ; Restore registers
        Restore_Registers
 
+
+;      pusha   
+
+;      mov     eax, 0xaa
+;      push    eax
+;      call    SerialPrintHex
+;      pop     eax
+
+;      mov     eax, 0xa
+;      push    eax
+;      call    SerialPutChar
+;      pop     eax
+
+;      popa
+
        ; Return from the interrupt.
        iret