123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- #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
|