RISCV: config: tizen_visionfive2: Disable JH7110 crypto driver
[platform/kernel/linux-starfive.git] / drivers / spi / spi-intel.c
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Intel PCH/PCU SPI flash driver.
4  *
5  * Copyright (C) 2016 - 2022, Intel Corporation
6  * Author: Mika Westerberg <mika.westerberg@linux.intel.com>
7  */
8
9 #include <linux/iopoll.h>
10 #include <linux/module.h>
11
12 #include <linux/mtd/partitions.h>
13 #include <linux/mtd/spi-nor.h>
14
15 #include <linux/spi/flash.h>
16 #include <linux/spi/spi.h>
17 #include <linux/spi/spi-mem.h>
18
19 #include "spi-intel.h"
20
21 /* Offsets are from @ispi->base */
22 #define BFPREG                          0x00
23
24 #define HSFSTS_CTL                      0x04
25 #define HSFSTS_CTL_FSMIE                BIT(31)
26 #define HSFSTS_CTL_FDBC_SHIFT           24
27 #define HSFSTS_CTL_FDBC_MASK            (0x3f << HSFSTS_CTL_FDBC_SHIFT)
28
29 #define HSFSTS_CTL_FCYCLE_SHIFT         17
30 #define HSFSTS_CTL_FCYCLE_MASK          (0x0f << HSFSTS_CTL_FCYCLE_SHIFT)
31 /* HW sequencer opcodes */
32 #define HSFSTS_CTL_FCYCLE_READ          (0x00 << HSFSTS_CTL_FCYCLE_SHIFT)
33 #define HSFSTS_CTL_FCYCLE_WRITE         (0x02 << HSFSTS_CTL_FCYCLE_SHIFT)
34 #define HSFSTS_CTL_FCYCLE_ERASE         (0x03 << HSFSTS_CTL_FCYCLE_SHIFT)
35 #define HSFSTS_CTL_FCYCLE_ERASE_64K     (0x04 << HSFSTS_CTL_FCYCLE_SHIFT)
36 #define HSFSTS_CTL_FCYCLE_RDSFDP        (0x05 << HSFSTS_CTL_FCYCLE_SHIFT)
37 #define HSFSTS_CTL_FCYCLE_RDID          (0x06 << HSFSTS_CTL_FCYCLE_SHIFT)
38 #define HSFSTS_CTL_FCYCLE_WRSR          (0x07 << HSFSTS_CTL_FCYCLE_SHIFT)
39 #define HSFSTS_CTL_FCYCLE_RDSR          (0x08 << HSFSTS_CTL_FCYCLE_SHIFT)
40
41 #define HSFSTS_CTL_FGO                  BIT(16)
42 #define HSFSTS_CTL_FLOCKDN              BIT(15)
43 #define HSFSTS_CTL_FDV                  BIT(14)
44 #define HSFSTS_CTL_SCIP                 BIT(5)
45 #define HSFSTS_CTL_AEL                  BIT(2)
46 #define HSFSTS_CTL_FCERR                BIT(1)
47 #define HSFSTS_CTL_FDONE                BIT(0)
48
49 #define FADDR                           0x08
50 #define DLOCK                           0x0c
51 #define FDATA(n)                        (0x10 + ((n) * 4))
52
53 #define FRACC                           0x50
54
55 #define FREG(n)                         (0x54 + ((n) * 4))
56 #define FREG_BASE_MASK                  GENMASK(14, 0)
57 #define FREG_LIMIT_SHIFT                16
58 #define FREG_LIMIT_MASK                 GENMASK(30, 16)
59
60 /* Offset is from @ispi->pregs */
61 #define PR(n)                           ((n) * 4)
62 #define PR_WPE                          BIT(31)
63 #define PR_LIMIT_SHIFT                  16
64 #define PR_LIMIT_MASK                   GENMASK(30, 16)
65 #define PR_RPE                          BIT(15)
66 #define PR_BASE_MASK                    GENMASK(14, 0)
67
68 /* Offsets are from @ispi->sregs */
69 #define SSFSTS_CTL                      0x00
70 #define SSFSTS_CTL_FSMIE                BIT(23)
71 #define SSFSTS_CTL_DS                   BIT(22)
72 #define SSFSTS_CTL_DBC_SHIFT            16
73 #define SSFSTS_CTL_SPOP                 BIT(11)
74 #define SSFSTS_CTL_ACS                  BIT(10)
75 #define SSFSTS_CTL_SCGO                 BIT(9)
76 #define SSFSTS_CTL_COP_SHIFT            12
77 #define SSFSTS_CTL_FRS                  BIT(7)
78 #define SSFSTS_CTL_DOFRS                BIT(6)
79 #define SSFSTS_CTL_AEL                  BIT(4)
80 #define SSFSTS_CTL_FCERR                BIT(3)
81 #define SSFSTS_CTL_FDONE                BIT(2)
82 #define SSFSTS_CTL_SCIP                 BIT(0)
83
84 #define PREOP_OPTYPE                    0x04
85 #define OPMENU0                         0x08
86 #define OPMENU1                         0x0c
87
88 #define OPTYPE_READ_NO_ADDR             0
89 #define OPTYPE_WRITE_NO_ADDR            1
90 #define OPTYPE_READ_WITH_ADDR           2
91 #define OPTYPE_WRITE_WITH_ADDR          3
92
93 /* CPU specifics */
94 #define BYT_PR                          0x74
95 #define BYT_SSFSTS_CTL                  0x90
96 #define BYT_FREG_NUM                    5
97 #define BYT_PR_NUM                      5
98
99 #define LPT_PR                          0x74
100 #define LPT_SSFSTS_CTL                  0x90
101 #define LPT_FREG_NUM                    5
102 #define LPT_PR_NUM                      5
103
104 #define BXT_PR                          0x84
105 #define BXT_SSFSTS_CTL                  0xa0
106 #define BXT_FREG_NUM                    12
107 #define BXT_PR_NUM                      5
108
109 #define CNL_PR                          0x84
110 #define CNL_FREG_NUM                    6
111 #define CNL_PR_NUM                      5
112
113 #define LVSCC                           0xc4
114 #define UVSCC                           0xc8
115 #define ERASE_OPCODE_SHIFT              8
116 #define ERASE_OPCODE_MASK               (0xff << ERASE_OPCODE_SHIFT)
117 #define ERASE_64K_OPCODE_SHIFT          16
118 #define ERASE_64K_OPCODE_MASK           (0xff << ERASE_64K_OPCODE_SHIFT)
119
120 /* Flash descriptor fields */
121 #define FLVALSIG_MAGIC                  0x0ff0a55a
122 #define FLMAP0_NC_MASK                  GENMASK(9, 8)
123 #define FLMAP0_NC_SHIFT                 8
124 #define FLMAP0_FCBA_MASK                GENMASK(7, 0)
125
126 #define FLCOMP_C0DEN_MASK               GENMASK(3, 0)
127 #define FLCOMP_C0DEN_512K               0x00
128 #define FLCOMP_C0DEN_1M                 0x01
129 #define FLCOMP_C0DEN_2M                 0x02
130 #define FLCOMP_C0DEN_4M                 0x03
131 #define FLCOMP_C0DEN_8M                 0x04
132 #define FLCOMP_C0DEN_16M                0x05
133 #define FLCOMP_C0DEN_32M                0x06
134 #define FLCOMP_C0DEN_64M                0x07
135
136 #define INTEL_SPI_TIMEOUT               5000 /* ms */
137 #define INTEL_SPI_FIFO_SZ               64
138
139 /**
140  * struct intel_spi - Driver private data
141  * @dev: Device pointer
142  * @info: Pointer to board specific info
143  * @base: Beginning of MMIO space
144  * @pregs: Start of protection registers
145  * @sregs: Start of software sequencer registers
146  * @host: Pointer to the SPI controller structure
147  * @nregions: Maximum number of regions
148  * @pr_num: Maximum number of protected range registers
149  * @chip0_size: Size of the first flash chip in bytes
150  * @locked: Is SPI setting locked
151  * @swseq_reg: Use SW sequencer in register reads/writes
152  * @swseq_erase: Use SW sequencer in erase operation
153  * @atomic_preopcode: Holds preopcode when atomic sequence is requested
154  * @opcodes: Opcodes which are supported. This are programmed by BIOS
155  *           before it locks down the controller.
156  * @mem_ops: Pointer to SPI MEM ops supported by the controller
157  */
158 struct intel_spi {
159         struct device *dev;
160         const struct intel_spi_boardinfo *info;
161         void __iomem *base;
162         void __iomem *pregs;
163         void __iomem *sregs;
164         struct spi_controller *host;
165         size_t nregions;
166         size_t pr_num;
167         size_t chip0_size;
168         bool locked;
169         bool swseq_reg;
170         bool swseq_erase;
171         u8 atomic_preopcode;
172         u8 opcodes[8];
173         const struct intel_spi_mem_op *mem_ops;
174 };
175
176 struct intel_spi_mem_op {
177         struct spi_mem_op mem_op;
178         u32 replacement_op;
179         int (*exec_op)(struct intel_spi *ispi,
180                        const struct spi_mem *mem,
181                        const struct intel_spi_mem_op *iop,
182                        const struct spi_mem_op *op);
183 };
184
185 static bool writeable;
186 module_param(writeable, bool, 0);
187 MODULE_PARM_DESC(writeable, "Enable write access to SPI flash chip (default=0)");
188
189 static void intel_spi_dump_regs(struct intel_spi *ispi)
190 {
191         u32 value;
192         int i;
193
194         dev_dbg(ispi->dev, "BFPREG=0x%08x\n", readl(ispi->base + BFPREG));
195
196         value = readl(ispi->base + HSFSTS_CTL);
197         dev_dbg(ispi->dev, "HSFSTS_CTL=0x%08x\n", value);
198         if (value & HSFSTS_CTL_FLOCKDN)
199                 dev_dbg(ispi->dev, "-> Locked\n");
200
201         dev_dbg(ispi->dev, "FADDR=0x%08x\n", readl(ispi->base + FADDR));
202         dev_dbg(ispi->dev, "DLOCK=0x%08x\n", readl(ispi->base + DLOCK));
203
204         for (i = 0; i < 16; i++)
205                 dev_dbg(ispi->dev, "FDATA(%d)=0x%08x\n",
206                         i, readl(ispi->base + FDATA(i)));
207
208         dev_dbg(ispi->dev, "FRACC=0x%08x\n", readl(ispi->base + FRACC));
209
210         for (i = 0; i < ispi->nregions; i++)
211                 dev_dbg(ispi->dev, "FREG(%d)=0x%08x\n", i,
212                         readl(ispi->base + FREG(i)));
213         for (i = 0; i < ispi->pr_num; i++)
214                 dev_dbg(ispi->dev, "PR(%d)=0x%08x\n", i,
215                         readl(ispi->pregs + PR(i)));
216
217         if (ispi->sregs) {
218                 value = readl(ispi->sregs + SSFSTS_CTL);
219                 dev_dbg(ispi->dev, "SSFSTS_CTL=0x%08x\n", value);
220                 dev_dbg(ispi->dev, "PREOP_OPTYPE=0x%08x\n",
221                         readl(ispi->sregs + PREOP_OPTYPE));
222                 dev_dbg(ispi->dev, "OPMENU0=0x%08x\n",
223                         readl(ispi->sregs + OPMENU0));
224                 dev_dbg(ispi->dev, "OPMENU1=0x%08x\n",
225                         readl(ispi->sregs + OPMENU1));
226         }
227
228         dev_dbg(ispi->dev, "LVSCC=0x%08x\n", readl(ispi->base + LVSCC));
229         dev_dbg(ispi->dev, "UVSCC=0x%08x\n", readl(ispi->base + UVSCC));
230
231         dev_dbg(ispi->dev, "Protected regions:\n");
232         for (i = 0; i < ispi->pr_num; i++) {
233                 u32 base, limit;
234
235                 value = readl(ispi->pregs + PR(i));
236                 if (!(value & (PR_WPE | PR_RPE)))
237                         continue;
238
239                 limit = (value & PR_LIMIT_MASK) >> PR_LIMIT_SHIFT;
240                 base = value & PR_BASE_MASK;
241
242                 dev_dbg(ispi->dev, " %02d base: 0x%08x limit: 0x%08x [%c%c]\n",
243                         i, base << 12, (limit << 12) | 0xfff,
244                         value & PR_WPE ? 'W' : '.', value & PR_RPE ? 'R' : '.');
245         }
246
247         dev_dbg(ispi->dev, "Flash regions:\n");
248         for (i = 0; i < ispi->nregions; i++) {
249                 u32 region, base, limit;
250
251                 region = readl(ispi->base + FREG(i));
252                 base = region & FREG_BASE_MASK;
253                 limit = (region & FREG_LIMIT_MASK) >> FREG_LIMIT_SHIFT;
254
255                 if (base >= limit || (i > 0 && limit == 0))
256                         dev_dbg(ispi->dev, " %02d disabled\n", i);
257                 else
258                         dev_dbg(ispi->dev, " %02d base: 0x%08x limit: 0x%08x\n",
259                                 i, base << 12, (limit << 12) | 0xfff);
260         }
261
262         dev_dbg(ispi->dev, "Using %cW sequencer for register access\n",
263                 ispi->swseq_reg ? 'S' : 'H');
264         dev_dbg(ispi->dev, "Using %cW sequencer for erase operation\n",
265                 ispi->swseq_erase ? 'S' : 'H');
266 }
267
268 /* Reads max INTEL_SPI_FIFO_SZ bytes from the device fifo */
269 static int intel_spi_read_block(struct intel_spi *ispi, void *buf, size_t size)
270 {
271         size_t bytes;
272         int i = 0;
273
274         if (size > INTEL_SPI_FIFO_SZ)
275                 return -EINVAL;
276
277         while (size > 0) {
278                 bytes = min_t(size_t, size, 4);
279                 memcpy_fromio(buf, ispi->base + FDATA(i), bytes);
280                 size -= bytes;
281                 buf += bytes;
282                 i++;
283         }
284
285         return 0;
286 }
287
288 /* Writes max INTEL_SPI_FIFO_SZ bytes to the device fifo */
289 static int intel_spi_write_block(struct intel_spi *ispi, const void *buf,
290                                  size_t size)
291 {
292         size_t bytes;
293         int i = 0;
294
295         if (size > INTEL_SPI_FIFO_SZ)
296                 return -EINVAL;
297
298         while (size > 0) {
299                 bytes = min_t(size_t, size, 4);
300                 memcpy_toio(ispi->base + FDATA(i), buf, bytes);
301                 size -= bytes;
302                 buf += bytes;
303                 i++;
304         }
305
306         return 0;
307 }
308
309 static int intel_spi_wait_hw_busy(struct intel_spi *ispi)
310 {
311         u32 val;
312
313         return readl_poll_timeout(ispi->base + HSFSTS_CTL, val,
314                                   !(val & HSFSTS_CTL_SCIP), 0,
315                                   INTEL_SPI_TIMEOUT * 1000);
316 }
317
318 static int intel_spi_wait_sw_busy(struct intel_spi *ispi)
319 {
320         u32 val;
321
322         return readl_poll_timeout(ispi->sregs + SSFSTS_CTL, val,
323                                   !(val & SSFSTS_CTL_SCIP), 0,
324                                   INTEL_SPI_TIMEOUT * 1000);
325 }
326
327 static bool intel_spi_set_writeable(struct intel_spi *ispi)
328 {
329         if (!ispi->info->set_writeable)
330                 return false;
331
332         return ispi->info->set_writeable(ispi->base, ispi->info->data);
333 }
334
335 static int intel_spi_opcode_index(struct intel_spi *ispi, u8 opcode, int optype)
336 {
337         int i;
338         int preop;
339
340         if (ispi->locked) {
341                 for (i = 0; i < ARRAY_SIZE(ispi->opcodes); i++)
342                         if (ispi->opcodes[i] == opcode)
343                                 return i;
344
345                 return -EINVAL;
346         }
347
348         /* The lock is off, so just use index 0 */
349         writel(opcode, ispi->sregs + OPMENU0);
350         preop = readw(ispi->sregs + PREOP_OPTYPE);
351         writel(optype << 16 | preop, ispi->sregs + PREOP_OPTYPE);
352
353         return 0;
354 }
355
356 static int intel_spi_hw_cycle(struct intel_spi *ispi,
357                               const struct intel_spi_mem_op *iop, size_t len)
358 {
359         u32 val, status;
360         int ret;
361
362         if (!iop->replacement_op)
363                 return -EINVAL;
364
365         val = readl(ispi->base + HSFSTS_CTL);
366         val &= ~(HSFSTS_CTL_FCYCLE_MASK | HSFSTS_CTL_FDBC_MASK);
367         val |= (len - 1) << HSFSTS_CTL_FDBC_SHIFT;
368         val |= HSFSTS_CTL_FCERR | HSFSTS_CTL_FDONE;
369         val |= HSFSTS_CTL_FGO;
370         val |= iop->replacement_op;
371         writel(val, ispi->base + HSFSTS_CTL);
372
373         ret = intel_spi_wait_hw_busy(ispi);
374         if (ret)
375                 return ret;
376
377         status = readl(ispi->base + HSFSTS_CTL);
378         if (status & HSFSTS_CTL_FCERR)
379                 return -EIO;
380         else if (status & HSFSTS_CTL_AEL)
381                 return -EACCES;
382
383         return 0;
384 }
385
386 static int intel_spi_sw_cycle(struct intel_spi *ispi, u8 opcode, size_t len,
387                               int optype)
388 {
389         u32 val = 0, status;
390         u8 atomic_preopcode;
391         int ret;
392
393         ret = intel_spi_opcode_index(ispi, opcode, optype);
394         if (ret < 0)
395                 return ret;
396
397         /*
398          * Always clear it after each SW sequencer operation regardless
399          * of whether it is successful or not.
400          */
401         atomic_preopcode = ispi->atomic_preopcode;
402         ispi->atomic_preopcode = 0;
403
404         /* Only mark 'Data Cycle' bit when there is data to be transferred */
405         if (len > 0)
406                 val = ((len - 1) << SSFSTS_CTL_DBC_SHIFT) | SSFSTS_CTL_DS;
407         val |= ret << SSFSTS_CTL_COP_SHIFT;
408         val |= SSFSTS_CTL_FCERR | SSFSTS_CTL_FDONE;
409         val |= SSFSTS_CTL_SCGO;
410         if (atomic_preopcode) {
411                 u16 preop;
412
413                 switch (optype) {
414                 case OPTYPE_WRITE_NO_ADDR:
415                 case OPTYPE_WRITE_WITH_ADDR:
416                         /* Pick matching preopcode for the atomic sequence */
417                         preop = readw(ispi->sregs + PREOP_OPTYPE);
418                         if ((preop & 0xff) == atomic_preopcode)
419                                 ; /* Do nothing */
420                         else if ((preop >> 8) == atomic_preopcode)
421                                 val |= SSFSTS_CTL_SPOP;
422                         else
423                                 return -EINVAL;
424
425                         /* Enable atomic sequence */
426                         val |= SSFSTS_CTL_ACS;
427                         break;
428
429                 default:
430                         return -EINVAL;
431                 }
432         }
433         writel(val, ispi->sregs + SSFSTS_CTL);
434
435         ret = intel_spi_wait_sw_busy(ispi);
436         if (ret)
437                 return ret;
438
439         status = readl(ispi->sregs + SSFSTS_CTL);
440         if (status & SSFSTS_CTL_FCERR)
441                 return -EIO;
442         else if (status & SSFSTS_CTL_AEL)
443                 return -EACCES;
444
445         return 0;
446 }
447
448 static u32 intel_spi_chip_addr(const struct intel_spi *ispi,
449                                const struct spi_mem *mem)
450 {
451         /* Pick up the correct start address */
452         if (!mem)
453                 return 0;
454         return (spi_get_chipselect(mem->spi, 0) == 1) ? ispi->chip0_size : 0;
455 }
456
457 static int intel_spi_read_reg(struct intel_spi *ispi, const struct spi_mem *mem,
458                               const struct intel_spi_mem_op *iop,
459                               const struct spi_mem_op *op)
460 {
461         u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
462         size_t nbytes = op->data.nbytes;
463         u8 opcode = op->cmd.opcode;
464         int ret;
465
466         writel(addr, ispi->base + FADDR);
467
468         if (ispi->swseq_reg)
469                 ret = intel_spi_sw_cycle(ispi, opcode, nbytes,
470                                          OPTYPE_READ_NO_ADDR);
471         else
472                 ret = intel_spi_hw_cycle(ispi, iop, nbytes);
473
474         if (ret)
475                 return ret;
476
477         return intel_spi_read_block(ispi, op->data.buf.in, nbytes);
478 }
479
480 static int intel_spi_write_reg(struct intel_spi *ispi, const struct spi_mem *mem,
481                                const struct intel_spi_mem_op *iop,
482                                const struct spi_mem_op *op)
483 {
484         u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
485         size_t nbytes = op->data.nbytes;
486         u8 opcode = op->cmd.opcode;
487         int ret;
488
489         /*
490          * This is handled with atomic operation and preop code in Intel
491          * controller so we only verify that it is available. If the
492          * controller is not locked, program the opcode to the PREOP
493          * register for later use.
494          *
495          * When hardware sequencer is used there is no need to program
496          * any opcodes (it handles them automatically as part of a command).
497          */
498         if (opcode == SPINOR_OP_WREN) {
499                 u16 preop;
500
501                 if (!ispi->swseq_reg)
502                         return 0;
503
504                 preop = readw(ispi->sregs + PREOP_OPTYPE);
505                 if ((preop & 0xff) != opcode && (preop >> 8) != opcode) {
506                         if (ispi->locked)
507                                 return -EINVAL;
508                         writel(opcode, ispi->sregs + PREOP_OPTYPE);
509                 }
510
511                 /*
512                  * This enables atomic sequence on next SW sycle. Will
513                  * be cleared after next operation.
514                  */
515                 ispi->atomic_preopcode = opcode;
516                 return 0;
517         }
518
519         /*
520          * We hope that HW sequencer will do the right thing automatically and
521          * with the SW sequencer we cannot use preopcode anyway, so just ignore
522          * the Write Disable operation and pretend it was completed
523          * successfully.
524          */
525         if (opcode == SPINOR_OP_WRDI)
526                 return 0;
527
528         writel(addr, ispi->base + FADDR);
529
530         /* Write the value beforehand */
531         ret = intel_spi_write_block(ispi, op->data.buf.out, nbytes);
532         if (ret)
533                 return ret;
534
535         if (ispi->swseq_reg)
536                 return intel_spi_sw_cycle(ispi, opcode, nbytes,
537                                           OPTYPE_WRITE_NO_ADDR);
538         return intel_spi_hw_cycle(ispi, iop, nbytes);
539 }
540
541 static int intel_spi_read(struct intel_spi *ispi, const struct spi_mem *mem,
542                           const struct intel_spi_mem_op *iop,
543                           const struct spi_mem_op *op)
544 {
545         u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
546         size_t block_size, nbytes = op->data.nbytes;
547         void *read_buf = op->data.buf.in;
548         u32 val, status;
549         int ret;
550
551         /*
552          * Atomic sequence is not expected with HW sequencer reads. Make
553          * sure it is cleared regardless.
554          */
555         if (WARN_ON_ONCE(ispi->atomic_preopcode))
556                 ispi->atomic_preopcode = 0;
557
558         while (nbytes > 0) {
559                 block_size = min_t(size_t, nbytes, INTEL_SPI_FIFO_SZ);
560
561                 /* Read cannot cross 4K boundary */
562                 block_size = min_t(loff_t, addr + block_size,
563                                    round_up(addr + 1, SZ_4K)) - addr;
564
565                 writel(addr, ispi->base + FADDR);
566
567                 val = readl(ispi->base + HSFSTS_CTL);
568                 val &= ~(HSFSTS_CTL_FDBC_MASK | HSFSTS_CTL_FCYCLE_MASK);
569                 val |= HSFSTS_CTL_AEL | HSFSTS_CTL_FCERR | HSFSTS_CTL_FDONE;
570                 val |= (block_size - 1) << HSFSTS_CTL_FDBC_SHIFT;
571                 val |= HSFSTS_CTL_FCYCLE_READ;
572                 val |= HSFSTS_CTL_FGO;
573                 writel(val, ispi->base + HSFSTS_CTL);
574
575                 ret = intel_spi_wait_hw_busy(ispi);
576                 if (ret)
577                         return ret;
578
579                 status = readl(ispi->base + HSFSTS_CTL);
580                 if (status & HSFSTS_CTL_FCERR)
581                         ret = -EIO;
582                 else if (status & HSFSTS_CTL_AEL)
583                         ret = -EACCES;
584
585                 if (ret < 0) {
586                         dev_err(ispi->dev, "read error: %x: %#x\n", addr, status);
587                         return ret;
588                 }
589
590                 ret = intel_spi_read_block(ispi, read_buf, block_size);
591                 if (ret)
592                         return ret;
593
594                 nbytes -= block_size;
595                 addr += block_size;
596                 read_buf += block_size;
597         }
598
599         return 0;
600 }
601
602 static int intel_spi_write(struct intel_spi *ispi, const struct spi_mem *mem,
603                            const struct intel_spi_mem_op *iop,
604                            const struct spi_mem_op *op)
605 {
606         u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
607         size_t block_size, nbytes = op->data.nbytes;
608         const void *write_buf = op->data.buf.out;
609         u32 val, status;
610         int ret;
611
612         /* Not needed with HW sequencer write, make sure it is cleared */
613         ispi->atomic_preopcode = 0;
614
615         while (nbytes > 0) {
616                 block_size = min_t(size_t, nbytes, INTEL_SPI_FIFO_SZ);
617
618                 /* Write cannot cross 4K boundary */
619                 block_size = min_t(loff_t, addr + block_size,
620                                    round_up(addr + 1, SZ_4K)) - addr;
621
622                 writel(addr, ispi->base + FADDR);
623
624                 val = readl(ispi->base + HSFSTS_CTL);
625                 val &= ~(HSFSTS_CTL_FDBC_MASK | HSFSTS_CTL_FCYCLE_MASK);
626                 val |= HSFSTS_CTL_AEL | HSFSTS_CTL_FCERR | HSFSTS_CTL_FDONE;
627                 val |= (block_size - 1) << HSFSTS_CTL_FDBC_SHIFT;
628                 val |= HSFSTS_CTL_FCYCLE_WRITE;
629
630                 ret = intel_spi_write_block(ispi, write_buf, block_size);
631                 if (ret) {
632                         dev_err(ispi->dev, "failed to write block\n");
633                         return ret;
634                 }
635
636                 /* Start the write now */
637                 val |= HSFSTS_CTL_FGO;
638                 writel(val, ispi->base + HSFSTS_CTL);
639
640                 ret = intel_spi_wait_hw_busy(ispi);
641                 if (ret) {
642                         dev_err(ispi->dev, "timeout\n");
643                         return ret;
644                 }
645
646                 status = readl(ispi->base + HSFSTS_CTL);
647                 if (status & HSFSTS_CTL_FCERR)
648                         ret = -EIO;
649                 else if (status & HSFSTS_CTL_AEL)
650                         ret = -EACCES;
651
652                 if (ret < 0) {
653                         dev_err(ispi->dev, "write error: %x: %#x\n", addr, status);
654                         return ret;
655                 }
656
657                 nbytes -= block_size;
658                 addr += block_size;
659                 write_buf += block_size;
660         }
661
662         return 0;
663 }
664
665 static int intel_spi_erase(struct intel_spi *ispi, const struct spi_mem *mem,
666                            const struct intel_spi_mem_op *iop,
667                            const struct spi_mem_op *op)
668 {
669         u32 addr = intel_spi_chip_addr(ispi, mem) + op->addr.val;
670         u8 opcode = op->cmd.opcode;
671         u32 val, status;
672         int ret;
673
674         writel(addr, ispi->base + FADDR);
675
676         if (ispi->swseq_erase)
677                 return intel_spi_sw_cycle(ispi, opcode, 0,
678                                           OPTYPE_WRITE_WITH_ADDR);
679
680         /* Not needed with HW sequencer erase, make sure it is cleared */
681         ispi->atomic_preopcode = 0;
682
683         val = readl(ispi->base + HSFSTS_CTL);
684         val &= ~(HSFSTS_CTL_FDBC_MASK | HSFSTS_CTL_FCYCLE_MASK);
685         val |= HSFSTS_CTL_AEL | HSFSTS_CTL_FCERR | HSFSTS_CTL_FDONE;
686         val |= HSFSTS_CTL_FGO;
687         val |= iop->replacement_op;
688         writel(val, ispi->base + HSFSTS_CTL);
689
690         ret = intel_spi_wait_hw_busy(ispi);
691         if (ret)
692                 return ret;
693
694         status = readl(ispi->base + HSFSTS_CTL);
695         if (status & HSFSTS_CTL_FCERR)
696                 return -EIO;
697         if (status & HSFSTS_CTL_AEL)
698                 return -EACCES;
699
700         return 0;
701 }
702
703 static int intel_spi_adjust_op_size(struct spi_mem *mem, struct spi_mem_op *op)
704 {
705         op->data.nbytes = clamp_val(op->data.nbytes, 0, INTEL_SPI_FIFO_SZ);
706         return 0;
707 }
708
709 static bool intel_spi_cmp_mem_op(const struct intel_spi_mem_op *iop,
710                                  const struct spi_mem_op *op)
711 {
712         if (iop->mem_op.cmd.nbytes != op->cmd.nbytes ||
713             iop->mem_op.cmd.buswidth != op->cmd.buswidth ||
714             iop->mem_op.cmd.dtr != op->cmd.dtr ||
715             iop->mem_op.cmd.opcode != op->cmd.opcode)
716                 return false;
717
718         if (iop->mem_op.addr.nbytes != op->addr.nbytes ||
719             iop->mem_op.addr.dtr != op->addr.dtr)
720                 return false;
721
722         if (iop->mem_op.data.dir != op->data.dir ||
723             iop->mem_op.data.dtr != op->data.dtr)
724                 return false;
725
726         if (iop->mem_op.data.dir != SPI_MEM_NO_DATA) {
727                 if (iop->mem_op.data.buswidth != op->data.buswidth)
728                         return false;
729         }
730
731         return true;
732 }
733
734 static const struct intel_spi_mem_op *
735 intel_spi_match_mem_op(struct intel_spi *ispi, const struct spi_mem_op *op)
736 {
737         const struct intel_spi_mem_op *iop;
738
739         for (iop = ispi->mem_ops; iop->mem_op.cmd.opcode; iop++) {
740                 if (intel_spi_cmp_mem_op(iop, op))
741                         break;
742         }
743
744         return iop->mem_op.cmd.opcode ? iop : NULL;
745 }
746
747 static bool intel_spi_supports_mem_op(struct spi_mem *mem,
748                                       const struct spi_mem_op *op)
749 {
750         struct intel_spi *ispi = spi_controller_get_devdata(mem->spi->controller);
751         const struct intel_spi_mem_op *iop;
752
753         iop = intel_spi_match_mem_op(ispi, op);
754         if (!iop) {
755                 dev_dbg(ispi->dev, "%#x not supported\n", op->cmd.opcode);
756                 return false;
757         }
758
759         /*
760          * For software sequencer check that the opcode is actually
761          * present in the opmenu if it is locked.
762          */
763         if (ispi->swseq_reg && ispi->locked) {
764                 int i;
765
766                 /* Check if it is in the locked opcodes list */
767                 for (i = 0; i < ARRAY_SIZE(ispi->opcodes); i++) {
768                         if (ispi->opcodes[i] == op->cmd.opcode)
769                                 return true;
770                 }
771
772                 dev_dbg(ispi->dev, "%#x not supported\n", op->cmd.opcode);
773                 return false;
774         }
775
776         return true;
777 }
778
779 static int intel_spi_exec_mem_op(struct spi_mem *mem, const struct spi_mem_op *op)
780 {
781         struct intel_spi *ispi = spi_controller_get_devdata(mem->spi->controller);
782         const struct intel_spi_mem_op *iop;
783
784         iop = intel_spi_match_mem_op(ispi, op);
785         if (!iop)
786                 return -EOPNOTSUPP;
787
788         return iop->exec_op(ispi, mem, iop, op);
789 }
790
791 static const char *intel_spi_get_name(struct spi_mem *mem)
792 {
793         const struct intel_spi *ispi = spi_controller_get_devdata(mem->spi->controller);
794
795         /*
796          * Return name of the flash controller device to be compatible
797          * with the MTD version.
798          */
799         return dev_name(ispi->dev);
800 }
801
802 static int intel_spi_dirmap_create(struct spi_mem_dirmap_desc *desc)
803 {
804         struct intel_spi *ispi = spi_controller_get_devdata(desc->mem->spi->controller);
805         const struct intel_spi_mem_op *iop;
806
807         iop = intel_spi_match_mem_op(ispi, &desc->info.op_tmpl);
808         if (!iop)
809                 return -EOPNOTSUPP;
810
811         desc->priv = (void *)iop;
812         return 0;
813 }
814
815 static ssize_t intel_spi_dirmap_read(struct spi_mem_dirmap_desc *desc, u64 offs,
816                                      size_t len, void *buf)
817 {
818         struct intel_spi *ispi = spi_controller_get_devdata(desc->mem->spi->controller);
819         const struct intel_spi_mem_op *iop = desc->priv;
820         struct spi_mem_op op = desc->info.op_tmpl;
821         int ret;
822
823         /* Fill in the gaps */
824         op.addr.val = offs;
825         op.data.nbytes = len;
826         op.data.buf.in = buf;
827
828         ret = iop->exec_op(ispi, desc->mem, iop, &op);
829         return ret ? ret : len;
830 }
831
832 static ssize_t intel_spi_dirmap_write(struct spi_mem_dirmap_desc *desc, u64 offs,
833                                       size_t len, const void *buf)
834 {
835         struct intel_spi *ispi = spi_controller_get_devdata(desc->mem->spi->controller);
836         const struct intel_spi_mem_op *iop = desc->priv;
837         struct spi_mem_op op = desc->info.op_tmpl;
838         int ret;
839
840         op.addr.val = offs;
841         op.data.nbytes = len;
842         op.data.buf.out = buf;
843
844         ret = iop->exec_op(ispi, desc->mem, iop, &op);
845         return ret ? ret : len;
846 }
847
848 static const struct spi_controller_mem_ops intel_spi_mem_ops = {
849         .adjust_op_size = intel_spi_adjust_op_size,
850         .supports_op = intel_spi_supports_mem_op,
851         .exec_op = intel_spi_exec_mem_op,
852         .get_name = intel_spi_get_name,
853         .dirmap_create = intel_spi_dirmap_create,
854         .dirmap_read = intel_spi_dirmap_read,
855         .dirmap_write = intel_spi_dirmap_write,
856 };
857
858 #define INTEL_SPI_OP_ADDR(__nbytes)                                     \
859         {                                                               \
860                 .nbytes = __nbytes,                                     \
861         }
862
863 #define INTEL_SPI_OP_NO_DATA                                            \
864         {                                                               \
865                 .dir = SPI_MEM_NO_DATA,                                 \
866         }
867
868 #define INTEL_SPI_OP_DATA_IN(__buswidth)                                \
869         {                                                               \
870                 .dir = SPI_MEM_DATA_IN,                                 \
871                 .buswidth = __buswidth,                                 \
872         }
873
874 #define INTEL_SPI_OP_DATA_OUT(__buswidth)                               \
875         {                                                               \
876                 .dir = SPI_MEM_DATA_OUT,                                \
877                 .buswidth = __buswidth,                                 \
878         }
879
880 #define INTEL_SPI_MEM_OP(__cmd, __addr, __data, __exec_op)              \
881         {                                                               \
882                 .mem_op = {                                             \
883                         .cmd = __cmd,                                   \
884                         .addr = __addr,                                 \
885                         .data = __data,                                 \
886                 },                                                      \
887                 .exec_op = __exec_op,                                   \
888         }
889
890 #define INTEL_SPI_MEM_OP_REPL(__cmd, __addr, __data, __exec_op, __repl) \
891         {                                                               \
892                 .mem_op = {                                             \
893                         .cmd = __cmd,                                   \
894                         .addr = __addr,                                 \
895                         .data = __data,                                 \
896                 },                                                      \
897                 .exec_op = __exec_op,                                   \
898                 .replacement_op = __repl,                               \
899         }
900
901 /*
902  * The controller handles pretty much everything internally based on the
903  * SFDP data but we want to make sure we only support the operations
904  * actually possible. Only check buswidth and transfer direction, the
905  * core validates data.
906  */
907 #define INTEL_SPI_GENERIC_OPS                                           \
908         /* Status register operations */                                \
909         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_RDID, 1),        \
910                               SPI_MEM_OP_NO_ADDR,                       \
911                               INTEL_SPI_OP_DATA_IN(1),                  \
912                               intel_spi_read_reg,                       \
913                               HSFSTS_CTL_FCYCLE_RDID),                  \
914         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_RDSR, 1),        \
915                               SPI_MEM_OP_NO_ADDR,                       \
916                               INTEL_SPI_OP_DATA_IN(1),                  \
917                               intel_spi_read_reg,                       \
918                               HSFSTS_CTL_FCYCLE_RDSR),                  \
919         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_WRSR, 1),        \
920                               SPI_MEM_OP_NO_ADDR,                       \
921                               INTEL_SPI_OP_DATA_OUT(1),                 \
922                               intel_spi_write_reg,                      \
923                               HSFSTS_CTL_FCYCLE_WRSR),                  \
924         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_RDSFDP, 1),      \
925                               INTEL_SPI_OP_ADDR(3),                     \
926                               INTEL_SPI_OP_DATA_IN(1),                  \
927                               intel_spi_read_reg,                       \
928                               HSFSTS_CTL_FCYCLE_RDSFDP),                \
929         /* Normal read */                                               \
930         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 1),             \
931                          INTEL_SPI_OP_ADDR(3),                          \
932                          INTEL_SPI_OP_DATA_IN(1),                       \
933                          intel_spi_read),                               \
934         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 1),             \
935                          INTEL_SPI_OP_ADDR(3),                          \
936                          INTEL_SPI_OP_DATA_IN(2),                       \
937                          intel_spi_read),                               \
938         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 1),             \
939                          INTEL_SPI_OP_ADDR(3),                          \
940                          INTEL_SPI_OP_DATA_IN(4),                       \
941                          intel_spi_read),                               \
942         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 1),             \
943                          INTEL_SPI_OP_ADDR(4),                          \
944                          INTEL_SPI_OP_DATA_IN(1),                       \
945                          intel_spi_read),                               \
946         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 1),             \
947                          INTEL_SPI_OP_ADDR(4),                          \
948                          INTEL_SPI_OP_DATA_IN(2),                       \
949                          intel_spi_read),                               \
950         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 1),             \
951                          INTEL_SPI_OP_ADDR(4),                          \
952                          INTEL_SPI_OP_DATA_IN(4),                       \
953                          intel_spi_read),                               \
954         /* Fast read */                                                 \
955         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST, 1),        \
956                          INTEL_SPI_OP_ADDR(3),                          \
957                          INTEL_SPI_OP_DATA_IN(1),                       \
958                          intel_spi_read),                               \
959         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST, 1),        \
960                          INTEL_SPI_OP_ADDR(3),                          \
961                          INTEL_SPI_OP_DATA_IN(2),                       \
962                          intel_spi_read),                               \
963         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST, 1),        \
964                          INTEL_SPI_OP_ADDR(3),                          \
965                          INTEL_SPI_OP_DATA_IN(4),                       \
966                          intel_spi_read),                               \
967         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST, 1),        \
968                          INTEL_SPI_OP_ADDR(4),                          \
969                          INTEL_SPI_OP_DATA_IN(1),                       \
970                          intel_spi_read),                               \
971         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST, 1),        \
972                          INTEL_SPI_OP_ADDR(4),                          \
973                          INTEL_SPI_OP_DATA_IN(2),                       \
974                          intel_spi_read),                               \
975         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST, 1),        \
976                          INTEL_SPI_OP_ADDR(4),                          \
977                          INTEL_SPI_OP_DATA_IN(4),                       \
978                          intel_spi_read),                               \
979         /* Read with 4-byte address opcode */                           \
980         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_4B, 1),          \
981                          INTEL_SPI_OP_ADDR(4),                          \
982                          INTEL_SPI_OP_DATA_IN(1),                       \
983                          intel_spi_read),                               \
984         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_4B, 1),          \
985                          INTEL_SPI_OP_ADDR(4),                          \
986                          INTEL_SPI_OP_DATA_IN(2),                       \
987                          intel_spi_read),                               \
988         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_4B, 1),          \
989                          INTEL_SPI_OP_ADDR(4),                          \
990                          INTEL_SPI_OP_DATA_IN(4),                       \
991                          intel_spi_read),                               \
992         /* Fast read with 4-byte address opcode */                      \
993         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST_4B, 1),     \
994                          INTEL_SPI_OP_ADDR(4),                          \
995                          INTEL_SPI_OP_DATA_IN(1),                       \
996                          intel_spi_read),                               \
997         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST_4B, 1),     \
998                          INTEL_SPI_OP_ADDR(4),                          \
999                          INTEL_SPI_OP_DATA_IN(2),                       \
1000                          intel_spi_read),                               \
1001         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ_FAST_4B, 1),     \
1002                          INTEL_SPI_OP_ADDR(4),                          \
1003                          INTEL_SPI_OP_DATA_IN(4),                       \
1004                          intel_spi_read),                               \
1005         /* Write operations */                                          \
1006         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_PP, 1),               \
1007                          INTEL_SPI_OP_ADDR(3),                          \
1008                          INTEL_SPI_OP_DATA_OUT(1),                      \
1009                          intel_spi_write),                              \
1010         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_PP, 1),               \
1011                          INTEL_SPI_OP_ADDR(4),                          \
1012                          INTEL_SPI_OP_DATA_OUT(1),                      \
1013                          intel_spi_write),                              \
1014         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_PP_4B, 1),            \
1015                          INTEL_SPI_OP_ADDR(4),                          \
1016                          INTEL_SPI_OP_DATA_OUT(1),                      \
1017                          intel_spi_write),                              \
1018         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_WREN, 1),             \
1019                          SPI_MEM_OP_NO_ADDR,                            \
1020                          SPI_MEM_OP_NO_DATA,                            \
1021                          intel_spi_write_reg),                          \
1022         INTEL_SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_WRDI, 1),             \
1023                          SPI_MEM_OP_NO_ADDR,                            \
1024                          SPI_MEM_OP_NO_DATA,                            \
1025                          intel_spi_write_reg),                          \
1026         /* Erase operations */                                          \
1027         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_BE_4K, 1),       \
1028                               INTEL_SPI_OP_ADDR(3),                     \
1029                               SPI_MEM_OP_NO_DATA,                       \
1030                               intel_spi_erase,                          \
1031                               HSFSTS_CTL_FCYCLE_ERASE),                 \
1032         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_BE_4K, 1),       \
1033                               INTEL_SPI_OP_ADDR(4),                     \
1034                               SPI_MEM_OP_NO_DATA,                       \
1035                               intel_spi_erase,                          \
1036                               HSFSTS_CTL_FCYCLE_ERASE),                 \
1037         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_BE_4K_4B, 1),    \
1038                               INTEL_SPI_OP_ADDR(4),                     \
1039                               SPI_MEM_OP_NO_DATA,                       \
1040                               intel_spi_erase,                          \
1041                               HSFSTS_CTL_FCYCLE_ERASE)                  \
1042
1043 static const struct intel_spi_mem_op generic_mem_ops[] = {
1044         INTEL_SPI_GENERIC_OPS,
1045         { },
1046 };
1047
1048 static const struct intel_spi_mem_op erase_64k_mem_ops[] = {
1049         INTEL_SPI_GENERIC_OPS,
1050         /* 64k sector erase operations */
1051         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_SE, 1),
1052                               INTEL_SPI_OP_ADDR(3),
1053                               SPI_MEM_OP_NO_DATA,
1054                               intel_spi_erase,
1055                               HSFSTS_CTL_FCYCLE_ERASE_64K),
1056         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_SE, 1),
1057                               INTEL_SPI_OP_ADDR(4),
1058                               SPI_MEM_OP_NO_DATA,
1059                               intel_spi_erase,
1060                               HSFSTS_CTL_FCYCLE_ERASE_64K),
1061         INTEL_SPI_MEM_OP_REPL(SPI_MEM_OP_CMD(SPINOR_OP_SE_4B, 1),
1062                               INTEL_SPI_OP_ADDR(4),
1063                               SPI_MEM_OP_NO_DATA,
1064                               intel_spi_erase,
1065                               HSFSTS_CTL_FCYCLE_ERASE_64K),
1066         { },
1067 };
1068
1069 static int intel_spi_init(struct intel_spi *ispi)
1070 {
1071         u32 opmenu0, opmenu1, lvscc, uvscc, val;
1072         bool erase_64k = false;
1073         int i;
1074
1075         switch (ispi->info->type) {
1076         case INTEL_SPI_BYT:
1077                 ispi->sregs = ispi->base + BYT_SSFSTS_CTL;
1078                 ispi->pregs = ispi->base + BYT_PR;
1079                 ispi->nregions = BYT_FREG_NUM;
1080                 ispi->pr_num = BYT_PR_NUM;
1081                 ispi->swseq_reg = true;
1082                 break;
1083
1084         case INTEL_SPI_LPT:
1085                 ispi->sregs = ispi->base + LPT_SSFSTS_CTL;
1086                 ispi->pregs = ispi->base + LPT_PR;
1087                 ispi->nregions = LPT_FREG_NUM;
1088                 ispi->pr_num = LPT_PR_NUM;
1089                 ispi->swseq_reg = true;
1090                 break;
1091
1092         case INTEL_SPI_BXT:
1093                 ispi->sregs = ispi->base + BXT_SSFSTS_CTL;
1094                 ispi->pregs = ispi->base + BXT_PR;
1095                 ispi->nregions = BXT_FREG_NUM;
1096                 ispi->pr_num = BXT_PR_NUM;
1097                 erase_64k = true;
1098                 break;
1099
1100         case INTEL_SPI_CNL:
1101                 ispi->sregs = NULL;
1102                 ispi->pregs = ispi->base + CNL_PR;
1103                 ispi->nregions = CNL_FREG_NUM;
1104                 ispi->pr_num = CNL_PR_NUM;
1105                 erase_64k = true;
1106                 break;
1107
1108         default:
1109                 return -EINVAL;
1110         }
1111
1112         /* Try to disable write protection if user asked to do so */
1113         if (writeable && !intel_spi_set_writeable(ispi)) {
1114                 dev_warn(ispi->dev, "can't disable chip write protection\n");
1115                 writeable = false;
1116         }
1117
1118         /* Disable #SMI generation from HW sequencer */
1119         val = readl(ispi->base + HSFSTS_CTL);
1120         val &= ~HSFSTS_CTL_FSMIE;
1121         writel(val, ispi->base + HSFSTS_CTL);
1122
1123         /*
1124          * Determine whether erase operation should use HW or SW sequencer.
1125          *
1126          * The HW sequencer has a predefined list of opcodes, with only the
1127          * erase opcode being programmable in LVSCC and UVSCC registers.
1128          * If these registers don't contain a valid erase opcode, erase
1129          * cannot be done using HW sequencer.
1130          */
1131         lvscc = readl(ispi->base + LVSCC);
1132         uvscc = readl(ispi->base + UVSCC);
1133         if (!(lvscc & ERASE_OPCODE_MASK) || !(uvscc & ERASE_OPCODE_MASK))
1134                 ispi->swseq_erase = true;
1135         /* SPI controller on Intel BXT supports 64K erase opcode */
1136         if (ispi->info->type == INTEL_SPI_BXT && !ispi->swseq_erase)
1137                 if (!(lvscc & ERASE_64K_OPCODE_MASK) ||
1138                     !(uvscc & ERASE_64K_OPCODE_MASK))
1139                         erase_64k = false;
1140
1141         if (!ispi->sregs && (ispi->swseq_reg || ispi->swseq_erase)) {
1142                 dev_err(ispi->dev, "software sequencer not supported, but required\n");
1143                 return -EINVAL;
1144         }
1145
1146         /*
1147          * Some controllers can only do basic operations using hardware
1148          * sequencer. All other operations are supposed to be carried out
1149          * using software sequencer.
1150          */
1151         if (ispi->swseq_reg) {
1152                 /* Disable #SMI generation from SW sequencer */
1153                 val = readl(ispi->sregs + SSFSTS_CTL);
1154                 val &= ~SSFSTS_CTL_FSMIE;
1155                 writel(val, ispi->sregs + SSFSTS_CTL);
1156         }
1157
1158         /* Check controller's lock status */
1159         val = readl(ispi->base + HSFSTS_CTL);
1160         ispi->locked = !!(val & HSFSTS_CTL_FLOCKDN);
1161
1162         if (ispi->locked && ispi->sregs) {
1163                 /*
1164                  * BIOS programs allowed opcodes and then locks down the
1165                  * register. So read back what opcodes it decided to support.
1166                  * That's the set we are going to support as well.
1167                  */
1168                 opmenu0 = readl(ispi->sregs + OPMENU0);
1169                 opmenu1 = readl(ispi->sregs + OPMENU1);
1170
1171                 if (opmenu0 && opmenu1) {
1172                         for (i = 0; i < ARRAY_SIZE(ispi->opcodes) / 2; i++) {
1173                                 ispi->opcodes[i] = opmenu0 >> i * 8;
1174                                 ispi->opcodes[i + 4] = opmenu1 >> i * 8;
1175                         }
1176                 }
1177         }
1178
1179         if (erase_64k) {
1180                 dev_dbg(ispi->dev, "Using erase_64k memory operations");
1181                 ispi->mem_ops = erase_64k_mem_ops;
1182         } else {
1183                 dev_dbg(ispi->dev, "Using generic memory operations");
1184                 ispi->mem_ops = generic_mem_ops;
1185         }
1186
1187         intel_spi_dump_regs(ispi);
1188         return 0;
1189 }
1190
1191 static bool intel_spi_is_protected(const struct intel_spi *ispi,
1192                                    unsigned int base, unsigned int limit)
1193 {
1194         int i;
1195
1196         for (i = 0; i < ispi->pr_num; i++) {
1197                 u32 pr_base, pr_limit, pr_value;
1198
1199                 pr_value = readl(ispi->pregs + PR(i));
1200                 if (!(pr_value & (PR_WPE | PR_RPE)))
1201                         continue;
1202
1203                 pr_limit = (pr_value & PR_LIMIT_MASK) >> PR_LIMIT_SHIFT;
1204                 pr_base = pr_value & PR_BASE_MASK;
1205
1206                 if (pr_base >= base && pr_limit <= limit)
1207                         return true;
1208         }
1209
1210         return false;
1211 }
1212
1213 /*
1214  * There will be a single partition holding all enabled flash regions. We
1215  * call this "BIOS".
1216  */
1217 static void intel_spi_fill_partition(struct intel_spi *ispi,
1218                                      struct mtd_partition *part)
1219 {
1220         u64 end;
1221         int i;
1222
1223         memset(part, 0, sizeof(*part));
1224
1225         /* Start from the mandatory descriptor region */
1226         part->size = 4096;
1227         part->name = "BIOS";
1228
1229         /*
1230          * Now try to find where this partition ends based on the flash
1231          * region registers.
1232          */
1233         for (i = 1; i < ispi->nregions; i++) {
1234                 u32 region, base, limit;
1235
1236                 region = readl(ispi->base + FREG(i));
1237                 base = region & FREG_BASE_MASK;
1238                 limit = (region & FREG_LIMIT_MASK) >> FREG_LIMIT_SHIFT;
1239
1240                 if (base >= limit || limit == 0)
1241                         continue;
1242
1243                 /*
1244                  * If any of the regions have protection bits set, make the
1245                  * whole partition read-only to be on the safe side.
1246                  *
1247                  * Also if the user did not ask the chip to be writeable
1248                  * mask the bit too.
1249                  */
1250                 if (!writeable || intel_spi_is_protected(ispi, base, limit))
1251                         part->mask_flags |= MTD_WRITEABLE;
1252
1253                 end = (limit << 12) + 4096;
1254                 if (end > part->size)
1255                         part->size = end;
1256         }
1257 }
1258
1259 static int intel_spi_read_desc(struct intel_spi *ispi)
1260 {
1261         struct spi_mem_op op =
1262                 SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_READ, 0),
1263                            SPI_MEM_OP_ADDR(3, 0, 0),
1264                            SPI_MEM_OP_NO_DUMMY,
1265                            SPI_MEM_OP_DATA_IN(0, NULL, 0));
1266         u32 buf[2], nc, fcba, flcomp;
1267         ssize_t ret;
1268
1269         op.addr.val = 0x10;
1270         op.data.buf.in = buf;
1271         op.data.nbytes = sizeof(buf);
1272
1273         ret = intel_spi_read(ispi, NULL, NULL, &op);
1274         if (ret) {
1275                 dev_warn(ispi->dev, "failed to read descriptor\n");
1276                 return ret;
1277         }
1278
1279         dev_dbg(ispi->dev, "FLVALSIG=0x%08x\n", buf[0]);
1280         dev_dbg(ispi->dev, "FLMAP0=0x%08x\n", buf[1]);
1281
1282         if (buf[0] != FLVALSIG_MAGIC) {
1283                 dev_warn(ispi->dev, "descriptor signature not valid\n");
1284                 return -ENODEV;
1285         }
1286
1287         fcba = (buf[1] & FLMAP0_FCBA_MASK) << 4;
1288         dev_dbg(ispi->dev, "FCBA=%#x\n", fcba);
1289
1290         op.addr.val = fcba;
1291         op.data.buf.in = &flcomp;
1292         op.data.nbytes = sizeof(flcomp);
1293
1294         ret = intel_spi_read(ispi, NULL, NULL, &op);
1295         if (ret) {
1296                 dev_warn(ispi->dev, "failed to read FLCOMP\n");
1297                 return -ENODEV;
1298         }
1299
1300         dev_dbg(ispi->dev, "FLCOMP=0x%08x\n", flcomp);
1301
1302         switch (flcomp & FLCOMP_C0DEN_MASK) {
1303         case FLCOMP_C0DEN_512K:
1304                 ispi->chip0_size = SZ_512K;
1305                 break;
1306         case FLCOMP_C0DEN_1M:
1307                 ispi->chip0_size = SZ_1M;
1308                 break;
1309         case FLCOMP_C0DEN_2M:
1310                 ispi->chip0_size = SZ_2M;
1311                 break;
1312         case FLCOMP_C0DEN_4M:
1313                 ispi->chip0_size = SZ_4M;
1314                 break;
1315         case FLCOMP_C0DEN_8M:
1316                 ispi->chip0_size = SZ_8M;
1317                 break;
1318         case FLCOMP_C0DEN_16M:
1319                 ispi->chip0_size = SZ_16M;
1320                 break;
1321         case FLCOMP_C0DEN_32M:
1322                 ispi->chip0_size = SZ_32M;
1323                 break;
1324         case FLCOMP_C0DEN_64M:
1325                 ispi->chip0_size = SZ_64M;
1326                 break;
1327         default:
1328                 return -EINVAL;
1329         }
1330
1331         dev_dbg(ispi->dev, "chip0 size %zd KB\n", ispi->chip0_size / SZ_1K);
1332
1333         nc = (buf[1] & FLMAP0_NC_MASK) >> FLMAP0_NC_SHIFT;
1334         if (!nc)
1335                 ispi->host->num_chipselect = 1;
1336         else if (nc == 1)
1337                 ispi->host->num_chipselect = 2;
1338         else
1339                 return -EINVAL;
1340
1341         dev_dbg(ispi->dev, "%u flash components found\n",
1342                 ispi->host->num_chipselect);
1343         return 0;
1344 }
1345
1346 static int intel_spi_populate_chip(struct intel_spi *ispi)
1347 {
1348         struct flash_platform_data *pdata;
1349         struct spi_board_info chip;
1350         int ret;
1351
1352         pdata = devm_kzalloc(ispi->dev, sizeof(*pdata), GFP_KERNEL);
1353         if (!pdata)
1354                 return -ENOMEM;
1355
1356         pdata->nr_parts = 1;
1357         pdata->parts = devm_kcalloc(ispi->dev, pdata->nr_parts,
1358                                     sizeof(*pdata->parts), GFP_KERNEL);
1359         if (!pdata->parts)
1360                 return -ENOMEM;
1361
1362         intel_spi_fill_partition(ispi, pdata->parts);
1363
1364         memset(&chip, 0, sizeof(chip));
1365         snprintf(chip.modalias, 8, "spi-nor");
1366         chip.platform_data = pdata;
1367
1368         if (!spi_new_device(ispi->host, &chip))
1369                 return -ENODEV;
1370
1371         ret = intel_spi_read_desc(ispi);
1372         if (ret)
1373                 return ret;
1374
1375         /* Add the second chip if present */
1376         if (ispi->host->num_chipselect < 2)
1377                 return 0;
1378
1379         chip.platform_data = NULL;
1380         chip.chip_select = 1;
1381
1382         if (!spi_new_device(ispi->host, &chip))
1383                 return -ENODEV;
1384         return 0;
1385 }
1386
1387 /**
1388  * intel_spi_probe() - Probe the Intel SPI flash controller
1389  * @dev: Pointer to the parent device
1390  * @mem: MMIO resource
1391  * @info: Platform specific information
1392  *
1393  * Probes Intel SPI flash controller and creates the flash chip device.
1394  * Returns %0 on success and negative errno in case of failure.
1395  */
1396 int intel_spi_probe(struct device *dev, struct resource *mem,
1397                     const struct intel_spi_boardinfo *info)
1398 {
1399         struct spi_controller *host;
1400         struct intel_spi *ispi;
1401         int ret;
1402
1403         host = devm_spi_alloc_host(dev, sizeof(*ispi));
1404         if (!host)
1405                 return -ENOMEM;
1406
1407         host->mem_ops = &intel_spi_mem_ops;
1408
1409         ispi = spi_controller_get_devdata(host);
1410
1411         ispi->base = devm_ioremap_resource(dev, mem);
1412         if (IS_ERR(ispi->base))
1413                 return PTR_ERR(ispi->base);
1414
1415         ispi->dev = dev;
1416         ispi->host = host;
1417         ispi->info = info;
1418
1419         ret = intel_spi_init(ispi);
1420         if (ret)
1421                 return ret;
1422
1423         ret = devm_spi_register_controller(dev, host);
1424         if (ret)
1425                 return ret;
1426
1427         return intel_spi_populate_chip(ispi);
1428 }
1429 EXPORT_SYMBOL_GPL(intel_spi_probe);
1430
1431 MODULE_DESCRIPTION("Intel PCH/PCU SPI flash core driver");
1432 MODULE_AUTHOR("Mika Westerberg <mika.westerberg@linux.intel.com>");
1433 MODULE_LICENSE("GPL v2");