/*;******************************************************************************** ; ; Copyright (C) 2012 Advanced Micro Devices, Inc. ; All rights reserved. ; ; Redistribution and use in source and binary forms, with or without ; modification, are permitted provided that the following conditions are met: ; * Redistributions of source code must retain the above copyright ; notice, this list of conditions and the following disclaimer. ; * Redistributions in binary form must reproduce the above copyright ; notice, this list of conditions and the following disclaimer in the ; documentation and/or other materials provided with the distribution. ; * Neither the name of Advanced Micro Devices, Inc. nor the names of ; its contributors may be used to endorse or promote products derived ; from this software without specific prior written permission. ; ; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ; ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED ; WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ; DISCLAIMED. IN NO EVENT SHALL ADVANCED MICRO DEVICES, INC. BE LIABLE FOR ANY ; DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES ; (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ; ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS ; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ; ;*********************************************************************************/ #ifndef _AMD_AMDLIB_H_ #define _AMD_AMDLIB_H_ typedef CHAR8 *va_list; #ifndef _INTSIZEOF #define _INTSIZEOF(n)( (sizeof(n) + sizeof(UINTN) - 1) & ~(sizeof(UINTN) - 1) ) #endif // Also support coding convention rules for var arg macros #ifndef va_start #define va_start(ap,v) ( ap = (va_list)&(v) + _INTSIZEOF(v) ) #endif #define va_arg(ap,t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) ) #define va_end(ap) ( ap = (va_list)0 ) #ifndef CIMx_DEBUG #define CIMx_DEBUG 0 #endif #pragma pack(push,1) #define IMAGE_ALIGN 32*1024 #define NUM_IMAGE_LOCATION 32 //Entry Point Call typedef void (*CIM_IMAGE_ENTRY)(void* pConfig); //Hook Call typedef struct _Reg8Mask { UINT8 bRegIndex; UINT8 bANDMask; UINT8 bORMask; }REG8MASK; typedef struct _CIMFILEHEADER{ UINT32 AtiLogo; UINT32 EntryPoint; UINT32 ModuleLogo; UINT32 ImageSize; UINT16 Version; UINT8 CheckSum; UINT8 Reserved1; UINT32 Reserved2; }CIMFILEHEADER; typedef struct _CPUID_DATA{ UINT32 REG_EAX; UINT32 REG_EBX; UINT32 REG_ECX; UINT32 REG_EDX; }CPUID_DATA; #ifndef BIT0 #define BIT0 (1 << 0) #endif #ifndef BIT1 #define BIT1 (1 << 1) #endif #ifndef BIT2 #define BIT2 (1 << 2) #endif #ifndef BIT3 #define BIT3 (1 << 3) #endif #ifndef BIT4 #define BIT4 (1 << 4) #endif #ifndef BIT5 #define BIT5 (1 << 5) #endif #ifndef BIT6 #define BIT6 (1 << 6) #endif #ifndef BIT7 #define BIT7 (1 << 7) #endif #ifndef BIT8 #define BIT8 (1 << 8) #endif #ifndef BIT9 #define BIT9 (1 << 9) #endif #ifndef BIT10 #define BIT10 (1 << 10) #endif #ifndef BIT11 #define BIT11 (1 << 11) #endif #ifndef BIT12 #define BIT12 (1 << 12) #endif #ifndef BIT13 #define BIT13 (1 << 13) #endif #ifndef BIT14 #define BIT14 (1 << 14) #endif #ifndef BIT15 #define BIT15 (1 << 15) #endif #ifndef BIT16 #define BIT16 (1 << 16) #endif #ifndef BIT17 #define BIT17 (1 << 17) #endif #ifndef BIT18 #define BIT18 (1 << 18) #endif #ifndef BIT19 #define BIT19 (1 << 19) #endif #ifndef BIT20 #define BIT20 (1 << 20) #endif #ifndef BIT21 #define BIT21 (1 << 21) #endif #ifndef BIT22 #define BIT22 (1 << 22) #endif #ifndef BIT23 #define BIT23 (1 << 23) #endif #ifndef BIT24 #define BIT24 (1 << 24) #endif #ifndef BIT25 #define BIT25 (1 << 25) #endif #ifndef BIT26 #define BIT26 (1 << 26) #endif #ifndef BIT27 #define BIT27 (1 << 27) #endif #ifndef BIT28 #define BIT28 (1 << 28) #endif #ifndef BIT29 #define BIT29 (1 << 29) #endif #ifndef BIT30 #define BIT30 (1 << 30) #endif #ifndef BIT31 #define BIT31 (1 << 31) #endif #define PCI_ADDRESS(bus,dev,func,reg) \ (UINT32) ( (((UINT32)bus) << 24) + (((UINT32)dev) << 19) + (((UINT32)func) << 16) + ((UINT32)reg) ) #pragma pack(pop) typedef enum { AccWidthUint8 = 0, AccWidthUint16, AccWidthUint32, } ACC_WIDTH; #define S3_SAVE 0x80 #endif //#ifndef _AMD_AMDLIB_H_