xref: /DragonStub/inc/protocol/piflash64.h (revision e7db4418b1fe6ea0220974b77c3b10918ab9b7a0)
1 #ifndef _PIFLASH64_H
2 #define _PIFLASH64_H
3 
4 /*++
5 
6 Copyright (c) 1999  Intel Corporation
7 
8 Module Name:
9 
10     PIflash64.h
11 
12 Abstract:
13 
14     Iflash64.efi protocol to abstract iflash from
15     the system.
16 
17 Revision History
18 
19 --*/
20 
21 //
22 // Guid that identifies the IFLASH protocol
23 //
24 #define IFLASH64_PROTOCOL_PROTOCOL \
25     { 0x65cba110, 0x74ab, 0x11d3, 0xbb, 0x89, 0x0, 0x80, 0xc7, 0x3c, 0x88, 0x81 };
26 
27 //
28 // Unlock FLASH from StartAddress to EndAddress and return a LockKey
29 //
30 typedef
31 EFI_STATUS
32 (EFIAPI *UNLOCK_FLASH_API)(
33     IN struct _IFLASH64_PROTOCOL_INTERFACE  *This
34     );
35 
36 //
37 // Lock the flash represented by the LockKey
38 //
39 typedef
40 EFI_STATUS
41 (EFIAPI *LOCK_FLASH_API)(
42     IN struct _IFLASH64_PROTOCOL_INTERFACE  *This
43     );
44 
45 //
46 // Status callback for a utility like IFLASH64
47 //
48 //  Token would map to a list like Ted proposed. The utility has no idea what
49 //      happens on the other side.
50 //  ErrorStatus - Level of Error or success. Independent of Token. If you
51 //      don't know the token you will at least know pass or fail.
52 //  String - Optional extra information about the error. Could be used for
53 //      debug or future expansion
54 //
55 //  Attributes - Options screen attributes for String. Could allow the string to be different colors.
56 //
57 typedef
58 EFI_STATUS
59 (EFIAPI *UTILITY_PROGRESS_API)(
60     IN struct _IFLASH64_PROTOCOL_INTERFACE  *This,
61     IN  UINTN                               Token,
62     IN  EFI_STATUS                          ErrorStatus,
63     IN  CHAR16                              *String,    OPTIONAL
64     IN  UINTN                               *Attributes OPTIONAL
65     );
66 
67 //
68 // Token Values
69 //
70 // IFlash64 Token Codes
71 #define IFLASH_TOKEN_IFLASHSTART    0xB0                // IFlash64 has started
72 #define IFLASH_TOKEN_READINGFILE    0xB1                // Reading File
73 #define IFLASH_TOKEN_INITVPP        0xB2                // Initializing Vpp
74 #define IFLASH_TOKEN_DISABLEVPP     0x10                // Disable Vpp
75 #define IFLASH_TOKEN_FLASHUNLOCK    0xB3                // Unlocking FLASH Devices
76 #define IFLASH_TOKEN_FLASHERASE     0xB4                // Erasing FLASH Devices
77 #define IFLASH_TOKEN_FLASHPROGRAM   0xB5                // Programming FLASH
78 #define IFLASH_TOKEN_FLASHVERIFY    0xB6                // Verifying FLASH
79 #define IFLASH_TOKEN_UPDATESUCCES   0xB7                // FLASH Updage Success!
80 
81 #define IFLASH_TOKEN_PROGRESS_READINGFILE   0x11        // % Reading File
82 #define IFLASH_TOKEN_PROGRESS_FLASHUNLOCK   0x13        // % Unlocking FLASH Devices
83 #define IFLASH_TOKEN_PROGRESS_FLASHERASE    0x14        // % Erasing FLASH Devices
84 #define IFLASH_TOKEN_PROGRESS_FLASHPROGRAM  0x15        // % Programming FLASH
85 #define IFLASH_TOKEN_PROGRESS_FLASHVERIFY   0x16        // % Verifying FLASH
86 
87 #define IFLASH_TOKEN_READINGFILE_ER 0xB8                // File Read Error
88 #define IFLASH_TOKEN_INITVPP_ER     0xB9                // Initialization of IFB Error
89 #define IFLASH_TOKEN_FLASHUNLOCK_ER 0xBA                // FLASH Unlock Error
90 #define IFLASH_TOKEN_FLASHERASE_ER  0xBB                // FLASH Erase Error
91 #define IFLASH_TOKEN_FLASHVERIFY_ER 0xBC                // FLASH Verify Error
92 #define IFLASH_TOKEN_FLASHPROG_ER   0xBD                // FLASH Program Error
93 
94 #define IFLASH_TABLE_END            0x00
95 
96 //
97 // If this number changes one of the existing API's has changes
98 //
99 #define IFLASH_PI_MAJOR_VERSION 0x01
100 
101 //
102 // This number changes when new APIs or data variables get added to the end
103 //  of the data structure
104 //
105 #define IFLASH_PI_MINOR_VERSION 0x01
106 
107 typedef struct _IFLASH64_PROTOCOL_INTERFACE {
108     UINT32                  MajorVersion;
109     UINT32                  MinorVersion;
110     UNLOCK_FLASH_API        UnlockFlash;
111     LOCK_FLASH_API          LockFlash;
112     UTILITY_PROGRESS_API    Progress;
113 
114     //
115     // Future expansion goes here
116     //
117 
118 } IFLASH64_PROTOCOL_INTERFACE;
119 
120 
121 #endif
122