/** @file
    Constructor and Deconstructor functions for <wchar.h>.

    Unless explicitly stated otherwise, the functions defined in this file order
    two wide characters the same way as two integers of the underlying integer
    type designated by wchar_t.

    Copyright (c) 2010 - 2013, 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 that accompanies this distribution.
    The full text of the license may be found at
    http://opensource.org/licenses/bsd-license.

    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  <Uefi.h>
#include  <Library/DebugLib.h>

#include  <LibConfig.h>

#include  <wchar.h>

/* Data initialized by the library constructor */
UINT8 *__wchar_bitmap       = NULL;
UINTN  __wchar_bitmap_size;
UINTN  __wchar_bitmap_64;

EFI_STATUS
EFIAPI
__wchar_construct(
  IN EFI_HANDLE        ImageHandle,
  IN EFI_SYSTEM_TABLE  *SystemTable
  )
{
  EFI_STATUS  Status;

  if( __wchar_bitmap == NULL) {
    __wchar_bitmap_size = (WCHAR_MAX + 8) / 8U;

    Status  = SystemTable->BootServices->AllocatePool(
                EfiBootServicesData, __wchar_bitmap_size, (VOID **)&__wchar_bitmap);
    ASSERT(__wchar_bitmap != NULL);
    if (EFI_ERROR (Status)) {
      __wchar_bitmap = NULL;
      return Status;
    }
    return  RETURN_SUCCESS;
  }
  return RETURN_ALREADY_STARTED;
}

EFI_STATUS
EFIAPI
__wchar_deconstruct(
  IN EFI_HANDLE        ImageHandle,
  IN EFI_SYSTEM_TABLE  *SystemTable
  )
{
  EFI_STATUS    Status  = RETURN_SUCCESS;

  if( __wchar_bitmap != NULL) {
    Status = SystemTable->BootServices->FreePool( __wchar_bitmap);
    ASSERT_EFI_ERROR (Status);
    __wchar_bitmap = NULL;
  }
  return Status;
}