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/Nt32Pkg/MiscSubClassPlatformDxe/MiscResetCapabilitiesFunction.c b/uefi/linaro-edk2/Nt32Pkg/MiscSubClassPlatformDxe/MiscResetCapabilitiesFunction.c
new file mode 100644
index 0000000..7c1ffab
--- /dev/null
+++ b/uefi/linaro-edk2/Nt32Pkg/MiscSubClassPlatformDxe/MiscResetCapabilitiesFunction.c
@@ -0,0 +1,72 @@
+/** @file

+  ResetCapabilities.

+  SMBIOS type 23.

+  

+Copyright (c) 2009 - 2011, 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.

+

+**/

+

+

+#include "MiscSubclassDriver.h"

+/**

+  This function makes boot time changes to the contents of the

+  MiscOemString (Type 11).

+

+  @param  RecordData                 Pointer to copy of RecordData from the Data Table.  

+

+  @retval EFI_SUCCESS                All parameters were valid.

+  @retval EFI_UNSUPPORTED            Unexpected RecordType value.

+  @retval EFI_INVALID_PARAMETER      Invalid parameter was found.

+

+**/

+MISC_SMBIOS_TABLE_FUNCTION(MiscResetCapabilities)

+{

+  EFI_STATUS               Status;

+  EFI_SMBIOS_HANDLE        SmbiosHandle;

+  SMBIOS_TABLE_TYPE23      *SmbiosRecord;

+  EFI_MISC_RESET_CAPABILITIES   *ForType23InputData;

+  

+  ForType23InputData = (EFI_MISC_RESET_CAPABILITIES *)RecordData;

+

+  //

+  // First check for invalid parameters.

+  //

+  if (RecordData == NULL) {

+    return EFI_INVALID_PARAMETER;

+  }

+

+

+  //

+  // Two zeros following the last string.

+  //

+  SmbiosRecord = AllocatePool(sizeof (SMBIOS_TABLE_TYPE23) + 1 + 1);

+  ZeroMem(SmbiosRecord, sizeof (SMBIOS_TABLE_TYPE23) + 1 + 1);

+

+  SmbiosRecord->Hdr.Type = EFI_SMBIOS_TYPE_SYSTEM_RESET;

+  SmbiosRecord->Hdr.Length = sizeof (SMBIOS_TABLE_TYPE23);

+  //

+  // Make handle chosen by smbios protocol.add automatically.

+  // 

+  SmbiosRecord->Hdr.Handle    = 0;  

+  SmbiosRecord->Capabilities  = *(UINT8*)&(ForType23InputData->ResetCapabilities);

+  SmbiosRecord->ResetCount    = (UINT16)ForType23InputData->ResetCount;

+  SmbiosRecord->ResetLimit    = (UINT16)ForType23InputData->ResetLimit;  

+  SmbiosRecord->TimerInterval = (UINT16)ForType23InputData->ResetTimerInterval;

+  SmbiosRecord->Timeout       = (UINT16)ForType23InputData->ResetTimeout;

+

+  //

+  // Now we have got the full smbios record, call smbios protocol to add this record.

+  //

+  Status = AddSmbiosRecord (Smbios, &SmbiosHandle, (EFI_SMBIOS_TABLE_HEADER *) SmbiosRecord);

+

+  FreePool(SmbiosRecord);

+  return Status;

+}

+