summaryrefslogtreecommitdiff
path: root/DuetPkg/DxeIpl/Ia32/EnterDxeCore.asm
blob: 0689a824c341f6dfd78002014d3af41826f1ac5a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
      TITLE   EnterDxeCore.asm: Assembly code for the entering DxeCore
;------------------------------------------------------------------------------
;*
;*   Copyright 2006, Intel Corporation                                                         
;*   All rights reserved. This program and the accompanying materials                          
;*   are licensed and made available under the terms and conditions of the BSD License         
;*   which accompanies this distribution.  The full text of the license may be found at        
;*   http://opensource.org/licenses/bsd-license.php                                            
;*                                                                                             
;*   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,                     
;*   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.             
;*   
;*    EnterDxeCore.asm
;*  
;*   Abstract:
;*
;------------------------------------------------------------------------------

.686p
.model  flat        

.code
.stack
.MMX
.XMM

;
; VOID
; EnterDxeMain (
;   IN VOID *StackTop,
;   IN VOID *DxeCoreEntryPoint,
;   IN VOID *Hob,
;   IN VOID *PageTable
;   )
;
EnterDxeMain    PROC  C    \
  StackTop:DWORD,          \
  DxeCoreEntryPoint:DWORD, \
  Hob:DWORD,               \
  PageTable:DWORD
  
  mov   eax, PageTable
;  mov   cr3, eax     ; load page table
;  mov   eax, cr4
;  bts   eax, 4       ; enable CR4.PSE
;  mov   cr4, eax
;  mov   eax, cr0
;  bts   eax, 31      ; enable CR0.PG
;  mov   cr0, eax
  mov   ecx, DxeCoreEntryPoint
  mov   eax, StackTop
  mov   esp, eax
  mov   edx, Hob
  push  edx
  push  0
  jmp   ecx

; should never get here
  jmp $
  ret

EnterDxeMain    ENDP

END