2 * HiSilicon SPI Nor Flash Controller Driver
4 * Copyright (c) 2015-2016 HiSilicon Technologies Co., Ltd.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 #include <linux/bitops.h>
20 #include <linux/clk.h>
21 #include <linux/dma-mapping.h>
22 #include <linux/iopoll.h>
23 #include <linux/module.h>
24 #include <linux/mtd/mtd.h>
25 #include <linux/mtd/spi-nor.h>
27 #include <linux/platform_device.h>
28 #include <linux/slab.h>
30 /* Hardware register offsets and field definitions */
32 #define FMC_CFG_OP_MODE_MASK BIT_MASK(0)
33 #define FMC_CFG_OP_MODE_BOOT 0
34 #define FMC_CFG_OP_MODE_NORMAL 1
35 #define FMC_CFG_FLASH_SEL(type) (((type) & 0x3) << 1)
36 #define FMC_CFG_FLASH_SEL_MASK 0x6
37 #define FMC_ECC_TYPE(type) (((type) & 0x7) << 5)
38 #define FMC_ECC_TYPE_MASK GENMASK(7, 5)
39 #define SPI_NOR_ADDR_MODE_MASK BIT_MASK(10)
40 #define SPI_NOR_ADDR_MODE_3BYTES (0x0 << 10)
41 #define SPI_NOR_ADDR_MODE_4BYTES (0x1 << 10)
42 #define FMC_GLOBAL_CFG 0x04
43 #define FMC_GLOBAL_CFG_WP_ENABLE BIT(6)
44 #define FMC_SPI_TIMING_CFG 0x08
45 #define TIMING_CFG_TCSH(nr) (((nr) & 0xf) << 8)
46 #define TIMING_CFG_TCSS(nr) (((nr) & 0xf) << 4)
47 #define TIMING_CFG_TSHSL(nr) ((nr) & 0xf)
48 #define CS_HOLD_TIME 0x6
49 #define CS_SETUP_TIME 0x6
50 #define CS_DESELECT_TIME 0xf
52 #define FMC_INT_OP_DONE BIT(0)
53 #define FMC_INT_CLR 0x20
55 #define FMC_CMD_CMD1(cmd) ((cmd) & 0xff)
56 #define FMC_ADDRL 0x2c
57 #define FMC_OP_CFG 0x30
58 #define OP_CFG_FM_CS(cs) ((cs) << 11)
59 #define OP_CFG_MEM_IF_TYPE(type) (((type) & 0x7) << 7)
60 #define OP_CFG_ADDR_NUM(addr) (((addr) & 0x7) << 4)
61 #define OP_CFG_DUMMY_NUM(dummy) ((dummy) & 0xf)
62 #define FMC_DATA_NUM 0x38
63 #define FMC_DATA_NUM_CNT(cnt) ((cnt) & GENMASK(13, 0))
65 #define FMC_OP_DUMMY_EN BIT(8)
66 #define FMC_OP_CMD1_EN BIT(7)
67 #define FMC_OP_ADDR_EN BIT(6)
68 #define FMC_OP_WRITE_DATA_EN BIT(5)
69 #define FMC_OP_READ_DATA_EN BIT(2)
70 #define FMC_OP_READ_STATUS_EN BIT(1)
71 #define FMC_OP_REG_OP_START BIT(0)
72 #define FMC_DMA_LEN 0x40
73 #define FMC_DMA_LEN_SET(len) ((len) & GENMASK(27, 0))
74 #define FMC_DMA_SADDR_D0 0x4c
75 #define HIFMC_DMA_MAX_LEN (4096)
76 #define HIFMC_DMA_MASK (HIFMC_DMA_MAX_LEN - 1)
77 #define FMC_OP_DMA 0x68
78 #define OP_CTRL_RD_OPCODE(code) (((code) & 0xff) << 16)
79 #define OP_CTRL_WR_OPCODE(code) (((code) & 0xff) << 8)
80 #define OP_CTRL_RW_OP(op) ((op) << 1)
81 #define OP_CTRL_DMA_OP_READY BIT(0)
82 #define FMC_OP_READ 0x0
83 #define FMC_OP_WRITE 0x1
84 #define FMC_WAIT_TIMEOUT 1000000
97 struct hifmc_host
*host
;
100 #define HIFMC_MAX_CHIP_NUM 2
105 void __iomem
*regbase
;
106 void __iomem
*iobase
;
109 dma_addr_t dma_buffer
;
111 struct spi_nor
*nor
[HIFMC_MAX_CHIP_NUM
];
115 static inline int wait_op_finish(struct hifmc_host
*host
)
119 return readl_poll_timeout(host
->regbase
+ FMC_INT
, reg
,
120 (reg
& FMC_INT_OP_DONE
), 0, FMC_WAIT_TIMEOUT
);
123 static int get_if_type(enum spi_nor_protocol proto
)
125 enum hifmc_iftype if_type
;
128 case SNOR_PROTO_1_1_2
:
129 if_type
= IF_TYPE_DUAL
;
131 case SNOR_PROTO_1_2_2
:
132 if_type
= IF_TYPE_DIO
;
134 case SNOR_PROTO_1_1_4
:
135 if_type
= IF_TYPE_QUAD
;
137 case SNOR_PROTO_1_4_4
:
138 if_type
= IF_TYPE_QIO
;
140 case SNOR_PROTO_1_1_1
:
142 if_type
= IF_TYPE_STD
;
149 static void hisi_spi_nor_init(struct hifmc_host
*host
)
153 reg
= TIMING_CFG_TCSH(CS_HOLD_TIME
)
154 | TIMING_CFG_TCSS(CS_SETUP_TIME
)
155 | TIMING_CFG_TSHSL(CS_DESELECT_TIME
);
156 writel(reg
, host
->regbase
+ FMC_SPI_TIMING_CFG
);
159 static int hisi_spi_nor_prep(struct spi_nor
*nor
, enum spi_nor_ops ops
)
161 struct hifmc_priv
*priv
= nor
->priv
;
162 struct hifmc_host
*host
= priv
->host
;
165 mutex_lock(&host
->lock
);
167 ret
= clk_set_rate(host
->clk
, priv
->clkrate
);
171 ret
= clk_prepare_enable(host
->clk
);
178 mutex_unlock(&host
->lock
);
182 static void hisi_spi_nor_unprep(struct spi_nor
*nor
, enum spi_nor_ops ops
)
184 struct hifmc_priv
*priv
= nor
->priv
;
185 struct hifmc_host
*host
= priv
->host
;
187 clk_disable_unprepare(host
->clk
);
188 mutex_unlock(&host
->lock
);
191 static int hisi_spi_nor_op_reg(struct spi_nor
*nor
,
192 u8 opcode
, int len
, u8 optype
)
194 struct hifmc_priv
*priv
= nor
->priv
;
195 struct hifmc_host
*host
= priv
->host
;
198 reg
= FMC_CMD_CMD1(opcode
);
199 writel(reg
, host
->regbase
+ FMC_CMD
);
201 reg
= FMC_DATA_NUM_CNT(len
);
202 writel(reg
, host
->regbase
+ FMC_DATA_NUM
);
204 reg
= OP_CFG_FM_CS(priv
->chipselect
);
205 writel(reg
, host
->regbase
+ FMC_OP_CFG
);
207 writel(0xff, host
->regbase
+ FMC_INT_CLR
);
208 reg
= FMC_OP_CMD1_EN
| FMC_OP_REG_OP_START
| optype
;
209 writel(reg
, host
->regbase
+ FMC_OP
);
211 return wait_op_finish(host
);
214 static int hisi_spi_nor_read_reg(struct spi_nor
*nor
, u8 opcode
, u8
*buf
,
217 struct hifmc_priv
*priv
= nor
->priv
;
218 struct hifmc_host
*host
= priv
->host
;
221 ret
= hisi_spi_nor_op_reg(nor
, opcode
, len
, FMC_OP_READ_DATA_EN
);
225 memcpy_fromio(buf
, host
->iobase
, len
);
229 static int hisi_spi_nor_write_reg(struct spi_nor
*nor
, u8 opcode
,
232 struct hifmc_priv
*priv
= nor
->priv
;
233 struct hifmc_host
*host
= priv
->host
;
236 memcpy_toio(host
->iobase
, buf
, len
);
238 return hisi_spi_nor_op_reg(nor
, opcode
, len
, FMC_OP_WRITE_DATA_EN
);
241 static int hisi_spi_nor_dma_transfer(struct spi_nor
*nor
, loff_t start_off
,
242 dma_addr_t dma_buf
, size_t len
, u8 op_type
)
244 struct hifmc_priv
*priv
= nor
->priv
;
245 struct hifmc_host
*host
= priv
->host
;
249 reg
= readl(host
->regbase
+ FMC_CFG
);
250 reg
&= ~(FMC_CFG_OP_MODE_MASK
| SPI_NOR_ADDR_MODE_MASK
);
251 reg
|= FMC_CFG_OP_MODE_NORMAL
;
252 reg
|= (nor
->addr_width
== 4) ? SPI_NOR_ADDR_MODE_4BYTES
253 : SPI_NOR_ADDR_MODE_3BYTES
;
254 writel(reg
, host
->regbase
+ FMC_CFG
);
256 writel(start_off
, host
->regbase
+ FMC_ADDRL
);
257 writel(dma_buf
, host
->regbase
+ FMC_DMA_SADDR_D0
);
258 writel(FMC_DMA_LEN_SET(len
), host
->regbase
+ FMC_DMA_LEN
);
260 reg
= OP_CFG_FM_CS(priv
->chipselect
);
261 if (op_type
== FMC_OP_READ
)
262 if_type
= get_if_type(nor
->read_proto
);
264 if_type
= get_if_type(nor
->write_proto
);
265 reg
|= OP_CFG_MEM_IF_TYPE(if_type
);
266 if (op_type
== FMC_OP_READ
)
267 reg
|= OP_CFG_DUMMY_NUM(nor
->read_dummy
>> 3);
268 writel(reg
, host
->regbase
+ FMC_OP_CFG
);
270 writel(0xff, host
->regbase
+ FMC_INT_CLR
);
271 reg
= OP_CTRL_RW_OP(op_type
) | OP_CTRL_DMA_OP_READY
;
272 reg
|= (op_type
== FMC_OP_READ
)
273 ? OP_CTRL_RD_OPCODE(nor
->read_opcode
)
274 : OP_CTRL_WR_OPCODE(nor
->program_opcode
);
275 writel(reg
, host
->regbase
+ FMC_OP_DMA
);
277 return wait_op_finish(host
);
280 static ssize_t
hisi_spi_nor_read(struct spi_nor
*nor
, loff_t from
, size_t len
,
283 struct hifmc_priv
*priv
= nor
->priv
;
284 struct hifmc_host
*host
= priv
->host
;
288 for (offset
= 0; offset
< len
; offset
+= HIFMC_DMA_MAX_LEN
) {
289 size_t trans
= min_t(size_t, HIFMC_DMA_MAX_LEN
, len
- offset
);
291 ret
= hisi_spi_nor_dma_transfer(nor
,
292 from
+ offset
, host
->dma_buffer
, trans
, FMC_OP_READ
);
294 dev_warn(nor
->dev
, "DMA read timeout\n");
297 memcpy(read_buf
+ offset
, host
->buffer
, trans
);
303 static ssize_t
hisi_spi_nor_write(struct spi_nor
*nor
, loff_t to
,
304 size_t len
, const u_char
*write_buf
)
306 struct hifmc_priv
*priv
= nor
->priv
;
307 struct hifmc_host
*host
= priv
->host
;
311 for (offset
= 0; offset
< len
; offset
+= HIFMC_DMA_MAX_LEN
) {
312 size_t trans
= min_t(size_t, HIFMC_DMA_MAX_LEN
, len
- offset
);
314 memcpy(host
->buffer
, write_buf
+ offset
, trans
);
315 ret
= hisi_spi_nor_dma_transfer(nor
,
316 to
+ offset
, host
->dma_buffer
, trans
, FMC_OP_WRITE
);
318 dev_warn(nor
->dev
, "DMA write timeout\n");
327 * Get spi flash device information and register it as a mtd device.
329 static int hisi_spi_nor_register(struct device_node
*np
,
330 struct hifmc_host
*host
)
332 const struct spi_nor_hwcaps hwcaps
= {
333 .mask
= SNOR_HWCAPS_READ
|
334 SNOR_HWCAPS_READ_FAST
|
335 SNOR_HWCAPS_READ_1_1_2
|
336 SNOR_HWCAPS_READ_1_1_4
|
339 struct device
*dev
= host
->dev
;
341 struct hifmc_priv
*priv
;
342 struct mtd_info
*mtd
;
345 nor
= devm_kzalloc(dev
, sizeof(*nor
), GFP_KERNEL
);
350 spi_nor_set_flash_node(nor
, np
);
352 priv
= devm_kzalloc(dev
, sizeof(*priv
), GFP_KERNEL
);
356 ret
= of_property_read_u32(np
, "reg", &priv
->chipselect
);
358 dev_err(dev
, "There's no reg property for %s\n",
363 ret
= of_property_read_u32(np
, "spi-max-frequency",
366 dev_err(dev
, "There's no spi-max-frequency property for %s\n",
373 nor
->prepare
= hisi_spi_nor_prep
;
374 nor
->unprepare
= hisi_spi_nor_unprep
;
375 nor
->read_reg
= hisi_spi_nor_read_reg
;
376 nor
->write_reg
= hisi_spi_nor_write_reg
;
377 nor
->read
= hisi_spi_nor_read
;
378 nor
->write
= hisi_spi_nor_write
;
380 ret
= spi_nor_scan(nor
, NULL
, &hwcaps
);
385 mtd
->name
= np
->name
;
386 ret
= mtd_device_register(mtd
, NULL
, 0);
390 host
->nor
[host
->num_chip
] = nor
;
395 static void hisi_spi_nor_unregister_all(struct hifmc_host
*host
)
399 for (i
= 0; i
< host
->num_chip
; i
++)
400 mtd_device_unregister(&host
->nor
[i
]->mtd
);
403 static int hisi_spi_nor_register_all(struct hifmc_host
*host
)
405 struct device
*dev
= host
->dev
;
406 struct device_node
*np
;
409 for_each_available_child_of_node(dev
->of_node
, np
) {
410 ret
= hisi_spi_nor_register(np
, host
);
414 if (host
->num_chip
== HIFMC_MAX_CHIP_NUM
) {
415 dev_warn(dev
, "Flash device number exceeds the maximum chipselect number\n");
423 hisi_spi_nor_unregister_all(host
);
427 static int hisi_spi_nor_probe(struct platform_device
*pdev
)
429 struct device
*dev
= &pdev
->dev
;
430 struct resource
*res
;
431 struct hifmc_host
*host
;
434 host
= devm_kzalloc(dev
, sizeof(*host
), GFP_KERNEL
);
438 platform_set_drvdata(pdev
, host
);
441 res
= platform_get_resource_byname(pdev
, IORESOURCE_MEM
, "control");
442 host
->regbase
= devm_ioremap_resource(dev
, res
);
443 if (IS_ERR(host
->regbase
))
444 return PTR_ERR(host
->regbase
);
446 res
= platform_get_resource_byname(pdev
, IORESOURCE_MEM
, "memory");
447 host
->iobase
= devm_ioremap_resource(dev
, res
);
448 if (IS_ERR(host
->iobase
))
449 return PTR_ERR(host
->iobase
);
451 host
->clk
= devm_clk_get(dev
, NULL
);
452 if (IS_ERR(host
->clk
))
453 return PTR_ERR(host
->clk
);
455 ret
= dma_set_mask_and_coherent(dev
, DMA_BIT_MASK(32));
457 dev_warn(dev
, "Unable to set dma mask\n");
461 host
->buffer
= dmam_alloc_coherent(dev
, HIFMC_DMA_MAX_LEN
,
462 &host
->dma_buffer
, GFP_KERNEL
);
466 ret
= clk_prepare_enable(host
->clk
);
470 mutex_init(&host
->lock
);
471 hisi_spi_nor_init(host
);
472 ret
= hisi_spi_nor_register_all(host
);
474 mutex_destroy(&host
->lock
);
476 clk_disable_unprepare(host
->clk
);
480 static int hisi_spi_nor_remove(struct platform_device
*pdev
)
482 struct hifmc_host
*host
= platform_get_drvdata(pdev
);
484 hisi_spi_nor_unregister_all(host
);
485 mutex_destroy(&host
->lock
);
486 clk_disable_unprepare(host
->clk
);
490 static const struct of_device_id hisi_spi_nor_dt_ids
[] = {
491 { .compatible
= "hisilicon,fmc-spi-nor"},
494 MODULE_DEVICE_TABLE(of
, hisi_spi_nor_dt_ids
);
496 static struct platform_driver hisi_spi_nor_driver
= {
499 .of_match_table
= hisi_spi_nor_dt_ids
,
501 .probe
= hisi_spi_nor_probe
,
502 .remove
= hisi_spi_nor_remove
,
504 module_platform_driver(hisi_spi_nor_driver
);
506 MODULE_LICENSE("GPL v2");
507 MODULE_DESCRIPTION("HiSilicon SPI Nor Flash Controller Driver");