xref: /openbmc/u-boot/drivers/spi/mtk_qspi.c (revision 9450ab2ba8d720bd9f73bccc0af2e2b5a2c2aaf1)
1  // SPDX-License-Identifier: GPL-2.0
2  /*
3   * Copyright (c) 2018  MediaTek, Inc.
4   * Author : Guochun.Mao@mediatek.com
5   */
6  
7  #include <common.h>
8  #include <dm.h>
9  #include <malloc.h>
10  #include <spi.h>
11  #include <asm/io.h>
12  #include <linux/iopoll.h>
13  #include <linux/ioport.h>
14  
15  /* Register Offset */
16  struct mtk_qspi_regs {
17  	u32 cmd;
18  	u32 cnt;
19  	u32 rdsr;
20  	u32 rdata;
21  	u32 radr[3];
22  	u32 wdata;
23  	u32 prgdata[6];
24  	u32 shreg[10];
25  	u32 cfg[2];
26  	u32 shreg10;
27  	u32 mode_mon;
28  	u32 status[4];
29  	u32 flash_time;
30  	u32 flash_cfg;
31  	u32 reserved_0[3];
32  	u32 sf_time;
33  	u32 pp_dw_data;
34  	u32 reserved_1;
35  	u32 delsel_0[2];
36  	u32 intrstus;
37  	u32 intren;
38  	u32 reserved_2;
39  	u32 cfg3;
40  	u32 reserved_3;
41  	u32 chksum;
42  	u32 aaicmd;
43  	u32 wrprot;
44  	u32 radr3;
45  	u32 dual;
46  	u32 delsel_1[3];
47  };
48  
49  struct mtk_qspi_platdata {
50  	fdt_addr_t reg_base;
51  	fdt_addr_t mem_base;
52  };
53  
54  struct mtk_qspi_priv {
55  	struct mtk_qspi_regs *regs;
56  	unsigned long *mem_base;
57  	u8 op;
58  	u8 tx[3]; /* only record max 3 bytes paras, when it's address. */
59  	u32 txlen; /* dout buffer length  - op code length */
60  	u8 *rx;
61  	u32 rxlen;
62  };
63  
64  #define MTK_QSPI_CMD_POLLINGREG_US 500000
65  #define MTK_QSPI_WRBUF_SIZE        256
66  #define MTK_QSPI_COMMAND_ENABLE    0x30
67  
68  /* NOR flash controller commands */
69  #define MTK_QSPI_RD_TRIGGER        BIT(0)
70  #define MTK_QSPI_READSTATUS        BIT(1)
71  #define MTK_QSPI_PRG_CMD           BIT(2)
72  #define MTK_QSPI_WR_TRIGGER        BIT(4)
73  #define MTK_QSPI_WRITESTATUS       BIT(5)
74  #define MTK_QSPI_AUTOINC           BIT(7)
75  
76  #define MTK_QSPI_MAX_RX_TX_SHIFT   0x6
77  #define MTK_QSPI_MAX_SHIFT         0x8
78  
79  #define MTK_QSPI_WR_BUF_ENABLE     0x1
80  #define MTK_QSPI_WR_BUF_DISABLE    0x0
81  
mtk_qspi_execute_cmd(struct mtk_qspi_priv * priv,u8 cmd)82  static int mtk_qspi_execute_cmd(struct mtk_qspi_priv *priv, u8 cmd)
83  {
84  	u8 tmp;
85  	u8 val = cmd & ~MTK_QSPI_AUTOINC;
86  
87  	writeb(cmd, &priv->regs->cmd);
88  
89  	return readb_poll_timeout(&priv->regs->cmd, tmp, !(val & tmp),
90  				  MTK_QSPI_CMD_POLLINGREG_US);
91  }
92  
mtk_qspi_tx_rx(struct mtk_qspi_priv * priv)93  static int mtk_qspi_tx_rx(struct mtk_qspi_priv *priv)
94  {
95  	int len = 1 + priv->txlen + priv->rxlen;
96  	int i, ret, idx;
97  
98  	if (len > MTK_QSPI_MAX_SHIFT)
99  		return -ERR_INVAL;
100  
101  	writeb(len * 8, &priv->regs->cnt);
102  
103  	/* start at PRGDATA5, go down to PRGDATA0 */
104  	idx = MTK_QSPI_MAX_RX_TX_SHIFT - 1;
105  
106  	/* opcode */
107  	writeb(priv->op, &priv->regs->prgdata[idx]);
108  	idx--;
109  
110  	/* program TX data */
111  	for (i = 0; i < priv->txlen; i++, idx--)
112  		writeb(priv->tx[i], &priv->regs->prgdata[idx]);
113  
114  	/* clear out rest of TX registers */
115  	while (idx >= 0) {
116  		writeb(0, &priv->regs->prgdata[idx]);
117  		idx--;
118  	}
119  
120  	ret = mtk_qspi_execute_cmd(priv, MTK_QSPI_PRG_CMD);
121  	if (ret)
122  		return ret;
123  
124  	/* restart at first RX byte */
125  	idx = priv->rxlen - 1;
126  
127  	/* read out RX data */
128  	for (i = 0; i < priv->rxlen; i++, idx--)
129  		priv->rx[i] = readb(&priv->regs->shreg[idx]);
130  
131  	return 0;
132  }
133  
mtk_qspi_read(struct mtk_qspi_priv * priv,u32 addr,u8 * buf,u32 len)134  static int mtk_qspi_read(struct mtk_qspi_priv *priv,
135  			 u32 addr, u8 *buf, u32 len)
136  {
137  	memcpy(buf, (u8 *)priv->mem_base + addr, len);
138  	return 0;
139  }
140  
mtk_qspi_set_addr(struct mtk_qspi_priv * priv,u32 addr)141  static void mtk_qspi_set_addr(struct mtk_qspi_priv *priv, u32 addr)
142  {
143  	int i;
144  
145  	for (i = 0; i < 3; i++) {
146  		writeb(addr & 0xff, &priv->regs->radr[i]);
147  		addr >>= 8;
148  	}
149  }
150  
mtk_qspi_write_single_byte(struct mtk_qspi_priv * priv,u32 addr,u32 length,const u8 * data)151  static int mtk_qspi_write_single_byte(struct mtk_qspi_priv *priv,
152  				      u32 addr, u32 length, const u8 *data)
153  {
154  	int i, ret;
155  
156  	mtk_qspi_set_addr(priv, addr);
157  
158  	for (i = 0; i < length; i++) {
159  		writeb(*data++, &priv->regs->wdata);
160  		ret = mtk_qspi_execute_cmd(priv, MTK_QSPI_WR_TRIGGER);
161  		if (ret < 0)
162  			return ret;
163  	}
164  	return 0;
165  }
166  
mtk_qspi_write_buffer(struct mtk_qspi_priv * priv,u32 addr,const u8 * buf)167  static int mtk_qspi_write_buffer(struct mtk_qspi_priv *priv, u32 addr,
168  				 const u8 *buf)
169  {
170  	int i, data;
171  
172  	mtk_qspi_set_addr(priv, addr);
173  
174  	for (i = 0; i < MTK_QSPI_WRBUF_SIZE; i += 4) {
175  		data = buf[i + 3] << 24 | buf[i + 2] << 16 |
176  		       buf[i + 1] << 8 | buf[i];
177  		writel(data, &priv->regs->pp_dw_data);
178  	}
179  
180  	return mtk_qspi_execute_cmd(priv, MTK_QSPI_WR_TRIGGER);
181  }
182  
mtk_qspi_write(struct mtk_qspi_priv * priv,u32 addr,const u8 * buf,u32 len)183  static int mtk_qspi_write(struct mtk_qspi_priv *priv,
184  			  u32 addr, const u8 *buf, u32 len)
185  {
186  	int ret;
187  
188  	/* setting pre-fetch buffer for page program */
189  	writel(MTK_QSPI_WR_BUF_ENABLE, &priv->regs->cfg[1]);
190  	while (len >= MTK_QSPI_WRBUF_SIZE) {
191  		ret = mtk_qspi_write_buffer(priv, addr, buf);
192  		if (ret < 0)
193  			return ret;
194  
195  		len -= MTK_QSPI_WRBUF_SIZE;
196  		addr += MTK_QSPI_WRBUF_SIZE;
197  		buf += MTK_QSPI_WRBUF_SIZE;
198  	}
199  	/* disable pre-fetch buffer for page program */
200  	writel(MTK_QSPI_WR_BUF_DISABLE, &priv->regs->cfg[1]);
201  
202  	if (len)
203  		return mtk_qspi_write_single_byte(priv, addr, len, buf);
204  
205  	return 0;
206  }
207  
mtk_qspi_claim_bus(struct udevice * dev)208  static int mtk_qspi_claim_bus(struct udevice *dev)
209  {
210  	/* nothing to do */
211  	return 0;
212  }
213  
mtk_qspi_release_bus(struct udevice * dev)214  static int mtk_qspi_release_bus(struct udevice *dev)
215  {
216  	/* nothing to do */
217  	return 0;
218  }
219  
mtk_qspi_transfer(struct mtk_qspi_priv * priv,unsigned int bitlen,const void * dout,void * din,unsigned long flags)220  static int mtk_qspi_transfer(struct mtk_qspi_priv *priv, unsigned int bitlen,
221  			     const void *dout, void *din, unsigned long flags)
222  {
223  	u32 bytes = DIV_ROUND_UP(bitlen, 8);
224  	u32 addr;
225  
226  	if (!bytes)
227  		return -ERR_INVAL;
228  
229  	if (dout) {
230  		if (flags & SPI_XFER_BEGIN) {
231  			/* parse op code and potential paras first */
232  			priv->op = *(u8 *)dout;
233  			if (bytes > 1)
234  				memcpy(priv->tx, (u8 *)dout + 1,
235  				       bytes <= 4 ? bytes - 1 : 3);
236  			priv->txlen = bytes - 1;
237  		}
238  
239  		if (flags == SPI_XFER_ONCE) {
240  			/* operations without receiving or sending data.
241  			 * for example: erase, write flash register or write
242  			 * enable...
243  			 */
244  			priv->rx = NULL;
245  			priv->rxlen = 0;
246  			return mtk_qspi_tx_rx(priv);
247  		}
248  
249  		if (flags & SPI_XFER_END) {
250  			/* here, dout should be data to be written.
251  			 * and priv->tx should be filled 3Bytes address.
252  			 */
253  			addr = priv->tx[0] << 16 | priv->tx[1] << 8 |
254  			       priv->tx[2];
255  			return mtk_qspi_write(priv, addr, (u8 *)dout, bytes);
256  		}
257  	}
258  
259  	if (din) {
260  		if (priv->txlen >= 3) {
261  			/* if run to here, priv->tx[] should be the address
262  			 * where read data from,
263  			 * and, din is the buf to receive data.
264  			 */
265  			addr = priv->tx[0] << 16 | priv->tx[1] << 8 |
266  			       priv->tx[2];
267  			return mtk_qspi_read(priv, addr, (u8 *)din, bytes);
268  		}
269  
270  		/* should be reading flash's register */
271  		priv->rx = (u8 *)din;
272  		priv->rxlen = bytes;
273  		return mtk_qspi_tx_rx(priv);
274  	}
275  
276  	return 0;
277  }
278  
mtk_qspi_xfer(struct udevice * dev,unsigned int bitlen,const void * dout,void * din,unsigned long flags)279  static int mtk_qspi_xfer(struct udevice *dev, unsigned int bitlen,
280  			 const void *dout, void *din, unsigned long flags)
281  {
282  	struct udevice *bus = dev->parent;
283  	struct mtk_qspi_priv *priv = dev_get_priv(bus);
284  
285  	return  mtk_qspi_transfer(priv, bitlen, dout, din, flags);
286  }
287  
mtk_qspi_set_speed(struct udevice * bus,uint speed)288  static int mtk_qspi_set_speed(struct udevice *bus, uint speed)
289  {
290  	/* nothing to do */
291  	return 0;
292  }
293  
mtk_qspi_set_mode(struct udevice * bus,uint mode)294  static int mtk_qspi_set_mode(struct udevice *bus, uint mode)
295  {
296  	/* nothing to do */
297  	return 0;
298  }
299  
mtk_qspi_ofdata_to_platdata(struct udevice * bus)300  static int mtk_qspi_ofdata_to_platdata(struct udevice *bus)
301  {
302  	struct resource res_reg, res_mem;
303  	struct mtk_qspi_platdata *plat = bus->platdata;
304  	int ret;
305  
306  	ret = dev_read_resource_byname(bus, "reg_base", &res_reg);
307  	if (ret) {
308  		debug("can't get reg_base resource(ret = %d)\n", ret);
309  		return -ENOMEM;
310  	}
311  
312  	ret = dev_read_resource_byname(bus, "mem_base", &res_mem);
313  	if (ret) {
314  		debug("can't get map_base resource(ret = %d)\n", ret);
315  		return -ENOMEM;
316  	}
317  
318  	plat->mem_base = res_mem.start;
319  	plat->reg_base = res_reg.start;
320  
321  	return 0;
322  }
323  
mtk_qspi_probe(struct udevice * bus)324  static int mtk_qspi_probe(struct udevice *bus)
325  {
326  	struct mtk_qspi_platdata *plat = dev_get_platdata(bus);
327  	struct mtk_qspi_priv *priv = dev_get_priv(bus);
328  
329  	priv->regs = (struct mtk_qspi_regs *)plat->reg_base;
330  	priv->mem_base = (unsigned long *)plat->mem_base;
331  
332  	writel(MTK_QSPI_COMMAND_ENABLE, &priv->regs->wrprot);
333  
334  	return 0;
335  }
336  
337  static const struct dm_spi_ops mtk_qspi_ops = {
338  	.claim_bus      = mtk_qspi_claim_bus,
339  	.release_bus    = mtk_qspi_release_bus,
340  	.xfer           = mtk_qspi_xfer,
341  	.set_speed      = mtk_qspi_set_speed,
342  	.set_mode       = mtk_qspi_set_mode,
343  };
344  
345  static const struct udevice_id mtk_qspi_ids[] = {
346  	{ .compatible = "mediatek,mt7629-qspi" },
347  	{ }
348  };
349  
350  U_BOOT_DRIVER(mtk_qspi) = {
351  	.name     = "mtk_qspi",
352  	.id       = UCLASS_SPI,
353  	.of_match = mtk_qspi_ids,
354  	.ops      = &mtk_qspi_ops,
355  	.ofdata_to_platdata       = mtk_qspi_ofdata_to_platdata,
356  	.platdata_auto_alloc_size = sizeof(struct mtk_qspi_platdata),
357  	.priv_auto_alloc_size     = sizeof(struct mtk_qspi_priv),
358  	.probe    = mtk_qspi_probe,
359  };
360