xref: /freebsd/sys/dev/flash/flexspi/flex_spi.h (revision 94e25b7acba7f929606a1a57f8d193995d8f8920)
1*94e25b7aSWojciech Macek /*-
2*94e25b7aSWojciech Macek  * Copyright (c) 2021 Alstom Group.
3*94e25b7aSWojciech Macek  * Copyright (c) 2021 Semihalf.
4*94e25b7aSWojciech Macek  *
5*94e25b7aSWojciech Macek  * Redistribution and use in source and binary forms, with or without
6*94e25b7aSWojciech Macek  * modification, are permitted provided that the following conditions
7*94e25b7aSWojciech Macek  * are met:
8*94e25b7aSWojciech Macek  * 1. Redistributions of source code must retain the above copyright
9*94e25b7aSWojciech Macek  *    notice, this list of conditions and the following disclaimer.
10*94e25b7aSWojciech Macek  * 2. Redistributions in binary form must reproduce the above copyright
11*94e25b7aSWojciech Macek  *    notice, this list of conditions and the following disclaimer in the
12*94e25b7aSWojciech Macek  *    documentation and/or other materials provided with the distribution.
13*94e25b7aSWojciech Macek  *
14*94e25b7aSWojciech Macek  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
15*94e25b7aSWojciech Macek  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16*94e25b7aSWojciech Macek  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17*94e25b7aSWojciech Macek  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
18*94e25b7aSWojciech Macek  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19*94e25b7aSWojciech Macek  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20*94e25b7aSWojciech Macek  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21*94e25b7aSWojciech Macek  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22*94e25b7aSWojciech Macek  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23*94e25b7aSWojciech Macek  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24*94e25b7aSWojciech Macek  */
25*94e25b7aSWojciech Macek 
26*94e25b7aSWojciech Macek #ifndef DEV_FLASH_FLEX_SPI_H_
27*94e25b7aSWojciech Macek #define	DEV_FLASH_FLEX_SPI_H_
28*94e25b7aSWojciech Macek 
29*94e25b7aSWojciech Macek #define	BIT(x)				(1 << (x))
30*94e25b7aSWojciech Macek 
31*94e25b7aSWojciech Macek /* Registers used by the driver */
32*94e25b7aSWojciech Macek #define	FSPI_MCR0			0x00
33*94e25b7aSWojciech Macek #define	FSPI_MCR0_AHB_TIMEOUT(x)	((x) << 24)
34*94e25b7aSWojciech Macek #define	FSPI_MCR0_IP_TIMEOUT(x)		((x) << 16)
35*94e25b7aSWojciech Macek #define	FSPI_MCR0_LEARN_EN		BIT(15)
36*94e25b7aSWojciech Macek #define	FSPI_MCR0_SCRFRUN_EN		BIT(14)
37*94e25b7aSWojciech Macek #define	FSPI_MCR0_OCTCOMB_EN		BIT(13)
38*94e25b7aSWojciech Macek #define	FSPI_MCR0_DOZE_EN		BIT(12)
39*94e25b7aSWojciech Macek #define	FSPI_MCR0_HSEN			BIT(11)
40*94e25b7aSWojciech Macek #define	FSPI_MCR0_SERCLKDIV		BIT(8)
41*94e25b7aSWojciech Macek #define	FSPI_MCR0_ATDF_EN		BIT(7)
42*94e25b7aSWojciech Macek #define	FSPI_MCR0_ARDF_EN		BIT(6)
43*94e25b7aSWojciech Macek #define	FSPI_MCR0_RXCLKSRC(x)		((x) << 4)
44*94e25b7aSWojciech Macek #define	FSPI_MCR0_END_CFG(x)		((x) << 2)
45*94e25b7aSWojciech Macek #define	FSPI_MCR0_MDIS			BIT(1)
46*94e25b7aSWojciech Macek #define	FSPI_MCR0_SWRST			BIT(0)
47*94e25b7aSWojciech Macek 
48*94e25b7aSWojciech Macek #define	FSPI_MCR1			0x04
49*94e25b7aSWojciech Macek #define	FSPI_MCR1_SEQ_TIMEOUT(x)	((x) << 16)
50*94e25b7aSWojciech Macek #define	FSPI_MCR1_AHB_TIMEOUT(x)	(x)
51*94e25b7aSWojciech Macek 
52*94e25b7aSWojciech Macek #define	FSPI_MCR2			0x08
53*94e25b7aSWojciech Macek #define	FSPI_MCR2_IDLE_WAIT(x)		((x) << 24)
54*94e25b7aSWojciech Macek #define	FSPI_MCR2_SAMEDEVICEEN		BIT(15)
55*94e25b7aSWojciech Macek #define	FSPI_MCR2_CLRLRPHS		BIT(14)
56*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABRDATSZ		BIT(8)
57*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABRLEARN		BIT(7)
58*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABR_READ		BIT(6)
59*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABRWRITE		BIT(5)
60*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABRDUMMY		BIT(4)
61*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABR_MODE		BIT(3)
62*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABRCADDR		BIT(2)
63*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABRRADDR		BIT(1)
64*94e25b7aSWojciech Macek #define	FSPI_MCR2_ABR_CMD		BIT(0)
65*94e25b7aSWojciech Macek 
66*94e25b7aSWojciech Macek #define	FSPI_AHBCR			0x0c
67*94e25b7aSWojciech Macek #define	FSPI_AHBCR_RDADDROPT		BIT(6)
68*94e25b7aSWojciech Macek #define	FSPI_AHBCR_PREF_EN		BIT(5)
69*94e25b7aSWojciech Macek #define	FSPI_AHBCR_BUFF_EN		BIT(4)
70*94e25b7aSWojciech Macek #define	FSPI_AHBCR_CACH_EN		BIT(3)
71*94e25b7aSWojciech Macek #define	FSPI_AHBCR_CLRTXBUF		BIT(2)
72*94e25b7aSWojciech Macek #define	FSPI_AHBCR_CLRRXBUF		BIT(1)
73*94e25b7aSWojciech Macek #define	FSPI_AHBCR_PAR_EN		BIT(0)
74*94e25b7aSWojciech Macek 
75*94e25b7aSWojciech Macek #define	FSPI_INTEN			0x10
76*94e25b7aSWojciech Macek #define	FSPI_INTEN_SCLKSBWR		BIT(9)
77*94e25b7aSWojciech Macek #define	FSPI_INTEN_SCLKSBRD		BIT(8)
78*94e25b7aSWojciech Macek #define	FSPI_INTEN_DATALRNFL		BIT(7)
79*94e25b7aSWojciech Macek #define	FSPI_INTEN_IPTXWE		BIT(6)
80*94e25b7aSWojciech Macek #define	FSPI_INTEN_IPRXWA		BIT(5)
81*94e25b7aSWojciech Macek #define	FSPI_INTEN_AHBCMDERR		BIT(4)
82*94e25b7aSWojciech Macek #define	FSPI_INTEN_IPCMDERR		BIT(3)
83*94e25b7aSWojciech Macek #define	FSPI_INTEN_AHBCMDGE		BIT(2)
84*94e25b7aSWojciech Macek #define	FSPI_INTEN_IPCMDGE		BIT(1)
85*94e25b7aSWojciech Macek #define	FSPI_INTEN_IPCMDDONE		BIT(0)
86*94e25b7aSWojciech Macek 
87*94e25b7aSWojciech Macek #define	FSPI_INTR			0x14
88*94e25b7aSWojciech Macek #define	FSPI_INTR_SCLKSBWR		BIT(9)
89*94e25b7aSWojciech Macek #define	FSPI_INTR_SCLKSBRD		BIT(8)
90*94e25b7aSWojciech Macek #define	FSPI_INTR_DATALRNFL		BIT(7)
91*94e25b7aSWojciech Macek #define	FSPI_INTR_IPTXWE		BIT(6)
92*94e25b7aSWojciech Macek #define	FSPI_INTR_IPRXWA		BIT(5)
93*94e25b7aSWojciech Macek #define	FSPI_INTR_AHBCMDERR		BIT(4)
94*94e25b7aSWojciech Macek #define	FSPI_INTR_IPCMDERR		BIT(3)
95*94e25b7aSWojciech Macek #define	FSPI_INTR_AHBCMDGE		BIT(2)
96*94e25b7aSWojciech Macek #define	FSPI_INTR_IPCMDGE		BIT(1)
97*94e25b7aSWojciech Macek #define	FSPI_INTR_IPCMDDONE		BIT(0)
98*94e25b7aSWojciech Macek 
99*94e25b7aSWojciech Macek #define	FSPI_LUTKEY			0x18
100*94e25b7aSWojciech Macek #define	FSPI_LUTKEY_VALUE		0x5AF05AF0
101*94e25b7aSWojciech Macek 
102*94e25b7aSWojciech Macek #define	FSPI_LCKCR			0x1C
103*94e25b7aSWojciech Macek 
104*94e25b7aSWojciech Macek #define	FSPI_LCKER_LOCK			0x1
105*94e25b7aSWojciech Macek #define	FSPI_LCKER_UNLOCK		0x2
106*94e25b7aSWojciech Macek 
107*94e25b7aSWojciech Macek #define	FSPI_BUFXCR_INVALID_MSTRID	0xE
108*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF0CR0		0x20
109*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF1CR0		0x24
110*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF2CR0		0x28
111*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF3CR0		0x2C
112*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF4CR0		0x30
113*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF5CR0		0x34
114*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF6CR0		0x38
115*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF7CR0		0x3C
116*94e25b7aSWojciech Macek #define	FSPI_AHBRXBUF0CR7_PREF		BIT(31)
117*94e25b7aSWojciech Macek 
118*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF0CR1		0x40
119*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF1CR1		0x44
120*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF2CR1		0x48
121*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF3CR1		0x4C
122*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF4CR1		0x50
123*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF5CR1		0x54
124*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF6CR1		0x58
125*94e25b7aSWojciech Macek #define	FSPI_AHBRX_BUF7CR1		0x5C
126*94e25b7aSWojciech Macek 
127*94e25b7aSWojciech Macek #define	FSPI_FLSHA1CR0			0x60
128*94e25b7aSWojciech Macek #define	FSPI_FLSHA2CR0			0x64
129*94e25b7aSWojciech Macek #define	FSPI_FLSHB1CR0			0x68
130*94e25b7aSWojciech Macek #define	FSPI_FLSHB2CR0			0x6C
131*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR0_SZ_KB		10
132*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR0_SZ(x)		((x) >> FSPI_FLSHXCR0_SZ_KB)
133*94e25b7aSWojciech Macek 
134*94e25b7aSWojciech Macek #define	FSPI_FLSHA1CR1			0x70
135*94e25b7aSWojciech Macek #define	FSPI_FLSHA2CR1			0x74
136*94e25b7aSWojciech Macek #define	FSPI_FLSHB1CR1			0x78
137*94e25b7aSWojciech Macek #define	FSPI_FLSHB2CR1			0x7C
138*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR1_CSINTR(x)		((x) << 16)
139*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR1_CAS(x)		((x) << 11)
140*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR1_WA		BIT(10)
141*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR1_TCSH(x)		((x) << 5)
142*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR1_TCSS(x)		(x)
143*94e25b7aSWojciech Macek 
144*94e25b7aSWojciech Macek #define	FSPI_FLSHA1CR2			0x80
145*94e25b7aSWojciech Macek #define	FSPI_FLSHA2CR2			0x84
146*94e25b7aSWojciech Macek #define	FSPI_FLSHB1CR2			0x88
147*94e25b7aSWojciech Macek #define	FSPI_FLSHB2CR2			0x8C
148*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR2_CLRINSP		BIT(24)
149*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR2_AWRWAIT		BIT(16)
150*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR2_AWRSEQN_SHIFT	13
151*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR2_AWRSEQI_SHIFT	8
152*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR2_ARDSEQN_SHIFT	5
153*94e25b7aSWojciech Macek #define	FSPI_FLSHXCR2_ARDSEQI_SHIFT	0
154*94e25b7aSWojciech Macek 
155*94e25b7aSWojciech Macek #define	FSPI_IPCR0			0xA0
156*94e25b7aSWojciech Macek 
157*94e25b7aSWojciech Macek #define	FSPI_IPCR1			0xA4
158*94e25b7aSWojciech Macek #define	FSPI_IPCR1_IPAREN		BIT(31)
159*94e25b7aSWojciech Macek #define	FSPI_IPCR1_SEQNUM_SHIFT		24
160*94e25b7aSWojciech Macek #define	FSPI_IPCR1_SEQID_SHIFT		16
161*94e25b7aSWojciech Macek #define	FSPI_IPCR1_IDATSZ(x)		(x)
162*94e25b7aSWojciech Macek 
163*94e25b7aSWojciech Macek #define	FSPI_IPCMD			0xB0
164*94e25b7aSWojciech Macek #define	FSPI_IPCMD_TRG			BIT(0)
165*94e25b7aSWojciech Macek 
166*94e25b7aSWojciech Macek #define	FSPI_DLPR			0xB4
167*94e25b7aSWojciech Macek 
168*94e25b7aSWojciech Macek #define	FSPI_IPRXFCR			0xB8
169*94e25b7aSWojciech Macek #define	FSPI_IPRXFCR_CLR		BIT(0)
170*94e25b7aSWojciech Macek #define	FSPI_IPRXFCR_DMA_EN		BIT(1)
171*94e25b7aSWojciech Macek #define	FSPI_IPRXFCR_WMRK(x)		((x) << 2)
172*94e25b7aSWojciech Macek 
173*94e25b7aSWojciech Macek #define	FSPI_IPTXFCR			0xBC
174*94e25b7aSWojciech Macek #define	FSPI_IPTXFCR_CLR		BIT(0)
175*94e25b7aSWojciech Macek #define	FSPI_IPTXFCR_DMA_EN		BIT(1)
176*94e25b7aSWojciech Macek #define	FSPI_IPTXFCR_WMRK(x)		((x) << 2)
177*94e25b7aSWojciech Macek 
178*94e25b7aSWojciech Macek #define	FSPI_DLLACR			0xC0
179*94e25b7aSWojciech Macek #define	FSPI_DLLACR_OVRDEN		BIT(8)
180*94e25b7aSWojciech Macek 
181*94e25b7aSWojciech Macek #define	FSPI_DLLBCR			0xC4
182*94e25b7aSWojciech Macek #define	FSPI_DLLBCR_OVRDEN		BIT(8)
183*94e25b7aSWojciech Macek 
184*94e25b7aSWojciech Macek #define	FSPI_STS0			0xE0
185*94e25b7aSWojciech Macek #define	FSPI_STS0_DLPHB(x)		((x) << 8)
186*94e25b7aSWojciech Macek #define	FSPI_STS0_DLPHA(x)		((x) << 4)
187*94e25b7aSWojciech Macek #define	FSPI_STS0_CMD_SRC(x)		((x) << 2)
188*94e25b7aSWojciech Macek #define	FSPI_STS0_ARB_IDLE		BIT(1)
189*94e25b7aSWojciech Macek #define	FSPI_STS0_SEQ_IDLE		BIT(0)
190*94e25b7aSWojciech Macek 
191*94e25b7aSWojciech Macek #define	FSPI_STS1			0xE4
192*94e25b7aSWojciech Macek #define	FSPI_STS1_IP_ERRCD(x)		((x) << 24)
193*94e25b7aSWojciech Macek #define	FSPI_STS1_IP_ERRID(x)		((x) << 16)
194*94e25b7aSWojciech Macek #define	FSPI_STS1_AHB_ERRCD(x)		((x) << 8)
195*94e25b7aSWojciech Macek #define	FSPI_STS1_AHB_ERRID(x)		(x)
196*94e25b7aSWojciech Macek 
197*94e25b7aSWojciech Macek #define	FSPI_AHBSPNST			0xEC
198*94e25b7aSWojciech Macek #define	FSPI_AHBSPNST_DATLFT(x)		((x) << 16)
199*94e25b7aSWojciech Macek #define	FSPI_AHBSPNST_BUFID(x)		((x) << 1)
200*94e25b7aSWojciech Macek #define	FSPI_AHBSPNST_ACTIVE		BIT(0)
201*94e25b7aSWojciech Macek 
202*94e25b7aSWojciech Macek #define	FSPI_IPRXFSTS			0xF0
203*94e25b7aSWojciech Macek #define	FSPI_IPRXFSTS_RDCNTR(x)		((x) << 16)
204*94e25b7aSWojciech Macek #define	FSPI_IPRXFSTS_FILL(x)		(x)
205*94e25b7aSWojciech Macek 
206*94e25b7aSWojciech Macek #define	FSPI_IPTXFSTS			0xF4
207*94e25b7aSWojciech Macek #define	FSPI_IPTXFSTS_WRCNTR(x)		((x) << 16)
208*94e25b7aSWojciech Macek #define	FSPI_IPTXFSTS_FILL(x)		(x)
209*94e25b7aSWojciech Macek 
210*94e25b7aSWojciech Macek #define	FSPI_RFDR			0x100
211*94e25b7aSWojciech Macek #define	FSPI_TFDR			0x180
212*94e25b7aSWojciech Macek 
213*94e25b7aSWojciech Macek #define	FSPI_LUT_BASE			0x200
214*94e25b7aSWojciech Macek #define	FSPI_LUT_REG(idx) \
215*94e25b7aSWojciech Macek 	(FSPI_LUT_BASE + (idx) * 0x10)
216*94e25b7aSWojciech Macek 
217*94e25b7aSWojciech Macek /*
218*94e25b7aSWojciech Macek  * Commands
219*94e25b7aSWojciech Macek  */
220*94e25b7aSWojciech Macek #define	FSPI_CMD_WRITE_ENABLE		0x06
221*94e25b7aSWojciech Macek #define	FSPI_CMD_WRITE_DISABLE		0x04
222*94e25b7aSWojciech Macek #define	FSPI_CMD_READ_IDENT		0x9F
223*94e25b7aSWojciech Macek #define	FSPI_CMD_READ_STATUS		0x05
224*94e25b7aSWojciech Macek #define	FSPI_CMD_WRITE_STATUS		0x01
225*94e25b7aSWojciech Macek #define	FSPI_CMD_READ			0x03
226*94e25b7aSWojciech Macek #define	FSPI_CMD_FAST_READ		0x0B
227*94e25b7aSWojciech Macek #define	FSPI_CMD_PAGE_PROGRAM		0x02
228*94e25b7aSWojciech Macek #define	FSPI_CMD_SECTOR_ERASE		0xD8
229*94e25b7aSWojciech Macek #define	FSPI_CMD_BULK_ERASE		0xC7
230*94e25b7aSWojciech Macek #define	FSPI_CMD_BLOCK_4K_ERASE		0x20
231*94e25b7aSWojciech Macek #define	FSPI_CMD_BLOCK_32K_ERASE	0x52
232*94e25b7aSWojciech Macek #define	FSPI_CMD_ENTER_4B_MODE		0xB7
233*94e25b7aSWojciech Macek #define	FSPI_CMD_EXIT_4B_MODE		0xE9
234*94e25b7aSWojciech Macek #define	FSPI_CMD_READ_CTRL_REG		0x35
235*94e25b7aSWojciech Macek #define	FSPI_CMD_BANK_REG_WRITE		0x17	/* (spansion) */
236*94e25b7aSWojciech Macek #define	FSPI_CMD_SECTOR_ERASE_4B	0xDC
237*94e25b7aSWojciech Macek #define	FSPI_CMD_BLOCK_4K_ERASE_4B	0x21
238*94e25b7aSWojciech Macek #define	FSPI_CMD_BLOCK_32K_ERASE_4B	0x5C
239*94e25b7aSWojciech Macek #define	FSPI_CMD_PAGE_PROGRAM_4B	0x12
240*94e25b7aSWojciech Macek #define	FSPI_CMD_FAST_READ_4B		0x0C
241*94e25b7aSWojciech Macek 
242*94e25b7aSWojciech Macek 
243*94e25b7aSWojciech Macek 
244*94e25b7aSWojciech Macek /* register map end */
245*94e25b7aSWojciech Macek 
246*94e25b7aSWojciech Macek /* Instruction set for the LUT register. */
247*94e25b7aSWojciech Macek #define	LUT_STOP			0x00
248*94e25b7aSWojciech Macek #define	LUT_CMD				0x01
249*94e25b7aSWojciech Macek #define	LUT_ADDR			0x02
250*94e25b7aSWojciech Macek #define	LUT_CADDR_SDR			0x03
251*94e25b7aSWojciech Macek #define	LUT_MODE			0x04
252*94e25b7aSWojciech Macek #define	LUT_MODE2			0x05
253*94e25b7aSWojciech Macek #define	LUT_MODE4			0x06
254*94e25b7aSWojciech Macek #define	LUT_MODE8			0x07
255*94e25b7aSWojciech Macek #define	LUT_NXP_WRITE			0x08
256*94e25b7aSWojciech Macek #define	LUT_NXP_READ			0x09
257*94e25b7aSWojciech Macek #define	LUT_LEARN_SDR			0x0A
258*94e25b7aSWojciech Macek #define	LUT_DATSZ_SDR			0x0B
259*94e25b7aSWojciech Macek #define	LUT_DUMMY			0x0C
260*94e25b7aSWojciech Macek #define	LUT_DUMMY_RWDS_SDR		0x0D
261*94e25b7aSWojciech Macek #define	LUT_JMP_ON_CS			0x1F
262*94e25b7aSWojciech Macek #define	LUT_CMD_DDR			0x21
263*94e25b7aSWojciech Macek #define	LUT_ADDR_DDR			0x22
264*94e25b7aSWojciech Macek #define	LUT_CADDR_DDR			0x23
265*94e25b7aSWojciech Macek #define	LUT_MODE_DDR			0x24
266*94e25b7aSWojciech Macek #define	LUT_MODE2_DDR			0x25
267*94e25b7aSWojciech Macek #define	LUT_MODE4_DDR			0x26
268*94e25b7aSWojciech Macek #define	LUT_MODE8_DDR			0x27
269*94e25b7aSWojciech Macek #define	LUT_WRITE_DDR			0x28
270*94e25b7aSWojciech Macek #define	LUT_READ_DDR			0x29
271*94e25b7aSWojciech Macek #define	LUT_LEARN_DDR			0x2A
272*94e25b7aSWojciech Macek #define	LUT_DATSZ_DDR			0x2B
273*94e25b7aSWojciech Macek #define	LUT_DUMMY_DDR			0x2C
274*94e25b7aSWojciech Macek #define	LUT_DUMMY_RWDS_DDR		0x2D
275*94e25b7aSWojciech Macek 
276*94e25b7aSWojciech Macek /* LUT to operation mapping */
277*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_READ		0
278*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_JEDECID		1
279*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_STATUS_READ	2
280*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_PAGE_PROGRAM	3
281*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_WRITE_ENABLE	4
282*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_WRITE_DISABLE	5
283*94e25b7aSWojciech Macek #define	LUT_FLASH_CMD_SECTOR_ERASE	6
284*94e25b7aSWojciech Macek 
285*94e25b7aSWojciech Macek 
286*94e25b7aSWojciech Macek /*
287*94e25b7aSWojciech Macek  * Calculate number of required PAD bits for LUT register.
288*94e25b7aSWojciech Macek  *
289*94e25b7aSWojciech Macek  * The pad stands for the number of IO lines [0:7].
290*94e25b7aSWojciech Macek  * For example, the octal read needs eight IO lines,
291*94e25b7aSWojciech Macek  * so you should use LUT_PAD(8). This macro
292*94e25b7aSWojciech Macek  * returns 3 i.e. use eight (2^3) IP lines for read.
293*94e25b7aSWojciech Macek  */
294*94e25b7aSWojciech Macek #define	LUT_PAD(x) (fls(x) - 1)
295*94e25b7aSWojciech Macek 
296*94e25b7aSWojciech Macek /*
297*94e25b7aSWojciech Macek  * Macro for constructing the LUT entries with the following
298*94e25b7aSWojciech Macek  * register layout:
299*94e25b7aSWojciech Macek  *
300*94e25b7aSWojciech Macek  *  ---------------------------------------------------
301*94e25b7aSWojciech Macek  *  | INSTR1 | PAD1 | OPRND1 | INSTR0 | PAD0 | OPRND0 |
302*94e25b7aSWojciech Macek  *  ---------------------------------------------------
303*94e25b7aSWojciech Macek  */
304*94e25b7aSWojciech Macek #define	PAD_SHIFT		8
305*94e25b7aSWojciech Macek #define	INSTR_SHIFT		10
306*94e25b7aSWojciech Macek #define	OPRND_SHIFT		16
307*94e25b7aSWojciech Macek 
308*94e25b7aSWojciech Macek /* Macros for constructing the LUT register. */
309*94e25b7aSWojciech Macek #define	LUT_DEF(idx, ins, pad, opr)			  \
310*94e25b7aSWojciech Macek 	((((ins) << INSTR_SHIFT) | ((pad) << PAD_SHIFT) | \
311*94e25b7aSWojciech Macek 	(opr)) << (((idx) % 2) * OPRND_SHIFT))
312*94e25b7aSWojciech Macek 
313*94e25b7aSWojciech Macek #define	POLL_TOUT		5000
314*94e25b7aSWojciech Macek #define	NXP_FSPI_MAX_CHIPSELECT		4
315*94e25b7aSWojciech Macek #define	NXP_FSPI_MIN_IOMAP	SZ_4M
316*94e25b7aSWojciech Macek 
317*94e25b7aSWojciech Macek #define	DCFG_RCWSR1		0x100
318*94e25b7aSWojciech Macek 
319*94e25b7aSWojciech Macek /* Access flash memory using IP bus only */
320*94e25b7aSWojciech Macek #define	FSPI_QUIRK_USE_IP_ONLY	BIT(0)
321*94e25b7aSWojciech Macek 
322*94e25b7aSWojciech Macek #define	FLASH_SECTORSIZE	512
323*94e25b7aSWojciech Macek 
324*94e25b7aSWojciech Macek #define	TSTATE_STOPPED		0
325*94e25b7aSWojciech Macek #define	TSTATE_STOPPING		1
326*94e25b7aSWojciech Macek #define	TSTATE_RUNNING		2
327*94e25b7aSWojciech Macek 
328*94e25b7aSWojciech Macek #define	STATUS_SRWD		BIT(7)
329*94e25b7aSWojciech Macek #define	STATUS_BP2		BIT(4)
330*94e25b7aSWojciech Macek #define	STATUS_BP1		BIT(3)
331*94e25b7aSWojciech Macek #define	STATUS_BP0		BIT(2)
332*94e25b7aSWojciech Macek #define	STATUS_WEL		BIT(1)
333*94e25b7aSWojciech Macek #define	STATUS_WIP		BIT(0)
334*94e25b7aSWojciech Macek 
335*94e25b7aSWojciech Macek 
336*94e25b7aSWojciech Macek #endif /* DEV_FLASH_FLEX_SPI_H_ */
337