2007-06-28 09:00:39 +02:00
|
|
|
/*++
|
|
|
|
|
2010-04-28 14:14:56 +02:00
|
|
|
Copyright (c) 2004 - 2007, Intel Corporation. All rights reserved.<BR>
|
|
|
|
This program and the accompanying materials
|
2007-06-28 09:00:39 +02:00
|
|
|
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.
|
|
|
|
|
|
|
|
Module Name:
|
|
|
|
|
|
|
|
EfiBind.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
Processor or Compiler specific defines and types for Intel Itanium(TM).
|
|
|
|
We are using the ANSI C 2000 _t type definitions for basic types.
|
|
|
|
This it technically a violation of the coding standard, but they
|
|
|
|
are used to make EfiTypes.h portable. Code other than EfiTypes.h
|
|
|
|
should never use any ANSI C 2000 _t integer types.
|
|
|
|
|
|
|
|
--*/
|
|
|
|
|
|
|
|
#ifndef _EFI_BIND_H_
|
|
|
|
#define _EFI_BIND_H_
|
|
|
|
|
|
|
|
|
|
|
|
#define EFI_DRIVER_ENTRY_POINT(InitFunction)
|
|
|
|
|
|
|
|
#define EFI_APPLICATION_ENTRY_POINT EFI_DRIVER_ENTRY_POINT
|
|
|
|
|
2008-12-03 14:53:50 +01:00
|
|
|
#define ECP_CPU_IPF
|
2007-06-28 09:00:39 +02:00
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// Make sure we are useing the correct packing rules per EFI specification
|
|
|
|
//
|
|
|
|
#pragma pack()
|
|
|
|
|
|
|
|
|
|
|
|
#if _MSC_EXTENSIONS
|
2008-11-18 10:57:59 +01:00
|
|
|
|
|
|
|
#if __INTEL_COMPILER
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disable the extra ";" warning;
|
|
|
|
// All places referencing EFI_GUID_STRING MACRO will generate this error.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 424 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// error #593: variable "Status" was set but never used
|
|
|
|
// This error may be flagged if a function only do ASSERT on return status when
|
|
|
|
// EFI_DEBUG is not defined (EDK's ASSERT will be defined as empty statement).
|
|
|
|
// To make EdkCompatibilityPkg buildable by ICC with EFI_DEBUG undefined, disable
|
|
|
|
// this warning.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 593 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disable ICC's remark #869: "Parameter" was never referenced warning.
|
|
|
|
// This is legal ANSI C code so we disable the remark that is turned on with -Wall
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 869 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disable ICC's remark #1418: external function definition with no prior declaration.
|
|
|
|
// This is legal ANSI C code so we disable the remark that is turned on with /W4
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 1418 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disable ICC's remark #1419: external declaration in primary source file
|
|
|
|
// This is legal ANSI C code so we disable the remark that is turned on with /W4
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 1419 )
|
|
|
|
|
2009-02-01 10:23:46 +01:00
|
|
|
//
|
|
|
|
// Disable ICC's remark #869: "Parameter" was never referenced warning.
|
|
|
|
// This is legal ANSI C code so we disable the remark that is turned on with -Wall
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 869 )
|
|
|
|
|
2008-11-18 10:57:59 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2007-06-28 09:00:39 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Disable warning that make it impossible to compile at /W4
|
|
|
|
// This only works for Microsoft tools. Copied from the
|
|
|
|
// IA-32 version of efibind.h
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disabling bitfield type checking warnings.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4214 )
|
|
|
|
|
|
|
|
|
|
|
|
// Disabling the unreferenced formal parameter warnings.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4100 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disable slightly different base types warning as CHAR8 * can not be set
|
|
|
|
// to a constant string.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4057 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// ASSERT(FALSE) or while (TRUE) are legal constructes so supress this warning
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4127 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Can not cast a function pointer to a data pointer. We need to do this on
|
|
|
|
// IPF to get access to the PLABEL.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4514 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Int64ShllMod32 unreferenced inline function
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4054 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Unreferenced formal parameter - We are object oriented, so we pass This even
|
|
|
|
// if we don't need them.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4100 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// This warning is caused by empty (after preprocessing) souce file.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4206 )
|
|
|
|
|
|
|
|
//
|
|
|
|
// Warning: The result of the unary '&' operator may be unaligned. Ignore it.
|
|
|
|
//
|
|
|
|
#pragma warning ( disable : 4366 )
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#if (__STDC_VERSION__ < 199901L)
|
|
|
|
//
|
|
|
|
// No ANSI C 2000 stdint.h integer width declarations, so define equivalents
|
|
|
|
//
|
|
|
|
|
|
|
|
#if _MSC_EXTENSIONS
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// use Microsoft C complier dependent interger width types
|
|
|
|
//
|
|
|
|
typedef unsigned __int64 uint64_t;
|
|
|
|
typedef __int64 int64_t;
|
|
|
|
typedef unsigned __int32 uint32_t;
|
|
|
|
typedef __int32 int32_t;
|
|
|
|
typedef unsigned short uint16_t;
|
|
|
|
typedef short int16_t;
|
|
|
|
typedef unsigned char uint8_t;
|
|
|
|
typedef char int8_t;
|
|
|
|
#else
|
|
|
|
#ifdef _EFI_P64
|
|
|
|
//
|
|
|
|
// P64 - is Intel Itanium(TM) speak for pointers being 64-bit and longs and ints
|
|
|
|
// are 32-bits
|
|
|
|
//
|
|
|
|
typedef unsigned long long uint64_t;
|
|
|
|
typedef long long int64_t;
|
|
|
|
typedef unsigned int uint32_t;
|
|
|
|
typedef int int32_t;
|
|
|
|
typedef unsigned short uint16_t;
|
|
|
|
typedef short int16_t;
|
|
|
|
typedef unsigned char uint8_t;
|
|
|
|
typedef char int8_t;
|
|
|
|
#else
|
|
|
|
//
|
|
|
|
// Assume LP64 - longs and pointers are 64-bit. Ints are 32-bit.
|
|
|
|
//
|
|
|
|
typedef unsigned long uint64_t;
|
|
|
|
typedef long int64_t;
|
|
|
|
typedef unsigned int uint32_t;
|
|
|
|
typedef int int32_t;
|
|
|
|
typedef unsigned short uint16_t;
|
|
|
|
typedef short int16_t;
|
|
|
|
typedef unsigned char uint8_t;
|
|
|
|
typedef char int8_t;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#else
|
|
|
|
//
|
|
|
|
// Use ANSI C 2000 stdint.h integer width declarations
|
|
|
|
//
|
|
|
|
#include "stdint.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//
|
|
|
|
// Native integer size in stdint.h
|
|
|
|
//
|
|
|
|
typedef uint64_t uintn_t;
|
|
|
|
typedef int64_t intn_t;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Processor specific defines
|
|
|
|
//
|
|
|
|
#define EFI_MAX_BIT 0x8000000000000000
|
|
|
|
#define MAX_2_BITS 0xC000000000000000
|
|
|
|
|
|
|
|
//
|
|
|
|
// Maximum legal Itanium-based address
|
|
|
|
//
|
|
|
|
#define EFI_MAX_ADDRESS 0xFFFFFFFFFFFFFFFF
|
|
|
|
|
|
|
|
//
|
|
|
|
// Bad pointer value to use in check builds.
|
|
|
|
// if you see this value you are using uninitialized or free'ed data
|
|
|
|
//
|
|
|
|
#define EFI_BAD_POINTER 0xAFAFAFAFAFAFAFAF
|
|
|
|
#define EFI_BAD_POINTER_AS_BYTE 0xAF
|
|
|
|
|
2008-12-03 14:53:50 +01:00
|
|
|
#define EFI_DEADLOOP() while(TRUE)
|
|
|
|
|
|
|
|
#ifdef __GNUC__
|
|
|
|
#define EFI_BREAKPOINT EcpEfiBreakPoint
|
|
|
|
#define MEMORY_FENCE EcpMemoryFence
|
|
|
|
#else
|
2007-06-28 09:00:39 +02:00
|
|
|
//
|
|
|
|
// Inject a break point in the code to assist debugging.
|
|
|
|
//
|
|
|
|
#pragma intrinsic (__break)
|
|
|
|
#define EFI_BREAKPOINT() __break(0)
|
|
|
|
#define EFI_DEADLOOP() while(TRUE)
|
|
|
|
|
|
|
|
//
|
|
|
|
// Memory Fence forces serialization, and is needed to support out of order
|
|
|
|
// memory transactions. The Memory Fence is mainly used to make sure IO
|
|
|
|
// transactions complete in a deterministic sequence, and to syncronize locks
|
|
|
|
// an other MP code. Intel Itanium(TM) processors require explicit memory fence instructions
|
|
|
|
// after every IO. Need to find a way of doing that in the function _mf.
|
|
|
|
//
|
|
|
|
void __mfa (void);
|
|
|
|
#pragma intrinsic (__mfa)
|
|
|
|
#define MEMORY_FENCE() __mfa()
|
2008-12-03 14:53:50 +01:00
|
|
|
#endif
|
2007-06-28 09:00:39 +02:00
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// Some compilers don't support the forward reference construct:
|
|
|
|
// typedef struct XXXXX. The forward reference is required for
|
|
|
|
// ANSI compatibility.
|
|
|
|
//
|
|
|
|
// The following macro provide a workaround for such cases.
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef EFI_NO_INTERFACE_DECL
|
|
|
|
#define EFI_FORWARD_DECLARATION(x)
|
|
|
|
#else
|
|
|
|
#define EFI_FORWARD_DECLARATION(x) typedef struct _##x x
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//
|
|
|
|
// Some C compilers optimize the calling conventions to increase performance.
|
|
|
|
// _EFIAPI is used to make all public APIs follow the standard C calling
|
|
|
|
// convention.
|
|
|
|
//
|
|
|
|
|
|
|
|
#if _MSC_EXTENSIONS
|
|
|
|
#define _EFIAPI __cdecl
|
|
|
|
#else
|
|
|
|
#define _EFIAPI
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef _EFI_WINNT
|
|
|
|
|
|
|
|
#define EFI_SUPPRESS_BENIGN_REDEFINITION_OF_TYPE_WARNING() \
|
|
|
|
warning ( disable : 4142 )
|
|
|
|
|
|
|
|
#define EFI_DEFAULT_BENIGN_REDEFINITION_OF_TYPE_WARNING() \
|
|
|
|
warning ( default : 4142 )
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define EFI_SUPPRESS_BENIGN_REDEFINITION_OF_TYPE_WARNING() \
|
|
|
|
warning ( disable : 4068 )
|
|
|
|
|
|
|
|
#define EFI_DEFAULT_BENIGN_REDEFINITION_OF_TYPE_WARNING() \
|
|
|
|
warning ( default : 4068 )
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|