]> git.proxmox.com Git - mirror_edk2.git/blame - QuarkPlatformPkg/Feature/Capsule/Library/PlatformFlashAccessLib/SpiFlashDevice.h
QuarkPlatformPkg/PlatformFlashAccessLib: Add instance for update.
[mirror_edk2.git] / QuarkPlatformPkg / Feature / Capsule / Library / PlatformFlashAccessLib / SpiFlashDevice.h
CommitLineData
63b9a685
JY
1/** @file\r
2 SPI flash device header file.\r
3\r
4 Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
5 This program and the accompanying materials\r
6 are licensed and made available under the terms and conditions of the BSD License\r
7 which accompanies this distribution. The full text of the license may be found at\r
8 http://opensource.org/licenses/bsd-license.php\r
9\r
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13**/\r
14\r
15#ifndef _SPI_FLASH_DEVICE_H_\r
16#define _SPI_FLASH_DEVICE_H_\r
17\r
18#include <PiDxe.h>\r
19#include <Protocol/Spi.h>\r
20#include <Protocol/FirmwareVolumeBlock.h>\r
21\r
22//\r
23// Supported SPI Flash Devices\r
24//\r
25typedef enum {\r
26 EnumSpiFlash25L3205D, // Macronix 32Mbit part\r
27 EnumSpiFlashW25Q32, // Winbond 32Mbit part\r
28 EnumSpiFlashW25X32, // Winbond 32Mbit part\r
29 EnumSpiFlashAT25DF321, // Atmel 32Mbit part\r
30 EnumSpiFlashQH25F320, // Intel 32Mbit part\r
31 EnumSpiFlash25VF064C, // SST 64Mbit part\r
32 EnumSpiFlashM25PX64, // NUMONYX 64Mbit part\r
33 EnumSpiFlashAT25DF641, // Atmel 64Mbit part\r
34 EnumSpiFlashS25FL064K, // Spansion 64Mbit part\r
35 EnumSpiFlash25L6405D, // Macronix 64Mbit part\r
36 EnumSpiFlashW25Q64, // Winbond 64Mbit part\r
37 EnumSpiFlashW25X64, // Winbond 64Mbit part\r
38 EnumSpiFlashQH25F640, // Intel 64Mbit part\r
39 EnumSpiFlashMax\r
40} SPI_FLASH_TYPES_SUPPORTED;\r
41\r
42//\r
43// Flash Device commands\r
44//\r
45// If a supported device uses a command different from the list below, a device specific command\r
46// will be defined just below it's JEDEC id section.\r
47//\r
48#define SPI_COMMAND_WRITE 0x02\r
49#define SPI_COMMAND_WRITE_AAI 0xAD\r
50#define SPI_COMMAND_READ 0x03\r
51#define SPI_COMMAND_ERASE 0x20\r
52#define SPI_COMMAND_WRITE_DISABLE 0x04\r
53#define SPI_COMMAND_READ_S 0x05\r
54#define SPI_COMMAND_WRITE_ENABLE 0x06\r
55#define SPI_COMMAND_READ_ID 0xAB\r
56#define SPI_COMMAND_JEDEC_ID 0x9F\r
57#define SPI_COMMAND_WRITE_S_EN 0x50\r
58#define SPI_COMMAND_WRITE_S 0x01\r
59#define SPI_COMMAND_CHIP_ERASE 0xC7\r
60#define SPI_COMMAND_BLOCK_ERASE 0xD8\r
61\r
62//\r
63// Flash JEDEC device ids\r
64//\r
65// SST 8Mbit part\r
66//\r
67#define SPI_SST25VF080B_ID1 0xBF\r
68#define SPI_SST25VF080B_ID2 0x25\r
69#define SPI_SST25VF080B_ID3 0x8E\r
70//\r
71// SST 16Mbit part\r
72//\r
73#define SPI_SST25VF016B_ID1 0xBF\r
74#define SPI_SST25VF016B_ID2 0x25\r
75#define SPI_SST25V016BF_ID3 0x41\r
76//\r
77// Macronix 32Mbit part\r
78//\r
79// MX25 part does not support WRITE_AAI comand (0xAD)\r
80//\r
81#define SPI_MX25L3205_ID1 0xC2\r
82#define SPI_MX25L3205_ID2 0x20\r
83#define SPI_MX25L3205_ID3 0x16\r
84//\r
85// Intel 32Mbit part bottom boot\r
86//\r
87#define SPI_QH25F320_ID1 0x89\r
88#define SPI_QH25F320_ID2 0x89\r
89#define SPI_QH25F320_ID3 0x12 // 32Mbit bottom boot\r
90//\r
91// Intel 64Mbit part bottom boot\r
92//\r
93#define SPI_QH25F640_ID1 0x89\r
94#define SPI_QH25F640_ID2 0x89\r
95#define SPI_QH25F640_ID3 0x13 // 64Mbit bottom boot\r
96//\r
97// QH part does not support command 0x20 for erase; only 0xD8 (sector erase)\r
98// QH part has 0x40 command for erase of parameter block (8 x 8K blocks at bottom of part)\r
99// 0x40 command ignored if address outside of parameter block range\r
100//\r
101#define SPI_QH25F320_COMMAND_PBLOCK_ERASE 0x40\r
102//\r
103// Winbond 32Mbit part\r
104//\r
105#define SPI_W25X32_ID1 0xEF\r
106#define SPI_W25X32_ID2 0x30 // Memory Type\r
107#define SPI_W25X32_ID3 0x16 // Capacity\r
108#define SF_DEVICE_ID1_W25Q32 0x16\r
109\r
110//\r
111// Winbond 64Mbit part\r
112//\r
113#define SPI_W25X64_ID1 0xEF\r
114#define SPI_W25X64_ID2 0x30 // Memory Type\r
115#define SPI_W25X64_ID3 0x17 // Capacity\r
116#define SF_DEVICE_ID0_W25QXX 0x40\r
117#define SF_DEVICE_ID1_W25Q64 0x17\r
118//\r
119// Winbond 128Mbit part\r
120//\r
121#define SF_DEVICE_ID0_W25Q128 0x40\r
122#define SF_DEVICE_ID1_W25Q128 0x18\r
123\r
124//\r
125// Atmel 32Mbit part\r
126//\r
127#define SPI_AT26DF321_ID1 0x1F\r
128#define SPI_AT26DF321_ID2 0x47 // [7:5]=Family, [4:0]=Density\r
129#define SPI_AT26DF321_ID3 0x00\r
130\r
131#define SF_VENDOR_ID_ATMEL 0x1F\r
132#define SF_DEVICE_ID0_AT25DF641 0x48\r
133#define SF_DEVICE_ID1_AT25DF641 0x00\r
134\r
135//\r
136// SST 8Mbit part\r
137//\r
138#define SPI_SST25VF080B_ID1 0xBF\r
139#define SPI_SST25VF080B_ID2 0x25\r
140#define SPI_SST25VF080B_ID3 0x8E\r
141#define SF_DEVICE_ID0_25VF064C 0x25\r
142#define SF_DEVICE_ID1_25VF064C 0x4B\r
143\r
144//\r
145// SST 16Mbit part\r
146//\r
147#define SPI_SST25VF016B_ID1 0xBF\r
148#define SPI_SST25VF016B_ID2 0x25\r
149#define SPI_SST25V016BF_ID3 0x41\r
150\r
151//\r
152// Winbond 32Mbit part\r
153//\r
154#define SPI_W25X32_ID1 0xEF\r
155#define SPI_W25X32_ID2 0x30 // Memory Type\r
156#define SPI_W25X32_ID3 0x16 // Capacity\r
157\r
158#define SF_VENDOR_ID_MX 0xC2\r
159#define SF_DEVICE_ID0_25L6405D 0x20\r
160#define SF_DEVICE_ID1_25L6405D 0x17\r
161\r
162#define SF_VENDOR_ID_NUMONYX 0x20\r
163#define SF_DEVICE_ID0_M25PX64 0x71\r
164#define SF_DEVICE_ID1_M25PX64 0x17\r
165\r
166//\r
167// Spansion 64Mbit part\r
168//\r
169#define SF_VENDOR_ID_SPANSION 0xEF\r
170#define SF_DEVICE_ID0_S25FL064K 0x40\r
171#define SF_DEVICE_ID1_S25FL064K 0x00\r
172\r
173//\r
174// index for prefix opcodes\r
175//\r
176#define SPI_WREN_INDEX 0 // Prefix Opcode 0: SPI_COMMAND_WRITE_ENABLE\r
177#define SPI_EWSR_INDEX 1 // Prefix Opcode 1: SPI_COMMAND_WRITE_S_EN\r
178#define BIOS_CTRL 0xDC\r
179\r
180#define PFAB_CARD_DEVICE_ID 0x5150\r
181#define PFAB_CARD_VENDOR_ID 0x8086\r
182#define PFAB_CARD_SETUP_REGISTER 0x40\r
183#define PFAB_CARD_SETUP_BYTE 0x0d\r
184\r
185\r
186#endif\r