hikey: Add UEFI sources for reference

UEFI needs to be built outside Android build system.
Please follow the instructions in README.

The sources correspond to:
https://github.com/96boards/edk2/commit/14eae0c12e71fd33c4c0fc51e4475e8db02566cf
https://github.com/96boards/arm-trusted-firmware/commit/e9b4909dcd75fc4ae7041cfb83d28ab9adb7afdf
https://github.com/96boards/l-loader/commit/6b784ad5c4ab00e2b1c6f53cd5f74054e5d00a78
https://git.linaro.org/uefi/uefi-tools.git/commit/abe618f8ab72034fff1ce46c9c006a2c6bd40a7e

Change-Id: Ieeefdb63e673e0c8e64e0a1f02c7bddc63b2c7fb
Signed-off-by: Vishal Bhoj <vishal.bhoj@linaro.org>
diff --git a/uefi/linaro-edk2/PcAtChipsetPkg/PciHostBridgeDxe/X64/IoFifo.asm b/uefi/linaro-edk2/PcAtChipsetPkg/PciHostBridgeDxe/X64/IoFifo.asm
new file mode 100644
index 0000000..d16f024
--- /dev/null
+++ b/uefi/linaro-edk2/PcAtChipsetPkg/PciHostBridgeDxe/X64/IoFifo.asm
@@ -0,0 +1,125 @@
+;------------------------------------------------------------------------------

+;

+; Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>

+; 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.

+;

+;------------------------------------------------------------------------------

+

+    .code

+

+;------------------------------------------------------------------------------

+;  VOID

+;  EFIAPI

+;  IoReadFifo8 (

+;    IN UINTN                  Port,              // rcx

+;    IN UINTN                  Size,              // rdx

+;    IN VOID                   *Buffer            // r8

+;    );

+;------------------------------------------------------------------------------

+IoReadFifo8 PROC

+    cld

+    xchg    rcx, rdx

+    xchg    rdi, r8             ; rdi: buffer address; r8: save rdi

+rep insb

+    mov     rdi, r8             ; restore rdi

+    ret

+IoReadFifo8 ENDP

+

+;------------------------------------------------------------------------------

+;  VOID

+;  EFIAPI

+;  IoReadFifo16 (

+;    IN UINTN                  Port,              // rcx

+;    IN UINTN                  Size,              // rdx

+;    IN VOID                   *Buffer            // r8

+;    );

+;------------------------------------------------------------------------------

+IoReadFifo16 PROC

+    cld

+    xchg    rcx, rdx

+    xchg    rdi, r8             ; rdi: buffer address; r8: save rdi

+rep insw

+    mov     rdi, r8             ; restore rdi

+    ret

+IoReadFifo16 ENDP

+

+;------------------------------------------------------------------------------

+;  VOID

+;  EFIAPI

+;  IoReadFifo32 (

+;    IN UINTN                  Port,              // rcx

+;    IN UINTN                  Size,              // rdx

+;    IN VOID                   *Buffer            // r8

+;    );

+;------------------------------------------------------------------------------

+IoReadFifo32 PROC

+    cld

+    xchg    rcx, rdx

+    xchg    rdi, r8             ; rdi: buffer address; r8: save rdi

+rep insd

+    mov     rdi, r8             ; restore rdi

+    ret

+IoReadFifo32 ENDP

+

+;------------------------------------------------------------------------------

+;  VOID

+;  EFIAPI

+;  IoWriteFifo8 (

+;    IN UINTN                  Port,              // rcx

+;    IN UINTN                  Size,              // rdx

+;    IN VOID                   *Buffer            // r8

+;    );

+;------------------------------------------------------------------------------

+IoWriteFifo8 PROC

+    cld

+    xchg    rcx, rdx

+    xchg    rsi, r8             ; rsi: buffer address; r8: save rsi

+rep outsb

+    mov     rsi, r8             ; restore rsi

+    ret

+IoWriteFifo8 ENDP

+

+;------------------------------------------------------------------------------

+;  VOID

+;  EFIAPI

+;  IoWriteFifo16 (

+;    IN UINTN                  Port,              // rcx

+;    IN UINTN                  Size,              // rdx

+;    IN VOID                   *Buffer            // r8

+;    );

+;------------------------------------------------------------------------------

+IoWriteFifo16 PROC

+    cld

+    xchg    rcx, rdx

+    xchg    rsi, r8             ; rsi: buffer address; r8: save rsi

+rep outsw

+    mov     rsi, r8             ; restore rsi

+    ret

+IoWriteFifo16 ENDP

+

+;------------------------------------------------------------------------------

+;  VOID

+;  EFIAPI

+;  IoWriteFifo32 (

+;    IN UINTN                  Port,              // rcx

+;    IN UINTN                  Size,              // rdx

+;    IN VOID                   *Buffer            // r8

+;    );

+;------------------------------------------------------------------------------

+IoWriteFifo32 PROC

+    cld

+    xchg    rcx, rdx

+    xchg    rsi, r8             ; rsi: buffer address; r8: save rsi

+rep outsd

+    mov     rsi, r8             ; restore rsi

+    ret

+IoWriteFifo32 ENDP

+

+    END

+