/** @file\r
- Processor or Compiler specific defines and types for Intel Itanium(TM).\r
+ Processor or Compiler specific defines and types for Intel Itanium(TM) processors.\r
\r
- Copyright (c) 2006 - 2008, Intel Corporation<BR>\r
+ Copyright (c) 2006 - 2009, Intel Corporation<BR>\r
All rights reserved. This program and the accompanying materials\r
are licensed and made available under the terms and conditions of the BSD License\r
which accompanies this distribution. The full text of the license may be found at\r
\r
\r
///\r
-/// Define the processor type so other code can make processor based choices\r
+/// Define the processor type so other code can make processor-based choices\r
///\r
#define MDE_CPU_IPF\r
\r
\r
//\r
// Can not cast a function pointer to a data pointer. We need to do this on\r
-// IPF to get access to the PLABEL.\r
+// Itanium processors to get access to the PLABEL.\r
//\r
#pragma warning ( disable : 4514 )\r
\r
\r
#if defined(_MSC_EXTENSIONS)\r
//\r
- // use Microsoft C complier dependent integer width types\r
+ // use Microsoft C compiler dependent integer width types\r
//\r
\r
///\r
// use the correct C calling convention. All protocol member functions and\r
// EFI intrinsics are required to modify their member functions with EFIAPI.\r
//\r
-#if defined(_MSC_EXTENSIONS)\r
+#ifdef EFIAPI\r
+ ///\r
+ /// If EFIAPI is already defined, then we use that definition.\r
+ ///\r
+#elif defined(_MSC_EXTENSIONS)\r
///\r
/// Microsoft* compiler specific method for EFIAPI calling convension\r
/// \r
\r
/**\r
Return the pointer to the first instruction of a function given a function pointer.\r
- For Itanium CPUs, all function calls are made through a PLABEL, so a pointer to a function \r
+ For Itanium processors, all function calls are made through a PLABEL, so a pointer to a function \r
is actually a pointer to a PLABEL. The pointer to the first instruction of the function \r
is contained within the PLABEL. This macro may be used to retrieve a pointer to the first \r
instruction of a function independent of the CPU architecture being used. This is very \r