#ifndef _PIFLASH64_H #define _PIFLASH64_H /*++ Copyright (c) 1999 Intel Corporation Module Name: PIflash64.h Abstract: Iflash64.efi protocol to abstract iflash from the system. Revision History --*/ /* * Guid that identifies the IFLASH protocol */ #define IFLASH64_PROTOCOL_PROTOCOL \ { 0x65cba110, 0x74ab, 0x11d3, 0xbb, 0x89, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 }; /* * Unlock FLASH from StartAddress to EndAddress and return a LockKey */ typedef EFI_STATUS (EFIAPI *UNLOCK_FLASH_API)( IN struct _IFLASH64_PROTOCOL_INTERFACE *This ); /* * Lock the flash represented by the LockKey */ typedef EFI_STATUS (EFIAPI *LOCK_FLASH_API)( IN struct _IFLASH64_PROTOCOL_INTERFACE *This ); /* * Status callback for a utility like IFLASH64 * * Token would map to a list like Ted proposed. The utility has no idea what * happens on the other side. * ErrorStatus - Level of Error or success. Independent of Token. If you * don't know the token you will at least know pass or fail. * String - Optional extra information about the error. Could be used for * debug or future expansion * * Attributes - Options screen attributes for String. Could allow the string to be different colors. */ typedef EFI_STATUS (EFIAPI *UTILITY_PROGRESS_API)( IN struct _IFLASH64_PROTOCOL_INTERFACE *This, IN UINTN Token, IN EFI_STATUS ErrorStatus, IN CHAR16 *String, OPTIONAL IN UINTN *Attributes OPTIONAL ); /* * Token Values * * IFlash64 Token Codes */ #define IFLASH_TOKEN_IFLASHSTART 0xB0 /* IFlash64 has started */ #define IFLASH_TOKEN_READINGFILE 0xB1 /* Reading File */ #define IFLASH_TOKEN_INITVPP 0xB2 /* Initializing Vpp */ #define IFLASH_TOKEN_DISABLEVPP 0x10 /* Disable Vpp */ #define IFLASH_TOKEN_FLASHUNLOCK 0xB3 /* Unlocking FLASH Devices */ #define IFLASH_TOKEN_FLASHERASE 0xB4 /* Erasing FLASH Devices */ #define IFLASH_TOKEN_FLASHPROGRAM 0xB5 /* Programming FLASH */ #define IFLASH_TOKEN_FLASHVERIFY 0xB6 /* Verifying FLASH */ #define IFLASH_TOKEN_UPDATESUCCES 0xB7 /* FLASH Updage Success! */ #define IFLASH_TOKEN_PROGRESS_READINGFILE 0x11 /* % Reading File */ #define IFLASH_TOKEN_PROGRESS_FLASHUNLOCK 0x13 /* % Unlocking FLASH Devices */ #define IFLASH_TOKEN_PROGRESS_FLASHERASE 0x14 /* % Erasing FLASH Devices */ #define IFLASH_TOKEN_PROGRESS_FLASHPROGRAM 0x15 /* % Programming FLASH */ #define IFLASH_TOKEN_PROGRESS_FLASHVERIFY 0x16 /* % Verifying FLASH */ #define IFLASH_TOKEN_READINGFILE_ER 0xB8 /* File Read Error */ #define IFLASH_TOKEN_INITVPP_ER 0xB9 /* Initialization of IFB Error */ #define IFLASH_TOKEN_FLASHUNLOCK_ER 0xBA /* FLASH Unlock Error */ #define IFLASH_TOKEN_FLASHERASE_ER 0xBB /* FLASH Erase Error */ #define IFLASH_TOKEN_FLASHVERIFY_ER 0xBC /* FLASH Verify Error */ #define IFLASH_TOKEN_FLASHPROG_ER 0xBD /* FLASH Program Error */ #define IFLASH_TABLE_END 0x00 /* * If this number changes one of the existing API's has changes */ #define IFLASH_PI_MAJOR_VERSION 0x01 /* * This number changes when new APIs or data variables get added to the end * of the data structure */ #define IFLASH_PI_MINOR_VERSION 0x01 typedef struct _IFLASH64_PROTOCOL_INTERFACE { UINT32 MajorVersion; UINT32 MinorVersion; UNLOCK_FLASH_API UnlockFlash; LOCK_FLASH_API LockFlash; UTILITY_PROGRESS_API Progress; /* * Future expansion goes here */ } IFLASH64_PROTOCOL_INTERFACE; #endif