mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2024-12-18 15:27:48 +01:00
121 lines
3.9 KiB
NASM
121 lines
3.9 KiB
NASM
|
;------------------------------------------------------------------------------
|
||
|
;
|
||
|
; Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>
|
||
|
; Copyright (c) 2017, AMD Incorporated. All rights reserved.<BR>
|
||
|
;
|
||
|
; SPDX-License-Identifier: BSD-2-Clause-Patent
|
||
|
;
|
||
|
;------------------------------------------------------------------------------
|
||
|
|
||
|
DEFAULT REL
|
||
|
SECTION .text
|
||
|
|
||
|
;------------------------------------------------------------------------------
|
||
|
; VOID
|
||
|
; EFIAPI
|
||
|
; IoReadFifo8 (
|
||
|
; IN UINTN Port, // rcx
|
||
|
; IN UINTN Size, // rdx
|
||
|
; OUT VOID *Buffer // r8
|
||
|
; );
|
||
|
;------------------------------------------------------------------------------
|
||
|
global ASM_PFX(IoReadFifo8)
|
||
|
ASM_PFX(IoReadFifo8):
|
||
|
cld
|
||
|
xchg rcx, rdx
|
||
|
xchg rdi, r8 ; rdi: buffer address; r8: save rdi
|
||
|
rep insb
|
||
|
mov rdi, r8 ; restore rdi
|
||
|
ret
|
||
|
|
||
|
;------------------------------------------------------------------------------
|
||
|
; VOID
|
||
|
; EFIAPI
|
||
|
; IoReadFifo16 (
|
||
|
; IN UINTN Port, // rcx
|
||
|
; IN UINTN Size, // rdx
|
||
|
; OUT VOID *Buffer // r8
|
||
|
; );
|
||
|
;------------------------------------------------------------------------------
|
||
|
global ASM_PFX(IoReadFifo16)
|
||
|
ASM_PFX(IoReadFifo16):
|
||
|
cld
|
||
|
xchg rcx, rdx
|
||
|
xchg rdi, r8 ; rdi: buffer address; r8: save rdi
|
||
|
rep insw
|
||
|
mov rdi, r8 ; restore rdi
|
||
|
ret
|
||
|
|
||
|
;------------------------------------------------------------------------------
|
||
|
; VOID
|
||
|
; EFIAPI
|
||
|
; IoReadFifo32 (
|
||
|
; IN UINTN Port, // rcx
|
||
|
; IN UINTN Size, // rdx
|
||
|
; OUT VOID *Buffer // r8
|
||
|
; );
|
||
|
;------------------------------------------------------------------------------
|
||
|
global ASM_PFX(IoReadFifo32)
|
||
|
ASM_PFX(IoReadFifo32):
|
||
|
cld
|
||
|
xchg rcx, rdx
|
||
|
xchg rdi, r8 ; rdi: buffer address; r8: save rdi
|
||
|
rep insd
|
||
|
mov rdi, r8 ; restore rdi
|
||
|
ret
|
||
|
|
||
|
;------------------------------------------------------------------------------
|
||
|
; VOID
|
||
|
; EFIAPI
|
||
|
; IoWriteFifo8 (
|
||
|
; IN UINTN Port, // rcx
|
||
|
; IN UINTN Size, // rdx
|
||
|
; IN VOID *Buffer // r8
|
||
|
; );
|
||
|
;------------------------------------------------------------------------------
|
||
|
global ASM_PFX(IoWriteFifo8)
|
||
|
ASM_PFX(IoWriteFifo8):
|
||
|
cld
|
||
|
xchg rcx, rdx
|
||
|
xchg rsi, r8 ; rsi: buffer address; r8: save rsi
|
||
|
rep outsb
|
||
|
mov rsi, r8 ; restore rsi
|
||
|
ret
|
||
|
|
||
|
;------------------------------------------------------------------------------
|
||
|
; VOID
|
||
|
; EFIAPI
|
||
|
; IoWriteFifo16 (
|
||
|
; IN UINTN Port, // rcx
|
||
|
; IN UINTN Size, // rdx
|
||
|
; IN VOID *Buffer // r8
|
||
|
; );
|
||
|
;------------------------------------------------------------------------------
|
||
|
global ASM_PFX(IoWriteFifo16)
|
||
|
ASM_PFX(IoWriteFifo16):
|
||
|
cld
|
||
|
xchg rcx, rdx
|
||
|
xchg rsi, r8 ; rsi: buffer address; r8: save rsi
|
||
|
rep outsw
|
||
|
mov rsi, r8 ; restore rsi
|
||
|
ret
|
||
|
|
||
|
;------------------------------------------------------------------------------
|
||
|
; VOID
|
||
|
; EFIAPI
|
||
|
; IoWriteFifo32 (
|
||
|
; IN UINTN Port, // rcx
|
||
|
; IN UINTN Size, // rdx
|
||
|
; IN VOID *Buffer // r8
|
||
|
; );
|
||
|
;------------------------------------------------------------------------------
|
||
|
global ASM_PFX(IoWriteFifo32)
|
||
|
ASM_PFX(IoWriteFifo32):
|
||
|
cld
|
||
|
xchg rcx, rdx
|
||
|
xchg rsi, r8 ; rsi: buffer address; r8: save rsi
|
||
|
rep outsd
|
||
|
mov rsi, r8 ; restore rsi
|
||
|
ret
|
||
|
|