]> git.karo-electronics.de Git - karo-tx-linux.git/blob - sound/soc/sh/rcar/ssi.c
xen/hvc: constify hv_ops structures
[karo-tx-linux.git] / sound / soc / sh / rcar / ssi.c
1 /*
2  * Renesas R-Car SSIU/SSI support
3  *
4  * Copyright (C) 2013 Renesas Solutions Corp.
5  * Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
6  *
7  * Based on fsi.c
8  * Kuninori Morimoto <morimoto.kuninori@renesas.com>
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License version 2 as
12  * published by the Free Software Foundation.
13  */
14 #include <linux/delay.h>
15 #include "rsnd.h"
16 #define RSND_SSI_NAME_SIZE 16
17
18 /*
19  * SSICR
20  */
21 #define FORCE           (1 << 31)       /* Fixed */
22 #define DMEN            (1 << 28)       /* DMA Enable */
23 #define UIEN            (1 << 27)       /* Underflow Interrupt Enable */
24 #define OIEN            (1 << 26)       /* Overflow Interrupt Enable */
25 #define IIEN            (1 << 25)       /* Idle Mode Interrupt Enable */
26 #define DIEN            (1 << 24)       /* Data Interrupt Enable */
27 #define CHNL_4          (1 << 22)       /* Channels */
28 #define CHNL_6          (2 << 22)       /* Channels */
29 #define CHNL_8          (3 << 22)       /* Channels */
30 #define DWL_8           (0 << 19)       /* Data Word Length */
31 #define DWL_16          (1 << 19)       /* Data Word Length */
32 #define DWL_18          (2 << 19)       /* Data Word Length */
33 #define DWL_20          (3 << 19)       /* Data Word Length */
34 #define DWL_22          (4 << 19)       /* Data Word Length */
35 #define DWL_24          (5 << 19)       /* Data Word Length */
36 #define DWL_32          (6 << 19)       /* Data Word Length */
37
38 #define SWL_32          (3 << 16)       /* R/W System Word Length */
39 #define SCKD            (1 << 15)       /* Serial Bit Clock Direction */
40 #define SWSD            (1 << 14)       /* Serial WS Direction */
41 #define SCKP            (1 << 13)       /* Serial Bit Clock Polarity */
42 #define SWSP            (1 << 12)       /* Serial WS Polarity */
43 #define SDTA            (1 << 10)       /* Serial Data Alignment */
44 #define PDTA            (1 <<  9)       /* Parallel Data Alignment */
45 #define DEL             (1 <<  8)       /* Serial Data Delay */
46 #define CKDV(v)         (v <<  4)       /* Serial Clock Division Ratio */
47 #define TRMD            (1 <<  1)       /* Transmit/Receive Mode Select */
48 #define EN              (1 <<  0)       /* SSI Module Enable */
49
50 /*
51  * SSISR
52  */
53 #define UIRQ            (1 << 27)       /* Underflow Error Interrupt Status */
54 #define OIRQ            (1 << 26)       /* Overflow Error Interrupt Status */
55 #define IIRQ            (1 << 25)       /* Idle Mode Interrupt Status */
56 #define DIRQ            (1 << 24)       /* Data Interrupt Status Flag */
57
58 /*
59  * SSIWSR
60  */
61 #define CONT            (1 << 8)        /* WS Continue Function */
62 #define WS_MODE         (1 << 0)        /* WS Mode */
63
64 #define SSI_NAME "ssi"
65
66 struct rsnd_ssi {
67         struct rsnd_ssi *parent;
68         struct rsnd_mod mod;
69         struct rsnd_mod *dma;
70
71         u32 flags;
72         u32 cr_own;
73         u32 cr_clk;
74         u32 cr_mode;
75         u32 wsr;
76         int chan;
77         int rate;
78         int err;
79         int irq;
80         unsigned int usrcnt;
81 };
82
83 /* flags */
84 #define RSND_SSI_CLK_PIN_SHARE          (1 << 0)
85 #define RSND_SSI_NO_BUSIF               (1 << 1) /* SSI+DMA without BUSIF */
86
87 #define for_each_rsnd_ssi(pos, priv, i)                                 \
88         for (i = 0;                                                     \
89              (i < rsnd_ssi_nr(priv)) &&                                 \
90                 ((pos) = ((struct rsnd_ssi *)(priv)->ssi + i));         \
91              i++)
92
93 #define rsnd_ssi_get(priv, id) ((struct rsnd_ssi *)(priv->ssi) + id)
94 #define rsnd_ssi_to_dma(mod) ((ssi)->dma)
95 #define rsnd_ssi_nr(priv) ((priv)->ssi_nr)
96 #define rsnd_mod_to_ssi(_mod) container_of((_mod), struct rsnd_ssi, mod)
97 #define rsnd_ssi_mode_flags(p) ((p)->flags)
98 #define rsnd_ssi_is_parent(ssi, io) ((ssi) == rsnd_io_to_mod_ssip(io))
99 #define rsnd_ssi_is_multi_slave(ssi, io) ((mod) != rsnd_io_to_mod_ssi(io))
100
101 int rsnd_ssi_use_busif(struct rsnd_dai_stream *io)
102 {
103         struct rsnd_mod *mod = rsnd_io_to_mod_ssi(io);
104         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
105         int use_busif = 0;
106
107         if (!rsnd_ssi_is_dma_mode(mod))
108                 return 0;
109
110         if (!(rsnd_ssi_mode_flags(ssi) & RSND_SSI_NO_BUSIF))
111                 use_busif = 1;
112         if (rsnd_io_to_mod_src(io))
113                 use_busif = 1;
114
115         return use_busif;
116 }
117
118 static void rsnd_ssi_status_clear(struct rsnd_mod *mod)
119 {
120         rsnd_mod_write(mod, SSISR, 0);
121 }
122
123 static u32 rsnd_ssi_status_get(struct rsnd_mod *mod)
124 {
125         return rsnd_mod_read(mod, SSISR);
126 }
127
128 static void rsnd_ssi_status_check(struct rsnd_mod *mod,
129                                   u32 bit)
130 {
131         struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
132         struct device *dev = rsnd_priv_to_dev(priv);
133         u32 status;
134         int i;
135
136         for (i = 0; i < 1024; i++) {
137                 status = rsnd_ssi_status_get(mod);
138                 if (status & bit)
139                         return;
140
141                 udelay(50);
142         }
143
144         dev_warn(dev, "status check failed\n");
145 }
146
147 static int rsnd_ssi_irq_enable(struct rsnd_mod *ssi_mod)
148 {
149         struct rsnd_priv *priv = rsnd_mod_to_priv(ssi_mod);
150
151         if (rsnd_is_gen1(priv))
152                 return 0;
153
154         /* enable SSI interrupt if Gen2 */
155         rsnd_mod_write(ssi_mod, SSI_INT_ENABLE,
156                        rsnd_ssi_is_dma_mode(ssi_mod) ?
157                        0x0e000000 : 0x0f000000);
158
159         return 0;
160 }
161
162 static int rsnd_ssi_irq_disable(struct rsnd_mod *ssi_mod)
163 {
164         struct rsnd_priv *priv = rsnd_mod_to_priv(ssi_mod);
165
166         if (rsnd_is_gen1(priv))
167                 return 0;
168
169         /* disable SSI interrupt if Gen2 */
170         rsnd_mod_write(ssi_mod, SSI_INT_ENABLE, 0x00000000);
171
172         return 0;
173 }
174
175 u32 rsnd_ssi_multi_slaves(struct rsnd_dai_stream *io)
176 {
177         struct rsnd_mod *mod;
178         struct snd_pcm_runtime *runtime = rsnd_io_to_runtime(io);
179         struct rsnd_priv *priv = rsnd_io_to_priv(io);
180         struct device *dev = rsnd_priv_to_dev(priv);
181         enum rsnd_mod_type types[] = {
182                 RSND_MOD_SSIM1,
183                 RSND_MOD_SSIM2,
184                 RSND_MOD_SSIM3,
185         };
186         int i, mask;
187
188         switch (runtime->channels) {
189         case 2: /* Multi channel is not needed for Stereo */
190                 return 0;
191         case 6:
192                 break;
193         default:
194                 dev_err(dev, "unsupported channel\n");
195                 return 0;
196         }
197
198         mask = 0;
199         for (i = 0; i < ARRAY_SIZE(types); i++) {
200                 mod = rsnd_io_to_mod(io, types[i]);
201                 if (!mod)
202                         continue;
203
204                 mask |= 1 << rsnd_mod_id(mod);
205         }
206
207         return mask;
208 }
209
210 static int rsnd_ssi_master_clk_start(struct rsnd_ssi *ssi,
211                                      struct rsnd_dai_stream *io)
212 {
213         struct rsnd_priv *priv = rsnd_io_to_priv(io);
214         struct snd_pcm_runtime *runtime = rsnd_io_to_runtime(io);
215         struct device *dev = rsnd_priv_to_dev(priv);
216         struct rsnd_dai *rdai = rsnd_io_to_rdai(io);
217         struct rsnd_mod *mod = rsnd_mod_get(ssi);
218         struct rsnd_mod *ssi_parent_mod = rsnd_io_to_mod_ssip(io);
219         int slots = rsnd_get_slot_width(io);
220         int j, ret;
221         int ssi_clk_mul_table[] = {
222                 1, 2, 4, 8, 16, 6, 12,
223         };
224         unsigned int main_rate;
225         unsigned int rate = rsnd_src_get_ssi_rate(priv, io, runtime);
226
227         if (!rsnd_rdai_is_clk_master(rdai))
228                 return 0;
229
230         if (ssi_parent_mod && !rsnd_ssi_is_parent(mod, io))
231                 return 0;
232
233         if (rsnd_ssi_is_multi_slave(mod, io))
234                 return 0;
235
236         if (ssi->usrcnt > 1) {
237                 if (ssi->rate != rate) {
238                         dev_err(dev, "SSI parent/child should use same rate\n");
239                         return -EINVAL;
240                 }
241
242                 return 0;
243         }
244
245         /*
246          * Find best clock, and try to start ADG
247          */
248         for (j = 0; j < ARRAY_SIZE(ssi_clk_mul_table); j++) {
249
250                 /*
251                  * this driver is assuming that
252                  * system word is 32bit x slots
253                  * see rsnd_ssi_init()
254                  */
255                 main_rate = rate * 32 * slots * ssi_clk_mul_table[j];
256
257                 ret = rsnd_adg_ssi_clk_try_start(mod, main_rate);
258                 if (0 == ret) {
259                         ssi->cr_clk     = FORCE | SWL_32 |
260                                 SCKD | SWSD | CKDV(j);
261                         ssi->wsr = CONT;
262
263                         ssi->rate = rate;
264
265                         dev_dbg(dev, "%s[%d] outputs %u Hz\n",
266                                 rsnd_mod_name(mod),
267                                 rsnd_mod_id(mod), rate);
268
269                         return 0;
270                 }
271         }
272
273         dev_err(dev, "unsupported clock rate\n");
274         return -EIO;
275 }
276
277 static void rsnd_ssi_master_clk_stop(struct rsnd_ssi *ssi,
278                                      struct rsnd_dai_stream *io)
279 {
280         struct rsnd_dai *rdai = rsnd_io_to_rdai(io);
281         struct rsnd_mod *mod = rsnd_mod_get(ssi);
282         struct rsnd_mod *ssi_parent_mod = rsnd_io_to_mod_ssip(io);
283
284         if (!rsnd_rdai_is_clk_master(rdai))
285                 return;
286
287         if (ssi_parent_mod && !rsnd_ssi_is_parent(mod, io))
288                 return;
289
290         if (ssi->usrcnt > 1)
291                 return;
292
293         ssi->cr_clk     = 0;
294         ssi->rate       = 0;
295
296         rsnd_adg_ssi_clk_stop(mod);
297 }
298
299 static int rsnd_ssi_config_init(struct rsnd_ssi *ssi,
300                                 struct rsnd_dai_stream *io)
301 {
302         struct rsnd_dai *rdai = rsnd_io_to_rdai(io);
303         struct snd_pcm_runtime *runtime = rsnd_io_to_runtime(io);
304         u32 cr_own;
305         u32 cr_mode;
306         u32 wsr;
307         int is_tdm;
308
309         is_tdm = (rsnd_get_slot_width(io) >= 6) ? 1 : 0;
310
311         /*
312          * always use 32bit system word.
313          * see also rsnd_ssi_master_clk_enable()
314          */
315         cr_own = FORCE | SWL_32 | PDTA;
316
317         if (rdai->bit_clk_inv)
318                 cr_own |= SCKP;
319         if (rdai->frm_clk_inv ^ is_tdm)
320                 cr_own |= SWSP;
321         if (rdai->data_alignment)
322                 cr_own |= SDTA;
323         if (rdai->sys_delay)
324                 cr_own |= DEL;
325         if (rsnd_io_is_play(io))
326                 cr_own |= TRMD;
327
328         switch (runtime->sample_bits) {
329         case 16:
330                 cr_own |= DWL_16;
331                 break;
332         case 32:
333                 cr_own |= DWL_24;
334                 break;
335         default:
336                 return -EINVAL;
337         }
338
339         if (rsnd_ssi_is_dma_mode(rsnd_mod_get(ssi))) {
340                 cr_mode = UIEN | OIEN | /* over/under run */
341                           DMEN;         /* DMA : enable DMA */
342         } else {
343                 cr_mode = DIEN;         /* PIO : enable Data interrupt */
344         }
345
346         /*
347          * TDM Extend Mode
348          * see
349          *      rsnd_ssiu_init_gen2()
350          */
351         wsr = ssi->wsr;
352         if (is_tdm) {
353                 wsr     |= WS_MODE;
354                 cr_own  |= CHNL_8;
355         }
356
357         ssi->cr_own     = cr_own;
358         ssi->cr_mode    = cr_mode;
359         ssi->wsr        = wsr;
360
361         return 0;
362 }
363
364 /*
365  *      SSI mod common functions
366  */
367 static int rsnd_ssi_init(struct rsnd_mod *mod,
368                          struct rsnd_dai_stream *io,
369                          struct rsnd_priv *priv)
370 {
371         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
372         int ret;
373
374         ssi->usrcnt++;
375
376         rsnd_mod_power_on(mod);
377
378         ret = rsnd_ssi_master_clk_start(ssi, io);
379         if (ret < 0)
380                 return ret;
381
382         if (rsnd_ssi_is_parent(mod, io))
383                 return 0;
384
385         ret = rsnd_ssi_config_init(ssi, io);
386         if (ret < 0)
387                 return ret;
388
389         ssi->err        = -1; /* ignore 1st error */
390
391         /* clear error status */
392         rsnd_ssi_status_clear(mod);
393
394         rsnd_ssi_irq_enable(mod);
395
396         return 0;
397 }
398
399 static int rsnd_ssi_quit(struct rsnd_mod *mod,
400                          struct rsnd_dai_stream *io,
401                          struct rsnd_priv *priv)
402 {
403         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
404         struct device *dev = rsnd_priv_to_dev(priv);
405
406         if (!ssi->usrcnt) {
407                 dev_err(dev, "%s[%d] usrcnt error\n",
408                         rsnd_mod_name(mod), rsnd_mod_id(mod));
409                 return -EIO;
410         }
411
412         if (!rsnd_ssi_is_parent(mod, io)) {
413                 if (ssi->err > 0)
414                         dev_warn(dev, "%s[%d] under/over flow err = %d\n",
415                                  rsnd_mod_name(mod), rsnd_mod_id(mod),
416                                  ssi->err);
417
418                 ssi->cr_own     = 0;
419                 ssi->err        = 0;
420
421                 rsnd_ssi_irq_disable(mod);
422         }
423
424         rsnd_ssi_master_clk_stop(ssi, io);
425
426         rsnd_mod_power_off(mod);
427
428         ssi->usrcnt--;
429
430         return 0;
431 }
432
433 static int rsnd_ssi_hw_params(struct rsnd_mod *mod,
434                               struct rsnd_dai_stream *io,
435                               struct snd_pcm_substream *substream,
436                               struct snd_pcm_hw_params *params)
437 {
438         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
439         int chan = params_channels(params);
440
441         /*
442          * Already working.
443          * It will happen if SSI has parent/child connection.
444          */
445         if (ssi->usrcnt > 1) {
446                 /*
447                  * it is error if child <-> parent SSI uses
448                  * different channels.
449                  */
450                 if (ssi->chan != chan)
451                         return -EIO;
452         }
453
454         ssi->chan = chan;
455
456         return 0;
457 }
458
459 static u32 rsnd_ssi_record_error(struct rsnd_ssi *ssi)
460 {
461         struct rsnd_mod *mod = rsnd_mod_get(ssi);
462         u32 status = rsnd_ssi_status_get(mod);
463
464         /* under/over flow error */
465         if (status & (UIRQ | OIRQ))
466                 ssi->err++;
467
468         return status;
469 }
470
471 static int __rsnd_ssi_start(struct rsnd_mod *mod,
472                             struct rsnd_dai_stream *io,
473                             struct rsnd_priv *priv)
474 {
475         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
476         u32 cr;
477
478         cr  =   ssi->cr_own     |
479                 ssi->cr_clk     |
480                 ssi->cr_mode;
481
482         /*
483          * EN will be set via SSIU :: SSI_CONTROL
484          * if Multi channel mode
485          */
486         if (!rsnd_ssi_multi_slaves(io))
487                 cr |= EN;
488
489         rsnd_mod_write(mod, SSICR, cr);
490         rsnd_mod_write(mod, SSIWSR, ssi->wsr);
491
492         return 0;
493 }
494
495 static int rsnd_ssi_start(struct rsnd_mod *mod,
496                           struct rsnd_dai_stream *io,
497                           struct rsnd_priv *priv)
498 {
499         /*
500          * no limit to start
501          * see also
502          *      rsnd_ssi_stop
503          *      rsnd_ssi_interrupt
504          */
505         return __rsnd_ssi_start(mod, io, priv);
506 }
507
508 static int __rsnd_ssi_stop(struct rsnd_mod *mod,
509                            struct rsnd_dai_stream *io,
510                            struct rsnd_priv *priv)
511 {
512         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
513         u32 cr;
514
515         /*
516          * disable all IRQ,
517          * and, wait all data was sent
518          */
519         cr  =   ssi->cr_own     |
520                 ssi->cr_clk;
521
522         rsnd_mod_write(mod, SSICR, cr | EN);
523         rsnd_ssi_status_check(mod, DIRQ);
524
525         /*
526          * disable SSI,
527          * and, wait idle state
528          */
529         rsnd_mod_write(mod, SSICR, cr); /* disabled all */
530         rsnd_ssi_status_check(mod, IIRQ);
531
532         return 0;
533 }
534
535 static int rsnd_ssi_stop(struct rsnd_mod *mod,
536                          struct rsnd_dai_stream *io,
537                          struct rsnd_priv *priv)
538 {
539         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
540
541         /*
542          * don't stop if not last user
543          * see also
544          *      rsnd_ssi_start
545          *      rsnd_ssi_interrupt
546          */
547         if (ssi->usrcnt > 1)
548                 return 0;
549
550         return __rsnd_ssi_stop(mod, io, priv);
551 }
552
553 static void __rsnd_ssi_interrupt(struct rsnd_mod *mod,
554                                  struct rsnd_dai_stream *io)
555 {
556         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
557         struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
558         struct device *dev = rsnd_priv_to_dev(priv);
559         int is_dma = rsnd_ssi_is_dma_mode(mod);
560         u32 status;
561         bool elapsed = false;
562
563         spin_lock(&priv->lock);
564
565         /* ignore all cases if not working */
566         if (!rsnd_io_is_working(io))
567                 goto rsnd_ssi_interrupt_out;
568
569         status = rsnd_ssi_record_error(ssi);
570
571         /* PIO only */
572         if (!is_dma && (status & DIRQ)) {
573                 struct snd_pcm_runtime *runtime = rsnd_io_to_runtime(io);
574                 u32 *buf = (u32 *)(runtime->dma_area +
575                                    rsnd_dai_pointer_offset(io, 0));
576
577                 /*
578                  * 8/16/32 data can be assesse to TDR/RDR register
579                  * directly as 32bit data
580                  * see rsnd_ssi_init()
581                  */
582                 if (rsnd_io_is_play(io))
583                         rsnd_mod_write(mod, SSITDR, *buf);
584                 else
585                         *buf = rsnd_mod_read(mod, SSIRDR);
586
587                 elapsed = rsnd_dai_pointer_update(io, sizeof(*buf));
588         }
589
590         /* DMA only */
591         if (is_dma && (status & (UIRQ | OIRQ))) {
592                 /*
593                  * restart SSI
594                  */
595                 dev_dbg(dev, "%s[%d] restart\n",
596                         rsnd_mod_name(mod), rsnd_mod_id(mod));
597
598                 __rsnd_ssi_stop(mod, io, priv);
599                 __rsnd_ssi_start(mod, io, priv);
600         }
601
602         if (ssi->err > 1024) {
603                 rsnd_ssi_irq_disable(mod);
604
605                 dev_warn(dev, "no more %s[%d] restart\n",
606                          rsnd_mod_name(mod), rsnd_mod_id(mod));
607         }
608
609         rsnd_ssi_status_clear(mod);
610 rsnd_ssi_interrupt_out:
611         spin_unlock(&priv->lock);
612
613         if (elapsed)
614                 rsnd_dai_period_elapsed(io);
615 }
616
617 static irqreturn_t rsnd_ssi_interrupt(int irq, void *data)
618 {
619         struct rsnd_mod *mod = data;
620
621         rsnd_mod_interrupt(mod, __rsnd_ssi_interrupt);
622
623         return IRQ_HANDLED;
624 }
625
626 /*
627  *              SSI PIO
628  */
629 static void rsnd_ssi_parent_attach(struct rsnd_mod *mod,
630                                    struct rsnd_dai_stream *io,
631                                    struct rsnd_priv *priv)
632 {
633         if (!__rsnd_ssi_is_pin_sharing(mod))
634                 return;
635
636         switch (rsnd_mod_id(mod)) {
637         case 1:
638         case 2:
639                 rsnd_dai_connect(rsnd_ssi_mod_get(priv, 0), io, RSND_MOD_SSIP);
640                 break;
641         case 4:
642                 rsnd_dai_connect(rsnd_ssi_mod_get(priv, 3), io, RSND_MOD_SSIP);
643                 break;
644         case 8:
645                 rsnd_dai_connect(rsnd_ssi_mod_get(priv, 7), io, RSND_MOD_SSIP);
646                 break;
647         }
648 }
649
650 static int rsnd_ssi_common_probe(struct rsnd_mod *mod,
651                                  struct rsnd_dai_stream *io,
652                                  struct rsnd_priv *priv)
653 {
654         struct device *dev = rsnd_priv_to_dev(priv);
655         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
656         int ret;
657
658         /*
659          * SSIP/SSIU/IRQ are not needed on
660          * SSI Multi slaves
661          */
662         if (rsnd_ssi_is_multi_slave(mod, io))
663                 return 0;
664
665         rsnd_ssi_parent_attach(mod, io, priv);
666
667         ret = rsnd_ssiu_attach(io, mod);
668         if (ret < 0)
669                 return ret;
670
671         ret = devm_request_irq(dev, ssi->irq,
672                                rsnd_ssi_interrupt,
673                                IRQF_SHARED,
674                                dev_name(dev), mod);
675
676         return ret;
677 }
678
679 static struct rsnd_mod_ops rsnd_ssi_pio_ops = {
680         .name   = SSI_NAME,
681         .probe  = rsnd_ssi_common_probe,
682         .init   = rsnd_ssi_init,
683         .quit   = rsnd_ssi_quit,
684         .start  = rsnd_ssi_start,
685         .stop   = rsnd_ssi_stop,
686         .hw_params = rsnd_ssi_hw_params,
687 };
688
689 static int rsnd_ssi_dma_probe(struct rsnd_mod *mod,
690                               struct rsnd_dai_stream *io,
691                               struct rsnd_priv *priv)
692 {
693         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
694         int dma_id = 0; /* not needed */
695         int ret;
696
697         /*
698          * SSIP/SSIU/IRQ/DMA are not needed on
699          * SSI Multi slaves
700          */
701         if (rsnd_ssi_is_multi_slave(mod, io))
702                 return 0;
703
704         ret = rsnd_ssi_common_probe(mod, io, priv);
705         if (ret)
706                 return ret;
707
708         ssi->dma = rsnd_dma_attach(io, mod, dma_id);
709         if (IS_ERR(ssi->dma))
710                 return PTR_ERR(ssi->dma);
711
712         return ret;
713 }
714
715 static int rsnd_ssi_dma_remove(struct rsnd_mod *mod,
716                                struct rsnd_dai_stream *io,
717                                struct rsnd_priv *priv)
718 {
719         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
720         struct device *dev = rsnd_priv_to_dev(priv);
721         int irq = ssi->irq;
722
723         /* PIO will request IRQ again */
724         devm_free_irq(dev, irq, mod);
725
726         return 0;
727 }
728
729 static int rsnd_ssi_fallback(struct rsnd_mod *mod,
730                              struct rsnd_dai_stream *io,
731                              struct rsnd_priv *priv)
732 {
733         struct device *dev = rsnd_priv_to_dev(priv);
734
735         /*
736          * fallback to PIO
737          *
738          * SSI .probe might be called again.
739          * see
740          *      rsnd_rdai_continuance_probe()
741          */
742         mod->ops = &rsnd_ssi_pio_ops;
743
744         dev_info(dev, "%s[%d] fallback to PIO mode\n",
745                  rsnd_mod_name(mod), rsnd_mod_id(mod));
746
747         return 0;
748 }
749
750 static struct dma_chan *rsnd_ssi_dma_req(struct rsnd_dai_stream *io,
751                                          struct rsnd_mod *mod)
752 {
753         struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
754         int is_play = rsnd_io_is_play(io);
755         char *name;
756
757         if (rsnd_ssi_use_busif(io))
758                 name = is_play ? "rxu" : "txu";
759         else
760                 name = is_play ? "rx" : "tx";
761
762         return rsnd_dma_request_channel(rsnd_ssi_of_node(priv),
763                                         mod, name);
764 }
765
766 static struct rsnd_mod_ops rsnd_ssi_dma_ops = {
767         .name   = SSI_NAME,
768         .dma_req = rsnd_ssi_dma_req,
769         .probe  = rsnd_ssi_dma_probe,
770         .remove = rsnd_ssi_dma_remove,
771         .init   = rsnd_ssi_init,
772         .quit   = rsnd_ssi_quit,
773         .start  = rsnd_ssi_start,
774         .stop   = rsnd_ssi_stop,
775         .fallback = rsnd_ssi_fallback,
776         .hw_params = rsnd_ssi_hw_params,
777 };
778
779 int rsnd_ssi_is_dma_mode(struct rsnd_mod *mod)
780 {
781         return mod->ops == &rsnd_ssi_dma_ops;
782 }
783
784
785 /*
786  *              Non SSI
787  */
788 static struct rsnd_mod_ops rsnd_ssi_non_ops = {
789         .name   = SSI_NAME,
790 };
791
792 /*
793  *              ssi mod function
794  */
795 static void rsnd_ssi_connect(struct rsnd_mod *mod,
796                              struct rsnd_dai_stream *io)
797 {
798         struct rsnd_dai *rdai = rsnd_io_to_rdai(io);
799         enum rsnd_mod_type types[] = {
800                 RSND_MOD_SSI,
801                 RSND_MOD_SSIM1,
802                 RSND_MOD_SSIM2,
803                 RSND_MOD_SSIM3,
804         };
805         enum rsnd_mod_type type;
806         int i;
807
808         /* try SSI -> SSIM1 -> SSIM2 -> SSIM3 */
809         for (i = 0; i < ARRAY_SIZE(types); i++) {
810                 type = types[i];
811                 if (!rsnd_io_to_mod(io, type)) {
812                         rsnd_dai_connect(mod, io, type);
813                         rsnd_set_slot(rdai, 2 * (i + 1), (i + 1));
814                         return;
815                 }
816         }
817 }
818
819 void rsnd_parse_connect_ssi(struct rsnd_dai *rdai,
820                             struct device_node *playback,
821                             struct device_node *capture)
822 {
823         struct rsnd_priv *priv = rsnd_rdai_to_priv(rdai);
824         struct device_node *node;
825         struct device_node *np;
826         struct rsnd_mod *mod;
827         int i;
828
829         node = rsnd_ssi_of_node(priv);
830         if (!node)
831                 return;
832
833         i = 0;
834         for_each_child_of_node(node, np) {
835                 mod = rsnd_ssi_mod_get(priv, i);
836                 if (np == playback)
837                         rsnd_ssi_connect(mod, &rdai->playback);
838                 if (np == capture)
839                         rsnd_ssi_connect(mod, &rdai->capture);
840                 i++;
841         }
842
843         of_node_put(node);
844 }
845
846 struct rsnd_mod *rsnd_ssi_mod_get(struct rsnd_priv *priv, int id)
847 {
848         if (WARN_ON(id < 0 || id >= rsnd_ssi_nr(priv)))
849                 id = 0;
850
851         return rsnd_mod_get(rsnd_ssi_get(priv, id));
852 }
853
854 int __rsnd_ssi_is_pin_sharing(struct rsnd_mod *mod)
855 {
856         struct rsnd_ssi *ssi = rsnd_mod_to_ssi(mod);
857
858         return !!(rsnd_ssi_mode_flags(ssi) & RSND_SSI_CLK_PIN_SHARE);
859 }
860
861 int rsnd_ssi_probe(struct rsnd_priv *priv)
862 {
863         struct device_node *node;
864         struct device_node *np;
865         struct device *dev = rsnd_priv_to_dev(priv);
866         struct rsnd_mod_ops *ops;
867         struct clk *clk;
868         struct rsnd_ssi *ssi;
869         char name[RSND_SSI_NAME_SIZE];
870         int i, nr, ret;
871
872         node = rsnd_ssi_of_node(priv);
873         if (!node)
874                 return -EINVAL;
875
876         nr = of_get_child_count(node);
877         if (!nr) {
878                 ret = -EINVAL;
879                 goto rsnd_ssi_probe_done;
880         }
881
882         ssi     = devm_kzalloc(dev, sizeof(*ssi) * nr, GFP_KERNEL);
883         if (!ssi) {
884                 ret = -ENOMEM;
885                 goto rsnd_ssi_probe_done;
886         }
887
888         priv->ssi       = ssi;
889         priv->ssi_nr    = nr;
890
891         i = 0;
892         for_each_child_of_node(node, np) {
893                 ssi = rsnd_ssi_get(priv, i);
894
895                 snprintf(name, RSND_SSI_NAME_SIZE, "%s.%d",
896                          SSI_NAME, i);
897
898                 clk = devm_clk_get(dev, name);
899                 if (IS_ERR(clk)) {
900                         ret = PTR_ERR(clk);
901                         goto rsnd_ssi_probe_done;
902                 }
903
904                 if (of_get_property(np, "shared-pin", NULL))
905                         ssi->flags |= RSND_SSI_CLK_PIN_SHARE;
906
907                 if (of_get_property(np, "no-busif", NULL))
908                         ssi->flags |= RSND_SSI_NO_BUSIF;
909
910                 ssi->irq = irq_of_parse_and_map(np, 0);
911                 if (!ssi->irq) {
912                         ret = -EINVAL;
913                         goto rsnd_ssi_probe_done;
914                 }
915
916                 ops = &rsnd_ssi_non_ops;
917                 if (of_get_property(np, "pio-transfer", NULL))
918                         ops = &rsnd_ssi_pio_ops;
919                 else
920                         ops = &rsnd_ssi_dma_ops;
921
922                 ret = rsnd_mod_init(priv, rsnd_mod_get(ssi), ops, clk,
923                                     RSND_MOD_SSI, i);
924                 if (ret)
925                         goto rsnd_ssi_probe_done;
926
927                 i++;
928         }
929
930         ret = 0;
931
932 rsnd_ssi_probe_done:
933         of_node_put(node);
934
935         return ret;
936 }
937
938 void rsnd_ssi_remove(struct rsnd_priv *priv)
939 {
940         struct rsnd_ssi *ssi;
941         int i;
942
943         for_each_rsnd_ssi(ssi, priv, i) {
944                 rsnd_mod_quit(rsnd_mod_get(ssi));
945         }
946 }