Merge tag 'sound-6.6-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai...
[platform/kernel/linux-starfive.git] / drivers / spi / spi-loopback-test.c
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  *  linux/drivers/spi/spi-loopback-test.c
4  *
5  *  (c) Martin Sperl <kernel@martin.sperl.org>
6  *
7  *  Loopback test driver to test several typical spi_message conditions
8  *  that a spi_master driver may encounter
9  *  this can also get used for regression testing
10  */
11
12 #include <linux/delay.h>
13 #include <linux/kernel.h>
14 #include <linux/ktime.h>
15 #include <linux/list.h>
16 #include <linux/list_sort.h>
17 #include <linux/mod_devicetable.h>
18 #include <linux/module.h>
19 #include <linux/printk.h>
20 #include <linux/vmalloc.h>
21 #include <linux/spi/spi.h>
22
23 #include "spi-test.h"
24
25 /* flag to only simulate transfers */
26 static int simulate_only;
27 module_param(simulate_only, int, 0);
28 MODULE_PARM_DESC(simulate_only, "if not 0 do not execute the spi message");
29
30 /* dump spi messages */
31 static int dump_messages;
32 module_param(dump_messages, int, 0);
33 MODULE_PARM_DESC(dump_messages,
34                  "=1 dump the basic spi_message_structure, " \
35                  "=2 dump the spi_message_structure including data, " \
36                  "=3 dump the spi_message structure before and after execution");
37 /* the device is jumpered for loopback - enabling some rx_buf tests */
38 static int loopback;
39 module_param(loopback, int, 0);
40 MODULE_PARM_DESC(loopback,
41                  "if set enable loopback mode, where the rx_buf "       \
42                  "is checked to match tx_buf after the spi_message "    \
43                  "is executed");
44
45 static int loop_req;
46 module_param(loop_req, int, 0);
47 MODULE_PARM_DESC(loop_req,
48                  "if set controller will be asked to enable test loop mode. " \
49                  "If controller supported it, MISO and MOSI will be connected");
50
51 static int no_cs;
52 module_param(no_cs, int, 0);
53 MODULE_PARM_DESC(no_cs,
54                  "if set Chip Select (CS) will not be used");
55
56 /* run tests only for a specific length */
57 static int run_only_iter_len = -1;
58 module_param(run_only_iter_len, int, 0);
59 MODULE_PARM_DESC(run_only_iter_len,
60                  "only run tests for a length of this number in iterate_len list");
61
62 /* run only a specific test */
63 static int run_only_test = -1;
64 module_param(run_only_test, int, 0);
65 MODULE_PARM_DESC(run_only_test,
66                  "only run the test with this number (0-based !)");
67
68 /* use vmalloc'ed buffers */
69 static int use_vmalloc;
70 module_param(use_vmalloc, int, 0644);
71 MODULE_PARM_DESC(use_vmalloc,
72                  "use vmalloc'ed buffers instead of kmalloc'ed");
73
74 /* check rx ranges */
75 static int check_ranges = 1;
76 module_param(check_ranges, int, 0644);
77 MODULE_PARM_DESC(check_ranges,
78                  "checks rx_buffer pattern are valid");
79
80 static unsigned int delay_ms = 100;
81 module_param(delay_ms, uint, 0644);
82 MODULE_PARM_DESC(delay_ms,
83                  "delay between tests, in milliseconds (default: 100)");
84
85 /* the actual tests to execute */
86 static struct spi_test spi_tests[] = {
87         {
88                 .description    = "tx/rx-transfer - start of page",
89                 .fill_option    = FILL_COUNT_8,
90                 .iterate_len    = { ITERATE_MAX_LEN },
91                 .iterate_tx_align = ITERATE_ALIGN,
92                 .iterate_rx_align = ITERATE_ALIGN,
93                 .transfer_count = 1,
94                 .transfers              = {
95                         {
96                                 .tx_buf = TX(0),
97                                 .rx_buf = RX(0),
98                         },
99                 },
100         },
101         {
102                 .description    = "tx/rx-transfer - crossing PAGE_SIZE",
103                 .fill_option    = FILL_COUNT_8,
104                 .iterate_len    = { ITERATE_LEN },
105                 .iterate_tx_align = ITERATE_ALIGN,
106                 .iterate_rx_align = ITERATE_ALIGN,
107                 .transfer_count = 1,
108                 .transfers              = {
109                         {
110                                 .tx_buf = TX(PAGE_SIZE - 4),
111                                 .rx_buf = RX(PAGE_SIZE - 4),
112                         },
113                 },
114         },
115         {
116                 .description    = "tx-transfer - only",
117                 .fill_option    = FILL_COUNT_8,
118                 .iterate_len    = { ITERATE_MAX_LEN },
119                 .iterate_tx_align = ITERATE_ALIGN,
120                 .transfer_count = 1,
121                 .transfers              = {
122                         {
123                                 .tx_buf = TX(0),
124                         },
125                 },
126         },
127         {
128                 .description    = "rx-transfer - only",
129                 .fill_option    = FILL_COUNT_8,
130                 .iterate_len    = { ITERATE_MAX_LEN },
131                 .iterate_rx_align = ITERATE_ALIGN,
132                 .transfer_count = 1,
133                 .transfers              = {
134                         {
135                                 .rx_buf = RX(0),
136                         },
137                 },
138         },
139         {
140                 .description    = "two tx-transfers - alter both",
141                 .fill_option    = FILL_COUNT_8,
142                 .iterate_len    = { ITERATE_LEN },
143                 .iterate_tx_align = ITERATE_ALIGN,
144                 .iterate_transfer_mask = BIT(0) | BIT(1),
145                 .transfer_count = 2,
146                 .transfers              = {
147                         {
148                                 .tx_buf = TX(0),
149                         },
150                         {
151                                 /* this is why we cant use ITERATE_MAX_LEN */
152                                 .tx_buf = TX(SPI_TEST_MAX_SIZE_HALF),
153                         },
154                 },
155         },
156         {
157                 .description    = "two tx-transfers - alter first",
158                 .fill_option    = FILL_COUNT_8,
159                 .iterate_len    = { ITERATE_MAX_LEN },
160                 .iterate_tx_align = ITERATE_ALIGN,
161                 .iterate_transfer_mask = BIT(0),
162                 .transfer_count = 2,
163                 .transfers              = {
164                         {
165                                 .tx_buf = TX(64),
166                         },
167                         {
168                                 .len = 1,
169                                 .tx_buf = TX(0),
170                         },
171                 },
172         },
173         {
174                 .description    = "two tx-transfers - alter second",
175                 .fill_option    = FILL_COUNT_8,
176                 .iterate_len    = { ITERATE_MAX_LEN },
177                 .iterate_tx_align = ITERATE_ALIGN,
178                 .iterate_transfer_mask = BIT(1),
179                 .transfer_count = 2,
180                 .transfers              = {
181                         {
182                                 .len = 16,
183                                 .tx_buf = TX(0),
184                         },
185                         {
186                                 .tx_buf = TX(64),
187                         },
188                 },
189         },
190         {
191                 .description    = "two transfers tx then rx - alter both",
192                 .fill_option    = FILL_COUNT_8,
193                 .iterate_len    = { ITERATE_MAX_LEN },
194                 .iterate_tx_align = ITERATE_ALIGN,
195                 .iterate_transfer_mask = BIT(0) | BIT(1),
196                 .transfer_count = 2,
197                 .transfers              = {
198                         {
199                                 .tx_buf = TX(0),
200                         },
201                         {
202                                 .rx_buf = RX(0),
203                         },
204                 },
205         },
206         {
207                 .description    = "two transfers tx then rx - alter tx",
208                 .fill_option    = FILL_COUNT_8,
209                 .iterate_len    = { ITERATE_MAX_LEN },
210                 .iterate_tx_align = ITERATE_ALIGN,
211                 .iterate_transfer_mask = BIT(0),
212                 .transfer_count = 2,
213                 .transfers              = {
214                         {
215                                 .tx_buf = TX(0),
216                         },
217                         {
218                                 .len = 1,
219                                 .rx_buf = RX(0),
220                         },
221                 },
222         },
223         {
224                 .description    = "two transfers tx then rx - alter rx",
225                 .fill_option    = FILL_COUNT_8,
226                 .iterate_len    = { ITERATE_MAX_LEN },
227                 .iterate_tx_align = ITERATE_ALIGN,
228                 .iterate_transfer_mask = BIT(1),
229                 .transfer_count = 2,
230                 .transfers              = {
231                         {
232                                 .len = 1,
233                                 .tx_buf = TX(0),
234                         },
235                         {
236                                 .rx_buf = RX(0),
237                         },
238                 },
239         },
240         {
241                 .description    = "two tx+rx transfers - alter both",
242                 .fill_option    = FILL_COUNT_8,
243                 .iterate_len    = { ITERATE_LEN },
244                 .iterate_tx_align = ITERATE_ALIGN,
245                 .iterate_transfer_mask = BIT(0) | BIT(1),
246                 .transfer_count = 2,
247                 .transfers              = {
248                         {
249                                 .tx_buf = TX(0),
250                                 .rx_buf = RX(0),
251                         },
252                         {
253                                 /* making sure we align without overwrite
254                                  * the reason we can not use ITERATE_MAX_LEN
255                                  */
256                                 .tx_buf = TX(SPI_TEST_MAX_SIZE_HALF),
257                                 .rx_buf = RX(SPI_TEST_MAX_SIZE_HALF),
258                         },
259                 },
260         },
261         {
262                 .description    = "two tx+rx transfers - alter first",
263                 .fill_option    = FILL_COUNT_8,
264                 .iterate_len    = { ITERATE_MAX_LEN },
265                 .iterate_tx_align = ITERATE_ALIGN,
266                 .iterate_transfer_mask = BIT(0),
267                 .transfer_count = 2,
268                 .transfers              = {
269                         {
270                                 /* making sure we align without overwrite */
271                                 .tx_buf = TX(1024),
272                                 .rx_buf = RX(1024),
273                         },
274                         {
275                                 .len = 1,
276                                 /* making sure we align without overwrite */
277                                 .tx_buf = TX(0),
278                                 .rx_buf = RX(0),
279                         },
280                 },
281         },
282         {
283                 .description    = "two tx+rx transfers - alter second",
284                 .fill_option    = FILL_COUNT_8,
285                 .iterate_len    = { ITERATE_MAX_LEN },
286                 .iterate_tx_align = ITERATE_ALIGN,
287                 .iterate_transfer_mask = BIT(1),
288                 .transfer_count = 2,
289                 .transfers              = {
290                         {
291                                 .len = 1,
292                                 .tx_buf = TX(0),
293                                 .rx_buf = RX(0),
294                         },
295                         {
296                                 /* making sure we align without overwrite */
297                                 .tx_buf = TX(1024),
298                                 .rx_buf = RX(1024),
299                         },
300                 },
301         },
302         {
303                 .description    = "two tx+rx transfers - delay after transfer",
304                 .fill_option    = FILL_COUNT_8,
305                 .iterate_len    = { ITERATE_MAX_LEN },
306                 .iterate_transfer_mask = BIT(0) | BIT(1),
307                 .transfer_count = 2,
308                 .transfers              = {
309                         {
310                                 .tx_buf = TX(0),
311                                 .rx_buf = RX(0),
312                                 .delay = {
313                                         .value = 1000,
314                                         .unit = SPI_DELAY_UNIT_USECS,
315                                 },
316                         },
317                         {
318                                 .tx_buf = TX(0),
319                                 .rx_buf = RX(0),
320                                 .delay = {
321                                         .value = 1000,
322                                         .unit = SPI_DELAY_UNIT_USECS,
323                                 },
324                         },
325                 },
326         },
327         {
328                 .description    = "three tx+rx transfers with overlapping cache lines",
329                 .fill_option    = FILL_COUNT_8,
330                 /*
331                  * This should be large enough for the controller driver to
332                  * choose to transfer it with DMA.
333                  */
334                 .iterate_len    = { 512, -1 },
335                 .iterate_transfer_mask = BIT(1),
336                 .transfer_count = 3,
337                 .transfers              = {
338                         {
339                                 .len = 1,
340                                 .tx_buf = TX(0),
341                                 .rx_buf = RX(0),
342                         },
343                         {
344                                 .tx_buf = TX(1),
345                                 .rx_buf = RX(1),
346                         },
347                         {
348                                 .len = 1,
349                                 .tx_buf = TX(513),
350                                 .rx_buf = RX(513),
351                         },
352                 },
353         },
354
355         { /* end of tests sequence */ }
356 };
357
358 static int spi_loopback_test_probe(struct spi_device *spi)
359 {
360         int ret;
361
362         if (loop_req || no_cs) {
363                 spi->mode |= loop_req ? SPI_LOOP : 0;
364                 spi->mode |= no_cs ? SPI_NO_CS : 0;
365                 ret = spi_setup(spi);
366                 if (ret) {
367                         dev_err(&spi->dev, "SPI setup with SPI_LOOP or SPI_NO_CS failed (%d)\n",
368                                 ret);
369                         return ret;
370                 }
371         }
372
373         dev_info(&spi->dev, "Executing spi-loopback-tests\n");
374
375         ret = spi_test_run_tests(spi, spi_tests);
376
377         dev_info(&spi->dev, "Finished spi-loopback-tests with return: %i\n",
378                  ret);
379
380         return ret;
381 }
382
383 /* non const match table to permit to change via a module parameter */
384 static struct of_device_id spi_loopback_test_of_match[] = {
385         { .compatible   = "linux,spi-loopback-test", },
386         { }
387 };
388
389 /* allow to override the compatible string via a module_parameter */
390 module_param_string(compatible, spi_loopback_test_of_match[0].compatible,
391                     sizeof(spi_loopback_test_of_match[0].compatible),
392                     0000);
393
394 MODULE_DEVICE_TABLE(of, spi_loopback_test_of_match);
395
396 static struct spi_driver spi_loopback_test_driver = {
397         .driver = {
398                 .name = "spi-loopback-test",
399                 .owner = THIS_MODULE,
400                 .of_match_table = spi_loopback_test_of_match,
401         },
402         .probe = spi_loopback_test_probe,
403 };
404
405 module_spi_driver(spi_loopback_test_driver);
406
407 MODULE_AUTHOR("Martin Sperl <kernel@martin.sperl.org>");
408 MODULE_DESCRIPTION("test spi_driver to check core functionality");
409 MODULE_LICENSE("GPL");
410
411 /*-------------------------------------------------------------------------*/
412
413 /* spi_test implementation */
414
415 #define RANGE_CHECK(ptr, plen, start, slen) \
416         ((ptr >= start) && (ptr + plen <= start + slen))
417
418 /* we allocate one page more, to allow for offsets */
419 #define SPI_TEST_MAX_SIZE_PLUS (SPI_TEST_MAX_SIZE + PAGE_SIZE)
420
421 static void spi_test_print_hex_dump(char *pre, const void *ptr, size_t len)
422 {
423         /* limit the hex_dump */
424         if (len < 1024) {
425                 print_hex_dump(KERN_INFO, pre,
426                                DUMP_PREFIX_OFFSET, 16, 1,
427                                ptr, len, 0);
428                 return;
429         }
430         /* print head */
431         print_hex_dump(KERN_INFO, pre,
432                        DUMP_PREFIX_OFFSET, 16, 1,
433                        ptr, 512, 0);
434         /* print tail */
435         pr_info("%s truncated - continuing at offset %04zx\n",
436                 pre, len - 512);
437         print_hex_dump(KERN_INFO, pre,
438                        DUMP_PREFIX_OFFSET, 16, 1,
439                        ptr + (len - 512), 512, 0);
440 }
441
442 static void spi_test_dump_message(struct spi_device *spi,
443                                   struct spi_message *msg,
444                                   bool dump_data)
445 {
446         struct spi_transfer *xfer;
447         int i;
448         u8 b;
449
450         dev_info(&spi->dev, "  spi_msg@%pK\n", msg);
451         if (msg->status)
452                 dev_info(&spi->dev, "    status:        %i\n",
453                          msg->status);
454         dev_info(&spi->dev, "    frame_length:  %i\n",
455                  msg->frame_length);
456         dev_info(&spi->dev, "    actual_length: %i\n",
457                  msg->actual_length);
458
459         list_for_each_entry(xfer, &msg->transfers, transfer_list) {
460                 dev_info(&spi->dev, "    spi_transfer@%pK\n", xfer);
461                 dev_info(&spi->dev, "      len:    %i\n", xfer->len);
462                 dev_info(&spi->dev, "      tx_buf: %pK\n", xfer->tx_buf);
463                 if (dump_data && xfer->tx_buf)
464                         spi_test_print_hex_dump("          TX: ",
465                                                 xfer->tx_buf,
466                                                 xfer->len);
467
468                 dev_info(&spi->dev, "      rx_buf: %pK\n", xfer->rx_buf);
469                 if (dump_data && xfer->rx_buf)
470                         spi_test_print_hex_dump("          RX: ",
471                                                 xfer->rx_buf,
472                                                 xfer->len);
473                 /* check for unwritten test pattern on rx_buf */
474                 if (xfer->rx_buf) {
475                         for (i = 0 ; i < xfer->len ; i++) {
476                                 b = ((u8 *)xfer->rx_buf)[xfer->len - 1 - i];
477                                 if (b != SPI_TEST_PATTERN_UNWRITTEN)
478                                         break;
479                         }
480                         if (i)
481                                 dev_info(&spi->dev,
482                                          "      rx_buf filled with %02x starts at offset: %i\n",
483                                          SPI_TEST_PATTERN_UNWRITTEN,
484                                          xfer->len - i);
485                 }
486         }
487 }
488
489 struct rx_ranges {
490         struct list_head list;
491         u8 *start;
492         u8 *end;
493 };
494
495 static int rx_ranges_cmp(void *priv, const struct list_head *a,
496                          const struct list_head *b)
497 {
498         struct rx_ranges *rx_a = list_entry(a, struct rx_ranges, list);
499         struct rx_ranges *rx_b = list_entry(b, struct rx_ranges, list);
500
501         if (rx_a->start > rx_b->start)
502                 return 1;
503         if (rx_a->start < rx_b->start)
504                 return -1;
505         return 0;
506 }
507
508 static int spi_check_rx_ranges(struct spi_device *spi,
509                                struct spi_message *msg,
510                                void *rx)
511 {
512         struct spi_transfer *xfer;
513         struct rx_ranges ranges[SPI_TEST_MAX_TRANSFERS], *r;
514         int i = 0;
515         LIST_HEAD(ranges_list);
516         u8 *addr;
517         int ret = 0;
518
519         /* loop over all transfers to fill in the rx_ranges */
520         list_for_each_entry(xfer, &msg->transfers, transfer_list) {
521                 /* if there is no rx, then no check is needed */
522                 if (!xfer->rx_buf)
523                         continue;
524                 /* fill in the rx_range */
525                 if (RANGE_CHECK(xfer->rx_buf, xfer->len,
526                                 rx, SPI_TEST_MAX_SIZE_PLUS)) {
527                         ranges[i].start = xfer->rx_buf;
528                         ranges[i].end = xfer->rx_buf + xfer->len;
529                         list_add(&ranges[i].list, &ranges_list);
530                         i++;
531                 }
532         }
533
534         /* if no ranges, then we can return and avoid the checks...*/
535         if (!i)
536                 return 0;
537
538         /* sort the list */
539         list_sort(NULL, &ranges_list, rx_ranges_cmp);
540
541         /* and iterate over all the rx addresses */
542         for (addr = rx; addr < (u8 *)rx + SPI_TEST_MAX_SIZE_PLUS; addr++) {
543                 /* if we are the DO not write pattern,
544                  * then continue with the loop...
545                  */
546                 if (*addr == SPI_TEST_PATTERN_DO_NOT_WRITE)
547                         continue;
548
549                 /* check if we are inside a range */
550                 list_for_each_entry(r, &ranges_list, list) {
551                         /* if so then set to end... */
552                         if ((addr >= r->start) && (addr < r->end))
553                                 addr = r->end;
554                 }
555                 /* second test after a (hopefull) translation */
556                 if (*addr == SPI_TEST_PATTERN_DO_NOT_WRITE)
557                         continue;
558
559                 /* if still not found then something has modified too much */
560                 /* we could list the "closest" transfer here... */
561                 dev_err(&spi->dev,
562                         "loopback strangeness - rx changed outside of allowed range at: %pK\n",
563                         addr);
564                 /* do not return, only set ret,
565                  * so that we list all addresses
566                  */
567                 ret = -ERANGE;
568         }
569
570         return ret;
571 }
572
573 static int spi_test_check_elapsed_time(struct spi_device *spi,
574                                        struct spi_test *test)
575 {
576         int i;
577         unsigned long long estimated_time = 0;
578         unsigned long long delay_usecs = 0;
579
580         for (i = 0; i < test->transfer_count; i++) {
581                 struct spi_transfer *xfer = test->transfers + i;
582                 unsigned long long nbits = (unsigned long long)BITS_PER_BYTE *
583                                            xfer->len;
584
585                 delay_usecs += xfer->delay.value;
586                 if (!xfer->speed_hz)
587                         continue;
588                 estimated_time += div_u64(nbits * NSEC_PER_SEC, xfer->speed_hz);
589         }
590
591         estimated_time += delay_usecs * NSEC_PER_USEC;
592         if (test->elapsed_time < estimated_time) {
593                 dev_err(&spi->dev,
594                         "elapsed time %lld ns is shorter than minimum estimated time %lld ns\n",
595                         test->elapsed_time, estimated_time);
596
597                 return -EINVAL;
598         }
599
600         return 0;
601 }
602
603 static int spi_test_check_loopback_result(struct spi_device *spi,
604                                           struct spi_message *msg,
605                                           void *tx, void *rx)
606 {
607         struct spi_transfer *xfer;
608         u8 rxb, txb;
609         size_t i;
610         int ret;
611
612         /* checks rx_buffer pattern are valid with loopback or without */
613         if (check_ranges) {
614                 ret = spi_check_rx_ranges(spi, msg, rx);
615                 if (ret)
616                         return ret;
617         }
618
619         /* if we run without loopback, then return now */
620         if (!loopback)
621                 return 0;
622
623         /* if applicable to transfer check that rx_buf is equal to tx_buf */
624         list_for_each_entry(xfer, &msg->transfers, transfer_list) {
625                 /* if there is no rx, then no check is needed */
626                 if (!xfer->len || !xfer->rx_buf)
627                         continue;
628                 /* so depending on tx_buf we need to handle things */
629                 if (xfer->tx_buf) {
630                         for (i = 0; i < xfer->len; i++) {
631                                 txb = ((u8 *)xfer->tx_buf)[i];
632                                 rxb = ((u8 *)xfer->rx_buf)[i];
633                                 if (txb != rxb)
634                                         goto mismatch_error;
635                         }
636                 } else {
637                         /* first byte received */
638                         txb = ((u8 *)xfer->rx_buf)[0];
639                         /* first byte may be 0 or xff */
640                         if (!((txb == 0) || (txb == 0xff))) {
641                                 dev_err(&spi->dev,
642                                         "loopback strangeness - we expect 0x00 or 0xff, but not 0x%02x\n",
643                                         txb);
644                                 return -EINVAL;
645                         }
646                         /* check that all bytes are identical */
647                         for (i = 1; i < xfer->len; i++) {
648                                 rxb = ((u8 *)xfer->rx_buf)[i];
649                                 if (rxb != txb)
650                                         goto mismatch_error;
651                         }
652                 }
653         }
654
655         return 0;
656
657 mismatch_error:
658         dev_err(&spi->dev,
659                 "loopback strangeness - transfer mismatch on byte %04zx - expected 0x%02x, but got 0x%02x\n",
660                 i, txb, rxb);
661
662         return -EINVAL;
663 }
664
665 static int spi_test_translate(struct spi_device *spi,
666                               void **ptr, size_t len,
667                               void *tx, void *rx)
668 {
669         size_t off;
670
671         /* return on null */
672         if (!*ptr)
673                 return 0;
674
675         /* in the MAX_SIZE_HALF case modify the pointer */
676         if (((size_t)*ptr) & SPI_TEST_MAX_SIZE_HALF)
677                 /* move the pointer to the correct range */
678                 *ptr += (SPI_TEST_MAX_SIZE_PLUS / 2) -
679                         SPI_TEST_MAX_SIZE_HALF;
680
681         /* RX range
682          * - we check against MAX_SIZE_PLUS to allow for automated alignment
683          */
684         if (RANGE_CHECK(*ptr, len,  RX(0), SPI_TEST_MAX_SIZE_PLUS)) {
685                 off = *ptr - RX(0);
686                 *ptr = rx + off;
687
688                 return 0;
689         }
690
691         /* TX range */
692         if (RANGE_CHECK(*ptr, len,  TX(0), SPI_TEST_MAX_SIZE_PLUS)) {
693                 off = *ptr - TX(0);
694                 *ptr = tx + off;
695
696                 return 0;
697         }
698
699         dev_err(&spi->dev,
700                 "PointerRange [%pK:%pK[ not in range [%pK:%pK[ or [%pK:%pK[\n",
701                 *ptr, *ptr + len,
702                 RX(0), RX(SPI_TEST_MAX_SIZE),
703                 TX(0), TX(SPI_TEST_MAX_SIZE));
704
705         return -EINVAL;
706 }
707
708 static int spi_test_fill_pattern(struct spi_device *spi,
709                                  struct spi_test *test)
710 {
711         struct spi_transfer *xfers = test->transfers;
712         u8 *tx_buf;
713         size_t count = 0;
714         int i, j;
715
716 #ifdef __BIG_ENDIAN
717 #define GET_VALUE_BYTE(value, index, bytes) \
718         (value >> (8 * (bytes - 1 - count % bytes)))
719 #else
720 #define GET_VALUE_BYTE(value, index, bytes) \
721         (value >> (8 * (count % bytes)))
722 #endif
723
724         /* fill all transfers with the pattern requested */
725         for (i = 0; i < test->transfer_count; i++) {
726                 /* fill rx_buf with SPI_TEST_PATTERN_UNWRITTEN */
727                 if (xfers[i].rx_buf)
728                         memset(xfers[i].rx_buf, SPI_TEST_PATTERN_UNWRITTEN,
729                                xfers[i].len);
730                 /* if tx_buf is NULL then skip */
731                 tx_buf = (u8 *)xfers[i].tx_buf;
732                 if (!tx_buf)
733                         continue;
734                 /* modify all the transfers */
735                 for (j = 0; j < xfers[i].len; j++, tx_buf++, count++) {
736                         /* fill tx */
737                         switch (test->fill_option) {
738                         case FILL_MEMSET_8:
739                                 *tx_buf = test->fill_pattern;
740                                 break;
741                         case FILL_MEMSET_16:
742                                 *tx_buf = GET_VALUE_BYTE(test->fill_pattern,
743                                                          count, 2);
744                                 break;
745                         case FILL_MEMSET_24:
746                                 *tx_buf = GET_VALUE_BYTE(test->fill_pattern,
747                                                          count, 3);
748                                 break;
749                         case FILL_MEMSET_32:
750                                 *tx_buf = GET_VALUE_BYTE(test->fill_pattern,
751                                                          count, 4);
752                                 break;
753                         case FILL_COUNT_8:
754                                 *tx_buf = count;
755                                 break;
756                         case FILL_COUNT_16:
757                                 *tx_buf = GET_VALUE_BYTE(count, count, 2);
758                                 break;
759                         case FILL_COUNT_24:
760                                 *tx_buf = GET_VALUE_BYTE(count, count, 3);
761                                 break;
762                         case FILL_COUNT_32:
763                                 *tx_buf = GET_VALUE_BYTE(count, count, 4);
764                                 break;
765                         case FILL_TRANSFER_BYTE_8:
766                                 *tx_buf = j;
767                                 break;
768                         case FILL_TRANSFER_BYTE_16:
769                                 *tx_buf = GET_VALUE_BYTE(j, j, 2);
770                                 break;
771                         case FILL_TRANSFER_BYTE_24:
772                                 *tx_buf = GET_VALUE_BYTE(j, j, 3);
773                                 break;
774                         case FILL_TRANSFER_BYTE_32:
775                                 *tx_buf = GET_VALUE_BYTE(j, j, 4);
776                                 break;
777                         case FILL_TRANSFER_NUM:
778                                 *tx_buf = i;
779                                 break;
780                         default:
781                                 dev_err(&spi->dev,
782                                         "unsupported fill_option: %i\n",
783                                         test->fill_option);
784                                 return -EINVAL;
785                         }
786                 }
787         }
788
789         return 0;
790 }
791
792 static int _spi_test_run_iter(struct spi_device *spi,
793                               struct spi_test *test,
794                               void *tx, void *rx)
795 {
796         struct spi_message *msg = &test->msg;
797         struct spi_transfer *x;
798         int i, ret;
799
800         /* initialize message - zero-filled via static initialization */
801         spi_message_init_no_memset(msg);
802
803         /* fill rx with the DO_NOT_WRITE pattern */
804         memset(rx, SPI_TEST_PATTERN_DO_NOT_WRITE, SPI_TEST_MAX_SIZE_PLUS);
805
806         /* add the individual transfers */
807         for (i = 0; i < test->transfer_count; i++) {
808                 x = &test->transfers[i];
809
810                 /* patch the values of tx_buf */
811                 ret = spi_test_translate(spi, (void **)&x->tx_buf, x->len,
812                                          (void *)tx, rx);
813                 if (ret)
814                         return ret;
815
816                 /* patch the values of rx_buf */
817                 ret = spi_test_translate(spi, &x->rx_buf, x->len,
818                                          (void *)tx, rx);
819                 if (ret)
820                         return ret;
821
822                 /* and add it to the list */
823                 spi_message_add_tail(x, msg);
824         }
825
826         /* fill in the transfer buffers with pattern */
827         ret = spi_test_fill_pattern(spi, test);
828         if (ret)
829                 return ret;
830
831         /* and execute */
832         if (test->execute_msg)
833                 ret = test->execute_msg(spi, test, tx, rx);
834         else
835                 ret = spi_test_execute_msg(spi, test, tx, rx);
836
837         /* handle result */
838         if (ret == test->expected_return)
839                 return 0;
840
841         dev_err(&spi->dev,
842                 "test failed - test returned %i, but we expect %i\n",
843                 ret, test->expected_return);
844
845         if (ret)
846                 return ret;
847
848         /* if it is 0, as we expected something else,
849          * then return something special
850          */
851         return -EFAULT;
852 }
853
854 static int spi_test_run_iter(struct spi_device *spi,
855                              const struct spi_test *testtemplate,
856                              void *tx, void *rx,
857                              size_t len,
858                              size_t tx_off,
859                              size_t rx_off
860         )
861 {
862         struct spi_test test;
863         int i, tx_count, rx_count;
864
865         /* copy the test template to test */
866         memcpy(&test, testtemplate, sizeof(test));
867
868         /* if iterate_transfer_mask is not set,
869          * then set it to first transfer only
870          */
871         if (!(test.iterate_transfer_mask & (BIT(test.transfer_count) - 1)))
872                 test.iterate_transfer_mask = 1;
873
874         /* count number of transfers with tx/rx_buf != NULL */
875         rx_count = tx_count = 0;
876         for (i = 0; i < test.transfer_count; i++) {
877                 if (test.transfers[i].tx_buf)
878                         tx_count++;
879                 if (test.transfers[i].rx_buf)
880                         rx_count++;
881         }
882
883         /* in some iteration cases warn and exit early,
884          * as there is nothing to do, that has not been tested already...
885          */
886         if (tx_off && (!tx_count)) {
887                 dev_warn_once(&spi->dev,
888                               "%s: iterate_tx_off configured with tx_buf==NULL - ignoring\n",
889                               test.description);
890                 return 0;
891         }
892         if (rx_off && (!rx_count)) {
893                 dev_warn_once(&spi->dev,
894                               "%s: iterate_rx_off configured with rx_buf==NULL - ignoring\n",
895                               test.description);
896                 return 0;
897         }
898
899         /* write out info */
900         if (!(len || tx_off || rx_off)) {
901                 dev_info(&spi->dev, "Running test %s\n", test.description);
902         } else {
903                 dev_info(&spi->dev,
904                          "  with iteration values: len = %zu, tx_off = %zu, rx_off = %zu\n",
905                          len, tx_off, rx_off);
906         }
907
908         /* update in the values from iteration values */
909         for (i = 0; i < test.transfer_count; i++) {
910                 /* only when bit in transfer mask is set */
911                 if (!(test.iterate_transfer_mask & BIT(i)))
912                         continue;
913                 test.transfers[i].len = len;
914                 if (test.transfers[i].tx_buf)
915                         test.transfers[i].tx_buf += tx_off;
916                 if (test.transfers[i].rx_buf)
917                         test.transfers[i].rx_buf += rx_off;
918         }
919
920         /* and execute */
921         return _spi_test_run_iter(spi, &test, tx, rx);
922 }
923
924 /**
925  * spi_test_execute_msg - default implementation to run a test
926  *
927  * @spi: @spi_device on which to run the @spi_message
928  * @test: the test to execute, which already contains @msg
929  * @tx:   the tx buffer allocated for the test sequence
930  * @rx:   the rx buffer allocated for the test sequence
931  *
932  * Returns: error code of spi_sync as well as basic error checking
933  */
934 int spi_test_execute_msg(struct spi_device *spi, struct spi_test *test,
935                          void *tx, void *rx)
936 {
937         struct spi_message *msg = &test->msg;
938         int ret = 0;
939         int i;
940
941         /* only if we do not simulate */
942         if (!simulate_only) {
943                 ktime_t start;
944
945                 /* dump the complete message before and after the transfer */
946                 if (dump_messages == 3)
947                         spi_test_dump_message(spi, msg, true);
948
949                 start = ktime_get();
950                 /* run spi message */
951                 ret = spi_sync(spi, msg);
952                 test->elapsed_time = ktime_to_ns(ktime_sub(ktime_get(), start));
953                 if (ret == -ETIMEDOUT) {
954                         dev_info(&spi->dev,
955                                  "spi-message timed out - rerunning...\n");
956                         /* rerun after a few explicit schedules */
957                         for (i = 0; i < 16; i++)
958                                 schedule();
959                         ret = spi_sync(spi, msg);
960                 }
961                 if (ret) {
962                         dev_err(&spi->dev,
963                                 "Failed to execute spi_message: %i\n",
964                                 ret);
965                         goto exit;
966                 }
967
968                 /* do some extra error checks */
969                 if (msg->frame_length != msg->actual_length) {
970                         dev_err(&spi->dev,
971                                 "actual length differs from expected\n");
972                         ret = -EIO;
973                         goto exit;
974                 }
975
976                 /* run rx-buffer tests */
977                 ret = spi_test_check_loopback_result(spi, msg, tx, rx);
978                 if (ret)
979                         goto exit;
980
981                 ret = spi_test_check_elapsed_time(spi, test);
982         }
983
984         /* if requested or on error dump message (including data) */
985 exit:
986         if (dump_messages || ret)
987                 spi_test_dump_message(spi, msg,
988                                       (dump_messages >= 2) || (ret));
989
990         return ret;
991 }
992 EXPORT_SYMBOL_GPL(spi_test_execute_msg);
993
994 /**
995  * spi_test_run_test - run an individual spi_test
996  *                     including all the relevant iterations on:
997  *                     length and buffer alignment
998  *
999  * @spi:  the spi_device to send the messages to
1000  * @test: the test which we need to execute
1001  * @tx:   the tx buffer allocated for the test sequence
1002  * @rx:   the rx buffer allocated for the test sequence
1003  *
1004  * Returns: status code of spi_sync or other failures
1005  */
1006
1007 int spi_test_run_test(struct spi_device *spi, const struct spi_test *test,
1008                       void *tx, void *rx)
1009 {
1010         int idx_len;
1011         size_t len;
1012         size_t tx_align, rx_align;
1013         int ret;
1014
1015         /* test for transfer limits */
1016         if (test->transfer_count >= SPI_TEST_MAX_TRANSFERS) {
1017                 dev_err(&spi->dev,
1018                         "%s: Exceeded max number of transfers with %i\n",
1019                         test->description, test->transfer_count);
1020                 return -E2BIG;
1021         }
1022
1023         /* setting up some values in spi_message
1024          * based on some settings in spi_master
1025          * some of this can also get done in the run() method
1026          */
1027
1028         /* iterate over all the iterable values using macros
1029          * (to make it a bit more readable...
1030          */
1031 #define FOR_EACH_ALIGNMENT(var)                                         \
1032         for (var = 0;                                                   \
1033             var < (test->iterate_##var ?                                \
1034                         (spi->master->dma_alignment ?                   \
1035                          spi->master->dma_alignment :                   \
1036                          test->iterate_##var) :                         \
1037                         1);                                             \
1038             var++)
1039
1040         for (idx_len = 0; idx_len < SPI_TEST_MAX_ITERATE &&
1041              (len = test->iterate_len[idx_len]) != -1; idx_len++) {
1042                 if ((run_only_iter_len > -1) && len != run_only_iter_len)
1043                         continue;
1044                 FOR_EACH_ALIGNMENT(tx_align) {
1045                         FOR_EACH_ALIGNMENT(rx_align) {
1046                                 /* and run the iteration */
1047                                 ret = spi_test_run_iter(spi, test,
1048                                                         tx, rx,
1049                                                         len,
1050                                                         tx_align,
1051                                                         rx_align);
1052                                 if (ret)
1053                                         return ret;
1054                         }
1055                 }
1056         }
1057
1058         return 0;
1059 }
1060 EXPORT_SYMBOL_GPL(spi_test_run_test);
1061
1062 /**
1063  * spi_test_run_tests - run an array of spi_messages tests
1064  * @spi: the spi device on which to run the tests
1065  * @tests: NULL-terminated array of @spi_test
1066  *
1067  * Returns: status errors as per @spi_test_run_test()
1068  */
1069
1070 int spi_test_run_tests(struct spi_device *spi,
1071                        struct spi_test *tests)
1072 {
1073         char *rx = NULL, *tx = NULL;
1074         int ret = 0, count = 0;
1075         struct spi_test *test;
1076
1077         /* allocate rx/tx buffers of 128kB size without devm
1078          * in the hope that is on a page boundary
1079          */
1080         if (use_vmalloc)
1081                 rx = vmalloc(SPI_TEST_MAX_SIZE_PLUS);
1082         else
1083                 rx = kzalloc(SPI_TEST_MAX_SIZE_PLUS, GFP_KERNEL);
1084         if (!rx)
1085                 return -ENOMEM;
1086
1087
1088         if (use_vmalloc)
1089                 tx = vmalloc(SPI_TEST_MAX_SIZE_PLUS);
1090         else
1091                 tx = kzalloc(SPI_TEST_MAX_SIZE_PLUS, GFP_KERNEL);
1092         if (!tx) {
1093                 ret = -ENOMEM;
1094                 goto err_tx;
1095         }
1096
1097         /* now run the individual tests in the table */
1098         for (test = tests, count = 0; test->description[0];
1099              test++, count++) {
1100                 /* only run test if requested */
1101                 if ((run_only_test > -1) && (count != run_only_test))
1102                         continue;
1103                 /* run custom implementation */
1104                 if (test->run_test)
1105                         ret = test->run_test(spi, test, tx, rx);
1106                 else
1107                         ret = spi_test_run_test(spi, test, tx, rx);
1108                 if (ret)
1109                         goto out;
1110                 /* add some delays so that we can easily
1111                  * detect the individual tests when using a logic analyzer
1112                  * we also add scheduling to avoid potential spi_timeouts...
1113                  */
1114                 if (delay_ms)
1115                         mdelay(delay_ms);
1116                 schedule();
1117         }
1118
1119 out:
1120         kvfree(tx);
1121 err_tx:
1122         kvfree(rx);
1123         return ret;
1124 }
1125 EXPORT_SYMBOL_GPL(spi_test_run_tests);