Blame view

drivers/mtd/spi/sf_internal.h 4.8 KB
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
1
2
3
4
  /*
   * SPI flash internal definitions
   *
   * Copyright (C) 2008 Atmel Corporation
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
5
6
   * Copyright (C) 2013 Jagannadha Sutradharudu Teki, Xilinx Inc.
   *
0c88a84ac   Jagannadha Sutradharudu Teki   sf: Add GPL-2.0+ ...
7
   * SPDX-License-Identifier:	GPL-2.0+
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
8
   */
469146c09   Jagannadha Sutradharudu Teki   sf: Minor cleanups.
9
10
  #ifndef _SF_INTERNAL_H_
  #define _SF_INTERNAL_H_
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
11

ff063ed48   Jagannadha Sutradharudu Teki   sf: Discover read...
12
13
  #define SPI_FLASH_3B_ADDR_LEN		3
  #define SPI_FLASH_CMD_LEN		(1 + SPI_FLASH_3B_ADDR_LEN)
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
14
  #define SPI_FLASH_16MB_BOUN		0x1000000
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
15

d08a1baf6   Jagannadha Sutradharudu Teki   sf: Set quad enab...
16
17
18
  /* CFI Manufacture ID's */
  #define SPI_FLASH_CFI_MFR_SPANSION	0x01
  #define SPI_FLASH_CFI_MFR_STMICRO	0x20
067951223   Jagannadha Sutradharudu Teki   sf: Add macronix ...
19
  #define SPI_FLASH_CFI_MFR_MACRONIX	0xc2
d08a1baf6   Jagannadha Sutradharudu Teki   sf: Set quad enab...
20
  #define SPI_FLASH_CFI_MFR_WINBOND	0xef
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
21
  /* SECT flags */
ce22b922d   Jagannadha Sutradharudu Teki   sf: Minor cleanups
22
  #define SECT_4K				(1 << 1)
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
23
24
25
26
27
28
29
30
  #define SECT_32K			(1 << 2)
  #define E_FSR				(1 << 3)
  
  /* Erase commands */
  #define CMD_ERASE_4K			0x20
  #define CMD_ERASE_32K			0x52
  #define CMD_ERASE_CHIP			0xc7
  #define CMD_ERASE_64K			0xd8
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
31

a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
32
  /* Write commands */
b4c87d658   Mike Frysinger   sf: drop unused/d...
33
  #define CMD_WRITE_STATUS		0x01
d4aa50091   Mike Frysinger   sf: unify write f...
34
  #define CMD_PAGE_PROGRAM		0x02
66ecb7cdb   Mike Frysinger   sf: unify write d...
35
  #define CMD_WRITE_DISABLE		0x04
6163045bc   Mike Frysinger   sf: unify status ...
36
  #define CMD_READ_STATUS			0x05
3163aaa63   Jagannadha Sutradharudu Teki   sf: Add quad read...
37
  #define CMD_QUAD_PAGE_PROGRAM		0x32
ffdb20bea   Mike Frysinger   sandbox: spi: Add...
38
  #define CMD_READ_STATUS1		0x35
e7b44eddb   Mike Frysinger   sf: unify erase f...
39
  #define CMD_WRITE_ENABLE		0x06
ce22b922d   Jagannadha Sutradharudu Teki   sf: Minor cleanups
40
41
  #define CMD_READ_CONFIG			0x35
  #define CMD_FLAG_STATUS			0x70
6163045bc   Mike Frysinger   sf: unify status ...
42

a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
43
44
45
  /* Read commands */
  #define CMD_READ_ARRAY_SLOW		0x03
  #define CMD_READ_ARRAY_FAST		0x0b
4e09cc1e2   Jagannadha Sutradharudu Teki   sf: Add extended ...
46
47
  #define CMD_READ_DUAL_OUTPUT_FAST	0x3b
  #define CMD_READ_DUAL_IO_FAST		0xbb
3163aaa63   Jagannadha Sutradharudu Teki   sf: Add quad read...
48
  #define CMD_READ_QUAD_OUTPUT_FAST	0x6b
c4ba0d82d   Jagannadha Sutradharudu Teki   sf: Add QUAD_IO_F...
49
  #define CMD_READ_QUAD_IO_FAST		0xeb
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
50
  #define CMD_READ_ID			0x9f
e612ddf59   Jagannadha Sutradharudu Teki   sf: Read flash ba...
51

cf6b11dcd   Jagannadha Sutradharudu Teki   sf: Discover the ...
52
  /* Bank addr access commands */
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
53
  #ifdef CONFIG_SPI_FLASH_BAR
1dcd6d038   Jagannadha Sutradharudu Teki   sf: Add bank addr...
54
55
56
57
58
  # define CMD_BANKADDR_BRWR		0x17
  # define CMD_BANKADDR_BRRD		0x16
  # define CMD_EXTNADDR_WREAR		0xC5
  # define CMD_EXTNADDR_RDEAR		0xC8
  #endif
cf6b11dcd   Jagannadha Sutradharudu Teki   sf: Discover the ...
59

6163045bc   Mike Frysinger   sf: unify status ...
60
61
  /* Common status */
  #define STATUS_WIP			0x01
d08a1baf6   Jagannadha Sutradharudu Teki   sf: Set quad enab...
62
  #define STATUS_QEB_WINSPAN		(1 << 1)
067951223   Jagannadha Sutradharudu Teki   sf: Add macronix ...
63
  #define STATUS_QEB_MXIC			(1 << 6)
615a15616   Jagannadha Sutradharudu Teki   sf: Add flag stat...
64
  #define STATUS_PEC			0x80
6163045bc   Mike Frysinger   sf: unify status ...
65

a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
66
67
68
69
70
71
72
73
  /* Flash timeout values */
  #define SPI_FLASH_PROG_TIMEOUT		(2 * CONFIG_SYS_HZ)
  #define SPI_FLASH_PAGE_ERASE_TIMEOUT	(5 * CONFIG_SYS_HZ)
  #define SPI_FLASH_SECTOR_ERASE_TIMEOUT	(10 * CONFIG_SYS_HZ)
  
  /* SST specific */
  #ifdef CONFIG_SPI_FLASH_SST
  # define SST_WP			0x01	/* Supports AAI word program */
ce22b922d   Jagannadha Sutradharudu Teki   sf: Minor cleanups
74
  # define CMD_SST_BP		0x02    /* Byte Program */
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
75
76
77
78
79
  # define CMD_SST_AAI_WP		0xAD	/* Auto Address Incr Word Program */
  
  int sst_write_wp(struct spi_flash *flash, u32 offset, size_t len,
  		const void *buf);
  #endif
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
  /* Send a single-byte command to the device and read the response */
  int spi_flash_cmd(struct spi_slave *spi, u8 cmd, void *response, size_t len);
  
  /*
   * Send a multi-byte command to the device and read the response. Used
   * for flash array reads, etc.
   */
  int spi_flash_cmd_read(struct spi_slave *spi, const u8 *cmd,
  		size_t cmd_len, void *data, size_t data_len);
  
  /*
   * Send a multi-byte command to the device followed by (optional)
   * data. Used for programming the flash array, etc.
   */
  int spi_flash_cmd_write(struct spi_slave *spi, const u8 *cmd, size_t cmd_len,
  		const void *data, size_t data_len);
d4aa50091   Mike Frysinger   sf: unify write f...
96

a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
97
98
  /* Flash erase(sectors) operation, support all possible erase commands */
  int spi_flash_cmd_erase_ops(struct spi_flash *flash, u32 offset, size_t len);
10ca45d00   Jagannadha Sutradharudu Teki   sf: probe: Add su...
99

9f4322fd2   Jagannadha Sutradharudu Teki   sf: Divide flash ...
100
101
  /* Read the status register */
  int spi_flash_cmd_read_status(struct spi_flash *flash, u8 *rs);
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
102
103
  /* Program the status register */
  int spi_flash_cmd_write_status(struct spi_flash *flash, u8 sr);
9f4322fd2   Jagannadha Sutradharudu Teki   sf: Divide flash ...
104
105
  /* Read the config register */
  int spi_flash_cmd_read_config(struct spi_flash *flash, u8 *rc);
067951223   Jagannadha Sutradharudu Teki   sf: Add macronix ...
106

9f4322fd2   Jagannadha Sutradharudu Teki   sf: Divide flash ...
107
108
  /* Program the config register */
  int spi_flash_cmd_write_config(struct spi_flash *flash, u8 wc);
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
109
110
  
  /* Enable writing on the SPI flash */
2744a4e68   Mike Frysinger   sf: unify write e...
111
112
113
114
  static inline int spi_flash_cmd_write_enable(struct spi_flash *flash)
  {
  	return spi_flash_cmd(flash->spi, CMD_WRITE_ENABLE, NULL, 0);
  }
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
115
  /* Disable writing on the SPI flash */
66ecb7cdb   Mike Frysinger   sf: unify write d...
116
117
118
119
120
121
  static inline int spi_flash_cmd_write_disable(struct spi_flash *flash)
  {
  	return spi_flash_cmd(flash->spi, CMD_WRITE_DISABLE, NULL, 0);
  }
  
  /*
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
122
123
   * Send the read status command to the device and wait for the wip
   * (write-in-progress) bit to clear itself.
d25ce7d24   Haavard Skinnemoen   SPI Flash subsystem
124
   */
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
125
  int spi_flash_cmd_wait_ready(struct spi_flash *flash, unsigned long timeout);
acc237544   Jagannadha Sutradharudu Teki   sf: Unify spi_fla...
126
127
128
129
130
131
132
133
134
135
  /*
   * Used for spi_flash write operation
   * - SPI claim
   * - spi_flash_cmd_write_enable
   * - spi_flash_cmd_write
   * - spi_flash_cmd_wait_ready
   * - SPI release
   */
  int spi_flash_write_common(struct spi_flash *flash, const u8 *cmd,
  		size_t cmd_len, const void *buf, size_t buf_len);
6163045bc   Mike Frysinger   sf: unify status ...
136
137
  
  /*
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
138
139
140
   * Flash write operation, support all possible write commands.
   * Write the requested data out breaking it up into multiple write
   * commands as needed per the write size.
6163045bc   Mike Frysinger   sf: unify status ...
141
   */
a5e8199a1   Jagannadha Sutradharudu Teki   sf: spi_flash cle...
142
143
144
145
146
147
148
149
150
151
152
153
154
  int spi_flash_cmd_write_ops(struct spi_flash *flash, u32 offset,
  		size_t len, const void *buf);
  
  /*
   * Same as spi_flash_cmd_read() except it also claims/releases the SPI
   * bus. Used as common part of the ->read() operation.
   */
  int spi_flash_read_common(struct spi_flash *flash, const u8 *cmd,
  		size_t cmd_len, void *data, size_t data_len);
  
  /* Flash read operation, support all possible read commands */
  int spi_flash_cmd_read_ops(struct spi_flash *flash, u32 offset,
  		size_t len, void *data);
6163045bc   Mike Frysinger   sf: unify status ...
155

469146c09   Jagannadha Sutradharudu Teki   sf: Minor cleanups.
156
  #endif /* _SF_INTERNAL_H_ */