Select one of the symbols to view example projects that use it.
 
Outline
#define OPENOCD_FLASH_NOR_SPI_H
flash_device
flash_devices;
#define SPIFLASH_BSY
#define SPIFLASH_BSY_BIT
#define SPIFLASH_WE
#define SPIFLASH_WE_BIT
#define SPIFLASH_READ_ID
#define SPIFLASH_READ_MID
#define SPIFLASH_READ_STATUS
#define SPIFLASH_WRITE_ENABLE
#define SPIFLASH_PAGE_PROGRAM
#define SPIFLASH_FAST_READ
#define SPIFLASH_READ
#define SPIFLASH_MASS_ERASE
#define SPIFLASH_READ_SFDP
#define SPIFLASH_DEF_PAGESIZE
Files
loading...
CodeScopeDevelopment ToolsOpenOCDsrc/flash/nor/spi.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* SPDX-License-Identifier: GPL-2.0-or-later */ /*************************************************************************** * Copyright (C) 2018-2019 by Andreas Bolsch * * andreas.bolsch@mni.thm.de * * * * Copyright (C) 2012 by George Harris * * george@luminairecoffee.com * * * * Copyright (C) 2010 by Antonio Borneo * * borneo.antonio@gmail.com * ***************************************************************************//* ... */ #ifndef OPENOCD_FLASH_NOR_SPI_H #define OPENOCD_FLASH_NOR_SPI_H #ifndef __ASSEMBLER__ /* data structure to maintain flash ids from different vendors */ struct flash_device { const char *name; uint8_t read_cmd; uint8_t qread_cmd; uint8_t pprog_cmd; uint8_t erase_cmd; uint8_t chip_erase_cmd; uint32_t device_id; uint32_t pagesize; uint32_t sectorsize; uint32_t size_in_bytes; ...}; #define FLASH_ID(n, re, qr, pp, es, ces, id, psize, ssize, size) \ { \ .name = n, \ .read_cmd = re, \ .qread_cmd = qr, \ .pprog_cmd = pp, \ .erase_cmd = es, \ .chip_erase_cmd = ces, \ .device_id = id, \ .pagesize = psize, \ .sectorsize = ssize, \ .size_in_bytes = size, \ ...}... #define FRAM_ID(n, re, qr, pp, id, size) \ { \ .name = n, \ .read_cmd = re, \ .qread_cmd = qr, \ .pprog_cmd = pp, \ .erase_cmd = 0x00, \ .chip_erase_cmd = 0x00, \ .device_id = id, \ .pagesize = 0, \ .sectorsize = 0, \ .size_in_bytes = size, \ ...}... extern const struct flash_device flash_devices[]; /* ... */ #endif /* fields in SPI flash status register */ #define SPIFLASH_BSY 0 #define SPIFLASH_BSY_BIT (1 << SPIFLASH_BSY) /* WIP Bit of SPI SR */ #define SPIFLASH_WE 1 #define SPIFLASH_WE_BIT (1 << SPIFLASH_WE) /* WEL Bit of SPI SR */ /* SPI Flash Commands */ #define SPIFLASH_READ_ID 0x9F /* Read Flash Identification */ #define SPIFLASH_READ_MID 0xAF /* Read Flash Identification, multi-io */ #define SPIFLASH_READ_STATUS 0x05 /* Read Status Register */ #define SPIFLASH_WRITE_ENABLE 0x06 /* Write Enable */ #define SPIFLASH_PAGE_PROGRAM 0x02 /* Page Program */ #define SPIFLASH_FAST_READ 0x0B /* Fast Read */ #define SPIFLASH_READ 0x03 /* Normal Read */ #define SPIFLASH_MASS_ERASE 0xC7 /* Mass Erase */ #define SPIFLASH_READ_SFDP 0x5A /* Read Serial Flash Discoverable Parameters */ #define SPIFLASH_DEF_PAGESIZE 256 /* default for non-page-oriented devices (FRAMs) */ 14 defines /* ... */#endif /* OPENOCD_FLASH_NOR_SPI_H */