mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-31 01:24:12 +02:00
BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3223 In the current design, memory protection is not available till CpuDxe is loaded. To resolve this, introduce CpuArchLib to move the CPU Architectural initialization to DxeCore. Cc: Eric Dong <eric.dong@intel.com> Cc: Ray Ni <ray.ni@intel.com> Cc: Laszlo Ersek <lersek@redhat.com> Cc: Rahul Kumar <rahul1.kumar@intel.com> Cc: Vitaly Cheptsov <vit9696@protonmail.com> Signed-off-by: Marvin Häuser <mhaeuser@posteo.de>
48 lines
1.3 KiB
NASM
48 lines
1.3 KiB
NASM
;------------------------------------------------------------------------------
|
|
;*
|
|
;* Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>
|
|
;* SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
;*
|
|
;* CpuAsm.nasm
|
|
;*
|
|
;* Abstract:
|
|
;*
|
|
;------------------------------------------------------------------------------
|
|
|
|
SECTION .text
|
|
|
|
;------------------------------------------------------------------------------
|
|
; VOID
|
|
; SetCodeSelector (
|
|
; UINT16 Selector
|
|
; );
|
|
;------------------------------------------------------------------------------
|
|
global ASM_PFX(SetCodeSelector)
|
|
ASM_PFX(SetCodeSelector):
|
|
mov ecx, [esp+4]
|
|
sub esp, 0x10
|
|
lea eax, [setCodeSelectorLongJump]
|
|
mov [esp], eax
|
|
mov [esp+4], cx
|
|
jmp dword far [esp]
|
|
setCodeSelectorLongJump:
|
|
add esp, 0x10
|
|
ret
|
|
|
|
;------------------------------------------------------------------------------
|
|
; VOID
|
|
; SetDataSelectors (
|
|
; UINT16 Selector
|
|
; );
|
|
;------------------------------------------------------------------------------
|
|
global ASM_PFX(SetDataSelectors)
|
|
ASM_PFX(SetDataSelectors):
|
|
mov ecx, [esp+4]
|
|
o16 mov ss, cx
|
|
o16 mov ds, cx
|
|
o16 mov es, cx
|
|
o16 mov fs, cx
|
|
o16 mov gs, cx
|
|
ret
|
|
|